PRELIMINARY PRODUCT SPECIFICATION T-52-33-53 # **Z86C06** CMOS Z8® CCP™ CONSUMER CONTROLLER PROCESSOR #### **FEATURES** - 8-bit CMOS microcontroller - 18-pin DIP package - Low Cost - 3.0 to 5.5 volt operating range - Fast instruction pointer 1.0 microseconds @ 12 MHz - Two standby modes STOP and HALT - 14 input/output lines (two with Comparator inputs) - 1 Kbyte of ROM - 124 bytes of RAM - Four Expanded Register File Control Registers and two SPI Registers - Two programmable 8-bit Counter/Timers - 6-bit programmable prescaler - Six vectored, priority interrupts from five different sources - Clock speeds 4, 8, and 12 MHz - Brown-Out protection - Watchdog/Power-On Reset Timer - Two Comparators with programmable interrupt polarity - On-chip oscillator that accepts a crystal, ceramic resonator, LC, RC, or external clock drive. - Serial Peripheral Interface (SPI) - Low EMI Noise Mode - Up to -40°C to 105°C operation #### **GENERAL DESCRIPTION** The Z86C06 CCP (Consumer Controller Processor) is a member of the Z8 single-chip microcontroller family with 1 Kbyte of ROM, and 124 bytes of General Purpose RAM. The device is housed in an 18-pin DIP, and is manufactured in CMOS technology. Zilog's CMOS microcontroller offers fast execution, efficient use of memory, sophisticated interrupts, input/output bit manipulation capabilities, and easy hardware/software system expansion along with low cost and low power consumption. The Z86C06 architecture is based on Zilog's 8-bit microcontroller core with the addition of an Expanded Register File which allows access to register mapped peripheral and I/O circuits. The CCP offers a flexible I/O scheme, and a number of ancillary features that are useful in many consumer, industrial, automotive, and advanced scientific applications. The device applications demand powerful I/O capabilities. The CCP fulfills this with 14 pins dedicated to input and output. These lines are grouped into two ports, and are configurable under software control to provide timing, status signals, or parallel I/O. Three basic address spaces are available to support this wide range of configurations; Program Memory, Register File, and Expanded Register File. The Register File is composed of 124 bytes of General-Purpose Registers, two I/O Port registers and fifteen Control and Status registers. The Expanded Register File consists of four control registers, SPI Receive Buffer, and the SPI compare register. # **GENERAL DESCRIPTION** (Continued) T-52-33-53 With powerful peripheral features such as on-board comparators, counter/timers, watch dog timer, and serial peripheral interface, the Z86C06 meets the needs for most sophisticated controller applications (Figure 1). Note: All Signals with a preceding front slash, "/", are active Low, e.g.: B//W (WORD is active Low); /B//W (BYTE is active Low, only); /N//S (NORMAL and SYSTEM are both active Low). Figure 1. Functional Block Diagram #### **PIN DESCRIPTION** Table 1. Pin Identification | No | Symbol | Function | Direction | |-------|--------|--------------------------|--------------| | 1-4 | P24-7 | Port 2 pin 4, 5, 6, 7 | In/Output | | 5 | VCC | Power Supply | Input | | 6 | XTAL2 | Crystal Oscillator Clock | Output | | 7 | XTAL1 | Crystal Oscillator Clock | Input | | 8-10 | P31-3 | Port 3 pin 1, 2, 3 | Fixed Input | | 11-13 | P34-6 | Port 3 pin 4, 5, 6 | Fixed Output | | 14 | GND | Ground | Input | | 15-18 | P20-3 | Port 2 pin 0, 1, 2, 3 | In/Output | Figure 2. Pin Configuration #### **PIN FUNCTIONS** XTAL1. Crystal 1 (time-based input). This pin connects a parallel-resonant crystal, ceramic resonator, LC or RC network or an external single-phase clock to the on-chip oscillator input. XTAL2. Crystal 2 (time-based output). This pin connects a parallel-resonant crystal, ceramic resonator, LC or RC network to the on-chip oscillator output. Port 2 P20-P27. Port 2 is an 8-bit, bi-directional, CMOS compatible I/O port. These 8 I/O lines can be configured under software control to be an input or output, independently. Input buffers are Schmitt-triggered and contain Auto-Latches. Bits programmed as outputs may be globally programmed as either push-pull or open drain (Figure 3a and 3b). In addition when the SPI is enabled, P20 functions as data-in (DI), and P27 functions as data-out (DO) for the SPI. PIN FUNCTIONS (Continued) Figure 3a. Port 2 Configuration Figure 3b. Port 2 Configuration ### PIN FUNCTIONS (Continued) T-52-33-53 Auto-Latch. The Auto-Latch puts valid CMOS levels on all CMOS inputs that are not externally driven. Whether this level is zero or one cannot be determined. A valid CMOS level rather than a floating node reduces excessive supply current flow in the input buffer. Port 3 P31-P36. Port 3 is a 6-bit, CMOS compatible, port. These six lines consist of three fixed inputs (P31-P33) and three fixed outputs (P34-P36). Pins P31, P32 and P33 are standard CMOS inputs (no auto-latches) and pins P34, P35, and P36 are push-pull outputs. Two on-board com- parators can process analog signals on P31 and P32 with reference to the voltage on P33. The analog function is enabled by programming Port 3 Mode Register (bit 1). Pins P31 and P32 are programmable as falling, rising, or both edge triggered interrupts (IRQ register bits 6 and 7). P33 is the comparator reference voltage input. Access to Counter/Timer 1 is made through P31 (Tin) and P36 (Tout). Pin P34 can also be configured as SPI clock (SK), input and output, and pin P35 can be configured as Slave select (SS) in slave mode only, when the SPI is enabled (Figures 4a. and 4b.). Figure 4a. Port 3 Configuration Figure 4b. Port 3 Configuration PORT Configuration Register (PCON). The PORT Configuration Register (PCON) configures the port's individually for; comparator output on Port 3, low EMI noise on Port's 2 and 3, and low EMI noise oscillator. The PCON Register is located in the Expanded Register File at bank F, location 00 (Figure 5). Bit 0 controls the comparator use in Port 3. A 1 in this location brings the comparator outputs to P34 and P35 (Figure 4b), and a 0 releases the Port to its standard I/O configuration. Bits 5 and 6 of this register configure Port's 2 and 3, respectively, for low EMI operation. A 1 in these locations configures the port for standard operation, and a 0 configures the port for low EMI operation. Finally, bit 7 of the PCON Register controls the low EMI noise oscillator. A 1 in this location configures the oscillator with standard drive, while a 0 configures the oscillator with low noise drive. #### PIN FUNCTIONS (Continued) Low EMI Option. The Z86C06 can be programmed to operate in a low EMI emission mode by the PCON register. The oscillator and all I/O ports can be programmed as low EMI emission mode independently. Use of this feature results in: - Less than 1 mA current consumption during the HALT mode. - The pre-drivers slew rate reduced to 10 ns typical. - Low EMI output drivers have resistance of 200 ohrns (lypical). - Oscillator divide-by-two circuitry is eliminated. - Internal SLCK/TCLK operation limited to a maximum of 4 MHz (250 ns cycle time) Comparator Inputs. Port 3, Pin P31 and Pin P32 each have a comparator front end. The comparator reference voltage, Pin P33, is common to both comparators. In analog mode, the P33 input functions as a reference voltage to the comparators. The internal P33 register and its corresponding IRQ1 is connected to the STOP Mode Recovery source selected by the SMR. In this mode, any of the STOP Mode T-52-33-53 Recovery sources are used to toggle the P33 bit or generate IRQ1. In digital mode, Pin P33 can be used as a P33 register input or IRQ1 source (Figure 17). Figure 5. PORT Configuration Register (PCON) # T-52-33-53 #### **FUNCTIONAL DESCRIPTION** The Z8 CCP incorporates special functions to enhance the Z8's application in consumer, automotive, industrial, scientific research, and advanced technologies applications. RESET. The device is reset in one of the following conditions: - Power-On Reset - Watch-Dog Timer - STOP Mode Recovery Source The device does not re-initialize the WDTMR, SMR, P2M, or P3M registers to their reset values on a STOP Mode Recovery operation. Program Memory. Z86C06 can address up to 1 Kbytes of internal program memory (Figure 6). The first 12 bytes of program memory are reserved for the interrupt vectors. These locations contain six 16-bit vectors that correspond to the six available interrupts. Byte 13 to byte 1023 consists of on-chip, mask-programmed ROM. ROM Protect. The 1 Kbytes of Program Memory is mask programmable. A ROM protect feature will prevent "dumping" of the ROM contents by inhibiting execution of the LDC and LDCI instructions to program memory in all modes. Expanded Register File. The register file has been expanded to allow for additional system control registers and for mapping of additional peripheral devices and input/output ports into the register address area. The Z8 register address space R0 through R15 is implemented as 16 groups of 16 registers per group (Figure 7). These register groups are known as the ERF (Expanded Register File). Bits 3:0 of the Register Pointer (RP) select the active ERF group. Bits 7:4 of register RP select the working register group (Figure 8). Three system configuration registers reside in the Expanded Register File address space in Bank F, while three SPI registers reside in Bank C. The rest of the Expanded Register addressing space is not physically implemented, and is open for future expansion. To write to the ERF, the upper nibble of the RP must be zero. To write to the rest of the register file, the lower nibble must be zero. #### Note When using Zilog's cross assembler Version 2.1 or earlier, use the LD RP, #0X instruction rather than the SRP #0X instruction to access the ERF. Figure 6. Program Memory Map Figure 7. Expanded Register File Architecture Note: Default Setting After Reset = 00000000 Figure 8. Register Pointer Register Register File. The Register File consists of two I/O port registers, 124 general purpose registers, 15 control and status registers, and four system configuration registers in the Expanded Register Group (Figure 7). The instructions can access registers directly or indirectly via an 8-bit address field. This allows a short 4-bit register address using the Register Pointer (Figure 9). In the 4-bit mode, the Register File is divided into 16 working register groups, each occupying 16 continuous locations. The Register Pointer addresses the starting location of the active working-register group. T-52-33-53 **Note:** Register Bank E0-EF is only accessed through working registers and indirect addressing modes. Caution: D4 of Control Register P01M (R251) must be 0. If the Z86C06 is emulated by Z86C90, D4 of P01M has to change to 0 before submission to ROM code. **GPR.** The Z86C06 has one extra General Purpose Register located at %FE(R254). Figure 9. Register Pointer T-52-33-53 Stack. The Z86C06 has an 8-bit Stack Pointer (R255) used for the internal stack that resides within the 124 general-purpose registers. Counter/Timers. There are two 8-bit programmable counter/timers (T0-T1), each driven by its own 6-bit programmable prescaler. The T1 prescaler can be driven by internal or external clock sources, however, the T0 prescaler is driven by the internal clock only (Figure 10). Figure 10. Counter/Timer Block Diagram T-52-33-53 The 6-bit prescalers divide the input frequency of the clock source by any integer number from 1 to 64. Each prescaler drives its counter, which decrements the value (1 to 256) that has been loaded into the counter. When the counter reaches the end of count, a timer interrupt request-IRQ4 (T0) or IRQ5 (T1), is generated. The counters are programmed to start, stop, restart to continue, or restart from the initial value. The counters can also be programmed to stop upon reaching zero (single-pass mode) or to automatically reload the initial value and continue counting (modulo-n continuous mode). The counters, but not the prescalers, are read at any time without disturbing their value or count mode. The clock source for T1 is user-definable and can be either the internal microprocessor clock divided by four, or an external signal input via Port 3. The Timer Mode register configures the external timer input (P31) as an external clock, a trigger input that can be retriggerable or non-retriggerable, or as a gate input for the internal clock. Port 3, line P36 serves as a timer output (Tout) through which T0, T1 or the internal clock can be output. The counter/timers can be cascaded by connecting the T0 output to the input of T1. Interrupts. The Z86C06 has six different interrupts from six different sources. The interrupts are mask-able and prioritized (Figure 11). The six sources are divided as follows; three sources are claimed by Port 3 lines P31-P33, two sources in the counter/timers, and one source for the SPI. The Interrupt Mask Register globally or singularly enables or disables the six interrupt requests (Table 2). Figure 11. Interrupt Block Diagram T-52-33-53 Table 2. Interrupt Types, Sources, and Vectors | Name | Source | Vector Location | Comments | |---------|------------------------|-----------------|-----------------------------------------------| | IRQ 0 | IRQ 0 | 0, 1 | External (P32), Rising Falling Edge Triggered | | IRQ 1 | IRQ 1 | 2, 3 | External (P33), Falling Edge Triggered | | IRQ 2 | IRQ 2, T <sub>IN</sub> | 4,5 | External (P31), Rising Falling Edge Triggered | | IRQ 3 . | | 6, 7 | Software Generated | | IRQ 4 | TO | 8, 9 | Internal | | IRQ 5 | TI | 10, 11 | Internal | | | | | • | Note: When SPI is enabled IRQ3 is an internal interrupt. When more than one interrupt is pending, priorities are resolved by a programmable priority encoder that is controlled by the Interrupt Priority register. An interrupt machine cycle is activated when an interrupt request is granted. This disables all subsequent interrupts, saves the Program Counter and Status Flags, and then branches to the program memory vector location reserved for that interrupt. All Z86C06 interrupts are vectored through locations in the program memory. This memory location and the next byte contain the 16-bit starting address of the interrupt service routine for that particular interrupt request. To accommodate polled interrupt systems, interrupt inputs are masked and the interrupt request register is polled to determine which of the interrupt requests needs services. When the SPI is disabled, IRQ3 has no hardware source but can be invoked by software (write to IRQ3 Register). When the SPI is enabled, an interrupt will be mapped to IRQ3 after a byte of data has been received by the SPI Shift Register. An interrupt resulting from AN1 is mapped into IRQ2, and an interrupt from AN2 is mapped into IRQ0. Interrupts IRQ2 and IRQ0 may be rising, falling, or both edge triggered, and are programmable by the user. The software can poll to identify the state of the pin. The programming bits for the INTERRUPT EDGE SELECT are located in the IRQ register (R250), bits D7 and D6. The configuration is shown in Table 3. Table 3. IRQ Register | IF. | IQ | , Interru | Interrupt Edge | | | | |-----|----|-----------|----------------|--|--|--| | D7 | D6 | P31 | P32 | | | | | 0 | 0 | É | F | | | | | 0 | 1 | · F | R | | | | | 1 | 0 | R | F | | | | | 1 | 1 | R/F | R/F | | | | Notes: F = Falling Edge R = Rising Edge Clock. The Z86C06 on-chip oscillator has a high-gain, parallel-resonant amplifier for connection to a crystal, RC, ceramic resonator, or any suitable external clock source (XTAL1 = Input, XTAL2 = Output). The crystal should be AT cut, 10 KHz to 12 MHz max, with a series resistance (RS) less than or equal to 100 Ohms. The crystal is connected across XTAL1 and XTAL2 using the recommended capacitors (C1=C2 is more than or equal to 22 pF) from each pin to ground. The RC oscillator option is mask-programmable, to be selected by the customer at the time the ROM code is submitted. The RC oscillator configuration must be an external resistor connected from XTAL1 to XTAL2, with a frequency-setting capacitor from XTAL1 to ground (Figure 12). <sup>\*</sup> Preliminary Value Including Pin Parasitics Figure 12. Oscillator Configuration The RC value vs Frequency curves are shown in Figure 54 and 55. (Limitation: The RC option is not available in the 12 MHz part.) In addition, a special feature has been incorporated into the Z86C06; in low EMI noise mode (bit 7 of PCON register=0) with the RC option selected, the oscillator is targeted to consume considerately less ICC current at frequencies of 10 KHz or less. Power-On Reset. A timer circuit clocked by a dedicated on-board RC oscillator or by the XTAL oscillator is used for the Power-On Reset (POR) timer function. The POR time allows $V_{\rm CC}$ and the oscillator circuit to stabilize before instruction execution begins. The POR timer circuit is a one-shot timer triggered by one of the three conditions: - Power fail to Power OK status - STOP mode recovery (If D5 of SMR=1) - WDT timeout The POR time is a nominal 5 ms. Bit 5 of the STOP Mode Register determines whether the POR timer is bypassed after STOP mode recovery (typical for external clock, and RC/LC oscillators with fast start up time). HALT. Will turn off the internal CPU clock but not the XTAL oscillation. The counter/timers and external interrupts IRQ0, IRQ1, and IRQ2 remain active. The device is recovered by interrupts, either externally or internally generated. STOP. This instruction turns off the internal clock and external crystal oscillation and reduces the standby current to 10 microamperes or less. The STOP mode is terminated by a RESET of either WDT timeout, POR, SPI compare, or SMR recovery. This causes the processor to restart the application program at address 000C (HEX). Note, the crystal remains active in STOP mode if bits 3 and 4 of the WDTMR are enabled. In this mode, only the watch dog timer runs in STOP mode. In order to enter STOP (or HALT) mode, it is necessary to first flush the instruction pipeline to avoid suspending execution in mid-instruction. To do this, the user executes a NOP (opcode=FFH) immediately before the appropriate sleep instruction, i.e.: FF NOP; clear the pipeline 6F STOP: enter STOP mode Or FF NOP; clear the pipeline 7F HALT; enter HALT mode Serial Peripheral Interface (SPI). The Z86C06 incorporates a serial peripheral interface for communication with other microcontrollers and peripherals. The SPI includes features such as STOP Mode Recovery, Master/Slave selection, and Compare mode. Table 4 contains the pin configuration for the SPI feature when it is enabled. The SPI consists of four registers; SPI Control Register (SCON), SPI Compare Register (SCOMP), SPI Receive/Buffer Register (RxBUF), and SPI Shift Register. SCON is located in bank (C) of the Expanded Register Group at address 02 (Figure 13). This register is a read/write register that controls; Master/Slave selection, interrupts, clock source and phase selection, and error flag. Bit 0 enables/disables the SPI with the default being SPI disabled. A one in this location will enable the SPI, and a 0 will disable the SPI. Bits 1 and 2 of the SCON register in Master mode select the clock rate. The user may choose whether internal clock is divide by 2, 4, 8 or 16. In slave mode, Bit 1 of this register flags the user if an overrun of the RxBUF Register has occurred. The RxCharOverrun flag is only reset by writing a 0 to this bit. In slave mode, bit 2 of the Control Register disables the data-out I/O function. If a 1 is written to this bit, the data-out pin is released to its original port configuration. If a 0 is written to this bit, the SPI shifts out one bit for each bit received. Bit 3 of the SCON Register enables the compare feature of the SPI, with the default being disabled. When the compare feature is enabled, a comparison of the value in the SCOMP Register is made with the value in the RxBUF Register. Bit 4 signals that a receive character is available in the RxBUF Register. If the associated IRQ3 is enabled, an interrupt is generated. Bit 5 controls the clock phase of the SPI. A 1 in Bit 5 allows for receiving data on the clock's falling edge and transmitting data on the clock's rising edge. A 0 allows receiving data on the clock's rising edge and transmitting on the clock's falling edge. The SPI clock source is defined in bit 6. A 1 uses TimerOoutput for the SPI clock, and a Ouses TCLK for clocking the SPI. Finally bit 7 determines whether the SPI is used as a Master or a Slave. A 1 puts the SPI into Master mode and a 0 puts the SPI into Slave mode. Table 4. SPI Pin Configuration | Name | Function | Pin Location | |------|--------------|--------------| | DI | Data-In | P20 | | DO | Data-Out | P27 | | SS | Slave Select | P35 | | SK | SPI Clock | P34 | | | | | SPI Operation. The SPI is used in one of two modes; either as system slave, or a system master. Several of the possible system configurations are shown in Figure 14. In the slave mode, data transfer starts when the slave select (SS) pin goes active. Data is transferred into the slave's SPI T-52-33-53 Shift Register, through the DI pin, which has the same address as the RxBUF Register. After a byte of data has been received by the SPI Shift Register, a Receive Character Available (RCA/IRQ3) flag and interrupt is generated. The next byte of data will be received at this time. The RxBUF Register must be cleared, or a Receive Character Overrun (RxCharOverrun) flag will be set in the SCON Register, and the data in the RxBUF Register will be overwritten. When the communication between the master and slave is complete, the SS goes inactive. Unless disconnected, for every bit that is transferred into the slave through the DI pin, a bit is transferred out through the DO pin on the opposite clock edge. During slave operation, the SPI clock pin (SK) is an input. In master mode, the CPU must first activate a SS through one of it's I/O ports. Next, data is transferred through the master's DO pin one bit per master clock cycle. Loading data into the shift register initiates the transfer. In master mode, the master's clock will drive the slave's clock. At the conclusion of a transfer, a Receive Character Available (RCA/IRQ3) flag and interrupt is generated. Before data is transferred via the DO pin, the SPI Enable bit in the SCON Register must be enabled. Figure 13. SPI Control Register (SCON) # Standard Parallel Setup Standard Parallel Setup Standard Parallel Setup Standard Parallel Setup Standard Parallel Setup Standard Parallel Setup Multiple slaves may have the same address. Figure 14. SPI System Configuration SPI Compare. When the SPI Compare Enable bit, D3 of the SCON Register is set to 1, the SPI Compare feature is enabled. The compare feature is only valid for slave mode. A compare transaction begins when the (SS) line goes active. Data is received as if it were a normal transaction, but there is no data transmitted to avoid bus contention with other slave devices. When the compare byte is received, IRQ3 is not generated. Instead, the data is compared with the contents of the SCOMP Register. If the data does not match, DO remains inactive and the slave ignores all data until the (SS) signal is reset. If the data received matches the data in the SCOMP register, then a SMR signal is generated. DO is activated if it is not tri-stated by D2 in the SCON Register, and data is received the same as any other SPI slave transaction. When the SPI is activated as a slave, it operates in all system modes; STOP, HALT, and RUN. Slaves' not comparing remain in their current mode, whereas slaves' comparing wake from a STOP or HALT mode by means of an SMR. SPI Clock. The SPI clock is driven from three sources; with Timer0, a division of the internal system clock, or an external master when in slave mode. Bit D6 of the SCON Register controls what source drives the SPI clock. A 0 in T-52-33-53 bit D6 of the SCON Register determines the division of the internal system clock if this is used as the SPI clock source. Divide by 2, 4, 8, or 16 is chosen as the scaler. Receive Character Available and Overrun. When a complete data stream is received, an interrupt is generated and the RxCharAvail bit in the SCON Register is set. Bit 4 in the SCON Register is for enabling or disabling the RxCharAvail interrupt. The RxCharAvail bit is available for interrupt polling purposes and is reset when the RxBUF Register is read. RxCharAvail is generated in both master and slave modes. While in slave mode, if the RxBUF is not read before the next data stream is received and loaded into the RxBUF Register, Receive Character Overrun (RxCharOverrun) occurs. Since there is no need for clock control in slave mode, bit D1 in the SPI Control Register is used to log any RxCharOverrun (Figure 15 and Figure 16). | No | Parameter | Min | Units | |----|--------------------|--------|-------| | 1 | DI to SK Set-up | 10 | ns | | 2 | SK to D0 Valid | 15 | ns | | 3 | SS to SK Set-up | .5 Tsk | ทร | | 4 | SS to D0 Valid | 15 | กร | | 5 | SK to Df hold time | 10 | กร | Figure 15. SPI Timing Figure 16. SPI Timing STOP Mode Recovery Register (SMR). This register selects the clock divide value and determines the mode of STOP mode recovery (Figure 17). All bits are write only except bit 7, which is read only. Bit 7 is a flag bit that is hardware set on the condition of a STOP recovery and reset on a power-on cycle. Bit 6 controls whether a low level or high level is required from the recovery source. The recovery level must be active LOW to work with SPI. Bit 5 controls the reset delay after recovery. Bits 2, 3, and 4 of the SMR specify the source of the STOP mode recovery signal. Bit 1 determines whether the XTAL is divided by 1 or 2. A 0 in this location uses XTAL divide-by-two, and a 1 uses XTAL. The default for this bit is XTAL divide by two. Bit 0 controls the divide-by-16 prescaler of SCLK/TCLK. SCLK/TCLK divide-by-16 select (D0). D0 of the SMR controls a divide-by-16 prescaler of SCLK/TCLK. The purpose of this control is to selectively reduce device power consumption during normal processor execution (SCLK control) and/or HALT mode (where TCLK sources the counter/timers and interrupt logic). XTAL Clock divide-by-2 (D1). This bit determines whether the XTAL clock is divided by two or one. When this bit is set to 1, the SCLK/TCLK is equal to the XTAL clock. This option can work together with the low EMI options in PCON register to reduce the EMI noise. Maximum frequency is 4 MHz when divide-by-1 selection is active. Default setting after RESET Figure 17. STOP Mode Recovery Register STOP Mode Recovery Source (D2,D3,D4). These three bits of the SMR specify the wake-up source of the STOP Mode recovery (Figure 18 and Table 5). Table 5. STOP Mode Recovery Source | D4 | SMR<br>D3 | D2 | Operation Description of Action | |----|-----------|----|---------------------------------| | 0 | 0 | 0 | POR recovery only | | 0 | 0 | 1 | POR recovery only | | 0 | 1 | 0 | P31 transition | | 0 | 1 | 1 | P32 transition | | 1 | 0 | 0 | P33 transition | | 1 | 0 | 1 | P27 transition | | 1 | 1 | 0 | Logical NOR of Port 2 bits 0:3 | | 1 | 1 | 1 | Logical NOR of Port 2 bits 0:7 | P31-P33 cannot wake up from STOP mode if the input lines are configured as analog inputs. When the SPI is enabled and the Compare feature is active, a SMR is generated upon a comparison in the SPI Shift Register and SCOMP Register, regardless of the above SMR Register settings. If SPI Compare is used to wake up the part from STOP mode, it is still possible to have one of the other STOP mode T-52-33-53 recovery sources active. Note: These other STOP mode recovery sources have to be active level low (bit D6 in SMR set to 0 if P31, P32, P33, and P27 selected, or bit D6 in SMR set to 1 if logical NOR of Port 2 is selected). STOP Mode Recovery Delay Select (D5). This bit disables the 5 ms RESET delay after STOP Mode Recovery. The default condition of this bit is 1. STOP Mode Recovery Level Select (D6). A 1 in this bit position indicates that a high level on any one of the recovery sources wakes the device from STOP mode. A 0 indicates low level recovery. The default is 0 on POR (Figure 18). Cold or Warm Start (D7). This bit is set by the device upon entering STOP mode. It is active high, and is 0 (cold) on POR/WDT RESET. This bit is READ only. It is used to distinguish between cold or warm start. Watch Dog Timer Mode Register (WDTMR). The WDT is a retriggerable one-shot timer that resets the Z8 if it reaches its terminal count. The WDT is initially enabled by executing the WDT instruction and retriggered on subsequent executions of the WDT instruction. The timer circuit is driven by an on-board RC oscillator or external clock source. The POR clock source is selected with bit 4 of the WDTMR. Figure 18. STOP Mode Recovery Source Bits 0 and 1 control a tap circuit that determines the timeout period. Bit 2 determines whether the WDT is active during HALT and bit 3 determines WDT activity during STOP. If bits 3 and 4 of this register are both set to 1, the WDT is only driven by the external clock during STOP mode. This feature makes it possible to wake up from STOP mode from an internal source. Bits 5 through 7 of the WDTMR are reserved (Figure 19). This register is accessible only during the first 64 processor cycles (128 XTAL clocks) from the execution of the first instruction after Power-On-Reset, Watch Dog Reset or a STOP Mode Recovery (Figure 20). After this point, the register cannot be modified by any means, intentional or otherwise. The WDTMR cannot be read and is located in bank F of the Expanded Register Group at address location 0FH. It is organized as follows: Figure 19. Watchdog Timer Mode Register Figure 20. Resets and WDT WDT Time Select (D1,D0). Selects the WDT time-out period. It is configured as shown in Table 6. Table 6. WDT Time Select | D1 | D0 | Timeout of<br>internal RC OSC | Timeout of<br>XTAL clock | |--------|--------|-------------------------------|--------------------------| | 0 | 0 | 5 ms mìn<br>15 ms min | 512TpC<br>1024TpC | | 1<br>1 | 0<br>1 | 25 ms min<br>100 ms min | 2048TpC<br>8192TpC | #### Notes: The default on a WDT initiated RESET is 15 ms. See Figures 50 through 53 for details. WDT During HALT (D2). This bit determines whether or not the WDT is active during HALT mode. A 1 indicates active during HALT. The default is 1. WDT During STOP (D3). This bit determines whether or not the WDT is active during STOP mode. Since XTAL clock is stopped during STOP mode, unless as specified below, the on-board RC has to be selected as the clock source to the POR counter. A 1 indicates active during STOP. The default is 1. If bits D3 and D4 are both set to 1, the WDT only, is driven by the external clock during STOP mode. On-Board, Power-On-Reset RC or External XTAL1 Oscillator Select (D4). This bit determines which oscillator source is used to clock the internal POR and WDT counter chain. If the bit is a 1, the internal RC oscillator is bypassed and the POR and WDT clock source is driven from the external pin, XTAL1. The default configuration of this bit is 0, which selects the RC oscillator. T-52-33-53 $m V_{cc}$ Voltage Comparator. An on-board Voltage Comparator checks that $\rm V_{cc}$ is at the required level to ensure correct operation of the device. Reset is globally driven if $\rm V_{cc}$ is below the specified voltage (typically 2.1V). Brown-Out Protection ( $V_{\rm BO}$ ). The brown-out trip voltage ( $V_{\rm BO}$ ) will be less than 3 volts and above 1.4 volts under the following conditions. Maximum (V<sub>BO</sub>) Conditions: Case 1 $T_A = -40^{\circ}$ , +105°C, Internal Clock Frequency equal or less than 1 MHz Case 2 T<sub>A</sub> = -40°, +85°C, Internal Clock Frequency equal or less than 2 MHz #### Note: The internal clock frequency is one half the external clock frequency, unless the device is in low EMI mode. The device functions normally at or above 3.0V under all conditions. Below 3.0V, the device functions normally until the Brown-Out Protection trip point ( $V_{80}$ ) is reached, for the temperatures and operating frequencies in cases 1 and 2 above. The device is guaranteed to function normally at supply voltages above the brown-out trip point. The actual brown-out trip point is a function of temperature and process parameters (Figure 21). ROM Protect. ROM protect is mask-programmable. It is selected by the customer at the time the ROM code is submitted. The selection of ROM protect disables the LDC and LDCI instructions. Figure 21. Typical Z86C06 $\rm V_{BO}$ Voltage vs Temperature ### **ABSOLUTE MAXIMUM RATINGS** | Symbol | Description | Min | Max | Units | |-------------------------------------------------------|------------------------------------------------------|------------------|--------------|--------| | V <sub>cc</sub><br>T <sub>srg</sub><br>T <sub>A</sub> | Supply Voltage*<br>Storage Temp<br>Oper Ambient Temp | -0.3<br>-65<br>† | +7.0<br>+150 | V<br>C | Voltage on all pins with respect to GND. † See Ordering Information Stress greater than those listed under Absolute Maximum Ratings may cause permanent damage to the device. This is a stress rating only; operation of the device at any condition above those indicated in the operational sections of these specifications is not implied. Exposure to absolute maximum rating conditions for extended period may affect device reliability. #### STANDARD TEST CONDITIONS The characteristics listed below apply for standard test conditions as noted. All voltages are referenced to ground. Positive current flows into the referenced pin (Figure 22). Figure 22. Test Load Configuration | Value Clock Input High S.3V O.9V <sub>cc</sub> V <sub>cc</sub> +0.3 | Symbol | Parameter | V <sub>cc</sub><br>Note [3] | T <sub>A</sub> = 1<br>to 70 | 0°C<br>0°C | T <sub>A</sub> = -4<br>to 10 | 10°C<br>5°C | Typical<br>@ 25°C | Units | Conditions | Notes | | | |---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------|----------------------|-----------------------------|-----------------------------|---------------------------|------------------------------|----------------------|-------------------|-------|----------------------------------------------------|----------------|--|--| | Variable | | | | | | Min | Max | Min | Max | | | | | | Voltage 5.0V 0.9 V <sub>CC</sub> V <sub>CC</sub> +0.3 0.9 V <sub>CC</sub> V <sub>CC</sub> +0.3 3.9 V Drivent Clock G | | Max Input Voltage | | | | | | | | I <sub>N</sub> ≤ 250 μA<br>I <sub>N</sub> ≤ 250 μA | | | | | Clock Input Low Clock Input Low Voltage S.0V V <sub>ss</sub> -0.3 0.2 V <sub>cc</sub> V <sub>ss</sub> -0.3 0.2 V <sub>cc</sub> 2.7 V Driven to Clock G V <sub>th</sub> Input High Voltage S.0V V <sub>ss</sub> -0.3 0.2 V <sub>cc</sub> V <sub>cc</sub> +0.3 0.7 V <sub>cc</sub> V <sub>cc</sub> +0.3 0.7 V <sub>cc</sub> V <sub>cc</sub> +0.3 1.8 V V <sub>th</sub> Input Low Voltage S.0V V <sub>ss</sub> -0.3 0.2 V <sub>cc</sub> V <sub>ss</sub> -0.3 0.7 V <sub>cc</sub> V <sub>cc</sub> +0.3 2.8 V V <sub>th</sub> Input Low Voltage S.0V V <sub>ss</sub> -0.3 0.2 V <sub>cc</sub> V <sub>ss</sub> -0.3 0.2 V <sub>cc</sub> V <sub>ss</sub> -0.3 0.2 V <sub>cc</sub> 1.0 V V <sub>th</sub> Output High Voltage S.0V V <sub>cc</sub> -0.4 V <sub>cc</sub> -0.4 V <sub>cc</sub> -0.4 S.0V V <sub>cc</sub> -0.4 | V <sub>CH</sub> | | 3.3V | • | V <sub>cc</sub> +0.3 | •• | V <sub>cc</sub> +0.3 | 2.4 | ٧ | Driven by External<br>Clock Generator | | | | | Voltage S.0V V <sub>SS</sub> -0.3 0.2 V <sub>CC</sub> V <sub>SS</sub> -0.3 0.2 V <sub>CC</sub> 2.7 V Drivent Clock G | | · · | 5.0V | 0.9 V <sub>cc</sub> | V <sub>cc</sub> +0.3 | 0.9 V <sub>cc</sub> | V <sub>cc</sub> +0.3 | 3.9 | V. | Driven by External<br>Clock Generator | • | | | | Solvarian Sol | V <sub>a.</sub> | | 3.3V | V <sub>ss</sub> -0.3 | | V <sub>ss</sub> -0.3 | 0.2 V <sub>cc</sub> | 1.6 | V | Driven by External<br>Clock Generator | · · | | | | Solvarian Sol | | · | 5.0V | V <sub>ss</sub> -0.3 | 0.2 V <sub>cc</sub> | V <sub>ss</sub> -0.3 | 0.2 V <sub>cc</sub> | 2.7 | V | Driven by External<br>Clock Generator | | | | | V <sub>L</sub> Input Low Voltage 3.3V V <sub>SS</sub> -0.3 0.2 V <sub>CC</sub> V <sub>SS</sub> -0.3 0.2 V <sub>CC</sub> 1.0 V | v | Input High Voltage | 3 3V | 0.7 V | V +0.3 | 07V | Λ τυ 3 | 1.8 | V | | | | | | $\begin{array}{c ccccccccccccccccccccccccccccccccccc$ | *H | sipat riigii voitago | | 0.7 V <sub>cc</sub> | V <sub>cc</sub> +0.3 | 0.7 V <sub>cc</sub> | | | ٧ | | | | | | $\begin{array}{c ccccccccccccccccccccccccccccccccccc$ | V. | Input Low Voltage | 3.3V | V <sub>ss</sub> -0.3 | 0.2 V <sub>cc</sub> | V <sub>ss</sub> -0.3 | 0.2 V <sub>cc</sub> | | | . 1 | | | | | Vol.1 Output Low Voltage 3.3V 0.8 0.8 0.2 V I <sub>OL</sub> = +4 | • | | 5.0V | V <sub>ss</sub> -0.3 | $0.2\mathrm{V_{cc}^{33}}$ | V <sub>ss</sub> -0.3 | 0.2 V <sub>cc</sub> | 1.5 | V | • | | | | | Vol.1 Output Low Voltage 3.3V 0.8 0.8 0.2 V I <sub>OL</sub> = +4 | V <sub>ort</sub> | Output High Voltage | | V <sub>cc</sub> -0.4 | | V <sub>cc</sub> -0.4 | | | | i <sub>ot</sub> = -2.0 mA | | | | | Vol.2 Output Low Voltage 3.3V 1.0 1.0 0.4 V I <sub>OL</sub> = 60 3 Pin M | • | | 5.0V | V <sub>cc</sub> -0.4 | | V <sub>cc</sub> -0.4 | | 4.8 | V | I <sub>01</sub> = -2.0 mA | | | | | Vol.2 Output Low Voltage 3.3V 1.0 1.0 0.4 V I <sub>OL</sub> = 60 3 Pin M | V <sub>0.1</sub> | Output Low Voltage | 3.3V | | 0.8 | | 0.8 | 0.2 | ٧ | $I_{0L} = +4.0 \text{ mA}$ | | | | | $ \begin{array}{c ccccccccccccccccccccccccccccccccccc$ | ж. | | 5.0V | | 0.4 | | 0.4 | 0.1 | ٧ | $l_{0L}^{0L} = +4.0 \text{ mA}$ | | | | | Voffset Comparator Input 3.3V 25 25 10 mV | V <sub>01.2</sub> | Output Low Voltage | | | | | | | ٧ | I <sub>ot</sub> = 6 mA,<br>3 Pin Max | | | | | $ \begin{array}{c ccccccccccccccccccccccccccccccccccc$ | | | 5.0V | | 1.0 | | 1.0 | 0.5 | ۷. | $I_{ot} = +12 \text{ mA},$<br>3 Pin Max | | | | | $ \begin{array}{c ccccccccccccccccccccccccccccccccccc$ | V <sub>OFFSET</sub> | | | | | · | | | | | | | | | $ \begin{array}{c ccccccccccccccccccccccccccccccccccc$ | | Offset Voltage | 5.0V | | 25 | | 25 | 10 | mV | | | | | | (Input bias current of comparator) $ \begin{array}{ccccccccccccccccccccccccccccccccccc$ | <u>L</u> | | | | | | | | | $V_{IN} = 0V, V_{CC}$ | | | | | 5.0V -1.0 1.0 -1.0 1.0 $\mu$ A $V_N = 0$ | | | 5.0V | -1.0 | 1.0 | -1.0 | 1.0 | | μА | $V_{M}^{H} = 0V, V_{CC}^{CC}$ | | | | | 5.0V -1.0 1.0 -1.0 1.0 $\mu$ A $V_{N} = 0$ | i <sub>a</sub> | Output Leakage | 3.3V | | 1.0 | -1.0 | 1.0 | | μΑ | $V_{\rm N} = 0 V, V_{\rm CC}$ | | | | | | ~ | _ | 5.0V | -1.0 | 1.0 | -1.0 | 1.0 | | | $V_{IN} = 0V$ , $V_{CC}$ | 1 | | | | | I <sub>cc</sub> | Supply Current | | , | | | | | | @ 8 MHz | [4,5] | | | | 5.0V 11.0 11.0 6.0 mA @ 8 M | | | | | | | | | | @ 8 MHz | [4,5] | | | | | | | | | | | | | | @ 12 MHz<br>@ 12 MHz | [4,5]<br>[4,5] | | | | Symbol | Parameter | V <sub>cc</sub> | т. | 000 | | 4000 | | | T-52-33-53 | | |------------------|--------------------------------------|-----------------|------|----------|--------|---------------|-------------------|--------------|----------------------------------------------------------------------|-------------| | oyboi | i arannytyi | Vœ<br>Note [3] | to 7 | .0°C | to 1 | ·40°C<br>05°C | Typical<br>@ 25°C | | Conditions | Note | | | | | Min | Max | Min | Max | | | | | | l <sub>cc1</sub> | Slandby Current | 3.3V | | 3.0 | | 3.0 | 1.3 | mA | HALT Mode V <sub>N</sub> = 0V,<br>V <sub>cc</sub> @ 8 MHz | [4, 5] | | | | 5.0V | | 5 | | 5 | 3.0 | mA | HALT Mode V <sub>N</sub> = OV,<br>V <sub>cc</sub> @ 8 MHz | [4, 5] | | | | 3.3V | | 4.5 | | 4.5 | 2.0 | mA | HALT Mode V <sub>N</sub> = OV,<br>V <sub>cc</sub> @ 12 MHz | [4, 5] | | | | 5.0V | | 7.0 | | 7.0 | 4.0 | mA | HALT Mode V <sub>IN</sub> = 0V,<br>V <sub>cc</sub> @ 12 MHz | [4,5] | | | | 3.3V | | 1.4 | | 1.4 | 0.7 | mA | Clock Divide by 16<br>@ 8 MHz | [4,5] | | | | 5.0V | | 3.5 | | 3.5 | 2.0 | mA | Clock Divide by 16<br>@ 8 MHz | [4, 5] | | | | 3.3V | | 2.0 | | 2.0 | 1.0 | mA | Clock Divide by 16<br>@ 12 MHz | [4,5] | | | | 5.0V | | 4.5 | | 4.5 | 2.5 | mA | Clock Divide by 16<br>@ 12 MHz | [4, 5] | | CC2 | Standby Current | 3.3V | | 10 | | 20 | 1.0 | μA | STOP Mode V <sub>M</sub> = 0V,<br>V <sub>cc</sub> WDT is not Running | [6] | | | | 5.0V | | 10 | | 20 | 3.0 | μА | STOP Mode V <sub>M</sub> = OV,<br>V <sub>cc</sub> WDT is not Running | [6] | | | | 3.3V | | | | | TBD | μΑ | STOP Mode V <sub>N</sub> = 0V,<br>V <sub>cc</sub> WDT is Running | [6] | | • | | 5.0V | | TBD | | TBD | 200 | μА | STOP Mode V <sub>R1</sub> = OV,<br>V <sub>CC</sub> WDT is Running | [6] | | WI | Auto Latch Low<br>Current | 3.3V | | 7.0 | | 14.0 | 4.0 | μ <b>Α</b> , | OV < V <sub>IN</sub> < V <sub>CC</sub> | | | | | 5.0V | | 20.0 | | 30.0 | 10 | μА | 0V < V <sub>IN</sub> < V <sub>CC</sub> | | | ALH | Auto Latch High | 3.3V | | -4.0 | | -8.0 | -2.0 | μA | 0V < V <sub>IN</sub> < V <sub>cc</sub> | <del></del> | | | Current | 5.0V | | -9.0 | | -16.0 | -5.0 | μA | $0V < V_{RI} < V_{CC}$ | | | POR | Power On Reset | 3.3V<br>5.0V | 7 | 24<br>13 | 6<br>2 | 25<br>14 | 13<br>7 | ms<br>ms | | - | | / <sub>80</sub> | V <sub>cc</sub> Brown Out<br>Voltage | | 1.50 | 2.65 | 1.2 | 2.95 | 2.1 | .٧ | 2 MHz max Ext. CLK Freq. | [8] | Notes: <sup>[1]</sup> I<sub>oc1</sub> Clock Driven on Crystal or Čeramic Resonator Typ 3.0 0.3 Max 5.0 5.0 Freq 8 MHz Unit mA mA 8 MHz <sup>[2]</sup> $V_{so} = 0V = GND$ [3] $5.0V \pm 0.5V$ , $3.0V \pm 0.3V$ . The $V_{so}$ increases as the temperature decreases. [4] All outputs unloaded, I/O pins floating, inputs at rail. [5] $C_{t,i} = C_{t,2} = 100 \text{ pF}$ [6] Same as note [4] except inputs at $V_{cc}$ . # **AC ELECTRICAL CHARACTERISTICS** T-52-33-53 Figure 23. Additional Timing # **AC ELECTRICAL CHARACTERISTICS** | No | Symbol | Parameter | V <sub>cc</sub> | | , = 0°C TC | | | | _= -40°C | | | Units | Notes | |---------------|---------|------------------------|-----------------|------------|------------|-------------|------------|------------|---------------|-------------|------------|-------|-------| | | | | Note[3] | 8 M<br>Min | Hz<br>Max | 12 N<br>Min | IHz<br>Max | 8 M<br>Min | iHz<br>Max | 12 r<br>Min | ИHz<br>Max | | | | 1 | ТрС | Input Clock Period | 3.3V | 125 | 100,000 | 83 | 100,000 | 125 | 100,000 | 83 | 100,000 | ns | ·[1] | | • | .,- | | 5.0V | 125 | 100,000 | 83 | 100,000 | 125 | 100,000 | . 83 | 100,000 | ns | [1] | | <u>-</u> - | TrC,TIC | Clock input Rise | 3.3V | | 25 | | 15 | | 25 | | 15 | ns | ·[1] | | _ | | and Fall Times | 5.0V | | 25 | | 15 | | 25 | | 15 | ns | [1] | | 3 | TwC | Input Clock Width | 3.3V | 37 | | 26 | | 37 | | 26 | | ns | [1] | | - | | | 5.0V | 37 | | 26 | | 37 | | 26 | | ns | [1] | | 4 | TwTinL | Timer Input Low Width | 3.3V | 100 | | 100 | | 100 | · · · · · · · | 100 | | ns | [1] | | ٠. | ****** | | 5.0V | 70 | | 70 | | 70 | | 70 | | ПS | [1] | | <del></del> 5 | TwTinH | Timer Input High Width | 3.3V | 3TpC | | 3TpC | | ЗТрС | | 3TpC | | | [1] | | - | | F | 5.0V | 3TpC | | 3TpC | | 3TpC | | ЗТрС | | | [1] | | | | | | | | | | | | | T-52-33-53 | | | | |----|-----------------|------------------------------------|----------------------------|------------------|-------------------------|-----------------------|---------------------------------------|-----------------------------------|-----------------------|--------------|------------|-------|------------------------|--| | No | Symbol | Parameter | V <sub>cc</sub><br>Note[3] | T,<br>8 M<br>Min | = 0°C T(<br> Hz<br> Max | 0 70°C<br>12 N<br>Min | ИНz<br>Мах | T <sub>A</sub> = -4<br>8 N<br>Min | 10°C TO<br>1Hz<br>Max | | MHz<br>Max | Units | Notes | | | 6 | TpTin | Timer Input Period | 3.3V<br>5.0V | 8TpC<br>8TpC | | 8TpC<br>8TpC | · · · · · · · · · · · · · · · · · · · | 8TpC<br>8TpC | | 8ТрС<br>8ТрС | .* | | [1] | | | 7 | TrTin,<br>TtTin | Timer Input Rise<br>and Fall Timer | 3.3V | | 100 | | 100 | | 100 | | 100 | ns | [1] | | | | | | 5.0V | | 100 | | 100 | | 100 | • | 100 | ns | [1] | | | 8 | TwlL | Int. Request Input<br>Low Time | 3.3V | 100 | | 100 | | 100 | | 100 | · | ns | [1,2] | | | | | | 5.0V | 70 | | 70 | | 70 | | 70 | | ns | [1,2] | | | } | TwlH | Int. Request Input<br>High Time | 3.3V | ЗТрС | | 3ТрС | | ЗТрС | | 3TpC | | | [1,2] | | | | | | 5.0V | 3TpC | | 3TpC | | 3TpC | | ЗТрС | | | [1,2] | | | 0 | Twsm | STOP Mode Recovery<br>Width Spec | 3.3V | 12 | | 12 | | 12 | | 12 | | ns | ··, · | | | | | | 5.0V | 12 | | 12 | | 12 | • | 12 | • | ns . | | | | 11 | Tost | Oscillator Startup Time | 3.3V | | 5ТрС | | 5TpC | | -5TpC | | 5TpC | , | Reg.<br>[4] | | | | Twdt | Watchdog Timer<br>Refresh Time | 5.0V<br>3.3V | 15 | 5TpC | 15 | 5TpC | 12 | 5ТрС | 12 | 5TpC | ns . | [5] | | | | | | 5.0V | 5 | | 5 . | | 3 | | 3 | • | ms | D0 = 0 [6<br>D1 = 0 [6 | | | | | | 3.3V | 30 | | 30 | | 25 | | 25 | | ms | D0 = 1 [6 | | | | | | 5.0V | 16 | | 16 | | 12 | | 12 | | ms | D1 = 0[6] | | | | | | 3.3V | 60 | | 60 | | 50 | | 50 | | ms | D0 = 0[6] | | | | | | 5.0V | 25 | | 25 | | 30 | | 30 | | ms | D1 = 1[6] | | | | | | 3.3V<br>5.0V | 250<br>120 | | 250 | - | 200 | | 200 | | ms | D0 = 1 [6 | | | | | | J.U4 | 120 | | 120 | | 100 | | 100 | | ms : | D1 = 1[6] | | Notes: [1] Timing Reference uses 0.9 V<sub>cc</sub> for a logic 1 and 0.1 V<sub>cc</sub> for a logic 0. [2] Interrupt request via Port 3 (P31-P33) [3] 5.0V ± 0.5V, 3.3V ± 0.3V [4] SMR-D5 = 0 [5] Reg. WDTMR [6] Internal RC Oscillator only. #### **EXPANDED REGISTER FILE CONTROL REGISTERS** \* Default settling after RESET Figure 24. STOP Mode Recovery Register Default setting after RESET Figure 25. Watchdog Timer Mode Register Figure 26. PORT Control Register \* Default Setting After Reset. Figure 27. SPI Control Register # **Z8 CONTROL REGISTER DIAGRAMS** P 240 D7 D6 D5 D4 D3 D2 D1 D0 Reserved Figure 28. Reserved Figure 29. Timer Mode Register (F1<sub>H</sub>: Read/Write) Figure 30. Counter Timer 1 Register (F2<sub>H</sub>: Read/Write) Figure 31. Prescaler 1 Register (F3<sub>n</sub>: Write Only) Figure 32. Counter/Timer 0 Register (F4<sub>H</sub>: Read/Write) Figure 33. Prescaler 0 Register (F5<sub>H</sub>: Write Only) T-52-33-53 #### **Z8 CONTROL REGISTER DIAGRAMS (Continued)** Figure 34. Port 2 Mode Register (F6<sub>st</sub>: Write Only) Figure 35. Port 3 Mode Register (F7<sub>H</sub>: Write Only) Figure 36. Port 0 and 1 Mode Register Figure 37. Interrupt Priority Register (F9<sub>H</sub>: Write Only) Figure 38. Interrupt Request Register (FA<sub>H</sub>: Read/Write) Figure 39. Interrupt Mask Register (FB<sub>H</sub>: Read/Write) Figure 40. Flag Register (FC<sub>H</sub>: Read/Write) Figure 41. Register Pointer (FD<sub>H</sub>: Read/Write) Figure 42. General Purpose Register (FE<sub>H</sub>: Read/Write) Figure 43. Stack Pointer (FF<sub>H</sub>: Read/Write) #### **DEVICE CHARACTERISTICS** Figure 44. Typical $I_{cc}$ vs Frequency Figure 45. Typical $V_{\rm ol}$ , $V_{\rm K}$ vs Temperature Figure 46. Typical $V_{\rm orb}$ , $V_{\rm ir}$ vs Temperature ## **DEVICE CHARACTERISTICS** (Continued) Figure 47. Typical $V_{\rm OH}$ vs $I_{\rm OH}$ Over Temperature Figure 48. Typical $\rm I_{oL}$ vs $\rm V_{oL}$ Over Temperature Figure 49. Typical Power-On Reset Time vs Temperature Figure 50. Typical 5 ms WDT Setting vs Temperature # **DEVICE CHARACTERISTICS** (Continued) Legend; A - Vcc = 3.0V B - Vcc = 3.5V C - Vcc = 4.0V D - Vcc = 4.5v E - Vcc = 5.0V F - Vcc = 5.5V Note: Using internal RC. Figure 51. Typical 15 ms WDT Setting vs Temperature Time (msec) T-52-33-53 Legend: A - Vcc = 3.0V B - Vcc = 3.5V C - Vcc = 4.0V D - Vcc = 4.5v E - Vcc = 5.0V F - Vcc = 5.5V Figure 52. Typical 25 ms WDT Setting vs Temperature #### **DEVICE CHARACTERISTICS (Continued)** Legend: A - Vcc = 3.0V B - Vcc = 3.5V C - Vcc = 4.0V D - Vcc = 4.5v E - Vcc = 5.0V F - Vcc = 5.5V Figure 53. Typical 100 ms WDT Setting vs Temperature Note: This chart for reference only. Each process will have a different characteristic curve. Figure 54. Typical Frequency vs RC Resistance ### **DEVICE CHARACTERISTICS (Continued)** T-52-33-53 Figure 55. Typical RC Resistance/Capacitance vs Frequency Figure 56. Auto Latch Characteristics ## INSTRUCTION SET NOTATION Addressing Modes. The following notation is used to describe the addressing modes and instruction operations as shown in the instruction summary. | Symbol | Meaning | |--------|----------------------------------------------------------------------| | IRR | Indirect register pair or indirect working-<br>register pair address | | Irr | Indirect working-register pair only | | X | Indexed address | | DA | Direct address | | RA | Relative address | | IM | Immediate | | R | Register or working-register address | | r | Working-register address only | | IR | Indirect-register or indirect | | | working-register address | | ir | Indirect working-register address only | | RR | Register pair or working register pair address | Symbols. The following symbols are used in describing the instruction set. | Symbol | Meaning | |--------|--------------------------------------| | dst | Destination location or contents | | src | Source location or contents | | CC | Condition code | | @ | Indirect address prefix | | SP | Stack Pointer | | PC | Program Counter | | FLAGS | Flag register (Control Register 252) | | RP | Register Pointer (R253) | | IMR | Interrupt mask register (R251) | T-52-33-53 Flags. Control register (R252) contains the following six flags: | Carry flag | |--------------------------------------| | Zero flag | | Sign flag | | Overflow flag | | Decimal-adjust flag | | Half-carry flag | | ges are indicated by: Clear to zero | | Set to one | | Set to clear according to operation | | Unaffected | | Undefined | | | # **CONDITION CODES** T-52-33-53 | Value | Mnemonic | Meaning | Flags Set | |-------|----------|--------------------------------|-------------------------| | 1000 | | Always True | <del></del> | | 0111 | С | Carry | C = 1 | | 1111 | NC | No Carry | C = 0 | | 0110 | Z | Zero | Z = 1 | | 1110 | NZ | Not Zero | Z = 0 | | 1101 | PL | Plus | S = 0 | | 0101 | MI | Minus | S = 1 | | 0100 | OV | Overflow | V = 1 | | 1100 | NOV | No Overflow | V = 0 | | 0110 | EQ | Equal | Z = 1 | | 1110 | NE | Not Equal | Z = 0 | | 1001 | GE | Greater Than or Equal | (S XOR V) = 0 | | 0001 | LT | Less than | (S XOR V) = 1 | | 1010 | GT | Greater Than | [Z OR (S XOR V)] = 0 | | 0010 | LE | Less Than or Equal | [Z OR (S XOR V)] = 1 | | 1111 | UGE | Unsigned Greater Than or Equal | C = 0 | | 0111 | ULT | Unsigned Less Than | C = 1 | | 1011 | UGT | Unsigned Greater Than | (C = 0 AND Z = 0) = 1 | | 0011 | ULE | Unsigned Less Than or Equal | (C OR Z) = 1 | | 0000 | | Never True | (0 0112) = 1 | #### **INSTRUCTION FORMATS** T-52-33-53 One-Byte Instructions **Two-Byte Instructions** Three-Byte Instructions #### **INSTRUCTION SÚMMARY** Note: Assignment of a value is indicated by the symbol " $\leftarrow$ ". For example: notation "addr (n)" is used to refer to bit (n) of a given operand location. For example: dst ← dst + src dst (7) indicates that the source data is added to the destination data and the result is stored in the destination location. The refers to bit 7 of the destination operand. | | | | | | • | | | | |--------------------------------------------------------------------------|----------------------------|----------------------|---|------------------|---------|---|---|---| | Instruction and Operation | Address<br>Mode<br>dst src | Opcode<br>Byte (Hex) | | ags<br>fect<br>Z | ed<br>S | v | D | н | | ADC dst, src<br>dst←dst + src +C | t | 1[] | * | * | * | * | 0 | * | | ADD dst, src<br>dst←dst + src | t | 0[] | * | * | * | * | 0 | * | | AND dst, src<br>dst←dst AND src | t | 5[] | - | * | * | 0 | - | - | | CALL dst<br>SP←SP - 2<br>@SP←PC,<br>PC←dsl | DA<br>IRR | D6<br>D4 | - | - | - | - | - | - | | CCF<br>C←NOT C | | EF | * | - | - | - | - | - | | CLR dst dst←0 | R<br>IR | B0<br>B1 | - | - | - | - | - | - | | COM dst<br>dst←NOT dst | R<br>IR | 60<br>61 | - | * | * | 0 | - | - | | CP dst, src<br>dst - src | t | A[ ] | * | * | * | * | - | - | | DA dst<br>dst←DA dst | R<br>IR | 40<br>41 | * | * | * | X | - | - | | DEC dst<br>dst←dst - 1 | R<br>IR | 00<br>01 | - | * | * | * | - | - | | DECW dst<br>dst←dst - 1 | RR<br>IR | 80<br>81 | - | * | * | * | - | - | | DI<br>IMR(7)←0 | | 8F | - | - | • | - | - | - | | DJNZr, dst<br>r←r - 1<br>if r ≠ 0<br>PC←PC + dst<br>Range: +127,<br>-128 | RA | rA<br>r = 0 - F | - | - | - | - | - | - | | EI<br>IMR(7)←1 | | 9F | - | - | - | - | - | - | | HALT | | 7F | - | - | - | - | - | - | | Instruction | Δdı | dress | Opcode | | ags | | ٠., | <u>-</u> ر | 53 | |----------------------------------------------------------------------|-------------------|-------------------|-------------------------|----|----------------|------------|-----|------------|----------| | and Operation | Mo | | Byte (Hex) | Af | fect<br>Z | | ٧ | D | Ĥ | | INC dst<br>dst←dst + 1 | r<br>R | | rE<br>r = 0 - F<br>20 | - | * | * | * | - | - | | | IR | | 21 | | | | ٠. | | | | INCW dst<br>dst←dst + 1 | RR<br>IR | | A0<br>A1 | - | * | * | * | - | - | | IRET<br>FLAGS←@SP;<br>SP←SP + 1<br>PC←@SP;<br>SP←SP + 2;<br>IMR(7)←1 | - | | BF | * | * | * | * | * | * | | JP cc, dst<br>if cc is true,<br>PC←dst | DA<br>IRR | | cD<br>c = 0 - F<br>30 | - | - | - | | - | - | | JR cc, dst<br>if cc is true,<br>PC←PC + dst<br>Range: +127,<br>-128 | RA | | cB<br>c=0-F | - | - | | - | - | - | | LD dst, src<br>dst←src | r<br>r<br>R | lm<br>R<br>r | rC<br>r8<br>r9<br>r=0-F | - | - | . <b>-</b> | - | | - | | | r<br>X<br>r<br>Ir | X<br>r<br>Ir<br>r | C7<br>D7<br>E3<br>F3 | | | | | | | | | R<br>R<br>R<br>R | R<br>IR<br>IM | E4<br>E5<br>E6<br>E7 | | - | | | | | | | IR | R | F5 | • | | • | | | | | LDC dst, src<br>dst←src | r | lrr | C2 | - | - | - | - | | <u>-</u> | | LDCI dst, src<br>dst←src<br>r←r + 1;rr←-rr + 1 | Ír | Irr | C3 | | - <del>-</del> | - | - | - | - | | NOP | | | FF | | - | - | - | - | - | | | | | | | | | | | | ## **INSTRUCTION SUMMARY** (Continued) | | | Γ_! | 52. | -33 | -53 | |--|--|-----|-----|-----|-----| |--|--|-----|-----|-----|-----| | Instruction and Operation | Address<br>Mode | Opcode<br>Byte (Hex) | Af | ags<br>fect | | | | - | |-----------------------------------|-----------------|----------------------|----|-------------|---|---|---|---| | | dst src | | C | Z | S | ٧ | D | Н | | OR dst, src<br>dst←dst OR src | † | 4[] | - | * | * | 0 | - | - | | POP dst<br>dst←@SP;<br>SP←SP + 1 | R<br>IR | 50<br>51 | - | - | - | - | - | - | | PUSH src<br>SP←SP - 1;<br>@SP←src | R<br>IR | 70<br>71 | - | - | - | - | - | - | | RCF<br>C←0 | | CF | 0 | - | - | - | - | - | | RET<br>PC←@SP;<br>SP←SP + 2 | | AF | - | - | - | - | - | - | | RL dst | R<br>IR | 90<br>91 | * | * | * | * | - | - | | RLC dst | R<br>IR | 10<br>11 | * | * | * | * | - | - | | RR dst | R<br>IR | E0<br>E1 | * | * | * | * | - | - | | RRC dst | R<br>IR | C0<br>C1 | * | * | * | * | - | - | | SBC dst, src<br>dst←dst←src←C | t | 3[] | * | * | * | * | 1 | * | | SCF<br>C←1 | <del></del> | DF | 1 | - | - | - | - | - | | SRA dst | R<br>IR | D0<br>D1 | * | * | * | 0 | • | - | | SRP dst<br>RP←src | lm | 31 | - | - | - | - | - | - | | STOP | | 6F | 1 | - | - | - | - | - | | Instruction and Operation | Address<br>Mode | Opcode<br>Byte (Hex) | | ags<br>fect | | | | | |--------------------------------------|-----------------|----------------------|----------|-------------|---|---|-----|---| | • | dst src | , | | | S | V | D | H | | SUB dst, src<br>dst←dst←src | t | 2[] | * | * | * | * | 1 | * | | SWAP dst | R<br>IR | F0<br>F1 | Х | * | * | X | . • | - | | TCM dst, src<br>(NOT dst)<br>AND src | t | 6[] | <b>.</b> | * | * | 0 | - | - | | TM dst, src<br>dst AND src | † | 7[] | - | * | * | 0 | - | - | | XOR dst, src<br>dst«-dst<br>XOR src | † | B[ ] | - | * | * | Ö | - | - | † These instructions have an identical set of addressing modes, which are encoded for brevity. The first opcode nibble is found in the instruction set table above. The second nibble is expressed symbolically by a '[]' in this table, and its value is found in the following table to the left of the applicable addressing mode pair. For example, the opcode of an ADC instruction using the addressing modes r (destination) and Ir (source) is 13. | ss Mode<br>src | Lower<br>Opcode Nibble | |----------------|------------------------| | r . | [2] | | ir · | [3] | | R | [4] | | IR | [5] | | IM . | [6] | | iM | [7] | | | r<br>Ir<br>R<br>IR | #### · OPCODE MAP | Lower | Nibble | (Hex) | |-------|--------|-------| |-------|--------|-------| | | T-52-33-53 | |--------------|--------------| | Nibble (Hev) | \ 1-52-55-55 | | | | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | • | 9 | | A | В | ( | C. | D | | E | F | |--------------------|---|--------------------------|--------------------------|--------------------------------|----------------------------------|-----------------------------|------------------------------|-----------------------------|-------------------------------|--------------------|-----|---------------------------|---|---------------------|-------------------------|---|----------|-----------------------------|---|------------------|--------------| | Upper Nibble (Hex) | 0 | 6.5<br>DEC<br>R1 | 6.5<br>DEC<br>IR1 | 6.5<br>ADD<br>r1, r2 | 6,5<br>ADD<br>r1, lr2 | 10.5<br>ADD<br>R2, R1 | 10.5<br>ADD<br>IR2, R1 | 10.5<br>ADD<br>R1, IM | 10.5<br><b>ADD</b><br>IR1, IM | 6.5<br>LD<br>r1, F | , [ | 6,5<br><b>LD</b><br>r2, R | D | 10.5<br>JNZ<br>, RA | 12/10.0<br>JR<br>cc, RA | L | | 12.10<br><b>JP</b><br>cc, D | 1 | 6.5<br>INC<br>r1 | | | | 1 | 6.5<br>RLC<br>R1 | 6.5<br>RLC<br>IR1 | 6.5<br>ADC<br>r1, r2 | 6.5<br>ADC<br>r1, lr2 | 10.5<br>ADC<br>R2, R1 | 10.5<br>ADC<br>IR2, R1 | 10.5<br>ADC<br>R1, IM | 10.5<br>ADC<br>IR1, IM | | | l | | | | | | | | | | | | 2 | 6.5<br>INC<br>R1 | 6.5<br>INC<br>IR1 | 6.5<br>SUB<br>r1, r2 | 6.5<br>SUB<br>r1, lr2 | 10.5<br>SUB<br>R2, R1 | 10.5<br>SUB<br>IR2, R1 | 10.5<br>SUB<br>R1, IM | 10.5<br>SUB<br>IR1, IM | Ì | | | | | | | | | | | | | | 3 | 8.0<br>JP<br>IRR1 | 6.1<br>SRP<br>IM | 6.5<br>SBC<br>r1, r2 | 6.5<br>SBC<br>r1, fr2 | 10.5<br>SBC<br>R2, R1 | 10.5<br>SBC<br>IR2, R1 | 10.5<br>SBC<br>R1, IM | 10,5<br>SBC<br>IR1, IM | | | I | | | | | | | | | | | | 4 | 8.5<br><b>DA</b><br>R1 | 8.5<br><b>DA</b><br>IR1 | 6.5<br>OR<br>r1, r2 | 6.5<br><b>OR</b><br>r1, lr2 | 10.5<br><b>OR</b><br>R2, R1 | 10.5<br><b>OR</b><br>1R2, R1 | 10.5<br><b>OR</b><br>R1, IM | 10.5<br>OR<br>IR1, IM | | | | | | | | | | | | | | | 5 | 10.5<br>POP<br>R1 | 10.5<br>POP<br>IR1 | 6.5<br>AND<br>r1, r2 | 6.5<br>AND<br>r1, lr2 | 10.5<br>AND<br>R2, R1 | 10.5<br>AND<br>IR2, R1 | 10.5<br>AND<br>R1, IM | 10.5<br>AND<br>IR1, IM | | | | | | | | | | | | 6.0<br>WDT | | | 6 | 6.5<br>COM<br>R1 | 6.5<br>COM<br>IR1 | 6.5<br>TCM<br>r1, r2 | 6.5<br>TCM<br>r1, lr2 | 10.5<br>TCM<br>R2, R1 | 10.5<br>TCM<br>IR2, R1 | 10,5<br>TCM<br>R1, IM | 10.5<br>TCM<br>IR1, IM | | | | | | | | | | | | 6,0<br>STOP | | | 7 | 10/12.1<br>PUSH<br>R2 | 12/14.1<br>PUSH<br>IR2 | 6.5<br>TM<br>r1, r2 | 6.5<br><b>TM</b><br>r1, lr2 | 10.5<br>TM<br>R2, R1 | 10.5<br><b>TM</b><br>IR2, R1 | 10.5<br>TM<br>R1, IM | 10.5<br><b>TM</b><br>IR1, IM | | | | | | | | | | | | 7,0<br>HALT | | | 8 | 10.5<br>DECW<br>RR1 | 10.5<br>DECW<br>IR1 | | | | | | | | | | | | | | | | | | 6.1<br>Di | | | 9 | 6.5<br>RL<br>R1 | 6.5<br><b>RL</b><br>IR1 | | | | | | | | | | | | | | | | | | 6.1<br>El | | | A | 10.5<br>INCW<br>RR1 | 10.5<br>INCW<br>IR1 | 6.5<br><b>CP</b><br>r1, r2 | 6.5<br><b>CP</b><br>r1, lr2 | 10.5<br><b>CP</b><br>R2, R1 | 10.5<br><b>CP</b><br>IR2, R1 | 10.5<br><b>CP</b><br>R1, IM | 10.5<br><b>CP</b><br>IR1, IM | | | ١ | | | | | | | | | 14.0<br>RET | | | В | 6.5<br><b>CLR</b><br>R1 | 6.5<br><b>CLR</b><br>IR1 | 6.5<br>XOR<br>r1, r2 | 6.5<br>XOR<br>r1, lr2 | 10.5<br>XOR<br>R2, R1 | 10.5<br>XOR<br>IR2, R1 | 10.5<br>XOR<br>R1, IM | 10.5<br><b>XOR</b><br>IR1, IM | | | | | | | | | | | | 16.0<br>IRET | | | C | 6.5<br>RRC<br>R1 | 6.5<br>RRC<br>IR1 | 12.0<br><b>LDC</b><br>r1, lrr2 | 18.0<br><b>LDCI</b><br>lr1, lrr2 | | | | 10.5<br><b>LD</b><br>r1,x,R2 | | | İ | | | | | | | | | 6.5<br>RCF | | | D | 6.5<br>SRA<br>R1 | 6,5<br>SRA<br>IR1 | | 0.5 | 20.0<br>CALL*<br>IRR1 | 40.5 | 20.0<br>CALL<br>DA | 10.5<br><b>LD</b><br>r2,x,R1 | | | | | | | | | | | | 6.5<br>SCF | | | E | 6.5<br>RR<br>R1 | 6.5<br>RR<br>IR1 | | 6.5<br>LD<br>r1, IR2 | 10.5<br><b>LD</b><br>R2, R1 | 10.5<br>LD<br>IR2, R1 | 10.5<br><b>LD</b><br>R1, IM | 10.5<br><b>LD</b><br>IR1, IM | | | | | | | | | | | | 6.5<br>CCF | | | F | 8.5<br><b>SWAP</b><br>R1 | 8.5<br>SWAP<br>IR1 | | 6.5<br><b>LD</b><br>lr1, r2 | | 10.5<br><b>LD</b><br>R2, IR1 | | | <b> </b> | | 1 | | <u> </u> | 1 | , | <u> </u> | 1 | | 1 | 6.0<br>NOP | | | | | | 2 | | | | 3_ | | _ | | | | 2 | | - | | 3 | | | ر<br>ا | #### Bytes per instruction Legend: R = 8-bit address r = 4-bit address R<sub>1</sub>or r<sub>2</sub> = Dst address R<sub>1</sub>or r<sub>2</sub> = Src address Sequence: Opcode, First Operand, Second Operand Note: The blank are not defined. \* 2-byte instruction appears as a 3-byte instruction