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 | 2KB (2K x 8) | | | Program Memory Type | FLASH | | | EEPROM Size | 64 x 8 | | | RAM Size | 512 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-SSOP (0.209", 5.30mm Width) | | | Supplier Device Package | - | | | Purchase URL | https://www.e-xfl.com/product-detail/zilog/z8f021ahh020sc | | # Z8 Encore! XP<sup>®</sup> F082A Series Product Specification vii | 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 | | | Universal Asynchronous Receiver/Transmitter | 97 | | Architecture | | | Operation | 98 | | Data Format | 98 | | Transmitting Data using the Polled Method | | | Transmitting Data using the Interrupt-Driven Method | | | Receiving Data using the Polled Method | | | Receiving Data using the Interrupt-Driven Method | | | Clear To Send (CTS) Operation | | | MULTIPROCESSOR (9-bit) Mode | | | External Driver Enable | | | UART Interrupts | | | UART Baud Rate Generator | | | UART Control Register Definitions | | | UART Control 0 and Control 1 Registers | | | UART Status 0 Register | | | UART Status 1 Register | | | UART Transmit Data Register | | | UART Receive Data Register | | | UART Address Compare Register | | | UART Baud Rate High and Low Byte Registers | | | Infrared Encoder/Decoder | 117 | | Architecture | 117 | | Operation | 445 | | Transmitting IrDA Data | | | Receiving IrDA Data | | | Infrared Encoder/Decoder Control Register Definitions | | | Analog-to-Digital Converter | 121 | | Architecture | | | Operation | | | Data Format | | | = | · · · · | PS022825-0908 Table of Contents # Z8 Encore! XP® F082A Series **Product Specification** | Hardware Overflow | 123 | |--------------------------------------------------------------|---------| | Automatic Powerdown | | | Single-Shot Conversion | | | Continuous Conversion | | | Interrupts | | | Calibration and Compensation | | | ADC Compensation Details | | | Input Buffer Stage | | | ADC Control Register Definitions | | | ADC Control Register 0 | | | ADC Control/Status Register 1 | | | ADC Data High Byte Register | | | ADC Data Low Byte Register | | | Low Power Operational Amplifier | 134 | | Overview | 134 | | Operation | 134 | | Comparator | | | • | | | Operation | | | Comparator Control Register Definitions | 136 | | Temperature Sensor | 139 | | Temperature Sensor Operation | 139 | | Flash Memory | 141 | | Architecture | 141 | | Flash Information Area | | | Operation | | | | | | Flash Operation Timing Using the Flash Frequency Registers | | | Flash Code Protection Against Accidental Program and Erasure | | | · · · · · · · · · · · · · · · · · · · | 147 | | | <br>147 | | | <br>147 | | | 148 | | <b>71</b> | 148 | | | 149 | | · · · · · · · · · · · · · · · · · · · | 149 | | • | 150 | | | 150 | PS022825-0908 **Table of Contents** Table 5. Z8 Encore! XP F082A Series Program Memory Maps (Continued) | Program Memory Address (Hex) | Function | |---------------------------------------------|------------------------------| | Z8F022A and Z8F021A Products | | | 0000–0001 | Flash Option Bits | | 0002–0003 | Reset Vector | | 0004–0005 | WDT Interrupt Vector | | 0006–0007 | Illegal Instruction Trap | | 0008–0037 | Interrupt Vectors* | | 0038–0039 | Reserved | | 003A-003D | Oscillator Fail Trap Vectors | | 003E-07FF | Program Memory | | Z8F012A and Z8F011A Products | | | 0000–0001 | Flash Option Bits | | 0002–0003 | Reset Vector | | 0004–0005 | WDT Interrupt Vector | | 0006–0007 | Illegal Instruction Trap | | 0008–0037 | Interrupt Vectors* | | 0038–0039 | Reserved | | 003A-003D | Oscillator Fail Trap Vectors | | 003E-03FF | Program Memory | | * See Table 32 on page 56 for a list of the | e interrupt vectors. | ## **Data Memory** The Z8 Encore! XP F082A Series does not use the eZ8 CPU's 64 KB Data Memory address space. ### Flash Information Area Table 6 on page 18 describes the Z8 Encore! XP F082A Series Flash Information Area. This 128 B Information Area is accessed by setting bit 7 of the Flash Page Select Register to 1. When access is enabled, the Flash Information Area is mapped into the Program Memory and overlays the 128 bytes at addresses FEOOH to FF7FH. When the Information Area access is enabled, all reads from these Program Memory addresses return the Infor- PS022825-0908 Address Space and as long as four. A reset pulse three clock cycles in duration might trigger a reset; a pulse four cycles in duration always triggers a reset. While the $\overline{RESET}$ input pin is asserted Low, the Z8 Encore! $XP^{\circledR}$ F082A Series devices remain in the Reset state. If the $\overline{RESET}$ pin is held Low beyond the System Reset timeout, the device exits the Reset state on the system clock rising edge following $\overline{RESET}$ pin deassertion. Following a System Reset initiated by the external $\overline{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 (see Port A–D Control Registers on page 46), the RESET pin functions as an open-drain (active Low) reset mode indicator in addition to the input functionality. This reset output feature allows a Z8 Encore! XP F082A 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. After an internal reset event occurs, the internal circuitry begins driving the RESET pin Low. The RESET pin is held Low by the internal circuitry until the appropriate delay listed in Table 8 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 On-Chip Debugger block is not reset but the rest 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** STOP mode is entered by execution of a STOP instruction by the eZ8 CPU. See Low-Power Modes on page 33 for detailed STOP mode information. During Stop Mode Recovery (SMR), the CPU is held in reset for 66 IPO cycles if the crystal oscillator is disabled or 5000 cycles if it is enabled. The SMR delay (see Table 131 on page 229) $T_{SMR}$ , also includes the time required to start up the IPO. Stop Mode Recovery does not affect on-chip registers other than the Watchdog Timer Control register (WDTCTL) 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, the Stop Mode Recovery code must reconfigure the oscillator control block such that the correct system clock source is enabled and selected. The eZ8 CPU fetches the Reset vector at Program Memory addresses 0002H and 0003H and loads that value into the Program Counter. Program execution begins at the Reset **Table 14. Port Alternate Function Mapping (Non 8-Pin Parts)** | Port | Pin | Mnemonic | Alternate Function Description | Alternate Function<br>Set Register AFS1 | |--------|-----|-------------|-----------------------------------------|-----------------------------------------| | Port A | PA0 | T0IN/T0OUT* | Timer 0 Input/Timer 0 Output Complement | N/A | | | | Reserved | | - | | | PA1 | T0OUT | Timer 0 Output | - | | | | Reserved | | - | | | PA2 | DE0 | UART 0 Driver Enable | - | | | | Reserved | | - | | | PA3 | CTS0 | UART 0 Clear to Send | - | | | | Reserved | | - | | | PA4 | RXD0/IRRX0 | UART 0/IrDA 0 Receive Data | _ | | | | Reserved | | _ | | | PA5 | TXD0/IRTX0 | UART 0/IrDA 0 Transmit Data | _ | | | | Reserved | | _ | | | PA6 | T1IN/T1OUT* | Timer 1 Input/Timer 1 Output Complement | _ | | | | Reserved | | _ | | | PA7 | T1OUT | Timer 1 Output | _ | | | | Reserved | | | **Note:** Because there is only a single alternate function for each Port A pin, the Alternate Function Set registers are not implemented for Port A. Enabling alternate function selections as described in Port A–D Alternate Function Sub-Registers on page 47 automatically enables the associated alternate function. <sup>\*</sup> Whether PA0/PA6 take on the timer input or timer output complement function depends on the timer configuration as described in Timer Pin Signal Operation on page 82. Set 1 Sub-Registers on page 50, GPIO Alternate Functions on page 38, and Port A–D Alternate Function Set 2 Sub-Registers on page 51. See GPIO Alternate Functions on page 38 to determine the alternate function 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. Table 20. Port A–D Alternate Function Sub-Registers (PxAF) | BITS | 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); 04H (Port A of 8-pin device) | | | | | | | | | R/W | R/W | | | | | | | | | ADDR | If 02H i | n Port A–D | Address Reg | gister, acces | sible througl | n the Port A- | -D Control F | Register | AF[7:0]—Port Alternate Function enabled 0 =The port pin is in normal mode and the DDx bit in the Port A–D Data Direction sub-register determines the direction of the pin. 1 = The alternate function selected through Alternate Function Set sub-registers is enabled. Port pin operation is controlled by the alternate function. ### Port A-D Output Control Sub-Registers The Port A–D Output Control sub-register (Table 21) is accessed through the Port A–D Control register by writing 03H to the Port A–D Address register. Setting the bits in the Port A–D Output Control sub-registers to 1 configures the specified port pins for opendrain operation. These sub-registers affect the pins directly and, as a result, alternate functions are also affected. Table 21. Port A–D Output Control Sub-Registers (PxOC) | BITS | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------|---------------------------------------------------------------------------------------|------|------|------|------|------|------|------| | FIELD | POC7 | POC6 | POC5 | POC4 | POC3 | POC2 | POC1 | POC0 | | RESET | 00H (Ports A-C); 01H (Port D) | | | | | | | | | R/W | ADDR | If 03H in Port A–D Address Register, accessible through the Port A–D Control Register | | | | | | | | POC[7:0]—Port Output Control These bits function independently of the alternate function bit and always disable the drains if set to 1. 0 = The source current is enabled for any output mode (unless overridden by the alternate ### Receiving Data using the Interrupt-Driven Method The UART Receiver interrupt indicates the availability of new data (as well as error conditions). Follow the steps below to configure the UART receiver for interrupt-driven operation: - 1. Write to the UART Baud Rate High and Low Byte registers to set the acceptable baud rate - 2. Enable the UART pin functions by configuring the associated GPIO Port pins for alternate function operation. - 3. Execute a DI instruction to disable interrupts. - 4. Write to the Interrupt control registers to enable the UART Receiver interrupt and set the acceptable priority. - 5. Clear the UART Receiver interrupt in the applicable Interrupt Request register. - 6. Write to the UART Control 1 Register to enable Multiprocessor (9-bit) mode functions, if appropriate. - Set the Multiprocessor Mode Select (MPEN) to Enable MULTIPROCESSOR mode. - Set the Multiprocessor Mode Bits, MPMD[1:0], to select the acceptable address matching scheme. - Configure the UART to interrupt on received data and errors or errors only (interrupt on errors only is unlikely to be useful for Z8 Encore!<sup>®</sup> devices without a DMA block) - 7. Write the device address to the Address Compare Register (automatic MULTIPRO-CESSOR modes only). - 8. Write to the UART Control 0 register to: - Set the receive enable bit (REN) to enable the UART for data reception - Enable parity, if appropriate and if multiprocessor mode is not enabled, and select either even or odd parity. - 9. Execute an EI instruction to enable interrupts. The UART is now configured for interrupt-driven data reception. When the UART Receiver interrupt is detected, the associated interrupt service routine (ISR) performs the following: - 1. Checks the UART Status 0 register to determine the source of the interrupt error, break, or received data. - 2. Reads the data from the UART Receive Data register if the interrupt was because of data available. If operating in MULTIPROCESSOR (9-bit) mode, further actions may be required depending on the MULTIPROCESSOR mode bits MPMD[1:0]. 128 Compensation Steps: 1. Correct for Offset | ADC MSB | ADC LSB | | | |------------|------------|--|--| | - | | | | | Offset MSB | Offset LSB | | | | = | | | | | #1 MSB | #1 LSB | | | 2. Take absolute value of the offset corrected ADC value *if negative*—the gain correction factor is computed assuming positive numbers, with sign restoration afterward. | #2 MSB | #2 LSB | |--------|--------| Also take absolute value of the gain correction word if negative. 3. Multiply by Gain Correction Word. If in DIFFERENTIAL mode, there are two gain correction values: one for positive ADC values, another for negative ADC values. Based on the sign of #2, use the appropriate Gain Correction Word. | | #2 MSB | #2 LSB | | | |---|-----------|-----------|----|----| | * | | | | | | | AGain MSB | AGain LSB | ] | | | = | | | | | | | #3 | #3 | #3 | #3 | 4. Round the result and discard the least significant two bytes (this is equivalent to dividing by $2^{16}$ ). | #3 | #3 | #3 | #3 | |--------|---------|------|------| | - | | | | | 0x00 | 0x00 | 0x80 | 0x00 | | = | | | | | #4 MSB | #4 I SB | | | 5. Determine sign of the gain correction factor using the sign bits from Step 2. If the offset corrected ADC value AND the gain correction word have the same sign, then the factor is positive and is left unchanged. If they have differing signs, then the factor is negative and must be multiplied by -1. 162 **Table 94. ADC Calibration Data Location** | AddressAddressCompensation UsageADC ModeType60FE60OffsetSingle-Ended UnbufferedInternal 2.0 V08FE08Gain High ByteSingle-Ended UnbufferedInternal 2.0 V09FE09Gain Low ByteSingle-Ended UnbufferedInternal 1.0 V63FE63OffsetSingle-Ended UnbufferedInternal 1.0 V0AFE0AGain High ByteSingle-Ended UnbufferedInternal 1.0 V0BFE0BGain Low ByteSingle-Ended UnbufferedExternal 2.0 V0CFE66OffsetSingle-Ended UnbufferedExternal 2.0 V0CFE0CGain High ByteSingle-Ended UnbufferedExternal 2.0 V0DFE0DGain Low ByteSingle-Ended UnbufferedExternal 2.0 V0BFE69OffsetSingle-Ended 1x BufferedInternal 2.0 V0BFE0BGain High ByteSingle-Ended 1x BufferedInternal 2.0 V0CFE0CGain Low ByteSingle-Ended 1x BufferedExternal 2.0 V0FFE0FGain Low ByteSingle-Ended 1x BufferedExternal 2.0 V10FE10Gain High ByteSingle-Ended 1x BufferedExternal 2.0 V11FE11Gain Low ByteSingle-Ended 1x BufferedExternal 2.0 V12FE12Positive Gain Low ByteDifferential UnbufferedInternal 2.0 V13FE13Positive Gain Low ByteDifferential UnbufferedInternal 2.0 V14FE14Positive Gain Low ByteDiffer | Info Page | Memory | | | Reference | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|---------|-------------------------|--------------------------|----------------| | FE08 Gain High Byte Single-Ended Unbuffered Internal 2.0 V 99 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 0B FE0B Gain Low Byte Single-Ended Unbuffered Internal 1.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 0D FE0D Gain Low Byte Single-Ended Unbuffered Internal 2.0 V 0D FE0B Gain High Byte Single-Ended 1x Buffered Internal 2.0 V 0D FE0B Gain High Byte Single-Ended 1x Buffered Internal 2.0 V 0F FE0F Gain Low Byte Single-Ended 1x Buffered External 2.0 V 0F FE0C Gain High Byte 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 12 FE12 Positive Gain High Byte Differential Unbuffered Internal 2.0 V 13 FE13 Positive Gain High Byte Differential Unbuffered Internal 2.0 V 14 FE31 Negative Gain Low Byte Differential Unbuffered Internal 2.0 V 15 FE72 Offset Differential Unbuffered Internal 2.0 V 16 FE16 Positive Gain Low Byte Differential Unbuffered Internal 2.0 V 17 FE17 Positive Gain Low Byte Differential Unbuffered Internal 2.0 V 18 FE31 Negative Gain Low Byte Differential Unbuffered Internal 1.0 V 19 FE15 Positive Gain High Byte Differential Unbuffered Internal 1.0 V 19 FE30 Negative Gain High Byte Differential Unbuffered Internal 1.0 V 19 FE31 Negative Gain High Byte Differential Unbuffered Internal 1.0 V 19 FE32 Negative Gain High Byte Differential Unbuffered Internal 1.0 V 19 FE33 Negative Gain High Byte Differential Unbuffered Internal 1.0 V 19 FE30 Negative Gain High Byte Differential Unbuffered Internal 1.0 V 19 FE30 Negative Gain High Byte Differential Unbuffered Internal 1.0 V 19 FE30 Negative Gain High Byte Differential Unbuffered Internal 1.0 V | Address | Address | Compensation Usage | ADC Mode | Туре | | FE09 Gain Low Byte Single-Ended Unbuffered Internal 2.0 V G3 FE63 Offset Single-Ended Unbuffered Internal 1.0 V G4 FE0A Gain High Byte Single-Ended Unbuffered Internal 1.0 V G5 FE0B Gain Low Byte Single-Ended Unbuffered Internal 1.0 V G6 FE66 Offset Single-Ended Unbuffered External 2.0 V G7 FE0C Gain High Byte Single-Ended Unbuffered External 2.0 V G8 FE0B Gain Low Byte Single-Ended Unbuffered External 2.0 V G8 FE0B Gain Low Byte Single-Ended Unbuffered External 2.0 V G8 FE69 Offset Single-Ended 1x Buffered Internal 2.0 V G9 FE0B Gain High Byte Single-Ended 1x Buffered Internal 2.0 V G6 FE0C Gain High Byte Single-Ended 1x Buffered Internal 2.0 V G6 FE6C Offset Single-Ended 1x Buffered External 2.0 V G7 FE0B Gain Low Byte Single-Ended 1x Buffered External 2.0 V G8 FE6B Offset Single-Ended 1x Buffered External 2.0 V G8 FE6C Offset Single-Ended 1x Buffered External 2.0 V G8 FE10 Gain High Byte Single-Ended 1x Buffered Internal 2.0 V G8 FE6B Offset Differential Unbuffered Internal 2.0 V G8 FE6B Offset Differential Unbuffered Internal 2.0 V G9 FE6B Offset Differential Unbuffered Internal 2.0 V C9 FE6B Offset Differential Unbuffered Internal 2.0 V C9 FE6B Offset Differential Unbuffered Internal 2.0 V C9 FE6B Offset Differential Unbuffered Internal 2.0 V C9 FE7D Differe | 60 | FE60 | Offset | Single-Ended Unbuffered | Internal 2.0 V | | FE63 Offset Single-Ended Unbuffered Internal 1.0 V OA FE0A Gain High Byte Single-Ended Unbuffered Internal 1.0 V OB FE0B Gain Low Byte Single-Ended Unbuffered Internal 1.0 V 66 FE66 Offset Single-Ended Unbuffered External 2.0 V OC FE0C Gain High Byte Single-Ended Unbuffered External 2.0 V OD FE0D Gain Low Byte Single-Ended Unbuffered External 2.0 V OD FE0D Gain High Byte Single-Ended Unbuffered External 2.0 V OF FE69 Offset Single-Ended 1x Buffered Internal 2.0 V OF FE0E Gain High Byte Single-Ended 1x Buffered Internal 2.0 V OF FE0F Gain Low Byte Single-Ended 1x Buffered Internal 2.0 V OF FE6C Offset Single-Ended 1x Buffered External 2.0 V OF FE6C Offset Single-Ended 1x Buffered External 2.0 V OF FE6C Offset Single-Ended 1x Buffered External 2.0 V OF FE6C Offset Single-Ended 1x Buffered External 2.0 V OF FE6C Offset Differential Unbuffered Internal 2.0 V OF FE6F 1.0 V OF FE7F | 08 | FE08 | Gain High Byte | Single-Ended Unbuffered | Internal 2.0 V | | FEOA Gain High Byte Single-Ended Unbuffered Internal 1.0 V B FEOB Gain Low Byte Single-Ended Unbuffered Internal 1.0 V GEOFECC Gain High Byte Single-Ended Unbuffered External 2.0 V CEOFECC Gain High Byte Single-Ended Unbuffered External 2.0 V DEOFECC Gain High Byte Single-Ended Unbuffered External 2.0 V DEOFECC Gain High Byte Single-Ended Unbuffered External 2.0 V GEOFECC Gain High Byte Single-Ended Unbuffered Internal 2.0 V GEOFECC Gain High Byte Single-Ended 1x Buffered Internal 2.0 V GEOFECC Gain High Byte Single-Ended 1x Buffered Internal 2.0 V GEOFECC Offset Single-Ended 1x Buffered External 2.0 V GEOFECC Offset Single-Ended 1x Buffered External 2.0 V GEOFECC Offset Single-Ended 1x Buffered External 2.0 V GEOFECC Offset Single-Ended 1x Buffered External 2.0 V GEOFECC Offset Single-Ended 1x Buffered External 2.0 V GEOFECC Offset Differential Unbuffered Internal 1.0 2.0 V GEOFECC Offset Differential Unbuffered External 2.0 V | 09 | FE09 | Gain Low Byte | Single-Ended Unbuffered | Internal 2.0 V | | Gain Low Byte Single-Ended Unbuffered External 2.0 V GENEROR Gain High Byte Single-Ended Unbuffered External 2.0 V CENTRO GENEROR Gain High Byte Single-Ended Unbuffered External 2.0 V CENTRO GENEROR | 63 | FE63 | Offset | Single-Ended Unbuffered | Internal 1.0 V | | FE66 Offset Single-Ended Unbuffered External 2.0 V OC FEOC Gain High Byte Single-Ended Unbuffered External 2.0 V OD FEOD Gain Low Byte Single-Ended Unbuffered External 2.0 V 69 FE69 Offset Single-Ended 1x Buffered Internal 2.0 V OE FE0E Gain High Byte Single-Ended 1x Buffered Internal 2.0 V OF FE0F Gain Low Byte Single-Ended 1x Buffered Internal 2.0 V OF FE0C 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 12 FE6F Offset Differential Unbuffered Internal 2.0 V 13 FE12 Positive Gain High Byte Differential Unbuffered Internal 2.0 V 14 FE13 Positive Gain Low Byte Differential Unbuffered Internal 2.0 V 30 FE30 Negative Gain Low Byte Differential Unbuffered Internal 2.0 V 15 FE72 Offset Differential Unbuffered Internal 2.0 V 16 FE14 Positive Gain Low Byte Differential Unbuffered Internal 2.0 V 17 FE72 Offset Differential Unbuffered Internal 1.0 V 18 FE14 Positive Gain High Byte Differential Unbuffered Internal 1.0 V 19 FE75 Positive Gain High Byte Differential Unbuffered Internal 1.0 V 19 FE75 Offset Differential Unbuffered Internal 1.0 V 10 FE15 Positive Gain Low Byte Differential Unbuffered Internal 1.0 V 10 FE16 Positive Gain High Byte Differential Unbuffered Internal 1.0 V 11 FE17 Positive Gain High Byte Differential Unbuffered Internal 1.0 V 12 FE75 Offset Differential Unbuffered Internal 1.0 V | 0A | FE0A | Gain High Byte | Single-Ended Unbuffered | Internal 1.0 V | | OC FEOC Gain High Byte Single-Ended Unbuffered External 2.0 V DD FEOD Gain Low Byte Single-Ended Unbuffered External 2.0 V FEOF Gain High Byte Single-Ended 1x Buffered Internal 2.0 V FEOF Gain Low Byte Single-Ended 1x Buffered Internal 2.0 V FEOF Gain Low Byte Single-Ended 1x Buffered Internal 2.0 V FEOF Gain Low Byte Single-Ended 1x Buffered External 2.0 V GC FEGC Offset Single-Ended 1x Buffered External 2.0 V DF FEOF Gain High Byte Single-Ended 1x Buffered External 2.0 V GF FEOF Gain Low Byte Single-Ended 1x Buffered External 2.0 V FE10 Gain High Byte Single-Ended 1x Buffered External 2.0 V FE11 Gain Low Byte Single-Ended 1x Buffered Internal 2.0 V FEOF FEOF Offset Differential Unbuffered Internal 2.0 V FE12 Positive Gain High Byte Differential Unbuffered Internal 2.0 V FE13 Positive Gain Low Byte Differential Unbuffered Internal 2.0 V FE30 Negative Gain High Byte Differential Unbuffered Internal 2.0 V FE31 Negative Gain Low Byte Differential Unbuffered Internal 2.0 V FE72 Offset Differential Unbuffered Internal 1.0 V FE14 Positive Gain High Byte Differential Unbuffered Internal 1.0 V FE15 Positive Gain High Byte Differential Unbuffered Internal 1.0 V FE15 Positive Gain High Byte Differential Unbuffered Internal 1.0 V FE32 Negative Gain High Byte Differential Unbuffered Internal 1.0 V FE33 Negative Gain Low Byte Differential Unbuffered Internal 1.0 V FE75 Offset Differential Unbuffered Internal 1.0 V FE75 Offset Differential Unbuffered Internal 1.0 V | 0B | FE0B | Gain Low Byte | Single-Ended Unbuffered | Internal 1.0 V | | OD FEOD Gain Low Byte Single-Ended Unbuffered External 2.0 V 69 FE69 Offset Single-Ended 1x Buffered Internal 2.0 V 0E FEOE Gain High Byte Single-Ended 1x Buffered Internal 2.0 V 0F FEOF Gain Low Byte Single-Ended 1x Buffered Internal 2.0 V 0F 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 12 FE6C Offset Differential Unbuffered Internal 2.0 V 13 FE12 Positive Gain High Byte Differential Unbuffered Internal 2.0 V 14 FE31 Positive Gain Low Byte Differential Unbuffered Internal 2.0 V 15 FE70 Offset Differential Unbuffered Internal 2.0 V 16 FE71 Negative Gain High Byte Differential Unbuffered Internal 2.0 V 17 FE71 Negative Gain Low Byte Differential Unbuffered Internal 2.0 V 18 FE71 Negative Gain Low Byte Differential Unbuffered Internal 2.0 V 19 FE72 Offset Differential Unbuffered Internal 2.0 V 19 FE72 Offset Differential Unbuffered Internal 1.0 V 19 FE73 Negative Gain High Byte Differential Unbuffered Internal 1.0 V 19 FE73 Negative Gain High Byte Differential Unbuffered Internal 1.0 V 19 FE75 Offset Differential Unbuffered Internal 1.0 V 19 FE75 Offset Differential Unbuffered Internal 1.0 V 19 FE75 Offset Differential Unbuffered Internal 1.0 V 19 FE75 Offset Differential Unbuffered Internal 1.0 V | 66 | FE66 | Offset | Single-Ended Unbuffered | External 2.0 V | | FE69 Offset Single-Ended 1x Buffered Internal 2.0 V DE FE0E Gain High Byte Single-Ended 1x Buffered Internal 2.0 V DF FE0F Gain Low Byte Single-Ended 1x Buffered Internal 2.0 V DF FE6C Offset Single-Ended 1x Buffered External 2.0 V DF FE10 Gain High Byte Single-Ended 1x Buffered External 2.0 V DF FE10 Gain High Byte Single-Ended 1x Buffered External 2.0 V DF FE11 Gain Low Byte Single-Ended 1x Buffered External 2.0 V DF FE6F Offset Differential Unbuffered Internal 2.0 V DF FE6F Offset Differential Unbuffered Internal 2.0 V DF FE12 Positive Gain High Byte Differential Unbuffered Internal 2.0 V DF FE30 Negative Gain Low Byte Differential Unbuffered Internal 2.0 V DF FE72 Offset Differential Unbuffered Internal 2.0 V DF FE72 Offset Differential Unbuffered Internal 1.0 V DF FE15 Positive Gain High Byte Differential Unbuffered Internal 1.0 V DF FE31 Negative Gain High Byte Differential Unbuffered Internal 1.0 V DF FE73 Negative Gain High Byte Differential Unbuffered Internal 1.0 V DF FE75 Offset 2.0 V | 0C | FE0C | Gain High Byte | Single-Ended Unbuffered | External 2.0 V | | OE FE0E Gain High Byte Single-Ended 1x Buffered Internal 2.0 V OF 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 12 FE6F Offset Differential Unbuffered Internal 2.0 V 13 FE12 Positive Gain High Byte Differential Unbuffered Internal 2.0 V 14 FE30 Negative Gain High Byte Differential Unbuffered Internal 2.0 V 15 FE70 Offset Differential Unbuffered Internal 2.0 V 16 FE71 Negative Gain Low Byte Differential Unbuffered Internal 2.0 V 17 FE72 Offset Differential Unbuffered Internal 2.0 V 18 FE73 Negative Gain High Byte Differential Unbuffered Internal 1.0 V 19 FE70 Offset Differential Unbuffered Internal 1.0 V 19 FE15 Positive Gain Low Byte Differential Unbuffered Internal 1.0 V 19 FE30 Negative Gain High Byte Differential Unbuffered Internal 1.0 V 19 FE15 Positive Gain Low Byte Differential Unbuffered Internal 1.0 V 19 FE31 Negative Gain High Byte Differential Unbuffered Internal 1.0 V 19 FE15 Positive Gain High Byte Differential Unbuffered Internal 1.0 V 19 FE30 Negative Gain High Byte Differential Unbuffered Internal 1.0 V 19 FE30 Negative Gain Low Byte Differential Unbuffered Internal 1.0 V 19 FE30 Negative Gain High Byte Differential Unbuffered Internal 1.0 V 19 FE30 Offset Differential Unbuffered Internal 1.0 V 19 FE30 Offset Differential Unbuffered Internal 1.0 V | 0D | FE0D | Gain Low Byte | Single-Ended Unbuffered | External 2.0 V | | OF FE0F Gain Low Byte Single-Ended 1x Buffered External 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 12 FE6F Offset Differential Unbuffered Internal 2.0 V 13 FE12 Positive Gain High Byte Differential Unbuffered Internal 2.0 V 14 FE30 Negative Gain High Byte Differential Unbuffered Internal 2.0 V 15 FE70 Offset Differential Unbuffered Internal 2.0 V 16 FE71 Positive Gain High Byte Differential Unbuffered Internal 2.0 V 17 FE30 Negative Gain Low Byte Differential Unbuffered Internal 2.0 V 18 FE31 Negative Gain Low Byte Differential Unbuffered Internal 2.0 V 19 FE72 Offset Differential Unbuffered Internal 1.0 V 19 FE14 Positive Gain High Byte Differential Unbuffered Internal 1.0 V 19 FE15 Positive Gain Low Byte Differential Unbuffered Internal 1.0 V 19 FE30 Negative Gain High Byte Differential Unbuffered Internal 1.0 V 19 FE31 Negative Gain High Byte Differential Unbuffered Internal 1.0 V 19 FE32 Negative Gain High Byte Differential Unbuffered Internal 1.0 V 19 FE30 Negative Gain Low Byte Differential Unbuffered Internal 1.0 V 19 FE30 Negative Gain Low Byte Differential Unbuffered Internal 1.0 V 19 FE30 Negative Gain Low Byte Differential Unbuffered Internal 1.0 V 19 FE30 Negative Gain Low Byte Differential Unbuffered Internal 1.0 V 19 FE30 Negative Gain Low Byte Differential Unbuffered Internal 1.0 V 19 FE30 Negative Gain Low Byte Differential Unbuffered Internal 1.0 V 19 FE30 Negative Gain Low Byte Differential Unbuffered Internal 2.0 V | 69 | FE69 | Offset | Single-Ended 1x Buffered | Internal 2.0 V | | FE6C Offset Single-Ended 1x Buffered External 2.0 V FE10 Gain High Byte Single-Ended 1x Buffered External 2.0 V FE11 Gain Low Byte Single-Ended 1x Buffered External 2.0 V FE6F Offset Differential Unbuffered Internal 2.0 V FE12 Positive Gain High Byte Differential Unbuffered Internal 2.0 V FE13 Positive Gain Low Byte Differential Unbuffered Internal 2.0 V Negative Gain High Byte Differential Unbuffered Internal 2.0 V RE30 Negative Gain High Byte Differential Unbuffered Internal 2.0 V FE7 Offset Differential Unbuffered Internal 2.0 V FE7 Diffset Differential Unbuffered Internal 1.0 V FE14 Positive Gain High Byte Differential Unbuffered Internal 1.0 V FE15 Positive Gain Low Byte Differential Unbuffered Internal 1.0 V FE7 FE7 Offset Differential Unbuffered Internal 1.0 V FE7 FE7 Positive Gain High Byte Differential Unbuffered Internal 1.0 V FE30 Negative Gain High Byte Differential Unbuffered Internal 1.0 V FE7 FE7 Offset Differential Unbuffered Internal 1.0 V FE7 FE7 Offset Differential Unbuffered Internal 1.0 V FE7 FE7 Offset Differential Unbuffered Internal 1.0 V FE7 FE75 Offset Differential Unbuffered External 2.0 V FE7 FE75 Offset Differential Unbuffered External 2.0 V | 0E | FE0E | Gain High Byte | Single-Ended 1x Buffered | Internal 2.0 V | | FE10 Gain High Byte Single-Ended 1x Buffered External 2.0 V FE11 Gain Low Byte Single-Ended 1x Buffered External 2.0 V FE6F Offset Differential Unbuffered Internal 2.0 V FE12 Positive Gain High Byte Differential Unbuffered Internal 2.0 V FE13 Positive Gain Low Byte Differential Unbuffered Internal 2.0 V Negative Gain High Byte Differential Unbuffered Internal 2.0 V Negative Gain Low Byte Differential Unbuffered Internal 2.0 V FE30 Negative Gain Low Byte Differential Unbuffered Internal 2.0 V FE31 Negative Gain Low Byte Differential Unbuffered Internal 1.0 V FE72 Offset Differential Unbuffered Internal 1.0 V FE14 Positive Gain High Byte Differential Unbuffered Internal 1.0 V FE15 Positive Gain Low Byte Differential Unbuffered Internal 1.0 V FE32 Negative Gain High Byte Differential Unbuffered Internal 1.0 V FE33 Negative Gain Low Byte Differential Unbuffered Internal 1.0 V FE75 FE75 Offset Differential Unbuffered External 2.0 V FE76 Positive Gain High Byte Differential Unbuffered External 2.0 V | 0F | FE0F | Gain Low Byte | Single-Ended 1x Buffered | Internal 2.0 V | | FE11 Gain Low Byte Single-Ended 1x Buffered External 2.0 V FE6F Offset Differential Unbuffered Internal 2.0 V FE12 Positive Gain High Byte Differential Unbuffered Internal 2.0 V RE13 Positive Gain Low Byte Differential Unbuffered Internal 2.0 V Negative Gain High Byte Differential Unbuffered Internal 2.0 V RE30 Negative Gain High Byte Differential Unbuffered Internal 2.0 V FE31 Negative Gain Low Byte Differential Unbuffered Internal 2.0 V FE72 Offset Differential Unbuffered Internal 1.0 V FE14 Positive Gain High Byte Differential Unbuffered Internal 1.0 V FE15 Positive Gain Low Byte Differential Unbuffered Internal 1.0 V FE32 Negative Gain High Byte Differential Unbuffered Internal 1.0 V RE33 Negative Gain Low Byte Differential Unbuffered Internal 1.0 V FE75 Offset Differential Unbuffered Internal 1.0 V FE75 Offset Differential Unbuffered External 2.0 V Differential Unbuffered External 2.0 V | 6C | FE6C | Offset | Single-Ended 1x Buffered | External 2.0 V | | FE6F Offset Differential Unbuffered Internal 2.0 V FE12 Positive Gain High Byte Differential Unbuffered Internal 2.0 V FE13 Positive Gain Low Byte Differential Unbuffered Internal 2.0 V Negative Gain High Byte Differential Unbuffered Internal 2.0 V Negative Gain Low Byte Differential Unbuffered Internal 2.0 V FE31 Negative Gain Low Byte Differential Unbuffered Internal 2.0 V FE72 Offset Differential Unbuffered Internal 1.0 V FE14 Positive Gain High Byte Differential Unbuffered Internal 1.0 V FE15 Positive Gain Low Byte Differential Unbuffered Internal 1.0 V FE32 Negative Gain High Byte Differential Unbuffered Internal 1.0 V FE33 Negative Gain Low Byte Differential Unbuffered Internal 1.0 V FE34 Negative Gain Low Byte Differential Unbuffered Internal 1.0 V FE35 Diffset Differential Unbuffered Internal 1.0 V FE75 FE75 Offset Differential Unbuffered External 2.0 V | 10 | FE10 | Gain High Byte | Single-Ended 1x Buffered | External 2.0 V | | 12 FE12 Positive Gain High Byte Differential Unbuffered Internal 2.0 V 13 FE13 Positive Gain Low Byte Differential Unbuffered Internal 2.0 V 14 FE30 Negative Gain High Byte Differential Unbuffered Internal 2.0 V 15 FE72 Offset Differential Unbuffered Internal 1.0 V 16 FE15 Positive Gain High Byte Differential Unbuffered Internal 1.0 V 17 FE32 Negative Gain Low Byte Differential Unbuffered Internal 1.0 V 18 FE33 Negative Gain High Byte Differential Unbuffered Internal 1.0 V 19 FE30 Negative Gain High Byte Differential Unbuffered Internal 1.0 V 19 FE31 Negative Gain High Byte Differential Unbuffered Internal 1.0 V 19 FE32 Negative Gain Low Byte Differential Unbuffered Internal 1.0 V 19 FE33 Negative Gain Low Byte Differential Unbuffered Internal 1.0 V 19 FE30 Offset Differential Unbuffered External 2.0 V 19 FE30 Positive Gain High Byte Differential Unbuffered External 2.0 V 19 FE30 Positive Gain High Byte Differential Unbuffered External 2.0 V | 11 | FE11 | Gain Low Byte | Single-Ended 1x Buffered | External 2.0 V | | FE13 Positive Gain Low Byte Differential Unbuffered Internal 2.0 V Negative Gain High Byte Differential Unbuffered Internal 2.0 V Negative Gain Low Byte Differential Unbuffered Internal 2.0 V FE31 Negative Gain Low Byte Differential Unbuffered Internal 1.0 V FE72 Offset Differential Unbuffered Internal 1.0 V FE14 Positive Gain High Byte Differential Unbuffered Internal 1.0 V FE15 Positive Gain Low Byte Differential Unbuffered Internal 1.0 V FE32 Negative Gain High Byte Differential Unbuffered Internal 1.0 V FE33 Negative Gain Low Byte Differential Unbuffered Internal 1.0 V FE75 Offset Differential Unbuffered External 2.0 V FE76 Positive Gain High Byte Differential Unbuffered External 2.0 V | 6F | FE6F | Offset | Differential Unbuffered | Internal 2.0 V | | 30 FE30 Negative Gain High Byte Differential Unbuffered Internal 2.0 V 31 FE31 Negative Gain Low Byte Differential Unbuffered Internal 2.0 V 72 FE72 Offset Differential Unbuffered Internal 1.0 V 14 FE14 Positive Gain High Byte Differential Unbuffered Internal 1.0 V 15 FE15 Positive Gain Low Byte Differential Unbuffered Internal 1.0 V 32 FE32 Negative Gain High Byte Differential Unbuffered Internal 1.0 V 33 FE33 Negative Gain Low Byte Differential Unbuffered Internal 1.0 V 75 FE75 Offset Differential Unbuffered External 2.0 V 16 FE16 Positive Gain High Byte Differential Unbuffered External 2.0 V | 12 | FE12 | Positive Gain High Byte | Differential Unbuffered | Internal 2.0 V | | 31 FE31 Negative Gain Low Byte Differential Unbuffered Internal 2.0 V 72 FE72 Offset Differential Unbuffered Internal 1.0 V 14 FE14 Positive Gain High Byte Differential Unbuffered Internal 1.0 V 15 FE15 Positive Gain Low Byte Differential Unbuffered Internal 1.0 V 32 FE32 Negative Gain High Byte Differential Unbuffered Internal 1.0 V 33 FE33 Negative Gain Low Byte Differential Unbuffered Internal 1.0 V 75 FE75 Offset Differential Unbuffered External 2.0 V 16 FE16 Positive Gain High Byte Differential Unbuffered External 2.0 V | 13 | FE13 | Positive Gain Low Byte | Differential Unbuffered | Internal 2.0 V | | FE72 Offset Differential Unbuffered Internal 1.0 V FE14 Positive Gain High Byte Differential Unbuffered Internal 1.0 V FE15 Positive Gain Low Byte Differential Unbuffered Internal 1.0 V RE32 Negative Gain High Byte Differential Unbuffered Internal 1.0 V RE33 Negative Gain Low Byte Differential Unbuffered Internal 1.0 V FE75 Offset Differential Unbuffered External 2.0 V FE76 Positive Gain High Byte Differential Unbuffered External 2.0 V | 30 | FE30 | Negative Gain High Byte | Differential Unbuffered | Internal 2.0 V | | 14 FE14 Positive Gain High Byte Differential Unbuffered Internal 1.0 V 15 FE15 Positive Gain Low Byte Differential Unbuffered Internal 1.0 V 32 FE32 Negative Gain High Byte Differential Unbuffered Internal 1.0 V 33 FE33 Negative Gain Low Byte Differential Unbuffered Internal 1.0 V 75 FE75 Offset Differential Unbuffered External 2.0 V 16 FE16 Positive Gain High Byte Differential Unbuffered External 2.0 V | 31 | FE31 | Negative Gain Low Byte | Differential Unbuffered | Internal 2.0 V | | 15 FE15 Positive Gain Low Byte Differential Unbuffered Internal 1.0 V 32 FE32 Negative Gain High Byte Differential Unbuffered Internal 1.0 V 33 FE33 Negative Gain Low Byte Differential Unbuffered Internal 1.0 V 75 FE75 Offset Differential Unbuffered External 2.0 V 16 FE16 Positive Gain High Byte Differential Unbuffered External 2.0 V | 72 | FE72 | Offset | Differential Unbuffered | Internal 1.0 V | | 32 FE32 Negative Gain High Byte Differential Unbuffered Internal 1.0 V 33 FE33 Negative Gain Low Byte Differential Unbuffered Internal 1.0 V 75 FE75 Offset Differential Unbuffered External 2.0 V 16 FE16 Positive Gain High Byte Differential Unbuffered External 2.0 V | 14 | FE14 | Positive Gain High Byte | Differential Unbuffered | Internal 1.0 V | | 33 FE33 Negative Gain Low Byte Differential Unbuffered Internal 1.0 V 75 FE75 Offset Differential Unbuffered External 2.0 V 16 FE16 Positive Gain High Byte Differential Unbuffered External 2.0 V | 15 | FE15 | Positive Gain Low Byte | Differential Unbuffered | Internal 1.0 V | | 75 FE75 Offset Differential Unbuffered External 2.0 V 16 FE16 Positive Gain High Byte Differential Unbuffered External 2.0 V | 32 | FE32 | Negative Gain High Byte | Differential Unbuffered | Internal 1.0 V | | 16 FE16 Positive Gain High Byte Differential Unbuffered External 2.0 V | 33 | FE33 | Negative Gain Low Byte | Differential Unbuffered | Internal 1.0 V | | | 75 | FE75 | Offset | Differential Unbuffered | External 2.0 V | | 17 FE17 Positive Gain Low Byte Differential Unbuffered External 2.0 V | 16 | FE16 | Positive Gain High Byte | Differential Unbuffered | External 2.0 V | | | 17 | FE17 | Positive Gain Low Byte | Differential Unbuffered | External 2.0 V | PS022825-0908 Flash Option Bits Table 104. NVDS Read Time (Continued) | Operation | Minimum<br>Latency | Maximum<br>Latency | |------------------------|--------------------|--------------------| | Read (128 byte array) | 883 | 7609 | | Write (16 byte array) | 4973 | 5009 | | Write (64 byte array) | 4971 | 5013 | | Write (128 byte array) | 4984 | 5023 | | Illegal Read | 43 | 43 | | Illegal Write | 31 | 31 | If NVDS read performance is critical to your software architecture, there are some things you can do to optimize your code for speed, listed in order from most helpful to least helpful: - Periodically refresh all addresses that are used. The optimal use of NVDS in terms of speed is to rotate the writes evenly among all addresses planned to use, bringing all reads closer to the minimum read time. Because the minimum read time is much less than the write time, however, actual speed benefits are not always realized. - Use as few unique addresses as possible: this helps to optimize the impact of refreshing as well as minimize the requirement for it. zilog # **Oscillator Control** The Z8 Encore! XP<sup>®</sup> F082A Series devices uses five possible clocking schemes, each user-selectable: - Internal precision trimmed RC oscillator (IPO). - On-chip oscillator using off-chip crystal or resonator. - On-chip oscillator using external RC network. - External clock drive. - On-chip low power Watchdog Timer oscillator. - Clock failure detection circuitry. In addition, Z8 Encore! XP F082A Series devices contain clock failure detection and recovery circuitry, allowing continued operation despite a failure of the system clock oscillator. # **Operation** This chapter discusses the logic used to select the system clock and handle primary oscillator failures. ## **System Clock Selection** The oscillator control block selects from the available clocks. Table 108 details each clock source and its usage. PS022825-0908 Oscillator Control # eZ8 CPU Instruction Set # **Assembly Language Programming Introduction** The eZ8 CPU assembly language provides a means for writing an application program without concern for actual memory addresses or machine instruction formats. A program written in assembly language is called a source program. Assembly language allows the use of symbolic addresses to identify memory locations. It also allows mnemonic codes (opcodes and operands) to represent the instructions themselves. The opcodes identify the instruction while the operands represent memory locations, registers, or immediate data values. Each assembly language program consists of a series of symbolic commands called statements. Each statement can contain labels, operations, operands and comments. Labels can be assigned to a particular instruction step in a source program. The label identifies that step in the program as an entry point for use by other instructions. The assembly language also includes assembler directives that supplement the machine instruction. The assembler directives, or pseudo-ops, are not translated into a machine instruction. Rather, the pseudo-ops are interpreted as directives that control or assist the assembly process. The source program is processed (assembled) by the assembler to obtain a machine language program called the object code. The object code is executed by the eZ8 CPU. An example segment of an assembly language program is detailed in the following example. ### **Assembly Language Source Program Example** | JP START | ; Everything after the semicolon is a comment. | |---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | START: | ; A label called 'START'. The first instruction (JP START) in this ; example causes program execution to jump to the point within the ; program where the START label occurs. | | LD R4, R7 | ; A Load (LD) instruction with two operands. The first operand, ; Working Register R4, is the destination. The second operand, ; Working Register R7, is the source. The contents of R7 is ; written into R4. | | LD 234H, #%01 | ; Another Load (LD) instruction with two operands.<br>; The first operand, Extended Mode Register Address 234H,<br>; identifies the destination. The second operand, Immediate Data | | | ; value 01H, is the source. The value 01H is written into the ; Register at address 234H. | PS022825-0908 eZ8 CPU Instruction Set **Table 115. Additional Symbols** | Symbol | Definition | |--------|------------------------------| | dst | Destination Operand | | src | Source Operand | | @ | Indirect Address Prefix | | SP | Stack Pointer | | PC | Program Counter | | FLAGS | Flags Register | | RP | Register Pointer | | # | Immediate Operand Prefix | | В | Binary Number Suffix | | % | Hexadecimal Number<br>Prefix | | Н | Hexadecimal Number<br>Suffix | Assignment of a value is indicated by an arrow. For example, $$dst \leftarrow dst + src$$ indicates the source data is added to the destination data and the result is stored in the destination location. ### **eZ8 CPU Instruction Classes** eZ8 CPU instructions can be divided functionally into the following groups: - Arithmetic - Bit Manipulation - Block Transfer - CPU Control - Load - Logical - Program Control - Rotate and Shift PS022825-0908 eZ8 CPU Instruction Set Table 124. eZ8 CPU Instruction Summary (Continued) | Assembly | Symbolic | Address Mode Opcode(s | | Opcode(s) | Flags | | | | | | Fetch | Instr. | |----------------------|----------------------------------------------------------------------------------|-----------------------|----------|-----------|-------|----|---|------|---|---|-------|--------| | Mnemonic | Operation | dst | src | (Hex) | С | Z | S | ٧ | D | Н | | Cycles | | AND dst, src | $dst \leftarrow dst \ AND \ src$ | r | r | 52 | _ | * | * | 0 | _ | - | 2 | 3 | | | | r | Ir | 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 \leftarrow dst \ AND \ src$ | ER | ER | 58 | - | * | * | 0 | - | - | 4 | 3 | | | | ER | IM | 59 | • | | | | | | 4 | 3 | | ATM | Block all interrupt and DMA requests during execution of the next 3 instructions | | | 2F | _ | _ | _ | _ | _ | _ | 1 | 2 | | BCLR bit, dst | $dst[bit] \leftarrow 0$ | r | | E2 | - | _ | _ | - | - | - | 2 | 2 | | BIT p, bit, dst | $dst[bit] \leftarrow p$ | r | | E2 | - | _ | _ | _ | - | - | 2 | 2 | | BRK | Debugger Break | | | 00 | - | _ | _ | - | - | - | 1 | 1 | | BSET bit, dst | dst[bit] ← 1 | r | | E2 | - | - | - | - | - | - | 2 | 2 | | BSWAP dst | dst[7:0] ← dst[0:7] | R | | D5 | Χ | * | * | 0 | - | - | 2 | 2 | | BTJ p, bit, src, dst | | | r | F6 | - | _ | _ | - | - | - | 3 | 3 | | | $PC \leftarrow PC + X$ | | lr | F7 | • | | | | | | 3 | 4 | | BTJNZ bit, src, dst | | | r | F6 | - | _ | _ | - | - | - | 3 | 3 | | | $PC \leftarrow PC + X$ | | lr | F7 | | | | | | | 3 | 4 | | BTJZ bit, src, dst | if src[bit] = 0 | | r | F6 | - | - | - | - | - | - | 3 | 3 | | | $PC \leftarrow PC + X$ | | lr | F7 | | | | | | | 3 | 4 | | CALL dst | SP ← SP -2 | IRR | | D4 | - | _ | _ | _ | _ | _ | 2 | 6 | | | @SP ← PC<br>PC ← dst | DA | | D6 | | | | | | | 3 | 3 | | CCF | C ← ~C | | | EF | * | _ | _ | _ | _ | _ | 1 | 2 | | CLR dst | dst ← 00H | R | | В0 | - | _ | _ | - | - | _ | 2 | 2 | | | | IR | | B1 | - | | | | | | 2 | 3 | | Flags Notation: | * = Value is a function of<br>- = Unaffected<br>X = Undefined | the result | of the o | peration. | | Re | | to ( | ס | | | | PS022825-0908 eZ8 CPU Instruction Set Table 124. eZ8 CPU Instruction Summary (Continued) | Assembly | Symbolic | Addres | s Mode | Opcode(s) | | | Fla | ags | | | Fetch | Instr. | |-----------------|------------------------------------------------------------------|-----------|----------|-----------|---|----------|-----|------|---|---|-------|--------| | Mnemonic | Operation | dst | src | (Hex) | С | Z | S | ٧ | D | Н | | Cycles | | RR dst | | R | | E0 | * | * | * | * | _ | _ | 2 | 2 | | | D7 D6 D5 D4 D3 D2 D1 D0 → C dst | IR | | E1 | - | | | | | | 2 | 3 | | RRC dst | | R | | C0 | * | * | * | * | _ | _ | 2 | 2 | | | D7 D6 D5 D4 D3 D2 D1 D0 dst C — | IR | | C1 | • | | | | | | 2 | 3 | | SBC dst, src | dst ← dst – src - C | r | r | 32 | * | * | * | * | 1 | * | 2 | 3 | | | | r | lr | 33 | - | | | | | | 2 | 4 | | | | R | R | 34 | = | | | | | | 3 | 3 | | | | R | IR | 35 | - | | | | | | 3 | 4 | | | | R | IM | 36 | - | | | | | | 3 | 3 | | | | IR | IM | 37 | - | | | | | | 3 | 4 | | SBCX dst, src | $dst \leftarrow dst - src - C$ | ER | ER | 38 | * | * | * | * | 1 | * | 4 | 3 | | | | ER | IM | 39 | - | | | | | | 4 | 3 | | SCF | C ← 1 | | | DF | 1 | _ | _ | _ | _ | _ | 1 | 2 | | SRA dst | | R | | D0 | * | * | * | 0 | _ | _ | 2 | 2 | | | D7 D6 D5 D4 D3 D2 D1 D0 C | IR | | D1 | - | | | | | | 2 | 3 | | SRL dst | 0 <b>-▶</b> D7 D6 D5 D4 D3 D2 D1 D0 <b>▶</b> C | R | | 1F C0 | * | * | 0 | * | _ | _ | 3 | 2 | | | dst | IR | | 1F C1 | - | | | | | | 3 | 3 | | SRP src | $RP \leftarrow src$ | | IM | 01 | _ | _ | _ | _ | _ | _ | 2 | 2 | | STOP | STOP Mode | | | 6F | _ | _ | _ | _ | _ | _ | 1 | 2 | | SUB dst, src | $dst \leftarrow dst - src$ | r | r | 22 | * | * | * | * | 1 | * | 2 | 3 | | | | r | lr | 23 | - | | | | | | 2 | 4 | | | | R | R | 24 | • | | | | | | 3 | 3 | | | | R | IR | 25 | - | | | | | | 3 | 4 | | | | R | IM | 26 | - | | | | | | 3 | 3 | | | | IR | IM | 27 | - | | | | | | 3 | 4 | | Flags Notation: | * = Value is a function of th<br>- = Unaffected<br>X = Undefined | ne result | of the o | peration. | | Re<br>Se | | to ( | ) | | | | PS022825-0908 Table 124. eZ8 CPU Instruction Summary (Continued) | Assembly | Symbolic | Addre | ss Mode | Opcode(s) | | | FI | ags | Fetch | Instr. | | | |-----------------|------------------------------------------------------------------------------------------------------------------------------|--------------|------------|-----------|---|----------|----|------|-------|--------|--------|---| | Mnemonic | Operation | dst | src | (Hex) | С | Z | S | ٧ | D | Н | Cycles | | | SUBX dst, src | $dst \leftarrow dst - src$ | ER | ER | 28 | * | * | * | * | 1 | * | 4 | 3 | | | | ER | IM | 29 | - | | | | | | 4 | 3 | | SWAP dst | $dst[7:4] \leftrightarrow dst[3:0]$ | R | | F0 | Χ | * | * | Χ | _ | _ | 2 | 2 | | | | IR | | F1 | _ | | | | | | 2 | 3 | | TCM dst, src | (NOT dst) AND src | r | r | 62 | - | * | * | 0 | _ | _ | 2 | 3 | | | | r | lr | 63 | - | | | | | | 2 | 4 | | | | R | R | 64 | - | | | | | | 3 | 3 | | | | R | IR | 65 | - | | | | | | 3 | 4 | | | | R | IM | 66 | - | | | | | | 3 | 3 | | | | IR | IM | 67 | - | | | | | | 3 | 4 | | TCMX dst, src | (NOT dst) AND src | ER | ER | 68 | - | * | * | 0 | _ | _ | 4 | 3 | | | | ER | IM | 69 | - | | | | | | 4 | 3 | | TM dst, src | dst AND src | r | r | 72 | - | * | * | 0 | - | - | 2 | 3 | | | | r | lr | 73 | _ | | | | | | 2 | 4 | | | | R | R | 74 | - | | | | | | 3 | 3 | | | | R | IR | 75 | _ | | | | | | 3 | 4 | | | | R | IM | 76 | _ | | | | | | 3 | 3 | | | | IR | IM | 77 | _ | | | | | | 3 | 4 | | TMX dst, src | dst AND src | ER | ER | 78 | - | * | * | 0 | _ | _ | 4 | 3 | | | | ER | IM | 79 | | | | | | | 4 | 3 | | TRAP Vector | $SP \leftarrow SP - 2$<br>$@SP \leftarrow PC$<br>$SP \leftarrow SP - 1$<br>$@SP \leftarrow FLAGS$<br>$PC \leftarrow @Vector$ | | Vector | F2 | _ | - | _ | _ | _ | _ | 2 | 6 | | WDT | | | | 5F | - | - | _ | - | _ | _ | 1 | 2 | | Flags Notation: | * = Value is a function of<br>— = Unaffected<br>X = Undefined | of the resul | t of the o | peration. | | Re<br>Se | | to ( | ) | | | | PS022825-0908 eZ8 CPU Instruction Set ### **AC Characteristics** The section provides information about the AC characteristics and timing. All AC timing information assumes a standard load of 50 pF on all outputs. ### **Table 129. AC Characteristics** | | | T <sub>A</sub> = -40 °C<br>(unless o | V to 3.6 V<br>to +105 °C<br>otherwise<br>ted) | | | |---------------------|------------------------------|--------------------------------------|-----------------------------------------------|-------|---------------------------------------------------------------------------------------------------------| | Symbol | Parameter | Minimum | Maximum | Units | Conditions | | F <sub>SYSCLK</sub> | System Clock Frequency | _ | 20.0 | MHz | Read-only from Flash memory | | | | 0.032768 | 20.0 | MHz | Program or erasure of the Flash memory | | F <sub>XTAL</sub> | Crystal Oscillator Frequency | - | 20.0 | MHz | System clock frequencies<br>below the crystal oscillator<br>minimum require an external<br>clock driver | | T <sub>XIN</sub> | System Clock Period | 50 | _ | ns | T <sub>CLK</sub> = 1/F <sub>sysclk</sub> | | T <sub>XINH</sub> | System Clock High Time | 20 | 30 | ns | T <sub>CLK</sub> = 50 ns | | T <sub>XINL</sub> | System Clock Low Time | 20 | 30 | ns | T <sub>CLK</sub> = 50 ns | | T <sub>XINR</sub> | System Clock Rise Time | _ | 3 | ns | T <sub>CLK</sub> = 50 ns | | T <sub>XINF</sub> | System Clock Fall Time | _ | 3 | ns | T <sub>CLK</sub> = 50 ns | PS022825-0908 Electrical Characteristics zilog 240 PS022825-0908 Electrical Characteristics Figure 43 displays the 20-pin Small Outline Integrated Circuit Package (SOIC) available for the Z8 Encore! XP F082A Series devices. | CVALDOI | MILLI | METER | INCH | | | | | | |---------|-------|-------|------|------|--|--|--|--| | SYMBOL | MIN | MAX | MIN | MAX | | | | | | Α | 2.40 | 2.65 | .094 | .104 | | | | | | A1 | 0.10 | 0.30 | .004 | .012 | | | | | | A2 | 2.24 | 2.44 | .088 | .096 | | | | | | В | 0.36 | 0.46 | .014 | .018 | | | | | | С | 0.23 | 0.30 | .009 | .012 | | | | | | D | 12.60 | 12.95 | .496 | .510 | | | | | | E | 7.40 | 7.60 | .291 | .299 | | | | | | е | 1.27 | BSC | .050 | BSC | | | | | | Н | 10.00 | 10.65 | .394 | .419 | | | | | | h | 0.30 | 0.40 | .012 | .016 | | | | | | L | 0.60 | 1.00 | .024 | .039 | | | | | | Q1 | 0.97 | 1.07 | .038 | .042 | | | | | CONTROLLING DIMENSIONS : MM LEADS ARE COPLANAR WITHIN .004 INCH. Figure 43. 20-Pin Small Outline Integrated Circuit Package (SOIC) PS022825-0908 Packaging 265 | L | MULT 203 | |------------------------------------------------|----------------------------------| | LD 205 | multiply 203 | | LDC 205 | multiprocessor mode, UART 103 | | LDCI 204, 205 | | | LDE 205 | | | LDEI 204, 205 | N | | LDX 205 | NOP (no operation) 204 | | LEA 205 | notation | | load 205 | b 201 | | load constant 204 | cc 201 | | load constant to/from program memory 205 | DA 201 | | load constant with auto-increment addresses | ER 201 | | 205 | IM 201 | | load effective address 205 | IR 201 | | load external data 205 | Ir 201 | | load external data to/from data memory and | IRR 201 | | auto-increment addresses 204 | Irr 201 | | load external to/from data memory and auto-in- | p 201 | | crement addresses 205 | R 201 | | load using extended addressing 205 | r 201 | | logical AND 205 | RA 201 | | logical AND/extended addressing 205 | RR 201 | | logical exclusive OR 206 | rr 201 | | logical exclusive OR/extended addressing 206 | vector 201 | | logical instructions 205 | X 201 | | logical OR 205 | notational shorthand 201 | | logical OR/extended addressing 206 | | | low power modes 33 | 0 | | | 0 | | | OCD | | M | architecture 173 | | master interrupt enable 57 | auto-baud detector/generator 176 | | memory | baud rate limits 177 | | data 17 | block diagram 173 | | program 15 | breakpoints 178 | | mode | commands 179 | | CAPTURE 85, 86 | control register 184 | | CAPTURE/COMPARE 85 | data format 176 | | CONTINUOUS 84 | DBG pin to RS-232 Interface 174 | | COUNTER 84 | debug mode 175 | | GATED 85 | debugger break 206 | | ONE-SHOT 84 | interface 174 | | PWM 85 | serial errors 177 | | modes 85 | status register 185 | | | | PS022825-0908 Index