



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             | Z8                                                     |
| Core Size                  | 8-Bit                                                  |
| Speed                      | 12MHz                                                  |
| Connectivity               | SPI                                                    |
| Peripherals                | POR, WDT                                               |
| Number of I/O              | 14                                                     |
| Program Memory Size        | 1KB (1K x 8)                                           |
| Program Memory Type        | ОТР                                                    |
| EEPROM Size                | -                                                      |
| RAM Size                   | 124 x 8                                                |
| Voltage - Supply (Vcc/Vdd) | 3V ~ 5.5V                                              |
| Data Converters            | -                                                      |
| Oscillator Type            | Internal                                               |
| Operating Temperature      | 0°C ~ 70°C (TA)                                        |
| Mounting Type              | Through Hole                                           |
| Package / Case             | 18-DIP (0.300", 7.62mm)                                |
| Supplier Device Package    | -                                                      |
| Purchase URL               | https://www.e-xfl.com/product-detail/zilog/z86e0612psg |

Email: info@E-XFL.COM

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



### **PIN DESCRIPTION**



Table 1. 18-Pin DIP and SOIC Pin Identification

| No       | Symbol                    | Function                                | Direction    |
|----------|---------------------------|-----------------------------------------|--------------|
| 1-4<br>5 | P24-27<br>V <sub>20</sub> | Port 2, pins 4, 5, 6, 7<br>Power Supply | In/Output    |
| 6        | V <sub>cc</sub><br>XTAL2  | Crystal Oscillator Clock                | Output       |
| 7        | XTAL1                     | Crystal Oscillator Clock                |              |
| 8-10     | P31-33                    | Port 3, pins 1, 2, 3                    | Fixed Input  |
| 11-13    | P34-36                    | Port 3, pins 4, 5, 6                    | Fixed Output |
| 14       | GND                       | Ground                                  | •            |
| 15-18    | P20-23                    | Port 2, pins 0, 1, 2, 3                 | In/Output    |

Figure 2. 18-Pin DIP Pin Configuration



Figure 3. 18-Pin SOIC 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 (P27-P20). Port 2 is an 8-bit, bidirectional, CMOS compatible I/O port. These eight 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 4a., 4b., and 4c.). Low EMI output buffers can be globally programmed by the software. In addition, when the SPI is enabled, P20 functions as data-in (DI), and P27 functions as data-out (DO) for the SPI (SPI on the Z86E06 only).





Figure 4a. Port 2 Configuration (Z86E06)

Auto Latch. The Auto Latch puts valid CMOS levels on all CMOS inputs (except P33, P32, P31) that are not externally driven. Whether this level is 0 or 1 cannot be determined. A valid CMOS level, rather than a floating node, reduces excessive supply current flow in the input buffer.

Port 3 (P36-P31). 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. Low EMI output buffers can be globally programmed by the software. Two on-board comparators 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 (P3M-bit D1). 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 when the analog mode is selected. P33 is a falling edge interrupt input only.

**Note:** P33 is available as an interrupt input only in the digital mode. P31 and P32 are valid interrupt inputs and P31 is the  $T_{\rm IN}$  input when the analog or digital input mode is selected.

The outputs from the analog comparator can be globally programmed to output from P34 and P35 by setting PCON (F) 00 bit D0 = 1.

Access to Counter/Timer 1 is made through P31 ( $T_{\text{IN}}$ ) and P36 ( $T_{\text{CL}\pi}$ ).

In the Z86E06, 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 5a and 5b).





Figure 5a. Port 3 Configuration

## PIN FUNCTIONS (Continued)



Figure 5b. Port 3 Configuration (Z86E06)

**Low EMI Emission.** The Z86E03/E06 can be programmed to operate in a low EMI emission mode in 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:

- The pre-drivers slew rate reduced to 10 ns (typical).
- Low EMI output drivers resistance of 200 ohms (typical).
- Low EMI oscillator.

Internal SCLK/TCLK = XTAL operation limited to a maximum of 4 MHz (250 ns cycle time) when the low EMI oscillator is selected and SCLK = External (SMR Register Bit D1=1).

