# 64000 LOGIC DEVELOPMENT SYSTEM



# ASSEMBLER SUPPLEMENT Z80



#### CERTIFICATION

Hewlett-Packard Company certifies that this product met its published specifications at the time of shipment from the factory. Hewlett-Packard further certifies that its calibration measurements are traceable to the United States National Bureau of Standards, to the extent allowed by the Bureau's calibration facility, and to the calibration facilities of other International Standards Organization members.

#### WARRANTY

This Hewlett-Packard system product is warranted against defects in materials and workmanship for a period of 90 days from date of installation. During the warranty period, HP will, at its options, either repair or replace products which prove to be defective.

Warranty service of this product will be performed at Buyer's facility at no charge within HP service travel areas. Outside HP service travel areas, warranty service will be performed at Buyer's facility only upon HP's prior agreement and Buyer shall pay HP's round trip travel expenses. In all other cases, products must be returned to a service facility designated by HP.

For products returned to HP for warranty service. Buyer shall prepay shipping charges to HP and HP shall pay shipping charges to return the product to Buyer. However, Buyer shall pay all shipping charges, duties, and taxes for products returned to HP from another country.

HP warrants that its software and firmware designated by HP for use with an instrument will execute its programming instructions when properly installed on that instrument. HP does not warrant that the operation of the instrument, or software, or firmware will be uninterrupted or error free.

#### LIMITATION OF WARRANTY

The foregoing warranty shall not apply to defects resulting from improper or inadequate maintenance by Buyer, Buyer-supplied software or interfacing, unauthorized modification or misuse, operation outside of the environmental specifications for the product, or improper site preparation or maintenance.

NO OTHER WARRANTY IS EXPRESSED OR IMPLIED. HP SPECIFICALLY DISCLAIMS THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.

#### EXCLUSIVE REMEDIES

THE REMEDIES PROVIDED HEREIN ARE BUYER'S SOLE AND EXCLUSIVE REMEDIES. HP SHALL NOT BE LIABLE FOR ANY DIRECT, INDIRECT, SPECIAL, INCIDENTAL, OR CONSEQUENTIAL DAMAGES, WHETHER BASED ON CONTRACT, TORT, OR ANY OTHER LEGAL THEORY.

#### ASSISTANCE

Product maintenance agreements and other customer assistance agreements are available for Hewlett-Packard products.

For any assistance, contact your nearest Hewlett-Packard Sales and Service Office.

## Model 64000 Reference Manuals

The following block diagram shows the documentation scheme for the HP Model 64000 Logic Development System. The interconnecting arrows show the recommended progression through the manuals as a way of gaining familiarity with the system.

For a detailed map showing specific manuals and their part numbers, refer to the Manual Map in the System Overview Manual.



# **Printing History**

Each new edition of this manual incorporates all material updated since the previous edition. Each new or revised page is indicated by a revision (rev) date. Manual change sheets are issued between editions, allowing you to correct or insert information in the current edition.

The part number on the back cover changes only when each new edition is published. Minor corrections or additions may be made as the manual is reprinted between editions.

First Printing . . . March 1980 Second Printing . . . September 1980

.

## Z80 Assembler Supplement



HP Model 64000 Logic Development System

© COPYRIGHT HEWLETT-PACKARD COMPANY/COLORADO SPRINGS DIVISION 1980 1900 GARDEN OF THE GODS ROAD, COLORADO SPRINGS, COLORADO, U.S.A.

ALL RIGHTS RESERVED

The information in this supplement has been checked for accuracy and is believed to be correct; however, no responsibility is assumed for inaccuracies. When discrepancies are noted, refer to the manufacturer's Microprocessor Programming Manual for clarification.

## **Table of Contents**

#### Chapter 1: General Information

| Introduction                       |
|------------------------------------|
| Programming Considerations1-1      |
| Z80 Architecture                   |
| Accumulator and Flag Registers1-1  |
| General Purpose Registers1-1       |
| Program Counter Register1-2        |
| Index Registers                    |
| Stack Pointer Register             |
| Interrupt Page Address Register1-2 |
| Memory Refresh Register            |
| Modes of Addressing                |
| Immediate Addressing1-3            |
| Immediate Extended Addressing1-3   |
| Relative Addressing1-3             |
| Extended Addressing1-3             |
| Indexed Addressing1-4              |
| Register Addressing1-4             |
| Register Indirect Addressing1-4    |
| Implied Addressing1-4              |
| Bit Addressing                     |
| Modified Page Zero Addressing1-4   |
| Condition Flags                    |
| Zero (Z) Flag                      |
| Sign (S) Flag                      |
| Parity/Overflow (P/V) Flag1-5      |
| Carry (CY) Flag                    |
| Half Carry (HC) Flag               |
| Add/Subtract (N) Flag              |

## Chapter 2: Operand Rules and Conventions

| Types of Information             |     |
|----------------------------------|-----|
| Identifying Types of Information | 2-2 |

#### Chapter 3: Special Pseudo Instructions

| Introduction     | 1 |
|------------------|---|
| DEFB Instruction | 2 |
| DEFS Instruction | 3 |
| DEFW Instruction | 4 |

# Table of Contents (Cont'd)

#### Chapter 4: Assembler Output Listing

| General                | . 4-1 |
|------------------------|-------|
| Input/Output Files     | . 4-1 |
| Source Input File      | .4-1  |
| Assembler Output Files | . 4-1 |
| Output Listing         | . 4-2 |
|                        |       |

### Chapter 5: Z80 Instruction Set Summary

| General            | ĺ |
|--------------------|---|
| Predefined Symbols | 3 |

# **List of Tables**

| 4-1. | Source Program Format Example | . 4-3 |
|------|-------------------------------|-------|
| 4-2. | Assembler Output Listing      | . 4-4 |
| 4-3. | Assembler Output with Errors  | . 4-6 |

# Chapter **1** General Information (Z80)

## Introduction

This chapter contains general information about the Z80 microprocessor. It briefly discusses the microprocessor's architecture, addressing modes, and condition codes. For a detailed description of the microprocessor refer to the manufacturer's Z80 User's Manual.

#### NOTE

If you are unfamiliar with assembly language or assemblers, read Chapter 6 in the Assembler/Linker Reference Manual. That chapter briefly reviews assemblers, assembly language, and the numbering systems.

# **Programming Considerations**

## **Z80** Architecture

There are eighteen 8-bit registers and four 16-bit registers available in the Z80 microprocessor for control of external memory and peripheral devices that may be associated with the target system. These registers are discussed briefly in the following paragraphs.

## **Accumulator and Flag Registers**

