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 | 5MHz | | Connectivity | IrDA, UART/USART | | Peripherals | Brown-out Detect/Reset, LED, POR, PWM, WDT | | Number of I/O | 16 | | Program Memory Size | 4KB (4K x 8) | | Program Memory Type | FLASH | | EEPROM Size | - | | RAM Size | 1K x 8 | | Voltage - Supply (Vcc/Vdd) | 2.7V ~ 3.6V | | Data Converters | A/D 7x10b | | Oscillator Type | Internal | | Operating Temperature | 0°C ~ 70°C (TA) | | Mounting Type | Surface Mount | | Package / Case | 20-SOIC (0.295", 7.50mm Width) | | Supplier Device Package | - | | Purchase URL | https://www.e-xfl.com/product-detail/zilog/z8f0423sh005sg | # **Table of Contents** | Revision History | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | List of Figures | | List of Tables | | Overview Features Part Selection Guide Block Diagram CPU and Peripheral Overview General-Purpose I/O Flash Controller Internal Precision Oscillator 10-Bit Analog-to-Digital Converter Analog Comparator Universal Asynchronous Receiver/Transmitter Timers Interrupt Controller Reset Controller On-Chip Debugger | | Pin Description | | Address Space 13 Register File 13 Program Memory 13 Data Memory 15 Flash Information Area 15 | | Register Map | | Reset and Stop Mode Recovery 21 Reset Types 21 Reset Sources 23 Power-On Reset 23 | | Voltage Brown-Out Reset | ### **CPU and Peripheral Overview** The eZ8 CPU, Zilog's latest 8-bit central processing unit (CPU), meets the continuing demand for faster and code-efficient microcontrollers. The eZ8 CPU executes a superset of the original Z8 instruction set. The eZ8 CPU features include: - Direct register-to-register architecture allows each register to function as an accumulator, improving execution time and decreasing the required program memory - Software stack allows much greater depth in subroutine calls and interrupts than hardware stacks - Compatible with existing Z8 code - Expanded internal Register File allows access of up to 4 KB - New instructions improve execution efficiency for code developed using higher-level programming languages, including C - Pipelined instruction fetch and execution - New instructions for improved performance including BIT, BSWAP, BTJ, CPC, LDC, LDCI, LEA, MULT, and SRL - New instructions support 12-bit linear addressing of the Register File - Up to 10 MIPS operation - C-Compiler friendly - 2 to 9 clock cycles per instruction For more information about the eZ8 CPU, refer to the eZ8 CPU Core User Manual (UM0128) available for download at www.zilog.com. ### General-Purpose I/O F0823 Series features 6 to 24 port pins (Ports A-C) for general-purpose I/O (GPIO). The number of GPIO pins available is a function of package. Each pin is individually programmable. 5 V-tolerant input pins are available on all I/Os on 8-pin devices, most I/Os on other package types. #### Flash Controller The Flash Controller programs and erases Flash memory. The Flash Controller supports protection against accidental program and erasure, as well as factory serialization and read protection. Figure 2. Z8F08x3, Z8F04x3, F02x3 and Z8F01x3 in 8-Pin SOIC, QFN/MLF-S, or PDIP Package\* Figure 3. Z8F08x3, Z8F04x3, F02x3 and Z8F01x3 in 20-Pin SOIC, SSOP or PDIP Package\* Figure 4. Z8F08x3, Z8F04x3, F02x3 and Z8F01x3 in 28-Pin SOIC, SSOP or PDIP Package\* **Table 3. Signal Descriptions (Continued)** | Signal Mnemonic | I/O | Description | |-------------------------------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | COUT | 0 | Comparator Output. This is the output of the comparator. | | Analog | | | | ANA[7:0] | I | Analog port. These signals are used as inputs to the ADC. The ANA0, ANA1, and ANA2 pins can also access the inputs and output of the integrated transimpedance amplifier. | | VREF | I/O | Analog-to-Digital Converter reference voltage input. | | Clock Input | | | | CLKIN | I | Clock Input Signal. This pin can be used to input a TTL-level signal to be used as the system clock. | | LED Drivers | | | | LED | 0 | Direct LED drive capability. All port C pins have the capability to drive an LED without any other external components. These pins have programmable drive strengths set by the GPIO block. | | On-Chip Debugger | | | | DBG | I/O | Debug. This signal is the control and data input and output to and from the OCD. Caution: The DBG pin is open-drain and requires an external pull-up resistor to ensure proper operation. | | Reset | | | | RESET | I/O | RESET. Generates a reset when asserted (driven Low). Also serves as a reset indicator; the Z8 Encore! XP forces this pin Low when in reset. This pin is open-drain and features an enabled internal pull-up resistor. | | Power Supply | | | | $V_{DD}$ | ļ | Digital Power Supply. | | AV <sub>DD</sub> <sup>2</sup> | I | Analog Power Supply. | | V <sub>SS</sub> | I | Digital Ground. | | AV <sub>SS</sub> | I | Analog Ground. | | Notos: | | | - 1. PB6 and PB7 are only available in 28-pin packages without ADC. In 28-pin packages with ADC, they are - replaced by AV<sub>DD</sub> and AV<sub>SS</sub>. 2. The AV<sub>DD</sub> and AV<sub>SS</sub> signals are available only in 28-pin packages with ADC. They are replaced by PB6 and PB7 on 28-pin packages without ADC. Table 5 provides detailed information about the characteristics for each pin available on Z8 Encore! XP F0823 Series 8-pin devices. **Table 5. Pin Characteristics (8-Pin Devices)** | Symbol<br>Mnemonic | Direction | Reset<br>Direction | Active<br>Low<br>or<br>Active<br>High | Tristate<br>Output | Internal<br>Pull-up<br>or Pull-<br>down | Schmitt-<br>Trigger<br>Input | Open Drain<br>Output | 5V<br>Tolerance | |--------------------|-----------|----------------------------------------------------------------------------|---------------------------------------|--------------------|------------------------------------------------------------|------------------------------|------------------------------------------------------|------------------------------------| | PA0/DBG | I/O | I (but can<br>change<br>during<br>reset if<br>key<br>sequence<br>detected) | N/A | Yes | Program-<br>mable<br>Pull-up | Yes | Yes,<br>Programmable | Yes, unless<br>pull-ups<br>enabled | | PA1 | I/O | I | N/A | Yes | Program-<br>mable<br>Pull-up | Yes | Yes,<br>Programmable | Yes, unless<br>pull-ups<br>enabled | | RESET/PA2 | I/O | I/O<br>(defaults<br>to<br>RESET) | N/A | Yes | Program-<br>mable for<br>PA2;<br>always<br>on for<br>RESET | Yes | Programma-<br>ble for PA2;<br>always on for<br>RESET | Yes, unless<br>pull-ups<br>enabled | | PA[5:3] | I/O | I | N/A | Yes | Program-<br>mable<br>Pull-up | Yes | Yes,<br>Programmable | Yes, unless<br>pull-ups<br>enabled | | VDD | N/A | VSS | N/A Table 8. Register File Address Map (Continued) | Address (Hex) | Register Description | Mnemonic | Reset (Hex) | Page<br>No. | |--------------------|--------------------------|----------|-------------|-------------| | LED Controller ( | (cont'd) | | | | | F84 | LED Drive Level Low Byte | LEDLVLL | 00 | <u>53</u> | | F85 | Reserved | _ | XX | | | Oscillator Contr | ol | | | | | F86 | Oscillator Control | OSCCTL | A0 | <u>172</u> | | F87–F8F | Reserved | _ | XX | | | Comparator 0 | | | | | | F90 | Comparator 0 Control | CMP0 | 14 | 133 | | F91–FBF | Reserved | _ | XX | | | Interrupt Contro | ller | | | | | FC0 | Interrupt Request 0 | IRQ0 | 00 | <u>59</u> | | FC1 | IRQ0 Enable High Bit | IRQ0ENH | 00 | <u>62</u> | | FC2 | IRQ0 Enable Low Bit | IRQ0ENL | 00 | <u>62</u> | | FC3 | Interrupt Request 1 | IRQ1 | 00 | <u>60</u> | | FC4 | IRQ1 Enable High Bit | IRQ1ENH | 00 | <u>64</u> | | FC5 | IRQ1 Enable Low Bit | IRQ1ENL | 00 | <u>64</u> | | FC6 | Interrupt Request 2 | IRQ2 | 00 | <u>61</u> | | FC7 | IRQ2 Enable High Bit | IRQ2ENH | 00 | <u>65</u> | | FC8 | IRQ2 Enable Low Bit | IRQ2ENL | 00 | <u>66</u> | | FC9-FCC | Reserved | _ | XX | | | FCD | Interrupt Edge Select | IRQES | 00 | <u>67</u> | | FCE | Shared Interrupt Select | IRQSS | 00 | <u>67</u> | | FCF | Interrupt Control | IRQCTL | 00 | <u>68</u> | | <b>GPIO Port A</b> | | | | | | FD0 | Port A Address | PAADDR | 00 | 40 | | FD1 | Port A Control | PACTL | 00 | <u>42</u> | | FD2 | Port A Input Data | PAIN | XX | <u>43</u> | | FD3 | Port A Output Data | PAOUT | 00 | <u>43</u> | | GPIO Port B | | | | _ | | FD4 | Port B Address | PBADDR | 00 | <u>40</u> | | FD5 | Port B Control | PBCTL | 00 | <u>42</u> | Note: XX=Undefined. #### **Reset Sources** Table 10 lists the possible sources of a System Reset. Table 10. Reset Sources and Resulting Reset Type | Operating Mode | Reset Source | Special Conditions | |----------------------|----------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------| | NORMAL or HALT modes | Power-On Reset/Voltage Brown-Out. | Reset delay begins after supply voltage exceeds POR level. | | | Watchdog Timer time-out when configured for Reset. | None. | | | RESET pin assertion. | All reset pulses less than three system clocks in width are ignored. | | | OCD initiated Reset (OCDCTL[0] set to 1). | System Reset, except the OCD is unaffected by the reset. | | STOP Mode | Power-On Reset/Voltage Brown-Out. | Reset delay begins after supply voltage exceeds POR level. | | | RESET pin assertion. | All reset pulses less than the specified analog delay are ignored. See the <u>Electrical Characteristics chapter on page 196</u> . | | | DBG pin driven Low. | None. | #### **Power-On Reset** Each device in the Z8 Encore! XP F0823 Series contains an internal POR circuit. The POR circuit monitors the supply voltage and holds the device in the Reset state until the supply voltage reaches a safe operating level. After the supply voltage exceeds the POR voltage threshold $(V_{POR})$ , the device is held in the Reset state until the POR Counter has timed out. If the crystal oscillator is enabled by the option bits, this time-out is longer. After the Z8 Encore! XP F0823 Series device exits the POR state, the eZ8 CPU fetches the Reset vector. Following the POR, the POR status bit in Watchdog Timer Control (WDTCTL) Register is set to 1. Figure 5 displays POR operation. For the POR threshold voltage ( $V_{POR}$ ), see the <u>Electrical Characteristics</u> chapter on page 196. 74 **Caution:** The frequency of the comparator output signal must not exceed one-fourth the system clock frequency. After reaching the reload value stored in the Timer Reload High and Low Byte registers, the timer generates an interrupt, the count value in the Timer High and Low Byte registers is reset to 0001H and counting resumes. 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 reload. Observe the following steps to configure a timer for COMPARATOR COUNTER Mode and initiating the count: - 1. Write to the Timer Control Register to: - Disable the timer. - Configure the timer for COMPARATOR COUNTER Mode. - Select either the rising edge or falling edge of the comparator output signal for the count. This also sets the initial logic level (High or Low) for the Timer Output alternate function. However, the Timer Output function is not required to be enabled. - 2. Write to the Timer High and Low Byte registers to set the starting count value. This action only affects the first pass in COMPARATOR COUNTER Mode. After the first timer reload in COMPARATOR COUNTER Mode, counting always begins at the reset value of 0001H. Generally, in COMPARATOR COUNTER Mode the Timer High and Low Byte registers must be written with the value 0001H. - 3. Write to the Timer Reload High and Low Byte registers to set the reload value. - 4. If appropriate, enable the timer interrupt 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. In COMPARATOR COUNTER Mode, the number of comparator output transitions since the timer start is computed via the following equation: Comparator Output Transitions = Current Count Value - Start Value #### **UART Control 0 and Control 1 Registers** The UART Control 0 and Control 1 registers (Table 68 and Table 69) configure the properties of the UART's transmit and receive operations. The UART Control registers must not be written while the UART is enabled. Table 68. UART Control 0 Register (U0CTL0) | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | |---------|-----|-----|------|-----|---------|------|------|------|--| | Field | TEN | REN | CTSE | PEN | PSEL | SBRK | STOP | LBEN | | | RESET | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | R/W | R/W | R/W | R/W | R/W | R/W R/W | | R/W | R/W | | | Address | | | | F4 | 2H | | | | | | Bit | Description | |-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | [7]<br>TEN | Transmit Enable This bit enables or disables the transmitter. The enable is also controlled by the CTS signal and the CTSE bit. If the CTS signal is low and the CTSE bit is 1, the transmitter is enabled. 0 = Transmitter disabled. 1 = Transmitter enabled. | | [6]<br>REN | Receive Enable This bit enables or disables the receiver. 0 = Receiver disabled. 1 = Receiver enabled. | | [5]<br>CTSE | CTSE—CTS Enable 0 = The CTS signal has no effect on the transmitter. 1 = The UART recognizes the CTS signal as an enable control from the transmitter. | | [4]<br>PEN | Parity Enable This bit enables or disables parity. Even or odd is determined by the PSEL bit. 0 = Parity is disabled. 1 = The transmitter sends data with an additional parity bit and the receiver receives an additional parity bit. | | [3]<br>PSEL | Parity Select 0 = Even parity is transmitted and expected on all received data. 1 = Odd parity is transmitted and expected on all received data. | | [2]<br>SBRK | Send Break This bit pauses or breaks data transmission. Sending a break interrupts any transmission in progress, so ensure that the transmitter has finished sending data before setting this bit. 0 = No break is sent. 1 = Forces a break condition by setting the output of the transmitter to zero. | Figure 19. Analog-to-Digital Converter Block Diagram ### **Operation** The output of the ADC is an 11-bit, signed, two's-complement digital value. The output generally ranges from 0 to $\pm 1023$ , but offset errors can cause small negative values. The ADC registers return 13 bits of data, but the two LSBs are intended for compensation use only. When the compensation routine is performed on the 13 bit raw ADC value, two bits of resolution are lost because of a rounding error. As a result, the final value is an 11-bit number. #### **Automatic Powerdown** If the ADC is idle (no conversions in progress) for 160 consecutive system clock cycles, portions of the ADC are automatically powered down. From this powerdown state, the ADC requires 40 system clock cycles to powerup. The ADC powers up when a conversion is requested by the ADC Control Register. #### **Single-Shot Conversion** When configured for single-shot conversion, the ADC performs a single analog-to-digital conversion on the selected analog input channel. After completion of the conversion, the ADC shuts down. Observe the following steps for setting up the ADC and initiating a single-shot conversion: - 1. Enable the acceptable analog inputs by configuring the general-purpose I/O pins for alternate function. This configuration disables the digital input and output drivers. - 2. Write the ADC Control/Status Register 1 to configure the ADC - Write the REFSELH bit of the pair {REFSELH, REFSELL} to select the internal voltage reference level or to disable the internal reference. The REFSELH bit is contained in the ADC Control/Status Register 1. - 3. Write to the ADC Control Register 0 to configure the ADC and begin the conversion. The bit fields in the ADC Control Register can be written simultaneously: - Write to the ANAIN[3:0] field to select from the available analog input sources (different input pins available depending on the device). - Clear CONT to 0 to select a single-shot conversion. - If the internal voltage reference must be output to a pin, set the REFEXT bit to 1. The internal voltage reference must be enabled in this case. - Write the REFSELL bit of the pair {REFSELH, REFSELL} to select the internal voltage reference level or to disable the internal reference. The REFSELL bit is contained in the ADC Control Register 0. - Set CEN to 1 to start the conversion. - 4. CEN remains 1 while the conversion is in progress. A single-shot conversion requires 5129 system clock cycles to complete. If a single-shot conversion is requested from an ADC powered-down state, the ADC uses 40 additional clock cycles to power-up before beginning the 5129 cycle conversion. - 5. When the conversion is complete, the ADC control logic performs the following operations: - 11-bit two's-complement result written to {ADCD\_H[7:0], ADCD\_L[7:5]} 14 - Programming operations are not limited to the page selected in the Page Select register - Bits in the Flash Sector Protect register can be written to one or zero - The second write of the Page Select register to unlock the Flash Controller is not necessary - The Page Select register can be written when the Flash Controller is unlocked - The Mass Erase command is enabled through the Flash Control Register - **Caution:** For security reasons, the Flash Controller allows only a single page to be opened for write/erase. When writing multiple Flash pages, the Flash controller must repeat the unlock sequence to select another page. ### **Flash Control Register Definitions** This section defines the features of the following Flash Control registers. Flash Control Register: see page 141 Flash Status Register: see page 143 <u>Flash Page Select Register</u>: see page 143 Flash Sector Protect Register: see page 145 Flash Frequency High and Low Byte Registers: see page 145 ### Flash Control Register The Flash Controller must be unlocked using the Flash Control (FTCTL) Register before programming or erasing the Flash memory. Writing the sequence 73H 8CH, sequentially, to the Flash Control Register unlocks the Flash Controller. When the Flash Controller is unlocked, the Flash memory can be enabled for Mass Erase or Page Erase by writing the appropriate enable command to the FCTL. Page Erase applies only to the active page selected in Flash Page Select register. Mass Erase is enabled only through the On-Chip Debugger. Writing an invalid value or an invalid sequence returns the Flash Controller to its locked state. The Write-only Flash Control Register shares its Register File address with the read-only Flash Status Register. 161 #### **OCD Unlock Sequence (8-Pin Devices Only)** Because of pin-sharing on the 8-pin device, an unlock sequence must be performed to access the DBG pin. If this sequence is not completed during a system reset, then the PAO/DBG pin functions only as a GPIO pin. The following sequence unlocks the DBG pin: - 1. Hold PA2/RESET Low. - 2. Wait 5 ms for the internal reset sequence to complete. - 3. Send the following bytes serially to the debug pin: ``` DBG \leftarrow 80H (autobaud) DBG \leftarrow EBH DBG \leftarrow 5AH DBG \leftarrow 70H DBG \leftarrow CDH (32-bit unlock key) ``` 4. Release PA2/RESET. The PA0/DBG pin is now identical in function to that of the DBG pin on the 20- or 28-pin device. To enter DEBUG Mode, reautobaud and write 80H to the OCD Control Register (see the On-Chip Debugger Commands section on page 162). ### **Breakpoints** Execution breakpoints are generated using the BRK instruction (opcode 00H). When the eZ8 CPU decodes a BRK instruction, it signals the OCD. If breakpoints are enabled, the OCD enters DEBUG Mode and idles the eZ8 CPU. If breakpoints are not enabled, the OCD ignores the BRK signal and the BRK instruction operates as an NOP instruction. #### **Breakpoints in Flash Memory** The BRK instruction is opcode 00H, which corresponds to the fully programmed state of a byte in Flash memory. To implement a breakpoint, write 00H to the required break address, overwriting the current instruction. To remove a breakpoint, the corresponding page of Flash memory must be erased and reprogrammed with the original data. #### **Runtime Counter** The OCD contains a 16-bit Runtime Counter. It counts system clock cycles between breakpoints. The counter starts counting when the OCD leaves DEBUG Mode and stops counting when it enters DEBUG Mode again or when it reaches the maximum count of FFFFH. **Table 117. Rotate and Shift Instructions (Continued)** | Mnemonic | Operands | Instruction | | | | | | |----------|----------|----------------------------|--|--|--|--|--| | RR | dst | Rotate Right | | | | | | | RRC dst | | Rotate Right through Carry | | | | | | | SRA | dst | Shift Right Arithmetic | | | | | | | SRL | dst | Shift Right Logical | | | | | | | SWAP | dst | Swap Nibbles | | | | | | ### **eZ8 CPU Instruction Summary** Table 118 summarizes the eZ8 CPU instruction set. The table identifies the addressing modes employed by the instruction, the effect upon the Flags Register, the number of CPU clock cycles required for the instruction fetch, and the number of CPU clock cycles required for the instruction execution. Table 118. eZ8 CPU Instruction Summary | Assembly | | Address<br>Mode | | _ Opcode(s) | Flags | | | | | | _ Fetch | Instr. | |---------------|--------------------------------|-----------------|-----|-------------|-------|---|---|---|---|---|---------|--------| | Mnemonic | <b>Symbolic Operation</b> | dst | src | (Hex) | С | Z | S | ٧ | D | Н | Cycles | Cycles | | ADC dst, src | dst ← dst + src + C | r | r | 12 | * | * | * | * | 0 | * | 2 | 3 | | | | r | lr | 13 | | | | | | | 2 | 4 | | | | R | R | 14 | • | | | | | | 3 | 3 | | | | R | IR | 15 | • | | | | | | 3 | 4 | | | | R | IM | 16 | • | | | | | | 3 | 3 | | | | IR | IM | 17 | • | | | | | | 3 | 4 | | ADCX dst, src | $dst \leftarrow dst + src + C$ | ER | ER | 18 | * | * | * | * | 0 | * | 4 | 3 | | | | ER | IM | 19 | • | | | | | | 4 | 3 | Note: Flags Notation: <sup>\* =</sup> Value is a function of the result of the operation. <sup>-</sup> = Unaffected. X = Undefined. <sup>0 =</sup> Reset to 0. <sup>1 =</sup> Set to 1. Table 118. eZ8 CPU Instruction Summary (Continued) | Assembly | | | dress<br>ode | _ Opcode(s) | Flags | | | | | | _ Fetch | Instr. | |---------------|------------------------------------------------------------------------------------------------------------------------------|-----|--------------|-------------|-------|---|------|---|---|---|---------|--------| | Mnemonic | Symbolic Operation | dst | src (Hex) | | С | Z | SVDF | | | Н | | Cycles | | 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 | Note: Flags Notation: <sup>\* =</sup> Value is a function of the result of the operation. <sup>-</sup> = Unaffected. X = Undefined. <sup>0 =</sup> Reset to 0. <sup>1 =</sup> Set to 1. | | | | | | | | | Lo | ower Nil | bble (He | x) | | | | | | | |--------------------|---|--------------------------|--------------------------|------------------------------|------------------------------|-----------------------------|-----------------------------|----------------------------|-----------------------------|-------------------------------|-----------------------|----------------------------|--------------------------|---------------------------|---------------------------|-------------------------|--------------------------| | | | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | Α | В | С | D | Е | F | | | 0 | 1.1<br>BRK | 2.2<br><b>SRP</b><br>IM | 2.3<br><b>ADD</b><br>r1,r2 | 2.4<br><b>ADD</b><br>r1,lr2 | 3.3<br><b>ADD</b><br>R2,R1 | 3.4<br><b>ADD</b><br>IR2,R1 | 3.3<br><b>ADD</b><br>R1,IM | 3.4<br><b>ADD</b><br>IR1,IM | 4.3<br>ADDX<br>ER2,ER1 | 4.3<br>ADDX<br>IM,ER1 | 2.3<br><b>DJNZ</b><br>r1,X | 2.2<br><b>JR</b><br>cc,X | 2.2<br><b>LD</b><br>r1,IM | 3.2<br><b>JP</b><br>cc,DA | 1.2<br><b>INC</b><br>r1 | 1.2<br><b>NOP</b> | | | 1 | 2.2<br><b>RLC</b><br>R1 | 2.3<br><b>RLC</b><br>IR1 | 2.3<br><b>ADC</b><br>r1,r2 | 2.4<br><b>ADC</b><br>r1,lr2 | 3.3<br><b>ADC</b><br>R2,R1 | 3.4<br><b>ADC</b><br>IR2,R1 | 3.3<br><b>ADC</b><br>R1,IM | 3.4<br><b>ADC</b><br>IR1,IM | 4.3<br>ADCX<br>ER2,ER1 | 4.3<br>ADCX<br>IM,ER1 | | | | | | See 2nd<br>Opcode<br>Map | | | 2 | 2.2<br><b>INC</b><br>R1 | 2.3<br><b>INC</b><br>IR1 | 2.3<br><b>SUB</b><br>r1,r2 | 2.4<br><b>SUB</b><br>r1,lr2 | 3.3<br><b>SUB</b><br>R2,R1 | 3.4<br><b>SUB</b><br>IR2,R1 | 3.3<br><b>SUB</b><br>R1,IM | 3.4<br><b>SUB</b><br>IR1,IM | 4.3<br><b>SUBX</b><br>ER2,ER1 | 4.3<br>SUBX<br>IM,ER1 | | | | | | 1 | | | 3 | 2.2<br><b>DEC</b><br>R1 | 2.3<br><b>DEC</b><br>IR1 | 2.3<br><b>SBC</b><br>r1,r2 | 2.4<br><b>SBC</b><br>r1,lr2 | 3.3<br><b>SBC</b><br>R2,R1 | 3.4<br><b>SBC</b><br>IR2,R1 | 3.3<br><b>SBC</b><br>R1,IM | 3.4<br>SBC<br>IR1,IM | 4.3<br><b>SBCX</b><br>ER2,ER1 | 4.3<br>SBCX<br>IM,ER1 | | | | | | | | | 4 | 2.2<br><b>DA</b> | 2.3<br><b>DA</b> | 2.3<br><b>OR</b> | 2.4<br><b>OR</b> | 3.3<br><b>OR</b> | 3.4<br><b>OR</b> | 3.3<br><b>OR</b> | 3.4<br><b>OR</b> | 4.3<br><b>ORX</b> | 4.3<br><b>ORX</b> | | | | | | | | | 5 | 2.2<br><b>POP</b> | 2.3<br><b>POP</b> | 2.3<br>AND | 2.4<br><b>AND</b> | 3.3<br><b>AND</b> | 3.4<br><b>AND</b> | 3.3<br><b>AND</b> | 3.4<br><b>AND</b> | 4.3<br><b>ANDX</b> | 4.3<br>ANDX | | | | | | 1.2<br><b>WDT</b> | | | 6 | 2.2<br>COM | 2.3<br><b>COM</b> | 2.3<br><b>TCM</b> | 2.4<br><b>TCM</b> | 3.3<br><b>TCM</b> | 3.4<br><b>TCM</b> | 3.3<br><b>TCM</b> | 3.4<br><b>TCM</b> | 4.3<br>TCMX | 4.3<br><b>TCMX</b> | | | | | | 1.2<br><b>STOP</b> | | e (Hex) | 7 | 2.2<br><b>PUSH</b> | 2.3<br><b>PUSH</b> | 2.3<br><b>TM</b> | r1,lr2<br>2.4<br><b>TM</b> | 3.3<br><b>TM</b> | 3.4<br><b>TM</b> | 3.3<br><b>TM</b> | 3.4<br><b>TM</b> | 4.3<br><b>TMX</b> | 4.3<br><b>TMX</b> | | | | | | 1.2<br><b>HALT</b> | | Upper Nibble (Hex) | 8 | 2.5<br><b>DECW</b> | 2.6<br><b>DECW</b> | 2.5<br><b>LDE</b> | r1,lr2<br>2.9<br><b>LDEI</b> | 3.2<br><b>LDX</b> | 3.3<br><b>LDX</b> | 3.4<br><b>LDX</b> | 3.5<br><b>LDX</b> | 3.4<br><b>LDX</b> | 3.4<br><b>LDX</b> | | | | | | 1.2<br><b>DI</b> | | Opp | 9 | 2.2<br><b>RL</b> | 2.3<br><b>RL</b> | 2.5<br><b>LDE</b> | 2.9<br>LDEI | 3.2<br><b>LDX</b> | 3.3<br><b>LDX</b> | 3.4<br><b>LDX</b> | 3.5<br><b>LDX</b> | 3.3<br><b>LEA</b> | 3.5<br><b>LEA</b> | | | | | | 1.2<br><b>El</b> | | | Α | 2.5<br>INCW | 2.6<br>INCW | 2.3<br><b>CP</b> | 2.4<br><b>CP</b> | 3.3<br><b>CP</b> | 3.4<br><b>CP</b> | 3.3<br><b>CP</b> | 3.4<br><b>CP</b> | r1,r2,X<br>4.3<br><b>CPX</b> | 4.3<br><b>CPX</b> | | | | | | 1.4<br><b>RET</b> | | | В | 2.2<br><b>CLR</b> | 2.3<br><b>CLR</b> | r1,r2<br>2.3<br><b>XOR</b> | r1,lr2<br>2.4<br><b>XOR</b> | 3.3<br><b>XOR</b> | 3.4<br><b>XOR</b> | 3.3<br><b>XOR</b> | 3.4<br><b>XOR</b> | 4.3<br><b>XORX</b> | 4.3<br>XORX | | | | | | 1.5<br>IRET | | | С | 2.2<br><b>RRC</b> | 2.3<br><b>RRC</b> | r1,r2<br>2.5<br><b>LDC</b> | r1,lr2<br>2.9<br><b>LDCI</b> | 2.3<br><b>JP</b> | 2.9<br><b>LDC</b> | R1,IM | 3.4<br><b>LD</b> | 3.2<br>PUSHX | IM,ER1 | | | | | | 1.2<br><b>RCF</b> | | | D | 2.2<br><b>SRA</b> | 2.3<br><b>SRA</b> | 2.5<br><b>LDC</b> | 2.9<br><b>LDCI</b> | 2.6<br>CALL | lr1,lrr2<br>2.2<br>BSWAP | 3.3<br>CALL | r1,r2,X<br>3.4<br><b>LD</b> | 3.2<br><b>POPX</b> | | | | | | | 1.2<br><b>SCF</b> | | | E | 2.2<br><b>RR</b> | 2.3<br><b>RR</b> | r2,Irr1<br>2.2<br><b>BIT</b> | 2.3<br><b>LD</b> | 3.2<br><b>LD</b> | R1<br>3.3<br><b>LD</b> | 3.2<br><b>LD</b> | r2,r1,X<br>3.3<br><b>LD</b> | 4.2<br><b>LDX</b> | 4.2<br><b>LDX</b> | | | | | | 1.2<br><b>CCF</b> | | | F | R1<br>2.2<br><b>SWAP</b> | 2.3<br><b>SWAP</b> | p,b,r1<br>2.6<br><b>TRAP</b> | r1,lr2<br>2.3<br><b>LD</b> | R2,R1<br>2.8<br><b>MULT</b> | 3.3<br><b>LD</b> | 3.3<br><b>BTJ</b> | 3.4<br><b>BTJ</b> | ER2,ER1 | IM,ER1 | | | | | | | | | ٢ | R1 | IR1 | Vector | Ir1,r2 | RR1 | R2,IR1 | | p,b,lr1,X | | | <b>V</b> | <b>V</b> | <b>V</b> | <b>V</b> | ▼ | | Figure 27. First Opcode Map Figure 28. Second Opcode Map after 1FH ## Electrical Characteristics The data in this chapter represents all known data prior to qualification and characterization of the F0823 Series of products, and is therefore subject to change. Additional electrical characteristics may be found in the individual chapters of this document. ### **Absolute Maximum Ratings** Stresses greater than those listed in Table 120 may cause permanent damage to the device. These ratings are stress ratings only. Operation of the device at any condition outside those indicated in the operational sections of these specifications is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability. For improved reliability, tie unused inputs to one of the supply voltages ( $V_{DD}$ or $V_{SS}$ ). **Table 120. Absolute Maximum Ratings** | Parameter | Minimum | Maximum | Units | Notes | |----------------------------------------------------------------|---------|---------|-------|-------| | Ambient temperature under bias | -40 | +105 | °C | | | Storage temperature | -65 | +150 | °C | | | Voltage on any pin with respect to V <sub>SS</sub> | -0.3 | +5.5 | V | 1 | | | -0.3 | +3.9 | V | 2 | | Voltage on V <sub>DD</sub> pin with respect to V <sub>SS</sub> | -0.3 | +3.6 | V | | | Maximum current on input and/or inactive output pin | -5 | +5 | μA | | | Maximum output current from active output pin | -25 | +25 | mA | | | 8-pin Packages Maximum Ratings at 0°C to 70°C | | | | | | Total power dissipation | | 220 | mW | | | Maximum current into V <sub>DD</sub> or out of V <sub>SS</sub> | | 60 | mA | | | 20-pin Packages Maximum Ratings at 0°C to 70°C | | | | | | Total power dissipation | | 430 | mW | | | Maximum current into V <sub>DD</sub> or out of V <sub>SS</sub> | | 120 | mA | | | 28-pin Packages Maximum Ratings at 0°C to 70°C | | | | | | Total power dissipation | | 450 | mW | | | Maximum current into V <sub>DD</sub> or out of V <sub>SS</sub> | | 125 | mA | | Notes: Operating temperature is specified in DC Characteristics. - This voltage applies to all pins except the following: V<sub>DD</sub>, AV<sub>DD</sub>, pins supporting analog input (Port B[5:0], Port C[2:0]) and pins supporting the crystal oscillator (PA0 and PA1). On the 8-pin packages, this applies to all pins but V<sub>DD</sub>. - 2. This voltage applies to pins on the 20/28 pin packages supporting analog input (Port B[5:0], Port C[2:0]) and pins supporting the crystal oscillator (PA0 and PA1). **Table 121. DC Characteristics (Continued)** | | | T <sub>A</sub> = -40°C to +105°C<br>(unless otherwise specified) | | | | | |-------------------|---------------------------------------|------------------------------------------------------------------|------------------|---------|-------|-------------------------------------------------------------------------------| | Symbol | Parameter | Minimum | Typical | Maximum | Units | Conditions | | I <sub>LED</sub> | Controlled Current<br>Drive | 1.8 | 3 | 4.5 | mA | $\{AFS2,AFS1\} = \{0,0\}.$ | | | | 2.8 | 7 | 10.5 | mA | $\{AFS2,AFS1\} = \{0,1\}.$ | | | | 7.8 | 13 | 19.5 | mΑ | $\{AFS2,AFS1\} = \{1,0\}.$ | | | | 12 | 20 | 30 | mΑ | {AFS2,AFS1} = {1,1}. | | C <sub>PAD</sub> | GPIO Port Pad<br>Capacitance | _ | 8.0 <sup>2</sup> | _ | pF | | | C <sub>XIN</sub> | X <sub>IN</sub> Pad Capaci-<br>tance | _ | 8.0 <sup>2</sup> | - | pF | | | C <sub>XOUT</sub> | X <sub>OUT</sub> Pad Capaci-<br>tance | _ | 9.5 <sup>2</sup> | - | pF | | | I <sub>PU</sub> | Weak Pull-up Cur-<br>rent | 30 | 100 | 350 | μΑ | V <sub>DD</sub> = 3.0V–3.6V. | | V <sub>RAM</sub> | RAM Data Retention Voltage | TBD | | | V | Voltage at which RAM retains static values; no reading or writing is allowed. | #### Notes: - 1. This condition excludes all pins that have on-chip pull-ups, when driven Low. - 2. These values are provided for design guidance only and are not tested in production. | compare with carry - extended addressing 178 | Watchdog Timer 202, 204 | |----------------------------------------------|-------------------------------------------| | complement 181 | enable interrupt 180 | | complement carry flag 179, 180 | ER 176 | | condition code 176 | extended addressing register 176 | | continuous conversion (ADC) 124 | external pin reset 25 | | CONTINUOUS mode 88 | eZ8 CPU features 4 | | control register definition, UART 108 | eZ8 CPU instruction classes 178 | | Control Registers 13, 16 | eZ8 CPU instruction notation 176 | | COUNTER modes 89 | eZ8 CPU instruction set 174 | | CP 178 | eZ8 CPU instruction summary 182 | | CPC 178 | | | CPCX 178 | | | CPU and peripheral overview 4 | F | | CPU control instructions 180 | FCTL register 141, 148, 149 | | CPX 178 | features, Z8 Encore! 1 | | Customer Support 230 | first opcode map 194 | | | FLAGS 177 | | | flags register 177 | | D | flash | | DA 176, 178 | controller 4 | | data memory 15 | option bit address space 149 | | DC characteristics 197 | option bit configuration - reset 146 | | debugger, on-chip 156 | program memory address 0000H 149 | | DEC 178 | program memory address 0001H 150 | | decimal adjust 178 | flash memory 134 | | decrement 178 | arrangement 135 | | decrement and jump non-zero 181 | byte programming 139 | | decrement word 178 | code protection 137 | | DECW 178 | configurations 134 | | destination operand 177 | control register definitions 141, 148 | | device, port availability 33 | controller bypass 140 | | DI 180 | electrical characteristics and timing 202 | | direct address 176 | flash control register 141, 148, 149 | | disable interrupts 180 | flash option bits 138 | | DJNZ 181 | flash status register 142 | | dst 177 | flow chart 136 | | | frequency high and low byte registers 144 | | | mass erase 139 | | E | operation 135 | | EI 180 | operation timing 137 | | electrical characteristics 196 | page erase 139 | | ADC 203 | page select register 142, 144 | | flash memory and timing 202 | FPS register 142, 144 | | GPIO input data sample timing 204 | FSTAT register 142 | | or roughly and sample anning 201 | $\mathcal{E}$ |