**Comparator Inputs.** Port 3 Pin P31 and P32 each have a comparator front end. The comparator reference voltage pin P33 is common to both comparators. In analog mode, the P31 and P32 are the positive inputs to the comparators, and P33 is the reference voltage supplied to both comparators. In digital mode, Pin P33 can be used as a P33 register input or IRQ1 source.

# **FUNCTIONAL DESCRIPTION (Continued)**



Note: Default Setting After Reset = 00000000

## Figure 8. Register Pointer Register

Register File. The Register File consists of two I/O port registers, 60/124 general-purpose registers, and 13/15 control and status registers. The Z86E03 General-Purpose Register file ranges from address 00 to 3F while the Z86E06 General-Purpose Register file ranges from ad-

dress 00 to 7F (see Figure 9). 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 s divided into 16 working register groups, each occupying 16 continuous locations. The Register Pointer addresses the starting location of the active working-register group.

**General-Purpose Registers (GPR).** These registers are undefined after the device is powered up. The registers keep their last value after any reset, as long as the reset occurs in the V<sub>CC</sub> voltage-specified operating range. **Note:** Register R254 has been designated as a general-purpose register.

**Stack.** An 8-bit Stack Pointer (R255) used for the internal stack that resides within the 60/124 general-purpose registers.



Figure 9. Register Pointer

# **FUNCTIONAL DESCRIPTION (Continued)**

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, RQ4 (T0) or IRQ5 (T1), is generated. Note that IRQ4 is softwaregenerated in the Z86E03.

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 exter-

nal 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 ( $T_{\text{OUT}}$ ) through which T0 (E06 only), T1, or the internal clock can be output. The counter/timers can be cascaded by connecting the T0 output to the input of T1 (E06 only). The  $T_{\text{IN}}$  mode is enabled by setting PRE1 bit D1 (R243) to 0.

Interrupts. The Z86E03/E06 has six different interrupts from six different sources. The interrupts are maskable 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

STOP. This instruction turns off the internal clock and external crystal oscillation and reduces the standby current. The STOP mode is terminated by a RESET only, either by WDT time-out, 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)—Z86E06 Only. The Z86E06 incorporates a serial peripheral interface for communication with other microcontrollers and peripherals. The SPI does not exist on the Z86E03. 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.

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          |

The SPI Control Register (SCON) (Figure 13) 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 1 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.



\* Default Setting After Reset.

Figure 13. SPI Control Register (SCON) (Z86E06 Only)

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 Timer0 output for the SPI clock, and a 0 uses 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.



Figure 16. SPI Logic (Z86E06 Only)

PORT Configuration Register (PCON). The PCON configures the ports individually for comparator output on Port 3, low EMI noise on Ports 2 and 3, and low EMI noise oscillator. The PCON Register is located in the Expanded Register File at bank F, location 00 (Figure 17).

Comparator Output Port 3 (D0). Bit 0 controls the comparator use in Port 3. A 1 in this location brings the comparator outputs to P34, and P35 and a 0 releases the Port to its standard I/O configuration.

Bits D4-D1. These bits are reserved and must be 1.

Low EMI Port 2 (D5). Port 2 is configured as a Low EMI Port by resetting this bit (D5=0) or configured as a Standard Port by setting D5=1. The default value is 1.

Low EMI Port 3 (D6). Port 3 is configured as a Low EMI Port by resetting this bit (D6=0) or configured as a Standard Port by setting D6=1. The default value is 1.

Low EMI OSC (D7). This bit 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, it does not affect the relationship of SCLK and XTAL.



Figure 17. Port Configuration Register (PCON) (Write Only)















# **FUNCTIONAL DESCRIPTION (Continued)**

STOP-Mode Recovery Register (SMR). This register selects the clock divide value and determines the mode of STOP-Mode Recovery (Figure 18). 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. The SMR is located in bank F of the Expanded Register Group at address 0BH.



Figure 18a. STOP-Mode Recovery Register (Write Only except bit D7, which is Read Only.) (Z86E03)



Figure 18b. STOP-Mode Recovery Register (Write Only except bit D7, which is Read Only.) (Z86E06)

SCLK/TCLK Divide-by-16 Select (D0)—Z86E06 Only. 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).