The microprocessor contains two independent 8-bit registers (accumulators) with associated 8-bit flag registers. They are referred to as register A and register A'. The F flag register is associated with the A register and the F' flag register is associated with the A' register. The A or A' register holds the result of 8-bit arithmetic or logical operations while the flag register (F or F') indicates the specific effect of those operations.

## **General Purpose Registers**

There are two sets of general purpose registers with each set containing six 8-bit registers that may be addressed individually or as 16-bit register pairs. One set contains register pairs BC, DE, and HL while the second set contains register pairs BC', DE', and HL'.

## **Program Counter Register**

The program counter (PC) is a two-byte (16-bit) register that points to the current program address. After each instruction the program counter will be automatically incremented. When a program branch is required, the branch address will be placed into the program counter, overriding the incremental operation.

## **Index Registers**

The two index registers (IX and IY) are special-purpose 16-bit registers that may be used as pointers to memory locations where data may be retrieved or stored. When using the indexed addressing mode, an additional byte may be included in the instructions to indicate an offset from the register content. The offset must be specified as a two's complement signed integer.

## **Stack Pointer Register**

The stack pointer (SP) register is another special-purpose 16-bit register that allows the microprocessor to use a section of external memory as a last-in, first-out (LIFO) file. Data may be pushed onto the stack or pulled off the stack by using the PUSH and POP instructions.

## Interrupt Page Address Register

The microprocessor may be operated whereby an indirect call to any memory location can be accomplished in response to an interrupt. The interrupt address (1) register may be used to store the high-order 8 bits of the indirect address while the interrupting device provides the low-order 8 bits.

## **Memory Refresh Register**

The microprocessor has a memory refresh register that allows dynamic memories to be used in the same fashion as static memories. The data in the refresh counter will be sent out on the address bus along with a refresh control signal while the microprocessor is executing an instruction.

## Modes of Addressing

A number of instructions, such as the "compare" instruction, require data to be operated on. The method of specifing or locating the data is generally referred to as the mode of addressing. The Z80 microprocessor uses ten addressing modes to reference the data stored in memory or in registers. The addressing modes are briefly explained in the following paragraphs.

## **Immediate Addressing**

In this mode of addressing, the operand field of the instruction contains the value to be used in the operation or computation. The value is an 8-bit quantity that immediately follows the opcode.

## **Immediate Extended Addressing**

This mode of addressing is the same as the immediate addressing mode except that the data is a 16-bit quantity (two bytes) that immediately follows the opcode.

## **Relative Addressing**

Branch instructions are somewhat different from other instructions in that their selected addresses do not indicate the location of data. Instead, the addresses indicate the location of the next instruction. This location will be relative to the current setting of the program counter (plus 2).

For the relative addressing mode to be valid, the branch distance (range) between the instruction and the destination of the branch must fall in the value range of -128 to +127 bytes. This relationship between the relative address and the absolute address of the destination of the branch may be expressed by:

$$\mathsf{DA} = (\mathsf{PC+2}) + \mathsf{R}$$

where:

DA = address of the destination of the branch instruction.

PC = content of the lowest 8 bits of the program counter.

R = the 8-bit, two's complement, binary number stored in the second byte of the instruction.

## **Extended Addressing**

In the extended addressing mode, the instruction uses three bytes of memory with the first byte containing the opcode of the instruction, the second byte containing the low-order 8 bits of the absolute numerical address, and the third byte containing the high-order 8 bits.

The second and third bytes of an extended address instruction may be an address to which a program can jump or it may be an address where an operand is located. To indicate an operand location as opposed to a jump address, enclose the second and third bytes of the instruction in brackets. The use of brackets always means that the enclosed value is to be used as a pointer to a memory location.

#### NOTE

Do not use parentheses as enclosing symbols. The Model 64000 assembler decodes parentheses as enclosing expressions.

### Indexed Addressing

The byte of data following the opcode contains an offset that is added to the designated index register to form a pointer to a memory location. The instruction will specify which index register (IX or IY) that is to be used. The content of the index register will not be altered by this operation.

### **Register Addressing**

The instruction itself specifies the register that contains the data.

## **Register Indirect Addressing**

The instruction specifies a 16-bit register that contains the memory address where the data is located.

### Implied Addressing

In a number of instructions, the opcode specifies one or more registers that contain operands or where results are to be stored. For example, there are a number of arithmetic instructions where the accumulator is always implied to be the destination of the results of the operation.

## **Bit Addressing**

The instruction set for the Z80 contains many set, reset, and test instructions. These instructions permit any memory location or register to be specified for a bit operation. Three bits in the opcode designates the specific bit to be manipulated or tested.

## Modified Page Zero Addressing

The Z80 microprocessor has a special call instruction that may specify any one of eight locations in page zero of memory. These locations may be used to initialize restart subroutines.

# **Condition Flags**

There are six condition flags associated with each flag register. The state of each flag will be established by the execution of various instructions. Unless the description of an instruction states otherwise (see Chapter 5), the condition flags associated with a specified register are affected as described in the following paragraphs.

## Zero (Z) Flag

If the result of the instruction has the value of 'zero', the zero flag will be set to 'one'; otherwise, it will be reset. The zero flag is assigned to bit-position 6 in the flag register.

## Sign (S) Flag

After an operation, if the most significant bit in the register has the value of 'one', the sign flag will be set to 'one'; otherwise, it will be reset. The sign flag is assigned to bit-position 7 in the flag register.

## Parity/Overflow (P/V) Flag

For logical operations, if the result of the instruction indicates even parity, the parity/overflow flag will be set; otherwise, it will be reset. For signed two's complement arithmetic operation, the parity/overflow flag will be set if the two's complement number in the associated register is in error. The error indicates that the resulting number of the arithmetic operation exceeds the maximum possible number (-128 to +127) that can be represented by the two's complement notation. The parity/overflow flag is assigned to bit-position 2 in the flag register.

## Carry (CY) Flag

If the result of the instruction is a carry (from addition) or a borrow (from subtraction) out of the high-order bit, the carry/borrow flag will be set to 'one'; otherwise, it will be reset. The carry flag is assigned to bit-position  $\emptyset$  in the flag register.

## Half Carry (HC) Flag

If the instruction causes a carry out of bit 3 into bit 4 of the resulting value, the auxiliary carry flag will be set to 'one'; otherwise, it will be reset. The half carry flag is assigned to bit-position 4 in the flag register.

## Add/Subtract (N) Flag

This flag is used to specify the type of instruction that was executed last so that a following decimal adjust operation will be executed correctly by the microprocessor. For all 'add' instructions, the N flag will be reset. For all 'subtract' instructions, the N flag will be set. The add/subtract flag is assigned to bit-position 1 in the flag register.

### NOTE

The first four flags (Z, S, P/V, and C) may be checked and - used as conditions for jump, call, or return instructions. Bitpositions 3 and 5 in the flag register are not used.

# **Operand Rules and Conventions**

# **Types of Information**

There are five types of information that may be used as data in the operand field:

a. Register Information - operands may reference directly, data contained in the processor registers such as the stack, register A, or data memory registers B,C,D,E,H, and L.

A.RØ

#### Example:

LD

;LOAD CONTENTS OF ;REGISTER Ø INTO ;REGISTER A

b. Register Pair Information - operands may reference directly data contained in register pairs such as the BC and DE registers.

#### Examples:

| LD | SP,HL    | ;LOAD REGISTER PAIR<br>;HL INTO STACK<br>;POINTER  |
|----|----------|----------------------------------------------------|
| LD | DE,5FFFH | ;LOAD IMMEDIATE DATA<br>;INTO REGISTER PAIR<br>;DE |

c. Immediate Data - operands may contain immediate data. The required value is inserted directly into the operand field. The value may be in the form of numbers, an expression to be evaluated at assembly time, a symbol, or an ASCII constant enclosed in quotation marks.

#### **Examples:**

| LD | D,ØFFH | ;LOAD "FF" HEX INTO<br>;REGISTER D                                 |
|----|--------|--------------------------------------------------------------------|
| LD | В,"А"  | ;LOAD VALUE OF ASCII<br>;CONSTANT A (Ø1ØØØØØ1)<br>;INTO REGISTER B |

d. 16-bit Memory Address - operands may reference a 16-bit absolute memory address within the range of  $\emptyset$  to 65,535 that contains the operand data.

#### Example:

- LD IX,[HL]
- e. Dual Operands when the operand field contains two operands, the first operand listed is the destination and the second operand is the source.

#### **Example:**

LD

;LOAD REGISTER H ;INTO REGISTER A

# **Identifying Types of Information**

A,H

There are nine ways to define the types of information that can be presented in the operand field. These ways are discussed in the following paragraphs.

a. Binary Data - each binary number must be followed by the letter B.

#### Example:

- SAM LD H,10010011B
- b. Octal Data each octal number must be followed by either the letter O or the letter Q.

| Example: |    |    |       |
|----------|----|----|-------|
| SAM      |    | LD | H,55O |
| SAM      | or | LD | H,55Q |

c. Hexadecimal Data - each hexadecimal number must begin with a number and be followed by the letter H.

Example:

- SAM LD H,ØF1H
- d. Decimal Data each decimal number may be followed by the letter D or it may stand alone. Any number not specifically identified as binary, octal, or hexadecimal is assumed to be decimal.

#### Example:

| SAM |    | LD | H,55D |
|-----|----|----|-------|
|     | or |    |       |
| SAM |    | LD | H,55  |

#### NOTE

Leading zeros are appended or truncated from constants to produce 8- or 16-bit values as required by the particular operand. Spaces are not permitted within a numeric constant. e. ASCII Constants - one or more ASCII characters enclosed in quotation marks or apostrophes identify an ASCII constant.

#### Example:

SAM

| l | _D  | Н,'Т'          | ;LOADS H REG WITH<br>;8-BIT ASCII CODE<br>;FOR LETTER T |
|---|-----|----------------|---------------------------------------------------------|
|   | ASC | "FULTON'S FOLL | _Y"                                                     |

f. Location Counter - The dollar symbol (\$) refers to the content of the program counter. The program counter contains the address of the current instruction or data statement being assembled.

#### Example:

JP

;JUMP TO ADDRESS ;3 BYTES BEYOND ;FIRST BYTE OF THIS ;INSTRUCTION

g. Label Assigned Values - The EQU directives can be used to assign values to labels.

\$+3

#### Example:

SAM EQU 6AH

h. Labels of Instruction or Data. The label assigned to an instruction or a data definition has as its value the address of the first byte of the instruction or data. Instructions elsewhere in the program can refer to this address by its symbolic name.

#### Example:

| SAM  | JP | FRED  | JUMP TO INSTRUC;<br>IION AT FRED; |
|------|----|-------|-----------------------------------|
|      | •  | •     |                                   |
|      | •  | •     |                                   |
|      | •  | •     |                                   |
|      | •  | •     |                                   |
| FRED | LD | B,6AH |                                   |

i. Expressions. The operand field may contain an expression consisting of one or more terms acted on by the expression operators. A term may be either a symbol, a string constant, a numeric constant, or an expression. The assembler reduces the entire expression to a single value.

Terms within expressions may be connected by the following arithmetic operators:

- a. The plus operator (+) produces the arithmetic sum of its operands.
- b. The minus operator (-) produces the arithmetic difference of its operands or the arithmetic negative of its operand when used alone.
- c. The asterisk operator (\*) produces the arithmetic product of the operands.
- d. The slant operator (/) produces the quotient of its operands, discarding any remainder.
- e. An instruction enclosed in parentheses is a legal expression in the operand field. For expressions in parentheses, the deepest expression in parentheses is evaluated first.

Care should be taken when using the arithmetic operators since their operational results may affect the condition flags in the condition code register.

ASSEMBLER SUPPLEMENT Z80

# Chapter 3

# **Special Pseudo Instructions**

# Introduction

This chapter supplements Chapter 3 in the HP Model 64000 Assembler/Linker Reference Manual. It lists and defines in detail those assembler instructions that are applicable to the Z80 microprocessor only.

÷

| DEFB                   |           |            | MODEL 64000<br>ASSEMBLER SUPPLEMENT<br>Z80 |
|------------------------|-----------|------------|--------------------------------------------|
| Define Byte<br>SYNTAX: |           |            |                                            |
| Label                  | Operation | Operand    |                                            |
| [Name]                 | DEFB      | expression |                                            |

The DEFB pseudo instruction will store data in consecutive memory locations starting with the current setting of the program counter. The operand field may contain an expression that evaluates to one-byte (8 bits) numbers in the range Ø through 255.

The label name is optional. If the label name is present, it is assigned the starting value of the program counter, and will reference the first byte stored by the DEFB instruction.

#### Example:

| Label | Operation | Operand |
|-------|-----------|---------|
| SAM   | DEFB      | CHARLIE |

| MODEL 64000<br>ASSEMBLER SUPPLEMENT<br>Z80 |           |            | DEFS                 |
|--------------------------------------------|-----------|------------|----------------------|
|                                            |           |            | Define Storage Block |
| SYNTAX:                                    |           |            |                      |
| Label                                      | Operation | Operand    |                      |
| [Name]                                     | DEFS      | expression |                      |
|                                            |           |            |                      |

The DEFS pseudo instruction may be used to define a block of memory space. The value of the expression in the operand field specifies the number of bytes to be reserved.

Any symbol appearing in the operand field must be predefined. If the value of the operand expression is zero, no memory will be reserved; however, if the optional label name is present, it will be assigned the current value of the program counter.

The DEFS instruction reserves space in memory by incrementing the program counter by the value in the operand expression.

Example:

| Label | Operation | Operand | Comment           |
|-------|-----------|---------|-------------------|
| SAM   | DEFS      | 15      | ;RESERVE 15 BYTES |
|       |           |         | FOR SAM ROUTINE   |

|             |           |            | MODEL 64000<br>ASSEMBLER SUPPLEMENT<br>Z80 |
|-------------|-----------|------------|--------------------------------------------|
| Define Word |           |            |                                            |
| SYNTAX:     |           |            |                                            |
| Label       | Operation | Operand    |                                            |
| [Name]      | DEFW      | expression |                                            |

The DEFW pseudo instruction will store a 16-bit value from the expression as an address. The value is stored in memory starting at the current setting of the program counter.

Expressions evaluate to one-word (16 bits) numbers, typically addresses. If an expression evaluates to a single byte, it is assumed to be the low-order byte of a l6-bit word where the high-order byte is all zeros.

If the label name is present, it is assigned the starting address of the program counter, and thus will reference the first byte stored by the DEFW instruction.

Example:

| Label | Operation | Operand |
|-------|-----------|---------|
| SAM   | DEFW      | ØB123H  |

# Chapter **4**

# **Assembler Output Listing**

# General

The assembler processes source program modules and produces an output that consists of a source program listing, a relocatable object file, and a symbol cross-reference list. Errors detected by the assembler will be noted in the output listing as error messages. Refer to Appendix D in the Assembler/Linker Manual for a listing of all error codes and their definitions.

## Input/Output Files

## **Source Input File**

Input to the assembler is a source file that is created through the editor. It consists of the following:

| Example | Description                                                                   |
|---------|-------------------------------------------------------------------------------|
| "Z80"   | - Assembler directive                                                         |
|         | - Source statements consisting of:                                            |
|         | Assembler Pseudos - refer to Chapter 3<br>(Assembler/Linker Reference Manual) |
|         | Assembler Instructions - refer to Chapter 5, this Supplement                  |

## **Assembler Output Files**

The assembler produces relocatable object modules that are stored under the same name as the source file but in a format that can be processed by the linker. If an object file does not exist at assembly time, the assembler will create one. If an object file does exist, the assembler will replace it. **List File** - The list file is a formatted file that is output to a line printer. It can also be stored in another file or applied to the system CRT display. The list may include:

- a. Source statements with object code.
- b. Error messages.
- c. Summary of errors with a description list.
- d. Symbol cross-reference list.

**Symbol Cross-reference List** - All symbols are cross-referenced except local macro labels and parameters. A cross-reference listing contains:

- a. Alphabetical list of program symbols.
- b. Line numbers where symbols are defined.
- c. All references (by line numbers) to symbols in the program.

## **Output Listing**

An example of an assembler output listing is given in table 4-2, using the source program example listed in table 4-1. To illustrate an assembler output listing that contains error messages refer to table 4-3.

#### NOTE

The source program example was not written as a specific program. It merely lists a group of mnemonics to present a formatted example.

| "Z80" LIST XREF |          |                    |
|-----------------|----------|--------------------|
|                 | EXT      | DSPL8,KYBD8        |
|                 | ORG      | Ø8ØØH              |
| EXEC8           | LD       | HL,ØCØØH           |
|                 | LD       | SP,HL              |
|                 | LD       | HL,Ø8Ø5H           |
|                 | LD       | A,Ø3H              |
| LP1             | LD       | [HL],A             |
|                 | DEC      | HL                 |
|                 | LD       | B,Ø6H              |
| LP2             | CALL     | KYBD8              |
|                 | JP       | C,LIGHT            |
|                 | PUSH     | AF                 |
|                 | DJNZ     | LP2                |
|                 | LD       | B,Ø1H              |
|                 | LD<br>LD |                    |
| GO              | LD       | DE,Ø8Ø4H<br>A,[DE] |
| GO              | CPDR     | A,[DE]             |
|                 | JP       | Z,LP2              |
|                 | DEC      | L,2,2,2            |
|                 | DEC      | E                  |
|                 | JP       | NZ,GO              |
|                 | POP      | AF                 |
|                 | CPD      |                    |
|                 | JP       | Z,LIGHT            |
|                 | LD       | [HL],A             |
|                 | DEC      | L                  |
| LIGHT           | CALL     | DSPL8              |
|                 | JP       | LP1                |
|                 | END      |                    |

## Table 4-1. Source Program Format Example

| Table | 4.0           | A         | <b>•</b> •••••• | 1 1 - 41 |
|-------|---------------|-----------|-----------------|----------|
| rable | 4- <u>Z</u> . | Assembler | Output          | LISTING  |

| LINE | LOC  | CODE | ADDR |                 | SOURC | E STATEMENT |
|------|------|------|------|-----------------|-------|-------------|
|      |      |      |      |                 |       |             |
| 1    |      |      |      | "Z80" LIST XREF |       |             |
| 2    |      |      |      |                 | EXT   | DSPL8,KYBD8 |
| 3    | Ø8ØØ |      |      |                 | ORG   | Ø8ØØH       |
| 4    | Ø8ØØ | 21   | ØCØØ | EXEC8           | LD    | HL,ØCØØH    |
| 5    | Ø8Ø3 | F9   |      |                 | LD    | SP,HL       |
| 6    | Ø8Ø4 | 21   | Ø8Ø5 |                 | LD    | HL,Ø8Ø5H    |
| 7    | Ø8Ø7 | 3E   | ØЗ   |                 | LD    | А,ØЗН       |
| 8    | Ø8Ø9 | 77   |      | LP1             | LD    | [HL],A      |
| 9    | Ø8ØA | 2B   |      |                 | DEC   | HL          |
| 1Ø   | Ø8ØB | Ø6   | Ø6   |                 | LD    | B,Ø6H       |
| 11   | Ø8ØD | CD   | ØØØØ | LP2             | CALL  | KYBD8       |
| 12   | Ø81Ø | DA   | Ø831 |                 | JP    | C,LIGHT     |
| 13   | Ø813 | F5   |      |                 | PUSH  | AF          |
| 14   | Ø814 | 1ØF7 |      |                 | DJNZ  | LP2         |
| 15   | Ø816 | Ø6   | Ø1   |                 | LD    | B,Ø1H       |
| 16   | Ø818 | 21   | Ø8Ø5 |                 | LD    | HL,Ø8Ø5H    |
| 17   | Ø81B | 11   | Ø8Ø4 |                 | LD    | DE,Ø8Ø4H    |
| 18   | Ø81E | 1A   |      | GO              | LD    | A,[DE]      |
| 19   | Ø81F | EDB9 |      |                 | CPDR  |             |
| 2Ø   | Ø821 | CA   | Ø8ØD |                 | JP    | Z,LP2       |
| 21   | Ø824 | 2D   |      |                 | DEC   | L           |
| 22   | Ø825 | 1D   |      |                 | DEC   | E           |
| 23   | Ø826 | C2   | Ø81E |                 | JP    | NZ,GO       |
| 24   | Ø829 | F1   |      |                 | POP   | AF          |
| 25   | Ø82A | EDA9 |      |                 | CPD   |             |
| 26   | Ø82C | CA   | Ø831 |                 | JP    | Z,LIGHT     |
| 27   | Ø82F | 77   |      |                 | LD    | [HL],A      |
| 28   | Ø83Ø | 2D   |      |                 | DEC   | L           |
| 29   | Ø831 | CD   | ØØØØ | LIGHT           | CALL  | DSPL8       |
| 3Ø   | Ø834 | C3   | Ø8Ø9 |                 | JP    | LP1         |
| 31   |      |      |      |                 | END   |             |

| FILE: EXEC | FILE: EXEC8:SAVE |      | CROSS REFERENCE TABLE |  |  |
|------------|------------------|------|-----------------------|--|--|
| LINE#      | SYMBOL           | TYPE | REFERENCES            |  |  |
|            | А                | R    | 7,8,18,27             |  |  |
|            | В                | R    | 10,15                 |  |  |
|            | С                | R    | 12                    |  |  |
|            | DE               | R    | 17,18                 |  |  |
| 2          | DSPL8            | E    | 29                    |  |  |
|            | E                | R    | 22                    |  |  |
| 4          | EXEC8            | А    |                       |  |  |
| 18         | GO               | А    | 23                    |  |  |
|            | HL               | R    | 4,5,6,8,9,16,27       |  |  |
| 2          | KYBD8            | Е    | 11                    |  |  |
|            | L                | R    | 21,28                 |  |  |
| 29         | LIGHT            | Α    | 12,26                 |  |  |
| 8          | LP1              | А    | 30                    |  |  |
| 11         | LP2              | А    | 14,2Ø                 |  |  |
|            | NZ               | А    | 23                    |  |  |
|            | SP               | R    | 5                     |  |  |
|            | Z                | А    | 20,26                 |  |  |
|            |                  |      |                       |  |  |

### Table 4-2. Assembler Output Listing (Cont'd)

- **NOTE:** In the cross-reference table, the letter listed under the TYPE column has the following definition:
  - A = Absolute
  - C = Common (COMN)
  - D = Data (DATA)
  - E = External
  - M = Multiple Defined
  - P = Program (PROG)
  - R = Predefined Register
  - U = Undefined

٦

### Table 4-3. Assembler Output with Errors

| FILE: EXEC8:SAVE                      |          |         | HEWLETT-PACKARD: ZILOG Z80 ASSEMBLER |                 |          |             |
|---------------------------------------|----------|---------|--------------------------------------|-----------------|----------|-------------|
| LINE                                  | LOC      | CODE    | ADDR                                 | SC              | OURCE ST | ATEMENT     |
| 1                                     |          |         |                                      | "Z80" LIST XREF |          |             |
| 2                                     |          |         |                                      |                 | EXT      | DSPL8,KYBD8 |
| 3                                     | Ø8ØØ     |         |                                      |                 | ORG      | Ø8ØØH       |
| 4                                     | Ø8ØØ     | 21      | ØCØØ                                 | EXEC8           | LD       | HL,ØCØØH    |
| 5                                     |          |         |                                      |                 | LB       | SP,HL       |
| ERR                                   | OR-UO    |         |                                      |                 | $\wedge$ | ,           |
| 6                                     | Ø8Ø3     | 21      | Ø8Ø5                                 |                 | LD       | HL,0805H    |
| 7                                     | Ø8Ø6     | 3E      | Ø3                                   |                 | LD       | А,Ø3Н       |
| 8                                     | Ø8Ø8     | 77      |                                      | LP1             | LD       | [HL],A      |
| 9                                     | Ø8Ø9     | 2B      |                                      |                 | DEC      | HL          |
| 1Ø                                    | Ø8ØA     | Ø6      | FF                                   |                 | LD       | B,Ø6FFH     |
| ERR                                   | OR-LR,s  | ee line | 5                                    |                 |          | $\wedge$    |
| 11                                    | Ø8ØC     | CD      | ØØØØ                                 | LP2             | CALL     | KYBD8       |
| 12                                    | Ø8ØF     | DA      | Ø83Ø                                 |                 | JP       | C,LIGHT     |
| 13                                    | Ø812     | F5      |                                      |                 | PUSH     | AF          |
| 14                                    | Ø813     | 1ØF7    |                                      |                 | DJNZ     | LP2         |
| 15                                    | Ø815     | Ø6      | Ø1                                   |                 | LD       | B,Ø1H       |
| 16                                    | Ø817     | 21      | Ø8Ø5                                 |                 | LD       | HL,Ø8Ø5H    |
| 17                                    | Ø81A     | 11      | Ø8Ø4                                 |                 | LD       | DE,Ø8Ø4H    |
| 18                                    | Ø81D     | 1A      |                                      | GO              | LD       | A,[DE]      |
| 19                                    | Ø81E     | EDB9    |                                      |                 | CPDR     |             |
| 2Ø                                    | Ø82Ø     | CA      | ØØØØ                                 |                 | JP       | Z,LP3       |
| ERRO                                  | R-US,see | e line  | 1Ø                                   |                 |          | $\wedge$    |
| 21                                    | Ø823     | 2D      |                                      |                 | DEC      | L           |
| 22                                    | Ø824     | 1D      |                                      |                 | DEC      | E           |
| 23                                    | Ø825     | C2      | Ø81D                                 |                 | JP       | NZ,GO       |
| 24                                    | Ø828     | F1      |                                      |                 | POP      | AF          |
| 25                                    | Ø829     | EDA9    |                                      |                 | CPD      |             |
| 26                                    | Ø82B     | CA      | Ø83Ø                                 |                 | JP       | Z,LIGHT     |
| 27                                    | Ø82E     | 77      |                                      |                 | LD       | [HL],A      |
| 28                                    | Ø82F     | 2D      |                                      |                 | DEC      | L           |
| 29                                    | Ø83Ø     | CD      | ØØØØ                                 | LIGHT           | CALL     | DSPL8       |
| 3Ø                                    | Ø833     | C3      | Ø8Ø8                                 |                 | JP       | LP1         |
| 31                                    |          |         |                                      |                 | END      |             |
| Errors = 3, previous error at line 20 |          |         |                                      |                 |          |             |



| <ul> <li>US - Undefined Symbol, The indicated symbol is not defined as a (wrap around: label or declared as an external)</li> <li>LR - Legal Range, Address or displacement is out of range of the (wrap around: instruction's addressing capability)</li> <li>UO - Unidentified Opcode, Opcode encountered is not defined for (wrap around: this micro-processor)</li> </ul> |        |         |                 |        |  |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|---------|-----------------|--------|--|
| FILE: EXEC                                                                                                                                                                                                                                                                                                                                                                    | B:SAVE | CROSS I | REFERENCE TABLE | PAGE 2 |  |
| LINE                                                                                                                                                                                                                                                                                                                                                                          | SYMBOL | TYPE    | REFERENCES      |        |  |
|                                                                                                                                                                                                                                                                                                                                                                               | А      | R       | 7,8,18,27       |        |  |
|                                                                                                                                                                                                                                                                                                                                                                               | В      | R       | 10,15           |        |  |
|                                                                                                                                                                                                                                                                                                                                                                               | С      | R       | 12              |        |  |
|                                                                                                                                                                                                                                                                                                                                                                               | DE     | R       | 17,18           |        |  |
| 2                                                                                                                                                                                                                                                                                                                                                                             | DSPL8  | E       | 29              |        |  |
|                                                                                                                                                                                                                                                                                                                                                                               | Е      | R       | 22              |        |  |
| 4                                                                                                                                                                                                                                                                                                                                                                             | EXEC8  | А       |                 |        |  |
| 18                                                                                                                                                                                                                                                                                                                                                                            | GO     | А       | 23              |        |  |
|                                                                                                                                                                                                                                                                                                                                                                               | HL     | R       | 4,6,8,9,16,27   |        |  |
| 2                                                                                                                                                                                                                                                                                                                                                                             | KYBD8  | E       | 11              |        |  |
|                                                                                                                                                                                                                                                                                                                                                                               | L      | R       | 21,28           |        |  |
| 29                                                                                                                                                                                                                                                                                                                                                                            | LIGHT  | А       | 12,26           |        |  |
| 8                                                                                                                                                                                                                                                                                                                                                                             | LP1    | А       | 30              |        |  |
| 11                                                                                                                                                                                                                                                                                                                                                                            | LP2    | А       | 14,20           |        |  |
| * * *                                                                                                                                                                                                                                                                                                                                                                         | LP3    | U       | 2Ø              |        |  |
|                                                                                                                                                                                                                                                                                                                                                                               | NZ     | А       | 23              |        |  |
|                                                                                                                                                                                                                                                                                                                                                                               | Z      | А       | 20,26           |        |  |

**NOTE:** Error messages are inserted immediately following the statement where the error occurs. All error messages (after the first error message) will contain a statement which points to the statement where the last error occurred. At the end of the source program listing, an error summary statement will be printed. The summary will contain a statement as to the total number of errors noted, along with a line reference to the previous error. It will also define all error codes listed in the source program listing.

The primary purpose of the error statement that points to the line number where the previous error occurred is to facilitate location of errors. Since some programs may be many pages in length, this feature helps the programmer locate errors quickly (as opposed to thumbing through each page of the program).

Chapter 5

# **Z80** Instruction Set Summary

## General

This chapter describes the instruction set for the Z80 microprocessor. It briefly explains the individual instructions and gives formatted examples and object codes. For a detailed description of the instruction set, refer to the manufacturer's User's Manual.

Each Z80 instruction consists of a mnemonic code and up to two operands. The descriptive symbols used in this chapter to represent items in mnemonic definitions are as follows:

| Symbol      |   | Description                                    |  |
|-------------|---|------------------------------------------------|--|
| Α           | - | Register A accumulator                         |  |
| Ā           | - | Complement of Register A                       |  |
| В           | - | Register B                                     |  |
| b           | - | Specifies one bit in the range Ø-7             |  |
| [BC]        | - | Memory location pointed to by register pair BC |  |
| С           | - | Register C                                     |  |
| СС          | - | Specifies the state of the condition flags for |  |
|             |   | certain conditional branch jump instructions   |  |
| CY          | - | Carry/borrow flag bit                          |  |
| CY          | - | Complement of carry/borrow flag bit            |  |
| D           | - | Register D                                     |  |
| d           | - | Specifies a one-byte expression in the range   |  |
|             |   | -128 to +127                                   |  |
| [DE]        | - | Memory location pointed to by register pair DE |  |
| E           | - | Register E                                     |  |
| е           | - | Specifies a one-byte expression in the range   |  |
|             |   | -126 to +129                                   |  |
| н           | - | Register H                                     |  |
| HC          | - | Half carry flag bit                            |  |
| [HL]        | - | Memory location pointed to by register pair HL |  |
| H subscript | - | High-order byte of a 16-bit word               |  |
| I           | - | Interrupt Vector Register                      |  |
| IFF         | - | Content of interrupt enable flip-flop          |  |
| IX          | - | X Index Register                               |  |

| [IX+d]               | - | Memory location pointed to by the X Index<br>Register plus d displacement |
|----------------------|---|---------------------------------------------------------------------------|
| IY                   | - | Y Index Register                                                          |
| [IY+d]               | - | Memory location pointed to by the Y Index<br>Register plus d displacement |
| L                    | - | Register L                                                                |
| L (subscript)        | - | Low-order byte of a 16-bit word                                           |
| m                    | - | Specifies any register r or memory location [HL],<br>[IX+d], or [IY+d]    |
| n                    | - | Specifies a one-byte expression in the range $\emptyset$ to 255           |
| nn                   | - | Specifies a two-byte expression in the range $\emptyset$ to 65,535        |
| PC                   | - | Program Counter Register                                                  |
| P/V                  | - | Conditional flag symbol indicating parity/overflow notation               |
| р                    | - | Page zero memory location                                                 |
| рр                   | - | Any register pair BC, DE, IX, or SP                                       |
| qq                   | - | Any register pair BC, DE, HL, or AF                                       |
| R                    | - | Memory Refresh Register                                                   |
| r                    | - | Any of the following registers: A, B, C, D, E, H, or L                    |
| rr                   | - | Any register pair BC, DE, IY, or SP                                       |
| S                    | - | Specifies any register r, value n, or memory location                     |
|                      |   | [HL], [IX+d], or [IY+d]                                                   |
| SP                   | - | Stack Pointer Register                                                    |
| SS                   | - | Any register pair BC, DE, HL, or SP                                       |
| <                    | - | Transfer into                                                             |
| <>                   | - | Exchange register content                                                 |
| •                    | - | Boolean AND                                                               |
| $\oplus$             | - | Exclusive OR                                                              |
| $\overline{\bullet}$ | - | Inclusive OR                                                              |
| +                    | - | Addition                                                                  |
| _                    | - | Subtraction                                                               |
| Ø                    | - | Condition flag is reset                                                   |
| 1                    | - | Condition flag is set                                                     |

# **Predefined Symbols**

The following symbols are reserved. They have special meaning to the assembler and cannot appear as user-defined symbols.

| Symbol | Definition                |
|--------|---------------------------|
| A      | Register A                |
| AF     | Register pair AF          |
| В      | Register B                |
| BC     | Register pair BC          |
| С      | Register C                |
| D      | Register D                |
| DE     | Register pair DE          |
| Е      | Register E                |
| Н      | Register H                |
| HL     | Register pair HL          |
| 1      | Interrupt Vector Register |
| IX     | X Register Index          |
| IY     | Y Register Index          |
| L      | Register L                |
| PC     | Program Counter Register  |
| R      | Memory Refresh Register   |
| SP     | Stack Pointer Register    |

**Z80** Instruction Set Summary

ASSEMBLER SUPPLEMENT Z80 MODEL 64000 ASSEMBLER SUPPLEMENT Z80

Add with carry to Register A

ADC A,\_ \_

| SYNTAX: |           |          |                     |
|---------|-----------|----------|---------------------|
| Label   | Operation | Operand  | Object<br>Code(hex) |
|         | ADC       | A,A      | 8F                  |
|         | ADC       | A,B      | 88                  |
|         | ADC       | A,C      | 89                  |
|         | ADC       | A,D      | 8A                  |
|         | ADC       | A,E      | 8B                  |
|         | ADC       | A,H      | 8C                  |
|         | ADC       | A,L      | 8D                  |
|         | ADC       | A,n      | CE(n)               |
|         | ADC       | A,[HL]   | 8E                  |
|         | ADC       | A,[IX+d] | DD8E(d)             |
|         | ADC       | A,[IY+d] | FD8E(d)             |

The ADC  $A_{,--}$  instruction will add the content of the designated register or memory location plus the carry flag bit (from register F) to the content of register A. The result of the operation will be stored in register A.

Symbolic Operation: A <--- A+s+CY

Condition codes affected: CY, N, P/V, HC, Z, and S.

Example:

| Label | Operation | Operand | Comment |
|-------|-----------|---------|---------|
|       | ADC       | A,A     |         |

This instruction will double the content of register A, plus the carry flag bit.

# ADC HL,\_\_

| YNTAX: |           |         |           |
|--------|-----------|---------|-----------|
|        |           |         | Object    |
| Label  | Operation | Operand | Code(hex) |
|        | ADC       | HL,BC   | ED4A      |
|        | ADC       | HL,DE   | ED5A      |
|        | ADC       | HL,HL   | ED6A      |
|        | ADC       | HL,SP   | ED7A      |

The ADC HL,  $\_\_$  instruction will add the content of the designated register pair plus the carry flag bit (from register F) to the content of register pair HL. The result of the operation will be stored in register pair HL.

Symbolic Operation: HL <--- HL+ss+CY

Condition codes affected: CY, N, P/V, HC, Z, and S.

Example:

| Label | Operation | Operand | Comment |
|-------|-----------|---------|---------|
|       | ADC       | HL,DE   |         |

This instruction will add the content of register pair DE to the content of register pair HL, plus the carry flag bit.

Add to Register A

ADD A,\_ \_!

## SYNTAX:

| Label | Operation | Operand  | Object<br>Code (hex) |
|-------|-----------|----------|----------------------|
|       | •         | •        | · · ·                |
|       | ADD       | A,A      | 87                   |
|       | ADD       | A,B      | 8Ø                   |
|       | ADD       | A,C      | 81                   |
|       | ADD       | A,D      | 82                   |
|       | ADD       | A,E      | 83                   |
|       | ADD       | A,H      | 84                   |
|       | ADD       | A,L      | 85                   |
|       | ADD       | A,n      | <b>C6</b> (n)        |
|       | ADD       | A,[HL]   | 86                   |
|       | ADD       | A,[IX+d] | DD86(d)              |
|       | ADD       | A,[IY+d] | FD86(d)              |

The ADD  $A_{,-}$  instruction will add the content of the designated register or memory location to the content of register A. The result of the operation will be stored in register A.

Symbolic Operation: A <--- A+s

Condition codes affected: CY, N, P/V, HC, Z, and S.

Example:

| Label | Operation | Operand | Comment |
|-------|-----------|---------|---------|
|       | ADD       | A,[HL]  |         |

This instruction will add the content of memory location addressed by register pair HL to the content of register A.

# ADD HL,\_\_I

# Add Register Pair to Register Pair HL

| Operation | Operand           | Object<br>Code (hex)                |
|-----------|-------------------|-------------------------------------|
| ADD       | HL,BC             | Ø9                                  |
| ADD       | HL,DE             | 19                                  |
| ADD       | HL,HL             | 29                                  |
| ADD       | HL,SP             | 39                                  |
|           | ADD<br>ADD<br>ADD | ADD HL,BC<br>ADD HL,DE<br>ADD HL,HL |

The ADD HL,\_\_ instruction will add the content of the designated register pair to the content of register pair HL. The result of the operation will be stored in register pair HL.

Symbolic Operation: HL <--- HL+ss

Condition codes affected: CY, N, and HC.

Example:

| Label | Operation | Operand | Comment |
|-------|-----------|---------|---------|
|       | ADD       | HL,DE   |         |

This instruction will add the content of register pair DE to the content of register pair HL.

MODEL 64000 ASSEMBLER SUPPLEMENT

Add Register Pair to Index Register IX

ADD IX,\_\_

| SYNTAX: |           |         |                      |
|---------|-----------|---------|----------------------|
| Label   | Operation | Operand | Object<br>Code (hex) |
|         | ADD       | IX,BC   | DDØ9                 |
|         | ADD       | IX,DE   | DD19                 |
|         | ADD       | IX,IX   | DD29                 |
|         | ADD       | IX,SP   | DD39                 |
|         |           |         |                      |

The ADD  $IX_{--}$  instruction will add the content of the designated register pair to the content of index register IX. The result of the operation will be stored in index register IX.

Symbolic Operation: IX <--- IX+pp

Condition codes affected: CY, N, and HC.

Example:

| Label | Operation | Operand | Comment |
|-------|-----------|---------|---------|
|       | ADD       | IX,IX   |         |

This instruction will double the value of the content of index register IX.

# ∎ADD IY,\_ \_I

| Add | Register | Pair | to | Index | Register | IY |  |
|-----|----------|------|----|-------|----------|----|--|
|     |          |      |    |       |          |    |  |

| SYNTAX: |           |         |            |
|---------|-----------|---------|------------|
|         |           |         | Object     |
| Label   | Operation | Operand | Code (hex) |
|         | ADD       | IY,BC   | FDØ9       |
|         | ADD       | IY,DE   | FD19       |
|         | ADD       | IY,IY   | FD29       |
|         | ADD       | IY,SP   | FD39       |

The ADD IY,\_\_ instruction will add the content of the designated register pair to the content of index register IY. The result of the operation will be stored in index register IY.

Symbolic Operation: IY <--- IY+rr

Condition codes affected: CY, N, and HC.

Example:

| Label | Operation | Operand | Comment |
|-------|-----------|---------|---------|
|       | ADD       | IY,BC   |         |

This instruction will add the content of register pair BC to the content of index register IY.

AND s

Logical 'AND' with Register A

## SYNTAX:

| Label | Operation | Operand | Object<br>Code (hex)   |
|-------|-----------|---------|------------------------|
|       |           | oporana | ,                      |
|       | AND       | A       | A7                     |
|       | AND       | В       | AØ                     |
|       | AND       | С       | A1                     |
|       | AND       | D       | A2                     |
|       | AND       | E       | A3                     |
|       | AND       | Н       | A4                     |
|       | AND       | L       | A5                     |
|       | AND       | n       | <b>E6</b> ( <b>n</b> ) |
|       | AND       | [HL]    | A6                     |
|       | AND       | [IX+d]  | DDA6(d)                |
|       | AND       | [IY+d]  | FDA6(d)                |
|       |           |         |                        |

A logical 'AND' operation will be performed between the byte specified by the operand field and the byte contained in register A. The result of the operation will be stored in register A.

Symbolic Operation: A <--- A • s

Condition codes affected: CY, N, P/V, HC, Z, and S.

Example:

| Label | Operation | Operand | Comment |
|-------|-----------|---------|---------|
|       | AND       | [HL]    |         |

This instruction performs a logical 'AND' operation using the content of memory location addressed by register pair HL and the content of register A.

# BIT b,\_ \_

Test Bit b

SYNTAX:

|     |                  | <b>.</b>  | <b>.</b>           |     | Object             |
|-----|------------------|-----------|--------------------|-----|--------------------|
|     | Label            | Operation | Operand            |     | Code (hex)         |
|     |                  | BIT       | b,reg o            | r   | (see below)        |
|     |                  |           | [addr]             |     |                    |
| bit | Ø,A=CB47         | bit       | 3,A=CB5F           | bit | 6,A=CB77           |
|     | Ø,B=CB4Ø         |           | 3,B=CB58           |     | 6,B=CB7Ø           |
|     | Ø,C=CB41         |           | 3,C=CB59           |     | 6,C=CB71           |
|     | Ø,D=CB42         |           | 3,D=CB5A           |     | 6,D=CB72           |
|     | Ø,E=CB43         |           | 3,E=CB5B           |     | 6,E=CB73           |
|     | Ø,H=CB44         |           | 3,H=CB5C           |     | 6,H=CB74           |
|     | Ø,L=CB45         |           | 3,L=CB5D           |     | 6,L=CB75           |
|     | Ø,[HL]=CB46      |           | 3,[HL]=CB5E        |     | 6,[HL]=CB76        |
|     | Ø,[IX+d]=DDCB(d) | )46       | 3,[IY+d]=DDCB(d)5E |     | 6,[IX+d]=DDCB(d)76 |
|     | Ø,[IY+d]=FDCB(d) | 46        | 3,[IY+d]=FDCB(d)5E |     | 6,[IY+d]=FDCB(d)76 |
|     | 1,A=CB4F         |           | 4,A=CB67           |     | 7,A=CB7F           |
|     | 1,B=CB48         |           | 4,B=CB6Ø           |     | 7,B=CB78           |
|     | 1,C=CB49         |           | 4,C=CB61           |     | 7,C=CB79           |
|     | 1,D=CB4A         |           | 4,D=CB62           |     | 7,D=CB7A           |
|     | 1,E=CB4B         |           | 4,E=CB63           |     | 7,E=CB7B           |
|     | 1,E=CB4C         |           | 4,H=CB64           |     | 7,H=CB7C           |
|     | 1,L=CB4D         |           | 4,L=CB65           |     | 7,L=CB7D           |
|     | 1,[HL]=CB4E      |           | 4,[HL]=CB66        |     | 7,[HL]=CB7E        |
|     | 1,[IX+d]=DDCB(d) | 4E        | 4,[IX+d]=DDCB(d)66 |     | 7,[IX+d]=DDCB(d)7E |
|     | 1,[IY+d]=FDCB(d) | 4E        | 4,[IY+d]=FDCB(d)66 |     | 7,[IY+d]=FDCB(d)7E |

MODEL 64000 ASSEMBLER SUPPLEMENT Z80

| 2,A=CB57           | 5,A=CB6F           |
|--------------------|--------------------|
| 2,B=CB5Ø           | 5,B=CB68           |
| 2,C=CB51           | 5,C=CB69           |
| 2,D=CB52           | 5,D=CB6A           |
| 2,E=CB53           | 5,E=CB6B           |
| 2,H=CB54           | 5,H=CB6C           |
| 2,L=CB55           | 5,L=CB6D           |
| 2,[HL]=CB56        | 5,[HL]=CB6E        |
| 2,[IX+d]=DDCB(d)56 | 5,[IX+d]=DDCB(d)6E |
| 2,[IY+d]=FDCB(d)56 | 5,[IY+d:=FDCB(d)6E |
|                    |                    |

### NOTE

BI

n

(Cont'd)

The expression (d) in the object codes listed above is the register offset assigned by the user. The hexadecimal value of the offset will be a one-byte expression in the range of -128 to +127.

The BIT  $b_{,-}$  instruction will test a specific bit (b) in the designated register or memory location and then adjust the zero (Z) flag accordingly.

Symbolic Operation: Z <--- s<sub>h</sub>

Condition Codes affected: N, HC, and Z.

Example:

| Label | Operation | Operand            | Comment |
|-------|-----------|--------------------|---------|
|       | BIT       | 4, <b>[</b> IX+3H] |         |

Assume the content of index register IX is  $\emptyset$ 5FAH. The instruction will check bit 4 of memory location  $\emptyset$ 5FDH and if the bit is set (1), the zero (Z) flag in register F will be reset (Z= $\emptyset$ ).

# CALL cc,nn

#### **Conditional Call of Subroutine**

|        |                   |         | Object                  |
|--------|-------------------|---------|-------------------------|
| Label  | Operation         | Operand | Code (hex)              |
|        | CALL              | C,nn    | DC(nn)                  |
|        | CALL              | M,nn    | FC(nn)                  |
|        | CALL              | NC,nn   | D4(nn)                  |
|        | CALL              | NZ,nn   | <b>C4</b> ( <b>nn</b> ) |
|        | CALL              | P,nn    | <b>F4</b> ( <b>nn</b> ) |
|        | CALL              | PE,nn   | EC(nn)                  |
|        | CALL              | PO,nn   | <b>E4</b> ( <b>nn</b> ) |
|        | CALL              | Z,nn    | CC(nn)                  |
| where: | C = carry         |         |                         |
|        | M = sign negative |         |                         |
|        | NC = non carry    |         |                         |
|        | NZ = non zero     |         |                         |
|        | P = sign positive |         |                         |
|        | PE = parity even  |         |                         |
|        | PO = parity odd   |         |                         |
|        | Z = zero          |         |                         |

The CALL cc,nn instruction will cause the condition flags in register F to be tested for the condition designated by the cc section of the operand. If the condition is true, the microprocessor will push the current content of the program counter (PC) onto the stack. It will then load the nn section of the operand into the program counter to point to the address in memory that contains the first opcode of a subroutine.

If condition cc is false, program execution will continue with the next instruction.

#### Condition codes affected: none.

#### Example:

| Labei | Operation | Operand | Comment |
|-------|-----------|---------|---------|
|       | CALL      | C,Ø5FAH |         |

If the carry flag in register F is set (1), this instruction will call the subroutine located at memory address Ø5FAH.

| MODEL 64000<br>ASSEMBLER SUPPLEMENT<br>Z80 |           |         | CALL nn                      |
|--------------------------------------------|-----------|---------|------------------------------|
|                                            |           | Unco    | nditional Call of Subroutine |
| SYNTAX:                                    |           |         |                              |
| Label                                      | Operation | Operand | Object<br>Code (hex)         |
|                                            | CALL      | nn      | CD(nn)                       |

The CALL nn instruction will push the current content of the program counter (PC) onto the stack. It will then load operand nn into the program counter, pointing to the memory address that contains the first opcode of a subroutine.

**Symbolic Operation:** [SP-1] <--- PC<sub>H</sub> [SP-2] <--- PC<sub>L</sub> PC <---nn

Condition codes affected: none.

Example:

| Label | Operation | Operand | Comment |
|-------|-----------|---------|---------|
|       | CALL      | Ø5FAH   |         |

This instruction will perform an unconditional branch to memory location Ø5FAH by loading the operand address into the program counter.

|                    |           |         | MODEL 6400<br>ASSEMBLER SUPPLEMEN<br>Z8 |
|--------------------|-----------|---------|-----------------------------------------|
| Complement Carry F | lag       |         |                                         |
| SYNTAX:            |           |         |                                         |
| Label              | Operation | Operand | Object<br>Code (hex)                    |
|                    | CCF       |         | 3F                                      |

The CCF instruction will invert the carry (CY) flag in register F.

Symbolic Operation: CY <---  $\overline{CY}$ 

Condition codes affected: CY and N.

Compare with Register A

СР

### SYNTAX:

|       |           |         | Object     |
|-------|-----------|---------|------------|
| Label | Operation | Operand | Code (hex) |
|       | CP        | А       | BF         |
|       | CP        | В       | B8         |
|       | CP        | С       | B9         |
|       | CP        | D       | BA         |
|       | CP        | E       | BB         |
|       | CP        | Н       | BC         |
|       | CP        | L       | BD         |
|       | СР        | n       | FE(n)      |
|       | СР        | [HL]    | BE         |
|       | СР        | [IX+d]  | DDBE(d)    |
|       | СР        | [IY+d]  | FDBE(d)    |

The CP  $\_$  \_ instruction will compare the content of the designated register or memory location with the content of register A. If the comparison is true, the zero (Z) flag will be set. The content of register A will not be affected by this operation.

#### Symbolic Operation: A-s

Condition codes affected: CY, N, P/V, HC, Z, and S.

#### Example:

| Label | Operation | Operand | Comment |
|-------|-----------|---------|---------|
|       | СР        | D       |         |

This instruction will compare the content of register D with the content of register A. The condition flags are set or reset according to the result of the operation.

| PD <b>man</b> |                          |         | MODE<br>ASSEMBLER SUPPL |
|---------------|--------------------------|---------|-------------------------|
| are Memory L  | ocation [- HL] with Regi | ister A |                         |
| SYNTAX:       |                          |         |                         |
| Label         | Operation                | Operand | Object<br>Code (hex)    |
|               |                          |         |                         |

The CPD instruction will compare the content of memory location addressed by the HL register pair with the content of register A. If the comparison is true, the zero (Z) condition flag will be set. The HL and BC register pairs will then be decremented.

The contents of memory location [HL] and register A will not be affected by this operation.

Symbolic Operation: A - [HL]; HL <---HL-1, BC <---BC-1

| MODEL 64000<br>ASSEMBLER SUPPLEME<br>280 | NT        |                        | CPD                      |
|------------------------------------------|-----------|------------------------|--------------------------|
|                                          | Com       | pare Memory Block (dec | cremented) with Register |
| SYNTAX:                                  |           |                        |                          |
|                                          |           |                        |                          |
| Label                                    | Operation | Operand                | Object<br>Code (hex)     |

The CPDR instruction will compare the content of memory location addressed by the HL register pair with the content of register A. If the comparison is true, the zero (Z) condition flag will be set. The HL and BC register pairs will then be decremented. If register A = [HL], the instruction will be terminated. If the BC register pair is not zero and if register A  $\neq$  [HL], the program counter will be decremented by 2 and the instruction will repeat itself.

#### NOTE

If the BC register pair is zeroed prior to executing the CPDR instruction, the microprocessor will loop through 64K bytes if no true comparison is found.

Symbolic Operation: A - [HL]; HI <--- HL-1, BC <--- BC-1; Repeat until A=[HL] or BC=Ø

| ;PI             |                         |         | ASSEMBLER SUPPLEMEN<br>Za |
|-----------------|-------------------------|---------|---------------------------|
| mpare Memory Lo | cation [+HL] with Regis | ter A   |                           |
| SYNTAX:         |                         |         |                           |
|                 |                         |         | Object                    |
| Label           | Operation               | Operand | Code (hex)                |
|                 | CPI                     |         | EDA1                      |
|                 |                         |         |                           |

The CPI instruction will compare the content of memory location addressed by the HL register pair with the content of register A. If the comparison is true, the zero (Z) condition flag will be set. The HL register pair is incremented and the BC register pair is decremented.

The contents of memory location [HL] and register A are not affected by this operation.

Symbolic Operation: A-[HL]; HL <--- HL+1, BC <--- BC-1

| MODEL 64000<br>ASSEMBLER SUPPLEMEN<br>Z80 | IT        |                          | CP                      |
|-------------------------------------------|-----------|--------------------------|-------------------------|
|                                           |           | Compare Memory Block (in | cremented) with Registe |
| SYNTAX:                                   |           |                          |                         |
| Label                                     | Operation | Operand                  | Object<br>Code (hex)    |
|                                           | CPIR      |                          | EDB1                    |

The CPIR instruction will compare the content of memory location addressed by register pair HL with the content of register A. If the comparison is true, the zero (Z) condition flag will be set. Register pair HL will be incremented and register pair BC will be decremented. If decrementing causes register pair BC to go to zero or if register A = [HL], the instruction will be terminated. If register pair BC is not zero and if register  $A \neq [HL]$ , the program counter will be decremented by 2 and the instruction will repeat itself.

#### NOTE

If register pair BC is zeroed prior to executing the CPIR instruction and no true comparison is found, the micro-processor will loop through 64K bytes.

Symbolic Operation: A-[HL]; HL <--- HL+1, BC <--- BC-1; Repeat until A=[HL] or BC=Ø

| SYNTAX:      |                                               |                           |                      |
|--------------|-----------------------------------------------|---------------------------|----------------------|
| Label        | Operation                                     | Operand                   | Object<br>Code (hex) |
|              | CPL                                           |                           | 2F                   |
|              | tion will invert the conte                    | nt of register A (1's ss  | molement             |
|              | tion win invent the conte                     | ant of register A (15 col | ilplement).          |
| Symbolic Or  | peration: A <a< td=""><td></td><td></td></a<> |                           |                      |
|              | peration: A <Ā                                |                           |                      |
|              | oeration: A <Ā                                |                           |                      |
|              |                                               |                           |                      |
| Condition co |                                               |                           |                      |
| Condition co |                                               |                           |                      |
| Condition co | odes affected: N and HC                       |                           |                      |
| Condition co | odes affected: N and HC                       |                           |                      |
| Condition co | odes affected: N and HC                       | Operand                   | Object<br>Code (hex) |
| Condition co | odes affected: N and HC                       |                           |                      |

#### Decrement

DEC

### SYNTAX:

|       |           |         | Object     |
|-------|-----------|---------|------------|
| Label | Operation | Operand | Code (hex) |
|       | DEC       | A       | 3D         |
|       | DEC       | В       |            |
|       |           |         | Ø5         |
|       | DEC       | С       | ØD         |
|       | DEC       | D       | 15         |
|       | DEC       | E       | 1D         |
|       | DEC       | Н       | 25         |
|       | DEC       | L       | 2D         |
|       | DEC       | [HL]    | 35         |
|       | DEC       | [IX+d]  | DD35(d)    |
|       | DEC       | [IY+d]  | FD35(d)    |
|       |           |         |            |

The DEC  $\_$   $\_$  instruction will decrement the content of the register or memory location designated by the operand field.

Symbolic Operation: s <--- s-1

Condition codes affected: N, P/V, HC, Z, and S.

Example:

| Label | Operation | Operand | Comment |
|-------|-----------|---------|---------|
|       | DEC       | [HL]    |         |

This instruction will decrement the content of the memory location addressed by register pair HL.

| crement Index Re              | gister IX<br>                             |                         |                      |
|-------------------------------|-------------------------------------------|-------------------------|----------------------|
| SYNTAX:                       |                                           |                         |                      |
| Label                         | Operation                                 | Operand                 | Object<br>Code (hex) |
|                               | DEC                                       | IX                      | DD2B                 |
|                               |                                           |                         |                      |
|                               | uction will decrement th                  | e content of index regi | ster IX.             |
| The DEC IX instru             |                                           | le content of maex regi |                      |
|                               | eration: IX < IX-1                        |                         |                      |
| Symbolic Ope                  |                                           | e content of mack regi  |                      |
| Symbolic Ope                  | eration: IX < IX-1                        | e content of mack regi  |                      |
| Symbolic Ope                  | eration: IX < IX-1                        |                         |                      |
| Symbolic Ope                  | eration: IX < IX-1<br>des affected: none. |                         |                      |
| Symbolic Ope                  | eration: IX < IX-1<br>des affected: none. |                         |                      |
| Symbolic Ope                  | eration: IX < IX-1<br>des affected: none. |                         |                      |
| Symbolic Ope<br>Condition cod | eration: IX < IX-1<br>des affected: none. |                         |                      |
| Symbolic Ope                  | eration: IX < IX-1<br>des affected: none. |                         |                      |
| Symbolic Ope<br>Condition cod | eration: IX < IX-1<br>des affected: none. |                         |                      |
| Symbolic Ope<br>Condition cod | eration: IX < IX-1<br>des affected: none. | Operand                 | Object<br>Code (hex) |

MODEL 64000 ASSEMBLER SUPPLEMENT Z80

DEC ssi

**Decrement Register Pair** 

| SYNTAX: |           |         |                      |
|---------|-----------|---------|----------------------|
| Label   | Operation | Operand | Object<br>Code (hex) |
|         | DEC       | BC      | ØB                   |
|         | DEC       | DE      | 1B                   |
|         | DEC       | HL      | 2B                   |
|         | DEC       | SP      | 3B                   |
|         |           |         |                      |

The DEC ss instruction will decrement the content of the designated register pair specified by the operand field.

Symbolic Operation: ss <--- ss-1

Example:

| Label | Operation | Operand | Comment |
|-------|-----------|---------|---------|
|       | DEC       | SP      |         |

This instruction will decrement the content of the Stack Pointer (SP).

|                    |           |         | MODEL 64000<br>ASSEMBLER SUPPLEMENT<br>Z80 |
|--------------------|-----------|---------|--------------------------------------------|
| Disable Interrupts |           | <u></u> |                                            |
| Label              | Operation | Operand | Object<br>Code (hex)                       |
|                    | DI        |         | F3                                         |

The DI instruction will disable the maskable interrupt by resetting the interrupt enable flipflops. The interrupt will remain disabled until reactivated by an EI instruction.

Symbolic Operation: IFF <--- Ø

 MODEL 64000
 DJNZ \_ \_ \_ \_

 ASSEMBLER SUPPLEMENT
 Decrement Register B - Conditionally Jump

 SYNTAX:
 Object

 Label
 Operation
 Operand

 DJNZ
 offset
 1Ø(e=2)

The DJNZ \_ \_ instruction will use the content of register B to determine if a branch must take place. The content of register B will be decremented and if a non zero value remains, the value of the offset indicated in the operand field will be added to the program counter (PC). The next instruction will then be brought from the location designated by the new content of the program counter. The jump will be measured from the address of the DJNZ instruction and has a range of -126 to +129 bytes.

If the result of decrementing register B leaves it with a value of zero, program execution will continue with the next instruction.

Symbolic Operation: B <---B-1; If B=Ø, continue If B=1, then PC <--- PC+e

Condition codes affected: none.

Example:

| Label | Operation | Operand | Comment |
|-------|-----------|---------|---------|
|       | DJNZ      | 4FH     |         |

This instruction will cause the program to jump to a location 4F-2 bytes from the current setting of the program counter if the content of register B is not zero.

|                   |                  |                          | MODEL 64<br>ASSEMBLER SUPPLEM |
|-------------------|------------------|--------------------------|-------------------------------|
| Ible Interrupts   |                  |                          | ·····                         |
| Label             | Operation        | Operand                  | Object<br>Code (hex)          |
|                   | EI               |                          | FB                            |
| naskable interrup | ot.              | t enable flip-flops allo | wing recognition of any       |
| Symbolic Op       | eration: IFF < 1 |                          |                               |
|                   |                  |                          |                               |

| K [SP],H       |                        |         |                      |
|----------------|------------------------|---------|----------------------|
| nange Memory I | ocation and HL Registe | r Pair  |                      |
| SYNTAX:        |                        |         |                      |
| Label          | Operation              | Operand | Object<br>Code (hex) |
|                | EX                     | [SP],HL | E3                   |

The EX [SP],HL instruction will exchange the low-order byte in register pair HL with the content of the memory location specified by the stack pointer (SP). It will then exchange the high-order byte in register pair HL with the next highest memory address [SP+1].

Symbolic Operation: L <---> [SP] H <---> [SP+1]

| <u> </u>                         |                        | Exchange Memory Loc | ation and IX Index Regis |
|----------------------------------|------------------------|---------------------|--------------------------|
| SYNTAX:                          |                        |                     |                          |
| Label                            | Operation              | Operand             | Object<br>Code (hex)     |
|                                  | EX                     | [SP],IX             | DDE3                     |
|                                  | X <sub>H</sub> <> [SP+ |                     |                          |
| Condition co                     | des affected: none.    |                     | EX [SP],I                |
| Condition co                     |                        |                     | EX [SP],I                |
|                                  |                        |                     |                          |
| Condition co<br>SYNTAX:<br>Label |                        |                     |                          |
| SYNTAX:                          | des affected: none.    | Exchange Memory Loc | ation and IY Index Regis |

| SYNTAX:                                  |                                             |                          |                           |
|------------------------------------------|---------------------------------------------|--------------------------|---------------------------|
| Label                                    | Operation                                   | Operand                  | Object<br>Code (hex)      |
|                                          | EX                                          | AF,AF'                   | Ø8                        |
| The EX AF,AF' i                          | nstruction will exchange t                  | he two-byte content of r | egister pairs AF and AF'. |
| ,                                        | 31                                          |                          | -9                        |
| Symbolic O                               | peration: AF <> AF'                         |                          |                           |
|                                          | peration: AF <> AF'<br>odes affected: none. |                          |                           |
|                                          |                                             |                          |                           |
|                                          |                                             |                          |                           |
|                                          | odes affected: none.                        |                          |                           |
| Condition c                              | odes affected: none.                        |                          |                           |
| Condition c                              | odes affected: none.                        |                          |                           |
| Condition c                              | odes affected: none.                        |                          |                           |
| Condition c<br>X DE,HL                   | odes affected: none.                        | Operand                  | Object<br>Code (hex)      |
| Condition c<br>K DE,HL<br>hange Register | odes affected: none.                        | <b>Operand</b><br>DE,HL  |                           |

|                |                                                       |         | Exchange Register Pa       |
|----------------|-------------------------------------------------------|---------|----------------------------|
| SYNTAX:        |                                                       |         |                            |
| Label          | Operation                                             | Operand | Object<br>Code (hex)       |
|                | EXX                                                   |         | D9                         |
|                | n will exchange each two<br>content of register pairs |         |                            |
| Symbolic Oper  | ration: BC <> BC'                                     |         |                            |
| Symbolic Oper  | ration: BC <> BC'<br>DE <> DE'<br>HL <> HL'           |         |                            |
|                | DE <> DE'<br>HL <> HL'                                |         |                            |
|                | DE <> DE'                                             |         |                            |
|                | DE <> DE'<br>HL <> HL'                                |         |                            |
|                | DE <> DE'<br>HL <> HL'                                |         | HAL                        |
|                | DE <> DE'<br>HL <> HL'                                |         | HAL                        |
|                | DE <> DE'<br>HL <> HL'                                |         | Hall                       |
|                | DE <> DE'<br>HL <> HL'                                |         |                            |
| Condition code | DE <> DE'<br>HL <> HL'                                |         | Ha                         |
| Condition code | DE <> DE'<br>HL <> HL'                                | Operand |                            |
| Condition code | DE <> DE'<br>HL <> HL'<br>es affected: none.          | Operand | Object                     |
| Condition code | DE <> DE'<br>HL <> HL'<br>es affected: none.          | Operand | Ha<br>Object<br>Code (hex) |

**Interrupt Modes** 

| SYNTAX: |           |         |                      |
|---------|-----------|---------|----------------------|
| Label   | Operation | Operand | Object<br>Code (hex) |
|         | IM        | Ø       | ED46                 |
|         | IM        | 1       | ED56                 |
|         | IM        | 2       | ED5E                 |

The IM  $\emptyset$  instruction will institute interrupt mode  $\emptyset$ . In this mode, the interrupting device may insert any instruction on the data bus for execution by the microprocessor. The first byte of a multi-byte instruction will be read during the interrupt acknowledgement cycle. The following bytes will be read by a normal read sequence.

The IM 1 instruction will institute interrupt mode 1. In this mode, the microprocessor will respond to an interrupt by executing a restart to location ØØ38H.

The IM 2 instruction will institute the vectored interrupt mode 2. In this mode, an indirect call to any memory location by an 8-bit vector supplied by the peripheral device is allowed.

| - 10 <sup>-</sup> - 100 - 2 <sup>14</sup> da ya <u></u> |                                                 | Loa                                          | d Register A from I/O    |
|---------------------------------------------------------|-------------------------------------------------|----------------------------------------------|--------------------------|
| YNTAX:                                                  |                                                 |                                              | <b>.</b>                 |
| Label                                                   | Operation                                       | Operand                                      | Object<br>Code (hex)     |
|                                                         | IN                                              | A,[n]                                        | DB(n)                    |
|                                                         |                                                 |                                              |                          |
|                                                         | uction will load register A<br>eration: A < [n] | A with one byte of data fr                   | om the selected I/O port |
| Symbolic Op                                             |                                                 | A with one byte of data fr                   | om the selected I/O port |
| Symbolic Op                                             | eration: A < [n]                                | A with one byte of data fr                   | om the selected I/O port |
| Symbolic Op<br>Condition co                             | eration: A < [n]                                | A with one byte of data fr<br><b>Operand</b> | om the selected I/O port |

This instruction will load into register A one byte of data from the device connected to the I/O port designated by 28H.

# IN r,[C]

#### Load Register from Designated Device

| 'NTAX: |           |                        |                      |
|--------|-----------|------------------------|----------------------|
| Label  | Operation | Operand                | Object<br>Code (hex) |
|        | IN        | A,[C]                  | ED78                 |
|        | IN        | B, <b>[</b> C <b>]</b> | ED4Ø                 |
|        | IN        | C, <b>[</b> C <b>]</b> | ED48                 |
|        | IN        | D, <b>[</b> C]         | ED5Ø                 |
|        | IN        | E,[C]                  | ED58                 |
|        | IN        | H, <b>[</b> C <b>]</b> | ED6Ø                 |
|        | IN        | L, [C]                 | ED68                 |

The IN r,[C] instruction will place the content of register C onto the bottom half of the address bus to select a specified I/O port. The content of register B will be placed on the top half of the address bus. One byte from the selected port will then be loaded into the designated register.

Symbolic Operation: r <--- [C]

Condition codes affected: N, P/V, HC, Z, and S.

Example:

| Label | Operation | Operand | Comment |
|-------|-----------|---------|---------|
|       | IN        | A,[C]   |         |

This instruction will load one byte of data into register A from I/O port selected by the content of register C.

#### **Increment Register**

# SYNTAX:

|       |           |         | Object     |
|-------|-----------|---------|------------|
| Label | Operation | Operand | Code (hex) |
|       | INC       | А       | 3C         |
|       | INC       | В       | Ø4         |
|       | INC       | С       | ØC         |
|       | INC       | D       | 14         |
|       | INC       | E       | 1C         |
|       | INC       | н       | 24         |
|       | INC       | L       | 2C         |

The INC  $\_$  instruction will increment the content of the register designated by the operand field.

#### Symbolic Operation: r <--- r+1

Condition codes affected: N, P/V, HC, Z, and S.

#### Example:

| Label | Operation | Operand | Comment |
|-------|-----------|---------|---------|
|       | INC       | A       |         |

This instruction will increment the content of register A.

| YNTAX:                       |                                                   |                       |                      |
|------------------------------|---------------------------------------------------|-----------------------|----------------------|
| Label                        | Operation                                         | Operand               | Object<br>Code (hex) |
|                              | INC                                               | [HL]                  | 34                   |
|                              | struction will increment                          | the content of memory | location addressed   |
| gister pair HL.              | struction will increment<br>eration: [HL] < [HL]+ |                       | location addressed   |
| ster pair HL.<br>Symbolic Op |                                                   | 1                     | location addressed   |

| SYNTAX: |           |         |                      |  |
|---------|-----------|---------|----------------------|--|
| Label   | Operation | Operand | Object<br>Code (hex) |  |
|         | INC       | IX      | DD23                 |  |
|         | INC       | IY      | FD23                 |  |

The INC IX or INC IY instruction will increment the content of the designated index register.

Symbolic Operation: IX <--- IX+1 or

IY <--- IY+1

MODEL 64000 ASSEMBLER SUPPLEMENT

Increment Memory Location Addressed by Index Register

INC [I \_ \_+d]

| SYNTAX: |           |         |                      |
|---------|-----------|---------|----------------------|
| Label   | Operation | Operand | Object<br>Code (hex) |
|         | INC       | [IX+d]  | <b>DD34</b> (d)      |
|         | INC       | [IY+d]  | FD34(d)              |

The INC [IX+d] or INC [IY+d] instruction will increment the content of memory location addressed by operand [I - +d].

Symbolic Operation: [IX+d] <--- [IX+d]+1 or [IY+d] <--- [IY+d]+1

Condition codes affected: N, P/V, HC, Z, and S.

Example:

| Label | Operation | Operand  | Comment |
|-------|-----------|----------|---------|
|       | INC       | [IX+Ø4H] |         |

This instruction will add the content of Index Register IX and the two's complement of integer Ø4H to point to a memory address which will then be incremented.

INC ss

#### **Increment Register Pair**

| SYNTAX: |           |         |                      |
|---------|-----------|---------|----------------------|
| Label   | Operation | Operand | Object<br>Code (hex) |
|         | INC       | BC      | ØЗ                   |
|         | INC       | DE      | . 13                 |
|         | INC       | HL      | 23                   |
|         | INC       | SP      | 33                   |

The INC ss instruction will increment the content of the register pair designated by the operand field.

Symbolic Operation: ss <--- ss+1

Condition codes affected: none.

Example:

| Label | Operation | Operand | Comment |
|-------|-----------|---------|---------|
|       | INC       | BC      |         |

This instruction will increment the content of register pair BC.

| DDEL 64000<br>SEMBLER SUPPLEME<br>0 | NT        |          | i N                   |
|-------------------------------------|-----------|----------|-----------------------|
|                                     |           | Load Mem | ory Location from I/O |
| SYNTAX:                             |           |          |                       |
| 01111/04                            |           |          |                       |
| Label                               | Operation | Operand  | Object<br>Code (hex)  |

The IND instruction will place the content of register C onto the bottom half of the address bus to select a specified I/O port. The content of register B will be placed on the top half of the address bus. One byte of data from the selected port will then be loaded into the memory location addressed by register pair HL. After the data transfer, the content of register B and the content of register pair HL will be decremented.

Symbolic Operation: [HL] <--- [C]; B <--- B-1, HL <--- HL-1

# 

MODEL 64000 ASSEMBLER SUPPLEMENT Z80

#### Load Decreasing Memory Locations from I/O Port

| SYNTAX: |           |         |                      |
|---------|-----------|---------|----------------------|
| Label   | Operation | Operand | Object<br>Code (hex) |
|         | INDR      |         | EDBA                 |

The INDR instruction will place the content of register C onto the bottom half of the address bus to select a specified I/O port. The content of register B will be placed on the top half of the address bus. One byte of data from the selected port will then be loaded into memory location addressed by register pair HL. After the data transfer, the content of register B and the content of register pair HL will be decremented. If decrementing causes register B to go to zero, the instruction will be terminated. If register B is not zero, the instruction will be repeated.

#### NOTE

If register B is zeroed prior to execution of the INDR instruction, 256 bytes of data will be read in from the I/O port.

**Symbolic Operation:** [HL] <--- [C]; B <--- B-1, HL <--- HL-1; Repeat until B=Ø

| MODEL 64000<br>ASSEMBLER SUPPLEMEN<br>Z80 | NT        |                |                            |
|-------------------------------------------|-----------|----------------|----------------------------|
|                                           |           | Load Memory Lo | cation [+HL] from I/O Port |
| SYNTAX:                                   |           |                |                            |
| Label                                     | Operation | Operand        | Object<br>Code (hex)       |
|                                           | INI       |                | EDA2                       |

The INI instruction will place the content of register C onto the bottom half of the address bus to select a specified I/O port. The content of register B will be placed on the top half of the address bus. One byte of data from the selected port will then be loaded into the memory location addressed by register pair HL. After the data transfer, the content of register B will be decremented and the content of register pair HL will be incremented.

Symbolic Operation: [HL] <--- [C]; B <--- B-1, HL <--- HL+1

Load Memory Location [+HL] from I/O Port - Repeat

| ę | SYNTAX: |           |         |                      |  |
|---|---------|-----------|---------|----------------------|--|
|   | Label   | Operation | Operand | Object<br>Code (hex) |  |
|   |         | INIR      |         | EDB2                 |  |

The INIR instruction will place the content of register C onto the bottom half of the address bus to select a specified I/O port. The content of register B will be placed on the top half of the address bus. One byte of data from the selected port will then be loaded into the memory location addressed by register pair HL. After the data transfer, the content of register B will be decremented and the content of register pair HL will be incremented. If decrementing causes register B to go to zero, the instruction will be terminated. If register B is not zero, the instruction will be repeated.

#### NOTE

If register B is zeroed prior to execution of the INIR instruction, 256 bytes of data will be read in from the I/O port.

Symbolic Operation: [HL] <--- [C]; B <--- B-1, HL <--- HL+1; Repeat until B=Ø

**Unconditional Jump to Memory Location** 

JP

| SYNTAX: |           |         |                         |
|---------|-----------|---------|-------------------------|
| Label   | Operation | Operand | Object<br>Code (hex)    |
|         | JP        | [HL]    | E9                      |
|         | JP        | [IX]    | DDE9                    |
|         | JP        | [IY]    | FDE9                    |
|         | JP        | nn      | <b>C3</b> ( <b>nn</b> ) |

The JP  $\_$  instruction will load the program counter (PC) with the content of the designated register pair or the value assigned by nn. The next instruction will then be brought from the memory location pointed to by the program counter.

Symbolic Operation: PC <--- [HL], or PC <--- [IX], or PC <--- [IY], or PC <--- nn

Condition codes affected: none.

Example:

| Label | Operation | Operand | Comment |
|-------|-----------|---------|---------|
|       | JP        | Ø5FAH   |         |

This instruction will cause the value Ø5FAH to be loaded into the program counter. The next instruction will then be brought from memory location Ø5FAH.

## JP cc,nn∎

#### Conditional Jump to Memory Location

|   | ~/ | N I | T | • | $\sim$ |   |
|---|----|-----|---|---|--------|---|
| S | Y  | IN  |   | А | х      |   |
| - | •  |     |   |   |        | • |

| Label  | Operation                                                                                                   | Operand                                                  | Object<br>Code (hex)                                                         |
|--------|-------------------------------------------------------------------------------------------------------------|----------------------------------------------------------|------------------------------------------------------------------------------|
|        | JP<br>JP<br>JP<br>JP<br>JP<br>JP<br>JP<br>JP<br>JP                                                          | C,nn<br>M,nn<br>NC,nn<br>NZ,nn<br>P,nn<br>PE,nn<br>PO,nn | DA(nn)<br>FA(nn)<br>D2(nn)<br>C2(nn)<br>F2(nn)<br>EA(nn)<br>E2(nn)<br>CA(nn) |
| where: | C = carry<br>M = sign r<br>NC = non c<br>NZ = non z<br>P = sign r<br>PE = parity<br>PO = parity<br>Z = zero | carry<br>cero<br>positive<br>r even                      | CA(nn)                                                                       |

The JP cc,nn instruction will cause the condition flags in register F to be tested for the condition designated by the cc section of the operand. If the condition is true, the instruction will load operand nn into the program counter (PC) and program execution will continue with the instruction located at address nn.

If condition cc is false, program execution will continue with the next instruction.

#### Condition codes affected: none.

Example:

| Label | Operation | Operand | Comment |
|-------|-----------|---------|---------|
|       | JP        | C,Ø5FAH |         |

If the carry flag in register F is set (1), this instruction will cause the program to branch to memory location  $\emptyset$ 5FAH. The branch will be accomplished by loading address  $\emptyset$ 5FAH into the program counter.

MODEL 64000 ASSEMBLER SUPPLEMENT Z80

Unconditional Jump to Location PC+e

IJR el

| SYNTAX: |           |         |                      |
|---------|-----------|---------|----------------------|
| Label   | Operation | Operand | Object<br>Code (hex) |
|         | JR        | е       | 18(e-2)              |

The JR e instruction will unconditionally branch to other portions of the program. The value of the offset e will be added to the program counter (PC) and the next instruction will be brought from the memory location designated by the new content in the program counter. Displacement e may be either a positive or negative number. The jump will be measured from the current content of the program counter and has a range of -126 to +129 bytes.

Symbolic Operation: PC <--- PC+e

Condition codes affected: none.

Example:

| Label | Operation | Operand | Comment |
|-------|-----------|---------|---------|
|       | JR        | \$+1Ø   |         |

This instruction will unconditionally jump to 10 locations from the current value of the program counter. The jump will be in a positive direction.

#### Conditional Jump to Location PC+e

SYNTAX:

JR \_ \_.e

| Label  | Operation                   | Operand                                                                                                  | Object<br>Code (hex)                     |
|--------|-----------------------------|----------------------------------------------------------------------------------------------------------|------------------------------------------|
|        | JR<br>JR<br>JR<br>JR        | C,e<br>NC,e<br>NZ,e<br>Z,e                                                                               | 38(e-2)<br>3Ø(e-2)<br>2Ø(e-2)<br>28(e-2) |
| where: | NC - carry c<br>NZ - zero c | condition flag = 1<br>condition flag = $\emptyset$<br>condition flag = $\emptyset$<br>condition flag = 1 |                                          |

The JR  $_-$  \_,e instructions will provide conditional branching to other parts of the program depending on the results of a test on either the carry or zero condition flags. If the condition flag meets the instruction requirements, offset e will be added to the program counter (PC) causing the next instruction to be brought from the new location. The jump will be measured from the current program counter address and has a range of -126 to +129 bytes.

If the test of the carry or zero flag does not meet the instruction requirements, program execution will continue with the next instruction.

#### Condition codes affected: none.

Example:

| Label | Operation | Operand | Comment |
|-------|-----------|---------|---------|
|       | JR        | C,\$+5  |         |

If the carry condition flag is set (1), the instruction will cause the program to branch ahead five bytes.

■LD \_ \_,\_

#### Load Register or Memory Location

| Label | Operation                            | Operand          | Object<br>Code (hex)                                                                                                                                                                                                                                                                                     |
|-------|--------------------------------------|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | LD                                   | reg,reg          | (see below)                                                                                                                                                                                                                                                                                              |
| Label |                                      |                  | (see below)<br>E,[IY+d]=FD5E(d)<br>E,A=5F<br>E,B=58<br>E,C=59<br>E,D=5A<br>E,E=5B<br>E,H=5C<br>E,L=5D<br>E,n=1E(n)<br>H,[HL]=66<br>H,[IX+d]=DD66(d)<br>H,[IY+d]=FD66(d)<br>H,A=67<br>H,B=60<br>H,C=61<br>H,D=62<br>H,E=63<br>H,H=64<br>H,L=65<br>H,n=26(n)<br>HL,[nn]=2A(nn)<br>HL,nn=21(nn)<br>I,A=ED47 |
|       | [IY+d],H=FD74(d)<br>[IY+d],L=FD75(d) | C,C=49<br>C,D=4A | IX,[nn]=DD2A(nn)<br>IX,nn=DD21(nn)                                                                                                                                                                                                                                                                       |
|       | [IY+d],n=FD36(d)(n)                  | C,E=4B           | IY,[nn]=FD2A(nn)                                                                                                                                                                                                                                                                                         |
|       | [nn],A=32(nn)<br>[nn],BC=ED43(nn)    | C,H=4C<br>C,L=4D | IY,nn=FD21(nn)<br>L,[HL]=6E                                                                                                                                                                                                                                                                              |
|       | [nn],DE=ED53(nn)                     | C,n=ØE(n)        | L,[IX+d]=DD6E(d)                                                                                                                                                                                                                                                                                         |

MODEL 64000 ASSEMBLER SUPPLEMENT Z80

| [nn],HL=22(nn)   | D, <b>[HL]</b> =56 | L,[IY+d]=FD6E(d) |
|------------------|--------------------|------------------|
| [nn],IX=DD22(nn) | D,[IX+d]=DD56(d)   | L,A=6F           |
| [nn],IY=FD22(nn) | D,[IY+d]=FD56(d)   | L,B=68           |
| [nn],SP=ED73(nn) | D,A=57             | L,C=69           |
| A,[BC]=ØA        | D,B=5Ø             | L,D=6A           |
| A,[DE]=1A        | D,C=51             | L,E=6B           |
| A,[HL]=7E        | D,D=52             | L,H=6C           |
| A,[IX+d]=DD7E(d) | D,E=53             | L,L=6D           |
| A,[IY+d]=FD7E(d) | D,H=54             | L,n=2E(n)        |
| A,[nn]=3A(nn)    | D,L=55             | R,A=ED4F         |
| A,A=7F           | D,n=16(n)          | SP,HL=F9         |
| A,B=78           | DE,[nn]=ED5B(nn)   | SP,IX=DDF9       |
| A,C=79           | DE,nn=11(nn)       | SP,IY=FDF9       |
| A,D=7A           | E,[HL]=5E          | SP,[nn]=ED7B(nn) |
| A,E=7B           | E,[IX+d]=DD5E(d)   | SP,nn=31(nn)     |
|                  |                    |                  |

#### NOTE

Portions of the object codes enclosed in parentheses are user assigned addresses or data. They will take the form of a hexadecimal number and will become part of the object code.

LD

(Cont'd)

The LD \_ \_ , \_ \_ instruction will load any register or memory location with any other register, memory location, or value.

**Condition codes affected:** the following condition codes are affected by the LD A,I and LD A,R instructions: N, P/V, HC, Z, and S. All other instructions have no effect on the condition flags.

#### Examples:

| a. | Label | Operation | Operand | Comment |
|----|-------|-----------|---------|---------|
|    |       | LD        | A,I     |         |

The content of interrupt vector register I will be loaded into register A.

| b. | Label | Operation | Operand | Comment |
|----|-------|-----------|---------|---------|
|    |       | LD        | Н,[НL]  |         |

The content of memory location addressed by register pair HL will be loaded into register H.

| С. | Label | Operation | Operand   | Comment |
|----|-------|-----------|-----------|---------|
|    |       | LD        | A,[IX+5H] |         |

The content of memory location addressed by the content of the index register (IX)+5H will be loaded into register A.

Cont'd

|                   |                          |          | MODEL 6400<br>ASSEMBLER SUPPLEMEN<br>Z8 |
|-------------------|--------------------------|----------|-----------------------------------------|
|                   |                          |          | 20                                      |
| Load Memory Locat | tion - Decrement Registe | ≱r Pairs |                                         |
| SYNTAX:           |                          |          |                                         |
| Label             | Operation                | Operand  | Object<br>Code (hex)                    |
|                   | LDD                      |          | EDA8                                    |

The LDD instruction will transfer one byte of data from memory location addressed by register pair HL to a memory location addressed by register pair DE. The three register pairs, BC, DE, and HL, will then be decremented.

Symbolic Operation: [DE] <--- [HL]; DE <--- DE-1, HL <--- HL-1, BC <--- BC-1

| Т |           |                        | LDDI                      |
|---|-----------|------------------------|---------------------------|
|   |           |                        |                           |
|   | Load Mer  | mory Location - Decrem | ent Register Pairs - Repe |
|   |           |                        |                           |
|   |           |                        | Object                    |
| I | Operation | Operand                | Code (hex)                |
|   | LDDR      |                        | EDB8                      |
|   |           |                        |                           |

The LDDR instruction will transfer one byte of data from memory location addressed by register pair HL to a memory location addressed by register pair DE. The three register pairs, BC, DE, and HL, will then be decremented. If decrementing causes register pair BC to go to zero, the instruction will be terminated. If register pair BC does not go to zero, the instruction will be repeated.

Symbolic Operation: [DE] <--- [HL]; DE <--- DE−1, HL <--- HL−1, BC <--- BC−1; Repeat until BC=Ø

#### NOTE

If register pair BC is zeroed prior to the execution of the LDDR instruction, the microprocessor will loop through 64K bytes.

| DI              |                          |         | MODEL 64000<br>ASSEMBLER SUPPLEMENT<br>Z80 |  |
|-----------------|--------------------------|---------|--------------------------------------------|--|
| ad Memory Locat | ion - Increment Register | Pairs   |                                            |  |
| SYNTAX:         |                          |         |                                            |  |
| Label           | Operation                | Operand | Object<br>Code (hex)                       |  |
|                 |                          |         |                                            |  |

The LDI instruction will transfer one byte of data from memory location addressed by register pair HL to a memory location addressed by register pair DE. Both register pairs, DE and HL, will then be incremented. Register pair BC will be decremented.

Symbolic Operation: [DE] <--- [HL]; DE <--- DE+1, HL <--- HL+1, BC <--- BC-1;

|                     |                         |            | EMBLER SUPPLEMEI |
|---------------------|-------------------------|------------|------------------|
| nent Register Pairs | emory Location - Increm | Load Me    |                  |
|                     |                         |            | SYNTAX:          |
|                     |                         |            |                  |
| Object              |                         | On analism |                  |
| Object<br>Code (hex | Operand                 | Operation  | Label            |

The LDIR instruction will transfer one byte of data from memory location addressed by register pair HL to a memory location addressed by register pair DE. Both register pairs, DE and HL, will then be incremented. Register pair BC will be decremented. If decrementing causes register pair BC to go to zero, the instruction will be terminated. If register BC does not go to zero, the instruction will be repeated.

#### NOTE

If register pair BC is zeroed prior to the execution of the LDIR instruction, the microprocessor will loop through 64K bytes.

Symbolic Operation: [DE] <--- [HL]; DE <--- DE+1, HL <--- HL+1, BC <--- BC-1; Repeat until BC=Ø

|                   |                           |                   | MODEL 640<br>ASSEMBLER SUPPLEMEN<br>Z |
|-------------------|---------------------------|-------------------|---------------------------------------|
| egate Contents of | Register A                |                   |                                       |
| SYNTAX:           |                           |                   |                                       |
| Label             | Operation                 | Operand           | Object<br>Code (hex)                  |
|                   | NEG                       |                   | ED44                                  |
| Condition c       |                           |                   |                                       |
|                   | :odes affected: CY, N, P/ | /V, HC, Z, and S. |                                       |
|                   | eodes affected: CY, N, P, | /V, HC, Z, and S. |                                       |
|                   | codes affected: CY, N, P, | /V, HC, Z, and S. |                                       |
|                   | eodes affected: CY, N, P, | /V, HC, Z, and S. |                                       |
| OP                | eodes affected: CY, N, P, | /V, HC, Z, and S. |                                       |
| Operation         | eodes affected: CY, N, P, | /V, HC, Z, and S. |                                       |

The NOP instruction performs no operation. The label field is optional; however, labels can be assigned to NOP statements for program branching. Operands are not permitted with the NOP instruction.

ØØ

Condition codes affected: none.

NOP

OR s

Logical OR with Register A

|       |           |         | Object                   |
|-------|-----------|---------|--------------------------|
| Label | Operation | Operand | Code (hex)               |
|       | OR        | [HL]    | B6                       |
|       | OR        | [IX+d]  | DDB6(d)                  |
|       | OR        | [IY+d]  | FDB6(d)                  |
|       | OR        | A       | B7                       |
|       | OR        | В       | BØ                       |
|       | OR        | С       | B1                       |
|       | OR        | D       | B2                       |
|       | OR        | E       | B3                       |
|       | OR        | Н       | B4                       |
|       | OR        | L       | B5                       |
|       | OR        | n       | <b>F6</b> ( <b>n</b> ) . |

The OR s instruction will perform a logical OR operation between the byte of data specified by the operand and the content of register A. The result will be stored in register A.

Symbolic Operation: A <--- A • s

Condition codes affected: CY, N, P/V, HC, Z, and S.

Example:

| Label | Operation | Operand | Comment |
|-------|-----------|---------|---------|
|       | OR        | [HL]    |         |

The content of memory location addressed by register pair HL will be logically ORed with the content of register A. The result will be stored in register A.

#### Load Output Port - Decrement Register - Repeat

| SYNTAX: |           |         |                      |
|---------|-----------|---------|----------------------|
| Label   | Operation | Operand | Object<br>Code (hex) |
|         | OTDR      |         | EDBB                 |

The OTDR instruction will cause the data byte at memory location addressed by register pair HL to be temporarily stored in the microprocessor. Register B will be decremented and the content of register C will be placed on the bottom half of the address bus to select the appropriate I/O port. The content of register B will be placed on the top half of the address bus. Next, the data byte stored temporarily will be placed on the data bus and written into the selected peripheral device. Register pair HL will then be decremented. If the decremented register B is not zero, the instruction will be repeated. If register B has gone to zero, the instruction will be terminated.

#### NOTE

If register B is zeroed prior to the execution of the OTDR instruction, the microprocessor will output 256 bytes of data.

Symbolic Operation: [C] <--- [HL]; B <--- B-1, HL <--- HL+1; Repeat until B=Ø

| ODEL 64000<br>SSEMBLER SUPPLEMENT<br>30 | <u> </u>  |                       | <b>T</b> 0            |
|-----------------------------------------|-----------|-----------------------|-----------------------|
|                                         |           | Load Output Port - Ir | ncrement Register - R |
| SYNTAX:                                 |           |                       |                       |
| Label                                   | Operation | Operand               | Object<br>Code (hex)  |
|                                         | OTIR      |                       | EDB3                  |

The OTIR instruction will cause the data byte at memory location addressed by register pair HL to be temporarily stored in the microprocessor. Register B will be decremented and the content of register C will be placed on the bottom half of the address bus to select the appropriate I/O port. The content of register B will be placed on the top half of the address bus. Next, the data byte stored temporarily will be placed on the data bus and written into the selected peripheral device. Register pair HL will then be incremented. If the decremented register B is not zero, the instruction will be repeated. If register B has gone to zero, the instruction will be terminated.

#### NOTE

If register B is zeroed prior to the execution of the OTIR instruction, the microprocessor will output 256 bytes of data.

**Symbolic Operation:** [C] <--- [HL]; B <--- B-1, HL <--- HL-1; Repeat until B=Ø

# ■OUT [C],r ■

#### Load Output Port with Register r

| SYNTAX: |           |         |                      |
|---------|-----------|---------|----------------------|
| Label   | Operation | Operand | Object<br>Code (hex) |
|         | OUT       | [C],A   | ED79                 |
|         | OUT       | [C],B   | ED41                 |
|         | OUT       | [C],C   | ED49                 |
|         | OUT       | [C],D   | ED51                 |
|         | OUT       | [C],E   | ED59                 |
|         | OUT       | [C],H   | ED61                 |
|         | OUT       | [C],L   | ED69                 |
|         |           |         |                      |

The OUT [C],r instruction will place the content of register C onto the bottom half of the address bus to select the appropriate I/O port. The content of register B will be placed on the top half of the address bus. Then the byte of data contained in the designated register will be placed on the data bus and written into the selected peripheral device.

Symbolic Operation: [C] <--- r

Condition codes affected: none.

**Example:** 

| Label | Operation | Operand | Comment |
|-------|-----------|---------|---------|
|       | OUT       | [C],B   |         |

This instruction will place the content of register B onto the output data bus. The output port will be selected by the content of register C.

|                                                                          |                                                             | Load C                                                                                 | Putput Port with Register |
|--------------------------------------------------------------------------|-------------------------------------------------------------|----------------------------------------------------------------------------------------|---------------------------|
| SYNTAX:                                                                  |                                                             |                                                                                        | Object                    |
| Label                                                                    | Operation                                                   | Operand                                                                                | Object<br>Code (hex)      |
|                                                                          | OUT                                                         | [n],A                                                                                  | D3(n)                     |
|                                                                          |                                                             |                                                                                        |                           |
| ddress bus to sele<br>op half of the addr                                | ect the appropriate I/O p<br>ress bus. Then the byte o      | perand [n] to be placed o<br>port. The content of regis<br>f data contained in registe | ter A will appear on the  |
| ata bus and writh                                                        | ten into the selected pe                                    | ripheral device.                                                                       |                           |
|                                                                          | ten into the selected pe<br>ration: [n] < A                 | ripheral device.                                                                       |                           |
| Symbolic Ope                                                             |                                                             | ripheral device.                                                                       |                           |
| Symbolic Ope                                                             | eration: [n] < A                                            | ripheral device.                                                                       |                           |
| Symbolic Ope<br>Condition cod                                            | eration: [n] < A                                            | ripheral device.<br>Operand                                                            | Comment                   |
| Symbolic Ope<br>Condition cod<br>Example:                                | e <b>ration: [</b> n] < A<br>les affected: none.            |                                                                                        | Comment                   |
| Symbolic Ope<br>Condition cod<br>Example:<br>Label<br>his instruction wi | eration: [n] < A<br>les affected: none.<br>Operation<br>OUT | Operand                                                                                |                           |
| Symbolic Ope<br>Condition cod<br>Example:<br>Label<br>his instruction wi | eration: [n] < A<br>les affected: none.<br>Operation<br>OUT | <b>Operand</b><br>[Ø5H],А                                                              |                           |
| Symbolic Ope<br>Condition cod<br>Example:<br>Label                       | eration: [n] < A<br>les affected: none.<br>Operation<br>OUT | <b>Operand</b><br>[Ø5H],А                                                              |                           |

| OUTD 🖿  |                        |         | MODEL 640<br>ASSEMBLER SUPPLEMEN<br>Zi |
|---------|------------------------|---------|----------------------------------------|
| SYNTAX: | t - Decrement Register |         |                                        |
| Label   | Operation              | Operand | Object<br>Code (hex)                   |
|         | OUTD                   |         | EDAB                                   |

The OUTD instruction will cause the data byte at memory location addressed by register pair HL to be temporarily stored in the microprocessor. Register B will be decremented and the content of register C will be placed on the bottom half of the address bus to select the appropriate I/O port. The content of register B will be placed on the top half of the address bus. Next, the data byte stored temporarily will be placed on the data bus and written into the selected peripheral device. Register pair HL will then be decremented.

Symbolic Operation: [C] <--- [HL]; B <--- B-1, HL <--- HL-1

| MODEL 64000<br>ASSEMBLER SUPPLEMEN<br>Z80 | т         |             |                           |
|-------------------------------------------|-----------|-------------|---------------------------|
|                                           |           | Load Output | Port - Increment Register |
| SYNTAX:                                   |           |             |                           |
|                                           |           |             | Object                    |
| Label                                     | Operation | Operand     | Code (hex)                |
|                                           | OUTI      |             | EDA3                      |

The OUTI instruction will cause the data byte at memory location addressed by register pair HL to be temporarily stored in the microprocessor. Register B will be decremented and the content of register C will be placed on the bottom half of the address bus to select the appropriate I/O port. The content of register B will be placed on the top half of the address bus. Next, the data byte stored temporarily will be placed on the data bus and written into the selected peripheral device. Register pair HL will then be incremented.

Symbolic Operation: [C] <--- [HL]; B <--- B-1, HL <--- HL+1

| Ρ | 0 | Ρ | <b> _</b> |  |
|---|---|---|-----------|--|
| Γ | U |   | I         |  |

#### Load Index Register with Top of Stack

| SYNTAX: |           |         |                      |
|---------|-----------|---------|----------------------|
| Label   | Operation | Operand | Object<br>Code (hex) |
|         | POP       | IX      | DDE1                 |
|         | POP       | IY      | FDE1                 |

The POP I\_ instruction will pull the top two bytes from the external stack into the designated index register. The stack pointer (SP) register holds the 16-bit address of the current 'top' of the stack.

Symbolic Operation: IX \_ <--- [SP] or IY \_ <--- [SP]

and

IX<sub>H</sub> <--- [SP+1] or IY<sub>H</sub> <--- [SP+1]

Condition codes affected: none.

**Example:** 

| Label | Operation | Operand | Comment |
|-------|-----------|---------|---------|
|       | POP       | IX      |         |

This instruction will load the byte of data at the memory location corresponding to the current address in the stack pointer into the low-order position of index register IX. The stack pointer will then be incremented and the corresponding adjacent memory location will be loaded into the high-order position of IX.

Load Register Pair with Top of Stack

POP qq

| SYNTAX: |           |         |                      |
|---------|-----------|---------|----------------------|
| Label   | Operation | Operand | Object<br>Code (hex) |
|         | POP       | AF      | F1                   |
|         | POP       | BC      | C1                   |
|         | POP       | DE      | D1                   |
|         | POP       | HL      | E1                   |
|         |           |         |                      |

The POP qq instruction will pull the top two bytes from the external stack into the register pair designated by the operand. The stack pointer (SP) register holds the 16-bit address of the current 'top' of the stack.

### Symbolic Operation: qq \_ <--- [SP], qq \_ <--- [SP+1]

Condition codes affected: none.

Example:

| Label | Operation | Operand | Comment |
|-------|-----------|---------|---------|
|       | POP       | BC      |         |

This instruction will load the byte of data at the memory location corresponding to the current address in the stack pointer into the low-order position of register pair BC. The stack pointer will then be incremented and the corresponding adjacent memory location will be loaded into the high-order position of register pair BC.

| Ρ | U | S | Η |  |
|---|---|---|---|--|
|   |   |   |   |  |

#### Load Index Register onto Stack

| SYNTAX: |              |          |                      |
|---------|--------------|----------|----------------------|
| Label   | Operation    | Operand  | Object<br>Code (hex) |
|         | PUSH<br>PUSH | IX<br>IY | DDE5<br>FDE5         |
|         | PUSH         | 11       | FDES                 |

The PUSH I  $\_$  instruction will push the content of the designated index register onto the stack. The instruction will decrement the stack pointer and then load the high-order byte of the designated index register into the memory location addressed by the stack pointer. The stack pointer will be decremented again and then the low-order byte will be loaded into the memory location corresponding to the new address.

Symbolic Operation: [SP-2] <--- IX\_ or [SP-2] <--- IY\_

and

Condition codes affected: none.

#### Example:

| Label | Operation | Operand | Comment |
|-------|-----------|---------|---------|
|       | PUSH      | IX      |         |

This instruction will decrement the stack pointer and load the high-order byte of index register IX into the memory location corresponding to the contents of the stack pointer. The stack pointer will be decremented again and then load the memory location specified by SP-2 with the low-order byte in the index register.

MODEL 64000 PUSH qq ASSEMBLER SUPPLEMENT Z80 Load Register Pair onto Stack SYNTAX: Object Code (hex) Label Operation Operand F5 PUSH AF PUSH BC C5 PUSH DE D5 PUSH E5 HL

The PUSH qq instruction will push the content of the designated register pair onto the stack. The instruction decrements the stack pointer and then loads the high-order byte of the designated register pair into the memory location addressed by the stack pointer. The stack pointer will be decremented again and then the low-order byte will be loaded into the memory location corresponding to the new address.

Symbolic Operation: [SP-1] <---qq<sub>H</sub> , [SP-2] <--- qq<sub>1</sub>

Condition codes affected: none.

Example:

| Label | Operation | Operand | Comment |
|-------|-----------|---------|---------|
|       | PUSH      | BC      |         |

This instruction will decrement the stack pointer and load the high-order byte of register pair BC into the memory location corresponding to the content of the stack pointer. The stack pointer will be decremented again and then will load the memory location specified by SP-2 with the low-order byte in register pair BC.

# RES b,m

#### **Reset Bit in Designated Location**

SYNTAX:

| $\begin{array}{c c c c c c c c c c c c c c c c c c c $                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |     | Label C                       | )peration | o Operand          | Object<br>Code (hex) |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-------------------------------|-----------|--------------------|----------------------|
| bit       Ø,[HL]=CB86       bit       3,[HL]=CB9E       bit       6,[HL]=CBB6         Ø,[IX+d]=DDCB(d)86       3,[IX+d]=DDCB(d)9E       6,[IX+d]=DDCB(d)B6         Ø,[IY+d]=FDCB(d)86       3,[IY+d]=FDCB(d)9E       6,[IY+d]=FDCB(d)B6         Ø,A=CB87       3,A=CB9F       6,A=CBB7         Ø,B=CB8Ø       3,B=CB98       6,B=CBBØ         Ø,C=CB81       3,C=CB99       6,C=CBB1         Ø,D=CB82       3,D=CB9A       6,D=CBB2         Ø,E=CB83       3,E=CB9B       6,E=CBB3         Ø,L=CB84       3,H=CB9C       6,H=CBB4         Ø,L=CB85       3,L=CB9D       6,L=CBB5         1,[HL]=CB8E       4,[HL]=CBA6       7,[HL]=CBBE         1,[IX+d]=DDCB(d)8E       4,[IX+d]=DDCB(d)A6       7,[IX+d]=DDCB(d)BE         1,[IY+d]=FDCB(d)8E       4,[IY+d]=FDCB(d)A6       7,[IY+d]=FDCB(d)BE         1,A=CB8F       4,A=CBA7       7,A=CBBF |     |                               | RES       |                    | (see below)          |
| Ø,[IX+d]=DDCB(d)86       3,[IX+d]=DDCB(d)9E       6,[IX+d]=DDCB(d)B6         Ø,[IY+d]=FDCB(d)86       3,[IY+d]=FDCB(d)9E       6,[IY+d]=FDCB(d)B6         Ø,A=CB87       3,A=CB9F       6,A=CBB7         Ø,B=CB8Ø       3,B=CB98       6,B=CBBØ         Ø,C=CB81       3,C=CB99       6,C=CBB1         Ø,D=CB82       3,D=CB9A       6,D=CBB2         Ø,E=CB83       3,E=CB9B       6,E=CBB3         Ø,L=CB84       3,H=CB9C       6,H=CBB4         Ø,L=CB85       3,L=CB9D       6,L=CBB5         1,[HL]=CB8E       4,[HL]=CBA6       7,[HL]=CBBE         1,[IX+d]=DDCB(d)8E       4,[IY+d]=FDCB(d)A6       7,[IY+d]=FDCB(d)BE         1,[IY+d]=FDCB(d)8E       4,[IY+d]=FDCB(d)A6       7,[IY+d]=FDCB(d)BE         1,A=CB8F       4,A=CBA7       7,A=CBBF                                                                                       |     |                               |           |                    |                      |
| Ø,[IY+d]=FDCB(d)86       3,[IY+d]=FDCB(d)9E       6,[IY+d]=FDCB(d)B6         Ø,A=CB87       3,A=CB9F       6,A=CBB7         Ø,B=CB8Ø       3,B=CB98       6,B=CBBØ         Ø,C=CB81       3,C=CB99       6,C=CBB1         Ø,D=CB82       3,D=CB9A       6,D=CBB2         Ø,E=CB83       3,E=CB9B       6,E=CBB3         Ø,H=CB84       3,H=CB9C       6,H=CBB4         Ø,L=CB85       3,L=CB9D       6,L=CBB5         1,[HL]=CB8E       4,[HL]=CBA6       7,[HL]=CBBE         1,[IX+d]=DDCB(d)8E       4,[IX+d]=DDCB(d)A6       7,[IY+d]=FDCB(d)BE         1,[IY+d]=FDCB(d)8E       4,A=CBA7       7,A=CBBF                                                                                                                                                                                                                                       | bit |                               |           |                    |                      |
| Ø,A=CB87       3,A=CB9F       6,A=CBB7         Ø,B=CB8Ø       3,B=CB98       6,B=CBBØ         Ø,C=CB81       3,C=CB99       6,C=CBB1         Ø,D=CB82       3,D=CB9A       6,D=CBB2         Ø,E=CB83       3,E=CB9B       6,E=CBB3         Ø,H=CB84       3,H=CB9C       6,H=CBB4         Ø,L=CB85       3,L=CB9D       6,L=CBB5         1,[HL]=CB8E       4,[HL]=CBA6       7,[HL]=CBBE         1,[IX+d]=DDCB(d)8E       4,[IX+d]=DDCB(d)A6       7,[IX+d]=DDCB(d)BE         1,[IY+d]=FDCB(d)8E       4,[IY+d]=FDCB(d)A6       7,[IY+d]=FDCB(d)BE         1,A=CB8F       4,A=CBA7       7,A=CBBF                                                                                                                                                                                                                                                 |     | Ø,[IX+d]=DDCB(d)86            |           | 3,[IX+d]=DDCB(d)9E |                      |
| Ø,B=CB8Ø       3,B=CB98       6,B=CBBØ         Ø,C=CB81       3,C=CB99       6,C=CBB1         Ø,D=CB82       3,D=CB9A       6,D=CBB2         Ø,E=CB83       3,E=CB9B       6,E=CBB3         Ø,H=CB84       3,H=CB9C       6,H=CBB4         Ø,L=CB85       3,L=CB9D       6,L=CBB5         1,[HL]=CB8E       4,[HL]=CBA6       7,[HL]=CBBE         1,[IX+d]=DDCB(d)8E       4,[IX+d]=DDCB(d)A6       7,[IX+d]=DDCB(d)BE         1,[IY+d]=FDCB(d)8E       4,[IY+d]=FDCB(d)A6       7,[IY+d]=FDCB(d)BE         1,A=CB8F       4,A=CBA7       7,A=CBBF                                                                                                                                                                                                                                                                                                |     | Ø,[IY+d]=FDCB(d)86            |           | 3,[IY+d]=FDCB(d)9E | 6,[IY+d]=FDCB(d)B6   |
| Ø,C=CB81       3,C=CB99       6,C=CBB1         Ø,D=CB82       3,D=CB9A       6,D=CBB2         Ø,E=CB83       3,E=CB9B       6,E=CBB3         Ø,H=CB84       3,H=CB9C       6,H=CBB4         Ø,L=CB85       3,L=CB9D       6,L=CBB5         1,[HL]=CB8E       4,[HL]=CBA6       7,[HL]=CBBE         1,[IX+d]=DDCB(d)8E       4,[IX+d]=DDCB(d)A6       7,[IX+d]=DDCB(d)BE         1,[IY+d]=FDCB(d)8E       4,[IY+d]=FDCB(d)A6       7,[IY+d]=FDCB(d)BE         1,A=CB8F       4,A=CBA7       7,A=CBBF                                                                                                                                                                                                                                                                                                                                               |     | Ø,A=CB87                      |           | 3,A=CB9F           | 6,A=CBB7             |
| Ø,D=CB82       3,D=CB9A       6,D=CBB2         Ø,E=CB83       3,E=CB9B       6,E=CBB3         Ø,H=CB84       3,H=CB9C       6,H=CBB4         Ø,L=CB85       3,L=CB9D       6,L=CBB5         1,[HL]=CB8E       4,[HL]=CBA6       7,[HL]=CBBE         1,[IX+d]=DDCB(d)8E       4,[IX+d]=DDCB(d)A6       7,[IX+d]=DDCB(d)BE         1,[IY+d]=FDCB(d)8E       4,[IY+d]=FDCB(d)A6       7,[IY+d]=FDCB(d)BE         1,A=CB8F       4,A=CBA7       7,A=CBBF                                                                                                                                                                                                                                                                                                                                                                                              |     | Ø,B=CB8Ø                      |           | 3,B=CB98           | 6,B=CBBØ             |
| Ø,E=CB83       3,E=CB9B       6,E=CBB3         Ø,H=CB84       3,H=CB9C       6,H=CBB4         Ø,L=CB85       3,L=CB9D       6,L=CBB5         1,[HL]=CB8E       4,[HL]=CBA6       7,[HL]=CBBE         1,[IX+d]=DDCB(d)8E       4,[IX+d]=DDCB(d)A6       7,[IX+d]=DDCB(d)BE         1,[IY+d]=FDCB(d)8E       4,[IY+d]=FDCB(d)A6       7,[IY+d]=FDCB(d)BE         1,A=CB8F       4,A=CBA7       7,A=CBBF                                                                                                                                                                                                                                                                                                                                                                                                                                             |     | Ø,C=CB81                      |           | 3,C=CB99           | 6,C=CBB1             |
| Ø,H=CB84       3,H=CB9C       6,H=CBB4         Ø,L=CB85       3,L=CB9D       6,L=CBB5         1,[HL]=CB8E       4,[HL]=CBA6       7,[HL]=CBBE         1,[IX+d]=DDCB(d)8E       4,[IX+d]=DDCB(d)A6       7,[IX+d]=DDCB(d)BE         1,[IY+d]=FDCB(d)8E       4,[IY+d]=FDCB(d)A6       7,[IY+d]=FDCB(d)BE         1,A=CB8F       4,A=CBA7       7,A=CBBF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |     | Ø,D=CB82                      |           | 3,D=CB9A           | 6,D=CBB2             |
| Ø,L=CB85       3,L=CB9D       6,L=CBB5         1,[HL]=CB8E       4,[HL]=CBA6       7,[HL]=CBBE         1,[IX+d]=DDCB(d)8E       4,[IX+d]=DDCB(d)A6       7,[IX+d]=DDCB(d)BE         1,[IY+d]=FDCB(d)8E       4,[IY+d]=FDCB(d)A6       7,[IY+d]=FDCB(d)BE         1,A=CB8F       4,A=CBA7       7,A=CBBF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |     | Ø,E=CB83                      |           | 3,E=CB9B           | 6,E=CBB3             |
| 1,[HL]=CB8E       4,[HL]=CBA6       7,[HL]=CBBE         1,[IX+d]=DDCB(d)8E       4,[IX+d]=DDCB(d)A6       7,[IX+d]=DDCB(d)BE         1,[IY+d]=FDCB(d)8E       4,[IY+d]=FDCB(d)A6       7,[IY+d]=FDCB(d)BE         1,A=CB8F       4,A=CBA7       7,A=CBBF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |     | Ø,H=CB84                      |           | 3,H=CB9C           | 6,H=CBB4             |
| 1,[IX+d]=DDCB(d)8E       4,[IX+d]=DDCB(d)A6       7,[IX+d]=DDCB(d)BE         1,[IY+d]=FDCB(d)8E       4,[IY+d]=FDCB(d)A6       7,[IY+d]=FDCB(d)BE         1,A=CB8F       4,A=CBA7       7,A=CBBF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |     | Ø,L=CB85                      |           | 3,L=CB9D           | 6,L=CBB5             |
| 1,[IY+d]=FDCB(d)8E       4,[IY+d]=FDCB(d)A6       7,[IY+d]=FDCB(d)BE         1,A=CB8F       4,A=CBA7       7,A=CBBF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |     | 1, <b>[</b> HL <b>]</b> =CB8E |           | 4,[HL]=CBA6        | 7,[HL]=CBBE          |
| 1,A=CB8F 4,A=CBA7 7,A=CBBF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |     | 1,[IX+d]=DDCB(d)8E            |           | 4,[IX+d]=DDCB(d)A6 | 7,[IX+d]=DDCB(d)BE   |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |     | 1,[IY+d]=FDCB(d)8E            |           | 4,[IY+d]=FDCB(d)A6 | 7,[IY+d]=FDCB(d)BE   |
| 1,B=CB88 4,B=CBAØ 7,B=CBB8                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |     | 1,A=CB8F                      |           | 4,A=CBA7           | 7,A=CBBF             |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |     | 1,B=CB88                      |           | 4,B=CBAØ           | 7,B=CBB8             |
| 1,C=CB89 4,C=CBA1 7,C=CBB9                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |     | 1,C=CB89                      |           | 4,C=CBA1           | 7,C=CBB9             |
| 1,D=CB8A 4,D=CBA2 7,D=CBBA                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |     | 1,D=CB8A                      |           | 4,D=CBA2           | 7,D=CBBA             |
| 1,E=CB8B 4,E=CBA3 7,E=CBBB                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |     | 1,E=CB8B                      |           | 4,E=CBA3           | 7,E=CBBB             |
| 1,H=CB8C 4,H=CBA4 7,H=CBBC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |     | 1,H=CB8C                      |           | 4,H=CBA4           | 7,H=CBBC             |
| 1,L=CB8D 4,L=CBA5 7,L=CBBD                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |     |                               |           | 4,L=CBA5           | 7,L=CBBD             |
| 2,[HL]=CB96 5,[HL]=CBAE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |     | 2,[HL]=CB96                   |           | 5,[HL]=CBAE        |                      |
| 2,[IX+d]=DDCB(d)96 $5,[IX+d]=DDCB(d)AE$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |     |                               | 6         |                    |                      |
| 2,[IY+d]=FDCB(d)96 $5,[IY+d]=FDCB(d)AE$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |     |                               |           |                    |                      |
| 2,A=CB97 5,A=CBAF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |     |                               |           |                    |                      |
| 2,B=CB9Ø 5,B=CBA8                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |     |                               |           | 5,B=CBA8           |                      |
| 2,C=CB91 5,C=CBA9                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |     |                               |           |                    |                      |
| 2,D=CB92 5,D=CBAA                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |     |                               |           |                    |                      |
| 2,E=CB93 5,E=CBAB                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |     |                               |           |                    |                      |
| 2,H=CB94 5,H=CBAC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |     |                               |           |                    |                      |
| 2,L=CB95 5,L=CBAD                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |     |                               |           |                    |                      |

The RES b,m instruction will reset the designated bit in the specified register or memory location.

RES

D.

Cont'd

Symbolic Operation:  $s_b < --- \emptyset$ 

Condition codes affected: none.

Examples:

| a. | Label | Operation | Operand | Comment |
|----|-------|-----------|---------|---------|
|    |       | RES       | 5,[HL]  |         |

This instruction will reset bit 5 of the data byte in memory location addressed by register pair HL.

| b. | Label | Operation | Operand | Comment |
|----|-------|-----------|---------|---------|
|    |       | RES       | 3,E     |         |

This instruction will reset bit 3 of the data byte in register E.

|                    |           |         | MODEL 64000<br>ASSEMBLER SUPPLEMENT<br>Z80 |
|--------------------|-----------|---------|--------------------------------------------|
| Return from Subrou | tine      |         |                                            |
| Label              | Operation | Operand | Object<br>Code (hex)                       |
|                    | RET       |         | C9                                         |

The RET instruction will cause the byte at the memory location addressed by the stack pointer (SP) register to be moved to the low-order eight bits of the program counter (PC). The stack pointer will then be incremented and the byte at the memory location now pointed to by the stack pointer will be moved into the high-order eight bits of the program counter. Program execution will continue from the point addressed by the program counter.

Symbolic Operation:  $\mathsf{PC}_L \mathrel{<---} [\mathsf{SP}], \; \mathsf{PC}_H \mathrel{<---} [\mathsf{SP+1}]$ 

Condition codes affected: none.

**Conditional Return from Subroutine** 

RET cc

| SYNTAX: |                                                                                                                                           |                                          |                                              |
|---------|-------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------|----------------------------------------------|
| Label   | Operation                                                                                                                                 | Operand                                  | Object<br>Code (hex)                         |
|         | RET<br>RET<br>RET<br>RET<br>RET<br>RET<br>RET                                                                                             | C<br>M<br>NC<br>NZ<br>P<br>PE<br>PO<br>Z | D8<br>F8<br>DØ<br>CØ<br>FØ<br>E8<br>EØ<br>C8 |
| where:  | C = carry<br>M = sign negative<br>NC = non carry<br>NZ = non zero<br>P = sign positive<br>PE = parity even<br>PO = parity odd<br>Z = zero |                                          |                                              |

The RET cc instruction will cause the condition flags in register F to be tested for the condition designated by the operand. If the condition is true, then a RET instruction will be performed. If the condition is false, then program execution will continue with the next step of the program counter.

Condition codes affected: none.

| urn from Interrup | ot                       |                         |                       |
|-------------------|--------------------------|-------------------------|-----------------------|
| SYNTAX:           | <u></u>                  |                         |                       |
| Label             | Operation                | Operand                 | Object<br>Code (hex)  |
|                   | RETI                     |                         | ED4D                  |
| The RETI instruc  | tion may be used at the  | end of a maskable inte  | rrupt service routine |
|                   | content of the program   |                         |                       |
|                   |                          | and                     |                       |
| b. signal an l    | O device that the interr | upt routine has been co | mpleted.              |
|                   |                          |                         |                       |
| Condition co      | des affected: none.      |                         |                       |
| Condition co      | des affected: none.      |                         |                       |
|                   | des affected: none.      |                         |                       |
|                   | des affected: none.      |                         |                       |
| ETN               |                          |                         |                       |
| ETN               |                          |                         |                       |
|                   |                          |                         |                       |
| ETN               |                          | Operand                 | Object<br>Code (hex)  |

The RETN instruction may be used at the end of a non-maskable interrupt service routine to restore the content of the program counter (PC).

Condition codes affected: none.

**Rotate Operand Left Through Carry** 

#### SYNTAX:

| Label | Operation | Operand | Object<br>Code (hex) |
|-------|-----------|---------|----------------------|
|       | RL        | [HL]    | CB16                 |
|       | RL        | [IY+d]  | DDCB(d)16            |
|       | RL        | [IY+d]  | FDCB(d)16            |
|       | RL        | А       | CB17                 |
|       | RL        | В       | CB1Ø                 |
|       | RL        | С       | CB11                 |
|       | RL        | D       | CB12                 |
|       | RL        | E       | CB13                 |
|       | RL        | Н       | CB14                 |
|       | RL        | L       | CB15                 |
|       |           |         |                      |

The RL m instruction will rotate the content of the designated register or memory location one bit position to the left. The content of bit 7 will be copied into the carry flag bit in register F and the previous carry flag bit will be copied into bit  $\emptyset$ .



Condition codes affected: CY, N, P/V, HC, Z, and S.

| Otate Register A Left Through Carry SYNTAX: Object Object | SYNTAX:                            |                     |                   |         | MODEL 64000<br>ASSEMBLER SUPPLEMENT<br>Z80 |
|-----------------------------------------------------------|------------------------------------|---------------------|-------------------|---------|--------------------------------------------|
| Object                                                    | Object                             | otate Register A Le | eft Through Carry |         |                                            |
|                                                           |                                    | SYNTAX:             |                   |         |                                            |
|                                                           | Label Operation Operand Code (nex) | Labal               | Orestian          | Onevend |                                            |

The RLA instruction will rotate the content of register A one bit position to the left. The content of bit 7 will be copied into the carry flag bit in register F and the previous carry flag bit will be copied into bit  $\emptyset$ .

| Symbolic Operation: | CY < 0 < |
|---------------------|----------|
|                     | А        |

**Rotate Operand Left Circular** 

RLC m

#### SYNTAX:

|       |           |         | Object     |
|-------|-----------|---------|------------|
| Label | Operation | Operand | Code (hex) |
|       | RLC       | [HL]    | CBØ6       |
|       | RLC       | [IX+d]  | DDCB(d)Ø6  |
|       | RLC       | [IY+d]  | FDCB(d)Ø6  |
|       | RLC       | А       | CBØ7       |
|       | RLC       | В       | CBØØ       |
|       | RLC       | С       | CBØ1       |
|       | RLC       | D       | CBØ2       |
|       | RLC       | Е       | CBØ3       |
|       | RLC       | Н       | CBØ4       |
|       | RLC       | L       | CBØ5       |
|       |           |         |            |

The RLC m instruction will rotate the content of the designated register or memory location one bit position to the left. The content of bit 7 will be copied into bit  $\emptyset$  and also into the carry flag bit position in register F.



Condition codes affected: CY, N, P/V, HC, Z, and S.

|                  |                     |              |         | MODEL 64000<br>ASSEMBLER SUPPLEMENT<br>Z80 |
|------------------|---------------------|--------------|---------|--------------------------------------------|
| $\left( \right)$ | Rotate Register A L | eft Circular |         |                                            |
|                  | SYNTAX:             |              |         |                                            |
|                  | Label               | Operation    | Operand | Object<br>Code (hex)                       |
|                  |                     | RLCA         |         | Ø7                                         |

The RLCA instruction will rotate the content of register A one bit position to the left. The content of bit 7 will be copied into bit  $\emptyset$  and also into the carry flag bit position in register F.

Symbolic Operation: CY < 7 <--- Ø <---

| MODEL 64000<br>ASSEMBLER SUPPLEMENT<br>Z80 |           |                   | RLD                       |
|--------------------------------------------|-----------|-------------------|---------------------------|
|                                            |           | Rotate Register A | and Register Pair HL Left |
| SYNTAX:                                    |           |                   |                           |
|                                            |           |                   | Object                    |
| Label                                      | Operation | Operand           | Code (hex)                |
|                                            | RLD       |                   | ED6F                      |

The RLD instruction will copy the low-order four bits into the high-order four bits of memory location addressed by register pair HL. The previous content of the high-order four bits of the same memory location will be copied into the low-order four bits of register A. The previous content of the low-order four bits of register A will be copied into the low-order four bits of memory location addressed by register pair HL. The high-order four bits of register A will be unaffected.

| Symbolic Operation: | 7 4 | 3 Ø < | - 7 4 < | 3 Ø< |
|---------------------|-----|-------|---------|------|
|                     | А   | А     | [HL]    | (HL] |

# RR m

## **Rotate Operand Right Through Carry**

|       |           |              | Object     |
|-------|-----------|--------------|------------|
| Label | Operation | Operand      | Code (hex) |
|       | RR        | <b>FLU 1</b> | CB1E       |
|       |           | [HL]         |            |
|       | RR        | [IX+d]       | DDCB(d)1E  |
|       | RR        | [IY+d]       | FDCB(d)1E  |
|       | RR        | А            | CB1F       |
|       | RR        | В            | CB18       |
|       | RR        | С            | CB19       |
|       | RR        | D            | CB1A       |
|       | RR        | Е            | CB1B       |
|       | RR        | Н            | CB1C       |
|       | RR        | L            | CB1D       |
|       |           |              |            |

The RR m instruction will rotate the content of the designated register or memory location one bit position to the right. The content of bit  $\emptyset$  will be copied into the carry flag bit in register F and the previous carry flag bit will be copied into bit 7.



|         |           | Rotate Regis | ter A Right Through |
|---------|-----------|--------------|---------------------|
| SYNTAX: |           |              |                     |
|         |           |              | Object              |
| Label   | Operation | Operand      | Code (hex)          |
|         | RRA       |              | 1F                  |

The RRA instruction will rotate the content of register A one bit position to the right. The content of bit  $\emptyset$  will be copied into the carry flag bit in register F and the previous carry flag bit will be copied into bit 7.

| Symbolic Operation: | >7> Ø -> CY |
|---------------------|-------------|
|                     | Α           |

Condition codes affected: CY, N, and HC.

# RRC m

## **Rotate Operand Right Circular**

| SYNTAX: |           |         |                      |
|---------|-----------|---------|----------------------|
| Label   | Operation | Operand | Object<br>Code (hex) |
|         | RRC       | [HL]    | CBØE                 |
|         | RRC       | [IX+d]  | DDCB(d)ØE            |
|         | RRC       | [IY+d]  | FDCB(d)ØE            |
|         | RRC       | A       | CBØF                 |
|         | RRC       | В       | CBØ8                 |
|         | RRC       | С       | CBØ9                 |
|         | RRC       | D       | CBØA                 |
|         | RRC       | Е       | CBØB                 |
|         | RRC       | н       | CBØC                 |
|         | RRC       | L       | CBØD                 |
|         |           |         |                      |

The RRC m instruction will rotate the content of the designated register or memory location one bit position to the right. The content of bit  $\emptyset$  will be copied into bit 7 and also into the carry flag bit position in register F.



|                      |                             | Rotate                       | Register A Right Circul     |
|----------------------|-----------------------------|------------------------------|-----------------------------|
| SYNTAX:              |                             |                              |                             |
| Label                | Operation                   | Operand                      | Object<br>Code (hex)        |
|                      | RRCA                        |                              | ØF                          |
|                      | tion will rotate the conter |                              |                             |
| content of bit Ø wil | Il be copied into bit 7 and | l also into the carry flag l | oit position in register F. |
| Symbolic Ope         | ration: $7 > 0$             | >CY                          |                             |
| Condition cod        | les affected: CY, N, and    | HC.                          |                             |
|                      |                             |                              |                             |
|                      |                             |                              |                             |
|                      |                             |                              |                             |
|                      |                             |                              |                             |
|                      |                             |                              |                             |
|                      |                             |                              |                             |
|                      |                             |                              |                             |
|                      |                             |                              |                             |
|                      |                             |                              |                             |

|                     |                          |         | MODEL 64000<br>ASSEMBLER SUPPLEMEN<br>Z80 |
|---------------------|--------------------------|---------|-------------------------------------------|
| otate Register A an | nd Register Pair HL Righ | nt      |                                           |
| Label               | Operation                | Operand | Object<br>Code (hex)                      |
|                     |                          |         |                                           |

The RRD instruction will copy the low-order four bits of memory location addressed by register pair HL into the low-order four bits of register A. The previous low-order four bits of register A will be copied into the high-order four bits of the memory location addressed by register pair HL. The high-order four bits of this same memory location will be copied into the low-order four bits of this same memory location will be copied into the low-order four bits of register A will be copied into the high-order four bits of this same memory location will be copied into the low-order four bits of register A will be unaffected.

Symbolic Operation:



Restart to Location p

IRST p

| SYNTAX: |           |         |                      |
|---------|-----------|---------|----------------------|
| Label   | Operation | Operand | Object<br>Code (hex) |
|         | RST       | ØØH     | C7                   |
|         | RST       | Ø8H     | CF                   |
|         | RST       | 1ØH     | D7                   |
|         | RST       | 18H     | DF                   |
|         | RST       | 2ØH     | E7                   |
|         | RST       | 28H     | EF                   |
|         | RST       | 3ØH     | F7                   |
|         | RST       | 38H     | FF                   |
|         |           |         |                      |

The RST p instruction will push the current program counter (PC) content onto the external stack and loads the page zero memory location given in the operand field into the program counter. The restart instruction allows for a jump to one of eight addresses as shown in the syntax block. Since all addresses will be in page zero of memory, the high-order byte of the program counter will be loaded with ØØH. The number selected in the operand column will be loaded into the low-order byte of the program counter.

Symbolic Operation: [SP-2] <--- PC\_L , [SP-1] <--- PC\_H ; PC\_H <---- Ø, PC\_I <---- p

Condition codes affected: none.

# SBC A,s

9A

9B

9C

9D

DE(n)

| SYNTAX: |           |          |                      |
|---------|-----------|----------|----------------------|
| Label   | Operation | Operand  | Object<br>Code (hex) |
|         | SBC       | A,[HL]   | 9E                   |
|         | SBC       | A,[IX+d] | DD9E(d)              |
|         | SBC       | A,[IY+d] | FD9E(d)              |
|         | SBC       | A,A      | 9F                   |
|         | SBC       | A,B      | 98                   |
|         | SBC       | A,C      | 99                   |

#### Subtract Operand from Register A with Carry

The SBC A,s instruction will subtract the content of the register or memory location designated in the operand field plus the carry flag bit from the content of register A. The result of the operation will be stored in register A. The instruction may also be used to subtract a numerical value plus the carry flag bit from register A.

A,D

A,E

A,H

A,L

A,n

Symbolic Operation: A <--- A-s-CY

Condition codes affected: CY, N, P/V, HC, Z, and S.

SBC

SBC

SBC

SBC

SBC

Example:

| Label | Operation | Operand | Comment |
|-------|-----------|---------|---------|
|       | SBC       | A,[HL]  |         |

This instruction will subtract the content of memory location addressed by register pair HL plus the carry flag bit from the content of register A. The result of the operation will be stored in register A.

MODEL 64000 ASSEMBLER SUPPLEMENT Z80

SBC HL,ssi

Subtract Operand from Register Pair HL with Carry

| SYNTAX: |           |         |                      |
|---------|-----------|---------|----------------------|
| Label   | Operation | Operand | Object<br>Code (hex) |
|         | SBC       | HL,BC   | ED42                 |
|         | SBC       | HL,DE   | ED52                 |
|         | SBC       | HL,HL   | ED62                 |
|         | SBC       | HL,SP   | ED72                 |
|         |           |         |                      |

The SBC HL,ss instruction will subtract the content of the designated register pair plus the carry flag bit from the content of register pair HL. The result of the operation will be stored in register pair HL.

Symbolic Operation: HL <--- HL-ss-CY

Condition codes affected: CY, N, P/V, HC, Z, and S.

Example:

| Label | Operation | Operand | Comment |
|-------|-----------|---------|---------|
|       | SBC       | HL,DE   |         |

This instruction will subtract the content of register pair DE plus the carry flag bit from the content of register pair HL. The result of the operation will be stored in register pair HL.

|                |           |         | MODEL 64000<br>ASSEMBLER SUPPLEMENT<br>Z80 |
|----------------|-----------|---------|--------------------------------------------|
| Set Carry Flag |           |         |                                            |
| SYNTAX:        |           |         |                                            |
| Label          | Operation | Operand | Object<br>Code (hex)                       |
|                | SCF       |         | 37                                         |

The SCF instruction will set the carry flag bit in register F.

Symbolic Operation: CY <--- 1

Condition codes affected: CY, N, and HC.

## MODEL 64000 ASSEMBLER SUPPLEMENT

Set Bit b

| ΥN  | ITAX:             |          |                      |     |                      |
|-----|-------------------|----------|----------------------|-----|----------------------|
|     | Label             | Operatio | n Operan             | d   | Object<br>Code (hex) |
|     |                   | SET      | b, reg               |     | (see below)          |
|     |                   | 0L1      | or [add              |     |                      |
| bit | Ø [HL]=CBC6       | bit      | 3,[HL]=CBDE          | bit | 6,[HL]=CBF6          |
|     | Ø,[IX+d]=DDCB(d)C |          | 3,[IX+d]=DDCB(d)DE   |     | 6,[IX+d]=DDCB(d)F6   |
|     | Ø,[IY+d]=FDCB(d)C |          | 3,[IY+d]=FDCB(d)DE   |     | 6,[IY+d]=FDCB(d)F6   |
|     | Ø,A=CBC7          |          | 3,A=CBDF             |     | 6,A=CBF7             |
|     | Ø,B=CBCØ          |          | 3,B=CBD8             |     | 6,B=CBFØ             |
|     | Ø,C=CBC1          |          | 3,C=CBD9             |     | 6,C=CBF1             |
|     | Ø,D=CBC2          |          | 3,D=CBDA             |     | 6,D=CBF2             |
|     | Ø,E=CBC3          |          | 3,E=CBDB             |     | 6,E=CBF3             |
|     | Ø,H=CBC4          |          | 3,H=CBDC             |     | 6,H=CBF4             |
|     | Ø,L=CBC5          |          | 3,L=CBDD             |     | 6,L=CBF5             |
|     | 1,[HL]=CBCE       |          | 4, <b>[HL]</b> -CBE6 |     | 7,[HL]=CBFE          |
|     | 1,[IX+d]=DDCB(d)C | E        | 4,[IX+d]=DDCB(d)E6   |     | 7,[IX+d]=DDCB(d)FE   |
|     | 1,[IY+d]=FDCB(d)C | E        | 4,[IY+d]=FDCB(d)E6   |     | 7,[IY+d]=FDCB(d)FE   |
|     | 1,A=CBCF          |          | 4,A=CBE7             |     | 7,A=CBFF             |
|     | 1,B=CBC8          |          | 4,B=CBEØ             |     | 7,B=CBF8             |
|     | 1,C=CBC9          |          | 4,C=CBE1             |     | 7,C=CBF9             |
|     | 1,D=CBCA          |          | 4,D=CBE2             |     | 7,D=CBFA             |
|     | 1,E=CBCB          |          | 4,E=CBE3             |     | 7,E=CBFB             |
|     | 1,H=CBCC          |          | 4,H=CBE4             |     | 7,H=CBFC             |
|     | 1,L=CBCD          |          | 4,H=CBE5             |     | 7,L=CBFD             |
|     | 2,[HL]=CBD6       |          | 5,[HL]=CBEE          |     |                      |
|     | 2,[IX+d]=DDCB(d)D |          | 5,[IX+d]=DDCB(d)EE   |     |                      |
|     | 2,[IY+d]=FDCB(d)D | 6        | 5,[IY+d]=FDCB(d)EE   |     |                      |
|     | 2,A=CBD7          |          | 5,A=CBEF             |     |                      |
|     | 2,B=CBDØ          |          | 5,B=CBE8             |     |                      |
|     | 2,C=CBD1          |          | 5,C=CBE9             |     |                      |
|     | 2,D=CBD2          |          | 5,D=CBEA             |     |                      |
|     | 2,E=CBD3          |          | 5,E=CBEB             |     |                      |
|     | 2,H=CBD4          |          | 5,H=CBEC             |     |                      |
|     | 2,L=CBD5          |          | 5,L=CBED             |     |                      |

# ■SET b, \_ \_ ■

The SET b,\_\_ instruction will set bit b in the designated register or memory location.

MODEL 64000

Z80

ASSEMBLER SUPPLEMENT

Symbolic Operation:  $s_b < --- 1$ 

Condition codes affected: none.

Example:

SET

b

Cont'd

| Label | Operation | Operand | Comment |
|-------|-----------|---------|---------|
|       | SET       | 4,D     |         |

This instruction will set bit 4 in register D.

ISLA mi

Shift Operand Left Arithmetic

## SYNTAX:

|       |           |         | Object     |
|-------|-----------|---------|------------|
| Label | Operation | Operand | Code (hex) |
|       | SLA       | [HL]    | CB26       |
|       | SLA       | [IX+d]  | DDCB(d)26  |
|       | SLA       | [IY+d]  | FDCB(d)26  |
|       | SLA       | А       | CB27       |
|       | SLA       | В       | CB2Ø       |
|       | SLA       | С       | CB21       |
|       | SLA       | D       | CB22       |
|       | SLA       | E       | CB23       |
|       | SLA       | Н       | CB24       |
|       | SLA       | L       | CB25       |

The SLA m instruction will perform an arithmetic shift left one bit position on the content of the designated register or memory location. The content of bit 7 will be copied into the carry flag bit in register F.

Symbolic Operation:  $\boxed{CY} < -- \boxed{7 < --- \emptyset} < --- \emptyset$ m

# SRA m

## Shift Operand Right Arithmetic

| SYNTAX: |           |         |                      |
|---------|-----------|---------|----------------------|
| Label   | Operation | Operand | Object<br>Code (hex) |
|         | SRA       | [HL]    | CB2E                 |
|         | SRA       | [IX+d]  | DDCB(d)2E            |
|         | SRA       | [IY+d]  | FDCB(d)2E            |
|         | SRA       | А       | CB2F                 |
|         | SRA       | В       | CB28                 |
|         | SRA       | С       | CB29                 |
|         | SRA       | D       | CB2A                 |
|         | SRA       | Е       | CB2B                 |
|         | SRA       | н       | CB2C                 |
|         | SRA       | L       | CB2D                 |

The SRA m instruction will perform an arithmetic shift right one bit position on the content of the designated register or memory location. The content of bit Ø will be copied into the carry flag bit in register F. The content of bit 7 will remain unchanged.



SRL m

Shift Operand Right Logical

.

| YNTAX: |           |         |                      |
|--------|-----------|---------|----------------------|
| Label  | Operation | Operand | Object<br>Code (hex) |
|        | SRL       | [HL]    | CB3E                 |
|        | SRL       | [IX+d]  | DDCB(d)3E            |
|        | SRL       | [IY+d]  | FDCB(d)3E            |
|        | SRL       | А       | CB3F                 |
|        | SRL       | В       | CB38                 |
|        | SRL       | С       | CB39                 |
|        | SRL       | D       | CB3A                 |
|        | SRL       | Е       | CB3B                 |
|        | SRL       | Н       | CB3C                 |
|        | SRL       | L       | CB3D                 |

The SRL m instruction will shift right one bit position the content of the designated register or memory location. The content of bit  $\emptyset$  will be copied into the carry flag bit in register F. Bit 7 will be reset.

SUB s

### Subtract Operand from Register A

| S | v | N   | т | ۸ | <b>X</b> : |
|---|---|-----|---|---|------------|
| 0 |   | 1 1 |   | ~ | Λ.         |

|       |           |         | Object                 |
|-------|-----------|---------|------------------------|
| Label | Operation | Operand | Code (hex)             |
|       | SUB       | (HL)    | 96                     |
|       | SUB       | [IX+d]  | DD96(d)                |
|       | SUB       | [IY+d]  | FD96(d)                |
|       | SUB       | A       | 97                     |
|       | SUB       | В       | 90                     |
|       | SUB       | С       | 91                     |
|       | SUB       | D       | 92                     |
|       | SUB       | Е       | 93                     |
|       | SUB       | Н       | 94                     |
|       | SUB       | L       | 95                     |
|       | SUB       | n       | <b>D6</b> ( <b>n</b> ) |
| 2     |           |         |                        |

The SUB s instruction will subtract the content of the designated register or memory location from the content of register A. The result of the operation will be stored in register A.

Symbolic Operation: A <--- A-s

Condition codes affected: CY, N, P/V, HC, Z, and S.

Example:

| Label | Operation | Operand | Comment |
|-------|-----------|---------|---------|
|       | SUB       | [HL]    |         |

This instruction will subtract the content of the memory location addressed by register pair HL from the content of register A. The result of the operation will be stored in register A.

Exclusive OR Operand and Register A

XOR s

|       |           |         | Object     |
|-------|-----------|---------|------------|
| Label | Operation | Operand | Code (hex) |
|       | XOR       | [HL]    | AE         |
|       | XOR       | [IX+d]  | DDAE(d)    |
|       | XOR       | [IY+d]  | FDAE(d)    |
|       | XOR       | А       | AF         |
|       | XOR       | В       | A8         |
|       | XOR       | С       | A9         |
|       | XOR       | D       | AA         |
|       | XOR       | E       | AB         |
|       | XOR       | Н       | AC         |
|       | XOR       | L       | AD         |
|       | XOR       | n       | EE(n)      |

The XOR s instruction will perform an exclusive-OR operation between the content of the designated register or memory location and the content of register A. The result of the operation will be stored in register A.

Symbolic Operation: A <--- A  $\oplus$  s

Condition codes affected: CY, N, P/V, HC, Z, and S.

Example:

| Label | Operation | Operand | Comment |
|-------|-----------|---------|---------|
|       | XOR       | С       |         |

This instruction will perform an exclusive-OR operation between the content of register C and the content of register A. The result of the operation will be stored in register A.

ASSEMBLER SUPPLEMENT Z80 ,

MODEL 64000