External Clock Divide Mode (D1). This bit can eliminate the oscillator divide-by-two circuitry. When this bit is 0, SCLK (System Clock) and TCLK (Timer Clock) are equal to the external clock frequency divided by two. The SCLK/TCLK is equal to the external clock frequency when this bit is set (D1=1). Using this bit, together with D7 of PCON, helps further lower EMI [i.e., D7 (PCON)=0, D1 (SMR=1). The default setting is 0.



\* Not available on the Z86E03, WDT fixed at 15 ms/1024TpC in the Z86E03.

Figure 21. Resets and WDT



### SPECIAL FUNCTIONS **EPROM Mode**

Besides  $\rm V_{DD}$  and GND ( $\rm V_{SS}),$  the Z86E03/E06 changes all its pin functions in the EPROM mode. XTAL2 has no function, XTAL1 functions as /CE, P31 functions as /OE, P32 functions as EPM, P33 functions as V<sub>FP</sub>, and P02 functions as /PGM.

EPROM Protect. ROM protect is EPROM-programmable. It is selected by the customer at the time the ROM code is EPROM programmed. The selection of ROM Protect disables the LDC and LDCI instructions in all modes. A ROM look-up table cannot be used in this mode.

### Application Caution

Please note that when using the device in a noisy enviro ment, it is suggested that the voltages on the EP /CE, /OE pins be clamped to  $V_{cc}$  through a diode to prevent accidentally entering the OTP mode. requires both a diode and a 100 pF capacitor.

User Modes. Table 7 shows the programming voltage each mode of Z86E06.

**Table 7. OTP Programming Table** 

| Programming Modes                        | V <sub>PP</sub> | EPM             | /CE             | /OE                                | /PGM            | ADDR         | DATA       | V,c*         |
|------------------------------------------|-----------------|-----------------|-----------------|------------------------------------|-----------------|--------------|------------|--------------|
| EPROM READ1<br>EPROM READ2               | ×               | V <sub>H</sub>  | V <sub>IL</sub> | V <sub>IL</sub>                    | V <sub>IH</sub> | ADDR<br>ADDR | Out<br>Out | 4 5V<br>5 5V |
| PROGRAM<br>PROGRAM VERIFY                | V <sub>H</sub>  | X               | V <sub>IL</sub> | V <sub>IH</sub><br>V <sub>IL</sub> | V <sub>IL</sub> | ADDR<br>ADDR | In<br>Out  | 6 0V<br>6 0V |
| EPROM PROTECT PERMANENT WDT ENABLED      | V <sub>H</sub>  | V <sub>H</sub>  | V <sub>H</sub>  | V <sub>IH</sub>                    | V <sub>IL</sub> | NU<br>NU     | NU<br>NU   | 6 0V         |
| GLOBAL AUTO LATCH DISABLED RC OSCILLATOR | V <sub>H</sub>  | V <sub>IH</sub> | V <sub>H</sub>  | V <sub>IL</sub>                    | V <sub>IL</sub> | NU<br>NU     | NU<br>NU   | 6 0V         |

### Notes:

In EPROM Mode, all Z8 inputs are TTL inputs.

 $V_{H}$  = 12.5V ±0.5V  $V_{H}$  = As per specific Z8 DC specification.

V<sub>it.</sub> = As per specific Z8 DC specification.
X = Not used, but must be set to V V

X = Not used, but must be set to V<sub>H</sub>, V<sub>H</sub>, or V<sub>IL</sub> level.

NU = Not used, but must be set to either V<sub>H</sub> or V<sub>IL</sub> level.

I<sub>pp</sub> during programming = 40 mA maximum. l<sub>cc</sub> during programming, verify, or read = 40 mA maximum.
\*V<sub>cc</sub> has a tolerance of ±0.25V.



# **SPECIAL FUNCTIONS** (Continued) **EPROM Mode**



Figure 25. Z86E03/E06 Programming Waveform (Program and Verify)



Figure 27. Z86E03/E06 Programming Algorithm



AC ELECTRICAL CHARACTERISTICS
Additional Timing Table (Divide-By-One Mode, SCLK/TCLK = EXTERNAL)

| No | Symbol  | Parameter                       | V <sub>cc</sub><br>Note [6] | T <sub>A</sub> = 0°C to +70°C<br>4 MHz<br>Min Max | T <sub>A</sub> = -40°C to +105°C<br>4 MHz<br>Min Max | Units       | Notes     |
|----|---------|---------------------------------|-----------------------------|---------------------------------------------------|------------------------------------------------------|-------------|-----------|
| 1  | ТрС     | Input Clock Period              | 3.0V                        | 250 DC                                            | 250 DC                                               | ns          | [1,7,8    |
|    |         |                                 | 5.5V                        | 250 DC                                            | 250 DC                                               | ns          | [1,7,8]   |
| 2  | TrC,TfC | Clock Input Rise & Fall Times   | 3.0V                        | 25                                                | 25                                                   | ns          | [1,7,8]   |
|    |         |                                 | 5.5V                        | 25                                                | 25                                                   | ns          | [1,7,8]   |
| 3  | TwC     | Input Clock Width               | 3.0V                        | 125                                               | 125                                                  | ns          | [1,7,8]   |
|    |         | ·                               | 5.5V                        | 125                                               | 125                                                  | ns          | [1,7,8]   |
| 4  | TwTinL  | Timer Input Low Width           | 3.0V                        |                                                   |                                                      | <del></del> |           |
| •  |         | Timor ripat Low Width           | 5.5V                        | 100<br>70                                         | 100<br>70                                            | ns          | [1,7,8]   |
| _  | T. T. H |                                 |                             |                                                   | 70                                                   | ΠS          | [1,7,8]   |
| 5  | TwTinH  | Timer Input High Width          | 3.0V                        | 3TpC                                              | ЗТрС                                                 |             | [1,7,8]   |
|    |         |                                 | 5.5V                        | 3TpC                                              | ЗТрС                                                 |             | [1,7,8]   |
| 6  | TpTin   | Timer Input Period              | 3.0V                        | 4TpC                                              | 4TpC                                                 |             | [1,7,8]   |
|    |         |                                 | 5.5V                        | 4TpC                                              | 4TpC                                                 |             | [1,7,8]   |
| 7  | TrTin,  | Timer Input Rise & Fall Timer   | 3.0V                        | 100                                               | 100                                                  | ns          | [1,7,8]   |
|    | TfTin   |                                 | 5.5V                        | 100                                               | 100                                                  | ns          | [1,7,8]   |
| 8  | TwiL    | Int. Request Low Time           | 3.0V                        | 100                                               | 100                                                  | ns          | [1,2,7,8  |
|    |         | •                               | 5.5V                        | 70                                                | 70                                                   | ns          | [1,7,8]   |
| 9  | TwiH    | Int. Request Input High Time    | 3.0V                        | 27-0                                              |                                                      |             |           |
| •  | 1 11111 | mic rieduest niput riigii riine | 5.5V                        | 3TpC                                              | 3TpC                                                 |             | [1,2,7,8] |
|    | _       |                                 |                             | ЗТрС                                              | ЗТрС                                                 |             | [1,2,7,8] |
| 10 | Twsm    | Stop-Mode Recovery Width Spec   | 3.0V                        | 12                                                | 12                                                   | ns          | [1,4,]    |
|    |         |                                 | 5.5V                        | 12                                                | 12                                                   | ns          | [1,4]     |
| 11 | Tost    | Oscillator Startup Time         | 3.0V                        | 5TpC                                              | 5TpC                                                 |             | [1,3,8,9] |
|    |         |                                 | 5.5V                        | 5TpC                                              | 5TpC                                                 |             | [1,3,8,9] |

Notes:
[1] Timing Reference uses 0.7 V<sub>∞</sub> for a logic 1 and 0.2 V<sub>∞</sub> for a logic 0.
[2] Interrupt request via Port 3 (P33-P31).
[3] SMR-D5 = 0.
[4] SMR-D5 = 1, POR STOP mode delay is on.
[5] Reg. WDTMR.

<sup>[6]</sup>  $V_{\infty} = 3.0V \text{ to } 5.5V.$ [7] SMR D1 = 1.

<sup>[8]</sup> Maximum frequency for internal system clock is 4 MHz when using

XTAL divide-by-one mode.
[9] For RC and LC oscillator, and for oscillator driven by clock driver.

# EXPANDED REGISTER FILE CONTROL REGISTERS



- \* Default setting after RESET.

  \* Default setting after RESET and STOP-Mode Recovery.
  † E03 reserved; must be 0.
  †† E06 only

Figure 30. STOP-Mode Recovery Register (Write Only except bit D7, which is Read Only)



\* Default setting after RESET. † For E06; E03 must be D0 = 1, D1 = 0.

Figure 31. Watch-Dog Timer Mode Register (Write Only)



Default Setting After Reset.

Figure 32. PORT Control Register (Write Only)



\* Default Setting After Reset.

Figure 33. SPI Control Register (Z86E06 Only)

R243 PRE1



## **EXPANDED REGISTER FILE CONTROL REGISTERS** (Continued)

SCOMP (C) 00 D7 D6 D5 D4 D3 D2 D1 D0 PUBUFF (C) 01

D7 D6 D5 D4 D3 D2 D1 D0

Figure 34. SPI Compare Register (Z86E06 Only)

Figure 35. SPI Receive Buffer (Z86E06 Only)

### **Z8 CONTROL REGISTER DIAGRAMS**



Figure 36. Reserved



D7 D6 D5 D4 D3 D2 D1 D0

Count Mode
0 T 1 Single Pass
1 T 1 Modulo-N

Clock Source
1 T 1 Internal
0 T 1 External Timing Input
(TN) Mode

Prescaler Modulo
(Range: 1-64 Decimal
01-00 HEX)

Figure 39. Prescaler 1 Register (F3<sub>x</sub>: Write Only)



Figure 40. Counter/Timer 0 Register (F4<sub>H</sub>: Read/Write; Z86E06 Only)



(F1<sub>H</sub>: Read/Write)

Figure 38. Counter Timer 1 Register (F2,: Read/Write)



Figure 41. Prescaler 0 Register (F5<sub>H</sub>: Write Only; Z86E06 Only)



## **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                                             |
| 1r      | 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)       |  |  |  |  |  |  |

**Flags.** Control register (R252) contains the following six flags:

| Symbol       | Meaning                             |
|--------------|-------------------------------------|
| С            | Carry flag                          |
| Z            | Zero flag                           |
| S            | Sign flag                           |
| V            | Overflow flag                       |
| D            | Decimal-adjust flag                 |
| H ·          | Half-carry flag                     |
| Affected fla | gs are indicated by:                |
| 0            | Clear to zero                       |
| 1            | Set to one                          |
| *            | Set to clear according to operation |
| _            | Unaffected                          |
|              |                                     |

## **CONDITION CODES**

| Value                                | Mnemonic                      | Meaning                                                                                                                                   | Flags Set                                                                               |
|--------------------------------------|-------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------|
| 1000<br>0111<br>1111<br>0110<br>1110 | C<br>NC<br>Z<br>NZ            | Always True<br>Carry<br>No Carry<br>Zero<br>Not Zero                                                                                      | C = 1<br>C = 0<br>Z = 1<br>Z = 0                                                        |
| 1101<br>0101<br>0100<br>1100<br>0110 | PL<br>MI<br>OV<br>NOV<br>EQ   | Plus<br>Minus<br>Overflow<br>No Overflow<br>Equal                                                                                         | S = 0<br>S = 1<br>V = 1<br>V = 0<br>Z = 1                                               |
| 1110<br>1001<br>0001<br>1010<br>0010 | NE<br>GE<br>LT<br>GT<br>LE    | Not Equal<br>Greater Than or Equal<br>Less than<br>Greater Than<br>Less Than or Equal                                                     | Z = 0<br>(S XOR V) = 0<br>(S XOR V) = 1<br>[Z OR (S XOR V)] = 0<br>[Z OR (S XOR V)] = 1 |
| 1111<br>0111<br>1011<br>0011<br>0000 | UGE<br>ULT<br>UGT<br>ULE<br>F | Unsigned Greater Than or Equal<br>Unsigned Less Than<br>Unsigned Greater Than<br>Unsigned Less Than or Equal<br>Never True (Always False) | C = 0<br>C = 1<br>(C = 0 AND Z = 0) = 1<br>(C OR Z) = 1                                 |

# INSTRUCTION FORMATS



CCF, DI, EI, IRET, NOP, RCF, RET, SCF

OPC dst

### One-Byte Instructions



Two-Byte instructions

Three-Byte Instructions

# INSTRUCTION SUMMARY

Note: Assignment of a value is indicated by the symbol " ← ". For example:

dst (7)

dst ← dst + src

indicates that the source data is added to the destination data and the result is stored in the destination location. The notation "addr (n)" is used to refer to bit (n) of a given operand location. For example:

refers to bit 7 of the destination operand.

## **OPCODE MAP**

|                    |   | Lower Nibble (Hex)           |                          |                                |                                  |                              |                               |                              |                               |                           |     |                            |                                  |                                |                                                  |                                |                  |                    |
|--------------------|---|------------------------------|--------------------------|--------------------------------|----------------------------------|------------------------------|-------------------------------|------------------------------|-------------------------------|---------------------------|-----|----------------------------|----------------------------------|--------------------------------|--------------------------------------------------|--------------------------------|------------------|--------------------|
|                    |   | 0                            | 1                        | 2                              | 3                                | 4                            | 5                             | 6                            | 7                             | 8                         |     | 9                          | A                                | В                              | С                                                | D                              | E                | F                  |
|                    | 0 | 6.5<br><b>DEC</b><br>R1      | 6.5<br><b>DEC</b><br>IR1 | 6.5<br><b>ADD</b><br>r1, r2    | 6.5<br><b>ADD</b><br>r1, lr2     | 10.5<br><b>ADD</b><br>R2, R1 | 10.5<br>ADD<br>IR2, R1        | 10.5<br><b>ADD</b><br>R1, IM | 10.5<br>ADD<br>IR1, IM        | 6.5<br><b>LD</b><br>r1, R | - 1 | 6.5<br><b>LD</b><br>r2, R1 | 12/10.5<br><b>DJNZ</b><br>r1, RA | 12/10.0<br><b>JR</b><br>cc, RA | 6.5<br><b>LD</b><br>r1, IM                       | 12.10.0<br><b>JP</b><br>cc, DA | 6.5<br>INC<br>r1 |                    |
|                    | 1 | 6.5<br><b>RLC</b><br>R1      | 6.5<br>RLC<br>IR1        | 6.5<br><b>ADC</b><br>r1, r2    | 6.5<br><b>ADC</b><br>r1, lr2     | 10.5<br>ADC<br>R2, R1        | 10.5<br>ADC<br>IR2, R1        | 10.5<br><b>ADC</b><br>R1, IM | 10.5<br><b>ADC</b><br>IR1, IM |                           |     |                            |                                  |                                |                                                  |                                | Ï                |                    |
|                    | 2 | 6.5<br><b>INC</b><br>R1      | 6.5<br>INC<br>IR1        | 6.5<br><b>SUB</b><br>r1, r2    | 6.5<br><b>SUB</b><br>r1, lr2     | 10.5<br>SUB<br>R2, R1        | 10.5<br><b>SUB</b><br>IR2, R1 | 10.5<br><b>SUB</b><br>R1, IM | 10.5<br><b>SUB</b><br>IR1, IM |                           |     |                            |                                  |                                |                                                  |                                |                  |                    |
|                    | 3 | 8.0<br><b>JP</b><br>IRR1     | 6.1<br>SRP<br>IM         | 6.5<br><b>SBC</b><br>r1, r2    | 6.5<br>SBC<br>r1, ir2            | 10.5<br><b>SBC</b><br>R2, R1 | 10.5<br>SBC<br>IR2, R1        | 10.5<br>SBC<br>R1, IM        | 10.5<br>SBC<br>IR1, IM        |                           |     |                            |                                  |                                |                                                  |                                |                  |                    |
|                    | 4 | 8.5<br><b>DA</b><br>R1       | 8.5<br><b>DA</b><br>IR1  | 6.5<br><b>OR</b><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>IR2, R1  | 10.5<br><b>CR</b><br>R1, IM  | 10.5<br><b>OR</b><br>IR1, IM  |                           |     |                            |                                  |                                |                                                  |                                |                  |                    |
|                    | 5 | 10.5<br><b>POP</b><br>R1     | 10.5<br>POP<br>IR1       | 6.5<br>AND<br>r1, r2           | 6.5<br><b>AND</b><br>r1, ir2     | 10.5<br>AND<br>R2, R1        | 10.5<br>AND<br>IR2, R1        | 10.5<br><b>AND</b><br>R1, IM | 10.5<br>AND<br>IR1, IM        |                           |     |                            |                                  |                                |                                                  |                                |                  | 6.0<br><b>WDT</b>  |
| Upper Nibble (Hex) | 6 | 6.5<br><b>COM</b><br>R1      | 6.5<br>COM<br>IR1        | 6.5<br><b>TCM</b><br>r1, r2    | 6.5<br><b>TCM</b><br>r1, lr2     | 10.5<br><b>TCM</b><br>R2, R1 | 10.5<br><b>TCM</b><br>IR2, R1 | 10.5<br>TCM<br>R1, IM        | 10.5<br><b>TCM</b><br>IR1, IM |                           |     |                            |                                  |                                |                                                  |                                |                  | 6.0<br><b>STOP</b> |
|                    | 7 | 10/12.1<br><b>PUSH</b><br>R2 | 12/14.1<br>PUSH<br>IR2   | 6.5<br><b>TM</b><br>r1, r2     | 6.5<br><b>TM</b><br>r1, lr2      | 10.5<br><b>TM</b><br>R2, R1  | 10.5<br><b>TM</b><br>IR2, R1  | 10.5<br><b>TM</b><br>R1, IM  | 10.5<br><b>TM</b><br>IR1, IM  |                           |     |                            |                                  |                                |                                                  |                                |                  | 7.0<br><b>HALT</b> |
| Jpper N            | 8 | 10.5<br>DECW<br>RR1          | 10.5<br>DECW<br>IR1      |                                |                                  |                              |                               |                              |                               | ļ                         |     |                            |                                  |                                |                                                  |                                |                  | 6.1<br><b>DI</b>   |
| _                  | 9 | 6.5<br><b>RL</b><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>CLR<br>IR1        | 6.5<br><b>XOR</b><br>r1, r2    | 6.5<br><b>XOR</b><br>r1, lr2     | 10.5<br><b>XOR</b><br>R2, R1 | 10.5<br><b>XOR</b><br>IR2, R1 | 10.5<br><b>XOR</b><br>R1, IM | 10.5<br><b>XOR</b><br>IR1, IM |                           |     |                            |                                  |                                |                                                  |                                |                  | 16.0<br>IRET       |
|                    | С | 6.5<br><b>RRC</b><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><b>SRA</b><br>R1      | 6.5<br><b>SRA</b><br>IR1 |                                |                                  | 20.0<br>CALL*<br>IRR1        |                               | 20.0<br>CALL<br>DA           | 10.5<br><b>LD</b><br>r2,x,R1  |                           |     |                            |                                  |                                |                                                  |                                |                  | 6.5<br><b>SCF</b>  |
|                    | E | 6.5<br><b>RR</b><br>R1       | 6.5<br><b>RR</b><br>IR1  |                                | 6.5<br><b>LD</b><br>r1, IR2      | 10.5<br><b>LD</b><br>R2, R1  | 10.5<br><b>LD</b><br>IR2, R1  | 10.5<br><b>LD</b><br>R1, IM  | 10.5<br><b>LD</b><br>IR1, IM  |                           |     |                            |                                  |                                |                                                  |                                |                  | 6.5<br><b>CCF</b>  |
|                    | F | 8.5<br><b>SWAP</b><br>R1     | 8.5<br>SWAP<br>IR1       |                                | 6.5<br><b>LD</b><br>Ir1, r2      |                              | 10.5<br><b>LD</b><br>R2, IR1  |                              |                               | <b>↓</b>                  |     |                            |                                  |                                |                                                  |                                |                  | 6.0<br><b>NOP</b>  |
|                    | • |                              |                          |                                |                                  |                              |                               |                              |                               |                           | -   |                            |                                  |                                | <del>-                                    </del> | <del></del>                    | للت              |                    |



Bytes per instruction

Legend: R = 8-bit address r = 4-bit address

R<sub>1</sub> or r<sub>1</sub> = Dst address R<sub>2</sub> or r<sub>2</sub> = Src address

Sequence: Opcode, First Operand, Second Operand

Note: The blank areas are reserved.

\* 2-byte instruction appears as a 3-byte instruction