

# **Z-80** REFERENCE GUIDE



# **Z80** Reference Guide

# **Z80 REFERENCE GUIDE**

Alan Tully



MELBOURNE HOUSE PUBLISHERS

### © 1984 Alan Tully

All rights reserved. This book is copyright and no part may be copied or stored by electromagnetic, electronic, photographic, mechanical or any other means whatsoever except as provided by national law. All enquiries should be addressed to the publishers:

IN THE UNITED KINGDOM — Melbourne House (Publishers) Ltd Castle Yard House Castle Yard Richmond, TW10 6TF

IN THE UNITED STATES OF AMERICA — Melbourne House Software Inc. 347 Reedwood Drive Nashville TN 37217

IN AUSTRALIA — Melbourne House (Australia) Pty Ltd Level 2, 70 Park Street South Melbourne, Victoria 3205

Printed by The Whitefriars Press Ltd, Tonbridge, Kent

ISBN 0 86161 162 4

Edition: 7654321 Printing: FEDCBA987654321 Year: 90/898887868584

# CONTENTS

| CHAPTER 1 — Introduction                            | 1  |
|-----------------------------------------------------|----|
| CHAPTER 2 — Registers and Flags                     |    |
| CHAPTER 3 — Timing                                  | 17 |
| CHAPTER 4 — Instruction Groups                      |    |
| CHAPTER 5 — Z80 Machine Code Instructions           | 71 |
| CHAPTER 6 — Hints and Tips                          |    |
| APPENDIX A — ASCII Codes                            |    |
| APPENDIX B — ASCII/Hexadecimal/Decimal Conversion   |    |
| APPENDIX C — Quick Reference to Z80 Instruction Set |    |

# **CHAPTER 1**

# Introduction

This book is intended for users and prospective users of Z8Ø based micro-computers who already have some machine code programming experience and wish to extend their ability to write and modify programs. It is designed to be a convenient reference manual when specifying and coding new programs or debugging and modifying existing systems and programs.

The Zilog Z80 micro-processor was designed to be compatible with the Intel 8080 range of micro-processors. That is programs which run on Intel 8008 or 8080 processors will also run ont he Z80, although, as the Z80 provides additional facilities (instructions, registers, block input/output, etc.) it is extremely unlikely that a program written for the Z80 would run successfully on either the 8008 or 8080.

Chapter 2 describes the various registers provided in the Z8Ø and contains tables showing the effect various groups of transactions have on the Flag Register.

Chapter 3 gives brief details of the timing principles used in the Z80.

Chapter 4 contains a summary of the instructions, identified within a number of groups, each of which is related to specific functions or activities. This chapter is intended for the programmer who knows what is required of the program and needs to select the most appropriate instruction(s).

Chapter 5 gives full details of each individual instruction, together with its effect on the Flag Register, Timing and an example of all except the most simple instructions.

Chapter 6 contains various practical hints and tips based on the experience of a number of individual programmers.

The following tables are provided as appendices for easy reference: Appendix A — ASCII Codes.

- Appendix B ASCII Hexadecimal/Decimal Conversion.
- Appendix C Glossary of Terms and Abbreviations used in this book.

Appendix D — Table of Instructions by Operator Code, indexed.

Appendix E — Table of Instructions by mnemonics, indexed.

# CHAPTER 2 Registers and Flags

Z8Ø Registers can be considered under three different groups:

| Type of Register          | No. |
|---------------------------|-----|
| General Purpose Registers | 14  |
| Flag Register             | 1   |
| Special Purpose Registers | 6   |

## **General Purpose Registers**

Fourteen 8-Bit General Purpose Registers are provided, in two sets, identified as A, B, C, D, E, H and L plus A', B', C', D', E', H' and L'. Only one set, together with the equivalent Flag Register (F or F') can be in use at any one time. A "set" of registers may consist of either A and F or A' and F' plus either B, C, D, E, H and L or A', B', C', D', E', H' and L', i.e.:

| Set |    | Set |    | Set |    | Set |
|-----|----|-----|----|-----|----|-----|
| А   |    | А   |    | A'  |    | A'  |
| В   |    | B'  |    | В   |    | B'  |
| С   |    | C'  |    | С   |    | C'  |
| D   | or | D'  | or | D   | or | D'  |
| Е   |    | E'  |    | Е   |    | E'  |
| н   |    | H'  |    | н   |    | H'  |
| L   |    | L'  |    | L   |    | L'  |

Special Register Selection instructions provide the facility to switch between the two sets of registers, allowing extra storage in registers, which is much faster than using external memory, particularly if interrupts are likely to occur.

The A Register is the Accumulator and is the most frequently used of all the registers. The result of an Arithmetic or Logical operation, such as ADD, SBC, XOR, etc., is always stored in the Accumulator (Register A).

The remaining six General Purpose Registers in a set can be used to store either data or memory addresses and are frequently referred to as Register Pairs — BC, DE, HL. This enables a Register Pair to be used to store a complete memory address (up to 64K) or to provide double precision arithmetic facilities.

NOTE: The H and L registers were originally designated as such because one held the High (H) byte of a memory address and the other the Low (L) byte of the same memory address.



# Flag Register

Two Flag Registers are provided, one identified as the F Register, which is always associated with Register A, and the other identified as F', which is always associated with Register A'. The Flag (F) Register contains 8 Bits, as do the General Purpose Registers, but each individual Bit is used to identify conditions within the C.P.U. (Central Processing Unit) which exist after an instruction has been obeyed. The purpose of each Bit within the Flag Register is given on the next page.

**Bit Positions** 

76543210

| Bit | Flag            | Details                                                                                                                                                                                                                                                                                                                           |
|-----|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7   | Sign            | SET = 1 if the result of certain operations are negative, RESET = $\emptyset$ if the result is not negative. (See Table 2.1)                                                                                                                                                                                                      |
| 6   | Zero            | SET = 1 if the result of certain operations are zero, RESET = $\emptyset$ if the result is not zero. (See Table 2.1)                                                                                                                                                                                                              |
| 5   | _               | Not used.                                                                                                                                                                                                                                                                                                                         |
| 4   | Half Carry      | Indicates whether there has been a carry from Bit 3 (Add operations), borrow from Bit 4 (Subtract operations) or if the Low Order half byte of the result of an operation has a value greater than 1001, i.e. is invalid for Binary Coded Decimal purposes. (See Table 2.3)                                                       |
| 3   | —               | Not used.                                                                                                                                                                                                                                                                                                                         |
| 2   | Parity/Overflow | A dual-purpose flag. When used to<br>indicate Parity, it is SET = 1, for Even<br>Parity and RESET = $\emptyset$ for Odd Parity.<br>When used to indicate Overflow it is<br>SET = 1 if the result of an arithmetic<br>operation is too large to be contained<br>in 8 Bits (or 16 Bits for Two Byte<br>operations). (See Table 2.4) |
| 1   | Subtract        | SET = 1 if the instruction was a Subtract operation, RESET = $\emptyset$ if the instruction was an Add Operation.                                                                                                                                                                                                                 |
| Ø   | Carry           | Indicates whether there has been a<br>Carry or Borrow during Arithmetic<br>operations and can be SET or RESET<br>by certain Shift and Rotate<br>operations. (See Table 2.5)                                                                                                                                                       |

Table 2.1 — Sign Flag

| Instruction<br>Group<br>(See Ch.4)                     | Instructions                                                                               | Effect                                                                                      |
|--------------------------------------------------------|--------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------|
| Single Byte<br>Load Group                              | LD A,I                                                                                     | SET = 1 if the I Register is negative, otherwise RESET = $\emptyset$ .                      |
| Exchange,<br>Block<br>Transfer<br>and Search<br>Group. | CPI<br>CPIR<br>CPD<br>CPDR                                                                 | SET = 1 if the result is negative, otherwise RESET = $\emptyset$ .                          |
| Single Byte<br>Arithmetic<br>Group                     | ADC A,s<br>ADD A,s<br>AND s<br>CP s<br>DEC s<br>INC s<br>OR s<br>SBC A,s<br>SUB s<br>XOR s | SET = 1 if the result is negative, otherwise RESET = $\emptyset$ .                          |
| Two Byte<br>Arithmetic<br>Group.                       | ADC HL,rr<br>SBC HL,rr                                                                     | SET = 1 if the result is negative, otherwise RESET = $\emptyset$ .                          |
| General<br>Purpose<br>Arithmetic<br>and C.P.U.         | DAA                                                                                        | SET = 1 if the most significant bit of the Accumulator = 1, otherwise RESET = $\emptyset$ . |
| Control<br>Group                                       | NEG                                                                                        | SET = 1 if the result is negative, otherwise RESET = $\emptyset$ .                          |

b represents a specified Bit. r represents a specified Register. s represents a specified Operand.

rr represents a specified Register Pair.

| Rotate and<br>Shift<br>Group                   | RL s<br>RR s<br>RLC s<br>RRC s<br>SLA s<br>SRA s<br>SRL s<br>RLD<br>RRD | SET = 1 if the result is negative,<br>otherwise RESET = $\emptyset$ .<br>SET = 1 if the Accumulator is<br>negative after the shift,<br>otherwise RESET = $\emptyset$ . |
|------------------------------------------------|-------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit Set,<br>Reset and<br>Test (Flag)<br>Group. | BIT b,r                                                                 | Unknown                                                                                                                                                                |
| Input and<br>Output<br>Group                   | IN R,(C)<br>IND<br>INDR<br>INI<br>INIR<br>OTDR<br>OTIR<br>OUTD<br>OUTI  | SET = 1 if the input data is<br>negative, otherwise RESET = $\emptyset$ .<br>Unknown                                                                                   |

NOTES: b represents a specified Bit. r represents a specified Register. s represents a specified Operand. rr represents a specified Register Pair.

Table 2.2 — Zero Flag

| Instruction<br>Group<br>(See Ch. 4)                                | Instructions                                                                      | Effect                                                                                                                               |
|--------------------------------------------------------------------|-----------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------|
| Single Byte<br>Load Group                                          | LD A,I                                                                            | SET = 1 if I Register = $\emptyset$ , otherwise<br>RESET = $\emptyset$ .                                                             |
|                                                                    | LD A,R                                                                            | SET = 1 if the R Register = $\emptyset$ , otherwise RESET = $\emptyset$ .                                                            |
| Exchange,<br>Block<br>Transfer<br>and Search<br>Group              | CPD<br>CPI<br>CPDR<br>CPIR                                                        | SET = 1 if the contents of the<br>Accumulator = the contents of the<br>memory location whose address is<br>held in Register Pair HL. |
| Single Byte<br>Arithmetic<br>Group                                 | ADC A,s<br>ADD A,s<br>CP s<br>DEC s<br>INC s<br>OR s<br>SBC A,s<br>SUB s<br>XOR s | SET = 1 if the result = $\emptyset$ ,<br>otherwise RESET = $\emptyset$ .                                                             |
| Two Byte<br>Arithmetic<br>Group                                    | ADC HL,rr<br>SBC HL,rr                                                            | SET = 1 if the result = $\emptyset$ ,<br>otherwise RESET = $\emptyset$ .                                                             |
| General<br>Purpose<br>Arithmetic<br>and C.P.U.<br>Control<br>Group | DAA<br>NEG                                                                        | SET = 1 if the result = $\emptyset$ ,<br>otherwise RESET = $\emptyset$ .                                                             |

b represents a specified Bit. r represents a specified Register. s represents a specified Operand. rr represents a specified Register Pair.

| Rotate and<br>Shift<br>Group                  | RL s<br>RR s<br>RLD<br>RRD<br>RLC s<br>RRC s<br>SLA s<br>SRA s<br>SRL s        | SET = 1 if the result = $\emptyset$ ,<br>otherwise RESET = $\emptyset$ .                                                                                                                                                                                                                             |
|-----------------------------------------------|--------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit Set,<br>Reset and<br>Test (Flag)<br>Group | BIT b,r                                                                        | SET = 1 if the nominated Bit in<br>the specified Register = $\emptyset$ ,<br>otherwise RESET = $\emptyset$ .                                                                                                                                                                                         |
| Input and<br>Output<br>Group                  | IN r,(C)<br>IND<br>INI<br>INDR<br>INIR<br>OTDR<br>OTDR<br>OTIR<br>OUTD<br>OUTI | SET = 1 if the Input Data = $\emptyset$ ,<br>otherwise RESET = $\emptyset$ .<br>SET = 1 if the contents of Register<br>B - 1 = $\emptyset$ , otherwise RESET = $\emptyset$ .<br>SET = 1.<br>SET = 1.<br>SET = 1 if the contents of Register<br>B - 1 = $\emptyset$ , otherwise RESET = $\emptyset$ . |

NOTES: b represents a specified Bit. r represents a specified Register. s represents a specified Operand. rr represents a specified Register Pair.

# Table 2.3 — Half Carry Flag

| Instruction<br>Group                                  | Instructions                                             | Effect                                                                                       |
|-------------------------------------------------------|----------------------------------------------------------|----------------------------------------------------------------------------------------------|
| (See Ch. 4)                                           |                                                          |                                                                                              |
| Single Byte<br>Load Group                             | LD A,I<br>LD A,R                                         | RESET = Ø.                                                                                   |
| Exchange,<br>Block<br>Transfer<br>and Search<br>Group | CPD<br>CPI<br>CPDR<br>CPIR<br>LDD<br>LDI<br>LDDR<br>LDIR | SET = 1 if no Borrow from Bit 4,<br>otherwise RESET = $\emptyset$ .<br>RESET = $\emptyset$ . |
| Single Byte<br>Arithmetic<br>Group                    | ADC A,s<br>ADD A,s<br>INC s                              | SET = 1 if Carry from Bit 3, otherwise RESET = $\emptyset$ .                                 |
|                                                       | CP s<br>DEC s<br>SBC A,s<br>SUB s                        | SET = 1 if no Borrow from Bit 4, otherwise RESET = $\emptyset$                               |
|                                                       | AND s<br>OR s<br>XOR s                                   | SET = 1.                                                                                     |
| Two Byte<br>Arithmetic<br>Group                       | ADC HL,rr<br>ADD HL,rr<br>ADD IX,rr<br>ADD IY,rr         | SET = 1 if Carry from Bit 11, otherwise RESET = $\emptyset$ .                                |
|                                                       | SBC HL,rr                                                | SET = 1 if no Borrow from Bit 12, otherwise RESET = $\emptyset$ .                            |

NOTES:

b represents a specified Bit. r represents a specified Register. s represents a specified Operand. rr represents a specified Register Pair.

| General<br>Purpose<br>Arithmetic    | CCF                                                                                                   | Not affected.                                                    |
|-------------------------------------|-------------------------------------------------------------------------------------------------------|------------------------------------------------------------------|
|                                     | CPL                                                                                                   | SET = 1.                                                         |
| and C.P.U.<br>Control               | DAA                                                                                                   | Not known.                                                       |
| Group                               | NEG                                                                                                   | SET = 1 if no borrow from Bit 4, otherwise RESET = $\emptyset$ . |
|                                     | SCF                                                                                                   | RESET = Ø.                                                       |
| Rotate and<br>Shift<br>Group        | RL s<br>RR s<br>RLA<br>RLD<br>RRA<br>RRD<br>RLC s<br>RRC s<br>RLCA<br>RRCA<br>SLA s<br>SRA s<br>SRL s | RESET = Ø.                                                       |
| Bit Set,<br>Reset and<br>Test Group | BIT r,s                                                                                               | SET = 1.                                                         |
| Input and<br>Output<br>Group        | IN r,(C)<br>IND<br>INI<br>INDR<br>INIR<br>OTDR<br>OTIR<br>OUTD<br>OUTI                                | RESET = Ø.<br>Not known.                                         |

b represents a specified Bit. r represents a specified Register. s represents a specified Operand. rr represents a specified Register Pair.

| Instruction<br>Group<br>(See Ch. 4)                   | Instructions                                   | Effect                                                                                                |
|-------------------------------------------------------|------------------------------------------------|-------------------------------------------------------------------------------------------------------|
| Single Byte<br>Load Group                             | LD A,I<br>LD A,R                               | Set equal to the contents of IFF2.                                                                    |
| Exchange,<br>Block<br>Transfer<br>and Search<br>Group | CPD<br>CPI<br>CPDR<br>CPIR<br>LDD<br>LDI       | SET = 1 if the new contents of<br>Register Pair BC = $\emptyset$ , otherwise<br>RESET = $\emptyset$ . |
|                                                       | LDDR<br>LDIR                                   | RESET = Ø.                                                                                            |
| Single Byte<br>Arithmetic<br>Group                    | ADC A,s<br>ADD A,s<br>CP s<br>SBC A,s<br>SUB s | SET = 1 if Overflow, otherwise RESET = $\emptyset$ .                                                  |
|                                                       | AND s<br>OR s<br>XOR s                         | SET = 1 for Parity Even, RESET = $\emptyset$ for Parity Odd.                                          |
|                                                       | DEC s                                          | SET = 1 if operand was $8\emptyset$ (Hex.)<br>before decrement, otherwise<br>RESET = $\emptyset$ .    |
|                                                       | INC s                                          | SET = 1 if Operand was 7F(Hex.)<br>before increment, otherwise<br>RESET = $\emptyset$ .               |
| Two Byte<br>Arithmetic<br>Group                       | ADC HL,rr<br>SBC HL,rr                         | SET = 1 if Overflow, otherwise RESET = $\emptyset$ .                                                  |

# Table 2.4 — Parity/Overflow Flag

#### NOTES:

b represents a specified Bit. r represents a specified Register. s represents a specified Operand. rr represents a specified Register Pair.

| General<br>Purpose<br>Arithmetic<br>and C.P.U.<br>Control<br>Group | DAA<br>NEG                                                              | SET = 1 if the Accumulator is<br>Parity Even, otherwise RESET = $\emptyset$ .<br>SET = 1 if the Accumulator contents<br>= $8\emptyset$ (Hex.) before negate,<br>otherwise RESET = $\emptyset$ . |
|--------------------------------------------------------------------|-------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Rotate and<br>Shift<br>Group                                       | RL s<br>RR s<br>RLD<br>RRD<br>RLC s<br>RRC s<br>SLA s<br>SRA s<br>SRL s | SET = 1 for Parity Even, RESET<br>= Ø for Parity Odd.                                                                                                                                           |
| Bit Set,<br>Reset and<br>Test Group                                | BIT b,r                                                                 | Not known.                                                                                                                                                                                      |
| Input and<br>Output<br>Group                                       | IN r,(C)<br>IND<br>INI<br>INDR<br>INIR<br>OTDR<br>OTIR<br>OUTD<br>OUTI  | SET = 1 for Parity Even,<br>RESET = Ø for Parity Odd.<br>Not known                                                                                                                              |

represents a specified Bit. r represents a specified Register. s represents a specified Operand. rr represents a specified Register Pair.

|                                                                    | 1                                                                      |                                                                                                                                                                                                                                                                                                                                                             |
|--------------------------------------------------------------------|------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Instruction<br>Group<br>(See Ch. 4)                                | Instructions                                                           | Effect                                                                                                                                                                                                                                                                                                                                                      |
| Single Byte<br>Arithmetic<br>Group                                 | ADC A s<br>ADD A,s<br>CP s<br>SBC s<br>SUB s<br>AND s<br>OR s<br>XOR s | SET = 1 if Carry from Bit 7,<br>otherwise RESET = $\emptyset$ .<br>SET = 1 if no Borrow,<br>otherwise RESET = $\emptyset$ .<br>RESET = $\emptyset$ .                                                                                                                                                                                                        |
| Two Byte<br>Arithmetic<br>Group                                    | ADC HL,rr<br>ADD HL,rr<br>ADD IX,rr<br>ADD IY,rr<br>SBC HL,rr          | SET = 1 if Carry from Bit 15,<br>otherwise RESET = $\emptyset$ .<br>SET = 1 if no Borrow, otherwise<br>RESET = $\emptyset$ .                                                                                                                                                                                                                                |
| General<br>Purpose<br>Arithmetic<br>and C.P.U.<br>Control<br>Group | CCF<br>DAA<br>NEG<br>SCF                                               | SET = 1 if the C (Carry) Flag<br>= $\emptyset$ before the instruction,<br>otherwise RESET = $\emptyset$ .<br>SET = 1 if Binary Coded Decimal<br>(BCD) carry, otherwise RESET = $\emptyset$ .<br>SET = 1 if the contents of the<br>Accumulator = $\emptyset\emptyset(\text{Hex.})$ before<br>the instruction, otherwise<br>RESET = $\emptyset$ .<br>SET = 1. |

Table 2.5 — Carry Flag

b represents a specified Bit. r represents a specified Register. s represents a specified Operand

s represents a specified Operand. rr represents a specified Register Pair.

| SI | otate and<br>hift<br>roup | RL s<br>RLC s<br>SLA s          | Set from Bit 7 of the Operand.               |
|----|---------------------------|---------------------------------|----------------------------------------------|
|    |                           | RR s<br>RRC s<br>SRA s<br>SRL s | Set from Bit Ø of the Operand.               |
|    |                           | RLA<br>RLCA                     | Set from Bit 7 of the Accumulator.           |
|    |                           | RRA<br>RRCA                     | Set from Bit $\emptyset$ of the Accumulator. |

b represents a specified Bit. r represents a specified Register. s represents a specified Operand. rr represents a specified Register Pair.

# CHAPTER 3 Timing

The execution of instructions within the Z80 requires time which is measured in cycles. There are two types of cycle - the clock or time cycles, known as T Cycles, and a longer machine cycle, referred to as the M Cycle. T Cycles are always of the same length, and indicate the time taken for the 'clock' which is used to co-ordinate the actions of the Z80 to 'tick' once. They are the fundamental unit of time for the processor. Machine cycles are more abstract, each one representing the time taken for the Z80 to perform one particular action, such as fetching a program instruction, or writing a byte to memory. Because they can represent different actions, M Cycles can take varying amounts of time, from 3 to 6 T states (Note: this is simply another term for a T cycle). To find the actual time taken by an instruction, divide the number of T states taken by the clock rate being used. Thus, if an instruction taken 11 T states, and the Z80 is being run at 2 megahertz, the instruction will take 5.5 microseconds to execute. If a 2 MHz. clock is used to control the Z80 (as is assumed throughout this book), each T cycle will take Ø.5 microseconds to complete.

NOTE: A 4 MHz. clock will reduce the completion time of one T cycle to  $\emptyset.25$  microseconds but will not necessarily halve the time required to execute any given instruction, as it may not be possible to fetch instructions and data from the memory twice as fast as they were previously being fetched.

Since the time required to execute a given instruction, or follow a loop or subroutine, can be crucial to the design and efficient running of a program, full details of the number of M and T cycles, and the processing time in microseconds (assuming a 2 MHz. clock) are given for each individual instruction code in chapter 5. Note that some conditional instructions will not always take the same amount of time to execute. Where two execution times are shown, one is for the case in which the condition is met, and the other is for the case in which the condition is not met. For instance, the instruction JR Z,1000 will take 12 T states if the zero flag is set, and the jump is performed, whereas it will take 7 T states if the zero flag is not set, and the jump is not performed.

Each instruction can be considered as executing in three stages;

- fetch the instruction
- where appropriate, read from the memory
- where appropriate, write to the memory, e.g.



During stage 1 the instruction will be fetched and decoded, then any necessary processing carried out within the C.P.U. If the instruction requires a memory read, this will take place during stage 2 and, similarly, any memory write activity takes place during stage 3.

# **CHAPTER 4**

# **Instruction Groups**

Full details of each instruction are given in Chapter 5. However, for convenience of programming, these can be considered under a number of separate groups, each related to a specific function or activity. These Groups are:

- 1. Single Byte (8 Bit) Load Group.
- 2. Two Byte (16 Bit) Load Group.
- 3. Exchange, Block Transfer and Search Group.
- 4. Single Byte (8 Bit) Arithmetic Group.
- 5. Two Byte (16 Bit) Arithmetic Group.
- 6. Logical Group.
- 7. General Purpose Arithmetic and C.P.U. Control Group.
- 8. Rotate and Shift Group.
- 9. Bit Set, Reset and Test (Flag) Group.
- 10. Jump, Call (Subroutine) and Return Group.
- 11. Input and Output Group.

The following pages give a brief description of each transaction within each of these groups, each transaction being cross-referenced to full details in Chapter 5.

# 1. Single Byte (8 Bit) Load Group

| SOURCE                                                                                 | OBJECT                                                                               |                                                                                         |        |     | +L/    | AGS         |     |     | NO.<br>OF | M           | TIMING              | μSEC @          |                                                                                                                                                          | CH S                                                 |
|----------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------|--------|-----|--------|-------------|-----|-----|-----------|-------------|---------------------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------|
| SOURCE<br>CODE                                                                         | CODE (HEX)                                                                           | DECIMAL                                                                                 | s      | Z   | н      | P/V         | N   | С   |           | CYCLES      | STATES              | 2MHZ            | COMMENTS                                                                                                                                                 | REF                                                  |
| Dir                                                                                    | Dependent on<br>r(Bits 5 4 3) ar<br>01 ← r →← t <sup>1</sup> →<br>(Binary)           | value of<br>dr (B4s2 1.0)                                                               | N      | Ν   | N      | N           | Ν   | N   | 1         | 1           | 4                   | 2               | r and r'<br>represent<br>Registers A.B.<br>C.D.E.H or L.<br>r and r' Bit<br>Patternis<br>A 111<br>B 000<br>C - 001<br>D 010<br>E 011<br>H 100<br>L - 101 | 189<br>189<br>189<br>189<br>189<br>189<br>189        |
| Dr.n<br>r A                                                                            | 3E n                                                                                 | 062 n                                                                                   | N      | N   | N      | N           | N   | N   | 2         | 2           | 7                   | 3.5             |                                                                                                                                                          | 188                                                  |
| r - B<br>r = C<br>r - D<br>r - E<br>r = H<br>r = L                                     | 06 n<br><b>0E n</b><br>16 n<br>1E n<br>26 n<br>2E n                                  | 006 n<br>014 n<br>022 n<br>030 n<br>038 n<br>046 n                                      |        |     |        |             |     |     |           |             |                     |                 |                                                                                                                                                          | 188<br>188<br>188<br>188<br>188                      |
| .Dr. (HL)<br>r = A<br>r = B<br>r = C<br>r = D<br>r = E<br>r = H                        | 7E<br>46<br><b>4E</b><br>56<br>5E<br>66<br>6F                                        | 126<br>070<br>078<br>086<br>094<br>102                                                  | N      | Ν   | N      | N           | Ν   | N   | 1         | 2           | 7                   | 35              |                                                                                                                                                          | 191<br>191<br>191<br>191<br>191<br>191<br>191        |
| r = L<br>.D r, (IX + d)<br>r = A<br>r = B<br>r = C<br>r = D<br>r = E<br>r = H<br>r = L | DD 7E d<br>DD 46 d<br>DD 46 d<br>DD 56 d<br>DD 56 d<br>DD 5E d<br>DD 66 d<br>DD 66 d | 221 126 d<br>221 070 d<br>221 078 d<br>221 086 d<br>221 094 d<br>221 102 d<br>221 110 d | N      | и   | Ν      | Ν           | Ν   | N   | 3         | 5           | 19                  | 9.5             |                                                                                                                                                          | 190<br>190<br>190<br>190<br>190<br>190<br>190        |
| Dr. (IY + d)<br>r = A<br>r = B<br>r = C<br>r = D<br>r = E<br>r = H<br>r = L            | FD 7E d<br>FD 46 d<br>FD 4E d<br>FD 56 d<br>FD 5E d<br>FD 66 d<br>FD 6E d            | 253 126 d<br>253 070 d<br>253 078 d<br>253 086 d<br>253 094 d<br>253 102 d<br>253 110 d | Ν      | z   | N      | N           | Ν   | N   | 3         | 5           | 19                  | 95              |                                                                                                                                                          | 190<br>190<br>190<br>190<br>190<br>190<br>190        |
| D(HL).r<br>r = A<br>r = B<br>r = C<br>r = D<br>r = E<br>r = H<br>r = L                 | 77<br>70<br>71<br>72<br>73<br>74<br>75                                               | 119<br>112<br>113<br>114<br>115<br>116<br>117                                           | N      | N   | N      | N           | N   | N   | 1         | 2           | 7                   | 3.5             |                                                                                                                                                          | 212<br>212<br>212<br>212<br>212<br>212<br>212<br>212 |
| D (IX + d), r<br>r = A<br>r = B<br>r = C<br>r = D<br>r = E<br>r = H<br>r = L           | DD 77 d<br>DD 70 d<br>DD 71 d<br>DD 72 d<br>DD 73 d<br>DD 74 d<br>DD 75 d            | 221 119 d<br>221 112 d<br>221 113 d<br>221 114 d<br>221 115 d<br>221 116 d<br>221 117 d | N      | 2   | N      | N           | Ν   | N   | 3         | 5           | 19                  | 9.5             |                                                                                                                                                          | 215<br>215<br>215<br>215<br>215<br>215<br>215<br>215 |
| LD (IY + d), r<br>r = A<br>r = B<br>r = C<br>r = D<br>r = E<br>r = H<br>r = L          | FD 77 d<br>FD 70 d<br>FD 71 d<br>FD 72 d<br>FD 73 d<br>FD 74 d<br>FD 75 d            | 253 119 d<br>253 112 d<br>253 113 d<br>253 114 d<br>253 115 d<br>253 116 d<br>253 117 d | N      | N   | N      | N           | N   | N   | 3         | 5           | 19                  | 95              |                                                                                                                                                          | 215<br>215<br>215<br>215<br>215<br>215<br>215        |
| LD (HL), n<br>LD (IX + d), n<br>LD (IY + d), n                                         | 36 n<br>DD 36 d n<br>FD 36 d n                                                       | 054 n<br>221 054 d n<br>253 054 d n                                                     | N N N  | ZZZ | N N N  | N<br>N<br>N | NNN | ZZZ | 2 4 4     | 3<br>5<br>5 | 10<br>19<br>19<br>7 | 5<br>9.5<br>9.5 |                                                                                                                                                          | 21<br>21<br>21<br>18                                 |
| LD A. (BC)<br>LD A. (DE)                                                               | 0A<br>1A                                                                             | 010<br>026                                                                              | N<br>N | NN  | N<br>N | N<br>N      | N   | N   | 1         | 2           | 7                   | 3.5<br>3.5      |                                                                                                                                                          | 18                                                   |

#### SINGLE BYTE (8 BIT) LOAD GROUP TABLE (cont.)

|                |                      | FLAGS    |   |   |   |     |   | NO. | TIMING      |             |             |                |          |              |
|----------------|----------------------|----------|---|---|---|-----|---|-----|-------------|-------------|-------------|----------------|----------|--------------|
| SOURCE<br>CODE | OBJECT<br>CODE (HEX) | DECIMAL  | s | z | н | PIV | N | с   | OF<br>BYTES | M<br>CYCLES | T<br>STATES | µSEC @<br>2MHZ | COMMENTS | CH.5<br>REF. |
| LDA, (nn)      | 3Ann                 | 050 n n  | N | N | N | N   | N | N   | 3           | 4           | 13          | 6.5            |          | 185          |
| LD (BC), A     | 02                   | 002      | N | N | N | N   | N | N   | 1           | 2           | 7           | 3.5            |          | 210          |
| LD (DE), A     | 12                   | 018      | N | N | N | N   | N | N   | 1           | 2           | 7           | 3.5            |          | 210          |
| LD (nn), A     | 32 n n               | 050 n n  | N | N | N | N   | N | N   | 3           | 4           | 13          | 6.5            |          | 205          |
| LDA.I          | ED 57                | 237 087  | • | • | 0 | IFF | Ø | N   | 2           | 2           | 9           | 4.5            |          | 183          |
| LDA, R         | ED 5F                | 237 095  | • | • | 0 | IFF | 0 | N   | 2           | 2           | 9           | 4.5            |          | 184          |
| LDI, A         | ED47                 | 237 07 1 | N | N | N | N   | N | N   | 2           | 2           | 9           | 4.5            |          | 195          |
| LDR, A         | ED4F                 | 237 079  | N | N | N | N   | N | N   | 2           | 2           | 9           | 4.5            |          | 196          |

FLAG KEY: N - Not affected

0 - RESET = 0. 1 - SET = 1.

- Unknown.

- Affected according to the result

IFF - Content of Interrupt Flip Flop 2 copied into flag.

LD r.r'

Where:

Chapter 5, Page 189

r and r' represent any of the C.P.U. registers A, B, C, D, E, H or L.

This instruction simply loads the contents of the r' register into the r register, leaving the contents of the r' register untouched.

LD r,n

Chapter 5, Page 188

Chapter 5, Page 191

Where:

r represents any of the C.P.U. registers A, B, C, D, E, H or L. n is an 8-bit value, specified in the instruction.

This instruction loads the 8-bit value n into the register r.

LD r,(HL)

Where:

r represents any of the C.P.U. registers A, B, C, D, E, H or L.

This loads the contents of a memory location, identified by the contents of register pair HL, into the register r, leaving the contents of both the memory location and register pair HL untouched.

LD r,(IX + d)Where:

Chapter 5, Page 193

r represents any of the C.P.U. registers A, B, C, D, E, H or L. d is the displacement, in Bytes, from the location identified by the contents of Index Register IX.

This loads the contents of a memory location, identified by the contents of Index Register IX (modified by displacement d, which is specified in the instruction), into the register r, leaving the contents of both the memory location and Index Register IX untouched.

LD r, (IY + d)

Chapter 5, Page 193

Where:

r represents any of the C.P.U. registers, A, B, C, D, E, H or L.

d is the displacement, in Bytes, from the location indentified by the contents of the Index Register IY.

This loads the contents of a memory location, identified by the contents of Index Register IY (modified by displacement d, which is specified in the instruction), into the register r, leaving the contents of both the memory location and Index Register IY untouched.

LD (HL), r

Chapter 5, Page 212

Where:

r represents any of the C.P.U. registers, A, B, C, D, E, H or L.

This loads the contents of register r into a memory location which is identified by the contents of Register Pair HL. The contents of Register Pair HL remain untouched.

LD(IX + d),rWhere: Chapter 5, Page 215

r represents any of the C.P.U. registers A, B, C, D, E, H or L. d is the displacement, in Bytes, from the location identified by the contents of Index Register IX.

This loads the contents of register r into a memory location, which is identified by the contents of Index Register IX (modified by displacement d, which is specified in the instruction). The contents of Index Register IX remain unaltered.

LD (IY + d),r Where: Chapter 5, Page 215

r represents any of the C.P.U. registers A, B, C, D, E, H or L. d is the displacement, in Bytes, from the location identified by the contents of Index Register IY.

This loads the contents of register r into a memory location, which is identified by the contents of Index Register IY (modified by displacement d, which is specified in the instruction). The contents of Index Register IY remain unaltered.

LD (HL),n

Chapter 5, Page 211

Where:

n is an 8-bit value, specified in the instruction.

Loads the value n into a memory location identified by the contents of Register Pair HL.

LD(IX + d),n

Where:

n is an 8-bit value, specified in the instruction.

d is the displacement, in Bytes, from the location identified by the contents of Index Register IX.

Loads the value n into a memory location, identified by the contents of Index Register IX (modified by displacement d, which is specified in the instruction).

LD(IY + d),n

Chapter 5, Page 214

Where:

n is an 8-bit value, specified in the instruction.

d is the displacement, in Bytes, from the location identified by the contents of Index Register IY.

Loads the value n into a memory location, identified by the contents of Index Register IY (modified by displacement d, which is specified in the instruction).

LD A, (BC)

Chapter 5, Page 186

Loads the contents of a memory location, specified by the contents of Register Pair BC, into the Accumulator, leaving the contents of the memory location untouched.

LD A, (DE)

Chapter 5, Page 187

Loads the contents of a memory location, identified by the contents of Register Pair DE, into the Accumulator, leaving the contents of the memory location unaltered.

LD A, (nn)

Chapter 5, Page 185

Where:

nn is a spcific memory location, identified in two bytes of the instruction.

Loads the contents of the specified memory location, nn, into the Accumulator, leaving the contents of location nn unaltered.

# LD (BC), A

Chapter 5, Page 210

Loads the contents of the Accumulator into a memory location identified by the contents of Register Pair BC. The contents of the Accumulator remain unchanged.

# LD (DE),A

Chapter 5, Page 210

Loads the contents of the Accumulator into a memory location identified by the contents of Register Pair DE, leaving the contents of the Accumulator unchanged.

LD (nn),A

Chapter 5, Page 205

Where:

nn is a specific memory location, identified by two bytes of the instruction.

Loads the contents of the Accumulator into the memory location specified in the instruction, leaving the contents of the Accumulator unaltered.

## LD A,I

Chapter 5, Page 183

Loads the contents of the Interrupt Register I into the Accumulator, leaving the contents of Interrupt Register I untouched.

LD A,R Chapter 5, Page 184 Loads the contents of the Refresh Register 'R' into the Accumulator, leaving the contents of Refresh Register R unchanged.

LD I, A Chapter 5, Page 195 Loads the contents of the Accumulator into the Interrupt Register I, leaving the contents of the Accumulator unchanged.

LD R, A Chapter 5, Page 196 Loads the contents of the Accumulator into the Refresher Register R, leaving the contents of the Accumulator unaltered.

# 2. Two Byte (16 Bit) Load Group

| SOURCE<br>CODE                                                                                                                                         | OBJECT<br>CODE (HEX)                         |                                                          |   |   | FL | AGS |   |     | NO.         |             | TIMING      |                |          |                                 |
|--------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------|----------------------------------------------------------|---|---|----|-----|---|-----|-------------|-------------|-------------|----------------|----------|---------------------------------|
|                                                                                                                                                        |                                              | ) DECIMAL                                                | s | z | н  | P/V | N | с   | OF<br>BYTES | M<br>CYCLES | T<br>STATES | μSEC @<br>2MHZ | COMMENTS | CH.<br>REF                      |
| $ \begin{array}{l} \text{LD, dd, nn} \\ \text{dd} = \text{BC} \\ \text{dd} = \text{DE} \\ \text{dd} = \text{HL} \\ \text{dd} = \text{SP} \end{array} $ | 01 nn<br>11 nn<br>21 nn<br>31                | 001<br>017<br>033<br>049                                 | N | N | N  | N   | N | N   | 3           | 3           | 10          | 5              |          | 197<br>197<br>197<br>197        |
| LDIX, nn                                                                                                                                               | DD21nn                                       | 221033nn                                                 | N | N | N  | N   | N | N   | 4           | 4           | 14          | 7              |          | 198                             |
| LDIY, nn                                                                                                                                               | FD21nn                                       | 253 033 n n                                              | N | N | N  | N   | N | N   | 4           | 4           | 14          | 7              |          | 198                             |
| LD dd, (nn)<br>dd = BC<br>dd = DE<br>dd = HL<br>dd = SP                                                                                                | ED 4B nn<br>ED 5B nn<br>ED 6B nn<br>ED 7B nn | 237 075<br>237 091<br>237 107<br>237 123                 | N | И | N  | N   | N | Ν   | 4           | 6           | 20          | 10             |          | 199<br>199<br>199<br>199        |
| LDIX (nn)                                                                                                                                              | DD2Ann                                       | 221042nn                                                 | Ν | N | N  | N   | N | N   | 4           | 6           | 20          | 10             |          | 201                             |
| LDIY, (nn)                                                                                                                                             | FD2Ann                                       | 253042nn                                                 | N | N | N  | N   | N | N   | 4           | 6           | 20          | 10             |          | 201                             |
| LD (nn), dd $dd = BC$ $dd = DE$ $dd = HL$ $dd = SP$                                                                                                    | ED43nn<br>ED53nn<br>ED63nn<br>ED73nn         | 237 067 n n<br>237 083 n n<br>237 099 n n<br>237 115 n n | Ν | И | N  | N   | И | N   | 4           | 6           | 20          | 10             |          | 206<br>206<br>206<br>206        |
| LD (nn), IX                                                                                                                                            | DD 22 nn                                     | 221034nn                                                 | Ν | N | N  | N   | N | N   | 4           | 6           | 20          | 10             |          | 208                             |
| LD (nn), IY                                                                                                                                            | FD22nn                                       | 253 034 n n                                              | N | N | N  | N   | N | N   | 4           | 6           | 20          | 10             |          | 208                             |
| LD SP, HL                                                                                                                                              | F9                                           | 249                                                      | N | N | N  | N   | N | . N | 1           | 1           | 6           | 3              |          | 203                             |
| LD, SP, IX                                                                                                                                             | DD F9                                        | 221249                                                   | Ν | N | N  | N   | N | N   | 2           | 2           | 10          | 5              |          | 204                             |
| LD SP, IY                                                                                                                                              | FDF9                                         | 253249                                                   | N | N | N  | N   | N | N   | 2           | 2           | 10          | 5              |          | 204                             |
| PUSH rr<br>rr = AF<br>rr = BC<br>rr = DE<br>rr = HL                                                                                                    | F5<br>C5<br>D5<br>E5                         | 245<br>197<br>213<br>229                                 | Ν | N | N  | N   | N | N   | 1           | 3           | 11          | 5.5            |          | 246<br>246<br>246<br>246        |
| PUSHIX                                                                                                                                                 | DDE5                                         | 221 229                                                  | N | N | N  | N   | N | N   | 2           | 4           | 15          | 7.5            |          | 248                             |
| PUSHIY                                                                                                                                                 | FDE5                                         | 253 229                                                  | N | N | N  | N   | N | N   | 2           | .4          | 15          | 7.5            |          | 248                             |
| POP rr<br>rr = AF<br>rr = BC<br>rr = DE<br>rr = HL                                                                                                     | F1<br>C1<br>D1<br>E1                         | 241<br>193<br>209<br>225                                 | N | И | N  | N   | И | N   | 1           | 3           | 10          | 5              |          | 242<br>242<br>242<br>242<br>242 |
| POPIX                                                                                                                                                  | DDE1                                         | 221 225                                                  | N | N | N  | N   | N | N   | 2           | 4           | 14          | 7              |          | 244                             |
| POPIY                                                                                                                                                  | FDE1                                         | 253 225                                                  | N | N | N  | N   | N | N   | 2           | 4           | 14          | 7              |          | 244                             |

FLAG KEY N - Not affected. Ø - Reset = Ø. 1 - Set = 1.

Unknown

- Affected according to the result.

IFF - Content of Interrupt Flip Flop copied into flag

LD dd.nn

Where:

Chapter 5, Page 197

dd is any of the register pairs BC, DE, HL or SP. nn is a specific memory location.

Loads the memory location nn into the Register Pair dd.

LD IX.nn

Where:

nn is a specific memory location.

Loads the contents of memory location nn, specified in the instruction, into the Low Order byte of Index Register IX and the contents of memory location nn+1 into the High Order byte of Index Register IX.

Chapter 5, Page 198

Chapter 5, Page 198

Chapter 5, Page 199

nn is a specific memory location.

Loads the contents of the memory location nn, specified in the instruction, into the Low Order byte of Index Register IY and the contents of memory location nn+1 into the High Order byte of Index Register IY.

LD dd.(nn) Where:

> dd is any of the register pairs BC, DE, HL or SP. nn is a specific memory location.

Loads the contents of memory location nn (specified in the instruction) into the Low Order byte of the specified Register Pair and the contents of memory location nn+1 into the High Order byte of the same Register Pair. The contents of both memory locations remain unchanged.

LD IX.(nn)

Chapter 5, Page 201

Where:

nn is a specific memory location.

Loads the contents of memory location nn, which is specified in the instruction, into the Low Order byte of Index Register IX and the contents of memory location nn+1 into the High Order byte of the same register. The contents of both memory locations remain unchanged.

LD IY,(nn) Where:

Chapter 5, Page 201

Chapter 5, Page 206

nn is a specific memory location.

Loads the contents of memory location nn, specified in the instruction, into the Low Order byte of Index Register IY and the contents of memory location nn+1 into the High Order byte of that register, leaving the contents of both memory locations unaltered.

LD (nn).dd

Where:

nn is a specific memory location. dd is any one of the Register Pairs BC, DE, HL or SP.

IDIY.nn

Where:

Loads the contents of the Low Order byte of the nominated Register Pair into memory location nn, and the contents of the High Order byte of the same Register Pair into memory location nn+1. The contents of the Register Pair are not affected.

LD (nn),IX

Chapter 5, Page 208

Where:

nn is a specified memory location.

Loads the contents of the Low Order byte of Index Register IX into memory location nn and the contents of the High Order byte of the same register into memory location nn+1. The contents of Index Register IX remain unchanged.

LD (nn),IY

Chapter 5, Page 208

Where:

nn is a specified memory location.

Loads the contents of the Low Order byte of Index Register IY into memory location nn and the contents of the High Order byte of the same register into memory location nn+1. The Index Register contents are not changed.

LD SP,HL Chapter 5, Page 203 Loads the Stack Pointer with the contents of Register Pair HL, but does not change the contents of Register Pair HL.

LD SP,IX

Chapter 5, Page 204

Loads the Stack Pointer with the contents of Index Register IX, leaving the contents of that register unchanged.

LD SP,IY

Chapter 5, Page 204

Loads the Stack Pointer with the contents of Index register IY, leaving the contents of that register unaltered.

## PUSH rr

Chapter 5, Page 246

Where:

rr is any of the Register Pairs AF, BC, DE or HL.

Pushes the contents of the nominated Register Pair on to the memory stack. The Stack Pointer (SP), which contains the address of the top of the memory stack, is decremented and the High Order byte of the Register Pair is pushed out to that location. The Stack Pointer is again decremented and the Low Order byte of the Register Pair is pushed out to this new location. The contents of the Register Pair are not changed.

# PUSH IX

# Chapter 5, Page 248

Pushes the contents of the Index Register IX on to the memory stack. The Stack Pointer (SP), which contains the address of the top of the memory stack, is decremented and the High Order byte of register IX is pushed out to that location. The Stack Pointer is again decremented and the Low Order byte of Index Register IX is pushed out to the new location. The contents of Index Register IX are not affected.

PUSH IYChapter 5, Page 248Pushes the contents of the Index Register IY on to the memorystack. The Stack Pointer (SP), which contains the address of the top ofthe memory stack, is decremented and the High Order byte of IndexRegister IY is pushed out to that location. The Stack Pointer is againdecremented and the Low Order byte of Index Register IY pushed out tothat new location. The contents of Index Register IY remain unaltered

#### POP rr

#### Chapter 5, Page 242

Where:

#### rr is any of the register pairs AF, BC, DE or HL.

Loads the contents of the memory location identified by the Stack Pointer into the Low Order byte of the nominated Register Pair. The Stack Pointer is then incremented and the contents of the location now identified by the Stack Pointer is loaded into the High Order byte of the same Register Pair. Finally, the Stack Pointer is again incremented.

#### POP IX

## Chapter 5, Page 244

Loads the contents of the memory location identified by the Stack Pointer into the Low Order byte of Index Register IX. The Stack Pointer is then incremented and the contents of this new location loaded into the High Order byte of the IX Index Register. The Stack Pointer is once again incremented.

## POP IY

#### Chapter 5, Page 244

Loads the contents of the memory location identified by the Stack Pointer into the Low Order byte of Index Register IY. The Stack Pointer is then incremented and the contents of that location loaded into the High Order byte of Index Register IY. The Stack Pointer is then incremented once more.

# 3. Exchange, Block Transfer and Search Group

This group of instructions allows the exchange of 16 bit data blocks between register pairs in the same set of registers AND between the two sets of registers. It also includes instructions which transfer data from one block of memory to another and those which search a specified block of memory.

|                |                      |         |   |   | FL | AGS |   |   | NO.         |             | TIMING      |                |                          |              |
|----------------|----------------------|---------|---|---|----|-----|---|---|-------------|-------------|-------------|----------------|--------------------------|--------------|
| SOURCE<br>CODE | OBJECT<br>CODE (HEX) | DECIMAL | s | z | н  | P/V | N | с | OF<br>BYTES | M<br>CYCLES | T<br>STATES | µSEC @<br>2MHZ | COMMENTS                 | CH.5<br>REF. |
| EXDE, HL       | EB                   | 235     | N | N | N  | N   | N | N | 1           | 1           | 4           | 2              |                          | 149          |
| EX AF, AF      | 08                   | 008     | N | N | N  | N   | N | N | 1           | 1           | 4           | 2              |                          | 148          |
| EXX            | D9                   | 217     | N | N | N  | N   | N | N | 1           | 1           | 4           | 2              |                          | 154          |
| EX (SP), HL    | E3                   | 227     | N | N | N  | N   | N | N | 1           | 5           | 19          | 9.5            |                          | 150          |
| EX (SP), IX    | DD E3                | 221 227 | N | N | N  | N   | N | N | 2           | 6           | 23          | 11.5           |                          | 152          |
| EX (SP), IY    | FD E3                | 253 227 | N | N | N  | N   | N | N | 2           | 6           | 23          | 11.5           |                          | 152          |
| LDD            | ED A8                | 237 168 | N | N | 0  |     | 0 | N | 2           | 4           | 16          | 8              |                          | 217          |
| LDDR           | ED B8                | 237 184 | N | N | 0  | 0   | 0 | N | 2           | 5           | 21          | 11.5           | If BC ≠ Ø                | 219          |
|                |                      |         |   |   |    |     |   |   |             | 4           | 16          | 8              | If BC = Ø                |              |
| LDI            | ED A0                | 237 160 | Ν | N | Ø  | •   | 0 | N | 2           | 4           | 16          | 8              |                          | 221          |
| LDIR           | ED B0                | 237 176 | N | N | ø  | ø   | ø | N | 2           | 5           | 21          | 11.5           | If BC ≠ Ø                | 223          |
|                |                      |         |   |   | -  | -   | - |   | -           | 4           | 16          | 8              | If BC = Ø                |              |
| CPD            | ED A9                | 237 169 | • | • | •  | •   | 1 | N | 2           | 4           | 16          | 8              |                          | 129          |
| CPDR           | ED B9                | 237 185 | • | • | •  | •   | 1 | N | 2           | 5           | 21          | 10.5           | If BC ≠ Øand<br>A ≠ (HL) | 130          |
|                |                      |         |   |   |    |     |   |   |             | 4           | 16          | 8              | If BC = Ø or A<br>= (HL) |              |
| CPI            | ED A1                | 237 161 | • | • | •  | •   | 1 | N | 2           | 4           | 16          | 8              |                          | 132          |
| CPIR           | ED B1                | 237 177 | · | • | •  | •   | 1 | N | 2           | 5           | 21          | 10.5           | If BC ≠ Øand<br>A ≠ (HL) | 133          |
|                |                      |         |   |   |    |     |   |   |             | 4           | 16          | 8              | If BC = Ø or A<br>= (HL) |              |

FLAG KEY: N - Not affected. Ø - RESET = Ø. 1 - SET = 1. ? - Unknown.

- Affected according to the result

IFF - Content of Interrupt Flip Flop copied into flag.

### A. Exchange Instructions

FX DE,HL

Chapter 5, Page 149

Exchanges the contents of the DE and HL Register Pairs.

EX AF.AF'

Chapter 5, Page 148

Exchanges the contents of Register Pair AF with Register Pair AF'.

FXX

Chapter 5, Page 154

The contents of Register Pairs BC, DE and HL are exchanged with the contents of Register Pairs BC', DE', and HL' respectively.

# EX (SP),HL

Chapter 5, Page 150

The Low Order byte of Register Pair HL (i.e. the contents of Register L) is exchanged with the contents of the memory location whose address is contained in the Stack Pointer (SP). The High Order byte of Register Pair HL is exchanged with the contents of the next sequential memory location. The contents of the Stack Pointer are not changed.

## EX (SP),IX

Exchanges the Low Order byte of Index Register IX with the memory location whose address is contained in the Stack Pointer (SP) and the High Order byte of that register is exchanged with the next memory location. The contents of the Stack Pointer are not altered.

## EX (SP),IY

Chapter 5, Page 152

Chapter 5, Page 152

The contents of the Low Order byte of Index Register IY are exchanged with the memory location whose address is contained in the Stack Pointer (SP) and the High order byte of the register is exchanged with the next sequential memory location. The contents of the Stack Pointer are not changed.

## B. Transfer Instructions

LDD

Chapter 5, Page 217

Transfers one byte of date from the memory location whose address is held in register Pair HL to the memory location whose address is held in Register Pair DE. Register Pair BC is used as a byte counter. All three register pairs (BC, DE and HL) are then decremented.

## LDDR

Chapter 5, Page 219

Transfers one byte of data from the memory location whose address is held in Register Pair HL to the memory location whose address is held in Register Pair DE. Register Pair BC is used as a byte counter. The three Register Pairs are then decremented. If Register Pair BC becomes zero, then the instruction is terminated, otherwise the Program Counter is decremented by 2 and the instruction is repeated.

WARNING: If Register Pair BC is initially set to zero, the instruction will loop through all 64K of memory.

LDI

## Chapter 5, Page 221

Transfers one byte of data from the memory location whose address is held in Register Pair HL to the memory location whose address is held in Register Pair DE. Register Pair BC is used as a byte counter. Register Pairs DE and HL are then incremented while Register Pair BC is decremented.

## LDIR

## Chapter 5, Page 223

Transfers one byte of data from the memory location whose address is held in Register Pair HL to the memory location whose address is held in Register Pair DE. Register Pair BC is used as a byte counter. Register Pairs DE and HL are then incremented while Register Pair BC is decremented. If Register Pair BC becomes zero then the instruction is terminated, otherwise the Program Counter (PC) is decremented by 2 and the instruction is repeated.

WARNING: If Register Pair BC is initially set to zero, the instruction will loop through 64K of memory.

## 6. Search Instructions

## CPD

Chapter 5, Page 129 Compares the contents of the Accumulator with the contents of the memory location whose address is contained in Register Pair HL. If the contents match Condition Flag Z is set, otherwise it is reset. The contents of Register Pair HL are decremented as are the contents of Register Pair BC (used as a byte counter).

## CPDR

Chapter 5, Page 130 Compares the contents of the Accumulator with the contents of the memory location whose address is contained in Register Pair HL. If the contents match Condition Flag Z is set, otherwise it is reset. The contents of both Register Pair HL and Register Pair BC (used as a byte counter) are decremented. If either a match has been achieved, or the new value of Register Pair BC is zero, the instruction is terminated. If neither of these conditions are met the Program Counter (PC) is decremented by 2 and the instruction is repeated.

NOTE: Execution of this instruction increments the Program Counter (PC) by 2, therefore failure of the tests returns the Program Counter to the start of the CPDR instruction.

WARNING: If Register Pair BC is initialised to zero, this instruction will loop until either a match is found or it has cycled through all 64K of memory. It can therefore be used to test all 64K of memory.

### CPI

Chapter 5, Page 132

Compares the contents of the Accumulator with the contents of the memory location whose address is contained in Register Pair HL. If the conditons match Condition Flag Z is set, otherwise it is reset. The contents of Register Pair HL are incremented while the contents of Register Pair BC (used as a byte counter) are decremented.

### CPIR

Chapter 5, Page 133

Compares the contents of the Accumulator with the contents of the memory location whose address is contained in Register Pair HL. If the contents match, then Condition Flag Z is set, otherwise it is reset. The contents of Register Pair HL are incremented while the contents of Register Pair BC (used as a byte counter) are decremented. If either a match has been achieved, or the new value of Register Pair BC is zero. the instruction is terminated. If neither of these conditions are met the Program Counter (PC) is decremented by 2 and the instruction is repeated.

NOTE: Execution of this instruction increments the Program Counter (PC) by 2, therefore failure of both tests returns the Program Counter to the start of the CPIR instruction.

WARNING: If Register Pair BC is initialised to zero, this instruction will loop through until either a match is found or it has cycled through all 64K of memory. It can be used to test the entire memory.

# 4. Single Byte (8 Bit) Arithmetic Group

SINGLE BYTE (8 BIT) ARITHMETIC GROUP TABLE

| 000000               | 00/507               |                    |   | 1 | FL/ | AGS |     |     | NO.         |             | TIMING | USEC C         | 1                  | CF  |
|----------------------|----------------------|--------------------|---|---|-----|-----|-----|-----|-------------|-------------|--------|----------------|--------------------|-----|
| SOURCE<br>CODE       | OBJECT<br>CODE (HEX) | DECIMAL            | S | z | н   | P/V | N   | с   | OF<br>BYTES | M<br>CYCLES |        | µSEC @<br>2MHZ | COMMENTS           | RE  |
| NDC A, n             | CEn                  | 206                | • | • | •   | V   | 0   | •   | 2           | 2           | 7      | 3.5            | Adds with<br>Carry | 7   |
| DC A, r              |                      |                    |   |   | •   | v   | 0   |     | 1           | 1           | 4      | 2              | Adds with          |     |
| r = A                | 8F                   | 143                |   |   |     |     |     |     |             |             |        |                | Carry              | 7   |
| r = B                | 88                   | 136                |   |   |     |     |     |     |             |             |        |                |                    | 7   |
| r = C                | 89                   | 137                |   |   |     |     |     |     |             |             |        |                |                    | 7   |
| r = D                | 8A                   | 138                |   |   |     |     | 1   |     |             |             |        |                |                    | 7   |
| r = E                | 8B                   | 139                |   |   |     |     |     |     |             |             |        |                |                    | 7   |
| r = H                | 8C                   | 140                |   |   |     |     |     |     |             |             |        |                |                    | 7   |
| r = L                | 8D                   | 141                |   |   |     |     |     |     |             |             |        |                |                    | 7   |
| DCA, (HL)            | 8E                   | 142                | • |   | •   | V   | 0   | · · | 1           | 2           | 7      | 3.5            |                    | 7   |
| DC A, $(IX + d)$     | DD 8E d              | 221 142 d          |   |   | •   | V   | 0   |     | 3           | 5           | 19     | 9.5            |                    | 7   |
| DC A, (IY + d)       | FD 8E d              | 253 142 d          |   |   |     | v   | 0   |     | 3           | 5           | 19     | 9.5            |                    | 7   |
| DDA, n               | C6n                  | 198 n              |   |   |     | v   | ø   | 1 . | 2           | 2           | 7      | 3.5            |                    | 8   |
|                      | Con                  | 19611              |   |   |     |     | -   |     | -           |             | 4      | 2              |                    |     |
| DD A.r               | 07                   | 105                |   | 1 |     | V   | 0   |     | 1           | 1           | 4      | 2              |                    | 8   |
| r = A<br>r = B       | 87<br>80             | 135<br>128         |   |   |     |     |     |     |             |             |        |                |                    | 8   |
| r = C                | 81                   | 120                |   |   |     |     |     |     |             |             |        |                |                    | 8   |
| r = D                | 82                   | 130                |   |   |     |     |     |     |             |             |        |                |                    | 8   |
| r = E                | 83                   | 131                |   |   |     |     |     |     |             |             |        |                |                    | 8   |
| r = H                | 84                   | 132                |   |   |     |     |     |     |             |             |        |                |                    | 8   |
| r = L                | 85                   | 133                |   |   |     |     |     |     |             |             |        |                |                    | 8   |
|                      | 86                   | 134                |   |   |     | v   | 0   |     | 1           | 2           | 7      | 3.5            |                    | 8   |
| DDA. (HL)            |                      |                    |   |   |     |     |     |     |             | 1           | 19     | 9.5            |                    | 8   |
| DD A, (IX + d)       | DD 86 d              | 221 134 d          |   |   |     | V   | 0   |     | 3           | 5           |        |                |                    | -   |
| DDA, (IY + D)<br>ECd | FD 86 D              | 253 134 D          | • | • | •   | v   | 0   | •   | 3           | 5           | 19     | 9.5            |                    | 8   |
| d = A                | 3D                   | 061                |   |   |     |     |     |     | 1           | 1           | 4      | 2              |                    | 13  |
| d = B                | 05                   | 005                |   |   |     |     |     |     | 1           | 1           | 4      | 2              |                    | 13  |
| d = C                | OD                   | 013                |   |   |     |     |     |     | 1           | 1           | 4      | 2              |                    | 13  |
| d = D                | 15                   | 021                |   |   |     |     |     |     | 1           | 1           | 4      | 2              |                    | 13  |
| d = E                | 1D                   | 029                |   |   |     |     |     |     | 1           | 1           | 4      | 2              |                    | 13  |
| d = H                | 25                   | 037                |   |   |     |     |     |     | 1           | 1           | 4      | 2              |                    | 13  |
| d = L                | 2D                   | 045                |   |   |     |     |     |     | 1           | 1           | 4      | 2              |                    | 13  |
| EC (HL)              | 35                   | 053                | • | • | •   | V   | 1   | N   | 1           | 3           | 11     | 5.5            |                    | 14  |
| EC (IX + d)          | DD 35 d              | 221 053 d          |   | • | •   | v   | 1   | N   | 3           | 6           | 23     | 11.5           |                    | 14  |
| EC (IY + d)          | FD 35 d              | 253 053 d          |   |   |     | v   | li  | N   | 3           | 6           | 23     | 11.5           |                    | 14  |
|                      | FD 35 0              | 253 055 0          |   |   |     | v   | 0   | N   | 1           | 1           | 4      | 2              |                    |     |
| IC r                 | зс                   | 060                |   |   |     | v   | U   |     | 1           |             | 4      | ۲ (            |                    | 16  |
| r = A<br>r = B       | 04                   | 000                |   |   |     |     |     |     |             |             |        |                |                    | 16  |
| r = C                | 0C                   | 012                |   |   | -   |     |     |     |             |             |        |                |                    | 16  |
| r = D                | 14                   | 020                |   |   |     |     |     |     |             |             |        |                |                    | 16  |
| r = E                | 10                   | 028                |   |   |     |     |     |     |             |             |        |                |                    | 16  |
| r = H                | 24                   | 036                |   |   |     |     |     |     |             |             |        |                |                    | 16  |
| r = L                | 2C                   | 044                |   |   |     |     |     |     |             |             |        |                |                    | 16  |
| IC (HL)              | 34                   | 052                |   |   | •   | V   | 0   | N   | 1           | 3           | 11     | 5.5            | 1                  | 116 |
| IC (IX + d)          | DD 34 d              | 221 052 d          |   |   | •   | v   | ø   | N   | 3           | 6           | 23     | 11.5           |                    | 16  |
| IC (IY + d)          | FD 34 d              | 253 052 d          |   |   |     | v   | 0   | N   | 3           | 6           | 23     | 11.5           |                    | 16  |
| . ,                  |                      | 253 052 d<br>222 n |   |   |     | v   |     |     | 2           | 2           | 7      | 3.5            | Subtract with      | 3   |
| BC A, n              | DEn                  | 222n               |   |   |     | v   | 1   |     | 2           | 2           | l '    | 3.5            | Carry              | 3   |
| BC A, r              |                      |                    |   |   |     | v   | 1   |     | 1           | 1           | 4      | 2              | Subtract with      |     |
| r = A                | 9F                   | 159                |   |   |     | l v | · · |     | 1           | 1           | 1      | 6              | Carry              | 3   |
| r = B                | 98                   | 152                |   |   |     |     |     |     |             |             |        |                |                    | 3   |
| r = C                | 99                   | 153                |   |   |     |     |     |     |             |             |        |                |                    | 3   |
| r = D                | 9A                   | 154                |   |   |     |     |     |     |             |             |        |                |                    | 3   |
| r = E                | 9B                   | 155                |   |   |     |     |     |     |             |             |        |                |                    | 3   |
| r = H                | 90                   | 156                |   |   |     |     |     |     |             |             |        |                |                    | 3   |
| r = L                | 9D                   | 157                |   |   |     |     |     |     |             |             |        |                |                    | 3   |
| BCA, (HL)            | 9E                   | 158                |   |   |     | V   | 1   |     | 1           | 2           | 7      | 3.5            |                    | 30  |
|                      |                      |                    |   |   |     |     |     |     |             | -           |        |                |                    | 30  |
| 3C A, (IX + d)       | DD 9E d              | 221 158 d          |   |   |     | V   | 1   |     | 3           | 5           | 19     | 9.5            |                    |     |
| BCA, (IY + d)        | FD 9E d              | 253 158 d          |   | 1 |     | V   | 1   |     | 3           | 5           | 19     | 9.5            |                    | 30  |
| JBn                  | D6 n                 | 214 n              | • |   |     | V   | 1   | •   | 2           | 2           | 7      | 3.5            |                    | 33  |
| UBr                  |                      |                    | • |   |     | V   | 1   | •   | 1           | 1           | 4      | 2              |                    |     |
| r = A                | 97                   | 151                |   |   |     |     |     |     |             |             |        |                |                    | 3   |
| r = B                | 90                   | 144                |   |   |     |     |     |     |             |             |        |                |                    | 33  |
| r = C<br>r = D       | 91                   | 145                |   | 1 | 1   |     |     |     | 1           |             |        |                |                    | 3:  |
|                      | 92                   | 146                |   | 1 | 1   | 1   | 1   | 1   | 1           | 1           |        | 1              | 1                  | 1.3 |

#### SINGLE BYTE (8 BIT) ARITHMETIC GROUP TABLE (cont.)

|                         |                      |                   |   |     | FL  | AGS |   |   | NO.         |             | TIMING |                |          |                   |
|-------------------------|----------------------|-------------------|---|-----|-----|-----|---|---|-------------|-------------|--------|----------------|----------|-------------------|
| SOURCE<br>CODE          | OBJECT<br>CODE (HEX) | DECIMAL           | s | z   | н   | P/V | N | с | OF<br>BYTES | M<br>CYCLES |        | μSEC @<br>2MHZ | COMMENTS | CH.5<br>REF.      |
| r = E<br>r = H<br>r = L | 93<br>94<br>95       | 147<br>148<br>149 |   |     |     |     |   |   |             |             |        |                |          | 337<br>337<br>337 |
| SUB (HL)                | 96                   | 150               | · |     | · · | v   | 1 | · | 1           | 2           | 7      | 3.5            |          | 339               |
| SUB (IX + d)            | DD 96 d              | 221 150 d         | • | · · | · · | V   | 1 | • | 3           | 5           | 19     | 9.5            |          | 341               |
| SUB (IY + d)            | FD 96 d              | 253 150 d         | · | · · | · · | V   | 1 |   | 3           | 5           | 19     | 9.5            |          | 341               |

V - Contains the Overflow of the result (1 = Overflow)  $\emptyset$  - RESET =  $\emptyset$ 

-SET = 1- Unknown

- Affected according to the result

IFF - Content of Interrupt Flip Flop copied into flag.

ADC A.n

Where:

Chapter 5, Page 71

Chapter 5, Page 73

n is an 8-bit value, specified in the instruction. Adds the value n to the Accumulator, with Carry.

ADC A.r

Where:

r represents any one of the single byte registers A, B, C, D,

E. Hor L.

Adds the contents of the specified register to the Accumulator, with Carry.

ADC A.(HL)

Chapter 5, Page 76

Adds the contents of the memory location whose address is contained in Register Pair HL, to the Accumulator, with Carry.

ADC A, (IX + d)Where:

Chapter 5, Page 78

d is the displacement, in bytes, from the location identified by the contents of Index Register IX.

Adds, with Carry, the contents of a memory location, identified by the contents of Index Register IX (modified by displacement d, which is specified in the instruction) into the Accumulator. The contents of the memory location remain unaltered.

ADC A, (IY + d)

Chapter 5, Pages 00

Where:

d is the displacement, in bytes, from the location identified by the contents of Index Register IY.

Adds, with Carry, the contents of a memory location, identified by the contents of Index Register IY (modified by displacement d, which is specified in the instruction) into the Accumulator. The contents of the memory location remain unchanged.

ADD A,n

Where:

n is an 8-bit value, specified in the instruction.

Adds n to the Accumulator.

ADD A,r

Chapter 5, Page 83

Chapter 5, Page 82

Where:

r represents any one of the registers A, B, C, D, E, H or L.

Adds the contents of the register specified in the instruction to the Accumulator. The register remains unchanged.

ADD A,(HL)

Adds the contents of the memory location whose address is contained in Register Pair HL to the Accumulator. The contents of the location remain unaltered.

ADD A,(IX + d)

Chapter 5, Page 86

Chapter 5, Page 85

Where:

d is the displacement, in bytes, from the memory location identified by the contents of Index Register IX.

Adds the contents of a memory location, identified by the contents of Index Register IY (modified by displacement d, which is specified in the instruction) to the Accumulator. The contents of the memory location remain unchanged.

ADD A, (IY + d)

Chapter 5, Page 86

Where:

d is the displacement, in bytes, from the memory location identified by the contents of Index Register IY.

Adds the contents of a memory location, identified by the contents of Index Register IY (modified by displacement d, which is specified in the instruction) to the Accumulator. The contents of the memory location remain unaltered.

DEC r

Chapter 5, Page 138

Where:

r represents any one of the registers A, B, C, D, E, H or L.

Decrements the contents of the specified register by 1.

Chapter 5, Page 140

Chapter 5, Page 141

Decrements by 1 the contents of the memory location whose address is held in Register Pair HL.

d is the displacement, in bytes, from the memory location identified by the contents of Index Register IX.

Decrements by 1 the contents of a memory location, identified by the contents of Index Register IX (modified by displacement d, which is specified in the instruction).

DEC(IY + d)Where

> d is the displacement, in bytes, from the memory location identified by the contents of Index Register IY.

Decrements, by 1, the contents of a memory location, identified by the contents of Index Register IY (modified by displacement d, which is specified in the instruction).

INC r

Where:

r represents any one of the Registers A, B, C, D, E, H or L.

Increments the contents of the specified register by 1.

INC (HL)

Chapter 5, Page 165 Increments by 1 the contents of a memory location whose address is held in Register Pair HL.

INC(IX + d)

Where

Chapter 5, Page 166

d is the displacement, in bytes, from the memory location identified by the contents of Index Register IX.

Increments by 1 the contents of a memory location, identified by the contents of Index Register IX (modified by displacement d, which is specified in the instruction).

DEC(IX + d)Where:

DEC (HL)

Where:

Chapter 5, Page 141

Chapter 5, Page 162

Chapter 5. Page 166

INC(IY + d)Where:

> d is the displacement, in bytes, from the memory location identified by the contents of Index Register IY.

Increments, by 1, the contents of a memory location, identified by the contents of Index Register IY (modified by displacement d. which is specified in the instruction).

SBC A.n

Where:

Chapter 5, Page 301

n is a single byte integer, specified in the instruction.

Subtracts n, and the Carry Flag, from the Accumulator.

SBC A.r

Where

Chapter 5, Page 302

r represents any one of the registers A, B, C, D, E, H or L.

Subtracts the contents of the register specified in the instruction, and the Carry Flag, from the Accumulator. The contents of the register are not changed.

SBC A.(HL)

Chapter 5, Page 305 Subtracts the contents of the memory location whose address is contained in Register Pair HL, and the Carry Flag, from the Accumulator. The contents of Register Pair HL are unchanged.

SBC A, (IX + d)Where:

Chapter 5, Page 307

d is the displacement, in bytes, from the memory location identified by the contents of Index Register IX.

Subtracts the contents of the memory location, identified by the contents of Index Register IX (modified by displacement d, which is specified in the instruction), and the Carry Flag, from the Accumulator. The contents of the memory location and Index Register IX remain unchanged.

37

Chapter 5, Page 307

d is the displacement, in bytes, from the memory location identified by the contents of Index Register IY.

Subtracts the contents of the memory location, identified by the contents of Index Register IY (modified by displacement d, which is specified in the instruction), and the Carry Flag, from the Accumulator. The contents of the memory location and Index Register IY are not altered.

SUB n

Where:

n is a single byte integer, specified in the instruction.

Subtracts the integer n from the Accumulator.

SUB r

Where:

Chapter 5, Page 336

Chapter 5. Page 334

r represents any one of the registers A, B, C, D, E, H or L.

Subtracts the contents of the register specified in the instruction from the Accumulator. The contents of the register remain unchanged.

SUB (HL)

Chapter 5, Page 339

Chapter 5, Page 341

Chapter 5, Page 341

Subtracts the contents of the memory location whose address is contained in Register Pair HL from the Accumulator. The contents of the memory location are not changed.

SUB(IX+d)

Where:

d is the displacement, in bytes, from the memory location identified by the contents of Index Register IX.

Subtracts the contents of the memory location identified by the contents of Index Register IX (modified by displacement d, which is specified in the instruction) from the Accumulator. The contents of the memory location are unchanged.

SUB(IY+d)

Where:

d is the displacement, in bytes, from the memory location identified by the contents of Index Register IY.

Subtracts the contents of the memory location identified by the contents of Index Register IY (modified by displacement d, which is specified in the instruction) from the Accumulator. The contents of the memory location remain unaltered.

## SBC A, (IY + d)

Where:

gea.

# 5. Two Byte (16 Bit) Arithmetic Group

|                                                        |                                  |                                          |             |        | FL     | AGS   |        |        | NO.         |             | TIMING        |                |          |                          |
|--------------------------------------------------------|----------------------------------|------------------------------------------|-------------|--------|--------|-------|--------|--------|-------------|-------------|---------------|----------------|----------|--------------------------|
| SOURCE<br>CODE                                         | OBJECT<br>CODE (HEX)             | DECIMAL                                  | s           | z      | н      | P/V   | N      | с      | OF<br>BYTES | M<br>CYCLES | T<br>STATES   | μSEC @<br>2MHZ | COMMENTS | CH.:<br>REF              |
| ADC HL, ss<br>ss = BC<br>ss = DE<br>ss = HL<br>ss = SP | ED 4A<br>ED 5A<br>ED 6A<br>ED 7A | 237 74<br>237 90<br>237 106<br>237 122   | •           |        | ·      | •     | 0      |        | 2           | 4           | 15            | 7.5            |          | 80<br>80<br>80<br>80     |
| SBC HL, ss<br>ss = BC<br>ss = DE<br>ss = HL<br>ss = SP | ED 42<br>ED 52<br>ED 62<br>ED 72 | 237 66<br>237 82<br>237 98<br>237 114    | •           |        | •      |       | 1      | •      | 2           | 4           | 15            | 7.5            |          | 309<br>309<br>309<br>309 |
| ADD HL, ss                                             | 09<br>19<br>29<br>39             | 009<br>025<br>041<br>057                 | N           | N      |        | N     | 0      | •      | 1           | 3           | 11            | 5.5            |          | 88<br>88<br>88<br>88     |
| ADD IX.pp<br>pp = BC<br>pp = DE<br>pp = IX<br>pp = SP  | DD 09<br>DD 19<br>DD 29<br>DD 39 | 221 009<br>221 025<br>221 041<br>221 057 | N           | N      | •      | N     | Ø      | ·      | 2           | 4           | 15            | 7.5            |          | 89<br>90<br>91<br>93     |
| ADD IY, rr<br>rr = BC<br>rr = DE<br>rr = IY<br>rr = SP | FD 09<br>FD 19<br>FD 29<br>FD 39 | 253 009<br>253 025<br>253 041<br>253 057 | N           | N      | •      | z     | 0      | •      | 2           | 4           | 15            | 7.5            |          | 89<br>90<br>92<br>93     |
| DEC ss<br>ss = BC<br>ss = DE<br>ss = HL<br>ss = SP     | OB<br>IB<br>2B<br>3B             | 011<br>027<br>043<br>059                 | N           | И      | И      | z     | и      | N      | 1           | 1           | 6             | 3              |          | 143<br>143<br>143<br>143 |
| DECIX<br>DECIY<br>INCss                                | DD 2B<br>FD 2B                   | 221 043<br>253 043                       | N<br>N<br>N | 2 2 2  | Z Z Z  | z z z | 2 2 2  | ZZZ    | 2<br>2<br>1 | 2<br>2<br>1 | 10<br>10<br>6 | 5<br>5<br>3    |          | 144                      |
| ss = BC<br>ss = DE<br>ss = HL<br>ss = SP               | 03<br>13<br>23<br>33             | 003<br>019<br>035<br>051                 |             |        |        |       |        |        |             |             |               |                |          | 164<br>164<br>164<br>164 |
| INCIX<br>INCIY                                         | DD 23<br>FD 23                   | 221 035<br>253 035                       | N<br>N      | N<br>N | N<br>N | z z   | N<br>N | N<br>N | 2<br>2      | 2<br>2      | 10<br>10      | 5<br>5         |          | 168<br>168               |

#### TWO BYTE (16 BIT) ARITHMETIC GROUP TABLE

FLAG KEY: N - Not affected.

Ø - Reset = Ø.
 1 - Set = 1.

? - Unknown.

- Affected according to the result.

ADC HL,ss

Where:

ss represents any one of the Register Pairs BC, DE, HL or SP.

Adds the contents of the nominated Register Pair to the HL Register Pair with carry. If the nominated Register Pair is BC, DE or SP its contents remain unaltered.

## ADD HL, ss

Where:

ss represents any one of the Register Pairs BC, DE, HL or

SP.

Adds the contents of the nominated Register Pair to the HL register pair. If the nominated Register Pair is BC, DE or SP its contents are unaltered.

Chapter 5, Page 88

Chapter 5, Page 80

Allected according to t

39

Chapter 5, Page 89

pp represents any one of the Register Pairs BC, DE, SP, or Index Register IX.

Adds the contents of the nominated Register Pair to Index Register IX. If the Register pair BC, DE or SP is nominated, the contents of that Register Pair are unchanged.

Chapter 5, Page 89

Chapter 5, Page 309

Chapter 5, Page 143

Chapter 5, Page 144

Chapter 5, Page 144

Chapter 5, Page 164

Where:

rr represents any one of the Register Pairs BC, DE or SP, or Index Register IY.

Adds the contents of the nominated Register Pair to Index Register IY. If Register Pair BC, DE or SP is nominated, the contents of that Register Pair are not changed.

SBC HL.ss

Where:

ss represents any one of the Register Pairs BC, DE, HL, or SP.

Subtracts the contents of the nominated Register Pair plus the carry, from the HL Register Pair. If the nominated Register Pair is BC, DE, or SP, its contents remain unaltered.

DFC ss Where:

> ss represents any one of the Register Pairs BC, DE, HL or SP.

Decrements the contents of the nominated Register Pair.

DFC IX

Decrements Index Register IX.

DFC IY

Decrements Index Register IY.

INC ss Where:

> ss represents any one of the Register Pairs BC, DE, HL or SP.

Increments the contents of the nominated Register Pair.

INC IX

Chapter 5, Page 168 Increments the contents of Index Register IX.

INC IY

Chapter 5, Page 168 Increments the contents of Index Register IY.

# Where:

ADD IX. rr

ADD IY.rr

# 6. Logical Group

#### LOGICAL GROUP TABLE

|                |                      |            |   |   | FL | AGS |   |   | NO.         |             | TIMING      |                |          |            |
|----------------|----------------------|------------|---|---|----|-----|---|---|-------------|-------------|-------------|----------------|----------|------------|
| SOURCE<br>CODE | OBJECT<br>CODE (HEX) | DECIMAL    | s | z | н  | P/V | N | с | OF<br>BYTES | M<br>CYCLES | T<br>STATES | μSEC @<br>2MHZ | COMMENTS | CH.        |
| ANDn           | E6n                  | 230 n      | • | • | 1  | Р   | 0 | 0 | 2           | 2           | 7           | 3.5            |          | 94         |
| ANDr           |                      |            | · |   | 1  | Р   | 0 | 0 | 1           | 1           | 4           | 2              |          |            |
| r = A          | A7                   | 167        |   |   |    |     |   |   |             |             |             |                |          | 95<br>95   |
| r = B          | AO                   | 160        |   |   |    |     |   |   |             |             |             |                |          | 95         |
| r = C<br>r = D | A1<br>A2             | 161<br>162 |   |   |    |     |   |   |             |             |             |                |          | 95         |
| r = E          | A3                   | 163        |   |   |    |     |   |   |             |             |             |                |          | 95         |
| r = H          | A4                   | 164        |   |   |    |     |   |   |             |             |             |                |          | 95         |
| r = L          | A5                   | 165        |   |   |    |     |   |   |             |             |             |                |          | 95         |
| AND (HL)       | A6                   | 166        | • |   | 1  | Р   | 0 | 0 | 1           | 2           | 7           | 3.5            |          | 98         |
| AND (IX + d)   | DD A6 d              | 221 166 d  | • |   | 1  | Р   | 0 | 0 | 3           | 5           | 19          | 9.5            |          | 99         |
| AND (IY + d)   | FD A6 d              | 253 166 d  | • |   | 1  | Р   | 0 | 0 | 3           | 5           | 19          | 9.5            |          | 99         |
| CPn            | FEn                  | n          |   |   | •  | v   | 1 | • | 2           | 2           | 7           | 3.5            |          | 122        |
| CPr            |                      |            | • |   | •  | v   | 1 |   | 1           | 1           | 4           | 2              |          |            |
| r = A          | BF                   | 181        |   |   |    |     |   |   |             |             |             |                |          | 123        |
| r = B          | B8                   | 184        |   |   |    |     |   |   |             |             |             |                |          | 124        |
| r = C          | B9                   | 185        |   |   |    |     |   |   |             |             |             |                |          | 124<br>124 |
| r = D<br>r = E | BA<br>BB             | 186<br>187 |   |   |    |     |   |   |             |             |             |                |          | 124        |
| r = E          | BC                   | 188        |   |   |    |     |   |   |             |             |             |                |          | 124        |
| r = L          | BD                   | 189        |   |   |    |     |   |   |             |             |             |                |          | 124        |
| CP (HL)        | BE                   | 190        |   |   | •  | v   | 1 | • | 1           | 2           | 7           | 3.5            |          | 126        |
| CP (IX + d)    | DD BE d              | 221 190 d  | • | • | •  | v   | 1 | • | . 3         | 5           | 19          | 9.5            |          | 127        |
| CP(IY + d)     | FD BE d              | 253 190 d  | • | • | •  | v   | 1 | • | 3           | 5           | 19          | 9.5            |          | 127        |
| ORn            | F6 n                 | 246 n      | • | • | 1  | Р   | 0 | 0 | 2           | 2           | 7           | 3.5            |          | 227        |
| ORr            |                      |            | · |   | 1  | Р   | 0 | Ø | 1           | 1           | 4           | 2              |          |            |
| r = A          | B7                   | 183        |   |   |    |     |   |   |             |             |             |                |          | 229        |
| r = B          | BO                   | 176        |   |   |    |     |   |   |             |             |             |                |          | 229        |
| r = C<br>r = D | B1<br>B2             | 177<br>178 |   |   |    |     |   |   |             |             |             |                |          | 229        |
| r = E          | B3                   | 179        |   |   |    |     |   |   |             |             |             |                |          | 229        |
| r = H          | B4                   | 180        |   |   |    |     |   |   |             |             |             |                |          | 229        |
| r = L          | B5                   | 181        |   |   |    |     |   |   |             |             |             |                |          | 229        |
| OR (HL)        | B6                   | 182        | • | • | 1  | Р   | Ø | Ø | 1           | 2           | 7           | 3.5            |          | 231        |
| OR (IX + d)    | DD B6 d              | 221 182 d  | • |   | 1  | Р   | 0 | 0 | 3           | 5           | 19          | 9.5            |          | 233        |
| OR (IY + d)    | FD B6 d              | 253 182 d  | • |   | 1  | Р   | 0 | 0 | 3           | 5           | 19          | 9.5            |          | 233        |
| XOR n          | EEn                  | 238 n      | • |   | 1  | Р   | 0 | Ø | 2           | 2           | 7           | 3.5            |          | 343        |
| XORr           |                      |            | • |   | 1  | Р   | 0 | 0 | 1           | 1           | 4           | 2              |          | 0.00       |
| r = A          | AF                   | 175        |   |   |    |     |   |   |             |             |             |                |          | 345<br>347 |
| r = B<br>r = C | A8<br>A9             | 168<br>169 |   |   |    |     |   |   |             |             |             |                |          | 347        |
| r = D          | A9                   | 170        |   |   |    |     |   |   |             |             |             |                |          | 347        |
| r = E          | AB                   | 171        |   |   |    |     |   |   |             |             |             |                |          | 347        |
| r = H          | AC                   | 172        |   |   |    |     |   |   |             |             |             |                |          | 347        |
| r ≖ L          | AD                   | 173        |   |   |    |     |   |   |             |             |             |                |          | 347        |
| XOR (HL)       | AE                   | 174        | · | • | 1  | Р   | Ø | 0 | 1           | 2           | 7           | 3.5            |          | 349        |
| XOR (IX + d)   | DD AE d              | 221 174 d  | • |   | 1  | Р   | Ø | Ø | 3           | 5           | 19          | 9.5            |          | 351        |
| XOR (IY + d)   | FD AE d              | 253 174 d  | • |   | 1  | Р   | Ø | 0 | 3           | 5           | 19          | 9.5            |          | 351        |

FLAG KEY N - Not affected.

P - Contains the Parity of the result (1 = Parity Even).
 V - Contains the Overflow of the result (1 = Overflow).

0 - RESET = 0

- SET = 1. ?

- Unknown,

- Affected according to the result.

The AND instruction compares a specified operand, bit by bit, with the Accumulator. For each bit position, if either operand or Accumulator is Ø, then Ø is placed in that bit position in the Accumulator. If a bit position in both the operand and the Accumulator contain a 1, then a 1 is placed in that bit position in the Accumulator. The prime use of the AND instruction is to mask out unwanted bits in a field.

Chapter 5, Page 94

AND n

Where:

n represents a single byte, specified in the instruction.

Performs a Logical AND on the contents of the Accumulator with n and stores the result in the Accumulator.

AND r

Where:

Chapter 5, Page 95

r represents any one of the registers A, B, C, D, E, H or L

Performs a Logical AND on the contents of the Accumulator, with the contents of the nominated register, and stores the result in the Accumulator. The contents of that register are not changed.

AND (HL)

Chapter 5, Page 98

Performs a Logical AND on the contents of the Accumulator, with the contents of the memory location whose address is contained in Register Pair HL and stores the result in the Accumulator. The contents of the memory location are not changed.

AND (IX + d) Where:

Chapter 5, Page 99

d is the displacement, in bytes, from the memory location whose address is identified by the contents of Index Register IX.

Performs a Logical AND on the contents of the Accumulator with the contents of the memory location identified by the contents of Index Register IX (modified by displacement d, which is specified in the instruction) and stores the result in the Accumulator. The contents of the memory location remain unaltered.

AND(IY + d)

Chapter 5, Page 99

Where:

d is the displacement, in bytes, from the memory location whose address is identified by the contents of Index Register IY.

Performs a Logical AND on the contents of the Accumulator with the contents of the memory location identified by the contents of Index Register IY (modified by displacement d, which is specified in the instruction) and stores the result in the Accumulator. The contents of the memory location are not changed.

The COMPARE (CP) instructions compare a specified operand with the contents of the Accumulator and, if the two bytes are equal (i.e. a TRUE condition exists) then a Flag is set.

42

Chapter 5, Page 122

n is a single byte, specified in the instruction.

Compares the contents of the Accumulator with n. If a TRUE condition exists a Flag is set. The contents of the Accumulator are not altered.

CP A Chapter 5, Page 123 Compares the contents of the Accumulator with itself. Since a TRUE condition must always exist this is a convenient method of setting a particular Flag. The contents of the Accumulator are not changed.

CP r

Where:

r represents any one of the registers B, C, D, E, H or L.

Compares the contents of the Accumulator with the contents of the register nominated in the instruction. If a TRUE condition exists a Flag is set. The contents of the nominated register and the Accumulator remain unchanged.

CP (HL) Compares the contents of the Accumulator with the contents of a memory location whose address is held in Register Pair HL. If a TRUE condition exists, a Flag is set.

CP(IX + d)

Where:

d is the displacement, in bytes, from the memory location whose address is identified by the contents of Index Register IX.

Compares the contents of the Accumulator with the contents of the memory location identified by the contents of Index Register IX (modified by displacement d, which is specified in the instruction). If a TRUE condition exists, a Flag is set.

CP(IY + d)Where:

> d is the displacement, in bytes, from the memory location whose address is identified by the contents of Index Register IY.

Compares the contents of the Accumulator with the contents of the memory location identified by the contents of Index Register IY (modified by displacement d, which is specified in the instruction). If a TRUE condition exists, a Flag is set.

The OR instruction compares a specified operand, bit by bit, with the Accumulator. For each bit position, if either the operand or the Accumulator is 1, then the result is always 1. This instruction can be used to set any number of bits to 1.

CPn

Where:

Chapter 5, Page 126

Chapter 5, Page 127

Chapter 5, Page 127

Chapter 5, Page 124

Chapter 5. Page 227

Where:

n is a single byte, specified in the instruction.

Performs a Logical OR on the contents of the Accumulator with n and stores the result in the Accumulator.

OR r

Where:

r represents any one of the registers A, B, C, D, E, H or L.

Performs a Logical OR on the contents of the Accumulator with the contents of the nominated register and stores the result in the Accumulator. The contents of the register are not altered.

OR (HL)

Chapter 5, Page 231

Chapter 5, Page 233

Chapter 5, Page 229

Performs a Logical OR on the contents of the Accumulator with the contents of the memory location whose address is contained in Register Pair HL and stores the result in the Accumulator. The contents of the memory location remain unchanged.

OR(IX + d)Where:

d is the displacement, in bytes, from the memory location whose address is identified by the contents of Index Register IX.

Performs a Logical OR on the contents of the Accumulator with the contents of the memory location identified by the contents of Index Register IX (modified by displacement d, which is specified in the instruction) and stores the result in he Accumulator. The contents of the memory location are not changed.

OR(IY + d)Where: Chapter 5, Page 233

d is the displacement, in bytes, from the memory location whose address is identified by the contents of Index Register IY.

Performs a Logical OR on the contents of the Accumulator with the contents of the memory location identified by the contents of Index Register IY (modified by displacement d, which is specified in the instruction) and stores the result in the Accumulator. The contents of the memory location remain unchanged.

The Exclusive OR (XOR) instruction differs from the OR instruction in only one respect. It compares a specified operand, bit by bit, with the Accumulator and, as for the OR instruction, if either the operand or Accumulator value for a bit position is 1, then the result is 1. However, unlike the OR instruction, if BOTH operand and Accumulator have a value of 1 in the same bit position, then the result is 0.

OR n

Chapter 5, Page 343

Chapter 5, Page 345

Where:

n is a single byte, specified in the instruction.

Performs a Logical XOR on the contents of the Accumulator with n and stores the result in the Accumulator.

XOR r Where:

r represents any one of the registers A, B, C, D, E, H or L

Performs a Logical XOR on the contents of the Accumulator with the contents of the nominated register and stores the result in the Accumulator. If the nominated register is B, C, D, E, H or L the contents of that register are not changed.

XOR (HL)

Chapter 5, Page 349

Chapter 5, Page 351

Performs a Logical XOR on the contents of the Accumulator with the contents of the memory location whose address is contained in Register Pair HL and stores the result in the Accumulator. The contents of the memory location are not changed.

XOR(IX + d)

Where:

d is the displacement, in bytes, from the memory location whose address is identified by the contents of Index Register IX.

Performs a Logical XOR on the contents of the Accumulator with the contents of the memory location identified by the contents of Index Register IX (modified by displacement d, which is specified in the instruction) and stores the result in the Accumulator. The contents of the memory location remain unaltered.

XOR(IY + d)

Chapter 5, Page 351

Where:

d is the displacement, in bytes, from the memory location whose address is identified by the contents of Index Register IY.

Performs a Logical XOR on the contents of the Accumulator with the contents of the memory location identified by the contents of Index Register IY (modified by displacement d, which is specified in the instruction) and stores the result in the Accumulator. The contents of the memory location are not changed.

XOR n

# 7. General Purpose Arithmetic and C.P.U. Control Group

All instructions in this Group are implied addressing instructions.

|                |                      |         |   |     | FL/ | AGS |   |     | NO.         |             | TIMING      |                |          |              |
|----------------|----------------------|---------|---|-----|-----|-----|---|-----|-------------|-------------|-------------|----------------|----------|--------------|
| SOURCE<br>CODE | OBJECT<br>CODE (HEX) | DECIMAL | s | z   | н   | P/V | N | с   | OF<br>BYTES | M<br>CYCLES | T<br>STATES | µSEC @<br>2MHZ | COMMENTS | CH.5<br>REF. |
| CCF            | 3F                   | 063     | N | N   | ?   | N   | 0 | •   | 1           | 1           | 4           | 2              |          | 121          |
| CPL            | 2F                   | 047     | N | N   | 1   | N   | 1 | N   | 1           | 1           | 4           | 2              |          | 135          |
| DAA            | 27                   | 039     | • | •   | •   | P   | N | · · | 1           | 1           | 4           | 2              |          | 136          |
| DI             | F3                   | 243     | N | N   | N   | N   | N | N   | 1           | 1           | 4           | 2              |          | 145          |
| EI             | FB                   | 251     | Ν | N   | N   | N   | N | N   | 1           | 1           | 4           | 2              |          | 147          |
| HALT           | 76                   | 118     | N | N   | N   | N   | N | N   | 1           | 1           | 4           | 2              |          | 155          |
| IM Ø           | ED 46                | 237 070 | N | N   | N   | N   | N | N   | 2           | 2           | 8           | 4              |          | 156          |
| IM 1           | ED 56                | 237 086 | Ν | N   | N   | N   | N | N   | 2           | 2           | 8           | 4              |          | 157          |
| IM 2           | ED 5E                | 237 094 | N | N   | N   | N   | N | N   | 2           | 2           | 8           | 4              |          | 158          |
| NEG            | ED44                 | 237 068 | • |     | •   | V   | 1 |     | 2           | 2           | 8           | 4              |          | 225          |
| NOP            | 00                   | 000     | N | N   | N   | N   | N | N   | 1           | 1           | 4           | 2              |          | 226          |
| SCF            | 37                   | 055     | • | · · | Ø   | •   | 0 | 1   | 1           | 1           | 4           | 2              |          | 311          |

#### GENERAL PURPOSE ARITHMETIC AND C.P.U. CONTROL GROUP TABLE

FLAG KEY: N - Not affected.

P - Contains the Parity of the result (1 = Parity Even).

V – Contains the Overflow of the result (1 = Overflow).

0 - RESET = 0 1 - SET = 1

1 - SET = 1. ? - Unknown

Affected according to the result.

CCF

Chapter 5, Page 121

Complements (i.e. reverses) the Carry bit C in the Flag Register.

CPL

Chapter 5, Page 135

Complements the entire contents of the Accumulator.

DAA

Chapter 5, Page 136

The Accumulator is decimal adjusted to obtain the correct representation for Binary Coded Decimal (BCD).

DI

Chapter 5, Page 145

Resets the Interruptable Flip-Flops, disabling all maskable interrupts.

ΕI

Chapter 5, Page 147

Sets the Interruptable Flip-Flops, enabling the maskable interrupt function. The maskable interrupt function is not enabled until this instruction is completed.

## HALT

Chapter 5, Page 155

Suspends operation of the CPU, until interrupt or reset is received.

NOTE: The CPU NOP's so that memory refresh continues until interrupt or reset is received.

## IMØ

Chapter 5, Page 156

Sets the Interrupt Mode Ø allowing an interrupting device to insert an instruction code on the data bus for immediate execution. *IM 1* Chapter 5, Page 157 Sets Interrupt Mode 1, allowing the CPU to execute a restart to Location 00 38H (Hexadecimal) when an interrupt takes place.

IM 2 Chapter 5, Page 158 Sets Interrupt Mode 2. A memory address is placed on to the address bus, the lower order byte being supplied by the interrupting device and the higher order byte being the contents of the Interrupt Vector Register I. A CALL to this address is then executed by the CPU.

### NEG

Chapter 5, Page 225

Negates the contents of the Accumulator, equivalent to subtracting those contents from zero.

## NOP

Chapter 5, Page 226

No Operation. Nothing is done for one machine cycle.

SCF

Chapter 5, Page 311

Sets the Carry Flag C in the Flag Register F.

# 8. Rotate and Shift Group

#### ROTATE AND SHIFT GROUP TABLE

| SOURCE         | OBJECT         |                    |   |    |   | AGS |   |     | NO.<br>OF | м      | TIMING<br>T | µSEC @ |          | Сн  |
|----------------|----------------|--------------------|---|----|---|-----|---|-----|-----------|--------|-------------|--------|----------|-----|
|                | CODE (HEX)     | DECIMAL            | s | z  | н | P/V | Ν | С   |           | CYCLES | STATES      | 2MHZ   | COMMENTS | REI |
| Lr             |                |                    | • | •  | 0 | Р   | Ø | •   | 2         | 2      | 8           | 4      |          |     |
| r = A          | CB 17          | 203 023            |   |    |   |     |   |     |           |        |             |        |          | 263 |
| r = B          | CB 10          | 203016             |   |    |   |     |   |     |           |        |             |        |          | 26  |
| r = C          | CB 11          | 203017             |   |    |   |     |   |     |           |        |             |        |          | 26  |
| r = D          | CB 12          | 203018             |   |    |   |     |   |     |           |        |             |        |          | .26 |
| r = E          | CB 13          | 203019             |   |    |   |     |   |     |           |        |             |        |          | 26  |
| r = H          | CB 14          | 203 020            |   |    |   |     |   |     |           |        |             |        |          | 26  |
| r = L          | CB 15          | 203 02 1           |   |    |   |     |   |     |           |        |             |        |          | 26  |
| LA             | 17             | 023                | N | N  | Ø | N   | Ø |     | 1         | 1      | 4           | 2      |          | 26  |
| L(HL)          | CB 16          | 203 022            | • | •  | 0 | P   | Ø | •   | 2         | 4      | 15          | 7.5    |          | 26  |
| L (IX + d)     | DD CB d 16     | 221 203 d 022      | • | •  | 0 | P   | Ø | •   | 4         | 6      | 23          | 11.5   |          | 26  |
| L (IY + d)     | FD CB d 16     |                    |   |    | 0 | P   | Ø |     | 4         | 6      | 23          | 11.5   |          | 26  |
| LCr            | 10 00 0 10     | 200 200 0 022      |   |    | 0 | P   | 0 |     | 2         | 2      | 8           | 4      |          |     |
| r = A          | CB07           | 203 007            |   |    |   |     |   |     | -         | -      |             |        |          | 27  |
| r = B          | CB 00          | 203 000            |   |    |   |     |   |     |           |        |             |        |          | 27  |
| r = C          | CB01           | 203 00 1           |   |    |   |     |   |     |           |        |             |        |          | 27  |
| r = D          | CB 02          | 203 002            |   |    |   |     |   |     |           |        |             |        |          | 27  |
| r = E          | CB 03          | 203 003            |   |    |   |     |   |     |           |        |             |        |          | 27  |
| r = H          | CB04           | 203 004            |   |    |   |     |   |     |           |        |             |        |          | 27  |
| r = L          | CB 05          | 203 005            |   |    |   |     |   |     |           |        |             |        |          | 27  |
| LCA            | 07             | 07                 | N | N  | 0 | N   | 0 |     | 1         | 1      | 4           | 2      |          | 27  |
| LC (HL)        | CB 06          | 203 006            |   |    | 0 | P   | ø |     | 2         | 4      | 15          | 7.5    |          | 27  |
|                |                |                    |   |    |   | P   |   | 1 . |           |        |             |        |          |     |
| LC (IX + d)    | DD CB d 06     | 221 203 d 006      |   |    | 0 |     | 0 |     | 4         | 6      | 23          | 11.5   |          | 27  |
| LC (IY + d)    | FD CB d 06     | 253 203 d 006      | • |    | Ø | Р   | Ø |     | 4         | 6      | 23          | 11.5   |          | 27  |
| LD             | ED 6F          | 237 111            | • | •  | 0 | P   | Ø | N   | 2         | 5      | 18          | 9      |          | 27  |
| Rr             |                |                    | • |    | 0 | Р   | Ø | · · | 2         | 2      | 8           | 4      |          |     |
| r = A          | CB1F           | 203 03 1           |   |    |   |     |   |     |           |        |             |        |          | 28  |
| r = B          | CB 18          | 203 024            |   |    |   |     |   |     |           |        |             |        |          | 28  |
| r = C          | CB 19          | 203 025            |   |    |   |     |   |     |           |        |             |        |          | 28  |
| r = D          | CB1A           | 203 026            |   |    |   |     |   |     |           |        |             |        |          | 28  |
| r = E          | CB1B           | 203 027            |   |    |   |     |   |     |           |        |             |        |          | 28  |
| r = H          | CB1C           | 203 028            |   |    |   |     |   |     |           |        |             |        |          | 28  |
| r = L          | CB1D           | 203 029            |   |    |   |     |   |     |           |        |             |        |          | 28  |
| RA             | 1F             | 31                 | N | N  | 0 | N   | 0 | •   | 1         | 1      | 4           | 2      |          | 28  |
| R(HL)          | CB1E           | 203 030            | • |    | ø | Р   | ø | •   | 2         | 4      | 15          | 7.5    |          | 283 |
| R (IX + d)     | DD CB d IE     | 221 203 d 030      |   |    | 0 | Р   | 0 |     | 4         | 6      | 23          | 11.5   |          | 28  |
|                |                |                    |   |    | 0 | P   | õ |     | 4         | 6      | 23          | 11.5   |          | 28  |
| R (IY + d)     | FD CB d IE     | 253 203 d 030      |   |    | - | P   |   |     |           |        |             |        |          | 20  |
| RCr            | 00.05          | 000.045            |   |    | 0 | Р   | Ø |     | 2         | 2      | 8           | 4      |          | 289 |
| r = A          | CB 0F<br>CB 08 | 203 015<br>203 008 |   | 1  |   |     |   |     |           |        |             |        |          | 28  |
| r = B          |                |                    |   |    |   |     |   |     |           |        |             |        |          | 28  |
| r = C<br>r = D | CB 09<br>CB 0A | 203 009<br>203 010 |   |    |   |     |   |     |           |        |             |        |          | 28  |
| r=E            | CBOB           | 203010             |   |    |   |     |   |     |           |        |             |        |          | 28  |
| r=H            | CBOC           | 203012             |   |    |   |     |   |     |           |        |             |        |          | 28  |
| r=L            | CBOD           | 203012             |   |    |   |     |   |     |           |        |             |        |          | 28  |
| RCA            | OF             | 15                 | N | N  | 0 | N   | 0 |     | 1         | 1      | 4           | 2      |          | 29  |
| RCA<br>RC(HL)  | CBOE           | 203 0 1 4          |   |    | 0 | P   | Ø |     | 2         | 4      | 15          | 7.5    |          | 29  |
|                |                |                    |   |    |   |     |   |     |           |        |             |        |          |     |
| RC (IX + d)    |                | 221 203 d 014      |   |    | 0 | Р   | Ø |     | 4         | 6      | 23          | 11.5   |          | 29  |
| RC (IY + d)    |                | 253 203 d 014      | • |    | 0 | Р   | 0 | · · | 4         | 6      | 23          | 11.5   |          | 29  |
| RD DF          | ED67           | 237 103            | • | •  | 0 | P   | 0 | N   | 2         | 5      | 18          | 9      |          | 29  |
| Ar             |                |                    | • | •  | 0 | P   | 0 |     | 2         | 2      | 8           | 4      |          |     |
| r = A          | CB27           | 203 039            |   |    |   |     |   |     | 1         |        |             |        |          | 31  |
| r = B          | CB 20          | 203 032            |   |    |   |     |   |     | 1         |        |             |        |          | 31  |
| r = C          | CB21           | 203 033            |   |    |   |     |   |     | 1         |        |             |        |          | 31  |
| r = D          | CB 22          | 203 034            |   |    |   |     |   |     |           |        |             |        |          | 31  |
| r = E          | CB 23          | 203 035            |   |    |   |     |   |     |           |        |             |        |          | 31  |
| r = H          | CB 24          | 203 036            |   |    |   |     |   |     |           |        |             |        |          | 31  |
| r = L          | CB 25          | 203 037            |   |    |   |     |   |     |           |        |             |        |          | 31  |
| A(HL)          | CB 26          | 203 038            | • | ·  | Ø | Р   | Ø | · · | 2         | 4      | 15          | 7.5    |          | 31  |
| .A (IY + d)    | FD CB d 26     | 253 203 d 038      | : | 1: | 0 | Р   | 0 | :   | 4         | 6      | 23          | 11.5   |          |     |
| RAr<br>r=A     | CB 2F          | 203 047            |   | 1. | Ø | Р   | Ø |     | 2         | 2      | 8           | 4      |          | 32  |
| r = A<br>r = B | CB2F<br>CB28   | 203 047            |   |    |   |     |   |     |           |        |             |        |          | 32  |
| r = C          | CB 29          | 203 040            |   |    |   |     |   |     | 1         |        |             |        |          | 32  |
| r = C<br>r = D | CB29<br>CB2A   | 203 041            |   |    |   |     |   |     |           |        |             |        |          | 32  |
| 0              | CB2R<br>CB2B   | 203042             |   |    |   |     |   |     | 1         |        |             |        |          | 32  |
| r = F          |                |                    |   | 1  | 1 | 1   |   | 1   | 1         | 1      |             |        |          |     |
| r = E<br>r = H | CB2C           | 203044             |   |    |   |     |   |     |           |        |             |        |          | 32  |

#### **ROTATE AND SHIFT GROUP TABLE (cont.)**

|                                                             |                                                      |                                                                           |   |   | FL          | AGS         |             |          | NO.         |             | TIMING         |                     |          |                                                             |
|-------------------------------------------------------------|------------------------------------------------------|---------------------------------------------------------------------------|---|---|-------------|-------------|-------------|----------|-------------|-------------|----------------|---------------------|----------|-------------------------------------------------------------|
| SOURCE<br>CODE                                              | OBJECT<br>CODE (HEX)                                 | DECIMAL                                                                   | s | z | н           | P/V         | N           | с        | OF<br>BYTES | M<br>CYCLES | T<br>STATES    | µSEC @<br>2MHZ      | COMMENTS | CH.S<br>REF                                                 |
| SRA (HL)                                                    | CB 2E                                                | 203 046                                                                   |   | • | 0           | P           | 0           | •        | 2           | 4           | 15             | 7.5                 |          | 324                                                         |
| SRA (IX + d)                                                | DD CBd 2E                                            | 221 203 d 046                                                             | • | • | 0           | P           | 0           | •        | 4           | 6           | 23             | 11.5                |          | 326                                                         |
| SRA (IY + d)                                                | FD CBd 2E                                            | 253 203 d 046                                                             | • | • | 0           | P           | 0           | •        | 4           | 6           | 23             | 11.5                |          | 326                                                         |
| SRLr                                                        |                                                      |                                                                           | • |   | 0           | P           | 0           | •        | 2           | 2           | 8              | 4                   |          |                                                             |
| r = A<br>r = B<br>r = C<br>r = D<br>r = E<br>r = H<br>r = L | CB3F<br>CB38<br>CB39<br>CB3A<br>CB3B<br>CB3C<br>CB3D | 203 063<br>203 056<br>203 057<br>203 058<br>203 059<br>203 060<br>203 061 |   |   | ·           |             |             |          |             |             |                |                     |          | 328<br>328<br>328<br>328<br>328<br>328<br>328<br>328<br>328 |
| SRL (HL)<br>SRL (IX + d)<br>SRL (IY + d)                    | CB3E<br>DD CBd3E                                     | 203 062<br>221 203 d 062                                                  | • |   | 0<br>0<br>0 | P<br>P<br>P | 0<br>0<br>0 | ·<br>  · | 2<br>4<br>4 | 4<br>6<br>6 | 15<br>23<br>23 | 7.5<br>11.5<br>11.5 |          | 330<br>332<br>332                                           |

FLAG KEY: N - Not affected. P - Contains the Parity of the result (1 = Parity Even)

- Contains the Overflow of the result (1 = Overflow). n

- RESET = Ø - SET = 1.

- Unknown

- Affected according to the result

RI A

RL r

Where:

Where:

Chapter 5, Page 269

This has the same effect as RL A, although it is slightly faster. This instruction is included to retain compatibility with the Intel 8080 processor.

Chapter 5, Page 263

r represents any one of the registers A, B, C, D, E, H or L.

Rotates the contents of the nominated register Left. The content of Bit 7 is placed in the Carry Flag (C in the Flag Register) and the previous content of C is placed in Bit Ø of the nominated register.

RL (HL)

Chapter 5, Page 265

Rotates Left the contents of the memory location, whose address is contained in Register Pair HL. The content of Bit 7 is placed in the Carry Flag (C in the Flag Register) and the previous content of C is placed in Bit Ø of the memory location.

RL(IX + d)

Chapter 5, Page 267

Where: d is the displacement, in bytes, from the memory location whose address is identified by the contents of Index Register IX.

Rotates Left the contents of the memory location identified by the contents of Index Register IX (modified by displacement d, which is specified in the instruction). The content of Bit 7 is placed in the Carry Flag (C in the Flag Register) and the previous content of C is placed in Bit 0 of the memory location.

49

Chapter 5, Page 267

d is the displacement, in bytes, from the memory location whose address is identified by the contents of Index Register IY.

Rotates Left the contents of the memory location identified by the contents of Index Register IY (modified by displacement d, which is specified in the instruction). The content of Bit 7 is placed in the Carry Flag (C in the Flag Register) and the previous content of C is placed in Bit  $\emptyset$  of the memory location.

RLCA

Where:

This has the same effect as RLC A, although it is slightly faster. This instruction is included to retain compatibility with the Intel 8080 processor.

RLC r

Where:

r represents any one of the registers A, B, C, D, E, H or L.

Rotates Left the contents of the nominated register. Bit 7 is placed in both the Carry Flag (C in the Flag Register) and the Bit Ø position.

RLC (HL)

Chapter 5, Page 273

Rotates Left the contents of the memory location whose address is contained in Register Pair HL. The content of Bit 7 is placed in both the Carry Flag (C in the Flag Register) and the Bit Ø position.

RLC(IX + d)

Chapter 5, Page 275

Chapter 5, Page 275

Where:

d is the displacement, in bytes, from the memory location whose address is identified by the contents of Index Register IX.

Rotates Left the contents of the memory location whose address is identified by the contents of Index Register IX (modified by displacement d, which is specified in the instruction). The content of Bit 7 is placed in both the Carry Flag (C in the Flag Register) and the Bit  $\phi$  position.

RLC (IY + d) Where:

> d is the displacement, in bytes, from the memory location whose address is identified by the contents of Index Register IY.

## RL (IY + d)

Where:

Chapter 5, Page 277

Chapter 5, Page 271

Rotates Left the contents of the memory location whose address is identified by the contents of Index Register IY (modified by displacement d, which is specified in the instruction). The content of Bit 7 is placed in both the Carry Flag (C in the Flag Register) and the Bit Ø position.

RLD

Chapter 5, Page 279

Rotates the contents of a memory location, whose address is held in Register Pair HL, with the Accumulator as follows:

- 1. The Lower Order four bits (Ø to 3) of the memory location are placed in the Higher Order four bit positions (4 to 7) of the same location.
- 2. The Higher Order four bits (4 to 7) of the memory location are placed in the Lower Order four bits (0 to 3) of the Accumulator.
- 3. The Lower Order four bits (Ø to 3) of the Accumulator are placed in the Lower Order four bits of the memory location.
- NOTE: This instruction has no affect on the Higher Order four bits (4 to 7) of the Accumulator.

Chapter 5, Page 281

Where:

r represents any one of the registers A, B, C, D, E, H or L.

Rotates Right the contents of the register nominated in the instruction. The content of Bit  $\emptyset$  is placed in the Carry Flag (C in the Flag Register) while the previous content of C is placed in Bit 7 of the nominated register.

RRA

RR r

Where:

This has the same effect as RR A, although it is slightly faster. This instruction is included to retain compatibility with the Intel 8080 processor.

RR (HL)

Chapter 5, Page 283

Chapter 5, Page 287

Rotates Right the contents of the memory location whose address is contained in Register Pair HL. The content of Bit  $\emptyset$  is placed in the Carry Flag (C in the Flag Register) while the previous content of C is placed in Bit 7 of the memory location.

RR(IX+d)

Chapter 5, Page 285

Where:

d is the displacement, in bytes, from the memory location whose address is identified by the contents of Index Register IX.

Rotates Right the contents of the memory location identified by the contents of Index Register IX (modified by displacement d, which is

specified in the instruction). The content of Bit  $\emptyset$  is placed in the Carry Flag (C in the Flag Register) while the previous content of C is placed in Bit 7 of the memory location.

RR(IY + d)

Where:

d is the displacement, in bytes, from the memory location whose address is identified by the contents of Index Register IY.

Rotates Right the contents of the memory location identified by the contents of Index Register IY (modified by displacement d, which is specified in the instruction). The content of Bit Ø is placed in the Carry Flag (C in the Flag Register) while the previous content of C is placed in Bit 7 of the memory location.

RRCA

Where:

This has the same effect as RRC A, although it is slightly faster. This instruction is included to retain compatibility with the Intel 8080 processor.

RRC r

Where:

r represents any one of the registers A, B, C, D, E, H or L.

Rotates Right the contents of the register nominated in the instruction. The content of Bit Ø is placed in both the Carry Flag (C in the Flag Register) and Bit 7 of the nominated register.

## RRC (HL)

Chapter 5, Page 291

Rotates Right the contents of the memory location whose address is contained in Register Pair HL. The content of Bit 0 is placed in both the Carry Flag (C in the Flag Register) and Bit 7 of the memory location.

RRC(IX + d)

Chapter 5, Page 293

Where:

d is the displacement, in bytes, from the memory location whose address is identified by the contents of Index Register IX.

Rotates Right the contents of the memory location whose address is identified by the contents of Index Register IX (modified by displacement d, which is specified in the instruction). The content of Bit Ø is placed in both the Carry Flag (C in the Flag Register) and Bit 7 of the memory location.

Chapter 5, Page 285

Chapter 5, Page 295

Chapter 5, Page 289

Chapter 5, Page 293

RRC (IY + d) Where:

d is the displacement, in bytes, from the memory location whose address is identified by the contents of Index Register IY.

Rotates Right the contents of the memory location whose address is identified by the contents of Index Register IY (modified by displacement d, which is specified in the instruction). The content of Bit  $\varphi$  is placed in both the Carry Flag (C in the Flag Register) and Bit 7 of the memory location.

RRD

Chapter 5, Page 297

Rotates the contents of a memory location, whose address is held in Register Pair HL, as follows:

- 1. Places the Lower Order four bits (Ø to 3) of the memory location into the Lower Order four bit positions of the Accumulator.
- 2. Places the previous contents of the Lower Order four bits (Ø to 3) of the Accumulator into the Higher Order four bits (4 to 7) of the memory location.
- 3. Places the original contents of the Higher Order four bits (4 to 7) of the memory location into the Lower Order four bits (Ø to 3) of the same location.
- NOTE: This instruction has no effect on the Higher Order four bits (4 to 7) of the Accumulator.

SLAr

Chapter 5, Page 316

Where:

r represents any one of the registers A, B, C, D, E, H or L.

Shifts Left the contents of the register nominated in the instruction as follows:

- 1. Bit Ø is Reset to Ø.
- 2. Bits 1 to 6 are Shifted Left one position.
- 3. The previous content of Bit 7 is placed in the Carry Flag (C in the Flag Register).

SLA (HL)

Chapter 5, Page 318

Shifts Left the contents of the memory location whose address is held in Register Pair HL as follows:

- 1. Bit Ø is Reset to Ø.
- 2. Bits 1 to 6 are Shifted Left one position.
- 3. The previous content of Bit 7 is placed in the Carry Flag (C in the Flag Register).

SLA(IX + d)

Chapter 5, Page 320

Where:

d is the displacement, in bytes from the memory location whose address is identified by the contents of Index Register IX.

Shifts Left the contents of the memory location whose address is identified by the contents of Index Register IX (modified by displacement d, which is specified in the instruction), as follows:

- 1. Bit Ø is Reset to Ø.
- 2. Bits 1 to 6 are Shifted Left one position.
- 3. The previous content of Bit 7 is placed in the Carry Flag (C in the Flag Register).

SLA (IY + d) Where:

Chapter 5, Page 320

d is the displacement, in bytes from the memory location whose address is identified by the contents of Index Register IY.

Shifts Left the contents of the memory location whose address is identified by the contents of Index Register IY (modified by displacement d, which is specified in the instruction), as follows:

- 1. Bit Ø is Reset to Ø.
- 2. Bits 1 to 6 are Shifted Left one position.
- 3. The previous content of Bit 7 is placed in the Carry Flag (C in the Flag Register).

SRA r

Chapter 5, Page 322

Where:

r represents any one of the registers A, B, C, D, E, H or L.

Shifts Right the contents of the register nominated in the instruction as follows:

- 1. The contents of Bit positions 1 to 7 are Shifted Right one position.
- 2. The original content of Bit position 7 remains unaltered.
- 3. The original content of Bit position Ø is placed in the Carry flag (C in the Flag Register).

# SRA (HL)

Chapter 5, Page 324

Shifts Right the contents of the memory location whose address is held in Register Pair HL as follows:

- 1. The contents of Bit positions 1 to 7 are Shifted Right one position.
- 2. The original content of Bit position 7 remains unchanged.
- 3. The original content of Bit position Ø is placed in the Carry Flag (C in the Flag Register).

SRA(IX + d)

Chapter 5, Page 326

Where:

d is the displacement, in bytes, from the memory location whose address is identified by the contents of Index Register IX.

Shifts Right the contents of the memory location whose address is identified by the contents of Register IX (modified by displacement d, which is specified in the instruction) as follows:

- 1. The contents of Bit positions 1 to 7 are Shifted Right one position.
- 2. The original content of Bit position 7 remains unaltered.
- 3. The original content of Bit position Ø is placed in the Carry Flag (C in the Flag Register).

SRA(IY + d)

Chapter 5, Page 326

Where:

d is the displacement, in bytes, from the memory location whose address is identified by the contents of Index Register IY.

Shifts Right the contents of the memory location whose address is identified by the contents of Index Register IY (modified by displacement d, which is specified in the instruction) as follows:

- 1. The contents of Bit positions 1 to 7 are Shifted Right one position.
- 2. The original content of Bit position 7 remains unchanged.
- 3. The original content of Bit position Ø is placed in the Carry Flag (C in the Flag Register).

SRL r

Chapter 5, Page 328

Where:

r represents any one of the registers A, B, C, D, E, H or L.

Shifts Right the contents of the register nominated in the instruction as follows:

- 1. The contents of Bit positions 1 to 7 are Shifted Right one position.
- 2. Bit position 7 is Reset to Ø.
- 3. The original content of Bit position Ø is placed in the Carry Flag (C in the Flag Register).

SRL (HL)

Chapter 5, Page 330

Shifts Right the contents of the memory location whose address is held in Register Pair HL as follows:

- 1. The contents of Bit positions 1 to 7 are Shifted Right one position.
- 2. Bit position 7 is Reset to Ø.
- 3. The original content of Bit position Ø is placed in the Carry Flag (C in the Flag Register).

SRL(IX + d)

Chapter 5, Page 332

Where:

d is the displacement, in bytes, from the memory location whose address is identified by the contents of Index Register IX.

Shifts Right the contents of the memory location whose address is identified by the contents of Index Register IX (modified by displacement d, which is specified in the instruction) as follows:

- 1. The contents of Bit positions 1 to 7 are Shifted Right one position.
- 2. Bit position 7 is Reset to Ø.
- 3. The original content of Bit position Ø is placed in the Carry Flag (C in the Flag Register).

SRL(IY + d)

Chapter 5, Page 332

Where:

d is the displacement, in bytes, from the memory location whose address is identified by the contents of Index Register IY.

Shifts Right the contents of the memory location whose address is identified by the contents of Index Register IY (modified by displacement d, which is specified in the instruction) as follows:

- 1. The contents of Bit positions 1 to 7 are Shifted Right one position.
- 2. Bit position 7 is Reset to Ø.
- 3. The original content of Bit position Ø is placed in the Carry Flag (C in the Flag Register).

## 9. Bit Set, Reset and Test (Flag) Group.

These instructions either Set, Reset or Test one of the Bits in a specified CPU register or, alternatively, a particular memory location.

| 0000005                                   | 00.505               |                    |   |   | FL | AGS |   |   | NO.         |             | TIMING      | 050            |          | 0          |
|-------------------------------------------|----------------------|--------------------|---|---|----|-----|---|---|-------------|-------------|-------------|----------------|----------|------------|
| SOURCE<br>CODE                            | OBJECT<br>CODE (HEX) | DECIMAL            | s | z | н  | P/V | N | с | OF<br>BYTES | M<br>CYCLES | T<br>STATES | µSEC @<br>2MHZ | COMMENTS | CH.<br>REI |
| BIT b, r                                  | 1                    |                    | ? | • | 1  | 2   | 0 | N | 2           | 2           | 8           | 4              |          |            |
| = A.b = Ø                                 | CB 47                | 203071             |   |   |    |     |   |   | -           |             |             |                |          | 101        |
| b = 1                                     | CB4F                 | 203 079            |   |   |    |     |   |   |             |             |             |                |          | 101        |
| b = 2                                     | CB 57                | 203 087            |   |   |    |     |   |   |             |             |             |                |          | 101        |
| b = 3                                     | CB 5F                | 203 095            |   |   |    |     |   |   |             |             |             |                |          | 101        |
| b = 4                                     | CB 67                | 203 103            |   |   |    |     |   |   |             |             |             |                |          | 101        |
| b = 5                                     | CB6F                 | 203 1 1 1          |   |   |    |     |   |   |             |             |             |                |          | 101        |
| b = 6                                     | CB77                 | 203 1 1 9          |   |   |    |     |   |   |             |             |             |                |          | 101        |
| b = 7                                     | CB7F                 | 203 127            |   |   |    |     |   |   |             |             |             |                |          | 101        |
| = B, b = 0                                | CB 40                | 203 064            |   |   |    |     |   |   |             |             |             |                |          | 101        |
| b = 1                                     | CB 48                | 203072             |   |   |    |     |   |   |             |             |             |                |          | 101        |
| b = 2                                     | CB 50                | 203 080            |   |   |    |     |   |   |             |             |             |                |          | 10         |
| b = 3                                     | CB 58                | 203 088            |   | 1 |    |     |   |   |             |             |             |                |          | 10         |
| b = 4                                     | CB 60                | 203 096            |   |   |    |     |   |   |             |             |             |                |          | 10         |
| b = 5                                     | CB 68                | 203 104            |   |   |    |     |   |   |             |             |             |                |          | 101        |
| b = 6                                     | CB 70                | 203 112            |   |   |    |     |   |   |             |             |             |                |          | 10         |
| b = 7                                     | CB 78                | 203 120            |   |   |    |     |   |   |             |             |             |                |          | 101        |
| r = C,b = 0                               | CB41                 | 203 065            |   |   |    |     |   |   |             |             |             |                |          | 101        |
| b = 1                                     | CB 49                | 203073             |   |   |    |     |   |   |             |             |             |                |          | 101        |
| b = 2                                     | CB 51                | 203 081            |   |   |    |     |   |   |             |             |             |                |          | 101        |
| b = 3                                     | CB 59                | 203 089            |   |   |    |     |   |   |             |             |             |                |          | 101        |
| b = 3<br>b = 4                            | CB 61                | 203 097            |   |   |    |     |   |   |             |             |             |                |          | 101        |
| b = 5                                     | CB 69                | 203 105            |   |   |    |     |   |   |             |             |             |                |          | 101        |
| b = 6                                     | CB 71                | 203 1 1 3          |   |   |    |     |   |   |             |             |             |                |          | 10         |
| b = 0                                     | CB 79                | 203 121            |   |   |    |     |   |   |             |             |             |                |          | 10         |
|                                           |                      |                    |   |   |    |     |   |   |             |             |             |                |          |            |
| = D.b = 0                                 | CB 42                | 203 066            |   |   |    |     |   |   |             |             |             |                |          | 10         |
| b = 1                                     | CB 4A                | 203074             |   |   |    |     |   |   |             |             |             |                |          | 10         |
| b = 2                                     | CB 52                | 203 082            |   |   |    |     |   |   |             |             |             |                |          |            |
| b = 3                                     | CB 5A                | 203 090            |   |   |    |     |   |   |             |             |             |                |          | 10         |
| b = 4                                     | CB62                 | 203 098            |   |   |    |     |   |   |             |             |             |                |          | 101        |
| b = 5<br>b = 6                            | CB6A<br>CB72         | 203 106<br>203 114 |   |   |    |     |   |   |             |             |             |                |          | 10         |
|                                           | CB72<br>CB7A         | 203 114            |   |   |    |     |   |   |             |             |             |                |          | 101        |
| b = 7                                     |                      |                    |   |   |    |     |   |   |             |             |             |                |          |            |
| $\mathbf{r} = \mathbf{E}, \mathbf{b} = 0$ | CB 43                | 203 067            |   |   |    |     |   |   |             |             |             |                |          | 101        |
| b = 1                                     | CB4B                 | 203075             |   |   |    |     |   |   |             |             |             |                |          | 101        |
| b = 2                                     | CB 53                | 203 083            |   |   |    |     |   |   |             |             |             |                |          | 101        |
| b = 3                                     | CB 5B                | 203 09 1           |   |   |    |     |   |   |             |             |             |                |          | 101        |
| b = 4                                     | CB 63                | 203 099            |   |   |    |     |   |   |             |             |             |                |          | 101        |
| b = 5                                     | CB6B                 | 203 107            |   |   |    |     |   |   |             |             |             |                |          | 101        |
| b = 6                                     | CB 73                | 203 1 1 5          |   |   |    |     |   |   |             |             |             |                |          | 101        |
| b = 7                                     | CB7B                 | 203 123            |   |   |    |     |   |   |             |             |             |                |          | 101        |
| = H,b = Ø                                 | CB 44                | 203 068            |   |   |    |     |   |   |             |             |             |                |          | 101        |
| b = 1                                     | CB4C                 | 203076             |   |   |    |     |   |   |             |             |             |                |          | 101        |
| b = 2                                     | CB 54                | 203 084            |   |   |    |     |   |   |             |             |             |                |          | 101        |
| b = 3                                     | CB 5C                | 203 092            |   |   |    |     |   |   |             |             |             |                |          | 10         |
| b = 4                                     | CB64                 | 203 100            |   |   |    |     |   |   |             |             |             |                |          | 10         |
| b = 5                                     | CB6C                 | 203 108            |   |   |    |     |   |   |             |             |             |                |          | 10         |
| b = 6                                     | CB 74                | 203 1 16           |   |   |    |     |   |   |             |             |             |                |          | 101        |
| b = 7                                     | CB7C                 | 203 124            |   |   |    |     |   |   |             |             |             |                |          | 101        |
| = L, b = Ø                                | CB 45                | 203 069            |   |   |    |     |   |   |             |             |             |                |          | 101        |
| b = 1                                     | CB4D                 | 203077             |   |   |    |     |   |   |             |             |             |                |          | 10         |
| b = 2                                     | CB 55                | 203 085            |   |   |    |     |   |   |             |             |             |                |          | 101        |
| b = 3                                     | CB 5D                | 203 093            |   |   |    |     |   |   |             |             |             |                |          | 101        |
| b = 4                                     | CB 65                | 203 101            |   |   |    |     |   |   |             |             |             |                |          | 101        |
| b = 5                                     | CB 6D                | 203 109            |   |   |    |     |   |   |             |             |             |                |          | 101        |
| b = 6                                     | CB 75                | 203 1 1 7          |   |   |    |     |   |   |             |             |             |                |          | 101        |
| b = 7                                     | CB 7D                | 203 125            |   |   |    |     |   |   |             |             |             |                |          | 101        |
| BIT b. (HL)                               |                      |                    | ? | • | 1  | ?   | 0 | N | 2           | 3           | 12          | 6              |          |            |
| b = 0                                     | CB 46                | 203 070            |   | ~ |    |     |   |   |             |             |             |                |          | 103        |
| b = 1                                     | CB 4E                | 203078             |   |   |    |     |   |   |             |             |             |                |          | 103        |
| b = 2                                     | CB 56                | 203 086            |   |   |    |     |   |   |             |             |             |                |          | 103        |
| b = 3                                     | CB 5E                | 203 094            |   |   |    |     |   |   |             |             |             |                |          | 103        |
| b = 4                                     | CB 66                | 203 102            |   |   |    |     |   |   |             |             |             |                |          | 103        |
| b = 5                                     | CB 6E                | 203 1 10           |   |   |    |     |   |   |             |             |             |                |          | 103        |
| b = 6                                     | CB 76                | 203 1 18           |   |   |    |     |   |   |             |             |             |                |          | 103        |
| b = 7                                     | CB 7E                | 203 126            |   |   |    |     |   |   |             |             |             |                |          | 103        |
| BIT b, (IX + D)                           |                      |                    | ? |   | 1  | ?   | 0 | N | 4           | 5           | 20          | 10             |          |            |
| b = 0                                     | DDCBd46              | 221 203 d 070      |   |   |    |     | - |   |             |             |             |                |          | 105        |
| b = 1                                     |                      | 221 203 d 078      |   |   |    |     |   |   |             |             |             |                |          | 105        |
| b = 2                                     |                      | 221 203 d 086      |   |   |    |     |   |   |             |             |             |                |          | 105        |
|                                           |                      |                    |   |   |    |     |   |   |             |             |             |                |          |            |

#### BIT SET, RESET AND TEST (FLAG) GROUP TABLE

#### BIT SET, RESET AND TEST (FLAG) GROUP TABLE (cont.)

| COURCE                                                                                                                       | OBJECT                                                               |                                                                                                 |   | 1 | FL. | AGS |   | - | NO.         |             | TIMING      | 050.5          |          |                                                      |
|------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------|-------------------------------------------------------------------------------------------------|---|---|-----|-----|---|---|-------------|-------------|-------------|----------------|----------|------------------------------------------------------|
| SOURCE<br>CODE                                                                                                               | OBJECT<br>CODE (HEX)                                                 | DECIMAL                                                                                         | S | z | н   | P/V | N | с | OF<br>BYTES | M<br>CYCLES | T<br>STATES | μSEC @<br>2MHZ | COMMENTS | CH.<br>REF                                           |
| b = 4<br>b = 5<br>b = 6<br>b = 7                                                                                             | DDCBd66<br>DDCBd6E<br>DDCBd76<br>DDCBd76<br>DDCBd7E                  | 221 203 d 118                                                                                   |   |   |     |     |   |   |             |             |             |                |          | 105<br>105<br>105<br>105                             |
| BIT b. (IY + D) $b = 0$ $b = 1$ $b = 2$ $b = 3$                                                                              | FDCBd46<br>FDCBd4E<br>FDCBd56<br>FDCBd56                             | 253 203 d 070<br>253 203 d 078<br>253 203 d 086<br>253 203 d 086                                | ? | • | 1   | ?   | Ø | N | 4           | 5           | 20          | 10             |          | 105<br>105<br>105<br>105                             |
| b = 4<br>b = 5<br>b = 6<br>b = 7                                                                                             | FDCBd66<br>FDCBd6E<br>FDCBd76<br>FDCBd76<br>FDCBd7E                  | 253 203 d 102<br>253 203 d 110<br>253 203 d 110<br>253 203 d 118<br>253 203 d 126               |   |   |     |     |   |   |             |             |             |                |          | 105<br>105<br>105<br>105                             |
| RESb, r<br>r = A, b = $\emptyset$<br>b = 1<br>b = 2<br>b = 3<br>b = 4<br>b = 5<br>b = 6<br>b = 7                             | CB 87<br>CB 8F<br>CB 97<br>CB 9F<br>CB A7<br>CB AF<br>CB B<br>CB BF  | 203 135<br>203 143<br>203 151<br>203 159<br>203 159<br>203 167<br>203 175<br>203 183<br>203 191 | N | N | N   | N   | N | N | 2           | 2           | 8           | 4              |          | 250<br>250<br>250<br>250<br>250<br>250<br>250<br>250 |
| $\begin{array}{c} = & B, b = 0 \\ & b = 1 \\ & b = 2 \\ & b = 3 \\ & b = 4 \\ & b = 5 \\ & b = 6 \\ & b = 7 \end{array}$     | CB 80<br>CB 88<br>CB 90<br>CB 98<br>CB A0<br>CB A8<br>CB B0<br>CB 88 | 203 128<br>203 136<br>203 144<br>203 152<br>203 160<br>203 168<br>203 176<br>203 184            |   |   |     |     |   |   |             |             |             |                |          | 250<br>250<br>250<br>250<br>250<br>250<br>250<br>250 |
|                                                                                                                              | CB 81<br>CB 89<br>CB 91<br>CB 99<br>CB A1<br>CB A9<br>CB B1<br>CB 89 | 203 129<br>203 137<br>203 145<br>203 153<br>203 161<br>203 169<br>203 177<br>203 185            |   |   |     |     |   |   |             |             |             |                |          | 250<br>250<br>250<br>250<br>250<br>250<br>250<br>250 |
| $ \begin{array}{l} = \ D, b = \ 0 \\ b = \ 1 \\ b = \ 2 \\ b = \ 3 \\ b = \ 4 \\ b = \ 5 \\ b = \ 6 \\ b = \ 7 \end{array} $ | CB 82<br>CB 8A<br>CB 92<br>CB 9A<br>CB A2<br>CB AA<br>CB B2<br>CB BA | 203 130<br>203 138<br>203 146<br>203 154<br>203 162<br>203 170<br>203 178<br>203 186            |   |   |     |     |   |   |             |             |             |                |          | 250<br>250<br>250<br>250<br>250<br>250<br>250<br>250 |
| = E, b = 0  b = 1  b = 2  b = 3  b = 4  b = 5  b = 6  b = 7                                                                  | CB 83<br>CB 8B<br>CB 93<br>CB 9B<br>CB A3<br>CB AB<br>CB B3<br>CB BB | 203 131<br>203 139<br>203 147<br>203 155<br>203 163<br>203 171<br>203 179<br>203 187            |   |   |     |     |   |   |             |             |             |                |          | 250<br>250<br>250<br>250<br>250<br>250<br>250<br>250 |
| f = H, b = 0<br>b = 1<br>b = 2<br>b = 3<br>b = 4<br>b = 5<br>b = 6<br>b = 7                                                  | CB 84<br>CB 8C<br>CB 94<br>CB 9C<br>CB A4<br>CB AC<br>CB B4<br>CB BC | 203 132<br>203 140<br>203 148<br>203 156<br>203 164<br>203 172<br>203 180<br>203 188            |   |   |     |     |   |   |             |             |             |                |          | 250<br>250<br>250<br>250<br>250<br>250<br>250<br>250 |
| r = L, b = 0                                                                                                                 | CB 85<br>CB 8D<br>CB 95<br>CB 9D<br>CB A5<br>CB AD<br>CB 85<br>CB BD | 203 133<br>203 141<br>203 149<br>203 157<br>203 165<br>203 173<br>203 181<br>203 189            |   |   |     |     |   |   |             |             |             |                |          | 250<br>250<br>250<br>250<br>250<br>250<br>250<br>250 |
| RES b. (HL)<br>b = 0<br>b = 1<br>b = 2<br>b = 3<br>b = 4<br>b = 5                                                            | CB 86<br>CB 8E<br>CB 96<br>CB 9E<br>CB A6<br>CB AE                   | 203 134<br>203 142<br>203 150<br>203 158<br>203 166<br>203 174                                  | Ν | N | N   | N   | Ν | N | 2           | 4           | 15          | 7.5            |          | 251<br>251<br>251<br>251<br>251<br>251               |

#### BIT SET, RESET AND TEST (FLAG) GROUP TABLE (cont.)

| SOURCE                   | OBJECT                   |                                |    |   |   | AGS |   |    | NO.<br>OF | м      | TIMING<br>T | µSEC @ |          | CH.        |
|--------------------------|--------------------------|--------------------------------|----|---|---|-----|---|----|-----------|--------|-------------|--------|----------|------------|
| CODE                     | CODE (HEX)               |                                | S  | z | н | P/V | N | С  |           | CYCLES |             | 2MHZ   | COMMENTS | REF        |
| b = 6<br>b = 7           | CB B6<br>CB BE           | 203 182<br>203 190             |    |   |   |     |   |    |           |        |             |        |          | 251<br>251 |
| RES b.(IX + d)           |                          |                                | N  | N | N | N   | N | N  | 4         | 6      | 23          | 11.5   |          | 1          |
| b = Ø                    | DD CB d 86<br>DD CB d 8E | 221 203 d 134<br>221 203 d 142 |    |   |   |     |   |    |           |        |             |        |          | 253        |
| b = 1<br>b = 2           | DD CB d 8E<br>DD CB d 96 |                                |    |   |   |     |   |    |           |        |             |        |          | 253        |
| b = 3                    | DD CB d 9E               | 221 203 d 158                  |    |   |   |     |   |    |           |        |             |        |          | 253        |
| b = 4<br>b = 5           | DD CB d A6<br>DD CB d AE | 221 203 d 166<br>221 203 d 174 |    |   |   |     |   |    |           |        |             |        |          | 253        |
| b = 6                    | DD CB d B6               | 221 203 d 182                  |    |   |   |     |   |    |           |        |             |        |          | 253        |
| b = 7<br>RES b.(IY + d)  | DD CB d BE               | 221 203 d 190                  | N  | N | N | N   | N | N  | 4         | 6      | 23          | 11.5   |          | 253        |
| b = Ø                    | FD CB d 86               |                                | N. |   |   | N.  |   | 14 | 4         |        | 23          | 11.5   |          | 253        |
| b = 1<br>b = 2           | FD CB d 8E<br>FD CB d 96 | 253 203 d 142<br>253 203 d 150 |    |   |   |     |   |    |           |        |             |        |          | 25         |
| b = 3                    | FD CB d 9E               | 253 203 d 158                  |    |   |   |     |   |    |           |        |             |        |          | 253        |
| b = 4<br>b = 5           | FD CB d A6<br>FD CB d AE | 253 203 d 166<br>253 203 d 174 |    |   |   |     |   |    |           |        |             |        |          | 253<br>253 |
| b = 6                    | FD CB d B6               | 253 203 d 182                  |    |   |   |     |   |    |           |        |             |        |          | 253        |
| b = 7                    | FD CB d BE               | 253 203 d 190                  |    |   |   |     |   |    |           |        |             | 4      |          | 253        |
| SET b, r<br>r = A, b = Ø | CBC7                     | 203 199                        | Ν  | N | N | N   | N | N  | 2         | 2      | 8           | 4      |          | 312        |
| b = 1                    | CBCF                     | 203 207                        |    |   |   |     |   |    |           |        |             |        |          | 312        |
| b = 2<br>b = 3           | CBD7<br>CBDF             | 203215<br>203223               |    |   |   |     |   |    |           |        |             |        |          | 312        |
| b = 4<br>b = 5           | CBE7<br>CBEF             | 203231                         |    |   |   |     |   |    |           |        |             |        |          | 312        |
| b = 5<br>b = 6           | CBF7                     | 203 239                        |    |   |   |     |   |    |           |        |             |        |          | 312        |
| b = 7                    | CBFF                     | 203 255                        |    |   |   |     |   |    |           |        |             |        |          | 312        |
| r = B, b = 0<br>b = 1    | CBCO<br>CBC8             | 203 192<br>203 200             |    | i |   |     |   |    |           |        |             |        |          | 312        |
| b = 1<br>b = 2           | CBDO                     | 203200                         |    |   |   |     |   |    |           |        |             |        |          | 312        |
| b = 3<br>b = 4           | CBD8<br>CBEO             | 203216<br>203224               |    |   |   |     |   |    |           |        |             |        |          | 312        |
| b = 4<br>b = 5           | CBE8                     | 203224                         |    |   |   |     |   |    |           |        |             |        |          | 312        |
| b = 6<br>b = 7           | CBFO<br>CBF8             | 203240<br>203248               |    |   |   |     |   |    |           |        |             |        |          | 312<br>312 |
| r = C, b = Ø             | CBC1                     | 203 248                        |    |   |   |     |   |    |           |        |             |        |          | 312        |
| b = 1                    | CBC9                     | 203 201                        |    |   |   |     |   |    |           |        |             |        |          | 312        |
| b = 2<br>b = 3           | CBD1<br>CBD9             | 203209                         |    |   |   |     |   |    |           |        |             |        |          | 312        |
| b = 4                    | CBE1                     | 203225                         |    |   |   |     |   |    |           |        |             |        |          | 312        |
| b = 5<br>b = 6           | CBE9<br>CBF1             | 203233<br>203241               |    |   |   |     |   |    |           |        |             |        |          | 312        |
| b = 7                    | CBF9                     | 203 249                        |    |   |   |     |   |    |           |        |             |        |          | 312        |
| r = D, b = 0<br>b = 1    | CBC2<br>CBCA             | 203 194<br>203 202             |    |   |   |     |   |    |           |        |             |        |          | 312        |
| b = 1                    | CB D2                    | 203210                         |    |   |   |     |   |    |           |        |             |        |          | 312        |
| b = 3<br>b = 4           | CBDA<br>CBE2             | 203218<br>203226               |    |   |   |     |   |    |           |        |             |        |          | 312        |
| b = 5                    | CBEA                     | 203234                         |    |   |   |     |   |    |           |        |             |        |          | 312        |
| b = 6<br>b = 7           | CB F2<br>CB FA           | 203242<br>203250               |    |   |   |     |   |    |           |        |             |        |          | 312        |
| r = E, b = 0             | CBC3                     | 203 195                        |    |   |   |     |   |    |           |        |             |        |          | 312        |
| b = 1                    | CBCB                     | 203 203                        |    |   |   |     |   |    |           |        |             |        |          | 312        |
| b = 2<br>b = 3           | CB D3<br>CB DB           | 203211 203219                  |    |   |   |     |   |    |           |        |             |        |          | 312        |
| b = 4                    | CBE3                     | 203 227                        |    |   |   |     |   |    |           |        |             |        |          | 312        |
| b = 5<br>b = 6           | CBEB<br>CBF3             | 203235<br>203243               |    |   |   |     |   |    |           |        |             |        |          | 312<br>312 |
| b = 7                    | CBFB                     | 203251                         |    |   |   |     |   |    |           |        |             |        |          | 312        |
| r = H,b = 0<br>b = 1     | CBC4<br>CBCC             | 203 196                        |    |   |   |     |   |    |           |        |             |        |          | 312<br>312 |
| b = 2                    | CBD4                     | 203212                         |    |   |   |     |   |    |           |        |             |        |          | 312        |
| b = 3<br>b = 4           | CBDC<br>CBE4             | 203 220<br>203 228             |    |   |   |     |   |    |           |        |             |        |          | 312<br>312 |
| b = 4<br>b = 5           | CBEC<br>CBEC             | 203228                         |    |   |   |     |   |    |           |        |             |        |          | 312        |
| b = 6<br>b = 7           | CBF4<br>CBFC             | 203 244<br>203 252             |    |   |   |     |   |    |           |        |             |        |          | 312<br>312 |
| b = 7                    | CBC5                     | 203 252 203 197                |    |   |   |     |   |    |           |        |             |        |          | 312        |
| b = 1                    | CBCD                     | 203 205                        |    |   |   |     |   |    |           |        |             |        |          | 312        |
| b = 2<br>b = 3           | CBD5<br>CBDD             | 203213 203221                  |    |   |   |     |   |    |           |        |             |        |          | 312<br>312 |
| b = 4                    | CBE5                     | 203 229                        |    |   |   |     |   |    |           |        |             |        |          | 312        |
| b = 5<br>b = 6           | CBED<br>CBF5             | 203237<br>203245               |    |   |   |     |   |    |           |        |             |        |          | 312<br>312 |
| b = 0                    |                          | 203 253                        |    |   |   |     |   |    |           |        |             |        |          | 312        |

#### BIT SET, RESET AND TEST (FLAG) GROUP TABLE (cont.)

|                 |                      |               |   |   | FL | AGS |   |   | NO.         |             | TIMING      |                |          |     |
|-----------------|----------------------|---------------|---|---|----|-----|---|---|-------------|-------------|-------------|----------------|----------|-----|
| SOURCE<br>CODE  | OBJECT<br>CODE (HEX) | DECIMAL       | s | z | н  | P/V | N | с | OF<br>BYTES | M<br>CYCLES | T<br>STATES | µSEC @<br>2MHZ | COMMENTS | CH. |
| SET b. (HL)     |                      |               | N | N | N  | N   | N | N | 2           | 4           | 15          | 7.5            |          |     |
| b = 0           | CBC6                 | 203 198       |   |   |    |     |   |   |             |             |             |                |          | 313 |
| io = 1          | CBCE                 | 203 206       |   |   |    |     |   |   |             |             |             |                |          | 313 |
| b = 2           | CBD6                 | 203214        |   |   |    |     |   |   |             |             |             |                |          | 313 |
| b = 3           | CBDE                 | 203 222       |   |   |    |     |   |   |             |             |             |                |          | 313 |
| b = 4           | CBE6                 | 203 230       |   |   |    |     |   |   |             |             |             |                |          | 313 |
| b = 5           | CBEE                 | 203 238       |   |   |    |     |   |   |             |             |             |                |          | 313 |
| b = 6           | CBF6                 | 203246        |   |   |    |     |   |   |             |             |             |                |          | 313 |
| b = 7           | CBFE                 | 203 254       |   |   |    |     |   |   |             |             |             |                |          | 313 |
| SET b.(IX + d)  |                      |               | N | N | N  | N   | N | N | 4           | 6           | 23          | 11.5           |          |     |
| b = Ø           | DD CB d C6           | 221 203 d 198 |   |   |    |     |   |   |             |             |             |                |          | 314 |
| b = 1           | DD CB d CE           | 221 203 d 206 |   |   |    |     |   |   |             |             |             |                |          | 314 |
| b = 2           | DD CB d D6           | 221 203 d 214 |   |   |    |     |   |   |             |             |             |                |          | 314 |
| b = 3           | DD CB d DE           | 221 203 d 222 |   |   |    |     |   |   |             |             |             |                |          | 314 |
| b = 4           | DD CB d E6           | 221 203 d 230 |   |   |    |     |   |   |             |             |             |                |          | 314 |
| b = 5           | DD CB d EE           | 221 203 d 238 |   |   |    |     |   |   |             |             |             |                |          | 314 |
| b = 6           | DD CB d F6           | 221 203 d 246 |   |   |    |     |   |   |             |             |             |                |          | 314 |
| b = 7           | DD CB d FE           | 221 203 d 254 |   |   |    |     |   |   |             |             |             |                |          | 314 |
| SET b, (IY + d) |                      |               | N | N | N  | N   | N | N | 4           | 6           | 23          | 11.5           |          |     |
| b = 0           | FD CB d C6           | 253 203 d 198 |   |   |    |     |   |   |             |             |             |                |          | 314 |
| b = 1           | FD CB d CE           | 253 203 d 206 |   |   |    |     |   |   |             |             |             |                |          | 314 |
| b = 2           | FD CB d D6           | 253 203 d 214 |   |   |    |     |   | 1 |             |             |             | 1. D           |          | 314 |
| b = 3           |                      | 253 203 d 222 |   |   |    |     |   |   |             |             |             |                |          | 314 |
| b = 4           | FD CB d E6           | 253 203 d 230 |   |   |    |     |   |   |             |             |             |                | 8 6      | 314 |
| b = 5           |                      | 253 203 d 238 |   |   |    |     |   |   |             |             |             |                |          | 314 |
| b = 6           |                      | 253 203 d 246 |   |   |    |     |   |   |             |             |             |                |          | 314 |
| b = 7           | FD CB d FE           | 253 203 d 254 |   |   |    |     |   |   |             |             |             |                |          | 314 |

FLAG KEY: N - Not affected.

 - No. alreated.

 - Contains the Parity of the result (1 = Parity Even).

 V
 - Contains the Overflow of the result (1 = Overflow).

 0
 - RESET = 0.

- Unknown

- Affected according to the result

BIT b.r

Where:

Chapter 5, Page 101

b specifies the bit position concerned.

r identifies one of the registers A, B, C, D, E, H or L.

This instruction tests the specified bit in the nominated register and Sets/Resets the Z Flag in the Flag Register to the COMPLEMENT of that bit.

BIT b. (HL) Where: Chapter 5, Page 103

b specifies the bit position to be tested.

Tests the specified bit in a memory location whose address is held in the Register Pair HL then Sets/Resets the Z Flag in the Flag Register to the COMPLEMENT of that bit

BIT b, (IX + d)

Where:

Chapter 5, Page 105

b specifies the bit position concerned.

d is the displacement, in bytes, from the memory location whose address is identified by the contents of Index Register IX.

Tests the specified bit in a memory location whose address is identified by he contents of Index Register IX (modified by displacement d, which is specified in the instruction) then Sets/Resets the Z Flag in the Flag Register to the COMPLEMENT of that bit.

BIT b.(IY + d)

Chapter 5, Page 107

Where:

b specifies the bit position concerned.

d is the displacement, in bytes, from the memory location whose address is identified by the contents of Index Register IY.

Tests the specified bit in a memory location whose address is identified by contents of Index Register IY (modified by displacement d, which is specified in the instruction) then Sets/Resets the Z Flag in the Flag Register to the COMPLEMENT of that bit.

RES b.r

Where:

b specifies the bit position required.

r represents one of the registers A, B, C, D, E, H or L.

Resets to Ø the specified Bit in the register nominated in the instruction.

RES b.(HL)

Chapter 5, Page 251

Chapter 5, Page 250

Where:

b specifies the bit position required.

Resets to  $\emptyset$  the specified bit in the memory location whose address is held in the Register Pair HL.

RESb.(IX + d)

Chapter 5, Page 253

Where:

b specifies the bit position required.

d is the displacement, in bytes, from the memory location whose address is identified by the contents of Index Register IX.

Resets to 0 the specified bit in the memory location whose address is identified by the contents of Index Register IX (modified by displacement d, which is specified in the instruction).

$$RESb,(IY+d)$$

Where:

Chapter 5, Page 253

b specifies the bit position required.

d is the displacement, in bytes, from the memory location whose address is identified by the contents of Index Register IY.

Resets to  $\emptyset$  the specified bit in the memory location whose address is indentified by the contents of Index Register IY (modified by displacement d, which is specified in the instruction).

SET b,r

Chapter 5, Page 312

Chapter 5, Page 313

Chapter 5, Page 314

Where:

b specifies the bit position required.

r represents one of the registers A, B, C, D, E, H or L.

Sets to 1 the specified bit in the Register nominated in the instruction.

SET b,(HL)

Where:

b specifies the bit position required.

Sets to 1 the specified bit in the memory location whose address is held in Register Pair HL.

SET  $b_{i}(IX + d)$ 

Where:

b specifies the bit position required.

d is the displacement, in bytes, from the memory location whose address is identified by the contents of Index Register IX.

Sets to 1 the specified bit in the memory location whose address is identified by the contents of Index Register IX (modified by displacement d, which is specified in the instruction).

SET b, (IY + d)

Chapter 5, Page 314

Where:

b specifies the bit position required.

d is the displacement, in bytes, from the memory location whose address is identified by the contents of Index Register IY.

Sets to 1 the specified bit in the memory location whose address is identified by the contents of Index Register IY (modified by displacement d, which is specified in the instruction).

## 10. Jump, Sub-Routine Call and Return Group

JUMP instructions transfer control to another location in memory but do not save the contents of the Program Counter (PC) to identify where the jump occurred.

CALL instructions also transfer control to another memory location but save the original contents of the Program Counter in the Memory Stack.

RETURN instructions transfer the contents of the top of the Memory Stack to the Program Counter, thus returning control to the location where the CALL instruction occurred.

| 0000005              | 00.00                |                  |        |    | FL     | AGS    |        | -      | NO.                |        | TIMING      | 050            |                                             |          |
|----------------------|----------------------|------------------|--------|----|--------|--------|--------|--------|--------------------|--------|-------------|----------------|---------------------------------------------|----------|
| SOURCE<br>CODE       | OBJECT<br>CODE (HEX) | DECIMAL          | s      | z  | н      | P/V    | N      | с      | OF M<br>BYTES CYCL |        | T<br>STATES | μSEC @<br>2MHZ | COMMENTS                                    | CH.      |
| CALLpq               | CDpq                 | 205 pq           | N<br>N | NN | N<br>N | N<br>N | N<br>N | N<br>N | 3                  | 5<br>5 | 17<br>17    | 8.5<br>8.5     | Ifccistrue                                  | 109      |
| CALL cc, pq          |                      |                  | N      | N  | N      | N      | N      | IN     | 3                  | 3      | 10          | 5              | If cc is false                              |          |
| cc = NZ              | C4 pq                | 196 pg           |        |    |        |        |        |        |                    | 5      | 10          | 5              | in certa raise                              | 11       |
| cc = Z               | CCpq                 | 204 pq           |        |    |        |        |        |        |                    |        |             |                |                                             | 11       |
| cc = NC              | D4 pq                | 212 pq           |        |    |        |        |        |        |                    |        |             |                |                                             | 11       |
| cc = C               | DC pq                | 220 pq           |        |    |        |        |        |        |                    |        |             |                |                                             | 11       |
| cc = PO              | E4 pq                | 228 pq           |        |    |        |        |        |        | 1                  |        |             |                |                                             | 12       |
| cc = PE<br>cc = P    | ECpq<br>F4pq         | 236 pq<br>244 pq |        |    |        |        |        |        |                    |        |             |                |                                             | 11       |
| cc = P<br>cc = M     | FCpq                 | 252 pq           |        |    |        |        |        |        |                    |        |             |                |                                             | 11       |
| DJNZe                | 10e-2                | 16e-2            | N      | N  | N      | N      | N      | N      | 2                  | 2      | 8           | 4              | If Register B = Ø                           | 14       |
| DUNZE                | 106-2                | 106.2            |        |    |        |        | 14     |        | 2                  | 3      | 13          | 6.5            | If Register B ≠ Ø                           | 1        |
| JPnn                 | C3 nn                | 195 nn           | N      | N  | N      | N      | N      | N      | 3                  | 3      | 10          | 5              | ii negisiei b ≠ v                           | 17       |
|                      | Conn                 | 195111           | N      | N  | N      | N      | N      | N      | 3                  | 3      | 10          | 5              |                                             |          |
| JP cc, pq<br>cc = NZ | C2 ap                | 194 ap           | N      | N  | N      | N      | N      | N      | 3                  | 3      | 10          | 5              |                                             | 17       |
| cc = Z               | CAqp                 | 202 qp           |        |    |        |        |        |        |                    |        |             |                |                                             | 17       |
| cc = NC              | D2 gp                | 210 gp           |        |    |        |        |        |        |                    |        |             |                |                                             | 17       |
| cc = C               | DAqp                 | 218 qp           |        |    |        |        |        |        |                    |        |             |                |                                             | 17       |
| cc = PO              | E2 qp                | 226 qp           |        |    |        |        |        |        |                    |        |             |                |                                             | 17       |
| cc = PE              | EAqp                 | 234 qp           |        |    |        |        |        |        |                    |        |             |                |                                             | 17       |
| cc = P<br>cc = M     | F2 qp                | 242 qp           |        |    |        |        |        |        |                    |        |             |                |                                             | 17       |
|                      | FAqp                 | 250 qp           |        |    |        |        |        |        |                    |        |             |                |                                             | 17       |
| JP (HL)              | E9                   | 233              | N      | N  | N      | N      | N      | N      | 1                  | 1      | 4           | 2              |                                             | 17       |
| JP (IX)              | DDE9                 | 221233           | N      | N  | N      | N      | N      | N      | 2                  | 2      | 8           | 4              |                                             | 17       |
| JP (IY)              | FD E9                | 253 233          | N      | N  | N      | N      | N      | N      | 2                  | 2      | 8           | 4              |                                             | 17       |
| JRe                  | 18 e-2               | 024 e-2          | N      | N  | N      | N      | N      | N      | 2                  | 3      | 12          | 6              | M                                           | 18       |
| IRC, e               | 38 e-2               | 056 e-2          | N      | N  | N      | N      | N      | N      | 2                  | 3      | 12<br>7     | 6<br>3.5       | If condition is met<br>If condition not met |          |
| 0.00                 | 30 e-2               | 0.40 - 0         |        | N  |        | N      |        |        |                    | 2      | 12          | 3.5<br>6       | If condition is met                         | 18       |
| JRNC, e              | 30 e-2               | 048 e-2          | N      | N  | N      | N      | N      | N      | 2                  | 2      | 7           | 3.5            | If condition not met                        | 18       |
| JRNZ.e               | 20 e-2               | 032 e-2          | N      | N  | N      | N      | N      | N      | 2                  | 3      | 12          | 6              | If condition is met                         | 10       |
|                      |                      |                  |        |    |        |        |        |        |                    | 2      | 7           | 3.5            | If condition not met                        | 18       |
| JRZ, e               | 28 e-2               | 040 e-2          | Ν      | N  | N      | N      | N      | N      | 2                  | 3      | 12          | 6              | If condition is met                         |          |
|                      |                      |                  |        |    |        |        |        |        |                    | 2      | 7           | 3.5            | If condition not met                        | 18       |
| RET                  | C9                   | 201              | N      | N  | N      | N      | N      | N      | 1                  | 3      | 10          | 5              |                                             | 22       |
| RETcc                |                      |                  | Ν      | N  | N      | N      | N      | N      | 1                  | 3      | 11<br>5     | 5.5<br>2.5     | If cc is true<br>If cc is false             |          |
| cc = NZ              | CO                   | 192              |        |    |        |        |        |        |                    | 1      | 5           | 2.5            | liccisiaise                                 | 25       |
| cc = Z               | C8                   | 200              |        |    |        |        |        |        |                    | 1      |             |                |                                             | 25       |
| cc = NC              | D0                   | 208              |        |    |        |        |        |        |                    |        |             |                |                                             | 25       |
| cc = C               | D8                   | 216              |        |    |        |        |        |        |                    |        |             |                |                                             | 25       |
| cc = PO              | EO                   | 224              |        |    |        |        |        |        |                    |        |             |                |                                             | 25       |
| cc = PE              | E8                   | 232              |        |    |        |        |        |        |                    |        |             |                |                                             | 25       |
| cc = P<br>cc = M     | F0<br>F8             | 240<br>248       |        |    |        |        |        |        |                    |        |             |                |                                             | 25<br>25 |
| RETI                 | ED4D                 | 237 077          |        |    |        |        |        |        | 2                  | 4      | 14          | 7              |                                             |          |
| RETN                 | ED4D<br>ED45         | 237077           | N      | N  | N      | N      | N      | N      | 2                  | 4      | 14          | 7              |                                             | 259      |
|                      | ED 45                | 237 069          | N      | N  | N      | N      | N      |        |                    |        |             |                |                                             | 26       |
| RST P<br>p = 00      |                      |                  | Ν      | N  | N      | N      | N      | N      | 1                  | 3      | 11          | 5.5            |                                             |          |
| (Hex.)               | C7                   | 199              |        |    |        |        |        |        |                    |        |             |                |                                             | 29       |
| p = 08               |                      |                  |        |    |        |        |        |        |                    |        |             |                |                                             |          |
| (Hex.)               | CF                   | 207              |        |    |        |        |        |        |                    |        |             |                |                                             | 299      |
| p = 10<br>(Hex.)     | D7                   | 215              |        |    |        |        |        |        |                    |        |             |                |                                             | 299      |
| p = 18<br>(Hex.)     | DF                   | 223              |        |    |        |        |        |        |                    |        |             |                |                                             | 29       |
| p = 20               |                      |                  |        |    |        |        |        |        |                    |        |             |                |                                             |          |
| (Hex.)<br>p = 28     | E7                   | 231              |        |    |        |        |        | 2      |                    |        |             |                |                                             | 29       |
| (Hex.)<br>p = 30     | EF                   | 239              |        |    |        |        |        |        |                    |        |             |                |                                             | 29       |
| (Hex.)<br>p = 38     | F7                   | 247              |        |    |        |        |        |        |                    |        |             |                |                                             | 29       |
|                      | FF                   | 255              |        |    |        | 1      |        | 1      | 1                  |        |             |                |                                             | 29       |

#### JUMP, (SUB-ROUTINE) CALL AND RETURN GROUP TABLE

FLAG KEY: N - Not affected.

CALL pq

Where:

p is the Lower Order byte of the address to which control is to be transferred.

q is the Higher Order byte of the address to which control is to be transferred.

Pushes the contents of the Program Counter (PC) on to the top of the Memory Stack then loads address pq into the Program Counter. This calls the subroutine which starts at memory address pq.

NOTE: To return from the subroutine, a RET instruction must be included in the subroutine code.

CALL cc,pq

Chapter 5, Page 111-120

Where:

cc specifies the condition which must be met for the Call to become effective, based on the following table:

| Condition     |    | cc (Bin.) | Flag |
|---------------|----|-----------|------|
| Non-zero      | NZ | ØØØ       | Z    |
| Zero          | Z  | ØØ1       | Z    |
| Non-Carry     | NC | Ø1Ø       | С    |
| Carry         | С  | Ø11       | С    |
| Parity Odd    | PO | 100       | P/V  |
| Parity Even   | PE | 101       | P/V  |
| Sign Positive | Р  | 110       | S    |
| Sign Negative | М  | 111       | S    |

p is the Lower Order byte of the address to which control is to be transferred.

q is the Higher Order byte of the address to which control is to be transferred.

Provided condition cc is TRUE, Pushes the contents of the Program Counter (PC) to the top of the Memory Stack then loads pq into the Program Counter. If Condition cc is NOT TRUE, the Program Counter is incremented and the program continues.

NOTE: A RET instruction must be included in the subroutine code to return control to the main program.

DJNZ e

Chapter 5, Page 146

Where:

e is the displacement required if the Jump instruction is to be followed.

NOTE: The initial value of the second byte of this instruction must be e-2.

Decrements register B and Jumps if the result is Non-Zero, when e is added to the Program Counter (PC) giving the address to which control is to be transferred. If the contents of register B are Zero, the Jump does not take place and the program continues with the next instruction.

JP nn

Chapter 5, Page 175

nn is a memory location specified in the instruction.

Jumps unconditionally to memory location nn, where the next instruction is held.

JP cc,pq

Where:

Where:

Chapter 5, Page 178

cc specifies the condition which must be met for the Jump to become effective, based on the following table:

| Condition     |    | cc (Bin.) | Flag |
|---------------|----|-----------|------|
| Non-Zero      | NZ | ØØØ Í     | z    |
| Zero          | Z  | ØØ1       | Z    |
| Non-Carry     | NC | Ø1Ø       | С    |
| Carry         | С  | Ø11       | С    |
| Parity Odd    | PO | 100       | P/V  |
| Parity Even   | PE | 1Ø1       | P/V  |
| Sign Positive | Р  | 110       | S    |
| Sign Negative | М  | 111       | S    |

p is the Lower Order byte of the address to which control is to be transferred.

q is the Higher Order byte of the address to which control is to be transferred.

Provided Condition cc is TRUE, loads pq into the Program Counter (PC). If condition cc is False the Program Counter is incremented to the next sequential instruction.

## JP (HL)

Chapter 5, Page 176

Jumps unconditionally to the memory location whose address is held in Register Pair HL, i.e. the contents of HL are loaded into the Program Counter (PC).

## JP (IX)

Chapter 5, Page 177

Jumps unconditionally to the memory location whose address is held in Index Register IX, i.e. the contents of IX are loaded into the Program Counter (PC). JP (IY)

JRe

Jumps unconditionally to the memory location whose address is held in Index Register IY, i.e. the contents of IY are loaded into the Program Counter (PC).

Chapter 5, Page 180

Where: e is the displacement required from the current contents of the Program Counter (PC).

Adds e to the Program Counter (PC), the next instruction being fetched from the location identified by the new contents of the Program Counter.

JR C,e

Where:

e is the displacement from the current contents of the Program Counter (PC) required if the Jump instruction is to be followed.

JR NC,e

Where:

e is the displacement from the current contents of the Program Counter (PC) required if the Jump instruction is to be followed.

If the Carry Flag C = 1, the program continues to the next instruction and the Jump does not occur. If the Carry Flag  $C = \emptyset$ , e is added to the Program Counter (PC) and the next instruction is fetched from the location identified by the new contents of the Program Counter.

JR NZ,e

Where:

Chapter 5, Page 181

Chapter 5, Page 181

e is the displacement from the current contents of the Program Counter (PC) required if the Jump instruction is to be followed.

If the Zero Flag Z = 1 the program continues to the next instruction and the Jump does not occur. If the Zero Flag  $Z = \emptyset$ , e is added to the Program Counter (PC) and the next instruction is fetched from the location identified by the new contents of the Program Counter.

JR Z,e

Where:

e is the displacement from the current contents of the Program Counter (PC) required if the Jump instruction is to be followed.

Chapter 5, Page 177

Chapter 5, Page 181

Chapter 5, Page 181

If the Zero Flag  $Z = \emptyset$  the program continues to the next instruction and the Jump does not occur. If the Zero Flag Z = 1, e is added to the Program Counter (PC) and the next instruction is fetched from the location identified by the new contents of the Program Counter.

*RET* Chapter 5, Page 255 Returns program control to the main program after a subroutine has been executed. Loads the Lower Order byte of the Program Counter (PC) with the contents of the memory location whose address is identified by the Stack Pointer (SP) and the Higher Order byte of the Program Counter with the contents of the next sequential location, i.e. SP + 1.

#### RETcc

Chapter 5, Page 257

Where:

cc specifies the condition which must be met for the Return to become effective, based on the following table:

| Condition     |    | cc (Bin.) | Flag |
|---------------|----|-----------|------|
| Non-Zero      | NZ | ØØØ       | Z    |
| Zero          | Z  | ØØ1       | Z    |
| No Carry      | NC | Ø1Ø       | С    |
| Carry         | С  | Ø11       | С    |
| Parity Odd    | PO | 100       | P/V  |
| Parity Even   | PE | 101       | P/V  |
| Sign Positive | Р  | 110       | S    |
| Sign Negative | М  | 111       | S    |

If the condition specified in the instruction is TRUE, control is returned to the main program. The Lower Order byte of the Program Counter (PC) is loaded with the contents of the memory location whose address is held in the Stack Pointer (SP) and the Higher Order byte of the Program Counter is loaded with the contents of the next sequential memory location (SP + 1).

#### RETI

Chapter 5, Page 259

Returns control to the main program following an Interrupt by placing the contents of the top two bytes of the Memory Stack into the Program Counter (the Top byte of the Memory Stack is placed in the Lower Order byte of the Program Counter and the next byte in the Higher Order byte of the Program Counter).

NOTE: An El instruction must be executed before the RETI instruction to re-enable interrupts.

#### RETN

Chapter 5, Page 261

Similar to a RET instruction but used at the end of a subroutine servicing a non-maskable interrupt. Returns program control to the main

program by loading the Lower Order byte of the Program Counter (PC) with the contents of the top location in the Memory Stack and the Higher Order byte with the contents of the next sequential location (SP + 1). The contents of IFF2 Flip-Flop are also copied back into IFF1, restoring it to its original condition.

RSTp

Where:

Chapter 5, Page 299

p is the Lower Order byte of an address in low memory where the program is to be restarted.

NOTE: The Higher Order byte of this address is automatically loaded with  $\emptyset\emptyset$ H, thus restricting the number of possible restart addresses to eight, based on the following values of p:

| Hex. |   | Bin. | Hex. |   | Bin. |
|------|---|------|------|---|------|
| ØØH  | _ | ØØØ  | 20H  | _ | 100  |
| Ø8H  | _ | ØØ1  | 28H  |   | 101  |
| 10H  | _ | Ø1Ø  | ЗØН  |   | 110  |
| 18H  |   | Ø11  | 38H  | _ | 111  |

The contents of the Program Counter (PC) are loaded on to the top of the Memory Stack (as for the PUSH instruction) and the Program Counter is then loaded with ØØH in the Higher Order byte and the value of p specified in the instruction in the Lower Order byte. The next instruction is then fetched from the nominated location in low memory.

#### 11. Input and Output Group

This Group allows the transfer of single or multiple bytes (up to 256) between CPU registers or memory blocks and any one of 256 Input/ Output device addresses.

|                |                      |         |   |     | FL | AGS |   |   | NO.         |             | TIMING      |                |                   |            |
|----------------|----------------------|---------|---|-----|----|-----|---|---|-------------|-------------|-------------|----------------|-------------------|------------|
| SOURCE<br>CODE | OBJECT<br>CODE (HEX) | DECIMAL | s | z   | н  | P/V | N | с | OF<br>BYTES | M<br>CYCLES | T<br>STATES | µSEC @<br>2MHZ | COMMENTS          | CH.<br>REF |
| INA.(N)        | DBN                  | 219 N   | N | N   | N  | N   | N | N | 2           | 3           | 11          | 5.5            |                   | 159        |
| IN r, (C)      |                      |         | • |     | •  | P   | 0 | N | 2           | 3           | 12          | 6              |                   |            |
| r = A          | ED 78                | 237 120 |   |     |    |     |   |   |             |             |             |                |                   | 160        |
| r = B          | ED 40                | 237 064 |   |     |    |     |   |   | 1           |             |             |                |                   | 160        |
| r = C          | ED 48                | 237 072 |   |     |    |     |   |   |             |             |             |                |                   | 160        |
| r = D          | ED 50                | 237 080 |   |     |    |     |   |   |             |             |             |                |                   | 160        |
| r = E          | ED 58                | 237 088 |   |     |    |     |   |   |             |             |             |                |                   | 160        |
| r = H          | ED 60                | 237 096 |   |     |    |     |   |   |             |             |             |                |                   | 160        |
| r = L          | ED 68                | 237 104 |   |     |    |     |   |   |             |             |             |                |                   | 160        |
| IND            | EDAA                 | 237 170 | ? | •   | ?  | ?   | 1 | N | 2           | 4           | 16          | 8              |                   | 169        |
| INI            | ED A2                | 237 162 | ? | •   | ?  | ?   | 1 | N | 2           | 4           | 16          | 8              |                   | 172        |
| INIR           | ED B2                | 237 172 | ? | 1   | ?  | ?   | 1 | N | 2           | 5           | 21          | 10.5           | If Register B ≠ 0 | 170        |
|                |                      |         |   |     |    |     |   |   |             | 4           | 16          | 8              | If Register B= 0  |            |
| INDR           | EDBA                 | 237 186 | ? | 1   | ?  | ?   | 1 | N | 2           | 5           | 21          | 10.5           | If Register B ≠ Ø | 235        |
|                |                      |         |   |     |    |     |   |   |             | 4           | 16          | 8              | If Register B = 0 |            |
| OTDR           | ED BB                | 237 187 | ? | 1   | ?  | ?   | 1 | N | 2           | 5           | 21          | 10.5           | If Register B ≠ Ø | 173        |
|                |                      |         |   |     |    |     |   |   |             | 4           | 16          | 8              | If Register B = 0 |            |
| OTIR           | ED B3                | 237 179 | ? | •   | ?  | ?   | 1 | N | 2           | 5           | 21          | 10.5           | If Register B ≠ 0 | 236        |
|                |                      |         |   |     |    |     |   |   |             | 4           | 16          | 8              | If Register B = 0 |            |
| OUT (n), A     | D3 n                 | 211 n   | N | N   | N  | N   | N | N | 2           | 3           | 11          | 5.5            |                   | 239        |
| OUT (C), r     |                      |         | N | N   | N  | N   | N | N | 2           | 3           | 12          | 6              |                   |            |
| r = A          | ED 79                | 237 121 |   |     |    |     |   |   |             |             |             |                |                   | 238        |
| r = B          | ED41                 | 237 065 |   |     |    |     |   |   |             |             |             |                |                   | 238        |
| r = C          | ED 49                | 237073  |   |     |    |     |   |   |             |             |             |                |                   | 238        |
| r = D          | ED51                 | 237 081 |   |     |    |     |   |   |             |             |             |                |                   | 238        |
| r = E          | ED 59                | 237 089 |   |     |    |     |   |   |             |             |             |                |                   | 238        |
| r = H          | ED61                 | 237 097 |   |     |    |     |   |   |             |             |             |                |                   | 238        |
| r = L          | ED 69                | 237 105 |   |     |    |     |   |   |             |             |             |                |                   | 238        |
| OUTD           | EDAB                 | 237 171 | ? | · · | ?  | ?   | 1 | N | 2           | 4           | 16          | 8              |                   | 240        |
| OUTI           | ED A3                | 237 163 | ? |     | 2  | 2   | 1 | N | 2           | 4           | 16          | 8              |                   | 241        |

#### INPUT AND OUTPUT GROUP TABLE

FLAG KEY: N - Not affected. P - Contains the

- Contains the Parity of the result (1 = Parity Even).

V - Contains the Overflow of the result (1 = Overflow).
 0 - RESET = 0.

IN A,(N)

1 - SET = 1. ? - Unknown.

Affected according to the result.

Chapter 5, Page 159

Where:

(N) is the address of the Input Port, in the range Ø to 255.

N (the address of the Input Port) is placed in the Lower Order byte of the Address Bus and the contents of the Accumulator are placed in the Higher Order byte of that Bus. One byte from the Input Port is placed in the Accumulator.

IN r,(C)

Where:

Chapter 5, Page 160

r represents one of the registers A, B, C, D, E, H or L.

The C register contains the address of an Input Port in the range Ø to 255. This Input Port is read and the single byte of data loaded into the nominated register. The Lower Order byte of the address bus is copied from Register C while the Higher Order byte is the previous contents of the B register.

69

Chapter 5, Page 169

This instruction reads, one byte at a time, up to 256 bytes of data from an Input Port and stores that data in consecutive memory locations. The address of the Input Port must be held in the C register (value  $\emptyset$  to 255) and Register B is used as a byte counter so must contain the number of bytes to be read. Register Pair HL must contain the address of the first memory location to be used to store the data. As each byte is read and stored both Register B and Register Pair HL are decremented.

INI

#### Chapter 5, Page 172

Similar to instruction IND except that the contents of Register Pair HL are incremented, rather than decremented, as each byte is stored. Up to 256 bytes of data are read, one byte at a time, from an Input Port and stored in consecutive memory locations. Register C must contain the address (value  $\emptyset$  to 255) of the Input Port and Register B must contain the number of bytes to be read. Register Pair HL must contain the address of the first memory location to be used to store the data. As each byte is read and stored Register B is decremented and Register Pair HL is incremented.

INDR

Identical to IND except:

- 1. If the contents of Register  $B 1 = \emptyset$ , the next instruction is executed.
- 2. If the contents of Register  $B 1 \neq \emptyset$ , the Program Counter (PC) is decremented by 2 and the INDR instruction is repeated.
  - NOTE 1: If the contents of Register b are Ø at the start of this instruction, 256 Bytes of data will be input.

NOTE 2: Interrupts will be recognised after each loop.

#### INIR

Chapter 5, Page 173

Similar to the INDR instruction except that the contents of Register Pair HL are incremented after each execution instead of being decremented.

#### OTDR

Chapter 5, Page 235

Outputs a pre-determined number of bytes of data, one byte at a time, to an output port selected from up to 256 (i.e.,  $\emptyset$  to 255) possible ports. The sequence of events is:

- 1. The data stored in a memory location whose address is held in the Accumulator is temporarily stored in the CPU.
- 2. Register B (used as a byte counter) is decremented and the new (decremented) value placed in the Higher Order byte of the Address Bus.
- 3. The contents of Register C are placed in the Lower Order byte of the Address Bus. This contains the identity of the Output Port to which the data is to be directed, (i.e. a value between Ø and 255).

IND

Chapter 5, Page 170

- 4. The data byte temporarily stored in the CPU is placed on the Data Bus for output to the nominated Output Port.
- 5. Register Pair HL is decremented.
- 6. If Register B is non-zero, the Program Counter (PC) is decremented by 2 and the instruction is executed again. If the value of Register B is zero, the program proceeds with the next sequential instruction.

NOTE 1: If Register B is set to zero prior to the first execution of this instruction then 256 bytes of data will be output.

NOTE 2: Interrupts are permitted after each byte is output.

OTIR

Chapter 5, Page 236

Similar to OTDR except that Register Pair HL is incremented instead of decremented after each data byte is output.

OUT (n), A Where:

Chapter 5, Page 239

(n) is the address of one of 256 (i.e. Ø to 255) Output Ports.

Places the Output Port address (n) in the Lower Order byte of the Address Bus and the contents of the Accumulator in the Higher Order byte of the Address Bus. The contents of the Accumulator are then passed to the selected Output Port.

OUT (C),r Where:

Chapter 5, Page 238

r represents one of the registers A, B, C, D, E, H or L.

Outputs the contents of the nominated register to the Output Port whose identity ( $\emptyset$  to 255) is held in the C Register. The contents of the C Register are placed in the Lower Order byte of the Address Bus.

#### OUTD

Chapter 5, Page 240

Outputs one or more (up to 256) bytes of data from consecutive memory locations to an Output Port identified by the contents of Register C. Register B is used as a byte counter and must therefore contain the number of bytes to be output. Register Pair HL contains the address of the first byte to be output. After each data transfer both Register B and Register Pair HL are decremented.

#### OUTI

Chapter 5, Page 241

This instruction is identical to OUTD except that, after each data transfer, Register Pair HL is incremented instead of decremented.

### **CHAPTER 5**

### Z8Ø Machine Code Instructions

This chapter contains details of each Z80 Machine Code instruction, in Source Code sequence, with the Object Code (Hexadecimal), Bit Pattern, Decimal Code, Flag Register Status, Addressing Mode, Timing and Description of each instruction.

### ADC A,n

Description: Adds the contents of the Accumulator plus the carry bit to n and stores the result in the Accumulator.

No. of Bytes: 2

Object Code (Hex.): CE n Decimal: 206 n

Where n is an 8 Bit value, specified in the instruction.

Bit Pattern

1 1 0 0 1 1 1 0

n

Flag Register:

| Flag            | Code | Bit | Effect                                                             |
|-----------------|------|-----|--------------------------------------------------------------------|
| Sign            | S    | 7   | SET = 1 if the result is negative, otherwise RESET = $\emptyset$ . |
| Zero            | Z    | 6   | SET = 1 if the result is zero, otherwise RESET = $\emptyset$ .     |
|                 |      | 5   | Not used.                                                          |
| Half Carry      | н    | 4   | SET = 1 if Carry from Bit 3, otherwise RESET = $\emptyset$ .       |
| _               | _    | 3   | Not used.                                                          |
| Parity/Overflow | P/V  | 2   | SET = 1 if Overflow, RESET = $\emptyset$ if no overflow.           |
| Subtract        | N    | 1   | $RESET = \emptyset.$                                               |
| Carry           | С    | Ø   | SET = 1 if Carry from Bit 7.                                       |

Cont.

#### Example: LD A,Ø2H SCF ADC A,Ø27H

If the Accumulator contains  $\emptyset$ 2H, the Carry Flag is set, and n in the instruction is 27H, then the result stored in the Accumulator will be  $\emptyset$ 2H + 27H +  $\emptyset$ 1H = 2AH. If the Carry Flag is not set, the result will be  $\emptyset$ 2H + 27H +  $\emptyset$  $\emptyset$ H = 29H.

Addressing Mode: Immediate.

| M Cycles | T States | μsec @ 2 MHz. |
|----------|----------|---------------|
| 2        | 7        | 3.5           |

### ADC A,A

Description: Adds the contents of the Accumulator plus the carry bit to itself and stores the result in the Accumulator.

No. of Bytes: 1

Object Code (Hex.): 8F

Decimal: 143

Flag Register:

| Flag            | Code | Bit | Effect                                                           |
|-----------------|------|-----|------------------------------------------------------------------|
| Sign            | S    | 7   | SET = 1 if the result is negative, otherwise RESET = $\emptyset$ |
| Zero            | Z    | 6   | SET = 1 if the result is zero, otherwise RESET = $\emptyset$     |
| <u> </u>        |      | 5   |                                                                  |
| Half Carry      | н    | 4   | SET = 1 if Carry from Bit 3, otherwise RESET = $\emptyset$       |
| _               | _    | 3   | Not used.                                                        |
| Parity/Overflow | P/V  | 2   | SET = 1 if Overflow, RESET = Ø if no overflow                    |
| Subtract        | N    | 1   | $RESET = \emptyset$                                              |
| Carry           | С    | Ø   | SET = 1 if Carry from BIT 7.                                     |

Example: LD A,Ø3H SCF CCF ADC A,A or LD A,Ø3H SCF

ADC A.A

If the Accumulator contains Ø3H prior to this instruction being executed, and the Carry Flag is reset, the result will be Ø6H. If the carry bit is set, the result will be Ø7H.

Addressing Mode: Implicit.

| M Cycles | T States | μsec @ 2 MHz. |
|----------|----------|---------------|
| 1        | 4        | 2             |

### ADC A,r

Where r is any of the registers B, C, D, E, H or L.

Object Code:

|         | Hex | Decimal |  |
|---------|-----|---------|--|
| ADC A,B | 88  | 136     |  |
| ADC A,C | 89  | 137     |  |
| ADC A,D | 8A  | 138     |  |
| ADC A,E | 8B  | 139     |  |
| ADC A,H | 8C  | 140     |  |
| ADC A,L | 8D  | 141     |  |
|         |     |         |  |

Description: Adds the contents of the Accumulator plus the carry bit to the contents of any of the other registers and stores the result in the Accumulator.

No. of Bytes: 1

Flag Register:

| Flag            | Code | Bit | Effect                                                           |
|-----------------|------|-----|------------------------------------------------------------------|
| Sign            | S    | 7   | SET = 1 if the result is negative, otherwise RESET = $\emptyset$ |
| Zero            | Z    | 6   | SET = 1 if the result is zero, otherwise RESET = $\emptyset$     |
| <u> </u>        | _    | 5   | Not used.                                                        |
| Half Carry      | н    | 4   | SET = 1 if Carry from Bit 3, otherwise RESET = $\emptyset$ .     |
| —               | _    | 3   | Not used.                                                        |
| Parity/Overflow | P/V  | 2   | SET = 1 if Overflow, RESET = $\emptyset$ if no Overflow.         |
| Subtract        | Ν    | 1   | $RESET = \emptyset$                                              |
| Carry           | С    | Ø   | SET = 1 if Carry from Bit 7, otherwise RESET = $\emptyset$       |

Cont.

Example: LD A,01H SCF ADC A,B or LD A,01H SCF CCF ADC A,B

If the Accumulator contains  $\emptyset$ 1H, the Carry Flag is set, and register B contains  $\emptyset$ 2H, the result will be  $\emptyset$ 1H +  $\emptyset$ 1H +  $\emptyset$ 2H =  $\emptyset$ 4H. If the Carry Flag is reset, the result will be  $\emptyset$ 1H +  $\emptyset$ 0H +  $\emptyset$ 2H =  $\emptyset$ 3H.

Addressing Mode: Implicit.

| M Cycles | T States | μsec @ 2 MHz. |
|----------|----------|---------------|
| 1        | 4        | 2             |

# ADC A,(HL)

Description: Adds the contents of the Accumulator plus the Carry Flag to the contents of the memory location whose address is held in Register Pair HL and stores the result in the Accumulator.

No. of Bytes: 2

Object Code (Hex.): 8E

Decimal: 142

Flag Register:

| Flag            | Code | Bit | Effect                                                           |
|-----------------|------|-----|------------------------------------------------------------------|
| Sign            | S    | 7   | SET = 1 if the result is negative, otherwise RESET = $\emptyset$ |
| Zero            | Z    | 6   | SET = 1 if the result is zero, otherwise RESET = $\emptyset$     |
| -               | _    | 5   | Not used.                                                        |
| Half Carry      | Н    | 4   | SET = 1 if Carry from Bit 3, otherwise RESET = $\emptyset$       |
| —               | —    | 3   | Not used.                                                        |
| Parity/Overflow | P/V  | 2   | SET = 1 if Overflow, otherwise RESET = $\emptyset$               |
| Subtract        | N    | 1   | $RESET = \emptyset$                                              |
| Carry           | С    | Ø   | SET = 1 if Carry from BIT 7, otherwise RESET = $\emptyset$ .     |

```
Example: LD A,02H
LD L,04H
LD H,05DH
SCF
ADC A,(HL)
or
LD A,02H
LD L,04H
LD H,05H
SCF
CCF
ADC A,(HL)
```

If the Accumulator contains @2H, the Carry Flag is reset, the H register contains 5DH and the L Register contains @4H then this instruction will add @2H to the contents of memory location 5D @4. If the contents of that location are @3H the result will be @2H + @0H + @3H = @5H. If the carry flag is set, the result will be @2H + @1H + @3H = @6H. The result is stored in the Accumulator, and there is no effect on the contents of the memory location.

Addressing Mode: Indirect.

| M Cycles | T States | μsec @ 2 MHz. |
|----------|----------|---------------|
| 2        | 7        | 3.5           |

### ADC A,(IX+d) ADC A,(IY+d)

Description: Adds the contents of the Accumulator plus the Carry Flag to the contents of a memory location whose address is identified by the contents of Index Register IX or IY (modified by displacement d, which is specified in the instruction) and places the result in the Accumulator.

No. of Bytes: 3

Object Code:

|               | Hex     | Decimal   |
|---------------|---------|-----------|
| ADC A,(IX+d)  | DD 8E d | 221 142 d |
| ADC A, (IY+d) | FD 8E d | 253 142 d |

Where d is the displacement, in bytes, from the memory location whose address is identified by the contents of Index Register IX.

Flag Register:

| Flag            | Code | Bit | Effect                                                           |
|-----------------|------|-----|------------------------------------------------------------------|
| Sign            | S    | 7   | SET = 1 if the result is negative, otherwise RESET = $\emptyset$ |
| Zero            | Z    | 6   | SET = 1 if the result is zero, otherwise RESET = $\emptyset$     |
| _               | _    | 5   | Not used.                                                        |
| Half Carry      | н    | 4   | SET = 1 if Carry from Bit 3, otherwise RESET = $\emptyset$       |
| —               | —    | 3   | Not used.                                                        |
| Parity/Overflow | P/V  | 2   | SET = 1 if Overflow, otherwise RESET $\emptyset$ .               |
| Subtract        | Ν    | 1   | $RESET = \emptyset$                                              |
| Carry           | С    | Ø   | SET = 1 if Carry from BIT 7, otherwise RESET = $\emptyset$ .     |

Cont.

Example: LD IX,3125H LD A,23H SCF ADC (A,(IX + 3) or LD IX,3125H LD A,23H SCF CCF ADC A,(1X + 3)

If the contents of the IX Index Register are 3125H and the value of d is  $\emptyset$ 3H, the content of location 3128H is 15H, the value of the Accumulator is 23H, and the Carry Flag is reset, the result placed in the Accumulator will be 15H +  $\emptyset\emptyset$ H + 23H = 38H. If the Carry Flag is set, the result will be 15H +  $\emptyset$ 1H + 23H = 39H

Addressing Mode: Indexed.

| M Cycles | T States | μsec @ 2 MHz. |
|----------|----------|---------------|
| 5        | 19       | 9.5           |

# ADC HL,rr

Where rr is any of the register pairs BC, DE, HL, SP.

Description: Adds the contents of Register Pair rr to the contents of Register Pair HL plus the Carry Flag, then stores the result in Register Pair HL.

No. of Bytes: 2

Object Code:

|           | Hex   | Decimal         |
|-----------|-------|-----------------|
| ADC HL,BC | ED 4A | 237 Ø74         |
| ADC HL,DE | ED 5A | 237 Ø9Ø         |
| ADC HL,HL | ED 6A | 237 <b>1</b> Ø6 |
| ADC HL,SP | ED 7A | 237 122         |

Flag Register:

| Flag            | Code | Bit | Effect                                                           |
|-----------------|------|-----|------------------------------------------------------------------|
| Sign            | S    | 7   | SET = 1 if the result is negative, otherwise RESET = $\emptyset$ |
| Zero            | Z    | 6   | SET = 1 if the result is zero, otherwise RESET = $\emptyset$     |
| _               | _    | 5   | Not used.                                                        |
| Half Carry      | н    | 4   | SET = 1 if Carry from Bit 11, otherwise RESET = $\emptyset$      |
|                 | _    | 3   | Not used.                                                        |
| Parity/Overflow | P/V  | 2   | $\begin{array}{rllllllllllllllllllllllllllllllllllll$            |
| Subtract        | Ν    | 1   | $RESET = \emptyset$                                              |
| Carry           | С    | Ø   | SET = 1 if Carry from BIT 15, otherwise RESET = $\emptyset$      |

Cont.

Example: LD HL,ØF18H LD BC,3291H SCF ADC HL,BC

If the contents of the BC Register Pair are 3291H and that of the HL Register Pair ØF 18H and the Carry Flag is reset, then the result will be 41A9H which is placed in Register Pair HL. If the Carry Flag is set, the result will be 41AAH.

Addressing Mode: Implicit.

| M Cycles | T States | μsec @ 2 MHz. |
|----------|----------|---------------|
| 4        | 15       | 75            |

# ADD A,n

Description: Adds n to the contents of the Accumulator, then stores the result in the Accumulator.

No. of Bytes: 2

Object Code (Hex.): C6 n Decimal: 198 n

Where n is an 8 Bit value, specified in the instruction.

Flag Register:

| Flag            | Code | Bit | Effect                                                           |
|-----------------|------|-----|------------------------------------------------------------------|
| Sign            | S    | 7   | SET = 1 if the result is negative, otherwise RESET = $\emptyset$ |
| Zero            | Z    | 6   | SET = 1 if the result is zero, otherwise RESET = $\emptyset$     |
|                 | -    | 5   | Not used.                                                        |
| Half Carry      | н    | 4   | SET = 1 if Carry from Bit 3, otherwise RESET = $\emptyset$       |
|                 | _    | 3   | Not used.                                                        |
| Parity/Overflow | P/V  | 2   | $\begin{array}{llllllllllllllllllllllllllllllllllll$             |
| Subtract        | N    | 1   | $RESET = \emptyset$                                              |
| Carry           | С    | Ø   | SET = 1 if Carry from BIT 7, otherwise RESET = $\emptyset$       |

Example: LD A,2AH

ADD A,33H

If the second byte of the instruction contains 33H and the contents of the Accumulator are 2AH, then the result will be 5DH.

Addressing Mode: Immediate.

| M Cycles | T States | μsec @ 2 MHz. |
|----------|----------|---------------|
| 2        | 7        | 3.5           |

# ADD A, r

Where r is any of the registers A, B, C, D, E, H, or L.

Object Code:

|          | Hex | Decimal |  |
|----------|-----|---------|--|
| ADD A,A  | 87  | 135     |  |
| ADD A, B | 8Ø  | 128     |  |
| ADD A,C  | 81  | 129     |  |
| ADD A,D  | 82  | 130     |  |
| ADD A,E  | 83  | 131     |  |
| ADD A,H  | 84  | 132     |  |
| ADD A,L  | 85  | 133     |  |
| ,        |     |         |  |

Description: Adds the contents of the Register r to the contents of the Accumulator and stores the result in the Accumulator. NOTE: in the case of ADD A,A the effect is to double the contents of the Accumulator.

No. of Bytes: 1

Flag Register:

| Flag            | Code | Bit | Effect                                                             |
|-----------------|------|-----|--------------------------------------------------------------------|
| Sign            | S    | 7   | SET = 1 if the result is negative, otherwise RESET = $\emptyset$ . |
| Zero            | Z    | 6   | SET = 1 if the result is zero, otherwise RESET = $\emptyset$ .     |
| _               | _    | 5   | Not used.                                                          |
| Half Carry      | н    | 4   | SET = 1 if Carry from Bit 3, otherwise RESET = $\emptyset$ .       |
| _               | _    | 3   | Not used.                                                          |
| Parity/Overflow | P/V  | 2   | SET = 1 if Overflow, otherwise RESET = $\emptyset$ .               |
| Subtract        | N    | 1   | $RESET = \emptyset.$                                               |
| Carry           | С    | Ø   | SET = 1 if Carry from Bit 7, otherwise RESET = $\emptyset$ .       |

#### Example: LD A,3EH LD B,Ø9H ADD A,B

If the contents of the Accumulator are 3EH and the contents of the B register are Ø8H, the result will be 47H.

Addressing Mode: Implicit.

| M Cycles | T States | μsec @ 2 MHz. |
|----------|----------|---------------|
| 1        | 4        | 2             |

# ADD A,(HL)

Description: Adds the contents of the memory location whose address is held in Register Pair HL to the contents of the Accumulator and stores the result in the Accumulator.

No. of Bytes: 1

Object Code (Hex.): 86

Decimal: 134

Flag Register:

| Flag            | Code | Bit | Effect                                                               |
|-----------------|------|-----|----------------------------------------------------------------------|
| Sign            | S    | 7   | SET = 1 if the result is negative, otherwise RESET = $\emptyset$     |
| Zero            | Z    | 6   | SET = 1 if the result is negative,,<br>otherwise RESET = $\emptyset$ |
| -               | _    | 5   | Not used.                                                            |
| Half Carry      | н    | 4   | SET = 1 if Carry from Bit 3, otherwise RESET = $\emptyset$           |
| _               | _    | 3   | Not used.                                                            |
| Parity/Overflow | P/V  | 2   | SET = 1 if Overflow, otherwise,<br>RESET = $\emptyset$               |
| Subtract        | N    | 1   | $RESET = \emptyset$                                                  |
| Carry           | С    | Ø   | SET = 1 if Carry from BIT 7, otherwise RESET = $\emptyset$ .         |

Example: LD HL,5AØ2H LD (HL),24H LD A,16H ADD A,(HL)

If the contents of Register Pair HL are 5A02H, the contents of that location are 24H and the contents of the Accumulator are 16H, then the result, stored in the Accumulator, is 3AH.

Addressing Mode: Indirect.

| M Cycles | T States | μsec @ 2 MHz. |
|----------|----------|---------------|
| 2        | 7        | 3.5           |

### ADD A,(IX + d)ADD A,(IY + d)

Description: Adds the contents of the memory location identified by the contents of Index Register IX or IY (modified by displacement d, which is specified in the instruction) to the contents of the Accumulator and stores the result in the Accumulator.

No. of Bytes: 3

Object Code:

|                | Hex     | Decimal   |
|----------------|---------|-----------|
| ADD A,(IX + d) | DD 86 d | 221 134 d |
| ADD A,(IY + d) | FD 86 d | 253 134 d |

Where d is the displacement required from the memory location whose address is held in Index Register IX or IY.

Flag Register:

| Flag            | Code | Bit | Effect                                                           |
|-----------------|------|-----|------------------------------------------------------------------|
| Sign            | S    | 7   | SET = 1 if the result is negative, otherwise RESET = $\emptyset$ |
| Zero            | Z    | 6   | SET = 1 if the result is zero, otherwise RESET = $\emptyset$     |
|                 | _    | 5   | Not used.                                                        |
| Half Carry      | н    | 4   | SET = 1 if Carry from Bit 3, otherwise RESET = $\emptyset$       |
|                 |      | 3   | Not used.                                                        |
| Parity/Overflow | P/V  | 2   | SET = 1 if Overflow, otherwise,<br>RESET = $\emptyset$           |
| Subtract        | N    | 1   | $RESET = \emptyset$                                              |
| Carry           | С    | Ø   | SET = 1 if Carry from BIT 7, otherwise RESET = $\emptyset$ .     |

Example: LD IX,122AH LD HL,125AH LD (HL),15H LD A,2AH ADD A,(IX + 30H)

If the contents of Index Register IX are 12 2AH and displacement is 30H, the required memory location is 12 5AH. If the contents of that location are 15H and the contents of the Accumulator are 2AH, then the result, stored in the Accumulator, will be 3FH.

Addressing Mode: Indexed.

| M Cycles | T States | μsec @ 2 MHz. |
|----------|----------|---------------|
| 5        | 19       | 9.5           |

# ADD HL,rr

Where rr is any of the register pairs BC, DE, HL, SP.

Description: Adds the contents of Register Pair rr to the contents of Register Pair HL and stores the result in Register Pair HL.

No. of Bytes: 1

Object Code:

|            | Hex | Decimal     |
|------------|-----|-------------|
| ADD HL,BC  | Ø9  | ØØ9         |
| ADD HL, DE | 19  | <b>Ø2</b> 5 |
| ADD HL,HL  | 29  | Ø41         |
| ADD HL,SP  | 39  | Ø57         |

Flag Register:

| Flag            | Code | Bit | Effect                                                        |
|-----------------|------|-----|---------------------------------------------------------------|
| Sign            | S    | 7   | Not affected.                                                 |
| Zero            | Z    | 6   | Not affected.                                                 |
| _               |      | 5   | Not used.                                                     |
| Half Carry      | Н    | 4   | SET = 1 if Carry from Bit 11, otherwise RESET = $\emptyset$   |
| -               |      | 3   | Not used.                                                     |
| Parity/Overflow | P/V  | 2   | Not affected.                                                 |
| Subtract        | Ν    | 1   | $RESET = \emptyset$                                           |
| Carry           | С    | Ø   | SET = 1 if carry from Bit 15, otherwise RESET = $\emptyset$ . |

Example: LD BC,15ØAH LD HL,2112H ADD HL,BC

If the contents of Register Pair BC are 150AH and the contents of Register Pair HL are 21 12H, the result is 36 1CH.

Addressing Mode: Implicit.

| M Cycles | T States | μsec @ 2 MHz. |
|----------|----------|---------------|
| 3        | 11       | 5.5           |

### ADD IX,BC ADD IY,BC

Description: Adds the contents of Register Pair BC to the contents of Index Register IX or IY and stores the result in Register IX or IY.

No. of Bytes: 2

Object Code:

|           | Hex   | Decimal |
|-----------|-------|---------|
| ADD IX,BC | DD Ø9 | 221 ØØ9 |
| ADD IY,BC | FD Ø9 | 253 ØØ9 |

Flag Register:

| Flag            | Code | Bit | Effect                                                        |
|-----------------|------|-----|---------------------------------------------------------------|
| Sign            | S    | 7   | Not affected.                                                 |
| Zero            | Z    | 6   | Not affected.                                                 |
|                 |      | 5   | Not used.                                                     |
| Half Carry      | н    | 4   | SET = 1 if Carry from Bit 11, otherwise RESET = $\emptyset$   |
|                 |      | 3   | Not used.                                                     |
| Parity/Overflow | P/V  | 2   | Not affected.                                                 |
| Subtract        | N    | 1   | RESET = Ø                                                     |
| Carry           | С    | Ø   | SET = 1 if Carry from BIT 15, otherwise RESET = $\emptyset$ . |

Example: LD BC,1172H LD IX,1012H ADD IX,BC

If the contents of Register Pair BC are 11 72H and the contents of Index Register IX are  $10\,12$ H, the result will be 21 84H.

Addressing Mode: Implicit.

| M Cycles | T States | μsec @ 2 MHz. |
|----------|----------|---------------|
| 4        | 15       | 7.5           |

### ADD IX,DE ADD IY,DE

Description: Adds the contents of Register Pair DE to the contents of Index Register IX or IY and stores the result in Index Register IX or IY.

No. of Bytes: 2

Object Code:

|            | Hex   | Decimal |
|------------|-------|---------|
| ADD IX, DE | DD 19 | 221 Ø25 |
| ADD IY, DE | FD 19 | 253 Ø25 |

Flag Register:

| Flag            | Code | Bit | Effect                          |
|-----------------|------|-----|---------------------------------|
| Sign            | S    | 7   | Not affected.                   |
| Zero            | Z    | 6   | Not affected.                   |
| _               |      | 5   | Not used.                       |
| Half Carry      | н    | 4   | SET = 1 if Carry from Bit 11,   |
|                 |      |     | otherwise RESET = $\emptyset$   |
| —               | —    | 3   | Not used.                       |
| Parity/Overflow | P/V  | 2   | Not affected.                   |
| Subtract        | Ν    | 1   | $RESET = \emptyset$             |
| Carry           | С    | Ø   | SET = 1 if Carry from BIT 15,   |
|                 |      |     | otherwise RESET = $\emptyset$ . |

Example: LD DE,1321H LD IX,2243H ADD IX,DE

If the contents of Register Pair DE are 13 21H and the contents of Index Register IX are 22 43H, the result will be 35 64H.

Addressing Mode: Implicit.

| M Cycles | T States | μsec @ 2 MHz. |
|----------|----------|---------------|
| 4        | 15       | 7.5           |

# ADD IX,IX

Description: Adds the contents of Index Register IX to the contents of Index Register IX and stores the result in Index Register IX, i.e. doubles the contents of that Index Register.

No. of Bytes: 2

Object Code (Hex.): DD 29

Decimal: 221 Ø41.

Flag Register:

| Flag            | Code | Bit | Effect                          |
|-----------------|------|-----|---------------------------------|
| Sign            | S    | 7   | Not affected.                   |
| Zero            | Z    | 6   | Not affected.                   |
|                 | _    | 5   | Not used.                       |
| Half Carry      | н    | 4   | SET = 1 if Carry from Bit 11,   |
|                 |      |     | otherwise RESET = $\emptyset$   |
| -               | —    | 3   | Not used.                       |
| Parity/Overflow | P/V  | 2   | Not affected.                   |
| Subtract        | Ν    | 1   | $RESET = \emptyset$             |
| Carry           | С    | Ø   | SET = 1 if Carry from BIT 15,   |
|                 |      |     | otherwise RESET = $\emptyset$ . |

Example: LD IX,2345H

ADD IX, IX

If the contents of Index Register IX are 23 45H, then the result will be 23 45H + 2345H = 468AH.

Addressing Mode: Implicit.

| M Cycles | T States | μsec @ 2 MHz. |
|----------|----------|---------------|
| 4        | 15       | 7.5           |

### ADD IY,IY

Description: Adds the contents of Index Register IY to the contents of Index Register IY and stores the result in Index Register IY, i.e. doubles the contents of Index Register IY.

No. of Bytes: 2

Object Code (Hex.): FD 29 Decimal: 253 Ø41.

Flag Register:

| Flag            | Code | Bit | Effect                                                        |
|-----------------|------|-----|---------------------------------------------------------------|
| Sign            | S    | 7   | Not affected.                                                 |
| Zero            | Z    | 6   | Not affected.                                                 |
| —               | _    | 5   | Not used.                                                     |
| Half Carry      | Н    | 4   | SET = 1 if Carry from Bit 11,                                 |
|                 |      |     | otherwise RESET = $\emptyset$                                 |
| —               | -    | 3   | Not used.                                                     |
| Parity/Overflow | P/V  | 2   | Not affected.                                                 |
| Subtract        | Ν    | 1   | $RESET = \emptyset$                                           |
| Carry           | С    | Ø   | SET = 1 if Carry from BIT 15, otherwise RESET = $\emptyset$ . |
|                 |      |     |                                                               |

Example: LD IY,1342H

ADD IY.IY

IF the contents of Index Register IY are 13 42H, then the result is 13 42H + 1342H = 2684H.

Addressing Mode: Implicit.

| M Cycles | T States | μsec @ 2 MHz. |
|----------|----------|---------------|
| 4        | 15       | 7.5           |

### ADD IX,SP ADD IY,SP

Description: Adds the contents of the Stack Pointer (Register Pair SP) to the contents of Index Register IX or IY and stores the result in Index Register IX or IY.

No. of Bytes: 2

Object Code:

|            | Hex   | Decimal        |
|------------|-------|----------------|
| ADD IX,SP  | DD 39 | <b>221</b> Ø57 |
| ADD IY, SP | FD 39 | 253 Ø57        |

Flag Register:

| Flag            | Code | Bit | Effect                          |
|-----------------|------|-----|---------------------------------|
| Sign            | S    | 7   | Not affected.                   |
| Zero            | Z    | 6   | Not affected.                   |
|                 | _    | 5   | Not used.                       |
| Half Carry      | н    | 4   | SET = 1 if Carry from Bit 11,   |
|                 |      |     | otherwise RESET = $\emptyset$   |
| —               | _    | 3   | Not used.                       |
| Parity/Overflow | P/V  | 2   | Not affected.                   |
| Subtract        | N    | 1   | $RESET = \emptyset$             |
| Carry           | С    | Ø   | SET = 1 if Carry from BIT 15,   |
|                 |      |     | otherwise RESET = $\emptyset$ . |

Example: LD SP,352BH LD IX,221AH ADD IX,SP

If the contents of the Stack Pointer are 35 2BH and the contents of Index Register IX are 22 1AH, the result will be 35 2BH + 22 1AH = 5745H.

Addressing Mode: Implicit.

| M Cycles | T States | μsec @ 2 MHz. |
|----------|----------|---------------|
| 4        | 15       | 7.5           |

### AND n

Description: Performs a Logical AND on the contents of the Accumulator with n, storing the result in the Accumulator.

No. of Bytes: 2

Object Code (Hex.): E6 n Decimal: 230 n

Where n is an 8 Bit value, specified in the second byte of the instruction.

Flag Register:

| Flag            | Code | Bit    | Effect                                                           |
|-----------------|------|--------|------------------------------------------------------------------|
| Sign            | S    | 7      | SET = 1 if the result is negative, otherwise RESET = $\emptyset$ |
| Zero            | Z    | 6      | SET = 1 if the result is zero, otherwise RESET = $\emptyset$     |
| _               | _    | 5      | Not used.                                                        |
| Half Carry      | н    | 4<br>3 | SET = 1                                                          |
| _               | —    |        | Not used.                                                        |
| Parity/Overflow | P/V  | 2      | SET = 1 for Parity Even, RESET = $\emptyset$ for Parity Odd.     |
| Subtract        | N    | 1      | $RESET = \emptyset$                                              |
| Carry           | С    | Ø      | RESET = Ø                                                        |

Example: LD A,ØA2H AND 38H

If the contents of the Accumulator are A2(Hex). (Bit Pattern 10100010) and the value of n is 38H (Bit Pattern 00111000) this has the effect of masking out Bits 7, 6, 2, 1 and 0 in the Accumulator as follows:

| Accumulator |   | 10100010       |
|-------------|---|----------------|
| n           |   | ØØ111ØØØ       |
| Result      | — | ØØ1ØØØØØ = 20H |

Addressing Mode: Immediate.

| M Cycles | T States | μsec @ 2 MHz. |
|----------|----------|---------------|
| 2        | 7        | 3.5           |

# AND A

Description: Performs a Logical AND on the contents of the Accumulator with the contents of the Accumulator and stores the result in the Accumulator. In practice, the contents of the Accumulator remain unaltered but the condition of the Flag Register Bits may change.

No. of Bytes: 1

Object Code (Hex.): A7

Decimal: 167.

Flag Register:

| Flag            | Code | Bit | Effect                                                             |
|-----------------|------|-----|--------------------------------------------------------------------|
| Sign            | S    | 7   | SET = 1 if the result is negative, otherwise RESET = $\emptyset$ . |
| Zero            | Z    | 6   | SET = 1 if the result is zero, otherwise RESET = $\emptyset$ .     |
|                 |      | 5   | Not used.                                                          |
| Half Carry      | н    | 4   | SET = 1                                                            |
| _               | _    | 3   | Not used.                                                          |
| Parity/Overflow | P/V  | 2   | SET = 1 for Parity Even, RESET = $\emptyset$ for Parity Odd.       |
| Subtract        | N    | 1   | $RESET = \emptyset$                                                |
| Carry           | С    | Ø   | $RESET = \emptyset.$                                               |

Example: LD A, ØC3H

AND A

If the contents of the Accumulator are C3(Hex.) (Bit Pattern 11000011) the Logical AND will perform as follows:

| Accumulator |   | 11000011 |  |
|-------------|---|----------|--|
| Accumulator | _ | 11000011 |  |
|             |   |          |  |

Result — 11000011 = C3H

Note that this has no effect on the value of the A register, but may change the values of the flags. This instruction is used specifically for its affects on the flags. For instance, if we want to RESET the Carry Flag, it is quicker and easier to say AND A than SCF followed by CCF.

Addressing Mode: Implicit.

| M Cycles | T States | μsec @ 2 MHz. |
|----------|----------|---------------|
| 1        | 4        | 2             |

# AND r

Where r is any of the registers B, C, D, E, H or L.

Object Code:

|       | Hex | Decimal |  |
|-------|-----|---------|--|
| AND B | AØ  | 160     |  |
| AND C | A1  | 161     |  |
| AND D | A2  | 162     |  |
| AND E | A3  | 163     |  |
| AND H | A4  | 164     |  |
| AND L | A5  | 165     |  |
|       |     |         |  |

Description: Performs a logical AND on the contents of the Accumulator with the contents of any of the other registers and stores the result in the Accumulator.

No. of Bytes: 1

Flag Register:

| Flag            | Code | Bit | Effect                                                             |
|-----------------|------|-----|--------------------------------------------------------------------|
| Sign            | S    | 7   | SET = 1 if the result is negative, otherwise RESET = $\emptyset$ . |
| Zero            | Z    | 6   | SET = 1 if the result is zero, otherwise RESET = $\emptyset$ .     |
| _               | _    | 5   | Not used.                                                          |
| Half Carry      | н    | 4   | SET = 1.                                                           |
| -               | _    | 3   | Not used.                                                          |
| Parity/Overflow | P/V  | 2   | SET = 1 for Parity Even, RESET = $\emptyset$ for Parity Odd.       |
| Subtract        | N    | 1   | $RESET = \emptyset.$                                               |
| Carry           | С    | Ø   | RESET = Ø.                                                         |

#### Example: LD A,ØA1H LD B,29H AND B

If the contents of the Accumulator are A1(Hex.) (Bit Pattern 10100001) and the contents of Register B are 29H (Bit Pattern 00101001) the Logical AND will perform as follows:

Accumulator — 10100001 Register B — 00101001 Result — 00100001 = 21H

Addressing Mode: Implicit.

| M Cycles | T States | μsec @ 2 MHz. |
|----------|----------|---------------|
| 1        | 4        | 2             |

# AND (HL)

Description: Performs a Logical AND on the contents of the Accumulator with the contents of a memory location whose address is held in Register Pair HL, then stores the result in the Accumulator.

No. of Bytes: 1

Object Code (Hex.): A6

Decimal: 166.

Flag Register:

| Flag            | Code | Bit | Effect                                                             |
|-----------------|------|-----|--------------------------------------------------------------------|
| Sign            | S    | 7   | SET = 1 if the result is negative, otherwise RESET = $\emptyset$ . |
| Zero            | Z    | 6   | SET = 1 if the result is zero, otherwise RESET = $\emptyset$ .     |
|                 | _    | 5   | Not used.                                                          |
| Half Carry      | н    | 4   | SET = 1                                                            |
| _               | _    | 3   | Not used.                                                          |
| Parity/Overflow | P/V  | 2   | SET = 1 for Parity Even, RESET = $\emptyset$ for Parity Odd.       |
| Subtract        | Ν    | 1   | $RESET = \emptyset$                                                |
| Carry           | С    | Ø   | RESET = Ø.                                                         |

Example: LD A,4AH

LD (HL),ØC8H

AND (HL)

If the contents of the Accumulator are 4A(Hex.) (Bit Pattern 01001010) and the contents of the memory location are C8H (Bit Pattern 11001000) the Logical AND will perform as follows:

Accumulator - 01001010 = 4AH Memory Location - 11001000 = C8H Result - 01001000 = 48H

Addressing Mode: Indirect.

| M Cycles | T States | μsec @ 2 MHz. |
|----------|----------|---------------|
| 2        | 7        | 3.5           |

# $\frac{AND (IX + d)}{AND (IY + d)}$

Description: Performs a Logical AND on the contents of the Accumulator with the contents of a memory location whose address is identified by the contents of Index Register IX or IY (modified by displacement d, which is specified in the instruction), then stores the result in the Accumulator.

No. of Bytes: 3

Object Code:

|             | Hex     | Decimal   |
|-------------|---------|-----------|
| AND(IX + d) | DD A6 d | 221 166 d |
| AND(IY + d) | FD A6 d | 253 166 d |

Flag Register:

| Flag            | Code | Bit | Effect                                                             |
|-----------------|------|-----|--------------------------------------------------------------------|
| Sign            | S    | 7   | SET = 1 if the result is negative, otherwise RESET = $\emptyset$ . |
| Zero            | Z    | 6   | SET = 1 if the result is zero, otherwise RESET = $\emptyset$ .     |
| _               | _    | 5   | Not used.                                                          |
| Half Carry      | н    | 4   | SET = 1                                                            |
| _               | _    | 3   | Not used.                                                          |
| Parity/Overflow | P/V  | 2   | SET = 1 for Parity Even, RESET = $\emptyset$ for Parity Odd.       |
| Subtract        | Ν    | 1   | $RESET = \emptyset$                                                |
| Carry           | С    | Ø   | $RESET = \emptyset.$                                               |

#### Example: LD A,7DH LD (IX + 5),6CH AND (IX + 5)

If the contents of the Accumulator are 7D(Hex.) (Bit Pattern 0111101) and the contents of the nominated memory location are 6CH (Bit Pattern 01101100) the Logical AND will perform as follows:

Accumulator-01111101=7DHMemory Location-01101100=6CHResult-01101100=6CH

Addressing Mode: Indexed.

| M Cycles | T States | μsec @ 2 MHz. |
|----------|----------|---------------|
| 5        | 19       | 9.5           |

#### BIT b,r

Description: Tests an individual Bit in the specified Register and sets the Z Flag in the Flag Register to the complement of the specified Bit.

No. of Bytes: 2

Where:

- b identifies the Bit to be tested by the instruction in the range  $\emptyset$  to 7.
- r identifies one of the Registers A, B, C, D, E, H or L which contains the Bit to be tested.

Object Code: (Hex.): CB xx Decimal 203 yyy

Where: xx or yyy are taken from the table below:

|          |                                              | A                                                    |                                              | В                                                    |                                              | С                                                    |                                              | D                                                    |                                              | E                                                    |                                              | Н                                                    |                                              | L                                                    |
|----------|----------------------------------------------|------------------------------------------------------|----------------------------------------------|------------------------------------------------------|----------------------------------------------|------------------------------------------------------|----------------------------------------------|------------------------------------------------------|----------------------------------------------|------------------------------------------------------|----------------------------------------------|------------------------------------------------------|----------------------------------------------|------------------------------------------------------|
| Bit      | xx                                           | ууу                                                  |
| Ø1234567 | 47<br>4F<br>57<br>5F<br>67<br>6F<br>77<br>7F | Ø71<br>Ø79<br>Ø87<br>Ø95<br>103<br>111<br>119<br>127 | 40<br>48<br>50<br>58<br>60<br>68<br>70<br>78 | Ø64<br>Ø72<br>Ø8Ø<br>Ø88<br>Ø96<br>1Ø4<br>112<br>12Ø | 41<br>49<br>51<br>59<br>61<br>69<br>71<br>79 | Ø65<br>Ø73<br>Ø81<br>Ø89<br>Ø97<br>1Ø5<br>113<br>121 | 42<br>4A<br>52<br>5A<br>62<br>6A<br>72<br>7A | Ø66<br>Ø74<br>Ø82<br>Ø9Ø<br>Ø98<br>1Ø6<br>114<br>122 | 43<br>4B<br>53<br>5B<br>63<br>6B<br>73<br>7B | Ø67<br>Ø75<br>Ø83<br>Ø91<br>Ø99<br>1Ø7<br>115<br>123 | 44<br>4C<br>54<br>5C<br>64<br>6C<br>74<br>7C | Ø68<br>Ø76<br>Ø84<br>Ø92<br>1ØØ<br>1Ø8<br>116<br>124 | 45<br>4D<br>55<br>5D<br>65<br>6D<br>75<br>7D | Ø69<br>Ø77<br>Ø85<br>Ø93<br>1Ø1<br>1Ø9<br>117<br>125 |

| Flag            | Code | Bit | Effect                                                                          |
|-----------------|------|-----|---------------------------------------------------------------------------------|
| Sign            | S    | 7   | Unknown.                                                                        |
| Zero            | Z    | 6   | SET = 1 if Bit B of Register R is $\emptyset$ , otherwise RESET = $\emptyset$ . |
| _               |      | 5   | Not used.                                                                       |
| Half Carry      | н    | 4   | SET = 1.                                                                        |
| _               |      | 3   | Not used.                                                                       |
| Parity/Overflow | P/V  | 2   | Unknown.                                                                        |
| Subtract        | N    | 1   | $RESET = \emptyset.$                                                            |
| Carry           | С    | Ø   | Not affected.                                                                   |

Example: LD C, 101001BBIT 3,C If bit 3 or the C register is set, BIT 3,C will leave the Z Flag = 0. (BIT 3,C produces the Object Code CB 59.)

Addressing Mode: Indexed

| M Cycles | T States | μsec @ 2 MHz. |
|----------|----------|---------------|
| 2        | 8        | 4             |

### BIT b, (HL)

Where b is any value from Ø to 7.

Object Code:

|                                                                                                | Hex                                                         | Decimal                                                                   |  |
|------------------------------------------------------------------------------------------------|-------------------------------------------------------------|---------------------------------------------------------------------------|--|
| BIT Ø,(HL)<br>BIT 1,(HL)<br>BIT 2,(HL)<br>BIT 3,(HL)<br>BIT 4,(HL)<br>BIT 5,(HL)<br>BIT 6,(HL) | CB 46<br>CB 4E<br>CB 56<br>CB 5E<br>CB 66<br>CB 6E<br>CB 76 | 203 070<br>203 078<br>203 086<br>203 094<br>203 102<br>203 110<br>203 118 |  |
| BIT 7,(HL)                                                                                     | CB 7E                                                       | 203 126                                                                   |  |

Description: Tests the appropriate Bit b of a memory location whose address is held in Register Pair HL and sets the Z Flag in the Flag Register to the complement of that Bit.

No. of Bytes: 2

| Flag            | Code | Bit | Effect                                                                      |
|-----------------|------|-----|-----------------------------------------------------------------------------|
| Sign            | S    | 7   | Unknown.                                                                    |
| Zero            | Z    | 6   | SET = 1 if Bit $\emptyset = \emptyset$ , otherwise<br>RESET = $\emptyset$ . |
| —               |      | 5   | Not used.                                                                   |
| Half Carry      | н    | 4   | SET = 1.                                                                    |
| _               | —    | 3   | Not used.                                                                   |
| Parity/Overflow | P/V  | 2   | Unknown.                                                                    |
| Subtract        | N    | 1   | $RESET = \emptyset.$                                                        |
| Carry           | С    | Ø   | Not affected.                                                               |

#### Example: LD HL,26A1H LD (HL), $\emptyset$ BIT $\emptyset$ ,(HL) If the contents of Register Pair HL are 26 A1(Hex.) and Bit $\emptyset$ of memory address 26 A1 contains a $\emptyset$ , then the Z Flag is SET = 1.

Addressing Mode: Indirect.

| M Cycles | T States | μsec @ 2 MHz. |
|----------|----------|---------------|
| 3        | 12       | 6             |

#### BIT b, (IX + d)

Where d is the required displacement from the memory location whose address is held in Index Register IX.

Object Code:

|                                                                                                                                           | Hex                                                                                                          | Decimal                                                                                                                              |  |
|-------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------|--|
| $BIT \emptyset, (IX + d) BIT 1, (IX + d) BIT 2, (IX + d) BIT 3, (IX + d) BIT 4, (IX + d) BIT 5, (IX + d) BIT 6, (IX + d) BIT 7, (IX + d)$ | DD CB d 46<br>DD CB d 4E<br>DD CB d 56<br>DD CB d 5E<br>DD CB d 66<br>DD CB d 6E<br>DD CB d 76<br>DD CB d 7E | 221 203 d 070<br>221 203 d 078<br>221 203 d 086<br>221 203 d 094<br>221 203 d 102<br>221 203 d 110<br>221 203 d 118<br>221 203 d 126 |  |

Description: Tests Bit b of the contents of a memory location identified by the contents of Index Register IX (modified by the two's complement displacement d, which is specified in the instruction), then sets the Z Flag in the Flag Register to the complement of that Bit b.

No. of Bytes: 4

| Flag            | Code | Bit | Effect                                                                      |
|-----------------|------|-----|-----------------------------------------------------------------------------|
| Sign            | S    | 7   | Unknown.                                                                    |
| Zero            | Z    | 6   | SET = 1 if Bit $\emptyset = \emptyset$ , otherwise<br>RESET = $\emptyset$ . |
| _               |      | 5   | Not used.                                                                   |
| Half Carry      | н    | 4   | SET = 1.                                                                    |
| -               | _    | 3   | Not used.                                                                   |
| Parity/Overflow | P/V  | 2   | Unknown.                                                                    |
| Subtract        | N    | 1   | $RESET = \emptyset.$                                                        |
| Carry           | С    | Ø   | Not affected.                                                               |

Example: LD, HL, **1200**H LD (HL),5 LD IX, **11**FCH BIT 2, (IX + 4)

If Bit 2 of the nominated memory location contains a 1, then the Z Flag is RESET =  $\emptyset$ .

Addressing Mode: Indexed.

| M Cycles | T States | μsec @ 2 MHz. |
|----------|----------|---------------|
| 5        | 2Ø       | 1Ø            |

#### BIT b, (IY + d)

Where D is the required displacement from the memory location whose address is held in Index Register IY.

Object Code:

|                 | Hex        | Decimal       |
|-----------------|------------|---------------|
| BIT Ø, (IY + d) | FD CB d 46 | 253 203 d 070 |
| BIT 1, (IY + d) | FD CB d 4E | 253 203 d 078 |
| BIT 2, (IY + d) | FD CB d 56 | 253 203 d 086 |
| BIT 3, (IY + d) | FD CB d 5E | 253 203 d 094 |
| BIT 4, (IY + d) | FD CB d 66 | 253 203 d 102 |
| BIT 5, (IY + d) | FD CB d 66 | 253 203 d 110 |
| BIT 6, (IY + d) | FD CB d 76 | 253 203 d 118 |
| BIT 7, (IY + d) | FD CB d 7E | 253 203 d 126 |

Description: Tests Bit b of the contents of a memory location identified by the contents of Index Register IY (modifed by the two's complement displacement D, which is specified in the instruction), then sets the Z Flag in the Flag Register to the complement of that Bit b.

No. of Bytes: 4

| Flag            | Code | Bit | Effect                                                                      |
|-----------------|------|-----|-----------------------------------------------------------------------------|
| Sign            | S    | 7   | Unknown.                                                                    |
| Zero            | Z    | 6   | SET = 1 if Bit $\emptyset = \emptyset$ , otherwise<br>RESET = $\emptyset$ . |
| _               | _    | 5   | Not used.                                                                   |
| Half Carry      | н    | 4   | SET = 1.                                                                    |
| _               | _    | 3   | Not used.                                                                   |
| Parity/Overflow | P/V  | 2   | Unknown.                                                                    |
| Subtract        | N    | 1   | $RESET = \emptyset.$                                                        |
| Carry           | С    | Ø   | Not affected.                                                               |

Example: LD HL,101H LD IY,100H LD (HL),44H BIT 3,(IY + 1)

If Bit 3 of the nominated memory location contains a  $\emptyset$ , then the Z Flag is SET = 1.

Addressing Mode: Indexed.

| M Cycles | T States | μsec @ 2 MHz. |
|----------|----------|---------------|
| 5        | 20       | 1Ø            |

#### CALL nn

Description: Calls a sub-routine whose address is specified in the second and third bytes of the instruction (nn). The existing contents of the Program Counter (PC) are pushed on to the top of the Memory Stack and the sub-routine address nn loaded into the Program Counter. The second byte of the instruction contains the Lower Order byte of the sub-routine address while the third byte contains the Higher Order byte of that address.

NOTE: To return from the sub-routine to the main program, a RET instruction must be included in the sub-routine code.

No. of Bytes: 3

Object Code (Hex.): CD n n Decimal: 205 n n

Where nn is the memory location to which control is to be transferred.

Flag Register: None of the flags is affected.

Example: If the existing contents of the Program Counter are 25 BA (Hex.) and the top of the Memory Stack is at location 48 18(Hex.), then the Stack Pointer (SP) will contain address 48 18H. If a CALL instruction then quotes a sub-routine address 32 AA, the current contents of the Program Counter will be placed in memory locations 48 16 and 48 17 (i.e. on top of the memory stack) and the contents of the Stack Pointer will be changed to 48 16H. The contents of the second and third bytes of the instruction are then placed in the Program Counter, which will then contain 32 AAH.

|                |                                                       | <br>                                      |                                         |
|----------------|-------------------------------------------------------|-------------------------------------------|-----------------------------------------|
| Object<br>Code |                                                       | Before                                    | After                                   |
| CD AA 32       | PC<br>SP<br>Loc'n 48 16<br>Loc'n 48 17<br>Loc'n 48 18 | <br>25 BA<br>48 18<br>?<br>?<br>Unchanged | 32 AA<br>48 16<br>BA<br>25<br>Unchanged |
|                |                                                       |                                           |                                         |

NOTE: The Lower Order byte of the original contents of the Program Counter is placed in the higher of the two new memory locations at the top of the Memory Stack and the Stack Pointer (SP) will therefore contain the address of that Lower Order byte.

| M Cycles | T States | μsec @ 2 MHz. |
|----------|----------|---------------|
| 5        | 17       | 8.5           |

#### CALL C,nn

Description: If the C Flag in the Flag Register indicates a Carry (i.e. = 1), this instruction CALLS a sub-routine whose address is specified in the second and third bytes of the instruction. If the C Flag contains  $\emptyset$  the instruction is ignored. If the condition is met (C = 1), the existing contents of the Program Counter (PC) are pushed on the top of the Memory Stack and the sub-routine address nn loaded into the Program Counter. To return from the sub-routine a RET instruction should be included in the sub-routine code.

NOTE: The second byte of the Object Code instruction contains the Lower Order byte of the address and the third byte contains the Higher Order byte of that address.

No. of Bytes: 3

Object Code (Hex.): DC n n Decimal: 220 n n

Where nn is the memory location to which control is to be transferred if the condition is met, i.e. True

Flag Register: None of the flags is affected.

Example: SCF

CALL C,2425H

If the C Flag = 1 (Carry), the existing contents of the Program Counter are 42 35 and the top of the Memory Stack is at memory location 46 2B, then he Stack Pointer (SP) will contain address 46 2B. If the CALL C nn instruction quotes address 24 25, then the current contents of the Program Counter (42 35) are placed in memory locations 46 2A (Higher Order byte) and 46 29 (lower Order byte), the Stack Pointer is changed to 46 29 and address 24 25 (nn in the instruction) is placed in the Program Counter.

| - |          |             |   |           |           |
|---|----------|-------------|---|-----------|-----------|
|   | Object   |             |   |           |           |
|   | Code     |             |   | Before    | After     |
| Γ | D4 25 24 | PC          | _ | 42 35     | 24 25     |
|   |          | SP          |   | 46 2B     | 46 29     |
|   |          | Loc'n 46 29 |   | ?         | 35        |
|   |          | Loc'n 46 2A |   | ?         | 42        |
|   |          | Loc'n 46 2B | _ | Unchanged | Unchanged |
| 1 |          |             |   |           |           |

| Timing:          | M Cycles | T States | μsec @ 2 MHz. |
|------------------|----------|----------|---------------|
| Condition True   | 5        | 17       | 8.5           |
| Condition Untrue | 3        | 1Ø       | 5             |

#### CALL NC.nn

Description: If the C Flag in the Flag Register indicates a No Carry (i.e. = 0), this instruction CALLS a sub-routine whose address is specified in the second and third bytes of the instruction. If the C Flag contains 1 the instruction is ignored. If the condition is met  $(C = \emptyset)$ , the existing contents of the Program Counter (PC) are pushed on the top of the Memory Stack and the sub-routine address nn loaded into the Program Counter. To return from the sub-routine, a RET instruction should be included in the sub-routine code.

NOTE: The second byte of the Object Code instruction contains the Lower Order byte of the address and the third byte contains the Higher Order byte.

No. of Bytes: 3

Object Code (Hex.): D4 n n Decimal: 212 n n

Where nn is the memory location to which control is to be transferred if the condition is met. i.e. True

Flag Register: None of the flags is affected.

Example: SCF CCF

CALL NC.1245H

If the C Flag =  $\emptyset$  (No Carry), the existing contents of the Program Counter are 45 A3 and the top of the Memory Stack is at memory location 56 78, then the Stack Pointer (SP) will contain address 56 78. If the CALL NC nn instruction guotes address 12 45, then the current contents of the Program Counter (45 A3) are placed in memory locations 56 77 (Higher Order byte) and 56 76 (Lower Order byte), the Stack Pointer is changed to 56 76 and address 12 45 (nn in the instruction) is placed in the Program Counter.

| Object<br>Code |             |   | Before    | After     |
|----------------|-------------|---|-----------|-----------|
| D4 45 12       | PC          |   | 45 A3     | 12 45     |
|                | SP          |   | 56 78     | 56 76     |
|                | Loc'n 56 76 |   | ?         | A3        |
|                | Loc'n 56 77 |   | ?         | 45        |
|                | Loc'n 56 78 | _ | Unchanged | Unchanged |
|                |             |   |           | -         |

| liming:          | M Cycles | T States | µsec @ 2 MHz. |
|------------------|----------|----------|---------------|
| Condition True   | 5        | 17       | 8.5           |
| Condition Untrue | 3        | 10       | 5             |

#### CALL P,nn

Description: If the S Flag in the Flag Register indicates a Positive sign condition (i.e. =  $\emptyset$ ), this instruction CALLS a sub-routine whose address is specified in the second and third bytes of the instruction. If the S Flag contains a 1 the instruction is ignored. If the condition is met (S Flag =  $\emptyset$ ), the existing contents of the Program Counter (PC) are pushed on to the top of the Memory Stack and sub-routine address nn is loaded into the Program Counter. To return from the sub-routine a RET instruction should be included in the sub-routine code.

NOTE: The second byte of the Object Code instruction contains the Lower Order byte of the address and the third byte contains the Higher Order byte of that address.

No. of Bytes: 3

Object Code (Hex.): F4 n n Decimal: 244 n n

Where nn is the memory location to which control is to be transferred if the condition is met, i.e. True.

Flag Register: None of the flags is affected.

Example: LD A,Ø ADD A,1 CALL P.2244H

If the S Flag =  $\emptyset$  (Sign Positive), the existing contents of the Program Counter are 15 67 and the top of the Memory Stack is at location 32 46, then the Stack Pointer (SP) will contain address 32 46. If the CALL P,nn instruction quotes address 22 44, then the current contents of the Program Counter (15 67) are placed in memory locations 32 45 (Higher Order byte) and 32 44 (Lower Order byte), the Stack Pointer is changed to 32 44 and address 22 44 (nn in the instruction) is placed in the Program Counter.

| Object<br>Code |                                                       | <br>Before                                | After                      |
|----------------|-------------------------------------------------------|-------------------------------------------|----------------------------|
| F4 44 22       | PC<br>SP<br>Loc'n 32 44<br>Loc'n 32 45<br>Loc'n 32 46 | <br>15 67<br>32 46<br>?<br>?<br>Unchanged | 22 44<br>32 44<br>67<br>15 |

|                  | M Cycles | T States | μsec @ 2 MHz. |
|------------------|----------|----------|---------------|
| Condition True   | 5        | 17       | 8.5           |
| Condition Untrue | 3        | 1Ø       | 5             |

#### CALL M,nn

Description: If the S Flag in the Flag Register indicates a Negative condition (i.e. = 1), this instruction CALLS a sub-routine whose address is specified in the second and third bytes of the instruction. If the S Flag contains a  $\emptyset$  the instruction is ignored. If the condition is met (S Flag = 1), the existing contents of the Program Counter (PC) are pushed on to the top of the Memory Stack and sub-routine address nn is loaded into the Program Counter. To return from the sub-routine a RET instruction should be included in the sub-routine code.

NOTE: The second byte of the Object Code instruction contains the Lower Order byte of the address and the third byte contains the Higher Order byte of that address.

No. of Bytes: 3

Object Code (Hex.): FC n n Decimal: 252 n n

Where nn is the memory location to which control is to be transferred if the condition is met, i.e. True.

Flag Register: None of the flags is affected.

Example: LD A,0 SUB A,1 CALL M,3814H

If the S Flag = 1 (Sign Negative), the existing contents of the Program Counter are 42 24 and the top of the Memory Stack is at location 9A 21, then the Stack Pointer (SP) will contain address 9A 21. If the CALL M,nn instruction quotes address 38 14, then the current contents of the Program Counter (42 24) are placed in memory locations 9A 20 (Higher Order byte) and 9A 1F (Lower Order byte), the Stack Pointer is changed to 9A 1F and address 38 14 (nn in the instruction) is placed in the Program Counter.

|   | Object<br>Code |             |   | Before    | After |
|---|----------------|-------------|---|-----------|-------|
| Γ | FC 14 38       | PC          |   | 42 24     | 38 14 |
|   |                | SP          |   | 9A 21     | 9A 1F |
|   |                | Loc'n 9A 1F |   | ?         | 38    |
|   |                | Loc'n 9A 2Ø |   | ?         | 14    |
| L |                | Loc'n 9A 21 | _ | Unchanged | k     |

| Timing:          | M Cycles | T States | μsec @ 2 MHz. |
|------------------|----------|----------|---------------|
| Condition True   | 5        | 17       | 8.5           |
| Condition Untrue | 3        | 10       | 5             |

#### CALL Z,nn

Description: If the Z Flag in the Flag Register indicates Zero (i.e. = 1) this instruction CALLS a sub-routine whose address is specified in the second and third bytes of the instruction. If the Z Flag contains a  $\emptyset$  the instruction is ignored. If the condition is met (Z = 1) the existing contents of the Program Counter (PC) are pushed on to the top of the Memory Stack and sub-routine address nn is loaded into the Program Counter. To return from the sub-routine a RET instruction should be included in the sub-routine code.

NOTE: The second byte of the Object Code instruction contains the Lower Order byte of the address and the third byte contains the Higher Order byte of that address.

No. of Bytes: 3

Object Code (Hex.): CC n n Decimal: 204 n n

Where nn is the memory location to which control is to be transferred if the condition is met

Flag Register: None of the flags is affected.

Example: SUB A,A

CALL Z,7639H

If the Z Flag = 1, the existing contents of the Program Counter are 2A 26 and the top of the Memory Stack is at location 58 2C, then the Stack Pointer (SP) will contain address 58 2C. If the CALL Z nn instruction quotes address 76 34, then the current contents of the Program Counter (2A 26) are placed in memory locations 58 2B (Higher Order byte) and 58 SA (Lower Order byte), the Stack Pointer is changed to 58 2A and address 67 34 (nn int he instruction) is placed in the Program Counter.

| Object<br>Code |                                                       | Before                                    | After                                   |
|----------------|-------------------------------------------------------|-------------------------------------------|-----------------------------------------|
| CC 34 76       | PC<br>SP<br>Loc'n 58 2A<br>Loc'n 58 2B<br>Loc'n 58 2C | <br>2A 26<br>58 2C<br>?<br>?<br>Unchanged | 34 76<br>58 2A<br>26<br>2A<br>Unchanged |

Addressing Mode: Immediate.

| rinnig.          | M Cycles | T States | μsec @ 2 MHz. |
|------------------|----------|----------|---------------|
| Condition True   | 5        | 17       | 8.5           |
| Condition Untrue | 3        | 1Ø       | 5             |

#### CALL NZ,nn

Description: If the Z Flag in the Flag Register indicates a Non-Zero (i.e.  $= \emptyset$ ) this instruction CALLS a sub-routine whose address is specified in the second and third bytes of the instruction. If the Z Flag = 1 the instruction is ignored.

NOTE: The second byte of the Object Code instruction contains the Lower Order byte of the address and the third byte contains the Higher Order byte.

If the condition is met, the existing contents of the Program Counter (PC) are pushed on to the top of the Memory Stack and the sub-routine address (nn) loaded into the Program Counter. To return from the sub-routine to the main program, a RET instruction should be included in the sub-routine code.

No. of Bytes: 3

Object Code (Hex.): C4 n n Decimal: 196 n n

Where nn is the memory location to which control is to be transferred if the condition is met.

Flag Register: None of the flags is affected.

Example: LD A,Ø

ADD A,1

CALL NZ,3521H

If the Z Flag =  $\emptyset$ , the existing contents of the Program Counter are 17 14(Hex.) and the top of the Memory Stack is at memory location 28 1A, then the Stack Pointer (SP) will contain address 28 1A. If the CALL NZ nn instruction quotes sub-routine address 35 21, the current contents of the Program Counter (17 14) are placed in memory locations 28 19 (Higher Order byte) and 28 18 (Lower Order byte), the Stack Pointer is changed to 28 18 and address 35 21 (nn in the instruction) is placed in the Program Counter.

| Object   |             |               |           |
|----------|-------------|---------------|-----------|
| Code     |             | <br>Before    | After     |
| C4 35 21 |             |               |           |
|          | PC          | <br>17 14     | 35 21     |
|          | SP          | <br>28 1A     | 28 18     |
|          | Loc'n 28 18 | <br>?         | 14        |
|          | Loc'n 28 19 | <br>?         | 17        |
|          | Loc'n 28 1A | <br>Unchanged | Unchanged |

|                  | M Cycles | T States | μsec @ 2 MHz. |
|------------------|----------|----------|---------------|
| Condition True   | 5        | 17       | 8.5           |
| Condition Untrue | 3        | 10       | 5             |

#### CALL PE,nn

Description: If the P/V Flag in the Flag Register indicates a Parity Even condition (i.e. = 1), this instruction CALLS a sub-routine whose address is specified in the second and third bytes of the instruction. If the P/V Flag contains a  $\emptyset$  the instruction is ignored. If the condition is met (P/V = 1), the existing contents of the Program Counter (PC) are pushed on to the top of the Memory Stack and sub-routine address nn is loaded into the Program Counter. To return from the sub-routine a RET instruction should be included in the sub-routine code.

NOTE: The second byte of the Object Code instruction contains the Lower Order byte of the address and the third byte contains the

Higher Order byte of that address.

No. of Bytes: 3

Object Code (Hex.): EC n n Decimal: 236 n n

Where nn is the memory location to which control is to be transferred if the condition is met, i.e. True.

Flag Register: None of the flags is affected.

Example: LD A,Ø AND 1BH CALL PE,12DFH

If the P/V Flag = 1 (Parity Even), the existing contents of the Program Counter e 68 54 and the top of the Memory Stack is at location 35 9A, then the Stack Pointer (SP) will contain address 35 9A. If the CALL PE,nn instruction quotes address 12 DF, then the current contents of the Program Counter (68 54) are placed in memory locations 35 99 (Higher Order byte) and 35 98 and (Lower Order byte), the Stack Pointer is changed to 35 98 and address 12 DF (nn in the instruction) is placed in the Program Counter.

| Object<br>Code |             |   | Before    | After |
|----------------|-------------|---|-----------|-------|
| EC DF 12       |             | _ | 68 54     | 12 DF |
|                | SP          |   | 35_9A     | 35_98 |
|                | Loc'n 35 98 | — | ?         | 54    |
|                | Loc'n 35 99 |   | ?         | 68    |
|                | Loc'n 35 9A | _ | Unchanged |       |

Addressing Mode: Immediate.

| Timing:          | M Cycles | T States | μsec @ 2 MHz. |
|------------------|----------|----------|---------------|
| Condition True   | 5        | 17       | 8.5           |
| Condition Untrue | 3        | 1Ø       | 5             |

#### CALL PO,nn

Description: If the P/V Flag in the Flag Register indicates a Parity Odd condition (i.e. =  $\emptyset$ ), this instruction CALLS a sub-routine whose address is specified in the second and third bytes of the instruction. If the P/V Flag contains a 1 the instruction is ignored. If the condition is met (P/V =  $\emptyset$ ), the existing contents of the Program Counter (PC) are pushed on to the top of the Memory Stack and sub-routine address nn is loaded into the Program Counter. To return from the sub-routine, a RET instruction should be included in the sub-routine code.

NOTE: The second byte of the Object Code instruction contains the Lower Order byte of the address and the third byte contains the Higher Order byte of that address.

No. of Bytes: 3

Object Code (Hex.): E4 n n Decimal: 228 n n

Where nn is the memory location to which control is to be transferred if the condition is met, i.e. True.

Flag Register: None of the flags is affected.

Example: LD A,Ø AND 19H CALL PO,3A4FH

If the P/V Flag =  $\emptyset$  (Parity Odd), the existing contents of the Program Counter are 13 31 and the top of the Memory Stack is at location 18  $\emptyset$ 5, then the Stack Pointer (SP) will contain address 18  $\emptyset$ 5. If the CALL PO,nn instruction quotes address 3A 4F, then the current contents of the Program Counter (13 31) are placed in memory locations 18  $\emptyset$ 4 (Higher Order byte) and 18  $\emptyset$ 3 (Lower Order byte), the Stack Pointer is changed to 18  $\emptyset$ 3 and address 3A 4F (nn in the instruction) is placed in the Program Counter.

| Object   |                     |               |           |
|----------|---------------------|---------------|-----------|
| Code     |                     | Before        | After     |
| E4 4F 3A | PC                  | <br>13 31     | 3A 4F     |
|          | SP                  | <br>18 Ø5     | 18 Ø3     |
|          | Loc'n 18 Ø3         | <br>?         | 31        |
|          | Loc'n 18 Ø4         | <br>?         | 13        |
|          | Loc'n <b>18 Ø</b> 5 | <br>Unchanged | Unchanged |

Addressing Mode: Immediate.

| nming:           | M Cycles | T States | μsec @ 2 MHz. |
|------------------|----------|----------|---------------|
| Condition True   | 5        | 17       | 8.5           |
| Condition Untrue | 3        | 1Ø       | 5             |

#### CCF

Description: Complements the Carry (C) Flag in the Flag Register, i.e. if the existing content is 1, it is changed to  $\emptyset$ ; if the existing content is  $\emptyset$ , it is changed to 1.

No. of Bytes: 1

Object Code (Hex.): 3F

Decimal: Ø63

Flag Register:

| Flag                                                                         | Code                         | Bit                                  | Effect                                                                                                                                                                     |
|------------------------------------------------------------------------------|------------------------------|--------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Sign<br>Zero<br>—<br>Half Carry<br>—<br>Parity/Overflow<br>Subtract<br>Carry | S<br>Z<br>H<br>P/V<br>N<br>C | 7<br>6<br>5<br>4<br>3<br>2<br>1<br>Ø | Not affected.<br>Not affected.<br>Not used.<br>Previous carry status<br>Not used.<br>Not affected.<br>RESET = $\emptyset$<br>SET = 1 if previous content was $\emptyset$ , |
|                                                                              |                              |                                      | otherwise RESET = $\emptyset$ .                                                                                                                                            |

Addressing Mode: Implicit.

| M Cycles | T States | μsec @ 2 MHz. |
|----------|----------|---------------|
| 1        | 4        | 2             |

### CP n

Description: Compares the contents of the Accumulator with the 8 Bit value n and sets a flag according to the result.

No. of Bytes: 2

Object Code (Hex.): FE n Decimal: 254 n

Where n is an 8 Bit value, specified in the instruction.

Flag Register:

| Flag            | Code | Bit | Effect                                                                  |
|-----------------|------|-----|-------------------------------------------------------------------------|
| Sign            | S    | 7   | SET = 1 if the result is negative, otherwise RESET = $\emptyset$        |
| Zero            | Z    | 6   | SET = 1 if the result is $\emptyset$ , otherwise<br>RESET = $\emptyset$ |
| _               | _    | 5   | Not used.                                                               |
| Half Carry      | н    | 4   | SET = 1 if no Borrow from Bit 4, otherwise RESET = $\emptyset$          |
| —               | —    | 3   | Not used.                                                               |
| Parity/Overflow | P/V  | 2   | SET = 1 if Overflow, otherwise RESET $\emptyset$ .                      |
| Subtract        | Ν    | 1   | SET = 1                                                                 |
| Carry           | С    | Ø   | SET = 1 if no Borrow, otherwise RESET = $\emptyset$ .                   |

Example: LD A,127 CP 129

If the contents of the Accumulator are 127 (Decimal) and the value on n in the instruction is 129, then n (129) is subtracted from 127 giving a result of -2. The S Flag and the N Flag are both SET = 1 and Flags Z, H, P/V and C are all RESET =  $\emptyset$ . The contents of the Accumulator remain unchanged and the result is discarded.

Addressing Mode: Immediate.

| T States | μsec @ 2 MHz. |  |
|----------|---------------|--|
| 7        | 3.5           |  |
|          | T States<br>7 |  |

#### **CP**A

Description: Compares the contents of the Accumulator with the contents of the Accumulator and sets a flag or flags according to the result. The contents of the Accumulator remain unchanged and the result is discarded.

NOTE: The result of this instruction must always be zero.

No. of Bytes: 1

Object Code (Hex.): BF Decimal: 191

Flag Register:

| Flag            | Code | Bit | Effect                                                                                                                |
|-----------------|------|-----|-----------------------------------------------------------------------------------------------------------------------|
| Sign            | S    | 7   | SET = 1 if the result is negative, otherwise RESET = $\emptyset$                                                      |
| Zero            | Z    | 6   | SET = 1 if the result is $\emptyset$ , otherwise<br>RESET = $\emptyset$ . In practice this will<br>always be SET = 1. |
| _               | —    | 5   | Not used.                                                                                                             |
| Half Carry      | н    | 4   | SET = 1 if no Borrow from Bit 4, otherwise RESET = $\emptyset$                                                        |
| -               | —    | 3   | Not used.                                                                                                             |
| Parity/Overflow | P/V  | 2   | SET = 1 if Overflow, otherwise<br>RESET $\emptyset$ . In practice this will<br>always be RESET = $\emptyset$ .        |
| Subtract        | Ν    | 1   | SET = 1                                                                                                               |
| Carry           | С    | Ø   | SET = 1 if no Borrow, otherwise<br>RESET = $\emptyset$ . In practice this will<br>always be RESET = $\emptyset$ .     |

Example: LD A,23H CP A

If the contents of the Accumulator are 23H the result is calculated as  $23H - 23H = \emptyset$ . Flags Z, H, N and C are SET = 1 and flags S and P/V are RESET = 0.

Addressing Mode: Immediate.

**Fiming**:

| M Cycles | T States μsec @ 2 MHz |   |
|----------|-----------------------|---|
| 1        | 4                     | 2 |

#### CP r

Where r is one of the registers B, C, D, E, H, L.

Description: Compares the contents of Register B with the contents of the Accumulator and sets a flag or flags according to the result. The contents of the register and the Accumulator remain unchanged while the result is discarded.

No. of Bytes: 1

Object Code:

|     | Hex | Decimal |
|-----|-----|---------|
| СРВ | B8  | 184     |
| CPC | B9  | 185     |
| CPD | BA  | 186     |
| CPE | BB  | 187     |
| СРН | BC  | 188     |
| CPL | BD  | 189     |

| Flag            | Code | Bit | Effect                                                           |
|-----------------|------|-----|------------------------------------------------------------------|
| Sign            | S    | 7   | SET = 1 if the result is negative, otherwise RESET = $\emptyset$ |
| Zero            | Z    | 6   | SET = 1 if the result is zero, otherwise RESET = $\emptyset$ .   |
|                 |      | 5   | Not used.                                                        |
| Half Carry      | н    | 4   | SET = 1 if no Borrow from Bit 4, otherwise RESET = $\emptyset$   |
| -               | —    | 3   | Not used.                                                        |
| Parity/Overflow | P/V  | 2   | SET = 1 if Overflow, otherwise RESET = $\emptyset$ .             |
| Subtract        | N    | 1   | SET = 1                                                          |
| Carry           | С    | Ø   | SET = 1 if no Borrow, otherwise RESET = $\varphi$ .              |

#### Example: LD A,17H LD B,02H CP B

If the contents of the Accumulator are 17H and the contents of Register B are  $\emptyset$ 2H, the result is calculated as  $17H - \emptyset$ 2H = 15H. Flags H, N and C are SET = 1 and flags S, Z and P/V are RESET =  $\emptyset$ .

Addressing Mode: Immediate.

| M Cycles | T States | μsec @ 2 MHz. |
|----------|----------|---------------|
| 1        | 4        | 2             |

## CP (HL)

Description: Compares the contents of a memory location whose address is held in Register Pair HL by subtracting the contents of that memory location from the Accumulator then sets a flag or flags according to the result. The contents of the register and the Accumulator remain unchanged while the result is discarded.

No. of Bytes: 1

Object Code (Hex.): BE

Decimal: 190

| Flag            | Code | Bit | Effect                                                           |
|-----------------|------|-----|------------------------------------------------------------------|
| Sign            | S    | 7   | SET = 1 if the result is negative, otherwise RESET = $\emptyset$ |
| Zero            | Z    | 6   | SET = 1 if the result is zero, otherwise RESET = $\emptyset$ .   |
| _               | _    | 5   | Not used.                                                        |
| Half Carry      | н    | 4   | SET = 1 if no Borrow from Bit 4, otherwise RESET = $\emptyset$   |
| -               | _    | 3   | Not used.                                                        |
| Parity/Overflow | P/V  | 2   | SET = 1 if Overflow, otherwise RESET = $\emptyset$ .             |
| Subtract        | N    | 1   | SET = 1                                                          |
| Carry           | С    | Ø   | SET = 1 if no Borrow, otherwise RESET = $\emptyset$ .            |

Flag Register:

Example: LD A,34H LD (HL),21H CP (HL)

If the contents of the Accumulator are 34H and the contents of the memory location are 21H, the result is calculated as 34H - 21H = 13H. Flags H and N are SET = 1 while flags S, Z, P/V and C are RESET = 0.

Addressing Mode: Indirect.

| M Cycles | T States | μsec @ 2 MHz. |
|----------|----------|---------------|
| 2        | 7        | 3.5           |

# $\begin{array}{l} CP (IX + d) \\ CP (IY + d) \end{array}$

Description: Compares the contents of the Accumulator with the contents of a memory location identified by the contents of Index Register IX or IY (modified by displacement d, which is specified in the instruction). The contents of the memory location are subtracted from the Accumulator and a flag or flags set according to the result. The contents of both the Accumulator and the memory remain unchanged while the result is discarded.

No. of Bytes: 3

Object Code:

|            | Hex     | Decimal           |
|------------|---------|-------------------|
| CP(IX + d) | DD BE d | 221 190 d         |
| CP(IY + d) | FD BE d | 253 <b>1</b> 90 d |

Where d is the required displacement from the memory location whose address is held in Index Register IX or IY.

| Flag            | Code | Bit | Effect                                                           |
|-----------------|------|-----|------------------------------------------------------------------|
| Sign            | S    | 7   | SET = 1 if the result is negative, otherwise RESET = $\emptyset$ |
| Zero            | Z    | 6   | SET = 1 if the result is zero, otherwise RESET = $\emptyset$ .   |
| —               | _    | 5   | Not used.                                                        |
| Half Carry      | н    | 4   | SET = 1 if no Borrow from Bit 4, otherwise RESET = $\emptyset$   |
| -               |      | 3   | Not used.                                                        |
| Parity/Overflow | P/V  | 2   | SET = 1 if Overflow, otherwise RESET = $\emptyset$ .             |
| Subtract        | Ν    | 1   | SET = 1                                                          |
| Carry           | С    | Ø   | SET = 1 if no Borrow, otherwise RESET = $\emptyset$ .            |

Example: LD A,12H LD (1000H),A LD A,17H LD IY,0F00H CP (IY + 100H)

If the contents of the Accumulator are 17H and the contents of the nominated location are 12H, the result is calculated as  $17H - 12H = \emptyset 5H$ . Flags H and N are SET = 1 while flags S, Z, P/V and C are RESET =  $\emptyset$ .

Addressing Mode: Indexed.

| M Cycles | T States | μsec @ 2 MHz. |  |
|----------|----------|---------------|--|
| 5        | 19       | 9.5           |  |

#### CPD

Description: The contents of the Accumulator are compared with the contents of a memory location whose address is held in Register Pair HL. The contents of the memory location are subtracted from the Accumulator and a flag or flags set depending on the result. The contents of the memory location and the Accumulator remain unchanged while the result is discarded. The contents of both Register Pair HL and Register Pair BC (Byte Counter) are decremented.

No. of Bytes: 2

Object Code (Hex.): ED A9 Decimal: 237 169

Flag Register:

| Flag            | Code | Bit | Effect                                                                                                                        |
|-----------------|------|-----|-------------------------------------------------------------------------------------------------------------------------------|
| Sign            | S    | 7   | SET = 1 if the result is negative, otherwise RESET = $\emptyset$                                                              |
| Zero            | Z    | 6   | SET = 1 if the result is zero, i.e. A = (HL), otherwise RESET = $\emptyset$ .                                                 |
|                 | _    | 5   | Not used.                                                                                                                     |
| Half Carry      | н    | 4   | SET = 1 if no Borrow from Bit 4, otherwise RESET = $\emptyset$                                                                |
| -               |      | 3   | Not used.                                                                                                                     |
| Parity/Overflow | P/V  | 2   | SET = 1 if the contents of Register<br>Pair BC - 1 (i.e. the Byte Counter)<br>= $\emptyset$ , otherwise RESET = $\emptyset$ . |
| Subtract        | N    | 1   | SET = 1                                                                                                                       |
| Carry           | С    | Ø   | Not affected.                                                                                                                 |

Example: LD A,16H LD (HL),12H CPD

If the contents of the Accumulator are 16H and the contents of the memory location are 12H, the result is calculated as  $16H - 12H = \emptyset 4H$ . Flags H and N are SET = 1, flags S, Z and P/V are RESET =  $\emptyset$  while flag C is unaffected.

Addressing Mode: Indirect.

| M Cycles | T States | μsec @ 2 MHz. |
|----------|----------|---------------|
| 4        | 16       | 8             |

#### CPDR

Description: The contents of a memory location whose address is held in Register pair HL are subtracted from the contents of the Accumulator. If the result is zero (i.e. A = (HL)), the zero bit is set and both Register Pair HL and Register Pair BC are decremented and the instruction is terminated. The instruction is also terminated if the new value of Register Pair BC is zero, even if the contents of the memory location and the Accumulator are not equal. If the new value of Register Pair BC is not zero, AND the contents of the memory location do not equal the contents of the Accumulator, the Program Counter is decremented (by 2) and the instruction is repeated, i.e. the Program Counter is returned to the value it contained when the CPDR instruction was initiated.

- NOTE 1: If the Register Pair BC is initialised to  $\emptyset$  prior to this instruction being initiated it will fail the BC =  $\emptyset$  test and cycle through all 64K of memory.
- NOTE 2: Data interrupts can be recognised after each time the instruction is processed.

No. of Bytes: 2

Object Code (Hex.): ED B9

Decimal: 237 185

| Flag            | Code | Bit | Effect                                                                                                        |
|-----------------|------|-----|---------------------------------------------------------------------------------------------------------------|
| Sign            | S    | 7   | SET = 1 if the result is negative, otherwise RESET = $\emptyset$                                              |
| Zero            | Z    | 6   | SET = 1 if the contents of the memory location and the Accumulator are equal, otherwise RESET = $\emptyset$ . |
| —               | _    | 5   | Not used.                                                                                                     |
| Half Carry      | н    | 4   | SET = 1 if no Borrow from Bit 4, otherwise RESET = $\emptyset$                                                |
| _               | _    | 3   | Not used.                                                                                                     |
| Parity/Overflow | P/V  | 2   | SET = 1 if the contents of Register<br>Pair BC $<>\emptyset$ , otherwise RESET = $\emptyset$ .                |
| Subtract        | N    | 1   | SET = 1                                                                                                       |
| Carry           | С    | Ø   | Not affected.                                                                                                 |

Example: If the contents of the Accumulator are 25H and the contents of the memory location whose address is held in Register Pair HL are 22H, then the Program Counter is returned to the point where the instruction was initiated while Register Pair HL and Register Pair BC are decremented. The instruction is then repeated (provided Register Pair BC does not contain zero), using the PRECEDING memory location. If the contents of this new location equal the contents of the Accumulator, then Flag Z will be SET = 1 and the instruction terminated.

Addressing Mode: Indirect.

|                                         | M Cycles | T States | μsec @ 2 MHz. |
|-----------------------------------------|----------|----------|---------------|
| $BC = \emptyset \text{ or} \\ A = (HL)$ | 4        | 16       | 8             |
| BC<>Ø and<br>A<>(HL)                    | 5        | 21       | 9.5           |

#### CPI

Description: The contents of the memory location whose address is held in Register Pair HL are subtracted from the Accumulator and a flag or flags set depending on the result. Register pair HL is INCREMENTED while Register Pair BC is DECREMENTED. The contents of the memory location and the Accumulator remain unchanged while the result is discarded.

No. of Bytes: 2

Object Code (Hex.): ED A1

Decimal: 237 161

| Flag | Register: |
|------|-----------|
|------|-----------|

| Flag            | Code | Bit | Effect                                                                                                |
|-----------------|------|-----|-------------------------------------------------------------------------------------------------------|
| Sign            | S    | 7   | SET = 1 if the result is negative, otherwise RESET = $\emptyset$                                      |
| Zero            | Z    | 6   | SET = 1 if the result is $\emptyset$ , otherwise<br>RESET = $\emptyset$                               |
|                 | _    | 5   | Not used.                                                                                             |
| Half Carry      | н    | 4   | SET = 1 if no Borrow from Bit 4, otherwise RESET = $\emptyset$                                        |
|                 | —    | 3   | Not used.                                                                                             |
| Parity/Overflow | P/V  | 2   | RESET = $\emptyset$ if new value of Register<br>Pair BC = $\emptyset$ , otherwise SET = $\emptyset$ . |
| Subtract        | N    | 1   | SET = 1                                                                                               |
| Carry           | С    | Ø   | Not affected.                                                                                         |

Example: LD A,ØA3H LD (HL),A LD BC,1 CPI

If the contents of both the Accumulator and the nominated location are A3H, the result is calculated as  $A3H - A3H = \emptyset\emptyset H$ . Flags Z, H and N are SET = 1 (also P/V if the new value of Register Pair BC =  $\emptyset$  while flag S is RESET =  $\emptyset$ . Flag C is not affected.

Addressing Mode: Indirect.

| M Cycles | T States | States µsec @ 2 MHz. |  |
|----------|----------|----------------------|--|
| 4        | 16       | 8                    |  |

#### CPIR

Description: The contents of a memory location whose address is held in Register Pair HL are subtracted from the contents of the Accumulator. If the result zero, i.e. A = (HL), the zero flag is set, Register Pair HL is INCREMENTED and Register Pair BC is DECREMENTED, then the instruction is terminated. The instruction is also terminated if the new value of Register Pair BC is zero, even if the contents of the memory location are not equal to the contents of the Accumulator. If the new value of Register Pair BC is not zero, AND the contents of the memory location do not equal the contents of the Accumulator, the Program. Counter is decremented (by 2) and the instruction is repeated, i.e. the Program Counter is returned to the value it contained when the CPIR instruction was initiated.

- NOTE 1: If Register Pair BC is initialised to  $\emptyset$  prior to this instruction being initiated it will fail the BC =  $\emptyset$  test and cycle through all 64K of memory.
- NOTE 2: Data interrupts can be recognised after each time the instruction is processed.

No. of Bytes: 2

Object Code (Hex.): ED B1

Decimal: 237 177

| Flag            | Code | Bit | Effect                                                                                                      |
|-----------------|------|-----|-------------------------------------------------------------------------------------------------------------|
| Sign            | S    | 7   | SET = 1 if the result is negative, otherwise RESET = $\emptyset$                                            |
| Zero            | Z    | 6   | SET = 1 if the contents of the memory location and the Accumulator are equal, otherwise RESET = $\emptyset$ |
| _               |      | 5   | Not used.                                                                                                   |
| Half Carry      | н    | 4   | SET = 1 if no Borrow from Bit 4, otherwise RESET = $\emptyset$                                              |
| —               | _    | 3   | Not used.                                                                                                   |
| Parity/Overflow | P/V  | 2   | RESET = $\emptyset$ if new value of Register<br>Pair BC = $\emptyset$ , otherwise SET = 1.                  |
| Subtract        | Ν    | 1   | SET = 1                                                                                                     |
| Carry           | С    | Ø   | Not affected.                                                                                               |

Flag Register:

Cont.

Example: LD A,ØA3H LD (HL),95H LD BC,2 CPIR

If the contents of the Accumulator are A3H and the contents of the memory location, whose address is held in Register Pair HL, are 95H, then the Program Counter is returned to the point where the instruction was initiated while Register Pair HL is INCREMENTED and Register Pair BC is DECREMENTED. Provided Register Pair BC does not then contain zero, the instruction is repeated, using the NEXT memory location (now pointed to by the contents of Register Pair HL). If the contents of this new location equal the contents of the Accumulator, then Flag Z will be SET = 1 and the instruction terminated.

Addressing Mode: Indirect.

|                                         | M Cycles | T States | μsec @ 2 MHz. |
|-----------------------------------------|----------|----------|---------------|
| $BC = \emptyset \text{ or} \\ A = (HL)$ | 4        | 16       | 8             |
| BC <> Ø and<br>A <> Ø                   | 5        | 21       | 9.5           |

#### CPL

Description: Complements the contents of the Accumulator.

No. of Bytes: 1

Object Code (Hex.): 2F Decimal: Ø47

Flag Register:

| Flag                                                                | Code                    | Bit                        | Effect                                                                                           |
|---------------------------------------------------------------------|-------------------------|----------------------------|--------------------------------------------------------------------------------------------------|
| Sign<br>Zero<br>—<br>Half Carry<br>—<br>Parity/Overflow<br>Subtract | S<br>Z<br>H<br>P/V<br>N | 7<br>6<br>5<br>4<br>3<br>2 | Not affected.<br>Not affected.<br>Not used.<br>SET = 1.<br>Not used.<br>Not affected.<br>SET = 1 |
| Carry                                                               | C                       | Ø                          | Not affected.                                                                                    |

Example: LD A,3DH CPL

If the contents of the Accumulator are 3DH (Bit Pattern 00111101) they are changed to C2H (Bit Pattern 11000010) and Flags H and N are both SET = 1.

Addressing Mode: Implicit.

| M Cycles | T States | μsec @ 2 MHz. |
|----------|----------|---------------|
| 1        | 4        | 2             |

#### DAA

Description: Adjusts the Accumulator to obtain the correct Bit Pattern for Binary Coded Decimal (BCD). This is achieved by conditionally adding 6 to either the left or right half byte of the Accumulator, based on the status of flags after an arithmetic operation.

No. of Bytes: 1

Object Code (Hex.): 27

Decimal: Ø39

| Flag            | Code | Bit | Effect                                                                                                                              |
|-----------------|------|-----|-------------------------------------------------------------------------------------------------------------------------------------|
| Sign            | S    | 7   | SET = 1 if the Most Significant Bit (MSB) of the Accumulator = 1 after the instruction is executed, otherwise RESET = $\emptyset$ . |
| Zero            | Z    | 6   | SET = 1 if the value of the Accumulator = $\emptyset$ after the instruction is executed.                                            |
| —               | _    | 5   | Not used.                                                                                                                           |
| Half Carry      | н    | 4   | See Operation Table below.                                                                                                          |
|                 | —    | 3   | Not used.                                                                                                                           |
| Parity/Overflow | P/V  | 2   | SET = 1 if the Accumulator has<br>Parity Even after the instruction is<br>executed.                                                 |
| Subtract        | Ν    | 1   | Not affected.                                                                                                                       |
| Carry           | С    | Ø   | See Operation Table below.                                                                                                          |

Operation Table:

| N                          | С                          | Initial<br>Lower Digit<br>(Bits 3 — Ø)                      | Value of<br>H                   | Upper Digit<br>(Bits 7 — 4)                                 | Value<br>Added<br>to Acc.                    | Final<br>Value<br>of C.              |
|----------------------------|----------------------------|-------------------------------------------------------------|---------------------------------|-------------------------------------------------------------|----------------------------------------------|--------------------------------------|
| Ø<br>(ADD,<br>ADC,<br>INC) | Ø<br>Ø<br>Ø<br>Ø<br>1<br>1 | Ø—9<br>A—F<br>Ø—3<br>Ø—9<br>A—F<br>Ø—3<br>Ø—9<br>A—F<br>Ø—3 | Ø<br>0<br>1<br>0<br>1<br>0<br>1 | Ø—9<br>Ø—8<br>Ø—9<br>A—F<br>9—F<br>A—F<br>Ø—2<br>Ø—2<br>Ø—3 | 00<br>06<br>60<br>66<br>66<br>66<br>60<br>66 | 0<br>0<br>1<br>1<br>1<br>1<br>1<br>1 |
| 1<br>(SUB,<br>SBC,<br>DEC, | Ø<br>Ø<br>1<br>1           | Ø—9<br>6—F<br>Ø—9<br>6—F                                    | Ø<br>1<br>Ø<br>1                | Ø—9<br>Ø—8<br>7—F<br>6—F                                    | ØØ<br>FA<br>AØ<br>9A                         | Ø<br>Ø<br>1<br>1                     |

Example: LD A,ØBBH INC A DAA

Assuming that the preceding arithmetic operation was NOT a subtract, then the value of the N Flag will be  $\emptyset$ . If, as a result of that operation, the contents of the Accumulator are BC (Hex.) and the value of the H Flag is  $\emptyset$ , then 66H is added to the Accumulator, making the value of the contents 22(BCD). The C Flag is made = 1.

Addressing Mode: Implicit.

| M Cycles | T States | µsec @ 2MHz. |
|----------|----------|--------------|
| 1        | 4        | 2            |

# DEC r

Decrements Register contents.

Where r is any of the registers A, B, C, D, E, H or L.

Object Code:

|                | Hex      | Decimal    |
|----------------|----------|------------|
| DEC A          | 3D       | Ø61        |
| DEC B<br>DEC C | Ø5<br>ØD | ØØ5<br>Ø13 |
| DEC D          | 15       | Ø21        |
| DEC E<br>DEC H | 1D<br>25 | Ø29<br>Ø37 |
| DECL           | 25<br>2D | Ø45        |
|                |          |            |

Description: Subtracts 1 from specified Register.

No. of Bytes: 1

Flag Register:

| Flag            | Code | Bit | Effect                                                                                                                                      |
|-----------------|------|-----|---------------------------------------------------------------------------------------------------------------------------------------------|
| Sign            | S    | 7   | SET = 1 if the result is negative, otherwise RESET = $\emptyset$ .                                                                          |
| Zero            | Z    | 6   | SET = 1 if the result is zero, otherwise RESET = $\emptyset$ .                                                                              |
| —               | —    | 5   | Not used.                                                                                                                                   |
| Half Carry      | н    | 4   | SET = 1 if no Borrow from Bit 4, otherwise RESET = $\emptyset$ .                                                                            |
| _               | _    | 3   | Not used.                                                                                                                                   |
| Parity/Overflow | P/V  | 2   | SET = 1 if the contents of the Accumulator were $8\emptyset$ (Hex.) before the instruction was carried out, otherwise RESET = $\emptyset$ . |
| Subtract        | Ν    | 1   | SET = 1.                                                                                                                                    |
| Carry           | С    | Ø   | Not affected.                                                                                                                               |

#### Example: LD A,8AH DEC A

If the original contents of the Accumulator are 8A(Hex.), then after the instruction is carried out the contents of the Accumulator will be 89(Hex.), Flags H and N will be SET = 1 and Flags S, Z and P/V will be RESET =  $\emptyset$ .

Addressing Mode: Implicit.

| M Cycles | T States | μsec @ 2 MHz. |  |
|----------|----------|---------------|--|
| 1        | 4        | 2             |  |

### DEC (HL)

Description: Decrements the contents of a memory location whose address is held in Register Pair HL.

No. of Bytes: 1

Object Code (Hex.): 35

Decimal: Ø53

Flag Register:

| Flag            | Code | Bit | Effect                                                                                                                                              |
|-----------------|------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| Sign            | S    | 7   | SET = 1 if the result is negative, otherwise RESET = $\emptyset$ .                                                                                  |
| Zero            | Z    | 6   | SET = 1 if the result is zero, otherwise RESET = $\emptyset$ .                                                                                      |
| -               | —    | 5   | Not used.                                                                                                                                           |
| Half Carry      | н    | 4   | SET = 1 if no Borrow from Bit 4, otherwise RESET = $\emptyset$ .                                                                                    |
| -               | _    | 3   | Not used.                                                                                                                                           |
| Parity/Overflow | P/V  | 2   | SET = 1 if the contents of the memory location were $8\emptyset(\text{Hex.})$ before the instruction was processed, otherwise RESET = $\emptyset$ . |
| Subtract        | N    | 1   | SET = 1.                                                                                                                                            |
| Carry           | С    | Ø   | Not affected.                                                                                                                                       |

Example: LD HL,24ACH LD (HL),45H DEC (HL)

If, before the instruction was processed, the contents of Register Pair HL were 24 AC and the contents of memory location 24 AC were 45(Hex.), then after the in instruction is processed the contents of Register Pair HL will remain unchanged, the contents of memory location 24 AC will be 44(Hex.), Flags H and N will be SET = 1 and Flags S, Z and P/V will be RESET =  $\emptyset$ .

Addressing Mode: Indirect.

| M Cycles | T States | μsec @ 2 MHz. |  |
|----------|----------|---------------|--|
| 3        | 11       | 5.5           |  |

# $\frac{\text{DEC (IX + d)}}{\text{DEC (IY + d)}}$

Description: Decrements the contents of a memory location identified by the contents of Index Register IX or IY (modified by displacement d, which is specified in the instruction).

#### No. of Bytes: 3

Object Code:

|             | Hex     | Decimal   |
|-------------|---------|-----------|
| DEC(IX + d) | DD 35 d | 221 Ø53 d |
| DEC(IY + d) | FD 35 d | 253 Ø53 d |

Where d is the required displacement from the memory location whose address is held in Index Register IX or IY.

Flag Register:

| Flag            | Code | Bit | Effect                                                                                                                                              |
|-----------------|------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| Sign            | S    | 7   | SET = 1 if the result is negative, otherwise RESET = $\emptyset$ .                                                                                  |
| Zero            | Z    | 6   | SET = 1 if the result is zero, otherwise RESET = $\emptyset$ .                                                                                      |
| —               | _    | 5   | Not used.                                                                                                                                           |
| Half Carry      | Н    | 4   | SET = 1 if no Borrow from Bit 4, otherwise RESET = $\emptyset$ .                                                                                    |
| -               | —    | 3   | Not used.                                                                                                                                           |
| Parity/Overflow | P/V  | 2   | SET = 1 if the contents of the memory location were $8\emptyset(\text{Hex.})$ before the instruction was processed, otherwise RESET = $\emptyset$ . |
| Subtract        | Ν    | 1   | SET = 1.                                                                                                                                            |
| Carry           | С    | Ø   | Not affected.                                                                                                                                       |

#### Example: LD A,ØA9H LD (36ADH),A LD IX,36ABH DEC (IX + 2)

If, before the instruction was processed, the contents of Index Register IX were 36 AB, the contents of memory location 36 AD were A9(Hex.) and the value of d in the instruction was  $\emptyset$ 2(Hex.), then after the instruction was processed, the contents of the Index Register IX remain unchanged, the contents of memory location 36 AD will be A8(Hex.), Flags H and N will be SET = 1 and Flags S, Z and P/V will be RESET =  $\emptyset$ .

Addressing Mode: Indirect.

| M Cycles | T States | μsec @ 2 MHz. |  |  |
|----------|----------|---------------|--|--|
| 6        | 23       | 11.5          |  |  |

## DEC rr

Where rr is any of the register pairs BC, DE, HL or SP.

Object Code:

| ØB | Ø11 |
|----|-----|
| 1B | Ø27 |
| 2B | Ø43 |
| 3B | Ø59 |
|    | 2B  |

Description: Decrements the 16-Bit contents of the Register Pair BC, DE, HL or SP.

No. of Bytes: 1

Flag Register:

| Flag            | Code | Bit | Effect        |
|-----------------|------|-----|---------------|
| Sign            | S    | 7   | Not affected. |
| Zero            | Z    | 6   | Not affected. |
|                 | _    | 5   | Not used.     |
| Half Carry      | н    | 4   | Not affected. |
| _               | _    | 3   | Not used.     |
| Parity/Overflow | P/V  | 2   | Not affected. |
| Subtract        | N    | 1   | Not affected. |
| Carry           | С    | Ø   | Not affected. |
|                 |      |     |               |

Example: LD BC,ØAC11H

DEC BC

If the contents of Register Pair BC and AC 11, then the effect of this instruction will be to decrement those contents to AC 10.

Addressing Mode: Implicit.

| M Cycles | T States | μsec @ 2 MHz. |
|----------|----------|---------------|
| 1        | 6        | 3             |

#### DEC IX DEC IY

Description: Decrements the contents of Index Register IX or IY.

No. of Bytes: 2

Object Code:

|        | Hex   | Decimal |
|--------|-------|---------|
| DEC IX | DD 2B | 221 Ø43 |
| DEC IY | FD 2B | 253 Ø43 |

Flag Register:

| SignS7Not affected.ZeroZ6Not affected5Not used.Half CarryH4Not affected3Not used.Parity/OverflowP/V2Not affected.SubtractN1Net affected. | Flag                                                                | Code                        | Bit                             | Effect                                                                                                      |
|------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------|-----------------------------|---------------------------------|-------------------------------------------------------------------------------------------------------------|
| Carry C Ø Not affected.                                                                                                                  | Sign<br>Zero<br>—<br>Half Carry<br>—<br>Parity/Overflow<br>Subtract | S<br>Z<br>H<br><br>P/V<br>N | 7<br>6<br>5<br>4<br>3<br>2<br>1 | Not affected.<br>Not affected.<br>Not used.<br>Not affected.<br>Not used.<br>Not affected.<br>Not affected. |

Example: LD IX,45H DEC IX

If the original contents of the register are 45(Hex.) then after the instruction is processed those contents will be 44(Hex.)

Addressing Mode: Implicit.

| M Cycles | T States | μsec @ 2 MHz. |
|----------|----------|---------------|
| 2        | 10       | 5             |

# DI

Description: Resets the Interrupt Flip-Flops, thus disabling the Maskable Interrupt function.

No. of Bytes: 1

Object Code (Hex.): F3 Decimal: 243

Flag Register:

| SignS7Not affected.ZeroZ6Not affected5Not used.Half CarryH4Not affected3Not used.Parity/OverflowP/V2Not affected. | Flag            | Code | Bit | Effect        |
|-------------------------------------------------------------------------------------------------------------------|-----------------|------|-----|---------------|
| SubtractN1Not affected.CarryCØNot affected.                                                                       | Zero            | Z    | 6   | Not affected. |
|                                                                                                                   | —               | —    | 5   | Not used.     |
|                                                                                                                   | Half Carry      | H    | 4   | Not affected. |
|                                                                                                                   | —               | —    | 3   | Not used.     |
|                                                                                                                   | Parity/Overflow | P/V  | 2   | Not affected. |
|                                                                                                                   | Subtract        | N    | 1   | Not affected. |

Addressing Mode: Implicit.

| M Cycles | T States | μsec @ 2 MHz. |
|----------|----------|---------------|
| 1        | 4        | 2             |

# DJNZ,d

Description: Decrements the contents of Register B and performs a Jump instruction if the new contents of that register are non-zero by adding displacement d to the Program Counter (PC), which then contains the address of the next instruction to be carried out. If the new contents of Register B are zero, the Jump instruction is ignored and the next sequential instruction is obeyed.

No. of Bytes: 2

Object Code (Hex.): 10 d-2 Decimal: 016 d-2

Where d is the displacement required from the current contents of the Program Counter (PC) if the Jump instruction is to be obeyed.

Flag Register:

| Flag                                                                | Code                    | Bit                             | Effect                                                                                                      |
|---------------------------------------------------------------------|-------------------------|---------------------------------|-------------------------------------------------------------------------------------------------------------|
| Sign<br>Zero<br>—<br>Half Carry<br>—<br>Parity/Overflow<br>Subtract | S<br>Z<br>H<br>P/V<br>N | 7<br>6<br>5<br>4<br>3<br>2<br>1 | Not affected.<br>Not affected.<br>Not used.<br>Not affected.<br>Not used.<br>Not affected.<br>Not affected. |
| Carry                                                               | С                       | Ø                               | Not affected.                                                                                               |

Example: LD BC,Ø1 DJNZ 6

If the contents of the Program Counter are 10 11, the contents of Register B are 01, and displacement d in the instruction is 06, then the effect of this instruction is to decrement the contents of Register B to 00, the Jump instruction is ignored and the contents of the Program Counter are incremented by 2 to 1013. If B were not zero, the program counter would be set to 1017.

Addressing Mode: Immediate.

|       | M Cycles | T States | μsec @ 2 MHz. |
|-------|----------|----------|---------------|
| B <>∅ | 3        | 13       | 6.5           |
| B = Ø | 2        | 8        | 4             |

#### EI

Description: Sets the Interrupt Flip-Flops thereby enabling the Maskable Interrupt function.

No. of Bytes: 1

Object Code (Hex.): FB Decimal: 251

NOTE: The Maskable Interrupt function is not enabled until this instruction has been completed.

Flag Register:

| Sign S 7 No                                           |                                                                                                                 |
|-------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------|
| 5NoHalf CarryH4No3NoParity/OverflowP/V2NoSubtractN1No | lot affected.<br>lot affected.<br>lot used.<br>lot affected.<br>lot affected.<br>lot affected.<br>lot affected. |

Addressing Mode: Implicit. Timing:

| M Cycles | T States | μsec @ 2 MHz. |
|----------|----------|---------------|
| 1        | 4        | 2             |

#### EX AF, AF'

Description: Exchanges the contents of Register Pair AF with the contents of Register AF'

No. of Bytes: 1

Object Code (Hex.): Ø8 Decimal: ØØ8

Flag Register:

| Flag            | Code | Bit | Effect        |
|-----------------|------|-----|---------------|
| Sign            | S    | 7   | Not affected. |
| Zero            | Z    | 6   | Not affected. |
| _               |      | 5   | Not used.     |
| Half Carry      | н    | 4   | Not affected. |
| -               | -    | 3   | Not used.     |
| Parity/Overflow | P/V  | 2   | Not affeced.  |
| Subtract        | N    | 1   | Not affected. |
| Carry           | С    | Ø   | Not affected. |

Example: If the contents of Register Pair AF are 34H and the contents of Register Pair AF' are ABH, then after this instruction is processed Register Pair AF will contain ABH and Register Pair AF' will contain 34H.

Addressing Mode: Implicit.

| M Cycles | T States | μsec @ 2 MHz. |
|----------|----------|---------------|
| 1        | 4        | 2             |

#### EX DE,HL

Description: Exchanges the contents of Register Pair DE with the contents of Register Pair HL.

No. of Bytes: 1

Object Code (Hex.): EB

Decimal: 235

Flag Register:

| Flag            | Code   | Bit    | Effect                         |
|-----------------|--------|--------|--------------------------------|
| Sign<br>Zero    | S<br>Z | 7      | Not affected.<br>Not affected. |
|                 | _      | 5      | Not used.                      |
| Half Carry<br>— | H<br>  | 4<br>3 | Not affected.<br>Not used.     |
| Parity/Overflow | P/V    | 2      | Not affected.                  |
| Subtract        | N      | 1      | Not affected.                  |
| Carry           | С      | Ø      | Not affected.                  |

Example: LD DE,23H LD HL,67H

EX DE, HL

If the contents of Register Pair DE are 23H and the contents of Register Pair HL are 67H, then after this instruction is processed Register Pair DE will contain 67 H and Register Pair HL will contain 23H.

Addressing Mode: Implicit.

| M Cycles | T States | μsec @ 2 MHz. |
|----------|----------|---------------|
| 1        | 4        | 2             |

# EX (SP),HL

Exchange contents of Register Pair HL with the top of the Stack.

Object Code:

| Hex        |    | Decimal |  |
|------------|----|---------|--|
| EX (SP),HL | E3 | 227     |  |

Description: Exchanges the Low Order byte of Register Pair HL (i.e. the contents of Register L) with the contents of the memory location whose address is pointed to by the contents of the Stack Pointer (SP) and exchanges the High Order byte of Register Pair HL with the contents of the next sequential memory location. The contents of the Stack Pointer remain unchanged.

No. of Bytes: 1

Flag Register:

| Flag                                                                | Code                        | Bit                             | Effect                                                                                                      |
|---------------------------------------------------------------------|-----------------------------|---------------------------------|-------------------------------------------------------------------------------------------------------------|
| Sign<br>Zero<br>—<br>Half Carry<br>—<br>Parity/Overflow<br>Subtract | S<br>Z<br>H<br><br>P/V<br>N | 7<br>6<br>5<br>4<br>3<br>2<br>1 | Not affected.<br>Not affected.<br>Not used.<br>Not affected.<br>Not used.<br>Not affected.<br>Not affected. |
| Carry                                                               | C                           | Ø                               | Not affected.                                                                                               |

Example: LD BC,ØFAACH LD (1824H),BC LD SP,1824 LD HL,7A2BH EX (SP),HL

If the contents of Register Pair HL are 7A 2B, the Stack Pointer contains the address of memory location 18 24, memory location 18 24 contains AC and memory location 18 25 contains FA, then after this instruction is processed the contents of Register Pair HL will be FA AC, the contents of memory location 18 24 will be 2B and the contents of memory location 18 25 will be 7A.

Addressing Mode: Indirect.

| M Cycles | T States | μsec @ 2 MHz. |
|----------|----------|---------------|
| 5        | 19       | 9.5           |

#### EX (SP),IX EX (SP),IY

Exchange contents of an Index Register and top of Stack.

Object Code:

|            | Hex   | Decimal  |  |
|------------|-------|----------|--|
| Ex (SP),IX | DD E3 | 221, 227 |  |
| Ex (SP),IY | FD E3 | 253, 227 |  |

Description: Exchanges the Low Order byte of designated Index Register with the contents of the memory location whose address is held in the Stack Pointer (SP) and exchanges the High Order byte of that Index Register with the contents of the next sequential memory location. The contents of the Stack Pointer remain unaltered.

No. of Bytes: 2

Flag Register:

| Flag            | Code | Bit | Effect        |
|-----------------|------|-----|---------------|
| Sign            | S    | 7   | Not affected. |
| Zero            | Z    | 6   | Not affected. |
| -               | _    | 5   | Not used.     |
| Half Carry      | Н    | 4   | Not affected. |
| —               |      | 3   | Not used.     |
| Parity/Overflow | P/V  | 2   | Not affected. |
| Subtract        | N    | 1   | Not affected. |
| Carry           | С    | Ø   | Not affected. |

Example: LD IX,89ADH LD SP,34A6H LD (SP),0219H EX (SP),IX

If the contents of Register Pair IX are 89 AD, the Stack Pointer contains the address of memory location 34 A6, memory location 34 A6 contains 19 and memory location 34 A7 contains 02, then after this instruction is processed the contents of Index Register IX will be 02 19, the contents of memory location 34 A6 will be AD and the contents of memory location 34 A7 will be 89.

Addressing Mode: Indirect.

| M Cycles | T States | μsec @ 2 MHz. |
|----------|----------|---------------|
| 6        | 23       | 11.5          |

#### EXX

Description: Exchanges the contents of Register Pairs BC, DE and HL with the contents of the equivalent Register Pairs BC', DE' and HL'.

No. of Bytes: 1

Object Code (Hex.): D9

Decimal: 217

Flag Register:

| Flag                                                                | Code                    | Bit                             | Effect                                                                                                      |
|---------------------------------------------------------------------|-------------------------|---------------------------------|-------------------------------------------------------------------------------------------------------------|
| Sign<br>Zero<br>—<br>Half Carry<br>—<br>Parity/Overflow<br>Subtract | S<br>Z<br>H<br>P/V<br>N | 7<br>6<br>5<br>4<br>3<br>2<br>1 | Not affected.<br>Not affected.<br>Not used.<br>Not affected.<br>Not used.<br>Not affected.<br>Not affected. |
| Carry                                                               | С                       | Ø                               | Not affected.                                                                                               |

Example: If the contents of Register Pairs BC, DE and HL are 19 90, 20 34 and DA AD respectively, and the contents of Register Pairs BC', DE' and HL' are AB CD, EF 12 and 34 56 respectively, then after this instruction has been processed the contents of each of these Register Pairs are:

| BC –  | AB CD | DE –  | EF 12 | HL –  | 34 56 |
|-------|-------|-------|-------|-------|-------|
| BC' – | 1990  | DE' – | 2034  | HL' – | DA AD |

Addressing Mode: Implicit.

| M Cycles | T States | μsec @ 2 MHz. |
|----------|----------|---------------|
| 1        | 4        | 2             |
|          |          |               |

## HALT

Description: CPU suspends operations, executing NOP's until either an nterrupt or a reset is received.

No. of Bytes: 1

Dbject Code (Hex.): 76 Decimal: 118

Flag Register:

| Flag            | Code | Bit | Effect        |
|-----------------|------|-----|---------------|
| Sign            | S    | 7   | Not affected. |
| Zero            | Z    | 6   | Not affected. |
|                 | ·    | 5   | Not used.     |
| Half Carry      | н    | 4   | Not affected. |
| -               | -    | 3   | Not used.     |
| Parity/Overflow | P/V  | 2   | Not affected. |
| Subtract        | N    | 1   | Not affected. |
| Carry           | С    | Ø   | Not affected. |
|                 |      |     |               |

Addressing Mode: Implicit.

Fiming:

| M Cycles | T States | μsec @ 2 MHz.           |
|----------|----------|-------------------------|
| 1        | 4        | 2 + Indefinite<br>NOP's |

#### IMØ

Description: Sets Interrupt Mode Ø allowing the interrupting device to insert an instruction on to the Data Bus for immediate execution.

No. of Bytes: 2

Object Code (Hex.): ED 46 Decimal: 237 Ø7Ø

Flag Register:

| Flag                                 | Code          | Bit              | Effect                                                       |
|--------------------------------------|---------------|------------------|--------------------------------------------------------------|
| Sign<br>Zero<br>—<br>Half Carry      | S<br>Z<br>H   | 7<br>6<br>5<br>4 | Not affected.<br>Not affected.<br>Not used.<br>Not affected. |
| Parity/Overflow<br>Subtract<br>Carry | P/V<br>N<br>C | 3<br>2<br>1<br>Ø | Not used.<br>Not affected.<br>Not affected.<br>Not affected. |

Addressing Mode: Implicit.

| M Cycles | T States | μsec @ 2 MHz. |
|----------|----------|---------------|
| 2        | 8        | 4             |

## IM 1

Description: Sets Interrupt Mode 1, i.e. the C.P.U. will execute a Restart to memory location ØØ 38(Hex.) when an Interrupt occurs.

No. of Bytes: 2

Object Code (Hex.): ED 56 Decimal: 237 Ø86

Flag Register:

| Flag                                                                         | Code                         | Bit                                  | Effect                                                                                                                           |
|------------------------------------------------------------------------------|------------------------------|--------------------------------------|----------------------------------------------------------------------------------------------------------------------------------|
| Sign<br>Zero<br>—<br>Half Carry<br>—<br>Parity/Overflow<br>Subtract<br>Carry | S<br>Z<br>H<br>P/V<br>N<br>C | 7<br>6<br>5<br>4<br>3<br>2<br>1<br>Ø | Not affected.<br>Not affected.<br>Not used.<br>Not affected.<br>Not affected.<br>Not affected.<br>Not affected.<br>Not affected. |

Addressing Mode: Implicit.

| M Cycles | T States | μsec @ 2 MHz. |
|----------|----------|---------------|
| 2        | 8        | 4             |

#### **IM 2**

Description: Sets Interrupt Mode 2. When an interrupt occurs a single byte is provided by the interrupting device and this is used as the Low Order byte of a memory location address to which control is to be transferred as a result of the interrupt. The contents of the Interrupt Register (I) are used as the High Order byte of that address.

No. of Bytes: 2

Object Code (Hex.): ED 5E Decimal: 237 094

Flag Register:

| Flag            | Code | Bit | Effect        |
|-----------------|------|-----|---------------|
| Sign            | S    | 7   | Not affected. |
| Zero            | Z    | 6   | Not affected. |
| —               | —    | 5   | Not used.     |
| Half Carry      | Н    | 4   | Not affected. |
| —               | —    | 3   | Not used.     |
| Parity/Overflow | P/V  | 2   | Not affected. |
| Subtract        | N    | 1   | Not affected. |
| Carry           | C    | Ø   | Not affected. |

Addressing Mode: Implicit.

| M Cycles | T States | μsec @ 2 MHz. |
|----------|----------|---------------|
| 2        | 8        | 4             |

# IN A,(n)

Input to Accumulator from Port n.

Object Code:

|          | Hex  | Decimal |  |
|----------|------|---------|--|
| IN A,(n) | DB n | 219 n   |  |

Description: Loads the Accumulator with a single byte of data from the Input Port identified by n in the instruction. The value of n is placed in the Lower Order byte of the address bus and the contents of the Accumulator are placed in the High Order byte of that address bus while the instruction is being processed.

No. of Bytes: 2

Flag Register:

| Flag                                                                         | Code                         | Bit                                  | Effect                                                                                                                           |
|------------------------------------------------------------------------------|------------------------------|--------------------------------------|----------------------------------------------------------------------------------------------------------------------------------|
| Sign<br>Zero<br>—<br>Half Carry<br>—<br>Parity/Overflow<br>Subtract<br>Carry | S<br>Z<br>H<br>P/V<br>N<br>C | 7<br>6<br>5<br>4<br>3<br>2<br>1<br>Ø | Not affected.<br>Not affected.<br>Not used.<br>Not affected.<br>Not affected.<br>Not affected.<br>Not affected.<br>Not affected. |

Example: LD A,Ø

IN A,(3)

If the second byte of the instruction contains Ø3H as the value of n, and the accumulator contains Ø0H, a single data byte will be loaded from Input Port 3 to the Accumulator.

Addressing Mode: External.

| M Cycles | T States | μsec @ 2 MHz. |
|----------|----------|---------------|
| 3        | 11       | 5.5           |

## IN r,(C)

Input to Register r where r is any of the registers A, B, C, D, E, H or L. Object Code:

|           | Hex   | Decimal         |
|-----------|-------|-----------------|
| IN A, (C) | ED 78 | 237 120         |
| IN B, (C) | ED 4Ø | 237 Ø64         |
| IN C, (C) | ED 48 | 237 Ø72         |
| IND, (C)  | ED 5Ø | 237 Ø8Ø         |
| INE, (C)  | ED 58 | 237 Ø88         |
| IN H, (C) | ED 6Ø | 237 Ø96         |
| IN L, (Ċ) | ED 68 | 237 <b>1</b> Ø4 |

Description: The address (Range  $\emptyset$  - 255) of an Input Port is held in Register C and this address is placed in the Lower Order byte of the address bus. The previous contents of Register B are used as the Higher Order byte in the address bus. A singlebyte of data is read from the nominated Input Port and placed in Register r.

No. of Bytes: 1

Flag Register:

| Flag            | Code | Bit | Effect                                                                 |
|-----------------|------|-----|------------------------------------------------------------------------|
| Sign            | S    | 7   | SET = 1 if the input data is negative, otherwise RESET = $\emptyset$ . |
| Zero            | Z    | 6   | SET = 1 if the input data is zero, otherwise RESET = $\emptyset$ .     |
| _               | —    | 5   | Not used.                                                              |
| Half Carry      | н    | 4   | SET = 1 if no Borrow from Bit 4 otherwise RESET = $\emptyset$ .        |
| —               | _    | 3   | Not used.                                                              |
| Parity/Overflow | P/V  | 2   | SET = 1 if Parity Even, RESET = $\emptyset$ if Parity Odd.             |
| Subtract        | N    | 1   | $RESET = \emptyset.$                                                   |
| Carry           | С    | Ø   | Not affected.                                                          |

#### Example: LD A,21H LD C,09H IN A,(C)

If the B register contains 21H and Register C contains Ø9H the address bus will be loaded with 21 Ø9, which identifies Input Port 9. If Input Port 9 holds a data byte, value A2H, that value is placed in the Accumulator, replacing the original contents (21H).

Addressing Mode: External.

| M Cycles | T States | μsec @ 2 MHz. |
|----------|----------|---------------|
| 3        | 12       | 6             |

#### INC r

Increment Register contents where r is any of the Registers A, B, C, D, E, H or L.

Object Code:

|       | Hex      | Decimal |  |
|-------|----------|---------|--|
| INC A | 3C       | Ø6Ø     |  |
| INC B | Ø4       | ØØ4     |  |
| INCC  | Ø4<br>ØC | Ø12     |  |
| INC D | 14       | Ø2Ø     |  |
| INC E | 1C       | Ø28     |  |
| INC H | 24       | Ø36     |  |
| INC L | 2C       | Ø44     |  |
|       |          |         |  |

Description: Add 1 to the specified register.

No. of Bytes: 1

Flag Register:

| Flag            | Code | Bit | Effect                                                                                                                        |
|-----------------|------|-----|-------------------------------------------------------------------------------------------------------------------------------|
| Sign            | S    | 7   | SET = 1 if the result is negative, otherwise RESET = $\emptyset$ .                                                            |
| Zero            | Z    | 6   | SET = 1 if the result is zero, otherwise RESET = $\emptyset$ .                                                                |
| _               | _    | 5   | Not used.                                                                                                                     |
| Half Carry      | Н    | 4   | SET = 1 if Carry from Bit 3, otherwise RESET = $\emptyset$ .                                                                  |
| _               | _    | 3   | Not used.                                                                                                                     |
| Parity/Overflow | P/V  | 2   | SET = 1 if the contents of the Accumulator were 7F(Hex.) before the instruction was executed, otherwise RESET = $\emptyset$ . |
| Subtract        | N    | 1   | $RESET = \emptyset.$                                                                                                          |
| Carry           | С    | Ø   | Not affected.                                                                                                                 |

Example: LD A,18H INC A

If the contents of the Accumulator are 18H the effect of INC A is to increment those contents to 19H, then RESET flags S, Z, H, P/V and N =  $\emptyset$ .

Addressing Mode: Implicit.

| M Cycles | T States | μsec @ 2 MHz. |
|----------|----------|---------------|
| 1        | 4        | 2             |

#### INC rr

Where rr is any of the register pairs BC, DE, HL or SP.

Object Code:

| Hex | Decimal        |                                                                  |
|-----|----------------|------------------------------------------------------------------|
| Ø3  | ØØ3            |                                                                  |
| 13  | Ø <b>1</b> 9   |                                                                  |
| 23  | Ø35            |                                                                  |
| 33  | Ø51            |                                                                  |
|     | Ø3<br>13<br>23 | Ø3         ØØ3           13         Ø19           23         Ø35 |

Description: Increments the 16 bit contents of the Register Pairs BC, DE, HL, or SP.

No. of Bytes: 1

Flag Register:

| Flag            | Code | Bit | Effect        |
|-----------------|------|-----|---------------|
| Sign            | S    | 7   | Not affected. |
| Zero            | Z    | 6   | Not affected. |
| —               | -    | 5   | Not used.     |
| Half Carry      | н    | 4   | Not affected. |
| —               | -    | 3   | Not used.     |
| Parity/Overflow | P/V  | 2   | Not affected. |
| Subtract        | N    | 1   | Not affected. |
| Carry           | С    | Ø   | Not affected. |

Example: LD BC,412H

INC BC

If the contents of register pair BC are 412H, then INC BC will change this to 413H. None of the flags will be changed.

Addressing Mode: Implicit.

| M Cycles | T States | μsec @ 2 MHz. |  |
|----------|----------|---------------|--|
| 1        | 6        | 3             |  |

# INC (HL)

Description: Increments the contents of a memory location whose address is held in Register Pair HL.

No. of Bytes: 1

Object Code (Hex.): 34

Decimal: Ø52

Flag Register:

| Flag            | Code | Bit | Effect                                                                                                                                 |
|-----------------|------|-----|----------------------------------------------------------------------------------------------------------------------------------------|
| Sign            | S    | 7   | SET = 1 if the result is negative, otherwise RESET = $\emptyset$ .                                                                     |
| Zero            | Z    | 6   | SET = 1 if the result is zero, otherwise RESET = $\emptyset$ .                                                                         |
| _               | _    | 5   | Not used.                                                                                                                              |
| Half Carry      | н    | 4   | SET = 1 if Carry from Bit 3, otherwise RESET = $\emptyset$ .                                                                           |
| -               |      | 3   | Not used.                                                                                                                              |
| Parity/Overflow | P/V  | 2   | SET = 1 if the contents of the nominated location were 7F(Hex.) before this instruction was processed, otherwise RESET = $\emptyset$ . |
| Subtract        | N    | 1   | $RESET = \emptyset.$                                                                                                                   |
| Carry           | С    | Ø   | Not affected.                                                                                                                          |

Example: LD HL,1815H LD (HL),1FH INC (HL)

If the contents of Register Pair HL were 18 15, and the contents of memory location 18 15 were 1F, the effect of this instruction is to increment the contents of memory location 18 15 to  $2\emptyset$ (Hex.), SET flag H = 1 and RESET flags S, Z, P/V and N =  $\emptyset$ .

Addressing Mode: Indirect.

| M Cycles | T States | μsec @ 2 MHz. |  |
|----------|----------|---------------|--|
| 3        | 11       | 5.5           |  |

#### INC (IX + d) INC (IY + d)

Description: Increments the contents of the memory location identified by the contents of Index Register IX or IY (modified by displacement d, which is specified in the instruction).

No. of Bytes: 3

Object Code:

|             | Hex     | Decimal   |
|-------------|---------|-----------|
| INC(IX + d) | DD 34 d | 221 Ø52 d |
| INC(IY + d) | FD 34 d | 253 Ø52 d |

Where d is the displacement required from the memory location whose address is held in Index Register IX or IY.

Flag Register:

| Flag            | Code | Bit | Effect                                                                                                                                |
|-----------------|------|-----|---------------------------------------------------------------------------------------------------------------------------------------|
| Sign            | S    | 7   | SET = 1 if the result is negative, otherwise RESET = $\emptyset$ .                                                                    |
| Zero            | Z    | 6   | SET = 1 if the result is zero, otherwise RESET = $\emptyset$ .                                                                        |
| _               | _    | 5   | Not used.                                                                                                                             |
| Half Carry      | н    | 4   | SET = 1 if Carry from Bit 3, otherwise RESET = $\emptyset$ .                                                                          |
| —               | —    | 3   | Not used.                                                                                                                             |
| Parity/Overflow | P/V  | 2   | SET = 1 if the contents of the nominated location were 7F(Hex.) before the instruction was processed, otherwise RESET = $\emptyset$ . |
| Subtract        | N    | 1   | $RESET = \emptyset.$                                                                                                                  |
| Carry           | С    | Ø   | Not affected.                                                                                                                         |

Example: LD IX,56A2H LD HL,56A8H LD (HL),7FH INC (IX + 6)

If d in the instruction is  $\emptyset$ 6H and the contents of Index Register IX are 56 A2, this instruction will increment the contents of memory location 56 A8. If the contents of that location were 7F they will be incremented to  $\vartheta\emptyset(\text{Hex.})$ , flags S, H and P/V will be SET = 1 and flags Z and N will be RESET =  $\emptyset$ .

Addressing Mode: Indexed.

| M Cycles | T States | μsec @ 2 MHz. |
|----------|----------|---------------|
| 6        | 23       | 11.5          |

#### INC IX INC IY

Increment contents of an Index Register.

Object Code:

|        | Hex   | Decimal        |   |
|--------|-------|----------------|---|
| INC IX | DD 23 | <b>221</b> Ø35 | 1 |
| INC IY | FD 23 | 253 Ø35        |   |

Description: The contents of the designated Index Register is increased by one.

No. of Bytes: 2

Flag Register:

| Flag                                                      | Code                    | Bit                             | Effect                                                                                                                       |
|-----------------------------------------------------------|-------------------------|---------------------------------|------------------------------------------------------------------------------------------------------------------------------|
| Sign<br>Zero<br>Half Carry<br>Parity/Overflow<br>Subtract | S<br>Z<br>H<br>P/V<br>N | 7<br>6<br>5<br>4<br>3<br>2<br>1 | Not affected.<br>Not affected.<br>Not used.<br>Not affected.<br>Not used.<br>Not affected.<br>Not affected.<br>Not affected. |
| Carry                                                     | С                       | Ø                               | Not affected.                                                                                                                |

Example: LD IY,804H

INC IY

If the contents of the IY register are 804H, the effect of INC IY will be to change this to 805H. None of the flags will be changed.

Addressing Mode: Implicit.

| M Cycles | T States | μsec @ 2 MHz. |
|----------|----------|---------------|
| 2        | 10       | 5             |

# IND

Description: The address (Range  $\emptyset$  - 255) of an Input Port is held in Register C and this address is placed in the Lower Order byte of the address bus. The contents of Register B (which is used as a Byte Counter) are placed in the Higher Order byte of the address bus. A single byte of data is read from the designated Input Port and stored in the memory location whose address is held in Register Pair HL, then both Register B and Register Pair HL are decremented.

No. of Bytes: 2

Object Code (Hex.): ED AA

Decimal: 237 170

| Flag            | Code | Bit | Effect                                                                                                                   |
|-----------------|------|-----|--------------------------------------------------------------------------------------------------------------------------|
| Sign            | S    | 7   | Unknown.                                                                                                                 |
| Zero            | Z    | 6   | SET = 1 if the contents of Register<br>B are zero AFTER the instruction is<br>processed, otherwise RESET = $\emptyset$ . |
|                 | _    | 5   | Not used.                                                                                                                |
| Half Carry      | н    | 4   | Unknown.                                                                                                                 |
| -               | _    | 3   | Not used.                                                                                                                |
| Parity/Overflow | P/V  | 2   | Unknown.                                                                                                                 |
| Subtract        | N    | 1   | SET = 1.                                                                                                                 |
| Carry           | С    | Ø   | Not affected.                                                                                                            |

Flag Register:

Example: LD C,Ø4H

LD HL,1824H LD B,Ø1H

IND

If the contents of Register C are @4(Hex.), this identifies Input Port 4. If the contents of Register pair HL are 1824 and the contents of Register B are @1H, this instruction will transfer the data byte from Input Port 4 to memory location 1824, decrement Register Pair HL to 1823, decrement Register B to @0 and SET flags Z and N = 1.

Addressing Mode: External.

| M Cycles | T States | μsec @ 2 MHz. |
|----------|----------|---------------|
| 4        | 16       | 8             |

## INDR

Description: The address (Range 0 - 255) of an Input Port is held in Register C and this address is placed in the Lower Order byte of the address bus. The contents of Register B (which is used as a Byte Counter) are placed in the Higher Order byte of the address bus. A single byte of data is read from the designated Input Port and stored in the memory location whose address is held in Register Pair HL, then both Register B and Register Pair HL are decremented. If the new contents of Register  $B = \emptyset$  the Program Counter (PC) is decremented by 2 and the instruction is repeated. If the new contents of Register  $B = \emptyset$ then the instruction is terminated.

- NOTE 1: If the contents of Register B are set =  $\emptyset$  prior to this instruction being processed, 256 bytes of data will be input and stored in consecutive memory locations.
- NOTE 2: Interrupts can be accepted after each iteration of this instruction.

No. of Bytes: 2

Object Code (Hex.): ED BA Decimal: 237 186

Flag Register:

| Flag                                                                         | Code                         | Bit                                  | Effect                                                                                             |
|------------------------------------------------------------------------------|------------------------------|--------------------------------------|----------------------------------------------------------------------------------------------------|
| Sign<br>Zero<br>—<br>Half Carry<br>—<br>Parity/Overflow<br>Subtract<br>Carry | S<br>Z<br>H<br>P/V<br>N<br>C | 7<br>6<br>5<br>4<br>3<br>2<br>1<br>Ø | Unknown.<br>SET = 1<br>Not used.<br>Unknown.<br>Not used.<br>Unknown.<br>SET = 1.<br>Not affected. |

#### Example: LD C,06H LD HL,2410H LD B,08H INDR

If the contents of Register C are  $\emptyset$ 6, this identifies Input Port 6. If the contents of Register Pair HL are 24 1 $\emptyset$  and those of Register B are  $\emptyset$ 8H, this instruction will transfer 8 bytes of date from Input Port 6 and store them in memory locations 24 1 $\emptyset$  to 24  $\emptyset$ 3. Register B will be decremented progressively to zero while Register Pair HL will also be progressively decremented to 24  $\emptyset$ 3. Flags Z and N will be SET = 1.

Addressing Mode: External.

|                 | M Cycles | T States | μsec @ 2 MHz. |
|-----------------|----------|----------|---------------|
| $B = \emptyset$ | 4        | 16       | 8             |
| B <>∅           | 5        | 21       | 1Ø.5          |

# INI

Description: The address (Range  $\emptyset$  - 255) of an Input Port is held in Register C and this address is placed in the Lower Order byte of the address bus while the contents of Register B (which is used as a Byte Counter) are placed in the Higher Order byte of the address bus. A single byte of data is read from the designated Input Port and stored in the memory location whose address is held in Register Pair HL, then Register B is Decremented and Register Pair HL is Incremented.

No. of Bytes: 2

Object Code (Hex.): ED A2

Decimal: 137 162

Flag Register:

| Flag                                                         | Code                    | Bit                        | Effect                                                                                                                               |
|--------------------------------------------------------------|-------------------------|----------------------------|--------------------------------------------------------------------------------------------------------------------------------------|
| Sign<br>Zero                                                 | S<br>Z                  | 7<br>6                     | Unknown.<br>SET = 1 if the contents of Register<br>B are zero AFTER the instruction is<br>processed, otherwise RESET = $\emptyset$ . |
| —<br>Half Carry<br>—<br>Parity/Overflow<br>Subtract<br>Carry | —<br>H<br>P/V<br>N<br>C | 5<br>4<br>3<br>2<br>1<br>Ø | Not used.<br>Unknown.<br>Not used.<br>Unknown.<br>SET = 1.<br>Not affected.                                                          |

Example: LD C,01H

LD HL,1613H LD B,18H INI

If the contents of Register C are 01(Hex.), this identifies Input Port 1. If the contents of Register pairl HL are 16 13 and those of Register B are 18H, this instruction will transfer one data byte from Input Port 1 to memory location 16 13, Increment Register Pair HL to 16 14, decrement Register B to 17H, and SET flag N = 1 and RESET flag Z = 0.

Addressing Mode: External.

| M Cycles | T States | μsec @ 2 MHz. |  |
|----------|----------|---------------|--|
| 4        | 16       | 8             |  |

### INIR

Description: The address (Range 0 - 255) of an Input Port is held in Register C and this address is placed in the Lower Order byte of the address bus. The contents of Register B (which is used as a Byte Counter) are placed in the Higher Order byte of the address bus. A single byte of data is read from the designated Input Port and stored in the memory location whose address is held in Register Pair HL, then Register B is Decremented and Register pair HL is Incremented. If the new contents of Register  $B = \emptyset$  the Program Counter (PC) is decremented by 2 and the instruction is repeated. If the new contents of Register  $B = \emptyset$  then the instruction is terminated.

- NOTE 1: If the contents of Register B are set =  $\emptyset$  prior to this instruction being processed, 256 bytes of data will be input and stored in consecutive memory locations.
- NOTE 2: Interrupts can be accepted after each iteration of this instruction.

No. of Bytes: 2

Object Code (Hex.): ED B2 Decimal: 237 178

Flag Register:

| SignS7Unknown.ZeroZ6 $SET = 1$ 5Not used.                                                          | Flag                                                                | Code                    | Bit                             | Effect                                                                            |
|----------------------------------------------------------------------------------------------------|---------------------------------------------------------------------|-------------------------|---------------------------------|-----------------------------------------------------------------------------------|
| Hair CarryH4Unknown3Not used.Parity/OverflowP/V2Unknown.SubtractN1 $SET = 1$ .CarryCØNot affected. | Sign<br>Zero<br>—<br>Half Carry<br>—<br>Parity/Overflow<br>Subtract | S<br>Z<br>H<br>P/V<br>N | 7<br>6<br>5<br>4<br>3<br>2<br>1 | Unknown.<br>SET = 1<br>Not used.<br>Unknown.<br>Not used.<br>Unknown.<br>SET = 1. |

#### Example: LD C,ØAH LD HL,23Ø2H LD B,Ø5H INIR

If the contents of Register C are  $\emptyset$ A, this identifies Input Port 1 $\emptyset$ . If the contents of Register Pair HI are 23  $\emptyset$ 2 and those of Register B are  $\emptyset$ H, this instruction will transfer 5 bytes of data from Input Port 1 $\emptyset$  and store them in memory locations 23  $\emptyset$ 2 to 23  $\emptyset$ 6. Register B will be decremented progressively to zero while Register Pair HL will be incremented progressively to 23  $\emptyset$ 6. Flags Z and N will be SET = 1.

Addressing Mode: External.

|                 | M Cycles | T States | μsec @ 2 MHz. |
|-----------------|----------|----------|---------------|
| $B = \emptyset$ | 4        | 16       | 8             |
| $B<>\emptyset$  | 5        | 21       | 10.5          |

### JP nn

Description: Unconditional Jump to a memory location specified in the second and third bytes of the instruction.

NOTE: The contents of the Program Counter are NOT saved.

No. of Bytes: 3

Object Code (Hex.): C3 n n Decimal: 195 n n

Where n n is the memory location to which control is to be transferred.

Flag Register:

| Flag                                                                | Code                    | Bit                             | Effect                                                                                                      |
|---------------------------------------------------------------------|-------------------------|---------------------------------|-------------------------------------------------------------------------------------------------------------|
| Sign<br>Zero<br>—<br>Half Carry<br>—<br>Parity/Overflow<br>Subtract | S<br>Z<br>H<br>P/V<br>N | 7<br>6<br>5<br>4<br>3<br>2<br>1 | Not affected.<br>Not affected.<br>Not used.<br>Not affected.<br>Not used.<br>Not affected.<br>Not affected. |
| Carry                                                               | С                       | Ø                               | Not affected.                                                                                               |

#### Example: JP 2E14H

If the second and third bytes in this instruction contain 2E 14, the contents of the Program Counter (PC) will be replaced by 2E 14 and the next instruction will be fetched from that memory location.

Addressing Mode: Immediate.

| M Cycles | T States | μsec @ 2 MHz. |
|----------|----------|---------------|
| 3        | 1Ø       | 5             |

## JP (HL)

Jump to address contained in register pair HL.

Object Code:

| Hex | Decimal   |                 |
|-----|-----------|-----------------|
| E9  | 233       | 1               |
|     | Hex<br>E9 | HexDecimalE9233 |

Description: Unconditional jump to a memory location whose address is held in Register Pair HL. The contents of that register pair are loaded into the Program Counter and the next instruction fetched from that location.

No. of Bytes: 1

Flag Register:

| Code                    | Bit                             | Effect                                                                                                      |
|-------------------------|---------------------------------|-------------------------------------------------------------------------------------------------------------|
| S<br>Z<br>H<br>P/V<br>N | 7<br>6<br>5<br>4<br>3<br>2<br>1 | Not affected.<br>Not affected.<br>Not used.<br>Not affected.<br>Not used.<br>Not affected.<br>Not affected. |
| С                       | Ø                               | Not affected.                                                                                               |
|                         | S<br>Z<br>H<br>P/V              | S 7<br>Z 6<br>— 5<br>H 4<br>— 3<br>P/V 2<br>N 1                                                             |

Example: LD HL,142BH JP (HL)

If the contents of Register Pair HL are 14 2B that data will be placed in the Program Counter (PC) by this instruction and the next instruction will be fetched from memory location 14 2B.

Addressing Mode: Implicit.

| M Cycles | T States | μsec @ 2 MHz. |
|----------|----------|---------------|
| 1        | 4        | 2             |

### JP (IX) JP (IY)

Jump to address contained in the designated Index Register.

Object Code:

|         | Hex   | Decimal  |  |
|---------|-------|----------|--|
| JP (IX) | DD E9 | 221, 233 |  |
| JP (IY) | FD E9 | 253, 233 |  |

Description: Unconditional jump to a memory location whose address is held in the designated Index Register. The contents of that Index Register is loaded into the Program Counter and the next instruction fetched from that location.

No. of Bytes: 2

Flag Register:

| Flag            | Code   | Bit    | Effect                         |
|-----------------|--------|--------|--------------------------------|
| Sign<br>Zero    | S<br>Z | 7<br>6 | Not affected.<br>Not affected. |
| —               | _      | 5      | Not used.                      |
| Half Carry<br>— | H<br>— | 4<br>3 | Not affected.<br>Not used.     |
| Parity/Overflow | P/V    | 2      | Not affected.                  |
| Subtract        | N      | 1      | Not affected.                  |
| Carry           | С      | Ø      | Not affected.                  |

Example: LD IX,1F34H

JP (IX)

If the contents of Index Register IX are 1F 34, that data will be placed in the Program Counter (PC) by this instruction and the next instruction will be fetched from memory location 1F 34.

Addressing Mode: Implicit.

| M Cycles | T States | μsec @ 2 MHz. |
|----------|----------|---------------|
| 2        | 8        | 4             |

### JP cc,nn

Jump to address nn if condition cc is met, where nn is the memory location to which control is to be transferred and cc can be NZ, Z, NC, C, PO, PE, P or M.

Object Code:

|          | Hex    | Decimal |  |
|----------|--------|---------|--|
| JP NZ,nn | C2 n n | 194 n n |  |
| JP Z,nn  | CA n n | 202 n n |  |
| JP NC,nn | D2 n n | 210 n n |  |
| JP C,nn  | DA n n | 218 n n |  |
| JP PO,nn | E2 n n | 226 n n |  |
| JP PE,nn | EA n n | 234 n n |  |
| JP P,nn  | F2 n n | 242 n n |  |
| JP M,nn  | FA n n | 250 n n |  |

Description: A Conditional Jump is obeyed only if the condition in the Flag Register is met. The address specified in the second and third bytes of the instruction is loaded into the Program Counter (PC) and the next instruction is fetched from that memory location. For detailed explanations of the various conditions, see the conditional CALL instructions, such as CALL NZ,nn, CALL Z, nn, etc.

- NOTE 1: The second byte of the instruction contains the Lower Order byte of the address and the third byte contains the Higher Order byte of that address.
- NOTE 2: The previous contents of the Program Counter are NOT saved.

| Condition     | Flag |
|---------------|------|
| Non zero      | Z    |
| Zero          | Z    |
| Non carry     | С    |
| Carry         | С    |
| Parity odd    | P/O  |
| Parity even   | P/E  |
| Sign positive | Р    |
| Sign negative | М    |

No. of Bytes: 3

Flag Register:

| Flag            | Code | Bit | Effect        |
|-----------------|------|-----|---------------|
| Sign            | S    | 7   | Not affected. |
| Zero            | Z    | 6   | Not affected. |
|                 | _    | 5   | Not used.     |
| Half Carry      | н    | 4   | Not affected. |
| —               | _    | 3   | Not used.     |
| Parity/Overflow | P/V  | 2   | Not affected. |
| Subtract        | Ν    | 1   | Not affected. |
| Carry           | С    | Ø   | Not affected. |
|                 |      |     |               |

Example: LD A,Ø ADD A,1 JP NZ,18A2H

If nn in the instruction contains 18 A2(Hex.) and the Z flag in the Flag Register = 1, the instruction is ignored and the next sequential instruction is obeyed.

Addressing Mode: Immediate.

| M Cycles | T States | μsec @ 2 MHz. |  |
|----------|----------|---------------|--|
| 3        | 1Ø       | 5             |  |

### JR d

Description: Adds the value of d-2 to the contents of the Program Counter (PC) and stores the result in the Program Counter. The next instruction is fetched from the memory location whose address is the new contents of the Program Counter.

NOTE 1: The value of d specified in the Object Code instruction must be two less than the required displacement because the Program Counter will already be incremented by 2 on reading this instruction. The Source Code value of d is decremented automatically by the assembler process.

No. of Bytes: 2

Object Code (Hex.): 18 d-2 Decimal: Ø24d-2

Where d is the required displacement from the current contents of the Program Counter (d may be negative).

Flag Register:

| Flag            | Code | Bit | Effect        |
|-----------------|------|-----|---------------|
| Sign            | S    | 7   | Not affected. |
| Zero            | Z    | 6   | Not affected. |
| —               | —    | 5   | Not used.     |
| Half Carry      | н    | 4   | Not affected. |
| -               | —    | 3   | Not used.     |
| Parity/Overflow | P/V  | 2   | Not affected. |
| Subtract        | N    | 1   | Not affected. |
| Carry           | С    | Ø   | Not affected. |

#### Example: JR 9

A Source Code statement of JR9 will result in an Object Code instruction of 18 Ø7 (Hex.). If the contents of the Program Counter are 1A 28 immediately prior to this instruction being read, the contents of that Program Counter will become 1A 2A when the instruction is read, then 1A 31 when the instruction is obeyed, giving a total displacement of 9 from the original contents of the Program Counter.

Addressing Mode: Relative.

| M Cycles | T States | μsec @ 2 MHz. |
|----------|----------|---------------|
| 3        | 12       | 6             |

### JR cc,d

Where: cc is one of the condition codes NZ, Z, NC or C.

d is the required displacement from the current contents of the Program Counter. (NOTE: d may be negative).

Object Code:

|         | Hex    | Decimal |  |
|---------|--------|---------|--|
| JR NZ,d | 20 d-2 | Ø32 d−2 |  |
| JR Z,d  | 28 d-2 | Ø4Ø d−2 |  |
| JR NC,d | 30 d-2 | Ø48 d−2 |  |
| JR C,d  | 38 d-2 | Ø56 d−2 |  |

Description: A Conditional Jump instruction which is obeyed only if the condition stated is true. If the condition is met, this instruction adds the value d-2 to the contents of the Program Counter (PC) and stores the result in the Program Counter. The next instruction is then fetched from the memory location whose address is the new contents of the Program Counter. If the condition is not met, this instruction is ignored and the next sequential instruction is executed. For detailed descriptions of the conditions, see the conditional call instructions, such as CALL NZ,nn and CALL Z,nn.

No. of Bytes: 2

Flag Register:

| Flag            | Code | Bit | Effect        |
|-----------------|------|-----|---------------|
| Sign            | S    | 7   | Not affected. |
| Zero            | Z    | 6   | Not affected. |
|                 | _    | 5   | Not used.     |
| Half Carry      | н    | 4   | Not affected. |
| —               | _    | 3   | Not used.     |
| Parity/Overflow | P/V  | 2   | Not affected. |
| Subtract        | N    | 1   | Not affected. |
| Carry           | С    | Ø   | Not affected. |

#### Example: SCF

#### JR C,4

A Source Code statement of JR C,4 will result in an Object Code instruction of 38  $\emptyset$ 2(Hex.). If the contents of the Program Counter are 2B 62 before this instruction is read, the contents of that Program Counter will become 2B 64 when the instruction is read, then 2B 66 if the instruction is obeyed, giving a total displacement of 4 from the original contents of the Program Counter.

Addressing Mode: Relative.

|                    | M Cycles | T States | μsec @ 2 MHz. |
|--------------------|----------|----------|---------------|
| Condition<br>true  | 3        | 12       | 6             |
| Condition<br>false | 2        | 7        | 3.5           |

# LD A,I

Object Code: (Hex) ED 57 (Decimal) 237 87.

Description: Loads the Accumulator with the contents of the I register. The I register is unaltered.

No. of Bytes: 2

Flag Register:

| Flag            | Code | Bit | Effect                                                  |
|-----------------|------|-----|---------------------------------------------------------|
| Sign            | S    | 7   | SET=1 if result negative, otherwise<br>RESET=Ø.         |
| Zero            | Z    | 6   | SET=1 if result is zero, otherwise RESET= $\emptyset$ . |
|                 |      | 5   | Not used.                                               |
| Half Carry      | н    | 4   | RESET=Ø.                                                |
| _               |      | 3   | Not used.                                               |
| Parity/Overflow | P/V  | 2   | Set to equal the contents of<br>Interrupt Flip Flop 2.  |
| Subtract        | N    | 1   | RESET=Ø.                                                |
| Carry           | С    | Ø   | Not affected.                                           |

Addressing Mode: Implicit.

| M Cycles | T States | μsec @ 2 MHz. |  |
|----------|----------|---------------|--|
| 2        | 9        | 4.5           |  |

### LD A,R

Object Code: (Hex) ED 5F (Decimal) 237 95.

Description: Loads the Accumulator with the contents of the R register. The R register is unaltered.

No. of Bytes: 2

Flag Register:

| Flag            | Code | Bit | Effect                                                   |
|-----------------|------|-----|----------------------------------------------------------|
| Sign            | S    | 7   | SET=1 if result negative, otherwise RESET= $\emptyset$ . |
| Zero            | Z    | 6   | SET=1 if result is zero, otherwise<br>RESET=Ø.           |
|                 | _    | 5   | Not used.                                                |
| Half Carry      | н    | 4   | RESET=Ø.                                                 |
|                 | _    | 3   | Not used.                                                |
| Parity/Overflow | P/V  | 2   | Set to equal the contents of the Interrupt Flip Flop 2.  |
| Subtract        | Ν    | 1   | RESET=Ø.                                                 |
| Carry           | С    | Ø   | Not affected.                                            |

Addressing Mode: Implicit.

| M Cycles | T States | μsec @ 2 MHz. |
|----------|----------|---------------|
| 2        | 9        | 4.5           |

# LD A,(nn)

Description: Loads the contents of a memory location whose address is specified as n n in the instruction into the Accumulator, leaving the contents of that memory location unaltered.

NOTE 1: In the Object Code, the second byte of the instruction contains the Lower Order byte of the address and the third byte contains the Higher Order byte of the address.

No. of Bytes: 3

Object Code (Hex.): 3A n n Decimal: Ø58 n n

Where nn is the address of a memory location.

Flag Register:

| Flag                                                                         | Code                             | Bit                                  | Effect                                                                                                                                        |
|------------------------------------------------------------------------------|----------------------------------|--------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------|
| Sign<br>Zero<br>—<br>Half Carry<br>—<br>Parity/Overflow<br>Subtract<br>Carry | S<br>Z<br>H<br><br>P/V<br>N<br>C | 7<br>6<br>5<br>4<br>3<br>2<br>1<br>Ø | Not affected.<br>Not affected.<br>Not used.<br>Not affected.<br>Not used.<br>Not affected.<br>Not affected.<br>Not affected.<br>Not affected. |

Example: An instruction LD A,(3D18) will result in an Object Code (Hex.) instruction 3A 18 3D. The contents of memory location 3D 18 will be loaded into the Accumulator, leaving the same value unchanged in memory location 3D 18.

Addressing Mode: Direct.

| M Cycles | T States | μsec @ 2 MHz. |
|----------|----------|---------------|
| 4        | 13       | 6.5           |

# LD A,(BC)

Description: Loads the Accumulator with the contents of a memory location whose address is held in Register Pair BC, leaving the contents of that memory location unaltered.

No. of Bytes: 1

Object Code (Hex.): ØA

Decimal: 010

Flag Register:

| Flag                                                                | Code                    | Bit                             | Effect                                                                                                                       |
|---------------------------------------------------------------------|-------------------------|---------------------------------|------------------------------------------------------------------------------------------------------------------------------|
| Sign<br>Zero<br>—<br>Half Carry<br>—<br>Parity/Overflow<br>Subtract | S<br>Z<br>H<br>P/V<br>N | 7<br>6<br>5<br>4<br>3<br>2<br>1 | Not affected.<br>Not affected.<br>Not used.<br>Not affected.<br>Not used.<br>Not affected.<br>Not affected.<br>Not affected. |
| Carry                                                               | С                       | Ø                               | Not affected.                                                                                                                |

Example: LD HL,142AH LD (HL),ØADH LD BC,142AH LD A,(BC)

If Register Pair BC contains 142A, and the contents of memory location 142A are AD, this instruction will load AD into the Accumulator, leaving the same value in memory location 142A.

Addressing Mode: Indirect.

| M Cycles | T States | μsec @ 2 MHz. |
|----------|----------|---------------|
| 2        | 7        | 3.5           |

## LD A,(DE)

Description: Loads the Accumulator with the contents of a memory location whose address is held in Register Pair DE, leaving the contents of that memory location unaltered.

No. of Bytes: 1

Object Code (Hex.): 1A Decimal: 026

Flag Register:

| Flag                                                                         | Code                         | Bit                                  | Effect                                                                                                                           |
|------------------------------------------------------------------------------|------------------------------|--------------------------------------|----------------------------------------------------------------------------------------------------------------------------------|
| Sign<br>Zero<br>—<br>Half Carry<br>—<br>Parity/Overflow<br>Subtract<br>Carry | S<br>Z<br>H<br>P/V<br>N<br>C | 7<br>6<br>5<br>4<br>3<br>2<br>1<br>Ø | Not affected.<br>Not affected.<br>Not used.<br>Not affected.<br>Not affected.<br>Not affected.<br>Not affected.<br>Not affected. |

Example: LD HL,4D23H LD (HL),68H LD DE, 4D23H LD A.(DE)

If Register Pair DE contains 4D 23, and the contents of memory location 4D 23 are 68, this instruction will load 68 into the Accumulator, leaving the same value in memory location 4D 23.

Addressing Mode: Indirect.

| M Cycles | T States | μsec @ 2 MHz. |
|----------|----------|---------------|
| 2        | 7        | 3.5           |

# LD r,n

Where r is one of A,B,C,D,E,H,L.

Description: Loads the value of n into register r.

No. of Bytes: 2

Object Code:

|                                                          | Hex                                          | Decimal                                            |  |
|----------------------------------------------------------|----------------------------------------------|----------------------------------------------------|--|
| LD A,n<br>LD B,n<br>LD c,n<br>LD D,n<br>LD E,n<br>LD H,n | 3E n<br>Ø6 n<br>ØE n<br>16 n<br>1E n<br>26 n | 062 n<br>006 n<br>014 n<br>022 n<br>030 n<br>038 n |  |
| LD L,n                                                   | 2E n                                         | Ø46 n                                              |  |

Where n is an 8 Bit integer, specified in the instruction.

Flag Register:

| Flag            | Code | Bit | Effect        |
|-----------------|------|-----|---------------|
| Sign            | S    | 7   | Not affected. |
| Zero            | Z    | 6   | Not affected. |
|                 |      | 5   | Not used.     |
| Half Carry      | н    | 4   | Not affected. |
|                 |      | 3   | Not used.     |
| Parity/Overflow | P/V  | 2   | Not affected. |
| Subtract        | N    | 1   | Not affected. |
| Carry           | C    | Ø   | Not affected. |
|                 |      |     |               |

Example: The Source Code statement LD B,14H will load the value 14(Hex.) into the accumulator.

Addressing Mode: Immediate.

| M Cycles | T States | μsec @ 2 MHz. |
|----------|----------|---------------|
| 2        | 7        | 3.5           |

### LD r,r'

Where r and r' are any of the Registers A,B,C,D,E,H or L.

Description: Loads Register r with the contents of Register r'. Register r' is unaltered.

No. of Bytes: 1

Object Code: LD r,r' produces the object code xx(Hex.) or yyy(Decimal.), where xx and yyy are taken from the table below.

|   |   |                | r               |                |                |        |                 |                |
|---|---|----------------|-----------------|----------------|----------------|--------|-----------------|----------------|
|   |   | А              | В               | С              | D              | Е      | Н               | L              |
|   |   | хх ууу         | хх ууу          | хх ууу         | хх ууу         | хх ууу | хх ууу          | хх ууу         |
|   | А | 7F 127         | 47 Ø71          | 4F Ø79         | 57 Ø87         | 5F Ø95 | 67 103          | 6F 111         |
| ŗ | В | 78 <b>1</b> 2Ø | 4 <b>Ø</b> 064  | 48 Ø72         | 5Ø Ø8Ø         | 58 Ø88 | 6Ø Ø96          | 68 <b>1</b> Ø4 |
|   | С | 79 121         | 4 <b>1 Ø</b> 65 | 49 <b>Ø</b> 73 | 5 <b>1 Ø81</b> | 59 Ø89 | 6 <b>1 Ø</b> 97 | 69 105         |
|   | D | 7A 122         | 42 Ø66          | 4A Ø74         | 5 <b>2 Ø82</b> | 5A Ø9Ø | 62 Ø98          | 6A 1Ø6         |
|   | Е | 7B 123         | 43 Ø67          | 4B Ø75         | 53 <b>Ø</b> 83 | 5B Ø91 | 63 Ø99          | 6B 1Ø7         |
|   | н | 7C 124         | 44 <b>Ø</b> 68  | 4C Ø76         | 54 <b>Ø</b> 84 | 5C Ø92 | 64 <b>100</b>   | 6C 1Ø8         |
|   | L | 7D 125         | 45 Ø69          | 4D Ø77         | 55 Ø85         | 5D Ø93 | 65 101          | 6D 1Ø9         |

Flag Register:

| Flag            | Code | Bit | Effect        |
|-----------------|------|-----|---------------|
| Sign            | s    | 7   | Not affected. |
| Zero            | Z    | 6   | Not affected. |
|                 |      | 5   | Not used.     |
| Half Carry      | н    | 4   | Not affected. |
|                 | _    | 3   | Not used.     |
| Parity/Overflow | P/V  | 2   | Not affected. |
| Subtract        | N    | 1   | Not affected. |
| Carry           | С    | Ø   | Not affected. |
|                 |      |     |               |

Example: LD A,53H

LD L,A

If the contents of the Accumulator are 53H, this instruction will load 53H into Register L, leaving the same value in the Accumulator. *Cont.* 

Addressing Mode: Implicit.

| M Cycles | T States | μsec @ 2 MHz. |  |
|----------|----------|---------------|--|
| 1        | 4        | 2             |  |

# LD r,(HL)

Where r is any of registers A,B,C,D,E,H or L.

Description: Loads Register r with the contents of the memory location whose address is held in Register Pair HL, leaving the contents of that memory location unaltered. Note that in the cases of LD H,(HL) and LD L,(HL), the contents of the HL Register Pair will be altered.

No. of Bytes: 1

Object Code:

|                                     | Hex                  | Decimal           |  |
|-------------------------------------|----------------------|-------------------|--|
| LD A,(HL)<br>LD B,(HL)<br>LD C,(HL) | 7E<br>46<br>4E<br>56 | 6 070<br>E 0178   |  |
| LD D,(HL)<br>LD E,(HL)<br>LD H,(HL) | 5E<br>66             | Ø86<br>Ø94<br>1Ø2 |  |
| LD E, (HL)                          | 5E                   | Ø94               |  |

Where n is an 8 Bit integer, specified in the instruction.

Flag Register:

| Flag            | Code | Bit | Effect        |
|-----------------|------|-----|---------------|
| Sign            | S    | 7   | Not affected. |
| Zero            | Z    | 6   | Not affected. |
|                 |      | 5   | Not used.     |
| Half Carry      | н    | 4   | Not affected. |
| -               |      | 3   | Not used.     |
| Parity/Overflow | P/V  | 2   | Not affected. |
| Subtract        | N    | 1   | Not affected. |
| Carry           | С    | Ø   | Not affected. |
|                 |      |     |               |

Example: LD HL, 4732H LD (HL), 56H LD E,(HL)

If the Register Pair HL contains 47 32H, and the content of memory location 4732H is 56H, this instruction will load 56H into Register E, leaving the same value in memory location 47 43H.

Cont.

Addressing Mode: Indirect.

| M Cycles | T States | μsec @ 2 MHz. |  |
|----------|----------|---------------|--|
| 2        | 7        | 3.5           |  |

#### LD r,(IX + d) LD r,(IY + d)

Where r is one of the Registers A,B,C,D,E,H or L, and d is an 8 bit integer.

Description: Loads register r with the contents of the memory location whose address is indentified by the contents of Index Register IX or IY (modified by displacement d, which is specified in the instruction), leaving the contents of that memory location unaltered.

No. of Bytes: 3

Object Code:

|              | Hex     | Decimal   |  |
|--------------|---------|-----------|--|
| LDA,(IX+d)   | DD 7E d | 221 126 d |  |
| LDA,(IY+d)   | FD 7E d | 253 126 d |  |
| LDB,(IX+d)   | DD 46 d | 221 Ø7Ø d |  |
| LD B,(IY+d)  | FD 46 d | 253 Ø7Ø d |  |
| LD C, (IX+d) | DD 4E d | 221 Ø78 d |  |
| LDC,(IY+d)   | FD 4E d | 253 Ø78 d |  |
| LD D,(IX+d)  | DD 56 d | 221 Ø86 d |  |
| LDD,(IY+d)   | FD 56 d | 253 Ø86 d |  |
| LD E,(IX+d)  | DD 5E d | 221 Ø94 d |  |
| LDE,(IY+d)   | FD 5E d | 253 Ø94 d |  |
| LD H,(IX+d)  | DD 66 d | 221 102 d |  |
| LD H,(IY+d)  | FD 66 d | 253 102 d |  |
| LD L,(IX+d)  | DD 6E d | 221 11Ø d |  |
| LD L,(IY+d)  | FD 6E d | 253 110 d |  |
|              |         |           |  |

Flag Register:

| Flag            | Code | Bit | Effect        |
|-----------------|------|-----|---------------|
| Sign            | S    | 7   | Not affected. |
| Zero            | Z    | 6   | Not affected. |
|                 |      | 5   | Not used.     |
| Half Carry      | н    | 4   | Not affected. |
|                 |      | 3   | Not used.     |
| Parity/Overflow | P/V  | 2   | Not affected. |
| Subtract        | N    | 1   | Not affected. |
| Carry           | С    | Ø   | Not affected. |
|                 |      |     |               |

Cont.

Example: LD HL, 3224H LD (HL), 62H LD IX, 3221H LC C,(IX+3)

If Index Register IX contains 3221 (Hex.), and d in the instruction is 3, the required memory location is 3224 (Hex.). If the content of memory location 3224 is 62 (Hex.), this instruction will load 62 into register C, leaving the same value in memory location 32 24.

Addressing Mode: Indexed.

| M Cycles | T States | μsec @ 2 MHz. |  |
|----------|----------|---------------|--|
| 5        | 19       | 9.5           |  |

# LD I,A

Load Interrupt Vector Register from Accumulator.

Object Code:

|        | Hex   | Decimal |  |
|--------|-------|---------|--|
| LD I,A | ED 47 | 237 Ø71 |  |

Description: Loads the contents of the Accumulator into the Interrupt Vector Register (Register I), leaving the contents of the Accumulator unaltered.

No. of Bytes: 2

Flag Register:

| Flag            | Code | Bit | Effect        |
|-----------------|------|-----|---------------|
| Sign            | S    | 7   | Not affected. |
| Zero            | Z    | 6   | Not affected. |
| _               |      | 5   | Not used.     |
| Half Carry      | н    | 4   | Not affected. |
| —               | _    | 3   | Not used.     |
| Parity/Overflow | P/V  | 2   | Not affected. |
| Subtract        | N    | 1   | Not affected. |
| Carry           | С    | Ø   | Not affected. |
|                 |      |     |               |

Example: LD A,24H LD I.A

If the Accumulator contains 24, this instruction loads 24 into Register 1, leaving the contents of the Accumulator unaltered.

Addressing Mode: Implicit.

| M Cycles | T States | μsec @ 2 MHz. |  |
|----------|----------|---------------|--|
| 2        | 9        | 4.5           |  |

## LD R,A

Description: Loads the contents of the Accumulator into the Memory Refresh Register (Register R), leaving the contents of the Accumulator unaltered.

No. of Bytes: 2

Object Code (Hex.): ED 4F

Decimal: 237 Ø79

Flag Register:

| Flag            | Code | Bit | Effect        |
|-----------------|------|-----|---------------|
| Sign            | S    | 7   | Not affected. |
| Zero            | Z    | 6   | Not affected. |
|                 | _    | 5   | Not used.     |
| Half Carry      | н    | 4   | Not affected. |
| _               | _    | 3   | Not used.     |
| Parity/Overflow | P/V  | 2   | Not affected. |
| Subtract        | N    | 1   | Not affected. |
| Carry           | С    | Ø   | Not affected. |
|                 |      |     |               |

Example: LD A,38

#### LD R,A

If the contents of the Accumulator are 38, this instruction will load 38 into Register R, leaving the same value in the Accumulator.

Addressing Mode: Implicit.

| M Cycles | T States | μsec @ 2 MHz. |
|----------|----------|---------------|
| 2        | 9        | 4.5           |

## LD rr, nn

Load Immediate into Register pair rr 16 bits of data nn, where rr is any of the Register Pairs BC, DE, HL or SP and nn is a two byte integer.

Object Code:

|          | Hex    | Decimal |  |
|----------|--------|---------|--|
| LD BC,nn | 01 n n | 001 n n |  |
| LD DE,nn | 11 n n | 017 n n |  |
| LD HL,nn | 21 n n | 033 n n |  |
| LD SP,nn | 31 n n | 049 n n |  |

Description: Loads specified Register Pair with the two byte integer nn specified in the instruction. The second byte of the Object Code instruction is the Lower Order byte of the integer nn and the third byte of the Object Code instruction is the Higher Order byte of integer nn.

No. of Bytes: 3

Flag Register:

| Flag            | Code | Bit | Effect        |
|-----------------|------|-----|---------------|
| Sign            | S    | 7   | Not affected. |
| Zero            | Z    | 6   | Not affected. |
|                 | _    | 5   | Not used.     |
| Half Carry      | н    | 4   | Not affected. |
| —               | _    | 3   | Not used.     |
| Parity/Overflow | P/V  | 2   | Not affected. |
| Subtract        | Ν    | 1   | Not affected. |
| Carry           | С    | Ø   | Not affected. |

Example: The Source Code statement LD HL,244EH will produce the Object Code instruction 21 4E 24(Hex.), which will load Register Pair HL with the data 24 4E(Hex.).

Addressing Mode: Immediate.

| M Cycles | T States | μsec @ 2 MHz. |  |
|----------|----------|---------------|--|
| 3        | 10       | 5             |  |

#### LD IX,nn LD IY,nn

Description: Loads Index Register IX or IY with the two byte integer nn specified in the instruction. The third byte of the Object Code instruction is the Lower Order byte of the integer nn, and is loaded into the Lower Order byte of the Index Register, while the fourth byte of the Object Code instruction is the Higher Order byte of nn and is loaded into the Higher Order byte of the Index Register.

No. of Bytes: 4

Object Code:

|          | Hex       | Decimal     |
|----------|-----------|-------------|
| LD IX,nn | DD 21 n n | 221 Ø33 n n |
| LD IY,nn | FD 21 n n | 253 Ø33 n n |

Where nn is a two Byte integer, specified in the instruction.

Flag Register:

| Flag                            | Code        | Bit              | Effect                                                       |
|---------------------------------|-------------|------------------|--------------------------------------------------------------|
| Sign<br>Zero<br>—<br>Half Carry | S<br>Z<br>H | 7<br>6<br>5<br>4 | Not affected.<br>Not affected.<br>Not used.<br>Not affected. |
| _                               | —           | 3                | Not used.                                                    |
| Parity/Overflow                 | P/V         | 2                | Not affected.                                                |
| Subtract                        | N           | 1                | Not affected.                                                |
| Carry                           | С           | Ø                | Not affected.                                                |

Example: The Source Code statement LD IX,1020H will produce the Object Code instruction DD 21 20 10(Hex.), which will load Index Register IX with the data 1020(Hex.).

Addressing Mode: Immediate.

| M Cycles | T States | μsec @ 2 MHz. |  |
|----------|----------|---------------|--|
| 4        | 14       | 7             |  |

## LD rr,(nn)

Load Register Pair from memory where rr is either BC, DE, HL or SP.

Object Code:

|            | Hex                    | Decimal                    |  |
|------------|------------------------|----------------------------|--|
| LD BC,(nn) | ED 4B n n              | 237 Ø75 n n                |  |
| LD DE,(nn) | ED 5B n n              | 237 Ø91 n n                |  |
| LD HL,(nn) | ED 6B n n<br>ED 7B n n | 237 107 n n<br>237 123 n n |  |
| LD SP,(nn) | ED / BITT              | 237 123111                 |  |

Description: Loads Register Pair rr with the contents of the memory location whose address is specified in the instruction AND the contents of that memory location + 1. The contents of the specified memory location are loaded into the Lower Order byte of Register Pair rr and the contents of the next memory location into the Higher Order byte of that Register pair.

No. of Bytes: 4

Flag Register:

| Flag                                                                | Code                    | Bit                             | Effect                                                                                                                       |
|---------------------------------------------------------------------|-------------------------|---------------------------------|------------------------------------------------------------------------------------------------------------------------------|
| Sign<br>Zero<br>—<br>Half Carry<br>—<br>Parity/Overflow<br>Subtract | S<br>Z<br>H<br>P/V<br>N | 7<br>6<br>5<br>4<br>3<br>2<br>1 | Not affected.<br>Not affected.<br>Not used.<br>Not affected.<br>Not used.<br>Not affected.<br>Not affected.<br>Not affected. |
| Carry                                                               | С                       | Ø                               | Not affected.                                                                                                                |

#### Example: LD HL,3145H LD (HL),68H LD BC,(3145H)

Source Code statement LD BC, (3145) will become Object Code instruction ED 4B 45 31. If the contents of memory location 31 45 are 68, and those of memory location 31 46 are A3, this instruction will load A3 into Register B and 68 into Register C, making the contents of Register Pair BC = A3 68.

Addressing Mode: Direct.

| M Cycles | T States | μsec @ 2 MHz. |  |
|----------|----------|---------------|--|
| 6        | 20       | 10            |  |

## LD IY,(nn) LD IX,(nn)

Description: Loads Index Register IX or IY with the contents of a memory location whose address is specified in the instruction AND the contents of the next sequential memory location. The contents of the specified memory location are loaded into the Lower Order byte of Index Register IX or IY and the contents of the next memory location into the Higher Order byte of that Register.

No. of Bytes: 4

Object Code:

|             | Hex       | Decimal            |  |
|-------------|-----------|--------------------|--|
| LD IX,(nn)  | DD 2A n n | <b>221 Ø42</b> n n |  |
| LD IY, (nn) | FD 2A n n | 253 Ø42 n n        |  |

Where (nn) is the address of a memory location.

Flag Register:

| Flag            | Code   | Bit    | Effect                         |
|-----------------|--------|--------|--------------------------------|
| Sign<br>Zero    | S<br>Z | 7<br>6 | Not affected.<br>Not affected. |
|                 | -      | 5      | Not used.                      |
| Half Carry      | н      | 4      | Not affected.                  |
| —               | —      | 3      | Not used.                      |
| Parity/Overflow | P/V    | 2      | Not affected.                  |
| Subtract        | N      | 1      | Not affected.                  |
| Carry           | С      | Ø      | Not affected.                  |

#### Example: LD HL,1812H LD (HL),6AH LD IX,(1812 H)

The Source Code statement LD IX,(1812) will produce Object Code instruction DD 2A 12 18. If the contents of memory location 18 12 are 6A, and the contents of memory location 1813 are 24, this instruction will load 6A into the Lower Order byte of Index Register IX and 24 into the Higher Order byte of that Register, making the contents 24 6A.

Addressing Mode: Direct.

| <sup>•</sup> M Cycles | T States | μsec @ 2 MHz. |
|-----------------------|----------|---------------|
| 6                     | 2Ø       | 10            |

# LD SP, HL

Move contents of Register Pair HL to Stack Pointer.

Object Code:

|           | Hex | Decimal |  |  |
|-----------|-----|---------|--|--|
| LD SP, HL | F9  | 249     |  |  |

Description: Loads the Stack Pointer with the contents of Register Pair HL, leaving the contents of Register Pair HL unaltered.

No. of Bytes: 1

Flag Register:

| Flag            | Code | Bit | Effect        |
|-----------------|------|-----|---------------|
| Sign            | S    | 7   | Not affected. |
| Zero            | Z    | 6   | Not affected. |
| —               | _    | 5   | Not used.     |
| Half Carry      | н    | 4   | Not affected. |
|                 | _    | 3   | Not used.     |
| Parity/Overflow | P/V  | 2   | Not affected. |
| Subtract        | N    | 1   | Not affected. |
| Carry           | С    | Ø   | Not affected. |
|                 |      |     |               |

Example: LD HL,5B24H

LD SP,HL

If the contents of Register Pair HL are 5B 24, this instruction will load 5B 24 into the Stack Pointer (SP), leaving the same value in Register Pair HL.

Addressing Mode: Implicit.

| M Cycles | T States | μsec @ 2 MHz. |
|----------|----------|---------------|
| 1        | 6        | 3             |

#### LD SP, IX LD SP, IY

Move contents of Index Register to Stack Pointer.

Object Code:

|           | Hex   | Decimal |  |
|-----------|-------|---------|--|
| LD SP, IX | DD F9 | 221 249 |  |
| LD SP, IY | FD F9 | 253 249 |  |

Description: Loads the Stack Pointer (SP) with the contents of specified Index Register, leaving the contents of Index Register unaltered.

No. of Bytes: 2

Flag Register:

| Flag            | Code | Bit | Effect        |
|-----------------|------|-----|---------------|
| Sign            | S    | 7   | Not affected. |
| Zero            | Z    | 6   | Not affected. |
|                 |      | 5   | Not used.     |
| Half Carry      | н    | 4   | Not affected. |
| _               | _    | 3   | Not used.     |
| Parity/Overflow | P/V  | 2   | Not affected. |
| Subtract        | N    | 1   | Not affected. |
| Carry           | С    | Ø   | Not affected. |
|                 |      |     |               |

Example: LD IX,26A5

LD SP,IX

If Index Register IX contains 26 A5, this instruction will load the Stack Pointer with the data 26 A5, leaving the same value in Index Register IX.

Addressing Mode: Implicit.

| M Cycles | T States | tates |  |
|----------|----------|-------|--|
| 2        | 1Ø       | 5     |  |

# LD (nn),A

Store Accumulator in memory location nn where nn is a two byte address.

Object Code:

|           | Hex    | Decimal<br>Ø5Ø n n |  |
|-----------|--------|--------------------|--|
| LD (nn),A | 32 n n |                    |  |

Description: Loads the contents of the Accumulator into the memory location whose address is specified in the second and third bytes of the Object Code instruction, leaving the contents of the Accumulator unaltered.

No. of Bytes: 3

Flag Register:

| Flag            | Code | Bit | Effect        |
|-----------------|------|-----|---------------|
| Sign            | S    | 7   | Not affected. |
| Zero            | Z    | 6   | Not affected. |
| _               | _    | 5   | Not used.     |
| Half Carry      | н    | 4   | Not affected. |
| _               | _    | 3   | Not used.     |
| Parity/Overflow | P/V  | 2   | Not affected. |
| Subtract        | N    | 1   | Not affected. |
| Carry           | С    | Ø   | Not affected. |
|                 |      |     |               |

Example: LD A,9CH

LD (**1**A49H),A

If nn is specified in the Source Code statement as 1A 49, this will produce the Object Code instruction 32 49 1A (Note that the Lower Order byte of the address appears in the second byte of the Object Code instruction). If the contents of the Accumulator are 9C, this instruction will load 9C into memory location 1A, 49, leaving the same value in the Accumulator.

Addressing Mode: Direct.

| M Cycles | T States | μsec @ 2 MHz. |  |
|----------|----------|---------------|--|
| 4        | 13       | 6.5           |  |

## LD (nn),rr

Store Register Pair into memory location nn where rr can be any of the Registers BC, DE, HL or SP.

NOTE: The Lower Order byte of the address is held in the third byte of the Object Code instruction and the Higher Order byte of that address is held in the fourth byte of that instruction.

Object Code:

|            | Hex       | Decimal     |  |
|------------|-----------|-------------|--|
| LD (nn),BC | ED 43 n n | 237 Ø67 n n |  |
| LD (nn),DE | ED 53 n n | 237 Ø83 n n |  |
| LD (nn),HL | ED 63 n n | 237 Ø99 n n |  |
| LD (nn),SP | ED 73 n n | 237 115 n n |  |

Description: Loads the Lower Order byte of the contents of the specified Register Pair into the memory location whose address is specified in the instruction, and the Higher Order byte of that Register Pair into the next sequential memory location, leaving the contents of the Register Pair unaltered.

No. of Bytes: 4

Flag Register:

| Flag            | Code | Bit | Effect        |
|-----------------|------|-----|---------------|
| Sign            | S    | 7   | Not affected. |
| Zero            | Z    | 6   | Not affected. |
|                 | _    | 5   | Not used.     |
| Half Carry      | н    | 4   | Not affected. |
| _               | _    | 3   | Not used.     |
| Parity/Overflow | P/V  | 2   | Not affected. |
| Subtract        | N    | 1   | Not affected. |
| Carry           | С    | Ø   | Not affected. |
|                 |      |     |               |

#### Example: LD BC,6789H LD (3456),BC

If nn is specified in the Source Code statement as 34 56, LD (3456),BC will produce the Object Code instruction ED 43 56 34. If the contents of Register Pair BC are 67 89, this instruction will load the value 89 into memory location 34 56 and the value 67 into memory location 34 57, leaving the value 67 89 in Register Pair BC.

Addressing Mode: Direct.

| M Cycles | T States | μsec @ 2 MHz. |
|----------|----------|---------------|
| 6        | 2Ø       | 10            |

#### LD (nn),IX LD (nn),IY

Store Index Register into memory location nn where nn is the 2 byte address.

Object Code:

|            | Hex       | Decimal     |  |
|------------|-----------|-------------|--|
| LD (nn),IX | DD 22 n n | 221 Ø34 n n |  |
| LD (nn),IY | FD 22 n n | 253 Ø34 n n |  |

Description: Loads the Lower Order byte of the contents of the specified Index Register into the memory location whose address is specified in the instruction, and the Higher Order byte of that Index Register into the next sequential location, leaving the contents of the Index Register unaltered.

No. of Bytes: 4

Flag Register:

| Flag            | Code | Bit | Effect        |
|-----------------|------|-----|---------------|
| Sign            | S    | 7   | Not affected. |
| Zero            | Z    | 6   | Not affected. |
| _               |      | 5   | Not used.     |
| Half Carry      | н    | 4   | Not affected. |
| _               | _    | 3   | Not used.     |
| Parity/Overflow | P/V  | 2   | Not affected. |
| Subtract        | N    | 1   | Not affected. |
| Carry           | С    | Ø   | Not affected. |
|                 |      |     |               |

#### Example: LD IX,7766H LD (11AAH).IX

If nn is specified in the Source Code statement as 11 AA, LD (11AA), IY will produce the Object Code instruction FD 22 AA. If the contents of Index Register IY are 77 66, this instruction will load 66 into memory location 11 AA and 77 into memory location 11 AB, leaving the value 77 66 in Index Register IY.

Addressing Mode: Direct.

| M Cycles | T States | μsec @ 2 MHz. |
|----------|----------|---------------|
| 6        | 2Ø       | 10            |

# LD (rr),A

Load Accumulator into memory location addressed by Register Pair rr where rr is Register Pairs BC or DE.

Object Code:

|          | Hex | Decimal |  |
|----------|-----|---------|--|
| LD(BC),A | Ø2  | ØØ2     |  |
| LD(DE),A | 12  | Ø18     |  |

Description: Loads the contents of the Accumulator into a memory location whose address is held in Register Pair rr, leaving the contents of the Accumulator unaltered.

No. of Bytes: 1

Flag Register:

| Flag            | Code | Bit | Effect        |
|-----------------|------|-----|---------------|
| Sign            | s    | 7   | Not affected. |
| Zero            | Z    | 6   | Not affected. |
| _               | _    | 5   | Not used.     |
| Half Carry      | н    | 4   | Not affected. |
| _               | _    | 3   | Not used.     |
| Parity/Overflow | P/V  | 2   | Not affected. |
| Subtract        | N    | 1   | Not affected. |
| Carry           | С    | Ø   | Not affected. |
|                 |      |     |               |

Example: LD BC,1A24H LD A,4AH LD (BC),A

If the contents of Register Pair BC are 1A 24, and the contents of the Accumulator are 4A, this instruction will load 4A into memory location 1A 24, leaving the same value in the Accumulator.

Addressing Mode: Indirect.

| M Cycles | T States | μsec @ 2 MHz. |  |
|----------|----------|---------------|--|
| 2        | 7        | 3.5           |  |

# LD (HL),n

Load Immediate into memory n, where n is an 8 bit integer.

Object Code:

|           | Hex  | Decimal |  |  |
|-----------|------|---------|--|--|
| LD (HL),n | 36 n | Ø54 n   |  |  |

Description: Loads the value n into a memory location whose address is held in Register Pair HL.

No. of Bytes: 2

Flag Register:

| Flag            | Code | Bit | Effect        |
|-----------------|------|-----|---------------|
| Sign            | S    | 7   | Not affected. |
| Zero            | Z    | 6   | Not affected. |
| _               |      | 5   | Not used.     |
| Half Carry      | н    | 4   | Not affected. |
| _               |      | 3   | Not used.     |
| Parity/Overflow | P/V  | 2   | Not affected. |
| Subtract        | N    | 1   | Not affected. |
| Carry           | С    | Ø   | Not affected. |
|                 |      |     |               |

Example: LD HL,223CH

LD (HL),**1**CH

The Source Code statement LD HL,1CH will produce the Object Code instruction 36 1C(Hex.). If the contents of Register Pair HL are 22 3C, this instruction will load the value 1C(Hex.) into memory location 22 3C.

Addressing Mode: Immediate/Indirect.

| M Cycles | T States | μsec @ 2 MHz. |
|----------|----------|---------------|
| 3        | 1Ø       | 5             |

# LD (HL),r

Load memory location from Register r where r is any of the Registers A, B, C, D, E, H or L.

Object Code:

|           | Hex | Decimal |  |
|-----------|-----|---------|--|
| LD (HL),A | 77  | 119     |  |
| LD (HL),B | 7Ø  | 112     |  |
| LD (HL),C | 71  | 113     |  |
| LD (HL),D | 72  | 114     |  |
| LD (HL),E | 73  | 115     |  |
| LD (HL),H | 74  | 116     |  |
| LD (HL),L | 75  | 117     |  |
| ,_        | ,   |         |  |

Description: Loads the contents of Register r into a memory location whose address is held in Register Pair HL, leaving the contents of Register r unaltered.

No. of Bytes: 1

| Flag            | Code | Bit | Effect        |
|-----------------|------|-----|---------------|
| Sign            | S    | 7   | Not affected. |
| Zero            | Z    | 6   | Not affected. |
|                 |      | 5   | Not used.     |
| Half Carry      | н    | 4   | Not affected. |
| _               | _    | 3   | Not used.     |
| Parity/Overflow | P/V  | 2   | Not affected. |
| Subtract        | N    | 1   | Not affected. |
| Carry           | С    | Ø   | Not affected. |
|                 |      |     |               |

Example: LD HL,48E1H LD A,87H LD (HL),A

If the contents of Register Pair HL are 48 E1, and the contents of the Accumulator are 87, this instruction will load 87 into memory location 48 E1, leaving the same value in the Accumulator.

Addressing Mode: Indirect.

| M Cycles | T States | μsec @ 2 MHz. |  |
|----------|----------|---------------|--|
| 2        | 7        | 3.5           |  |

### LD (IX + d),n LD (IY + d),n

Description: Loads the integer n into a memory location which is identified by the contents of Index Register IX or IY (modified by displacement d, which is specified in the instruction), leaving the contents of that memory location unaltered.

No. of Bytes: 4

Object Code:

|               | Hex       | Decimal             |  |
|---------------|-----------|---------------------|--|
| LD (IX + d),n | DD 36 d n | <b>221 Ø</b> 54 d n |  |
| LD (IY + d),n | FD 36 d n | 253 Ø54 d n         |  |

Where: d is the required displacement from the memory location whose address is held in Index Register IX or IY.

Flag Register:

| Flag                                                                | Code                         | Bit                             | Effect                                                                                                                                            |
|---------------------------------------------------------------------|------------------------------|---------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| Sign<br>Zero<br>—<br>Half Carry<br>—<br>Parity/Overflow<br>Subtract | S<br>Z<br>H<br>P/V<br>N<br>C | 7<br>6<br>5<br>4<br>3<br>2<br>1 | Not affected.<br>Not affected.<br>Not used.<br>Not affected.<br>Not affected.<br>Not affected.<br>Not affected.<br>Not affected.<br>Not affected. |
| Carry                                                               |                              | Ø                               |                                                                                                                                                   |

Example: LD IX,2A35H LD (IX+3),5H

If the contents of Index Register IX are 2A 35 and d and n are specified in he instruction as 3 and 5 respectively, this instruction will load the value 05(Hex.) into memory location 2A 38.

Addressing Mode: Indexed/Immediate.

| M Cycles | T States | μsec @ 2 MHz. |  |
|----------|----------|---------------|--|
| 3        | 19       | 9.5           |  |

## LD (IX+d),r LD (IY+d),r

Load memory from Register r using Index Register IX or IY, where r can be any of the registers A, B, C, D, E, H or L and d is the required displacement from the memory location whose address is held in the Index Register.

Object Code:

|             | Hex     | Decimal   |
|-------------|---------|-----------|
| LD (IY+d),A | FD 77 d | 253 119 d |
| LD (IY+d),B | FD 70 d | 253 112 d |
| LD (IY+d),C | FD 71 d | 253 113 d |
| LD (IY+d),D | FD 72 d | 253 114 d |
| LD (IY+d),E | FD 73 d | 253 115 d |
| LD (IY+d),H | FD 74 d | 253 116 d |
| LD(IY+d),L  | FD 75 d | 253 117 d |
|             |         |           |

| d 221 119 d<br>d 221 112 d<br>d 221 113 d<br>d 221 113 d<br>d 221 115 d<br>d 221 116 d<br>d 221 117 d |                                                                                                               |
|-------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------|
|                                                                                                       | d         221 112 d           d         221 113 d           d         221 115 d           d         221 116 d |

Description: Loads the contents of Register r into a memory location whose address is identified by the contents of Index Register IX or IY (modified by displacement d, which is specified in the instruction), leaving the contents of the Register unaltered.

No. of Bytes: 3

Flag Register:

| Flag            | Code | Bit | Effect        |
|-----------------|------|-----|---------------|
| Sign            | s    | 7   | Not affected. |
| Zero            | z    | 6   | Not affected. |
| _               | _    | 5   | Not used.     |
| Half Carry      | н    | 4   | Not affected. |
| _               | _    | 3   | Not used.     |
| Parity/Overflow | P/V  | 2   | Not affected. |
| Subtract        | Ν    | 1   | Not affected. |
| Carry           | С    | Ø   | Not affected. |
|                 |      |     |               |

Example: LD IX, 34A1H LD A,48H LD (IX+6),A

If the contents of Index Register IX are 34 A1, and d in the instruction is 6, the required memory location is 34 A7. If the contents of the Accumulator are 48, this instruction will load 48 into memory location 34 A7, leaving the same value in the Accumulator.

Addressing Mode: Indexed.

| M Cycles | T States | μsec @ 2 MHz. |
|----------|----------|---------------|
| 5        | 19       | 9.5           |

## LDD

Data transfer between memory locations. Decrement source and destination addresses.

Object Code:

|     | Hex   | Decimal |  |
|-----|-------|---------|--|
| LDD | ED A8 | 237 168 |  |

Description: Transfers one byte of data from the memory location whose address is held in Register Pair HL to the memory location whose address is held in Register Pair DE, then decrements Register Pairs BC (which is used as a byte counter), DE and HL.

No. of Bytes: 2

| Flag            | Code | Bit | Effect                                                                                                   |
|-----------------|------|-----|----------------------------------------------------------------------------------------------------------|
| Sign            | S    | 7   | Not affected.                                                                                            |
| Zero            | Z    | 6   | Not affected.                                                                                            |
|                 |      | 5   | Not used.                                                                                                |
| Half Carry      | н    | 4   | RESET = Ø.                                                                                               |
| _               |      | 3   | Not used.                                                                                                |
| Parity/Overflow | P/V  | 2   | SET = 1 if the new contents of<br>Register Pair BC $\neq \emptyset$ , otherwise<br>RESET = $\emptyset$ . |
| Subtract        | N    | 1   | $RESET = \emptyset.$                                                                                     |
| Carry           | С    | Ø   | Not affected.                                                                                            |

#### Example: LD HL,2145H LD DE,6785H LD BC,Ø1H LDD

If the contents of Register Pair HL are 21 45 and the contents of Register Pair DE are 67 85, this instruction will transfer the contents of memory location 21 45 to memory location 67 85, leaving the same value in memory location 21 45. It will also decrement Register Pair HL to 21 44, Register Pair DE to 67 84 and, if the original contents of Register Pair BC were  $\emptyset$ 1, that Register Pair will be decremented to  $\emptyset$ 0, then Flags H, P/V and N will be RESET =  $\emptyset$ .

Addressing Mode: Indirect.

| M Cycles | T States | μsec @ 2 MHz. |
|----------|----------|---------------|
| 4        | 16       | 8             |

## LDDR

Data transfer between memory locations until counter is zero. Decrement source and destination registers.

Object Code:

|      | Hex   | Decimal |  |
|------|-------|---------|--|
| LDDR | ED B8 | 237 184 |  |

Description: Transfers one byte of data from the memory location whose address is held in Register Pair HL to the memory location whose address is held in Register Pair DE, then decrements Register Pairs BC (which is used as a byte counter), DE and HL. If the new contents of Register Pair BC =  $\emptyset$  the instruction is terminated, otherwise the Program Counter (PC) is decremented by 2 and the instruction is repeated.

NOTE 1 If the initial value of Register Pair is set to zero, this instruction will cycle through all 64K of memory.

NOTE 2 Interrupts can be accepted after each transfer is complete.

No. of Bytes: 2

| Flag            | Code | Bit | Effect               |
|-----------------|------|-----|----------------------|
| Sign            | S    | 7   | Not affected.        |
| Zero            | Z    | 6   | Not affected.        |
|                 | _    | 5   | Not used.            |
| Half Carry      | н    | 4   | $RESET = \emptyset.$ |
|                 | _    | 3   | Not used.            |
| Parity/Overflow | P/V  | 2   | $RESET = \emptyset.$ |
| Subtract        | N    | 1   | $RESET = \emptyset.$ |
| Carry           | С    | Ø   | Not affected.        |
|                 |      |     |                      |

#### Example: LD HL,4680H LD DE,2435H LD BC,03H LDDR

If the contents of Register Pair HL are 46 80, the contents of Register Pair DE are 24 35 and the contents of Register Pair BC are 0003, this instruction will transfer the contents of memory location 46 80 to memory location 24 35, then decrement the contents of Register Pairs HL to 46 7F, DE to 24 34 and BC to 00 02 and RESET Flags H, P/V and N = 0. Because the new contents of Register Pair BC = 0, the Program Counter will be decremented by 2 (which returns it to the address of this instruction) and the LDDR instruction is repeated using the new memory location addresses in Register Pairs HL and DE.

Addressing Mode: Indirect.

|                  | M Cycles | T States | μsec @ 2 MHz. |
|------------------|----------|----------|---------------|
| BC ≠ Ø           | 5        | 21       | <b>10</b> .5  |
| $BC = \emptyset$ | 4        | 16       | 8             |

# LDI

Data transfer between memory locations. Increment source and destination addresses.

Object Code:

|     | Hex   | Decimal |  |
|-----|-------|---------|--|
| LDI | ED AØ | 237 160 |  |

Description: Transfers one byte of data from the memory location whose address is held in Register Pair HL to the memory location whose address is held in Register Pair DE, then increments Register Pairs HL and DE and decrements Register Pair BC (which is used as a byte counter).

No. of Bytes: 2

| Flag            | Code | Bit | Effect                                     |
|-----------------|------|-----|--------------------------------------------|
| Sign            | S    | 7   | Not affected.                              |
| Zero            | Z    | 6   | Not affected.                              |
|                 | _    | 5   | Not used.                                  |
| Half Carry      | Н    | 4   | RESET = Ø.                                 |
| -               | _    | 3   | Not used.                                  |
| Parity/Overflow | P/V  | 2   | SET = 1 if the new contents of             |
|                 |      |     | Register Pair BC = $\emptyset$ , otherwise |
|                 |      |     | $RESET = \emptyset.$                       |
| Subtract        | Ν    | 1   | $RESET = \emptyset.$                       |
| Carry           | С    | Ø   | Not affected.                              |

Example: LD HL,4567H LD DE,32A5H LD BC,1628H LDI

If the contents of Register Pair HL are 45 67 and the contents of Register Pair DE are 32 A5 and the contents of Register Pair BC are 16 28, this instruction will transfer the contents of memory location 45 67 to memory location 32 A5, leaving the same value in location 45 67, then increment the contents of Register Pairs HL and DE to 45 68 and 32 A6 respectively and decrement the contents of Register Pair BC to 16 27. Flags H and N will be RESET =  $\emptyset$  and Flag P/V will be SET = 1.

Addressing Mode: Indirect.

| M Cycles | T States | μsec @ 2 MHz. |
|----------|----------|---------------|
| 4        | 16       | 8             |

# LDIR

Data transfer between memory locations until counter is zero. Increment source and destination registers.

Object Code:

|      | Hex   | Decimal |  |  |
|------|-------|---------|--|--|
| LDIR | ED BØ | 237 176 |  |  |

Description: Transfers one byte of data from the memory location whose address is held in Register Pair HL to the memory location whose address is held in Register Pair DE, then increments Register Pairs HL and DE and decrements Register Pair BC (which is used as a byte counter). If the new contents of Register Pair BC =  $\emptyset$  the instruction is terminated, otherwise the Program Counter (PC) is decremented by 2 and the instruction is repeated, using the new addresses in Register Pairs HL and DE.

NOTE 1 If the initial value of Register Pair BC is set to zero, this instruction will loop through all 64K of memory.

NOTE 2 Interrupts can be accepted after each transfer is complete.

No. of Bytes: 2

| Flag            | Code | Bit | Effect               |
|-----------------|------|-----|----------------------|
| Sign            | S    | 7   | Not affected.        |
| Zero            | Z    | 6   | Not affected.        |
| _               |      | 5   | Not used.            |
| Half Carry      | н    | 4   | $RESET = \emptyset.$ |
| _               | _    | 3   | Not used.            |
| Parity/Overflow | P/V  | 2   | $RESET = \emptyset.$ |
| Subtract        | N    | 1   | $RESET = \emptyset.$ |
| Carry           | С    | Ø   | Not affected.        |

#### Example: LD HL,4668H LD DE,2332H LD BC,Ø11H LDIR

If the contents of Register Pair HL are 46 68, the contents of Register Pair DE are 23 32 and the contents of Register Pair BC are  $\emptyset\emptyset$  11, this instruction will transfer the contents of memory location 46 68 to memory location 23 32, leaving the same value in location 46 68, then increment the contents of Register Pairs HL and DE to 46 69 and 23 33 respectively and decrement the contents of Register Pair BC to  $\emptyset\emptyset$  1 $\emptyset$ . Flags H, P/V and N will be RESET =  $\emptyset$ .

Addressing Mode: Indirect.

|        | M Cycles | T States | μsec @ 2 MHz. |
|--------|----------|----------|---------------|
| BC ≠ Ø | 5        | 21       | 10.5          |
| BC = Ø | 4        | 16       | 8             |

## NEG

Description: Negates the contents of the Accumulator by subtracting those contents from zero (two's complement) and storing the result in the Accumulator.

NOTE: If the contents of the Accumulator are 80(Hex.), those contents will not be changed by this instruction.

No. of Bytes: 2

Object Code (Hex.): ED 44 Decimal: 237 Ø68

| Flag | Register: |
|------|-----------|
|------|-----------|

| Flag            | Code | Bit | Effect                                                                                                           |
|-----------------|------|-----|------------------------------------------------------------------------------------------------------------------|
| Sign            | S    | 7   | SET = 1 if the result is negative, otherwise RESET = $\emptyset$ .                                               |
| Zero            | Z    | 6   | SET = 1 if the result is zero, otherwise RESET = $\emptyset$ .                                                   |
| —               | _    | 5   | Not used.                                                                                                        |
| Half Carry      | н    | 4   | SET = 1 if no Borrow from Bit 4, otherwise RESET = $\emptyset$ .                                                 |
| —               | _    | 3   | Not used.                                                                                                        |
| Parity/Overflow | P/V  | 2   | SET = 1 if the original value of the Accumulator was $8\emptyset(\text{Hex.})$ , otherwise RESET = $\emptyset$ . |
| Subtract        | N    | 1   | SET = 1.                                                                                                         |
| Carry           | С    | Ø   | SET = 1 if the original value of the Accumulator was NOT $\emptyset \emptyset$ , otherwise RESET = $\emptyset$ . |

Example: LD A,02H

NEG

If the original contents of the Accumulator are @2(Hex.), this instruction will make those contents equal FE(Hex.), then SET Flags S, N and C = 1and RESET Flags Z, H and P/V =  $\hat{Q}$ .

Addressing Mode: Implicit.

| M Cycles | T States | μsec @ 2 MHz. |  |
|----------|----------|---------------|--|
| 2        | 8        | 4             |  |

## NOP

Description: Nothing occurs for one Machine Cycle.

No. of Bytes: 1

Object Code (Hex.): ØØ

Decimal: 000

#### Flag Register:

| Flag            | Code | Bit | Effect        |
|-----------------|------|-----|---------------|
| Sign            | S    | 7   | Not affected. |
| Zero            | Z    | 6   | Not affected. |
|                 | —    | 5   | Not used.     |
| Half Carry      | H    | 4   | Not affected. |
|                 | —    | 3   | Not used.     |
| Parity/Overflow | P/V  | 2   | Not affected. |
| Subtract        | N    | 1   | Not affected. |
| Carry           | C    | Ø   | Not affected. |

Addressing Mode: Implicit.

| M Cycles | T States | μsec @ 2 MHz. |
|----------|----------|---------------|
| 1        | 4        | 2             |

# OR n

OR Accumulator with data n, where n is an 8 bit integer.

Object Code:

Where n is an 8 Bit integer, specified in the instruction.

|      | Hex  | Decimal |  |
|------|------|---------|--|
| OR n | F6 n | 246 n   |  |

Description: Performs a Bit by Bit logical OR between the contents of the Accumulator and the integer n, then stores the result in the Accumulator.

No. of Bytes: 2

| Flag            | Code | Bit | Effect                                                             |
|-----------------|------|-----|--------------------------------------------------------------------|
| Sign            | S    | 7   | SET = 1 if the result is negative, otherwise RESET = $\emptyset$ . |
| Zero            | Z    | 6   | SET = 1 if the result is zero, otherwise RESET = $\emptyset$ .     |
| —               | _    | 5   | Not used.                                                          |
| Half Carry      | н    | 4   | $RESET = \emptyset.$                                               |
| -               | —    | 3   | Not used.                                                          |
| Parity/Overflow | P/V  | 2   | SET = 1 for Parity Even, RESET = $\emptyset$ for Parity Odd.       |
| Subtract        | N    | 1   | RESET = Ø.                                                         |
| Carry           | С    | Ø   | RESET = Ø.                                                         |

#### Example: LD A,6AH OR 15H

If the contents of the Accumulator are 6AH (Bit Pattern  $\emptyset 11\emptyset 1\emptyset 1\emptyset$ ) and n in the intructions is 15H (Bit Pattern  $\emptyset 0\emptyset 1\emptyset 1\emptyset$ 1) the result will be 7FH (Bit Pattern  $\emptyset 1111111$ ) and this is stored in the Accumulator, while Flags S, Z, P/V, N, H and C are RESET =  $\emptyset$ .

Addressing Mode: Immediate.

| M Cycles | T States | μsec @ 2 MHz. |  |
|----------|----------|---------------|--|
| 2        | 7        | 3.5           |  |

## OR r

Or Register r with the Accumulator where r is any of the Registers A, B, C, D, E, H or L.

Object Code:

|      | Hex | Decimal |  |
|------|-----|---------|--|
| ORA  | B7  | 183     |  |
| OR B | ВØ  | 176     |  |
| ORC  | B1  | 177     |  |
| OR D | B2  | 178     |  |
| OR E | B3  | 179     |  |
| OR H | B4  | 18Ø     |  |
| ORL  | B5  | 181     |  |
|      |     |         |  |

Description: Performs a Bit by Bit logical OR between the contents of the Accumulator and the contents of specified register, then stores the result in the Accumulator leaving the contents of the specified register unaltered. Note that this instruction will never change the value of the A register, but will change the value of some of the flags. As with AND A, OR A is used only for setting flags to useful values.

No. of Bytes: 1

| Flag            | Code | Bit | Effect                                                             |
|-----------------|------|-----|--------------------------------------------------------------------|
| Sign            | S    | 7   | SET = 1 if the result is negative, otherwise RESET = $\emptyset$ . |
| Zero            | Z    | 6   | SET = 1 if the result is zero, otherwise RESET = $\emptyset$ .     |
| -               | -    | 5   | Not used.                                                          |
| Half Carry      | н    | 4   | $RESET = \emptyset.$                                               |
| _               | _    | 3   | Not used.                                                          |
| Parity/Overflow | P/V  | 2   | SET = 1 for Parity Even, RESET = $\emptyset$ for Parity Odd.       |
| Subtract        | N    | 1   | $RESET = \emptyset.$                                               |
| Carry           | С    | Ø   | $RESET = \emptyset.$                                               |

#### Example: LD A,21H

#### OR A

If the contents of the Accumulator are 21(Hex.) the logical OR is performed as follows:

|             | Hex | Binary   |
|-------------|-----|----------|
| Accumulator | 21  | ØØ1ØØØØ1 |
| Accumulator | 21  | ØØ1ØØØØ1 |
| Result      | 21  | ØØ1ØØØØ1 |

Flag P/V is SET = 1 and Flags S, Z, N, H and C are RESET =  $\emptyset$ .

Addressing Mode: Implicit.

| M Cycles | T States | μsec @ 2 MHz. |
|----------|----------|---------------|
| 1        | 4        | 2             |

# OR (HL)

Description: Performs a Bit by Bit logical OR between the contents of the Accumulator and the contents of a memory location whose address is held in Register Pair HL. The contents of both Register Pair HL and the memory location remain unaltered.

No. of Bytes: 1

Object Code (Hex.): B6

Decimal: 182

Flag Register:

| Flag            | Code | Bit | Effect                                                             |
|-----------------|------|-----|--------------------------------------------------------------------|
| Sign            | S    | 7   | SET = 1 if the result is negative, otherwise RESET = $\emptyset$ . |
| Zero            | Z    | 6   | SET = 1 if the result is zero, otherwise RESET = $\emptyset$ .     |
| —               | _    | 5   | Not used.                                                          |
| Half Carry      | н    | 4   | RESET = $\emptyset$                                                |
| —               | _    | 3   | Not used.                                                          |
| Parity/Overflow | P/V  | 2   | SET = 1 for Parity Even, RESET = $\emptyset$ for Parity Odd.       |
| Subtract        | N    | 1   | $RESET = \emptyset.$                                               |
| Carry           | С    | Ø   | RESET = Ø.                                                         |

Example: LD A,24H

LD HL,A367H

LD (HL),12H

OR (HL)

If the contents of the Accumulator are 24(Hex.), the contents of Register Pair HL are A3 67 and the contents of memory location A3 67 are 12, the logical OR is performed as follows:

|                | Hex | Binary   |
|----------------|-----|----------|
| Accumulator    | 24  | ØØ1ØØ1ØØ |
| Location A3 67 | 12  | ØØØ1ØØ1Ø |
| Result         | 36  | 00110110 |

Flag P/V is SET = 1 while Flags S, Z, N, H and C are RESET =  $\emptyset$ . Addressing Mode: Indirect.

Cont.

| M Cycles | T States | μsec @ 2 MHz. |
|----------|----------|---------------|
| 2        | 7        | 3.5           |

# $\frac{OR (IX + d)}{OR (IY + d)}$

Description: Performs a Bit by Bit logical OR between the contents of the Accumulator and the contents of a memory location whose address is identified by the contents of Index Register IX or IY (modified by displacement d, which is specified in the instruction), then stores the result in the Accumulator. The contents of both Index Register IX and IY and the memory location remain unaltered.

No. of Bytes: 3

Object Code:

|            | Hex     | Decimal   |  |
|------------|---------|-----------|--|
| OR(IX + d) | DD B6 d | 221 182 d |  |
| OR(IY + d) | FD B6 d | 253 182 d |  |

Where d is the required displacement from the memory location whose address is held in Index Register IX or IY.

| Flag            | Code | Bit | Effect                                                             |
|-----------------|------|-----|--------------------------------------------------------------------|
| Sign            | S    | 7   | SET = 1 if the result is negative, otherwise RESET = $\emptyset$ . |
| Zero            | Z    | 6   | SET = 1 if the result is zero, otherwise RESET = $\emptyset$ .     |
| —               | _    | 5   | Not used.                                                          |
| Half Carry      | н    | 4   | $RESET = \emptyset.$                                               |
| —               | -    | 3   | Not used.                                                          |
| Parity/Overflow | P/V  | 2   | SET = 1 for Parity Even, RESET = $\emptyset$ for Parity Odd.       |
| Subtract        | Ν    | 1   | $RESET = \emptyset.$                                               |
| Carry           | С    | Ø   | RESET = Ø.                                                         |

Example: LD IX,2105H LD HL,2108H LD (HL),12H LD A,0A3H OR (IX+3)

If the contents of Index Register IX are 21  $\emptyset$ 5 and d in the instruction is 3, the required memory location is 21  $\emptyset$ 8. If the contents of the Accumulator are A3 and the contents of memory location 21  $\emptyset$ 8 are 12, the logical OR performs as follows:

|                | Hex | Binary   |
|----------------|-----|----------|
| Accumulator    | A3  | 10100011 |
| Location 21 Ø8 | 12  | 00010010 |
| Result         | B3  | 10110011 |

Flag S is SET = 1, while Flags Z, H, P/V, N and C are RESET =  $\emptyset$ .

Addressing Mode: Indexed.

| M Cycles | T States | μsec @ 2 MHz. |
|----------|----------|---------------|
| 5        | 19       | 9.5           |

## OTDR

Description: Outputs, to the device identified by the contents of Register C, the contents of a memory location whose address is held in register Pair HL, then decrements register B (which is used as a byte counter) and Register Pair HL. If Register B is then  $<> \emptyset$ , the Program Counter (PC) is decremented by 2 and the instruction is repeated.

NOTE: Register C supplies Bits Ø to 7 to the Address Bus and Register B provides Bits 8 to 15 (after Register B is decremented.

No. of Bytes: 2

Object Code (Hex.): ED BB

Decimal: 237 187

Flag Register:

| Flag                                                                | Code                    | Bit                             | Effect                                                                                  |
|---------------------------------------------------------------------|-------------------------|---------------------------------|-----------------------------------------------------------------------------------------|
| Sign<br>Zero<br>—<br>Half Carry<br>—<br>Parity/Overflow<br>Subtract | S<br>Z<br>H<br>P/V<br>N | 7<br>6<br>5<br>4<br>3<br>2<br>1 | Not known.<br>SET = 1<br>Not used.<br>Not known.<br>Not used.<br>Not known.<br>SET = 1. |
| Carry                                                               | С                       | Ø                               | Not affected.                                                                           |

Example: LD C,21H LD HL,43A1H LD B,1 OTDR

If Register C contains 21 (Hex.) and Register Pair HL contains 43 A1, this instruction will output the contents of memory location 43 A1 to device number 21H, then decrements Register B and Register Pair HL. If the new contents of Register  $B = \emptyset$ , the instruction is terminated, otherwise the Program Counter reverts to the address of the instruction which is then repeated (Register Pair HL will now contain 43 A $\emptyset$ ).

Addressing Mode: External.

|                  | M Cycles | T States | μsec @ 2 MHz. |
|------------------|----------|----------|---------------|
| $B <> \emptyset$ | 5        | 21       | 10.5          |
| $B= \emptyset$   | 4        | 16       | 8             |

## OTIR

Description: Outputs, to the device identified by the contents of Register C, the contents of a memory location whose address is held in register Pair HL, then decrements register B (which is used as a byte counter) and increments Register Pair HL. If Register B is then  $<> \emptyset$ , the Program Counter (PC) is decremented by 2 and the instruction is repeated.

NOTE: Register C supplies Bits Ø to 7 to the Address Bus and Register B provides Bits 8 to 15 (after Register B is decremented).

No. of Bytes: 2

Object Code (Hex.): ED B3

Decimal: 237 179

Flag Register:

| Flag            | Code | Bit | Effect        |
|-----------------|------|-----|---------------|
| Sign            | S    | 7   | Not known.    |
| Zero            | Z    | 6   | SET = 1       |
| -               | _    | 5   | Not used.     |
| Half Carry      | н    | 4   | Not known.    |
| —               | —    | 3   | Not used.     |
| Parity/Overflow | P/V  | 2   | Not known.    |
| Subtract        | N    | 1   | SET = 1.      |
| Carry           | С    | Ø   | Not affected. |

Example: LD C,8H LD HL,3564H

LD B.1ØH

OTIR

If Register C contains Ø8(Hex.) and Register Pair HL contains 35 64, this instruction will output the contents of memory location 35 64 to device number 8, then decrements Register B and increments Register Pair HL to 35 65. If the new contents of Register B are zero, the instruction is terminated, otherwise theProgram Counter reverts to the address of this instruction which is then repeated using the new memory location address which is now held in Register Pair HL.

Addressing Mode: External.

|                 | M Cycles | T States | μsec @ 2 MHz. |
|-----------------|----------|----------|---------------|
| B <> Ø          | 5        | 21       | 10.5          |
| $B = \emptyset$ | 4        | 16       | 8             |

# **OUT (C),**r

Output from Register r where r is any of the registers A, B, C, D, E, H or L.

Object Code:

|                                                                            | Hex                                                | Decimal                                                        |  |
|----------------------------------------------------------------------------|----------------------------------------------------|----------------------------------------------------------------|--|
| OUT (C),A<br>OUT (C),B<br>OUT (C),C<br>OUT (C),D<br>OUT (C),E<br>OUT (C),H | ED 79<br>ED 41<br>ED 49<br>ED 51<br>ED 59<br>ED 61 | 237 113<br>237 Ø65<br>237 Ø73<br>237 Ø81<br>237 Ø89<br>237 Ø97 |  |
| OUT (C),L                                                                  | ED 69                                              | 237 105                                                        |  |

Description: Output from Register r to I/O Port addressed by Register C.

No. of Bytes: 2

Flag Register:

| Flag                                                                | Code                    | Bit                             | Effect                                                                                                      |
|---------------------------------------------------------------------|-------------------------|---------------------------------|-------------------------------------------------------------------------------------------------------------|
| Sign<br>Zero<br>—<br>Half Carry<br>—<br>Parity/Overflow<br>Subtract | S<br>Z<br>H<br>P/V<br>N | 7<br>6<br>5<br>4<br>3<br>2<br>1 | Not affected.<br>Not affected.<br>Not used.<br>Not affected.<br>Not used.<br>Not affected.<br>Not affected. |
| Carry                                                               | С                       | Ø                               | Not affected.                                                                                               |

Example: LD A,18H LD C,ØAH OUT (C),A

If the contents of the Accumulator are 18(Hex.) and the contents of Register C are ØA(Hex.), OUT (C), A will output 18(Hex.) to Port number ØAH, leaving the original values in both the Accumulator and Register C.

Addressing Mode: External.

| M Cycles | T States | μsec @ 2 MHz. |
|----------|----------|---------------|
| 3        | 12       | 6             |

# OUT (n),A

Output A from the Accumulator to Port n, where n is any value from  $\emptyset$ -255.

Object Code: (Hex.) D3 n Decimal: 211 n

Description: Output from the Accumulator to Port n.

No. of Bytes: 2

Flag Register:

| Flag                                                                         | Code                         | Bit                                  | Effect                                                                                                                           |
|------------------------------------------------------------------------------|------------------------------|--------------------------------------|----------------------------------------------------------------------------------------------------------------------------------|
| Sign<br>Zero<br>—<br>Half Carry<br>—<br>Parity/Overflow<br>Subtract<br>Carry | S<br>Z<br>H<br>P/V<br>N<br>C | 7<br>6<br>5<br>4<br>3<br>2<br>1<br>Ø | Not affected.<br>Not affected.<br>Not used.<br>Not affected.<br>Not affected.<br>Not affected.<br>Not affected.<br>Not affected. |
| ,                                                                            |                              |                                      |                                                                                                                                  |

Example: LD A,18H

OUT (ØAH),A

If the contents of the Accumulator are 18(Hex.) and the value of n is  $\emptyset$ A(Hex.), this instruction will output 18(Hex.) to Port number  $\emptyset$ AH leaving the original value in the Accumulator.

Addressing Mode: External.

| M Cycles | T States | μsec @ 2 MHz. |
|----------|----------|---------------|
| 3        | 11       | 5.5           |

## OUTD

Description: Outputs the contents of a memory location, whose address is held in Register Pair HL, to the Port (one of 256) whose address is held in Register C. The contents of the memory location and Register C remain unchanged while the contents of Register B (which is used as a byte counter) and Register Pair HL are both decremented.

No. of Bytes: 2

Object Code (Hex.): ED AB

Decimal: 237 171

Flag Register:

| Flag            | Code | Bit | Effect                                                                                 |
|-----------------|------|-----|----------------------------------------------------------------------------------------|
| Sign            | S    | 7   | Not known.                                                                             |
| Zero            | Z    | 6   | SET = 1 if the new value of Register $B = \emptyset$ , otherwise RESET = $\emptyset$ . |
| _               | —    | 5   | Not used.                                                                              |
| Half Carry      | Н    | 4   | Not known.                                                                             |
| -               | —    | 3   | Not used.                                                                              |
| Parity/Overflow | P/V  | 2   | Not known.                                                                             |
| Subtract        | N    | 1   | SET = 1.                                                                               |
| Carry           | С    | Ø   | Not affected.                                                                          |

Example: LD HL,2134H LD C,08H

LD (HL),12H LD B,Ø OUTD

If the contents of Register Pair HL are 21 34 and the contents of Register C are  $\emptyset$ 8(Hex.), the requirement is for the contents of memory location 21 34 to be output to Port number 8. If the contents of memory location 21 34 are 12(Hex.), this instruction will output 12(Hex.) to Port number 8, decrement Register Pair HL to 21 33, decrement Register B, SET Flag N =  $\emptyset$  and either SET Flag Z = 1 (if the new value of Register B =  $\emptyset$ ) or RESET that flag =  $\emptyset$ .

Addressing Mode: External.

| M Cycles | T States | μsec @ 2 MHz. |
|----------|----------|---------------|
| 4        | 16       | 8             |

## ΙΤͶΟ

Description: Outputs the contents of a memory location, whose address is held in Register Pair HL, to the Port (one of 256) whose address is held in Register C. The contents of the memory location and Register C remain unchanged while the contents of Register B (which is used as a byte counter) are decremented, and Register Pair HL is incremented.

No. of Bytes: 2

Object Code (Hex.): ED A3

Decimal: 237 163

Flag Register:

| Flag            | Code | Bit | Effect                                                                                 |
|-----------------|------|-----|----------------------------------------------------------------------------------------|
| Sign            | S    | 7   | Not known.                                                                             |
| Zero            | Z    | 6   | SET = 1 if the new value of Register $B = \emptyset$ , otherwise RESET = $\emptyset$ . |
|                 | _    | 5   | Not used.                                                                              |
| Half Carry      | н    | 4   | Not known.                                                                             |
| —               |      | 3   | Not used.                                                                              |
| Parity/Overflow | P/V  | 2   | Not known.                                                                             |
| Subtract        | Ν    | 1   | SET = 1.                                                                               |
| Carry           | С    | Ø   | Not affected.                                                                          |

Example: LD HL,2134H LD (HL),12H LD C,08H LD B,1 OUTI

If the contents of Register Pair HL are 21 34, and the contents of Register C are  $\emptyset$ 8(Hex.), the requirement is for the contents of memory location 21 34 to be output to Port number 8. If the contents of memory location 21 34 are 12(Hex.), this instruction will output 12(Hex.) to Port number 8, increment Register Pair HL to 21 35, decrement Register B, SET Flag N =  $\emptyset$  and either SET Flag Z = 1 (if the new value of Register B =  $\emptyset$ ) or RESET that flag =  $\emptyset$ .

Addressing Mode: External.

| M Cycles | T States | μsec @ 2 MHz. |  |
|----------|----------|---------------|--|
| 4        | 16       | 8             |  |

## POP rr

Read from top of Stack into Register Pair rr where rr is any of the Register Pairs AF, BC, DE or HL.

Object Code:

|        | Hex | Decimal |  |
|--------|-----|---------|--|
| POP AF | F1  | 241     |  |
| POP BC | C1  | 193     |  |
| POP DE | D1  | 209     |  |
| POP HL | E1  | 225     |  |
|        |     |         |  |

Description: Loads the contents of the memory location, whose address is held in the Stack Pointer (SP), into the Lower Order Byte of the designated Register Pair and the contents of the next memory location (SP+1) into the Higher Order byte of that Register Pair. The Stack Pointer is incremented twice while the contents of both memory locations remain unaltered.

No. of Bytes: 1

| Flag            | Code | Bit | Effect        |
|-----------------|------|-----|---------------|
| Sign            | S    | 7   | Not affected. |
| Zero            | Z    | 6   | Not affected. |
|                 | _    | 5   | Not used.     |
| Half Carry      | н    | 4   | Not affected. |
| _               | _    | 3   | Not used.     |
| Parity/Overflow | P/V  | 2   | Not affected. |
| Subtract        | N    | 1   | Not affected. |
| Carry           | С    | Ø   | Not affected. |
|                 |      |     |               |

Example: LD BC,0568H LD (1234),BC LD SP,1234 POP AF

If the Stack Pointer (SP) contains 12 34, and memory location 12 34 contains 68, that value (68) is loaded into Register F then the Stack Pointer is incremented to 12 35 and the contents of memory location 12 35 (say 05H), loaded into the Accumulator after which the Stack Pointer is incremented again to 12 36.

Addressing Mode: Indirect.

| M Cycles | T States | μsec @ 2 MHz. |
|----------|----------|---------------|
| 3        | 1Ø       | 5             |

## POP IX POP IY

Read from top of Stack into Index Register.

Object Code:

|        | Hex   | Decimal |  |
|--------|-------|---------|--|
| POP IX | DD E1 | 221 225 |  |
| POP IY | FD E1 | 253 225 |  |

Description: Loads the contents of the memory location, whose address is held in the Stack Pointer (SP), into the Lower Order Byte of the designated Index Register and the contents of the next memory location (SP+1) into the Higher Order byte of that Index Register. The Stack Pointer is incremented twice while the contents of both memory locations remain unaltered.

No. of Bytes: 2

| Flag            | Code | Bit | Effect        |
|-----------------|------|-----|---------------|
| Sign            | S    | 7   | Not affected. |
| Zero            | Z    | 6   | Not affected. |
|                 |      | 5   | Not used.     |
| Half Carry      | н    | 4   | Not affected. |
| _               | _    | 3   | Not used.     |
| Parity/Overflow | P/V  | 2   | Not affected. |
| Subtract        | N    | 1   | Not affected. |
| Carry           | С    | Ø   | Not affected. |
|                 |      |     |               |

Example: LD BC,3714H LD (4589H),BC LD SP,4589H POP IX

If the Stack Pointer contains 45 89, and memory location 45 89 contains 14, that value (14) is loaded into the Lower Order byte of Index Register IX then the Stack Pointer is incremented to 45 8A and the contents of memory location 45 8A loaded into the Higher Order byte of Index Register IX. If the contents of location 45 8A are 37, the contents of Index Register IX will be 37 14. The Stack Pointer is then again incremented to 45 8B.

Addressing Mode: Indirect.

| M Cycles | T States | μsec @ 2 MHz. |
|----------|----------|---------------|
| 4        | 14       | 7             |

### PUSH rr

Write contents of Register Pair rr to the top of the Stack, where rr can be AF, BC, DE or HL.

Object Code:

|                               | Hex            | Decimal           |  |
|-------------------------------|----------------|-------------------|--|
| PUSH AF<br>PUSH BC<br>PUSH DE | F5<br>C5<br>D5 | 245<br>197<br>213 |  |
| PUSH HL                       | E5             | 229               |  |

Description: Pushes the contents of the specified Register Pair on to the top of the memory Stack. The Stack Pointer is decremented and the contents of the Higher Order byte of the Register Pair loaded into the memory location whose address is now held in the Stack Pointer (SP), then the Stack Pointer is again decremented and the contents of the Lower Order byte of the Register Pair loaded into the memory location whose address is the new contents of the Stack Pointer. The contents of the Register Pair remain unaltered.

No. of Bytes: 1

| Flag            | Code | Bit | Effect        |
|-----------------|------|-----|---------------|
| Sign            | S    | 7   | Not affected. |
| Zero            | Z    | 6   | Not affected. |
|                 | _    | 5   | Not used.     |
| Half Carry      | н    | 4   | Not affected. |
| —               | _    | 3   | Not used.     |
| Parity/Overflow | P/V  | 2   | Not affected. |
| Subtract        | N    | 1   | Not affected. |
| Carry           | С    | Ø   | Not affected. |
|                 |      |     |               |

#### Example: LD SP,3462H LD BC,AABBH PUSH BC

If the contents of the Stack Pointer are 34, 62, PUSH BC will decrement this to 34 61 and load the contents of the B Register into memory location 34 61, decrement the Stack Pointer again to 34 60 and load the contents of the C Register into memory location 34 60.

Addressing Mode: Indirect.

| M Cycles | T States | μsec @ 2 MHz. |
|----------|----------|---------------|
| 3        | 11       | 5.5           |

### PUSH IX PUSH IY

Write contents of Index Register to the top of the Stack.

Object Code:

|         | Hex   | Decimal |  |
|---------|-------|---------|--|
| PUSH IX | DD E5 | 221 229 |  |
| PUSH IY | FD E5 | 253 229 |  |

Description: Pushes the contents of the specified Index Register on to the top of the memory Stack. The Stack Pointer (SP) is decremented and the contents of the Higher Order byte of the Index Register loaded into the memory location whose address is now held in the Stack Pointer, then the Stack Pointer is again decremented and the contents of the Lower Order byte of the Index Register loaded into the memory location whose address is the new contents of the Stack Pointer. The contents of the Index Register remain unaltered.

No. of Bytes: 2

| Flag            | Code | Bit | Effect        |
|-----------------|------|-----|---------------|
| Sign            | S    | 7   | Not affected. |
| Zero            | Z    | 6   | Not affected. |
|                 | _    | 5   | Not used.     |
| Half Carry      | н    | 4   | Not affected. |
| _               |      | 3   | Not used.     |
| Parity/Overflow | P/V  | 2   | Not affected. |
| Subtract        | N    | 1   | Not affected. |
| Carry           | С    | Ø   | Not affected. |
|                 |      |     |               |

Example: LD SP,5834H LD IX,ØAABBH PUSH IX

If the contents of the Stack Pointer are 58 34, this instruction will decrement this to 58 33 and load the contents of the Higher Order byte of Index Register IX into the memory location 58 33, decrement the Stack Pointer again, to 58 32, then load the contents of the Lower Order byte of Index Register IX into memory location 58 32.

Addressing Mode: Indirect.

| M Cycles | T States | μsec @ 2 MHz. |
|----------|----------|---------------|
| 4        | 15       | 7.5           |

## RES b,r

No. of Bytes: 2

Object Code (Hex.): CB xx Decimal: 203 yyy

Where: b is the specified Bit (Range  $\emptyset$  — 7) to be RESET. r is the nominated Register (A, B, C, D, E, H or L) containing b. xx and yyy are taken from the table below:

|              |                                        | A                                                    |                                        | В                                                    |                                              | С                                                    |                                        | D                                                    |                                              | E                                                    |                                        | н                                                    |                                              | L                                                    |
|--------------|----------------------------------------|------------------------------------------------------|----------------------------------------|------------------------------------------------------|----------------------------------------------|------------------------------------------------------|----------------------------------------|------------------------------------------------------|----------------------------------------------|------------------------------------------------------|----------------------------------------|------------------------------------------------------|----------------------------------------------|------------------------------------------------------|
| Bit          | xx                                     | ууу                                                  | XX                                     | ууу                                                  | xx                                           | ууу                                                  | xx                                     | ууу                                                  | xx                                           | ууу                                                  | xx                                     | ууу                                                  | XX                                           | ууу                                                  |
| Ø<br>1234567 | 87<br>8F<br>97<br>9F<br>A7<br>B7<br>BF | 135<br>143<br>151<br>159<br>167<br>175<br>183<br>191 | 8Ø<br>88<br>9Ø<br>98<br>AØ<br>BØ<br>B8 | 128<br>136<br>144<br>152<br>16Ø<br>168<br>176<br>184 | 81<br>89<br>91<br>99<br>A1<br>A9<br>B1<br>B9 | 129<br>137<br>145<br>153<br>161<br>169<br>177<br>185 | 82<br>92<br>9A<br>A2<br>AA<br>B2<br>BA | 130<br>138<br>146<br>154<br>162<br>170<br>178<br>186 | 83<br>8B<br>93<br>9B<br>A3<br>AB<br>B3<br>BB | 131<br>139<br>147<br>155<br>163<br>171<br>179<br>187 | 84<br>94<br>9C<br>A4<br>AC<br>B4<br>BC | 132<br>140<br>148<br>156<br>164<br>172<br>180<br>188 | 85<br>8D<br>95<br>9D<br>A5<br>AD<br>85<br>BD | 133<br>141<br>149<br>157<br>165<br>173<br>181<br>189 |

Description:  $RESETS = \emptyset$  the specified Bit in the nominated Register.

Flag Register:

| Flag                                                    | Code            | Bit                        | Effect                                                                                     |
|---------------------------------------------------------|-----------------|----------------------------|--------------------------------------------------------------------------------------------|
| Sign<br>Zero<br>—<br>Half Carry<br>—<br>Parity/Overflow | S<br>Z<br>H<br> | 7<br>6<br>5<br>4<br>3<br>2 | Not affected.<br>Not affected.<br>Not used.<br>Not affected.<br>Not used.<br>Not affected. |
| Subtract<br>Carry                                       | N<br>C          | 1<br>Ø                     | Not affected.<br>Not affected.                                                             |

Example: LD E,ØFFH

RES 3,E

The Source Code statement RES 3,E, will produce the Object Code instruction CB 9B(Hex.) which will RESET =  $\emptyset$  Bit 3 in Register E.

Addressing Mode: Implicit.

| M Cycles | T States | µsec @ 2 MHz. |
|----------|----------|---------------|
| 2        | 8        | 4             |

## RES b, (HL)

Description:  $RESETS = \emptyset$  the specified Bit in the memory location whose address is held in Register Pair HL.

No. of Bytes: 2

Object Code (Hex.): CB xx Decimal: 203 yyy

Where b is the specified Bit (range  $\emptyset$  to 7) to be RESET.

xx and yyy are taken from the table below:

| Bit | xx | ууу |
|-----|----|-----|
| Ø   | 86 | 134 |
| 1   | 8E | 142 |
| 2   | 96 | 150 |
| 3   | 9E | 158 |
| 4   | A6 | 166 |
| 5   | AE | 174 |
| 6   | B6 | 182 |
| 7   | BE | 19Ø |

Description:  $RESETS = \emptyset$  the specified Bit in the memory location whose address is held in Register Pair HL.

| Flag                                                                         | Code                             | Bit                                  | Effect                                                                                                                           |
|------------------------------------------------------------------------------|----------------------------------|--------------------------------------|----------------------------------------------------------------------------------------------------------------------------------|
| Sign<br>Zero<br>—<br>Half Carry<br>—<br>Parity/Overflow<br>Subtract<br>Carry | S<br>Z<br>H<br><br>P/V<br>N<br>C | 7<br>6<br>5<br>4<br>3<br>2<br>1<br>0 | Not affected.<br>Not affected.<br>Not used.<br>Not affected.<br>Not affected.<br>Not affected.<br>Not affected.<br>Not affected. |
| Carry                                                                        | C                                | Ψ                                    | NOT ATTECTED.                                                                                                                    |

#### Example: LP HL,1000H LD (HL),0FFH RES 5,(HL)

The Source Code statement RES 5,(HL), will produce the Object Code instruction CB AE(Hex.) which will RESET =  $\emptyset$  Bit 5 in the memory location whose address is held in Register Pair HL.

Addressing Mode: Indirect.

| M Cycles | T States | μsec @ 2 MHz. |
|----------|----------|---------------|
| 4        | 15       | 7.5           |

### RES b,(IX+d) RES b,(IY+d)

Description:  $RESETS = \emptyset$  the specified bit in the memory location whose address is held in the specified Index Register (modified by displacement d, which is specified in the instruction).

No. of Bytes:

Object Code:

|              | Hex        | Decimal       |
|--------------|------------|---------------|
| RES b,(IX+d) | DD CB d xx | 221 203 d yyy |
| RES b,(IY+d) | FD CB d xx | 253 203 d yyy |

Where:

b is the specified bit (range Ø to 7) to be RESET. d is the required displacement from the memory location whose address is held in the specified Index Register. xx and yyy are taken from the table below.

| Bit | xx | ууу        |
|-----|----|------------|
| Ø   | 86 | 134        |
| 1   | 8E | 142        |
| 2   | 96 | <b>150</b> |
| 3   | 9E | 158        |
| 4   | A6 | 166        |
| 5   | AE | 174        |
| 6   | B6 | 182        |
| 7   | BE | 19Ø        |

Cont.

#### Flag Register:

| Flag            | Code | Bit | Effect        |
|-----------------|------|-----|---------------|
| Sign            | S    | 7   | Not affected. |
| Zero            | Z    | 6   | Not affected. |
| _               | _    | 5   | Not used.     |
| Half Carry      | н    | 4   | Not affected. |
|                 |      | 3   | Not used.     |
| Parity/Overflow | P/V  | 2   | Not affected. |
| Subtract        | N    | 1   | Not affected  |
| Carry           | С    | Ø   | Not affected. |
|                 |      |     |               |

Example: LD HL,4569H LD (HL),ØFFH LD IX,4567H RES 4,(IX+2)

If the contents of Index Register IX are 4567, and d in the instruction is 2, the required memory location is 4569. The Source Code statement RES 4,(IX+2) will produce the Object Code instruction DD CB 2 A6(Hex.) which will RESET =  $\emptyset$  bit 4 in memory location 4569.

Addressing Mode: Indexed.

| M Cycles | T States | μsec @ 2 MHz. |
|----------|----------|---------------|
| 6        | 23       | 11.5          |

### RET

Return from subroutine.

Object Code:

|     | Hex | Decimal |  |
|-----|-----|---------|--|
| RET | C9  | 201     |  |

Description: Returns control to the main program after a sub-routine has been called and followed. When the sub-routine was called the contents of the Program Counter (PC) at that time were stored in two consecutive memory locations and the address of the higher of those locations was placed in the Stack Pointer (SP). This instruction loads the contents of the memory location whose address is held in the Stack Pointer into the Lower Order byte of the Program Counter, then increments the Stack Pointer and loads the contents of the memory location now pointed to by the Stack Pointer into the Higher Order byte of the Program Counter then the Stack Pointer is incremented again.

No. of Bytes: 1

| Flag            | Code | Bit | Effect        |
|-----------------|------|-----|---------------|
| Sign            | S    | 7   | Not affected. |
| Zero            | Z    | 6   | Not affected. |
| _               | _    | 5   | Not used.     |
| Half Carry      | н    | 4   | Not affected. |
| _               | _    | 3   | Not used.     |
| Parity/Overflow | P/V  | 2   | Not affected. |
| Subtract        | N    | 1   | Not affected. |
| Carry           | С    | Ø   | Not affected. |
|                 |      |     |               |

Example: If the contents of the Stack Pointer are 21 14, and the contents of memory location 21 14 are 3A, the value 3A is loaded into the Lower Order byte of the Program Counter, the Stack Pointer is incremented to 21 15 and the contents of memory location 21 15 (say 48) are loaded into the Higher Order byte of the Program Counter, making the contents of the Program Counter 48 3A. The Stack Pointer is then again incremented to 21 16. The next instruction will be fetched from memory location 48 3A.

Addressing Mode: Indirect.

| M Cycles | T States | μsec @ 2 MHz. |
|----------|----------|---------------|
| 3        | 10       | 5             |

### RET cc

Return from subroutine if condition cc is satisfied where cc can be NZ, Z, NC, C, PO, PE, P or M.

Object Code:

|                 | Hex      | Decimal    |  |
|-----------------|----------|------------|--|
| RETNZ           | CØ       | 192        |  |
| RET Z<br>RET NC | C8<br>DØ | 200<br>208 |  |
| RETC            | D8       | 216        |  |
| RET PO          | EØ       | 224        |  |
| RET PE<br>RET P | E8<br>FØ | 232<br>24Ø |  |
| RETM            | F8       | 248        |  |
|                 |          |            |  |

Description: Conditionally returns control to the calling routine provided the condition is met. If this condition is not met, this instruction is ignored. If the condition is met, i.e. TRUE, this instruction loads the contents of the memory location whose address is held in the Stack Pointer into the Lower Order byte of the Program Counter, increments the Stack Pointer then loads the contents of the memory location now pointed to by the Stack Pointer into the Higher Order byte of the Program Counter, then again increments the Stack Pointer.

| Condition     | Flag |
|---------------|------|
| Non zero      | Z    |
| Zero          | Z    |
| Non carry     | С    |
| Carry         | С    |
| Parity odd    | P/O  |
| Parity even   | P/O  |
| Sign positive | S    |
| Sign negative | S    |

No. of Bytes: 1

Flag Register:

| Flag            | Code | Bit | Effect        |
|-----------------|------|-----|---------------|
| Sign            | S    | 7   | Not affected. |
| Zero            | Z    | 6   | Not affected. |
| _               |      | 5   | Not used.     |
| Half Carry      | н    | 4   | Not affected. |
| _               | _    | 3   | Not used.     |
| Parity/Overflow | P/V  | 2   | Not affected. |
| Subtract        | Ν    | 1   | Not affected. |
| Carry           | С    | Ø   | Not affected. |
|                 |      |     |               |

Assuming that the C Flag is SET = 1, if the contents of the Stack Pointer are 65 23, the contents of memory location 65 23 are 4B and the contents of memory location 65 24 are 87, RET C will load 4B into the Lower Order byte of the Program Counter, increment the Stack Pointer to 65 24, load 87 into the Higher Order byte of the Program Counter and again increment the Stack Pointer (to 65 25). The new contents of the Program Counter will then be 87 4B, and the next instruction will be fetched from that location.

| LD BC,874BH   |
|---------------|
| LD (6523H),BC |
| LD SP,6523H   |
| SCF           |
| RET C         |
|               |

Addressing Mode: Indirect.

|                      | M Cycles | T States | μsec @ 2 MHz. |
|----------------------|----------|----------|---------------|
| Condition<br>Met     | 3        | 11       | 5.5           |
| Condition<br>Not Met | 1        | 5        | 2.5           |

# RETI

Description: Returns control to the calling routine after an interrupt has been received and serviced. Loads the contents of the memory location whose address is held in the Stack Pointer to the Lower Order byte of the Program Counter, increments the Stack Pointer, then loads the contents of the memory location now pointed to by the Stack Pointer into the Higher Order byte of the Program Counter. Finally, the Stack Pointer is again incremented and the IFF1 and IFF2 Flip Flops are RESET =  $\emptyset$ . NOTE: An El instruction must be obeyed prior to the RETI instruction in

order to re-enable interrupts.

No. of Bytes: 2

Object Code (Hex.): ED 4D Decimal: 237 Ø77

| Flag                                                                         | Code                         | Bit                                  | Effect                                                                                                                           |
|------------------------------------------------------------------------------|------------------------------|--------------------------------------|----------------------------------------------------------------------------------------------------------------------------------|
| Sign<br>Zero<br>—<br>Half Carry<br>—<br>Parity/Overflow<br>Subtract<br>Carry | S<br>Z<br>H<br>P/V<br>N<br>C | 7<br>6<br>5<br>4<br>3<br>2<br>1<br>Ø | Not affected.<br>Not affected.<br>Not used.<br>Not affected.<br>Not affected.<br>Not affected.<br>Not affected.<br>Not affected. |

Example: LD SP,436AH LD BC,78A3H LD (436AH),BC EI RETI

If the Stack Pointer contains 43 6A, the contents of memory location 43 6A are A3 and the contents of memory location 43 6B are 78, this instruction will load A3 into the Lower Order byte of the Program Counter, increment the Stack Pointer to 43 6B, load 78 into the Higher Order byte of the Program Counter, then again increment the Stack Pointer (to 43 6C). The new contents of the Program Counter will be 78 A3, and the next instruction will be fetched from that memory location.

Addressing Mode: Indirect.

| M Cycles | T States | μsec @ 2 MHz. |  |
|----------|----------|---------------|--|
| 4        | 14       | 7             |  |

### RETN

Description: Returns control to the main program after a Non-Maskable Interrupt has been received and serviced. Loads the contents of the memory location whose address is held in the Stack Pointer to the Lower Order byte of the Program Counter, increments the Stack Pointer, then loads the contents of the memory location now pointed to by the Stack Pointer into the Higher Order byte of the Program Counter. The Stack Pointer is again incremented, then the contents of the IFF2 Flip-Flop (Storage flip-flop) are copied into the IFF1 Flip-Flop, restoring it to the condition which existed before the Non-Maskable Interrupt.

No. of Bytes: 2

Object Code (Hex.): ED 45

Decimal: 237 Ø69

Flag Register:

| Flag                                                                         | Code                         | Bit                                  | Effect                                                                                                                           |
|------------------------------------------------------------------------------|------------------------------|--------------------------------------|----------------------------------------------------------------------------------------------------------------------------------|
| Sign<br>Zero<br>—<br>Half Carry<br>—<br>Parity/Overflow<br>Subtract<br>Carry | S<br>Z<br>H<br>P/V<br>N<br>C | 7<br>6<br>5<br>4<br>3<br>2<br>1<br>Ø | Not affected.<br>Not affected.<br>Not used.<br>Not affected.<br>Not affected.<br>Not affected.<br>Not affected.<br>Not affected. |

Example: LD SP,3179H LD BC, ØB42H LD (3179H),BC RETN

If the Stack Pointer contains 31 79, the contents of memory location 31 79 are 42 and the contents of memory location 31 7A are ØB, this instruction will load 42 into the Lower Order byte of the Program Counter, increment the Stack Pointer to 31 7A, load ØB into the Higher Order byte of the Program Counter, then again increment the Stack Pointer (to 31 7B). The contents of the IFF2 Flip-Flop will be copied in to the IFF1 FLip-FLop. The new contents of the Program Counter will be ØB 42 and the next instruction will be fetched from that memory location.

Addressing Mode: Indirect.

| M Cycles | T States | μsec @ 2 MHz. |
|----------|----------|---------------|
| 4        | 14       | 7             |

# RL r

Rotate Register r left where r is any of the registers A, B, C, D, E, H or L. Object Code:

|      | Hex   | Decimal |  |
|------|-------|---------|--|
| RL A | CB 17 | 203 23  |  |
| RL B | CB1Ø  | 203 16  |  |
| RL C | CB11  | 203 17  |  |
| RL D | CB12  | 203 18  |  |
| RL E | CB13  | 203 19  |  |
| RL H | CB14  | 203 20  |  |
| RL L | CB15  | 203 21  |  |

Description: Rotate contents of Register r left one bit through carry status.



No. of Bytes: 2

| Flag            | Code | Bit | Effect                                                             |
|-----------------|------|-----|--------------------------------------------------------------------|
| Sign            | S    | 7   | SET = 1 if the result is negative, otherwise RESET = $\emptyset$ . |
| Zero            | Z    | 6   | SET = 1 if the result is zero, otherwise RESET = $\emptyset$       |
| —               | _    | 5   | Not used.                                                          |
| Half Carry      | н    | 4   | $RESET = \emptyset.$                                               |
| _               | _    | 3   | Not used.                                                          |
| Parity/Overflow | P/V  | 2   | SET = 1 for Parity Even, RESET = $\emptyset$ for Parity Odd.       |
| Subtract        | Ν    | 1   | $RESET = \emptyset.$                                               |
| Carry           | С    | Ø   | Contains the data previously held in Bit 7 of Register B.          |

#### Example: LD B,3AH

SCF CCF

#### RL B

If Register B contains 3A(Hex.) and the C Flag =  $\emptyset$ , the effect of RL B will be:

|                                   | Register B |                                    |        |
|-----------------------------------|------------|------------------------------------|--------|
|                                   |            | Bits                               | С      |
|                                   | Hex.       | 76543210                           | Flag   |
| Original Contents<br>New Contents | 3A<br>74   | 0 0 1 1 1 0 1 0<br>0 1 1 1 0 1 0 0 | Ø<br>Ø |

Flags S, Z, H and N are RESET =  $\emptyset$ , Flag P/V is SET = 1 and Flag C will contain the  $\emptyset$  previously held in Bit 7 of Register B.

Addressing Mode: Implicit.

| M Cycles | T States | μsec @ 2 MHz. |
|----------|----------|---------------|
| 2        | 8        | 4             |

# RL (HL)

Description: Rotates Left the contents of the memory location whose address is held in Register Pair HL through the C (Carry) Flag in the Flag Register. Each Bit is shifted Left one position, i.e. the contents of Bit  $\emptyset$  are moved into Bit 1, the contents of Bit 1 are moved into Bit 2, etc. The contents of Bit 7 are moved into the C Flag and the previous contents of the C Flag are moved into Bit  $\emptyset$ .



No. of Bytes: 2

Object Code (Hex.): CB 16

Decimal: 203 022

| Flag            | Code | Bit | Effect                                                             |
|-----------------|------|-----|--------------------------------------------------------------------|
| Sign            | S    | 7   | SET = 1 if the result is negative, otherwise RESET = $\emptyset$ . |
| Zero            | Z    | 6   | SET = 1 if the result is zero, otherwise RESET = $\emptyset$ .     |
|                 |      | 5   | Not used.                                                          |
| Half Carry      | н    | 4   | $RESET = \emptyset.$                                               |
|                 | _    | 3   | Not used.                                                          |
| Parity/Overflow | P/V  | 2   | SET = 1 for Parity Even, RESET = $\emptyset$ for Parity Odd.       |
| Subtract        | N    | 1   | $RESET = \emptyset.$                                               |
| Carry           | С    | Ø   | Contains the data previously held in Bit 7 of the memory location. |

#### Example: LD HL,2A15H LD (HL),58H

RL (HL)

If Register Pair HL contains 2A 15, the contents of memory location 2A 15 are 58, and the C Flag = 1, the effect of this instruction will be:

|                                   |          | Bits                 | С      |
|-----------------------------------|----------|----------------------|--------|
|                                   | Hex.     | 76543210             | Flag   |
| Original Contents<br>New Contents | 58<br>B1 | 01011000<br>10110001 | 1<br>Ø |

Flags Z, H and N are RESET =  $\emptyset$ , Flags S and P/V are SET = 1 and Flag C will contain the  $\emptyset$  previously held in Bit 7 of the memory location.

Addressing Mode: Indirect.

| M Cycles | T States | μsec @ 2 MHz. |
|----------|----------|---------------|
| 4        | 15       | 7.5           |

# $\frac{RL(IX + d)}{RL(IY + d)}$

Description: Rotates Left the contents of the memory location whose address is identified by the contents of Index Register IX or IY (modified by displacement d, which is specified in the instruction) through the C (Carry) Flag in the Flag Register. Each Bit is shifted Left one position, i.e. the contents of Bit  $\emptyset$  are moved into Bit 1, the contents of Bit 1 are moved into Bit 2, etc. The contents of Bit 7 are moved into the C Flag and the previous contents of the C Flag are moved into Bit  $\emptyset$ .



No. of Bytes: 4

Object Code

|                                                   | Hex                      | Decimal                        |  |
|---------------------------------------------------|--------------------------|--------------------------------|--|
| $\frac{RL\left(IX+d\right)}{RL\left(IY+d\right)}$ | DD CB d 16<br>FD CB d 16 | 221 203 d 022<br>253 203 d 022 |  |

Where d is the required displacement from the memory location whose address is held in Index Register IX or IY.

Flag Register:

| Flag            | Code | Bit | Effect                                                             |
|-----------------|------|-----|--------------------------------------------------------------------|
| Sign            | S    | 7   | SET = 1 if the result is negative, otherwise RESET = $\emptyset$ . |
| Zero            | Z    | 6   | SET = 1 if the result is zero, otherwise RESET = $\emptyset$ .     |
| —               |      | 5   | Not used.                                                          |
| Half Carry      | Н    | 4   | $RESET = \emptyset.$                                               |
| —               |      | 3   | Not used.                                                          |
| Parity/Overflow | P/V  | 2   | SET = 1 for Parity Even, RESET = $\emptyset$ for Parity Odd.       |
| Subtract        | Ν    | 1   | $RESET = \emptyset.$                                               |
| Carry           | С    | Ø   | Contains the data previously held in Bit 7 of the memory location. |

Cont.

Example: LD IX,5643H LD A,89 LD (5649H),A SCF CCF RL (IX+6)

If the contents of index Register IX are 56 43, and d in the instruction is  $\emptyset$ 6(Hex.), the required memory location is 56 49. If the contents of that memory location are 89 and the C Flag =  $\emptyset$ , the effect of this instruction will be:

|                                   | Memory Location |          |        |
|-----------------------------------|-----------------|----------|--------|
|                                   |                 | Bits     | С      |
|                                   | Hex.            | 76543210 | Flag   |
| Original Contents<br>New Contents | 89<br>12        | 1        | Ø<br>1 |

Flags S, Z, H and N are RESET =  $\emptyset$ , Flag P/V is SET = 1 and Flag C will contain the 1 previously held in Bit 7 of the memory location.

Addressing Mode: Indexed.

| M Cycles | T States | μsec @ 2 MHz. |
|----------|----------|---------------|
| 6        | 23       | 11.5          |

# RLA

Description: Rotates Left the contents of the Accumulator through the C (Carry) Flag. Each Bit is shifted Left one position, i.e. the contents of Bit  $\emptyset$  are moved into Bit 1, the contents of Bit 1 are moved into Bit 2, etc. The contents of Bit 7 are moved into the C Flag and the previous contents of the C Flag are moved into Bit  $\emptyset$ .



NOTE: This instruction has the same effect as instruction RL A but is faster in execution, and has a different effect on the Flag Register. It is provided for compatibility with the Intel 8080.

No. of Bytes: 1

Object Code (Hex.): 17

Decimal: Ø23

| Flag | Register: |
|------|-----------|
|------|-----------|

| Flag                                                                | Code                    | Bit                                    | Effect                                                                                       |
|---------------------------------------------------------------------|-------------------------|----------------------------------------|----------------------------------------------------------------------------------------------|
| Sign<br>Zero<br>—<br>Half Carry<br>—<br>Parity/Overflow<br>Subtract | S<br>Z<br>H<br>P/V<br>N | Bit<br>7<br>6<br>5<br>4<br>3<br>2<br>1 | EffectNot affected.Not used.RESET = $\emptyset$ .Not used.Not affected.RESET = $\emptyset$ . |
| Carry                                                               | С                       | Ø                                      | Contains the data previously held in Bit 7 of the Accumulator.                               |

### Example: LD A,57

#### SCF RLA

If the contents of the Accumulator are 57, and the C Flag = 1, the effect of this instruction will be:

|                                   |          | Accumulator                        |        |
|-----------------------------------|----------|------------------------------------|--------|
|                                   |          | Bits                               | С      |
|                                   | Hex.     | 76543210                           | Flag   |
| Original Contents<br>New Contents | 57<br>AF | Ø 1 Ø 1 Ø 1 1 1<br>1 Ø 1 Ø 1 1 1 1 | 1<br>Ø |

Flags H and N will be RESET =  $\emptyset$ , and Flag C will contain the  $\emptyset$  previously held in Bit 7 of the Accumulator.

Addressing Mode: Implicit.

| M Cycles | T States | μsec @ 2 MHz. |
|----------|----------|---------------|
| 1        | 4        | 2             |

# RLC r

Rotate contents of Register r left circular where r is any of the registers A, B, C, D, E, H or L.

Object Code:

|                                                    | Hex                                                | Decimal                                                        |  |
|----------------------------------------------------|----------------------------------------------------|----------------------------------------------------------------|--|
| RLC A<br>RLC B<br>RLC C<br>RLC D<br>RLC E<br>RLC H | CB Ø7<br>CB ØØ<br>CB Ø1<br>CB Ø2<br>CB Ø3<br>CB Ø4 | 203 007<br>203 000<br>203 001<br>203 002<br>203 003<br>203 004 |  |
| RLC L                                              | CB Ø5                                              | 203 005                                                        |  |

Description: Rotate contents of Register r left circular one bit, copying bit 7 into the carry status. That is, bit 7 is copied into bit  $\emptyset$ , and also into the carry flag.



No. of Bytes: 2

| Flag            | Code | Bit | Effect                                                             |
|-----------------|------|-----|--------------------------------------------------------------------|
| Sign            | S    | 7   | SET = 1 if the result is negative, otherwise RESET = $\emptyset$ . |
| Zero            | Z    | 6   | SET = 1 if the result is zero, otherwise RESET = $\emptyset$       |
|                 | _    | 5   | Not used.                                                          |
| Half Carry      | н    | 4   | $RESET = \emptyset.$                                               |
| —               |      | 3   | Not used.                                                          |
| Parity/Overflow | P/V  | 2   | SET = 1 for Parity Even, RESET = $\emptyset$ for Parity Odd.       |
| Subtract        | N    | 1   | $RESET = \emptyset.$                                               |
| Carry           | С    | Ø   | Contains the data previously held in Bit 7 of the Accumulator.     |

Example: LD A,ØB6H

RLC A

If the contents of the Accumulator are B6, the effect of this instruction will be:

|                                   | Accumulator |                                    |        |
|-----------------------------------|-------------|------------------------------------|--------|
|                                   |             | Bits                               | С      |
|                                   | Hex.        | 76543210                           | Flag   |
| Original Contents<br>New Contents | B6<br>6D    | 1 Ø 1 1 Ø 1 1 Ø<br>Ø 1 1 Ø 1 1 Ø 1 | ?<br>1 |

Flags S, Z, H, P/V and N are RESET =  $\emptyset$  and Flag C will contain the data previously held in Bit 7 of the Accumulator, which is identical to that now held in Bit  $\emptyset$  of the Accumulator.

Addressing Mode: Implicit.

| M Cycles | T States | μsec @ 2 MHz. |
|----------|----------|---------------|
| 2        | 8        | 4             |

# RLC (HL)

Description: Rotates Left the contents of the memory location whose address is held in Register Pair HL. Each Bit is shifted Left one position, i.e. the contents of Bit  $\emptyset$  are moved into Bit 1, the contents of Bit 1 are moved into Bit 2, etc. The contents of Bit 7 are moved into Bit  $\emptyset$  and into the C (Carry) Flag in the Flag Register.



No. of Bytes: 2

Object Code (Hex.): CB Ø6

Decimal: 203 006

| Flag            | Code | Bit    | Effect                                                             |
|-----------------|------|--------|--------------------------------------------------------------------|
| Sign            | S    | 7      | SET = 1 if the result is negative, otherwise RESET = $\emptyset$ . |
| Zero            | Z    | 6      | SET = 1 if the result is zero, otherwise RESET = $\emptyset$ .     |
| _               | _    | 5      | Not used.                                                          |
| Half Carry      | н    | 4<br>3 | $RESET = \emptyset.$                                               |
| _               |      | 3      | Not used.                                                          |
| Parity/Overflow | P/V  | 2      | SET = 1 for Parity Even, RESET = $\emptyset$ for Parity Odd.       |
| Subtract        | N    | 1      | $RESET = \emptyset.$                                               |
| Carry           | С    | Ø      | Contains the data previously held in Bit 7 of the memory location. |

### Example: LD HL,1745H

LD (HL),5AH

RLČ (HĹ)

If the contents of Register Pair HL are 1745, and the contents of memory location 1745 are 5A, the effect of this instruction will be:

|                                   |          |        | Мe     | m      | ory    | Lo     | DCa    | atic   | n      |        |
|-----------------------------------|----------|--------|--------|--------|--------|--------|--------|--------|--------|--------|
|                                   |          |        |        |        | В      | its    |        |        |        | С      |
|                                   | Hex.     | 7      | 6      | 5      | 4      | 3      | 2      | 1      | Ø      | Flag   |
| Original Contents<br>New Contents | 5A<br>B4 | Ø<br>1 | 1<br>Ø | Ø<br>1 | 1<br>1 | 1<br>Ø | Ø<br>1 | 1<br>Ø | Ø<br>Ø | ?<br>Ø |

Flags Z, H and N are RESET =  $\emptyset$ , Flags S and P/V are SET = 1 and Flag C will contain the data previously held in Bit 7 of the memory location, which is identical to that now held in Bit  $\emptyset$  of the memory location.

Addressing Mode: Indirect.

| M Cycles | T States | μsec @ 2 MHz. |
|----------|----------|---------------|
| 4        | 15       | 7.5           |

# $\frac{RLC (IX + d)}{RLC (IY + d)}$

Description: Rotates Left the contents of the memory location whose address is identified by the contents of Index Register IX or IY (modified by displacement d, which is specified in the instruction). Each Bit is shifted Left one position. i.e. the contents of Bit Ø are moved into Bit 1, the contents of Bit 1 are moved into Bit 2, etc. The contents of Bit 7 are moved into Bit  $\emptyset$  and into the C Flag in the Flag Register.



No. of Bytes: 4

Object Code

|              | Hex        | Decimal       |
|--------------|------------|---------------|
| RLC (IX + d) | DD CB d Ø6 | 221 203 d 006 |
| RLC (IY + d) | FD CB d Ø6 | 253 203 d 006 |

Where d is the required displacement from the memory location whose address is held in Index Register IX or IY.

Flag Register:

| Flag            | Code | Bit | Effect                                                             |
|-----------------|------|-----|--------------------------------------------------------------------|
| Sign            | S    | 7   | SET = 1 if the result is negative, otherwise RESET = $\emptyset$ . |
| Zero            | Z    | 6   | SET = 1 if the result is zero, otherwise RESET = $\emptyset$ .     |
|                 | _    | 5   | Not used.                                                          |
| Half Carry      | н    | 4   | $RESET = \emptyset.$                                               |
| —               | —    | 3   | Not used.                                                          |
| Parity/Overflow | P/V  | 2   | SET = 1 for Parity Even, RESET = $\emptyset$ for Parity Odd.       |
| Subtract        | Ν    | 1   | $RESET = \emptyset.$                                               |
| Carry           | С    | Ø   | Contains the data previously held in Bit 7 of the memory location. |

Cont.

#### Example: LD IX,4521H LD A,27H LD (452BH),A RLC (IX+ØAH)

If the contents of Index Register IX are 45 21, and d in the instruction is  $\emptyset A(\text{Hex.})$ , the required memory location is 45 2B. If the contents of Memory Location 45 2B are 27(Hex.) the effect of this instruction will be:

|                                   |          | Memory Location                    |        |
|-----------------------------------|----------|------------------------------------|--------|
|                                   |          | Bits                               | С      |
|                                   | Hex.     | 76543210                           | Flag   |
| Original Contents<br>New Contents | 27<br>4E | 0 0 1 0 0 1 1 1<br>0 1 0 0 1 1 1 0 | ?<br>Ø |

Flags S, Z, H and N are RESET =  $\emptyset$ , Flag P/V will be SET = 1 and Flag C will contain the data previously held in Bit 7 of the memory location, which is identical to that now held in Bit  $\emptyset$  of the memory location.

Addressing Mode: Indexed.

| M Cycles | T States | μsec @ 2 MHz. |
|----------|----------|---------------|
| 6        | 23       | 11.5          |

### RLCA

Description: Rotates Left the contents of the Accumulator. Each Bit is shifted Left one position, i.e. the contents of Bit  $\emptyset$  are moved into Bit 1, the contents of Bit 1 are moved into Bit 2, etc. The contents of Bit 7 are moved into Bit  $\emptyset$  and into the C (Carry) Flag in the Flag Register.

NOTE: This instruction is identical to RLC A, except for the effect on the Flag Register, but is faster in execution. It is provided for compatibility with the Intel 8080.



No. of Bytes: 1

Object Code (Hex.): Ø7

Decimal: 007

| SignS7Not affected.ZeroZ6Not affected. $ -$ 5Not used.Half CarryH4RESET = $\emptyset$ . | Flag                                                                | Code                        | Bit                             | Effect                                                                                                                                                           |
|-----------------------------------------------------------------------------------------|---------------------------------------------------------------------|-----------------------------|---------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                                                         | Sign<br>Zero<br>—<br>Half Carry<br>—<br>Parity/Overflow<br>Subtract | S<br>Z<br>H<br><br>P/V<br>N | 7<br>6<br>5<br>4<br>3<br>2<br>1 | Not affected.<br>Not affected.<br>Not used.<br>RESET = $\emptyset$ .<br>Not used.<br>Not affected.<br>RESET = $\emptyset$ .<br>Contains the data previously held |

#### Example: LD A,37H

RLCA

If the contents of the Accumulator are 37(Hex.), the effect of this instruction will be:

|                                   |          | Bits                               | С      |
|-----------------------------------|----------|------------------------------------|--------|
|                                   | Hex.     | 76543210                           | Flag   |
| Original Contents<br>New Contents | 37<br>6E | 0 0 1 1 0 1 1 1<br>0 1 1 0 1 1 1 0 | ?<br>Ø |

Flags H and N are RESET =  $\emptyset$  and Flag C will contain the data previously held in Bit 7 of the Accumulator, which is identical to that now held in Bit  $\emptyset$  of the Accumulator.

Addressing Mode: Implicit.

| M Cycles | T States | μsec @ 2 MHz. |
|----------|----------|---------------|
| 1        | 4        | 2             |

# RLD

Description: Rotates Left Decimal the Lower Order 4 bits of the Accumulator with the Higher Order 4 bits and the Lower Order 4 bits of the memory location whose address is held in Register Pair HL. The Higher Order 4 bits of the specified location is moved into the Lower Order 4 bits of the Accumulator, the Lower Order 4 bits of the Accumulator is moved into the Lower Order 4 bits of the memory location, and the Lower Order 4 bits of the same memory location.



No. of Bytes: 2

Object Code (Hex.): ED 6F

Decimal: 237 111

Flag Register:

| Flag            | Code | Bit | Effect                                                                                                              |
|-----------------|------|-----|---------------------------------------------------------------------------------------------------------------------|
| Sign            | S    | 7   | SET = 1 if the result in the Accumulator is negative, otherwise RESET = $\emptyset$ .                               |
| Zero            | Z    | 6   | SET = 1 if the result in the Accumulator is zero, otherwise RESET = $\emptyset$ .                                   |
|                 | _    | 5   | Not used.                                                                                                           |
| Half Carry      | н    | 4   | $RESET = \emptyset.$                                                                                                |
|                 |      | 3   | Not used.                                                                                                           |
| Parity/Overflow | P/V  | 2   | SET = 1 if for Parity Even in the Accumulator result, RESET = $\emptyset$ for Parity Odd in the Accumulator result. |
| Subtract        | N    | 1   | $RESET = \emptyset.$                                                                                                |
| Carry           | С    | Ø   | Not affected.                                                                                                       |

Cont.

Example: LD HL1000H LD (HL),28H LD A,6EH RLD

If the contents of the Accumulator are 6E(Hex.) and the contents of the nominated memory location are 28(Hex.) the effect of this instruction will be:

| Origina     | l Contents | New Contents |          |  |
|-------------|------------|--------------|----------|--|
| Accumulator | Location   | Accumulator  | Location |  |
| 6 E         | 28         | 62           | 8 E      |  |
|             |            |              |          |  |

Flags S, Z, H, P/V and N are RESET =  $\emptyset$ .

Addressing Mode: Indirect

| M Cycles | T States | μsec @ 2 MHz. |
|----------|----------|---------------|
| 5        | 18       | 9             |

### RR r

Description: Rotates Right the contents of Register r through the C (Carry) Flag in the Flag Register. Each Bit is shifted Right one position, i.e. the contents of Bit 7 are moved into Bit 6, the contents of Bit 6 are moved into Bit 5, etc. The contents of Bit  $\emptyset$  are moved into the C Flag and the previous contents of the C Flag are moved into Bit 7.



No. of Bytes: 2

Object Code

|      | Hex   | Decimal |  |
|------|-------|---------|--|
| RR A | CB 1F | 203 031 |  |
| RR B | CB 18 | 203 024 |  |
| RR C | CB 19 | 203 025 |  |
| RR D | CB 1A | 203 026 |  |
| RR E | CB 1B | 203 027 |  |
| RR H | CB 1C | 2Ø3 Ø28 |  |
| RR L | CB 1D | 2Ø3 Ø29 |  |

| Flag            | Code | Bit    | Effect                                                             |
|-----------------|------|--------|--------------------------------------------------------------------|
| Sign            | S    | 7      | SET = 1 if the result is negative, otherwise RESET = $\emptyset$ . |
| Zero            | Z    | 6      | SET = 1 if the result is zero, otherwise RESET = $\emptyset$ .     |
|                 | _    | 5      | Not used.                                                          |
| Half Carry      | н    | 4<br>3 | $RESET = \emptyset.$                                               |
| _               | _    | 3      | Not used.                                                          |
| Parity/Overflow | P/V  | 2      | SET = 1 for Parity Even, RESET = $\emptyset$ for Parity Odd.       |
| Subtract        | N    | 1      | $RESET = \emptyset.$                                               |
| Carry           | С    | Ø      | Contains the data previously held in Bit Ø of the memory location. |

#### Example: LD B,3AH

SCF CCF

RR B

If Register B contains 3A(Hex.) and the C Flag =  $\emptyset$ , the effect of this instruction will be:

|                                   |          | С                                  |        |
|-----------------------------------|----------|------------------------------------|--------|
|                                   | Hex.     | 76543210                           | Flag   |
| Original Contents<br>New Contents | 3A<br>1D | 0 0 1 1 1 0 1 0<br>0 0 0 1 1 1 0 1 | Ø<br>Ø |

Flags S, Z, H and N are RESET =  $\emptyset$ , Flag P/V is SET = 1 and Flag C contains the  $\emptyset$  previously held in Bit  $\emptyset$  of Register B.

Addressing Mode: Implicit.

| M Cycles | T States | usec @ 2 MHz. |
|----------|----------|---------------|
| 2        | 8        | 4             |

# RR (HL)

Description: Rotates Right the contents of the memory location whose address is held in Register Pair HL through the C (Carry) Flag in the Flag Register. Each Bit is shifted Right one position, i.e. the contents of Bit 7 are moved into Bit 6, the contents of Bit 6 are moved into Bit 5, etc. The contents of Bit Ø are moved into the C Flag and the previous contents of the C Flag are moved into Bit 7.



No. of Bytes: 2

Object Code (Hex.): CB 1E

Decimal: 203 030

| Flag            | Code | Bit | Effect                                                             |
|-----------------|------|-----|--------------------------------------------------------------------|
| Sign            | S    | 7   | SET = 1 if the result is negative, otherwise RESET = $\emptyset$ . |
| Zero            | Z    | 6   | SET = 1 if the result is zero, otherwise RESET = $\emptyset$ .     |
| —               | -    | 5   | Not used.                                                          |
| Half Carry      | н    | 4   | $RESET = \emptyset.$                                               |
| —               | -    | 3   | Not used.                                                          |
| Parity/Overflow | P/V  | 2   | SET = 1 for Parity Even, RESET = $\emptyset$ for Parity Odd.       |
| Subtract        | N    | 1   | $RESET = \emptyset.$                                               |
| Carry           | С    | Ø   | Contains the data previously held in Bit Ø of the memory location  |

#### Example: LD HL,2A15H LD (HL),58H

SCÈ RR (HL)

If Register Pair HL contains 2A 15(Hex.), the contents of memory location 2A 15 are 58(Hex.) and the C Flag = 1, the effect of this instruction will be:

|                                   |          | С                                  |        |
|-----------------------------------|----------|------------------------------------|--------|
|                                   | Hex.     | 76543210                           | Flag   |
| Original Contents<br>New Contents | 58<br>AC | Ø 1 Ø 1 1 Ø Ø Ø<br>1 Ø 1 Ø 1 1 Ø Ø | 1<br>Ø |

Flags Z, H and N will be RESET =  $\emptyset$ , Flags S and P/V will be SET = 1 and the C Flag will contain the  $\emptyset$  previously held in Bit  $\emptyset$  of the memory location.

Addressing Mode: Indirect.

| M Cycles | T States | μsec @ 2 MHz. |
|----------|----------|---------------|
| 4        | 15       | 7.5           |

### RR(IX + d)RR(IY + d)

Description: Rotates Right the contents of the memory location whose address is identified by the contents of Index Register IX or IY (modified by displacement d, which is specified in the instruction) through the C (Carry) Flag in the Flag Register. Each Bit is shifted Right one position. i.e. the contents of Bit 7 are moved into Bit 6, the contents of Bit 6 are moved into Bit 5, etc. The contents of Bit Ø are moved into the C Flag and the previous contents of the C Flag are moved into Bit 7.



No. of Bytes: 4

**Object Code:** 

|                                 | Hex                      | Decimal                        |
|---------------------------------|--------------------------|--------------------------------|
| $\frac{RR(IX + d)}{RR(IY + d)}$ | DD CB d 1E<br>FD CB d 1E | 221 203 d 030<br>253 203 d 030 |

Where d is the required displacement from the memory location whose address is held in Index Register IX or IY.

Flag Register:

| Flag            | Code | Bit | Effect                                                                      |
|-----------------|------|-----|-----------------------------------------------------------------------------|
| Sign            | S    | 7   | SET = 1 if the result is negative, otherwise RESET = $\emptyset$ .          |
| Zero            | Z    | 6   | SET = 1 if the result is zero, otherwise RESET = $\emptyset$ .              |
| —               | _    | 5   | Not used.                                                                   |
| Half Carry      | н    | 4   | $RESET = \emptyset.$                                                        |
| _               | -    | 3   | Not used.                                                                   |
| Parity/Overflow | P/V  | 2   | SET = 1 for Parity Even, RESET = $\emptyset$ for Parity Odd.                |
| Subtract        | N    | 1   | $RESET = \emptyset.$                                                        |
| Carry           | С    | Ø   | Contains the data previously held in Bit $\emptyset$ of the memory location |

Cont.

Example: SCF CCF LD IX,5643H LD A,89H LD (5649H),A RR (IX+6)

If the contents of Index Register IX are 56 43, and d in the instruction is  $\emptyset$ 6(Hex.), the required memory location is 56 49. If the contents of that memory location are 89 and the C Flag =  $\emptyset$ , the effect of this instruction will be:

|                                   | [        |          |        |
|-----------------------------------|----------|----------|--------|
|                                   |          | Bits     | С      |
|                                   | Hex.     | 76543210 | Flag   |
| Original Contents<br>New Contents | 89<br>44 | 1        | Ø<br>1 |

Flags S, Z, H and N are RESET =  $\emptyset$ , Flag P/V is SET = 1 and the C Flag contains the 1 previously held in Bit  $\emptyset$  of the memory location.

Addressing Mode: Indexed.

| M Cycles | T States | μsec @ 2 MHz. |
|----------|----------|---------------|
| 6        | 23       | 11.5          |

RRA

Description: Rotates Right the contents of the Accumulator through the C (Carry) Flag. Each Bit is shifted Right one position, i.e. the contents of Bit 7 are moved into Bit 6, the contents of Bit 6 are moved into Bit 5, etc. The contents of Bit  $\emptyset$  are moved into the C Flag and the previous contents of the C Flag are moved into Bit 7.

NOTE: This instruction is provided for compatibility with the Intel 8080. It is similar to instruction RR A, except that the effect on the Flag Register is different and it is faster in execution.



No. of Bytes: 1

Object Code (Hex.): 1F

Decimal: Ø31

| Flag Code Bit Effect                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| SignS7Not affected.ZeroZ6Not affected. $-$ -5Not used.Half CarryH4RESET = Ø. $-$ -3Not used.Parity/OverflowP/V2Not affected.SubtractN1RESET = Ø.CarryCØContains the data previous t |  |

#### Example: LD A,57H

#### SCF RRA

If the contents of the Accumulator are 57, and the C Flag = 1, the effect of this instruction will be:

|                                   |          | Bits                               | С      |
|-----------------------------------|----------|------------------------------------|--------|
|                                   | Hex.     | 76543210                           | Flag   |
| Original Contents<br>New Contents | 57<br>AB | Ø 1 Ø 1 Ø 1 1 1<br>1 Ø 1 Ø 1 Ø 1 1 | 1<br>1 |

Flags H and N will be RESET =  $\emptyset$  and Flag C will contain the 1 previously held in Bit  $\emptyset$  of the Accumulator.

Addressing Mode: Implicit.

| M Cycles | T States | μsec @ 2 MHz. |
|----------|----------|---------------|
| 1        | 4        | 2             |

### RRC r

Rotate contents of Register r circular where r is any of the registers A, B, C, D, E, H or L.

Object Code:

|       | Hex   | Decimal |
|-------|-------|---------|
| RRC A | CB ØF | 203 015 |
| RRC B | CB ØB | 203 008 |
| RRC C | CB Ø9 | 203 009 |
| RRC D | CB ØA | 203 010 |
| RRC E | CB ØB | 203 011 |
| RRC H | CB ØC | 203 012 |
| RRC L | CB ØD | 203 013 |

Description: Rotates Right the contents of Register r. Each Bit is shifted Right one position, i.e. the contents of Bit 7 are moved into Bit 6, the contents of Bit 6 are moved into Bit 5, etc. The contents of Bit  $\emptyset$  are moved into Bit 7 and into the C (Carry) Flag in the Flag Register.



No. of Bytes: 2

| Flag            | Code | Bit | Effect                                                             |
|-----------------|------|-----|--------------------------------------------------------------------|
| Sign            | S    | 7   | SET = 1 if the result is negative, otherwise RESET = $\emptyset$ . |
| Zero            | Z    | 6   | SET = 1 if the result is zero, otherwise RESET = $\emptyset$       |
| —               | _    | 5   | Not used.                                                          |
| Half Carry      | н    | 4   | $RESET = \emptyset.$                                               |
| _               | _    | 3   | Not used.                                                          |
| Parity/Overflow | P/V  | 2   | SET = 1 for Parity Even, RESET = $\emptyset$ for Parity Odd.       |
| Subtract        | N    | 1   | $RESET = \emptyset.$                                               |
| Carry           | С    | Ø   | Contains the data previously held in Bit Ø of the Accumulator.     |

#### Example: LD A,ØB6H

#### RRC A

If the contents of the Accumulator are B6(Hex.), the effect of this instruction will be:

|                                   | Accumulator |                                    |        |
|-----------------------------------|-------------|------------------------------------|--------|
|                                   |             | Bits                               | С      |
|                                   | Hex.        | 76543210                           | Flag   |
| Original Contents<br>New Contents | B6<br>5B    | 1 Ø 1 1 Ø 1 1 Ø<br>Ø 1 Ø 1 1 Ø 1 1 | ?<br>Ø |

Flags S, Z, H, P/V and S are RESET =  $\emptyset$  and Flag C will contain the  $\emptyset$  previously held in Bit  $\emptyset$  of the Accumulator, which is identical to that now held in Bit 7 of the Accumulator.

Addressing Mode: Implicit.

| M Cycles | T States | μsec @ 2 MHz. |
|----------|----------|---------------|
| 2        | 8        | 4             |

# RRC (HL)

Description: Rotates Right the contents of the memory location whose address is held in Register Pair HL. Each Bit is shifted Right one position, i.e. the contents of Bit 7 are moved into Bit 6, the contents of Bit 6 are moved into Bit 5, etc. The contents of Bit  $\emptyset$  are moved into Bit 7 and into the C (Carry) Flag in the Flag Register.



No. of Bytes: 2

Object Code (Hex.): CB ØE

Decimal: 203 014

| Flag            | Code | Bit | Effect                                                                |
|-----------------|------|-----|-----------------------------------------------------------------------|
| Sign            | S    | 7   | SET = 1 if the result is negative, otherwise RESET = $\emptyset$ .    |
| Zero            | Z    | 6   | SET = 1 if the result is zero, otherwise RESET = $\emptyset$ .        |
|                 |      | 5   | Not used.                                                             |
| Half Carry      | Н    | 4   | $RESET = \emptyset.$                                                  |
| -               | _    | 3   | Not used.                                                             |
| Parity/Overflow | P/V  | 2   | SET = 1 for Parity Even, RESET = $\emptyset$ for Parity Odd.          |
| Subtract        | Ν    | 1   | $RESET = \emptyset.$                                                  |
| Carry           | С    | Ø   | Contains the data previously held<br>in Bit Ø of the memory location. |

#### Example: LD HL,1745H

LD (HL),5A RRC (HL)

If the contents of Register Pair HL are 1745, and the contents of memory location 1745 are 5A, the effect of this instruction will be:

|                                   | Memory Location |                      |        |
|-----------------------------------|-----------------|----------------------|--------|
|                                   |                 | Bits                 | С      |
|                                   | Hex.            | 76543210             | Flag   |
| Original Contents<br>New Contents | 5A<br>2C        | 01011010<br>00101100 | ?<br>Ø |

Flags S, Z, H, P/V and N are RESET =  $\emptyset$  and Flag C contains the data previously held in Bit  $\emptyset$  of the memory location, which is identical to that now held in Bit 7 of the memory location.

Addressing Mode: Indirect.

| M Cycles | T States   | μsec @ 2 MHz. |
|----------|------------|---------------|
| 4        | <b>1</b> 5 | 7.5           |

# $\frac{RRC (IX + d)}{RRC (IY + d)}$

Description: Rotates Right the contents of the memory location whose address is identified by the contents of Index Register IX or IY (modified by displacement d, which is specified in the instruction). Each bit is shifted Right one position, i.e. the contents of Bit 7 are moved into Bit 6, the contents of Bit 6 are moved into Bit 5, etc. The contents of Bit  $\emptyset$  are moved into Bit 7 and into the C (Carry) Flag in the Flag Register.



No. of Bytes: 4

Object Code:

|                                   | Hex                      | Decimal                        |
|-----------------------------------|--------------------------|--------------------------------|
| $\frac{RRC(IX + d)}{RRC(IY + d)}$ | DD CB d ØE<br>FD CB d ØE | 221 203 d 014<br>253 203 d 014 |

Where d is the required displacement from the memory location whose address is held in Index Register IX or IY.

| Flag            | Code | Bit | Effect                                                                       |
|-----------------|------|-----|------------------------------------------------------------------------------|
| Sign            | S    | 7   | SET = 1 if the result is negative, otherwise RESET = $\emptyset$ .           |
| Zero            | Z    | 6   | SET = 1 if the result is zero, otherwise RESET = $\emptyset$ .               |
| -               | _    | 5   | Not used.                                                                    |
| Half Carry      | н    | 4   | $RESET = \emptyset.$                                                         |
| _               | -    | 3   | Not used.                                                                    |
| Parity/Overflow | P/V  | 2   | SET = 1 for Parity Even, RESET = $\emptyset$ for Parity Odd.                 |
| Subtract        | N    | 1   | $RESET = \emptyset.$                                                         |
| Carry           | С    | Ø   | Contains the data previously held in Bit $\emptyset$ of the memory location. |

#### Example: LD IX,4521H LD A,27H LD (452BH),A RLC (IX+ØAH)

If the contents of Index Register IX are 45 21, and d in the instruction is  $\emptyset A(\text{Hex.})$ , the required memory location is 45 2B. If the contents of memory location 45 2B are 27(Hex.) the effect of this instruction will be:

|                                   |          | Bits                               | С      |
|-----------------------------------|----------|------------------------------------|--------|
|                                   | Hex.     | 76543210                           | Flag   |
| Original Contents<br>New Contents | 27<br>93 | 0 0 1 0 0 1 1 1<br>1 0 0 1 0 0 1 1 | ?<br>1 |

Flags Z, H and N are RESET =  $\emptyset$ , Flags S and P/V are SET =  $\emptyset$  and Flag C will contain the 1 previously held in Bit  $\emptyset$  of the memory location, which is identical to that now held in Bit 7 of the memory location.

Addressing Mode: Indexed.

| M Cycles | T States | μsec @ 2 MHz. |
|----------|----------|---------------|
| 6        | 23       | 11.5          |

### RRCA

Description: Rotates Right the contents of the Accumulator. Each Bit is shifted Right one position, i.e. the contents of Bit 7 are moved into Bit 6, the contents of Bit 6 are moved into Bit 5, etc. The contents of Bit  $\emptyset$  are moved into Bit  $\emptyset$  and into the C (Carry) Flag in the Flag Register.



NOTE: This instruction is identical to RRC A, except for the effect on the Flag Register, but is faster in execution. It is provided for compatibility with the Intel 8080.

No. of Bytes: 1

Object Code (Hex.): ØF

Decimal: Ø15

| Flag                                                                | Code                        | Bit                             | Effect                                                                                                                      |
|---------------------------------------------------------------------|-----------------------------|---------------------------------|-----------------------------------------------------------------------------------------------------------------------------|
| Sign<br>Zero<br>—<br>Half Carry<br>—<br>Parity/Overflow<br>Subtract | S<br>Z<br>H<br><br>P/V<br>N | 7<br>6<br>5<br>4<br>3<br>2<br>1 | Not affected.<br>Not affected.<br>Not used.<br>RESET = $\emptyset$ .<br>Not used.<br>Not affected.<br>RESET = $\emptyset$ . |
| Carry                                                               | С                           | Ø                               | Contains the data previously held in Bit Ø of the Accumulator.                                                              |

#### Example: LD A,37H

#### RRCA

If the contents of the Accumulator are 37(Hex.), the effect of this instruction will be:

|                                   | Accumulator |                                    |        |
|-----------------------------------|-------------|------------------------------------|--------|
|                                   |             | Bits                               | С      |
|                                   | Hex.        | 76543210                           | Flag   |
| Original Contents<br>New Contents | 37<br>9B    | Ø Ø 1 1 Ø 1 1 1<br>1 Ø Ø 1 1 Ø 1 1 | ?<br>1 |

Flags H and N are RESET =  $\emptyset$  and Flag C contains the 1 previously held in Bit  $\emptyset$  of the Accumulator, which is identical to that now held in Bit 7 of the Accumulator.

Addressing Mode: Implicit.

| M Cycles | T States | μsec @ 2 MHz. |
|----------|----------|---------------|
| 1        | 4        | 2             |

### RRD

Description: Rotates Right Decimal the Lower Order 4 bits of the Accumulator with the Higher Order and Lower Order 4 bits of the memory location whose address is held in Register Pair HL. The Lower Order 4 bits of the Accumulator is moved into the Higher Order 4 bits of the specified memory location, the Higher Order byte of the memory location is moved into the Lower Order 4 bits of the same location and the Lower Order 4 bits of that memory location is moved into the Lower Order 4 bits of the Accumulator.



No. of Bytes: 2

Object Code (Hex.): ED 67

Decimal: 237 103

| Flag            | Code | Bit | Effect                                                                                                              |
|-----------------|------|-----|---------------------------------------------------------------------------------------------------------------------|
| Sign            | S    | 7   | SET = 1 if the result in the Accumulator is negative, otherwise RESET = $\emptyset$ .                               |
| Zero            | Z    | 6   | SET = 1 if the result in the Accumulator is zero, otherwise RESET = $\emptyset$ .                                   |
|                 | _    | 5   | Not used.                                                                                                           |
| Half Carry      | н    | 4   | $RESET = \emptyset.$                                                                                                |
|                 |      | 3   | Not used.                                                                                                           |
| Parity/Overflow | P/V  | 2   | SET = 1 if for Parity Even in the Accumulator result, RESET = $\emptyset$ for Parity Odd in the Accumulator result. |
| Subtract        | N    | 1   | $RESET = \emptyset.$                                                                                                |
| Carry           | С    | Ø   | Not affected.                                                                                                       |

Example: LD HL,1000H LD (HL),28H LD A,6EH RRD

If the contents of the Accumulator are 6E(Hex.) and the contents of the nominated location are 28(Hex.) the effect of this instruction will be:

| Original Contents |          | New Contents |          |
|-------------------|----------|--------------|----------|
| Accumulator       | Location | Accumulator  | Location |
| 6 E               | 28       | 68           | E 2      |
|                   |          |              |          |

Flags S, Z, H, P/V and N are RESET =  $\emptyset$ .

Addressing Mode: Indirect

| M Cycles | T States | μsec @ 2 MHz. |
|----------|----------|---------------|
| 5        | 18       | 9             |

### RST n

Description: Restart from memory location  $\emptyset\emptyset$  n. Pushes the contents of the Program Counter on to the top of the memory Stack by first decrementing the Stack Pointer (SP) and loading the Higher Order byte of the Program Counter (PC) into the memory location whose address is now held in the Stack Pointer, then decrementing the Stack Pointer again and loading the Lower Order byte of the Program Counter into the memory location whose address is the new contents of the Stack Pointer. Finally, the value  $\emptyset\emptyset$  n is loaded into the Program Counter and the next instruction is fetched from that address.

NOTE: The RST instructions transfer control to specific addresses in low memory. It can be used for a fast response to an interrupt

No. of Bytes: 1

Object Code:

|        | Hex | Decimal |   |
|--------|-----|---------|---|
| RST ØØ | C7  | 199     |   |
| RST Ø8 | CF  | 207     | 6 |
| RST 1Ø | D7  | 215     |   |
| RST 18 | DF  | 223     |   |
| RST 2Ø | E7  | 231     |   |
| RST 28 | EF  | 239     |   |
| RST 3Ø | F7  | 247     |   |
| RST 38 | FF  | 255     |   |

| Flag            | Code | Bit    | Effect                     |
|-----------------|------|--------|----------------------------|
| Sign            | S    | 7      | Not affected.              |
| Zero            | Z    | 6      | Not affected.              |
| Half Carry      | н    | 5<br>4 | Not used.<br>Not affected. |
|                 | _    | 3      | Not used.                  |
| Parity/Overflow | P/V  | 2      | Not affected.              |
| Subtract        | N    | 1      | Not affected.              |
| Carry           | С    | Ø      | Not affected.              |

Example: RST  $\emptyset \emptyset$  — If the contents of the Program Counter are 64 B1, and the contents of the Stack Pointer are 32 75, the effect of this instruction will be:

|                                   | Program        | Counter       |                  | Loc                              | ation                              |
|-----------------------------------|----------------|---------------|------------------|----------------------------------|------------------------------------|
|                                   | Higher<br>Byte | Lower<br>Byte | Stack<br>Pointer | Address                          | Contents                           |
| Original Contents<br>New Contents | 64<br>ØØ       | B1<br>ØØ      | 32 75<br>32 73   | 32 75<br>32 75<br>32 74<br>32 73 | ?<br>?(Not<br>Changed)<br>64<br>B1 |

#### Addressing Mode: Implicit.

| M Cycles | T States | µsec @ 2MHz |
|----------|----------|-------------|
| 3        | 11       | 5.5         |

## SBC A,n

Description: Subtracts from the Accumulator the integer n, summed with the contents of the Carry Flag in the Flag Register. The result is stored in the Accumulator.

No. of Bytes: 2

Object Code (Hex.): DE n Decimal: 222 n

Where n is an 8 Bit integer, specified in the instruction.

Flag Register:

| Flag            | Code | Bit | Effect                                                             |
|-----------------|------|-----|--------------------------------------------------------------------|
| Sign            | S    | 7   | SET = 1 if the result is negative, otherwise RESET = $\emptyset$ . |
| Zero            | Z    | 6   | SET = 1 if the result is zero, otherwise RESET = $\emptyset$ .     |
| —               | -    | 5   | Not used.                                                          |
| Half Carry      | н    | 4   | SET = 1 if no Borrow from Bit 4, otherwise RESET = $\emptyset$ .   |
| —               |      | 3   | Not used.                                                          |
| Parity/Overflow | P/V  | 2   | SET = 1 if Overflow, otherwise RESET = $\emptyset$ .               |
| Subtract        | Ν    | 1   | SET = 1.                                                           |
| Carry           | С    | Ø   | SET = 1 if no Borrow, otherwise RESET = $\emptyset$ .              |

Example: LD A,45H SCF SBC A.4

If the contents of the Accumulator are 45(Hex.), the C(Carry) Flag = 1 and n in the instruction is 4, this instruction will subract 4 + 1 (=5) from the contents of the Accumulator and store 40(Hex.), the result, in the Accumulator. Flags S, Z and P/V are RESET = 0 and Flags N and C are SET = 1.

Addressing Mode: Immediate.

| M Cycles | T States | μsec @ 2 MHz. |  |
|----------|----------|---------------|--|
| 2        | 7        | 3.5           |  |

### SBC A,A

Description: Subtracts from the Accumulator the contents of the Accumulator, summed with the contents of the C (Carry) Flag in the Flag register. The result is stored in the Accumulator. Note that the result in the Accumulator will always be  $\emptyset$ H or FFH (negative one in twos complement notation), depending on the contents of the carry flag.

No. of Bytes: 1

Object Code (Hex.): 9F

Decimal: 159

Flag Register:

| Flag            | Code | Bit | Effect                                                             |
|-----------------|------|-----|--------------------------------------------------------------------|
| Sign            | S    | 7   | SET = 1 if the result is negative, otherwise RESET = $\emptyset$ . |
| Zero            | Z    | 6   | SET = 1 if the result is zero, otherwise RESET = $\emptyset$ .     |
| —               | _    | 5   | Not used.                                                          |
| Half Carry      | н    | 4   | SET = 1 if no Borrow from Bit 4, otherwise RESET = $\emptyset$ .   |
|                 | _    | 3   | Not used.                                                          |
| Parity/Overflow | P/V  | 2   | SET = 1 if Overflow, otherwise RESET = $\emptyset$ .               |
| Subtract        | Ν    | 1   | SET = 1.                                                           |
| Carry           | С    | Ø   | SET = 1 if no Borrow, otherwise RESET = $\emptyset$ .              |

Example: LD A,28H SCF CCF

SBC A.A

If the contents of the Accumulator are 28(Hex.) and the C Flag =  $\emptyset$ , this instruction will subtract 28 +  $\emptyset$ (=28) from the Accumulator and store the result ( $\emptyset$ ) in the Accumulator. Flags S and P/V are RESET =  $\emptyset$  and Flags Z, H, N and C are SET = 1.

Addressing Mode: Implicit.

| M Cycles | T States | μsec @ 2 MHz. |  |
|----------|----------|---------------|--|
| 1        | 4        | 2             |  |

### SBC A,r

Subtract Register r with carry from the Accumulator where r is any of the registers A, B, C, D, E, H or L.

Object Code:

|         | Hex | Decimal |  |
|---------|-----|---------|--|
| SBC A,B | 98  | 152     |  |
| SBC A,C | 99  | 153     |  |
| SBC A,D | 9A  | 154     |  |
| SBC A,E | 9B  | 155     |  |
| SBC A,H | 9C  | 156     |  |
| SBC A,L | 9D  | 157     |  |
|         |     |         |  |

Description: Subtracts from the Accumulator the contents of Register r and the contents of the C (Carry) Flag in the Flag Register, then stores the result in the Accumulator.

No. of Bytes: 1

| Flag            | Code | Bit | Effect                                                             |
|-----------------|------|-----|--------------------------------------------------------------------|
| Sign            | S    | 7   | SET = 1 if the result is negative, otherwise RESET = $\emptyset$ . |
| Zero            | Z    | 6   | SET = 1 if the result is zero, otherwise RESET = $\emptyset$       |
| —               | _    | 5   | Not used.                                                          |
| Half Carry      | н    | 4   | SET = 1 if no Borrow from Bit 4, otherwise RESET = $\emptyset$ .   |
| -               | _    | 3   | Not used.                                                          |
| Parity/Overflow | P/V  | 2   | SET = 1 if Overflow, otherwise RESET = $\emptyset$ .               |
| Subtract        | N    | 1   | SET = 1.                                                           |
| Carry           | С    | Ø   | SET = 1 if no Borrow, otherwise RESET = $\emptyset$ .              |

#### Example: LD A,ØA9H LD B,16H SCF

SBC A,B

If the contents of the Accumulator are A9(Hex.), the contents of Register B are 16(Hex.) and the C Flag = 1, the effect of this instruction will be:

|                                                           | Accumulator         | Register<br>B | C<br>Flag |
|-----------------------------------------------------------|---------------------|---------------|-----------|
| Original Contents<br>Subtract<br>(Register B)<br>Subtract | A9<br>16<br>93<br>1 | 16            | 1         |
| (C Flag)<br>New Contents                                  | 92                  | 16            | 1         |

Flags Z and P/V are RESET =  $\emptyset$  while Flags S, H, N and C are SET = 1. Addressing Mode: Implicit.

| M Cycles | T States | μsec @ 2 MHz. |
|----------|----------|---------------|
| 1        | 4        | 2             |

### SBC A,(HL)

Description: Subtracts from the Accumulator the contents of the memory location whose address is held in Register Pair HL and the contents of the C (Carry) Flag in the Flag Register, then stores the result in the Accumulator.

No. of Bytes: 1

Object Code (Hex.): 9E

Decimal: 158

| Flag            | Code | Bit | Effect                                                             |
|-----------------|------|-----|--------------------------------------------------------------------|
| Sign            | S    | 7   | SET = 1 if the result is negative, otherwise RESET = $\emptyset$ . |
| Zero            | Z    | 6   | SET = 1 if the result is zero, otherwise RESET = $\emptyset$ .     |
| —               | —    | 5   | Not used.                                                          |
| Half Carry      | н    | 4   | SET = 1 if no borrow from Bit 4, otherwise RESET = $\emptyset$ .   |
| —               | —    | 3   | Not used.                                                          |
| Parity/Overflow | P/V  | 2   | SET = 1 if Overflow, otherwise RESET = $\emptyset$ .               |
| Subtract        | Ν    | 1   | SET = 1.                                                           |
| Carry           | С    | Ø   | SET = 1 if no Borrow, otherwise RESET = $\emptyset$ .              |

Example: LD HL,ØAF34H LD (HL),24H LD A,25H SCF SBC A,(HL)

If the contents of Register Pair HL are AF 34, the required location is AF 34. If the contents of the Accumulator are 25(Hex.), the contents of memory location AF 34 are 24(Hex.) and the C Flag = 1, the effect of this instruction will be:

|                                           | Accumulator   | Memory<br>Location | C<br>Flag |
|-------------------------------------------|---------------|--------------------|-----------|
| Original Contents<br>Subtract             | 25            | 24                 | 1         |
| (Memory Location)<br>Subtract<br>(C Flag) | 24<br>Ø1<br>1 |                    |           |
| New Contents                              | ØØ            | 24                 | 1         |

Flags S and P/V are RESET =  $\emptyset$  while Flags Z, H, N and C are SET = 1.

Addressing Mode: Indirect.

| M Cycles | T States | μsec @ 2 MHz. |  |
|----------|----------|---------------|--|
| 2        | 7        | 3.5           |  |

#### SBC A,(IX + d)SBC A,(IY + d)

Description: Subtracts from the Accumulator the contents of the memory location whose address is identified by the contents of Index Register IX or IY (modified by displacement d, which is specified in the instruction) and the contents of the C (Carry) Flag in the Flag Register, then stores the result in the Accumulator.

No. of Bytes: 3

Object Code:

| Hex Dec           |         | Decimal   |  |
|-------------------|---------|-----------|--|
| SBC A, $(IX + d)$ | DD 9E d | 221 158 d |  |
| SBC A, $(IY + d)$ | FD 9E d | 253 158 d |  |

Where d is the required displacement from the memory location whose address is held in Index Register IX or IY.

| Flag            | Code | Bit | Effect                                                             |
|-----------------|------|-----|--------------------------------------------------------------------|
| Sign            | S    | 7   | SET = 1 if the result is negative, otherwise RESET = $\emptyset$ . |
| Zero            | Z    | 6   | SET = 1 if the result is zero, otherwise RESET = $\emptyset$ .     |
|                 | _    | 5   | Not used.                                                          |
| Half Carry      | Н    | 4   | SET = 1 if no Borrow from Bit 4, otherwise RESET = $\emptyset$ .   |
|                 | —    | 3   | Not used.                                                          |
| Parity/Overflow | P/V  | 2   | $\begin{array}{rllllllllllllllllllllllllllllllllllll$              |
| Subtract        | Ν    | 1   | SET = 1.                                                           |
| Carry           | С    | Ø   | SET = 1 if no Borrow, otherwise RESET = $\emptyset$ .              |

Example: SCF CCF LD HL,ØA244H LD (HL),12H LD IX,ØA234H LD A,28H SBC A,(IX+10H)

If the contents of Index Register IX are A2 34, and d in the instruction is 16(10 Hex.), the required memory location is A2 44. If the contents of the Accumulator are 28(Hex.), the contents of memory location A2 44 are 12(Hex.) and the C Flag =  $\emptyset$ , the result of this instruction will be:

|                     | Accumulator | Memory<br>Location<br>A2 44 | C<br>Flag |
|---------------------|-------------|-----------------------------|-----------|
| Original Contents   | 28          | 12                          | Ø         |
| Subtract            | 12          |                             |           |
| (Index Register IX) |             |                             |           |
|                     | 16          |                             |           |
| Subtract            | Ø           |                             |           |
| (C Flag)            |             |                             |           |
| New Contents        | 16          | 12                          | Ø         |

Flags S, Z and P/V are RESET =  $\emptyset$ , while Flags H, N and C are SET = 1. Addressing Mode: Indexed.

| M Cycles | T States | μsec @ 2 MHz. |
|----------|----------|---------------|
| 5        | 19       | 9.5           |

### SBC HL,rr

Where rr is any of the Register Pairs BC, DE, HL, SP.

Description: Subtracts from the contents of Register Pair HL the contents of the specified register pair and the contents of the C (Carry) Flag in the Flag Register, then stores the result in Register Pair HL.

No. of Bytes: 2

Object Code:

|           | Hex   | Decimal |  |
|-----------|-------|---------|--|
| SBC HL,BC | ED 42 | 237 Ø66 |  |
| SBC HL,DE | ED 52 | 237 Ø82 |  |
| SBC HL,HL | ED 62 | 237 Ø98 |  |
| SBC HL,SP | ED 72 | 237 114 |  |

| Flag            | Code | Bit | Effect                                                             |
|-----------------|------|-----|--------------------------------------------------------------------|
| Sign            | S    | 7   | SET = 1 if the result is negative, otherwise RESET = $\emptyset$ . |
| Zero            | Z    | 6   | SET = 1 if the result is zero, otherwise RESET = $\emptyset$ .     |
|                 |      | 5   | Not used.                                                          |
| Half Carry      | н    | 4   | SET = 1 if no Borrow from Bit 12, otherwise RESET = $\emptyset$ .  |
| —               | _    | 3   | Not used.                                                          |
| Parity/Overflow | P/V  | 2   | $\begin{array}{rllllllllllllllllllllllllllllllllllll$              |
| Subtract        | N    | 1   | SET = 1.                                                           |
| Carry           | С    | Ø   | SET = 1 if no Borrow, otherwise RESET = $\emptyset$ .              |

#### Example: LD HL,2816H LD BC,2715H SCF SBC HL,BC

If the contents of Register Pair HL are 28 16(Hex.), the contents of Register Pair BC are 27 15(Hex.) and the C Flag = 1, the effect of this instruction will be:

|                                                                             | Register<br>Pair HL                | Register<br>Pair BC | C<br>Flag |
|-----------------------------------------------------------------------------|------------------------------------|---------------------|-----------|
| Original Contents<br>Subtract<br>(Register Pair HL)<br>Subtract<br>(C Flag) | 28 16<br>27 15<br>——<br>Ø1 Ø1<br>1 | 27 15               | 1         |
| New Contents                                                                | Ø1 ØØ                              | 27 15               | 1         |

Flags S, Z and P/V are RESET =  $\emptyset$  while Flags H, N and C are SET = 1.

Addressing Mode: Implicit.

| M Cycles | T States | μsec @ 2 MHz. |
|----------|----------|---------------|
| 4        | 15       | 7.5           |

### SCF

Description: SETS the C (Carry) Flag in the Flag Register = 1.

No. of Bytes: 1

Object Code (Hex.): 37 Decimal: Ø55

Flag Register:

| Flag              | Code   | Bit      | Effect                            |
|-------------------|--------|----------|-----------------------------------|
| Sign<br>Zero      | S      | 7        | Not affected.                     |
| —                 | Z<br>— | 6<br>5   | Not affected.<br>Not used.        |
| Half Carry<br>—   | н<br>— | 4<br>3   | $RESET = \emptyset.$<br>Not used. |
| Parity/Overflow   | P/V    | 2        | Not affected.                     |
| Subtract<br>Carry | N<br>C | 1<br>  Ø | RESET = Ø.<br>SET = 1.            |
| Carry             |        | ~        |                                   |

Addressing Mode: Implicit.

| M Cycles | T States | μsec @ 2 MHz. |
|----------|----------|---------------|
| 1        | 4        | 2             |

### SET b,r

Description: The specified Bit in the nominated Register is SET = 1.

No. of Bytes: 2

Object Code (Hex.): CB xx Decimal: 203 yyy

Where: b is the Bit (Range  $\emptyset$  — 7) to be SET = 1 and r is the Register (A, B, C, D, E, H or L) which contains that bit. xx or yyy are taken from the table below:

|          |                                        | A                                                    |                                  | В                                                    |                                              | С                                                    |                                  | D                                                    |                                              | E                                                    |                                              | н                                                    |                                              | L                                                    |
|----------|----------------------------------------|------------------------------------------------------|----------------------------------|------------------------------------------------------|----------------------------------------------|------------------------------------------------------|----------------------------------|------------------------------------------------------|----------------------------------------------|------------------------------------------------------|----------------------------------------------|------------------------------------------------------|----------------------------------------------|------------------------------------------------------|
| Bit      | XX                                     | ууу                                                  | xx                               | ууу                                                  | XX                                           | ууу                                                  | XX                               | ууу                                                  | xx                                           | ууу                                                  | xx                                           | ууу                                                  | xx                                           | ууу                                                  |
| Ø1234567 | C7<br>CF<br>D7<br>E7<br>E7<br>F7<br>FF | 199<br>207<br>215<br>223<br>231<br>239<br>247<br>255 | CØ<br>C8<br>D8<br>E9<br>F8<br>F8 | 192<br>200<br>208<br>216<br>224<br>232<br>240<br>248 | C1<br>C9<br>D1<br>D9<br>E1<br>E9<br>F1<br>F9 | 193<br>201<br>209<br>217<br>225<br>233<br>241<br>249 | C2<br>CA<br>D2<br>E2<br>EA<br>FA | 194<br>202<br>210<br>218<br>226<br>234<br>242<br>250 | C3<br>CB<br>D3<br>DB<br>E3<br>EB<br>F3<br>FB | 195<br>203<br>211<br>219<br>227<br>235<br>243<br>251 | C4<br>CC<br>D4<br>DC<br>E4<br>EC<br>F4<br>FC | 196<br>204<br>212<br>220<br>228<br>236<br>244<br>252 | C5<br>CD<br>D5<br>DD<br>E5<br>ED<br>F5<br>FD | 197<br>205<br>213<br>221<br>229<br>237<br>245<br>253 |

Flag Register:

| Flag                                                                | Code                        | Bit                             | Effect                                                                                                      |
|---------------------------------------------------------------------|-----------------------------|---------------------------------|-------------------------------------------------------------------------------------------------------------|
| Sign<br>Zero<br>—<br>Half Carry<br>—<br>Parity/Overflow<br>Subtract | S<br>Z<br>H<br><br>P/V<br>N | 7<br>6<br>5<br>4<br>3<br>2<br>1 | Not affected.<br>Not affected.<br>Not used.<br>Not affected.<br>Not used.<br>Not affected.<br>Not affected. |
| Carry                                                               | С                           | Ø                               | Not affected.                                                                                               |

Example: LD E,Ø

SET 2,E

The Source Code statement SET 2,E, will result in the Object Code (Hex.) instruction CB D3 which will SET = 1 Bit 2 in Register E.

Addressing Mode: Implicit.

| M Cycles | T States | μsec @ 2 MHz. |
|----------|----------|---------------|
| 2        | 8        | 4             |

# SET b,(HL)

Description: The nominated Bit in the memory location whose address is held in Register Pair HL is SET = 1.

No. of Bytes: 2

Object Code (Hex.): CB xx

Decimal: 203 yyy

Where: xx or yyy are taken from the table below:

| Bit | xx | ууу |
|-----|----|-----|
| Ø   | C6 | 198 |
| 1   | CE | 206 |
| 2   | D6 | 214 |
| 3   | DE | 222 |
| 4   | E6 | 230 |
| 5   | EE | 238 |
| 6   | F6 | 246 |
| 7   | FE | 254 |

Flag Register:

| Flag                                                    | Code                   | Bit                        | Effect                                                                                     |  |
|---------------------------------------------------------|------------------------|----------------------------|--------------------------------------------------------------------------------------------|--|
| Sign<br>Zero<br>—<br>Half Carry<br>—<br>Parity/Overflow | S<br>Z<br>H<br><br>P/V | 7<br>6<br>5<br>4<br>3<br>2 | Not affected.<br>Not affected.<br>Not used.<br>Not affected.<br>Not used.<br>Not affected. |  |
| Subtract<br>Carry                                       | N<br>C                 | 1<br>  Ø                   | Not affected.<br>Not affected.                                                             |  |

Example: LD HL,1000H LD (HL),0 SET 5,(HL)

The Source Code statement SET 5,(HL) will produce the Object Code (Hex.) instruction CD EE, which will SET = 1 Bit 5 in the memory location whose address is held in Register Pair HL.

Addressing Mode: Indirect.

| M Cycles | T States | μsec @ 2 MHz. |
|----------|----------|---------------|
| 4        | 15       | 7.5           |

#### SET b,(IX + d) SET b,(IY + d)

Description: SETs = 1 the nominated Bit in the memory location whose address is identified by the contents of Index Register IX or IY (modified by displacement d, which is specified in the instruction).

No. of Bytes: 4

Object Code:

|                                                                                               | Hex                      | Decimal                        |
|-----------------------------------------------------------------------------------------------|--------------------------|--------------------------------|
| $\begin{array}{l} \text{SET b}, (\text{IX + d}) \\ \text{SET b}, (\text{IY + d}) \end{array}$ | DD CB d xx<br>FD CB d xx | 221 203 d yyy<br>253 203 d yyy |

Where:b is the Bit (Range  $\emptyset$  — 7) to be SET = 1, and D is the required displacement from the memory location whose address is held in Index Register IX.

xx or yyy are taken from the table below:

| Bit | xx | ууу |
|-----|----|-----|
| Ø   | C6 | 198 |
| 1   | CE | 2Ø6 |
| 2   | D6 | 214 |
| 3   | DE | 222 |
| 4   | E6 | 23Ø |
| 5   | EE | 238 |
| 6   | F6 | 246 |
| 7   | FE | 254 |

Flag Register:

| Flag            | Code | Bit | Effect        |
|-----------------|------|-----|---------------|
| Sign            | S    | 7   | Not affected. |
| Zero            | Z    | 6   | Not affected. |
| _               | _    | 5   | Not used.     |
| Half Carry      | н    | 4   | Not affected. |
| —               |      |     |               |
|                 | I    | 3   | Not used.     |
| Parity/Overflow | P/V  | 2   | Not affected. |
| Subtract        | Ν    | 1   | Not affected. |
| Carry           | С    | Ø   | Not affected. |
|                 |      |     |               |

Cont.

Example: LD HL,348EH LD (HL),Ø LD IX,348AH SET 2,(IX+4)

The Source Code statement SET 2,(IX + 4) will produce the Object Code (Hex.) instruction DD CB 4 D6. If the contents of Index Register IX are 34 8A, the required memory location is 34 8E (i.e. 34 8A + 4). This instruction will SET = 1 Bit 2 in memory location 34 8E.

Addressing Mode: Indexed.

| M Cycles | T States | μsec @ 2 MHz. |
|----------|----------|---------------|
| 6        | 23       | 11.5          |

# SLA r

Where r is any of the registers A, B, C, D, E, H, L.

Description: Shifts Left the contents of the specified register, through the C (Carry) Flag in the Flag Register. Bit 0 is RESET = 0, the previous contents of Bit 0 are moved into Bit 1, the previous contents of Bit 1 are moved to Bit 2, etc. The previous contents of Bit 7 are moved into the C (Carry) Flag in the Flag Register. The previous contents of the Carry Flag are destroyed.



No. of Bytes: 2

Object Code:

|       | Hex   | Decimal |  |
|-------|-------|---------|--|
| SLA A | CB 27 | 2Ø3 39  |  |
| SLA B | CB 2Ø | 2Ø3 32  |  |
| SLA C | CB 21 | 2Ø3 33  |  |
| SLA D | DB 22 | 2Ø3 34  |  |
| SLA E | CB 23 | 203 35  |  |
| SLA H | CB 24 | 2Ø3 36  |  |
| SLA L | CB 25 | 2Ø3 37  |  |

Flag Register:

| Flag            | Code | Bit | Effect                                                             |
|-----------------|------|-----|--------------------------------------------------------------------|
| Sign            | S    | 7   | SET = 1 if the result is negative, otherwise RESET = $\emptyset$ . |
| Zero            | Z    | 6   | SET = 1 if the result is zero, otherwise RESET = $\emptyset$ .     |
|                 | _    | 5   | Not used.                                                          |
| Half Carry      | н    | 4   | $RESET = \emptyset.$                                               |
| _               | _    | 3   | Not used.                                                          |
| Parity/Overflow | P/V  | 2   | SET = 1 for Parity Even, RESET = $\emptyset$ for Parity Odd.       |
| Subtract        | N    | 1   | $RESET = \emptyset.$                                               |
| Carry           | С    | Ø   | Contains the data previously held in Bit 7 of the Accumulator.     |

Cont.

#### Example: LD A,93H

SLA H

If the contents of the Accumulator are 93(Hex.), the effect of this instruction will be:

|                                   |          | Bits                               | С      |
|-----------------------------------|----------|------------------------------------|--------|
|                                   | Hex.     | 76543210                           | Flag   |
| Original Contents<br>New Contents | 93<br>26 | 1 Ø Ø 1 Ø Ø 1 1<br>Ø Ø 1 Ø Ø 1 1 Ø | ?<br>1 |

Flags S, Z, H, P/V and N are RESET =  $\emptyset$  while Flag C contains the 1 previously held in Bit 7 of the Accumulator.

Addressing Mode: Implicit.

| M Cycles | T States | μsec @ 2 MHz. |
|----------|----------|---------------|
| 2        | 8        | 4             |

# SLA (HL)

Description: Shifts Left the contents of the memory location whose address is held in Register Pair HL, through the C (Carry) Flag in the Flag Register. Bit  $\emptyset$  is RESET =  $\emptyset$ , the previous contents of Bit  $\emptyset$  are moved into Bit 1, the previous contents of Bit 1 are moved into Bit 2, etc. The previous contents of Bit 7 are moved into the C Flag in the Flag Register. The previous contents of the carry flag are destroyed.



No. of Bytes: 2

Object Code (Hex.): CB 26

Decimal: 203 038

| Flag            | Code | Bit | Effect                                                             |
|-----------------|------|-----|--------------------------------------------------------------------|
| Sign            | S    | 7   | SET = 1 if the result is negative, otherwise RESET = $\emptyset$ . |
| Zero            | Z    | 6   | SET = 1 if the result is zero, otherwise RESET = $\emptyset$ .     |
| _               | —    | 5   | Not used.                                                          |
| Half Carry      | н    | 4   | $RESET = \emptyset.$                                               |
| -               | _    | 3   | Not used.                                                          |
| Parity/Overflow | P/V  | 2   | SET = 1 for Parity Even, RESET = $\emptyset$ for Parity Odd.       |
| Subtract        | N    | 1   | $RESET = \emptyset.$                                               |
| Carry           | С    | Ø   | Contains the data previously held in Bit 7 of the memory location. |

#### Example: LD HL,ØCD45H LD (HL),23H SLA (HL)

If the contents of Register Pair HL are CD 45, and the contents of memory location CD 45 are 23(Hex.), the effect of this instruction will be:

|                                   | Memo     | Memory Location CD 45              |        |  |
|-----------------------------------|----------|------------------------------------|--------|--|
|                                   |          | Bits                               | С      |  |
|                                   | Hex.     | 76543210                           | Flag   |  |
| Original Contents<br>New Contents | 23<br>46 | 0 0 1 0 0 0 1 1<br>0 1 0 0 0 1 1 0 | ?<br>Ø |  |

Flags S, Z, H, P/V and N are RESET =  $\emptyset$ , while Flag C contains the  $\emptyset$  previously held in Bit 7 of memory location CD 45.

Addressing Mode: Indirect.

| M Cycles | T States   | μsec @ 2 MHz. |
|----------|------------|---------------|
| 4        | <b>1</b> 5 | 7.5           |

#### SLA (IX + d)SLA (IY + d)

Description: Shifts Left the contents of the memory location whose address is identified by the contents of Index Register IX or IY (modified by displacement d, which is specified in the instruction), through the C (Carry) Flag in the Flag Register. Bit  $\emptyset$  is RESET =  $\emptyset$ , the previous contents of Bit  $\emptyset$  are moved into Bit 1, the previous contents of Bit 1 are moved into Bit 2, etc. The previous contents of Bit 7 are moved into the C Flag in the Flag Register. The previous contents of the carry flag are destroyed.



No. of Bytes: 4

Object Code:

| lex | Decimal                      |
|-----|------------------------------|
|     | 221 203 d 38<br>253 203 d 38 |
|     | DD CB d 26<br>D CB d 26      |

Where d is the required displacement from the memory location whose address is held in Index Register IX or IY.

| Flag            | Code | Bit | Effect                                                             |
|-----------------|------|-----|--------------------------------------------------------------------|
| Sign            | S    | 7   | SET = 1 if the result is negative, otherwise RESET = $\emptyset$ . |
| Zero            | Z    | 6   | SET = 1 if the result is zero, otherwise RESET = $\emptyset$ .     |
|                 |      | 5   | Not used.                                                          |
| Half Carry      | Н    | 4   | $RESET = \emptyset.$                                               |
| —               |      | 3   | Not used.                                                          |
| Parity/Overflow | P/V  | 2   | SET = 1 for Parity Even, RESET = $\emptyset$ for Parity Odd.       |
| Subtract        | N    | 1   | $RESET = \emptyset.$                                               |
| Carry           | С    | Ø   | Contains the data previously held in Bit 7 of the memory location. |

Example: LD HL,283AH LD (HL),16H LD IX,2834 SLA (IX + 6)

If the contents of Index Register IX are 28 34 and d in the instruction is 6, the required location is 28 3A. If the contents of memory location 28 3A are 16(Hex.), the effect of this instruction will be:

|                                   | Memo     |                                    |        |
|-----------------------------------|----------|------------------------------------|--------|
|                                   |          | Bits                               | С      |
|                                   | Hex.     | 76543210                           | Flag   |
| Original Contents<br>New Contents | 16<br>2C | 0 0 0 1 0 1 1 0<br>0 0 1 0 1 1 0 0 | ?<br>Ø |

Flags S, Z, H, P/V and N are RESET =  $\emptyset$ , while Flag C contains the  $\emptyset$  previously held in Bit 7 of memory location 28 3A.

Addressing Mode: Indexed.

| M Cycles | T States | μsec @ 2 MHz. |
|----------|----------|---------------|
| 6        | 23       | 11.5          |

### SRA r

Arithmetic shift contents of Register r right, where r is any of the Registers A, B, C, D, E, H or L.

Object Code:

|       | Hex   | Decimal |
|-------|-------|---------|
| SRA A | CB 2F | 203 047 |
| SRA B | CB 28 | 203 040 |
| SRA C | CB 29 | 203 041 |
| SRA D | CB 2A | 203 042 |
| SRA E | CB 2B | 203 043 |
| SRA H | CB 2C | 203 044 |
| SRA L | CB 2D | 203 045 |
| SRA L | CB 2D | 2Ø3 Ø45 |

Description: Shift Register r right one bit. Bit 7 is unchanged. Bit  $\emptyset$  is moved into the carry flag. Bit 7 is moved into bit 6, but is not itself changed. Bit 6 is moved into bit 5. Bit 5 is moved into bit 4, etc.



No. of Bytes: 2

| Flag            | Code | Bit | Effect                                                             |
|-----------------|------|-----|--------------------------------------------------------------------|
| Sign            | S    | 7   | SET = 1 if the result is negative, otherwise RESET = $\emptyset$ . |
| Zero            | Z    | 6   | SET = 1 if the result is zero, otherwise RESET = $\emptyset$       |
| _               | _    | 5   | Not used.                                                          |
| Half Carry      | н    | 4   | $RESET = \emptyset.$                                               |
| _               |      | 3   | Not used.                                                          |
| Parity/Overflow | P/V  | 2   | SET = 1 for Parity Even, RESET = $\emptyset$ for Parity Odd.       |
| Subtract        | Ν    | 1   | $RESET = \emptyset.$                                               |
| Carry           | С    | Ø   | Contains the data previously held in Bit Ø of the Accumulator.     |

#### Example: LD A,93H

#### SRA A

If the contents of the Accumulator are 93(Hex.), the effect of this instruction will be:

|                                   |          | Bits                               | С      |
|-----------------------------------|----------|------------------------------------|--------|
|                                   | Hex.     | 76543210                           | Flag   |
| Original Contents<br>New Contents | 93<br>C9 | 1 0 0 1 0 0 1 1<br>1 1 0 0 1 0 0 1 | ?<br>1 |

Flags Z, H and N are RESET =  $\emptyset$ , Flags S and P/V are SET = 1 while Flag C contains the 1 previously held in Bit  $\emptyset$  of the Accumulator.

Addressing Mode: Implicit.

| M Cycles | T States | μsec @ 2 MHz. |
|----------|----------|---------------|
| 2        | 8        | 4             |

# SRA (HL)

Description: Shifts Right the contents of the memory location whose address is held in Register Pair HL, through the C (Carry) Flag in the Flag Register. The contents of Bit 7 remain unchanged but are copied into Bit 6, the previous contents of Bit 6 are moved into Bit 5, the previous contents of Bit 5 are moved into Bit 4, etc. The previous contents of Bit  $\emptyset$  are moved into the C (Carry) Flag in the Flag Register.



No. of Bytes: 2

Object Code (Hex.): CB 2E

Decimal: 203 046

| Flag            | Code | Bit    | Effect                                                                       |
|-----------------|------|--------|------------------------------------------------------------------------------|
| Sign            | S    | 7      | SET = 1 if the result is negative, otherwise RESET = $\emptyset$ .           |
| Zero            | Z    | 6      | SET = 1 if the result is zero, otherwise RESET = $\emptyset$ .               |
| _               | _    | 5      | Not used.                                                                    |
| Half Carry      | Н    | 4<br>3 | $RESET = \emptyset.$                                                         |
| —               | _    | 3      | Not used.                                                                    |
| Parity/Overflow | P/V  | 2      | SET = 1 for Parity Even, RESET = $\emptyset$ for Parity Odd.                 |
| Subtract        | Ν    | 1      | $RESET = \emptyset.$                                                         |
| Carry           | С    | Ø      | Contains the data previously held in Bit $\emptyset$ of the memory location. |

#### Example: LD HL,0CD45H LD (HL),23H SRA (HL)

If the contents of Register Pair HL are CD 45, and the contents of memory location CD 45 are 23(Hex.), the effect of this instruction will be:

|                   | Memory Location CD |   |   |   | 45 |     |   |   |   |      |
|-------------------|--------------------|---|---|---|----|-----|---|---|---|------|
|                   |                    |   |   |   | В  | its |   |   |   | С    |
|                   | Hex.               | 7 | 6 | 5 | 4  | 3   | 2 | 1 | Ø | Flag |
| Original Contents | 23                 | Ø | Ø | 1 | Ø  | Ø   | Ø | 1 | 1 | ?    |
| New Contents      | 11                 | Ø | Ø | Ø | 1  | Ø   | Ø | Ø | 1 | 1    |

Flags S, Z, H and N are RESET =  $\emptyset$ , Flag P/V is SET = 1 while Flag C contains the 1 previously held in Bit  $\emptyset$  of memory location CD 45.

Addressing Mode: Indirect

| M Cycles | T States | μsec @ 2 MHz. |
|----------|----------|---------------|
| 4        | 15       | 7.5           |

#### SRA (IX + d)SRA (IY + d)

Description: Shifts Right the contents of the memory location whose address is identified by the contents of Index Register IX or IY (modified by displacement d, which is specified in the instruction), using the C (Carry) Flag in the Flag Register. The contents of Bit 7 remain unchanged but are copied into Bit 6, the previous contents of Bit 6 are moved into Bit 5, the previous contents of Bit 5 are moved into Bit 4, etc. The previous contents of Bit  $\emptyset$  are moved into the C (Carry) Flag in the Flag Register.



No. of Bytes: 4

Object Code:

|              | Hex        | Decimal       |
|--------------|------------|---------------|
| SRA (IX + d) | DD CB d 2E | 221 203 d 046 |
| SRA(IY + d)  | FD CB d 2E | 253 2Ø3 d Ø46 |

Where d is the required displacement from the memory location whose address is held in Index Register IX or IY.

| Flag            | Code | Bit | Effect                                                             |
|-----------------|------|-----|--------------------------------------------------------------------|
| Sign            | S    | 7   | SET = 1 if the result is negative, otherwise RESET = $\emptyset$ . |
| Zero            | Z    | 6   | SET = 1 if the result is zero, otherwise RESET = $\emptyset$ .     |
| <b></b>         | _    | 5   | Not used.                                                          |
| Half Carry      | н    | 4   | $RESET = \emptyset.$                                               |
| -               | -    | 3   | Not used.                                                          |
| Parity/Overflow | P/V  | 2   | SET = 1 for Parity Even, RESET = $\emptyset$ for Parity Odd.       |
| Subtract        | N    | 1   | $RESET = \emptyset.$                                               |
| Carry           | С    | Ø   | Contains the data previously held in Bit Ø of the memory location. |

Example: LD HL,283AH LD (HL),16H LD IX,2834H SRA (IX+6)

If the contents of Index Register IX are 28 34 and D in the instruction is 6, the required location is 28 3A. If the contents of memory location 28 3A are 16(Hex.), the effect of this instruction will be:

|                                   | Mem      |                      |        |
|-----------------------------------|----------|----------------------|--------|
|                                   |          | Bits                 | С      |
|                                   | Hex.     | 76543210             | Flag   |
| Original Contents<br>New Contents | 16<br>ØB | 00010110<br>00001011 | ?<br>Ø |

Flags S, Z, H, P/V and N are RESET =  $\emptyset$ , while Flag C contains the  $\emptyset$  previously held in Bit  $\emptyset$  of memory location 28 3A.

Addressing Mode: Indexed.

| M Cycles | T States | usec @ 2 MHz. |
|----------|----------|---------------|
| 6        | 23       | 11.5          |

### SRL r

Shift contents of Register r right logical, where r is any of the Registers A, B, C, D, E, H or L.

Object Code:

| 2Ø3 Ø63<br>2Ø3 Ø56 |
|--------------------|
| _, _, _,           |
|                    |
| 203 057            |
| 203 058            |
| 203 059            |
| 203 060            |
| 203 061            |
|                    |

Description: Shift contents of Register r right one bit. Bit 7 is RESET =  $\emptyset$ . Bit  $\emptyset$  is moved to the carry flag.



No. of Bytes: 2

| Flag            | Code | Bit | Effect                                                             |
|-----------------|------|-----|--------------------------------------------------------------------|
| Sign            | S    | 7   | SET = 1 if the result is negative, otherwise RESET = $\emptyset$ . |
| Zero            | Z    | 6   | SET = 1 if the result is zero, otherwise RESET = $\emptyset$       |
| _               |      | 5   | Not used.                                                          |
| Half Carry      | н    | 4   | $RESET = \emptyset.$                                               |
| -               |      | 3   | Not used.                                                          |
| Parity/Overflow | P/V  | 2   | SET = 1 for Parity Even, RESET = $\emptyset$ for Parity Odd.       |
| Subtract        | N    | 1   | $RESET = \emptyset.$                                               |
| Carry           | С    | Ø   | Contains the data previously held in Bit Ø of the Accumulator.     |

Example: LD A,93H

#### SRLA

If the contents of the Accumulator are 93(Hex.), the effect of this instruction will be:

|                                   |          | Bits                               | С      |
|-----------------------------------|----------|------------------------------------|--------|
|                                   | Hex.     | 76543210                           | Flag   |
| Original Contents<br>New Contents | 93<br>49 | 1 0 0 1 0 0 1 1<br>0 1 0 0 1 0 0 1 | ?<br>1 |

Flags S, Z, H, P/V and N are RESET =  $\emptyset$ , while Flag C contains the 1 previously held in Bit  $\emptyset$  of the Accumulator.

Addressing Mode: Implicit.

| M Cycles | T States | μsec @ 2 MHz. |  |
|----------|----------|---------------|--|
| 2        | 8        | 4             |  |

### SRL (HL)

Description: Logical Shift Right of the contents of the memory location whose address is held in Register Pair IX. Bit 7 is RESET =  $\emptyset$ , the previous contents of Bit 7 are moved into Bit 6, the previous contents of Bit 6 are moved into Bit 5, etc. The previous contents of Bit Ø are moved into the C (Carry) Flag in the Flag Register.



No. of Bytes: 2 Object Code (Hex.): CB 3E Decimal: 203 062

| Flag            | Code | Bit | Effect                                                             |
|-----------------|------|-----|--------------------------------------------------------------------|
| Sign            | S    | 7   | SET = 1 if the result is negative, otherwise RESET = $\emptyset$ . |
| Zero            | Z    | 6   | SET = 1 if the result is zero, otherwise RESET = $\emptyset$ .     |
|                 | _    | 5   | Not used.                                                          |
| Half Carry      | Η    | 4   | $RESET = \emptyset$                                                |
|                 | _    | 3   | Not used.                                                          |
| Parity/Overflow | P/V  | 2   | SET = 1 for Parity Even, RESET = $\emptyset$ for Parity Odd.       |
| Subtract        | Ν    | 1   | $RESET = \emptyset.$                                               |
| Carry           | С    | Ø   | Contains the data previously held in Bit Ø of the memory location. |

#### Example: LD HL,0CD45H

LD (HL),23H SRL (HL)

If the contents of Register Pair HL are CD 45, and the contents of memory location CD 45 are 23(Hex.), the effect of this instruction will be:

|                   | Memory Location CD 45 |   |   |   |   |     |   |   |   |      |
|-------------------|-----------------------|---|---|---|---|-----|---|---|---|------|
|                   |                       |   |   |   | В | its |   |   |   | С    |
|                   | Hex.                  | 7 | 6 | 5 | 4 | 3   | 2 | 1 | Ø | Flag |
| Original Contents | 23                    | Ø | Ø | 1 | Ø | Ø   | Ø | 1 | 1 | ?    |
| New Contents      | 11                    | Ø | Ø | Ø | 1 | Ø   | Ø | Ø | 1 | 1    |

Flags S, Z, H and N are RESET =  $\emptyset$ , Flag P/V is SET = 1, while Flag C contains the 1 previously held in Bit  $\emptyset$  of memory location CD 45.

Addressing Mode: Indirect.

| M Cycles | T States | μsec @ 2 MHz. |
|----------|----------|---------------|
| 4        | 15       | 7.5           |

# $\frac{SRL (IX + d)}{SRL (IY + d)}$

Description: Logical Shift Right of the contents of the memory location whose address is identified by the contents of Index Register IX or IY (modified by displacement d, which is specified in the instruction. Bit 7 is RESET =  $\emptyset$ , the previous contents of Bit 7 are moved into Bit 6, the previous contents of Bit 6 are moved into Bit 5, etc. The previous contents of Bit  $\emptyset$  are moved into the C (Carry) Flag in the Flag Register.



No. of Bytes: 4

Object Code:

|                                     | Hex                      | Decimal                        |
|-------------------------------------|--------------------------|--------------------------------|
| $\frac{SRL (IX + d)}{SRL (IY + d)}$ | DD CB d 3E<br>FD CB d 3E | 221 203 d 062<br>253 203 d 062 |

Where d is the required displacement from the memory location whose address is held in Index Register IX or IY.

Flag Register:

| Flag            | Code | Bit | Effect                                                                       |
|-----------------|------|-----|------------------------------------------------------------------------------|
| Sign            | S    | 7   | SET = 1 if the result is negative, otherwise RESET = $\emptyset$ .           |
| Zero            | Z    | 6   | SET = 1 if the result is zero, otherwise RESET = $\emptyset$ .               |
|                 |      | 5   | Not used.                                                                    |
| Half Carry      | н    | 4   | $RESET = \emptyset.$                                                         |
| _               | _    | 3   | Not used.                                                                    |
| Parity/Overflow | P/V  | 2   | SET = 1 for Parity Even, RESET = $\emptyset$ for Parity Odd.                 |
| Subtract        | N    | 1   | $RESET = \emptyset.$                                                         |
| Carry           | С    | Ø   | Contains the data previously held in Bit $\emptyset$ of the memory location. |

Cont.

#### Example: LD HL,283AH LD (HL),16H LD IX,2834H SRL (IX+6)

If the contents of Index Register IX are 28 34 and d in the instruction is 6, the required location is 28 3A. If the contents of memory location 28 3A are 16(Hex.), the effect of this instruction will be:

|                                   | Memory Location 28 3A |                                    |        |
|-----------------------------------|-----------------------|------------------------------------|--------|
|                                   |                       | Bits                               | С      |
|                                   | Hex.                  | 76543210                           | Flag   |
| Original Contents<br>New Contents | 16<br>ØB              | 0 0 0 1 0 1 1 0<br>0 0 0 0 1 0 1 1 | ?<br>Ø |

Addressing Mode: Indexed.

| M Cycles | T States | μsec @ 2 MHz. |
|----------|----------|---------------|
| 6        | 23       | 11.5          |

### SUB n

Description: Subtracts the integer n from the contents of the Accumulator and stores the result in the Accumulator.

No. of Bytes: 2

Object Code (Hex.): D6 n Decimal: 214 n

Where n is an 8 Bit integer, specified in the instruction.

Flag Register:

| Flag            | Code | Bit | Effect                                                             |
|-----------------|------|-----|--------------------------------------------------------------------|
| Sign            | S    | 7   | SET = 1 if the result is negative, otherwise RESET = $\emptyset$ . |
| Zero            | Z    | 6   | SET = 1 if the result is zero, otherwise RESET = $\emptyset$ .     |
| —               |      | 5   | Not used.                                                          |
| Half Carry      | н    | 4   | SET = 1 if no Borrow from Bit 4, otherwise RESET = $\emptyset$ .   |
| —               |      | 3   | Not used.                                                          |
| Parity/Overflow | P/V  | 2   | $\begin{array}{rllllllllllllllllllllllllllllllllllll$              |
| Subtract        | N    | 1   | SET = 1.                                                           |
| Carry           | С    | Ø   | SET = 1 if no Borrow, otherwise RESET = $\emptyset$ .              |

Example: LD A,45H SUB 4

If the contents of the Accumulator are 45(Hex.) and n in the instruction is 4, the effect of this instruction will be:

|                                 | Accumulator (Hex.) |
|---------------------------------|--------------------|
| Original Contents<br>Subtract n | 45<br>4            |
| New Contents                    | 41                 |

Flags S, Z and P/V are RESET =  $\emptyset$  while Flags H, N and C are SET = 1. Addressing Mode: Immediate.

Cont.

| M Cycles | T States | μsec @ 2 MHz. |
|----------|----------|---------------|
| 2        | 7        | 3.5           |

### SUB A

Description: Subtracts the contents of the Accumulator from the contents of the Accumulator and stores the result in the Accumulator. Note that this will always leave a result of zero in the Accumulator.

No. of Bytes: 1

Object Code (Hex.): 97 Decimal: 151

Flag Register:

| Flag            | Code | Bit | Effect                                                             |
|-----------------|------|-----|--------------------------------------------------------------------|
| Sign            | S    | 7   | SET = 1 if the result is negative, otherwise RESET = $\emptyset$ . |
| Zero            | Z    | 6   | SET = 1 if the result is zero, otherwise RESET = $\emptyset$ .     |
| —               |      | 5   | Not used.                                                          |
| Half Carry      | н    | 4   | SET = 1 if no Borrow from Bit 4, otherwise RESET = $\emptyset$ .   |
| _               | _    | 3   | Not used.                                                          |
| Parity/Overflow | P/V  | 2   | SET = 1 if Overflow, otherwise RESET = $\emptyset$                 |
| Subtract        | N    | 1   | SET = 1.                                                           |
| Carry           | С    | Ø   | SET = 1 if no Borrow, otherwise RESET = $\emptyset$ .              |

Example: LD A.28

SUB A

If the contents of the Accumulator are 28(Hex.), the effect of this instruction will be:

|                   | Accumulator (Hex.) |
|-------------------|--------------------|
| Original Contents | 28                 |
| Subtract          | 28                 |
| New Contents      | ØØ                 |

Flags S and P/V are RESET =  $\emptyset$  while Flags Z, H, C and N are SET = 1.

Addressing Mode: Implicit

| M Cycles | T States | μsec @ 2 MHz. |
|----------|----------|---------------|
| 1        | 4        | 2             |

### SUB r

Subtract Register r from the Accumulator, where r is any of the Registers B, C, D, E, H or L.

Object Code:

|       | Hex | Decimal |  |
|-------|-----|---------|--|
| SUB B | 90  | 144     |  |
| SUB C | 91  | 145     |  |
| SUB D | 92  | 146     |  |
| SUB E | 93  | 147     |  |
| SUB H | 94  | 148     |  |
| SUB L | 95  | 149     |  |
|       |     |         |  |

Description: Subtract the contents of Register r from the contents of the Accumulator, contents of Register r unchanged.

No. of Bytes: 1

| Flag            | Code | Bit | Effect                                                             |
|-----------------|------|-----|--------------------------------------------------------------------|
| Sign            | S    | 7   | SET = 1 if the result is negative, otherwise RESET = $\emptyset$ . |
| Zero            | Z    | 6   | SET = 1 if the result is zero, otherwise RESET = $\emptyset$       |
| -               |      | 5   | Not used.                                                          |
| Half Carry      | Н    | 4   | SET = 1 if no Borrow from Bit 4, otherwise RESET = $\emptyset$ .   |
|                 | —    | 3   | Not used.                                                          |
| Parity/Overflow | P/V  | 2   | SET = 1 if Overflow, otherwise RESET = $\emptyset$ .               |
| Subtract        | N    | 1   | SET = 1.                                                           |
| Carry           | С    | Ø   | SET = 1 if no Borrow, otherwise RESET = $\emptyset$ .              |

Example: LD A,ØA9H LD B,16H SUB B

If the contents of the Accumulator are A9(Hex.), and the contents of Register B are 16(Hex.), the effect of this instruction will be:

|                                               | Accumulator | Register<br>B |
|-----------------------------------------------|-------------|---------------|
| Original Contents<br>Subtract<br>(Register B) | A9<br>16    | 16            |
| New Contents                                  | 93          | 16            |

Flags S, Z, and P/V are RESET =  $\emptyset$ , while Flags H, N and C are SET = 1. Addressing Mode: Implicit.

| M Cycles | T States | μsec @ 2 MHz. |
|----------|----------|---------------|
| 1        | 4        | 2             |

## SUB (HL)

Description: Subtracts from the Accumulator the contents of the memory location whose address is held in Register Pair HL, then stores the result in the Accumulator. The contents of the memory location remain unchanged.

No. of Bytes: 1

Object Code (Hex.): 96

Decimal: 150

| Flag            | Code | Bit | Effect                                                             |
|-----------------|------|-----|--------------------------------------------------------------------|
| Sign            | S    | 7   | SET = 1 if the result is negative, otherwise RESET = $\emptyset$ . |
| Zero            | Z    | 6   | SET = 1 if the result is zero, otherwise RESET = $\emptyset$ .     |
| _               | _    | 5   | Not used.                                                          |
| Half Carry      | н    | 4   | SET = 1 if no Borrow from Bit 4, otherwise RESET = $\emptyset$ .   |
| -               | _    | 3   | Not used.                                                          |
| Parity/Overflow | P/V  | 2   | $\begin{array}{llllllllllllllllllllllllllllllllllll$               |
| Subtract        | N    | 1   | SET = 1.                                                           |
| Carry           | С    | Ø   | SET = 1 if no Borrow, otherwise RESET = $\emptyset$ .              |

#### Example: LD HL,ØAF34H LD (HL),24H LD A,25H SUB (HL)

If the contents of Register Pair HL are AF 34, the required memory locatin is AF 34. If the contents of the Accumulator are 25(Hex.), and the contents of memory location AF 34 are 24(Hex.), the effect of this instruction will be:

|                               | Accumulator | Memory<br>Location<br>AF 34 |
|-------------------------------|-------------|-----------------------------|
| Original Contents<br>Subtract | 25          | 24                          |
| (Memory Location)             | 24          |                             |
| New Contents                  | Ø1          | 24                          |

Flags S, Z and P/V are RESET =  $\emptyset$ , while Flags H, N and C are SET = 1. Addressing Mode: Indirect.

| M Cycles | T States | μsec @ 2 MHz. |
|----------|----------|---------------|
| 2        | 7        | 3.5           |

### SUB (IX + d) SUB (IY + d)

Description: Subtracts from the Accumulator the contents of the memory location whose address is identified by the contents of Index Register IX or IY (modified by displacement d, which is specified in the instruction), then stores the result in the Accumulator. The contents of the memory location remain unchanged.

No. of Bytes: 3

Object Code:

|             | Hex     | Decimal   |  |
|-------------|---------|-----------|--|
| SUB(IX + d) | DD 96 d | 221 150 d |  |
| SUB(IY + d) | FD 96 d | 253 15Ø d |  |

Where d is the required displacement from the memory location whose address is held in Index Register IX or IY.

| Flag            | Code | Bit | Effect                                                             |
|-----------------|------|-----|--------------------------------------------------------------------|
| Sign            | S    | 7   | SET = 1 if the result is negative, otherwise RESET = $\emptyset$ . |
| Zero            | Z    | 6   | SET = 1 if the result is zero, otherwise RESET = $\emptyset$ .     |
|                 | _    | 5   | Not used.                                                          |
| Half Carry      | н    | 4   | SET = 1 if no Borrow from Bit 4, otherwise RESET = $\emptyset$ .   |
| —               | _    | 3   | Not used.                                                          |
| Parity/Overflow | P/V  | 2   | $\begin{array}{llllllllllllllllllllllllllllllllllll$               |
| Subtract        | N    | 1   | SET = 1.                                                           |
| Carry           | С    | Ø   | SET = 1 if no Borrow, otherwise RESET = $\emptyset$ .              |

Example: LD HL,ØA244H LD (HL),12H LD IX,ØA234H LD A,28H SUB (IX+10H)

If the contents of Index Register IX are A2 34, and d in the Source Code is 16(10 Hex.), the required memory location is A2 44. If the contents of the Accumulator are 28(Hex.), and the contents of memory location A2 44are 12(Hex.), the effect of this instruction will be:

|                               | Accumulator | Memory<br>Location<br>A2 44 |
|-------------------------------|-------------|-----------------------------|
| Original Contents<br>Subtract | 28          | 12                          |
| (Memory Location<br>A2 44)    | 12          |                             |
| New Contents                  | 16          | 12                          |

Flags S, Z and P/V are RESET =  $\emptyset$ , while Flags H, N and C are SET = 1. Addressing Mode: Indexed.

| M Cycles | T States | μsec @ 2 MHz. |
|----------|----------|---------------|
| 5        | 19       | 9.5           |

### XOR n

Description: Performs a Bit by Bit logical Exclusive OR between the contents of the Accumulator and integer n, then stores the result in the Accumulator. For any corresponding bit positions, if the two contents are equal, i.e. both = 1 or both =  $\emptyset$ , the result, for that bit position, will be  $\emptyset$ , but if the two contents are not equal, i.e. one =  $\emptyset$  and the other = 1, the result for that bit position will be 1.

NOTE: The XOR instruction can be used to complement the Accumulator by specifying n as 255, i.e. FF(Hex.).

No. of Bytes: 2

Object Code (Hex.): EE n Decimal: 238 n

Where n is an 8 Bit integer, specified in the instruction.

| Flag            | Code | Bit | Effect                                                             |
|-----------------|------|-----|--------------------------------------------------------------------|
| Sign            | S    | 7   | SET = 1 if the result is negative, otherwise RESET = $\emptyset$ . |
| Zero            | Z    | 6   | SET = 1 if the result is zero, otherwise RESET = $\emptyset$ .     |
|                 |      | 5   | Not used.                                                          |
| Half Carry      | н    | 4   | RESET = $\emptyset$                                                |
| _               |      | 3   | Not used.                                                          |
| Parity/Overflow | P/V  | 2   | SET = 1 for Parity Even, RESET = $\emptyset$ for Parity Odd.       |
| Subtract        | N    | 1   | $RESET = \emptyset.$                                               |
| Carry           | С    | Ø   | RESET = Ø                                                          |

#### Example: LD A,67H

XOR 5EH

If the contents of the Accumulator are 67(Hex.), and n is specified in the Source Code as 94 (5E Hex.), the effect of this instruction will be:

|                           |          | Bits   |   |   |   |        |   |   |   |
|---------------------------|----------|--------|---|---|---|--------|---|---|---|
|                           | Hex.     | 7      | 6 | 5 | 4 | 3      | 2 | 1 | Ø |
| Accumulator<br>Value of n | 67<br>5E | Ø<br>Ø |   |   |   | Ø<br>1 |   |   |   |
| Result                    | 39       | Ø      | Ø | 1 | 1 | 1      | Ø | Ø | 1 |

Flags S, H, Z, N and C are RESET =  $\emptyset$ , while the P/V flag is SET = 1.

Addressing Mode: Immediate.

| T States | μsec @ 2 MHz. |
|----------|---------------|
| 7        | 3.5           |
|          | T States<br>7 |

### XOR A

Description: Performs a Bit by Bit logical Exclusive OR between the contents of the Accumulator and the contents of the Accumulator. For any corresponding bit positions, if the two contents are equal, i.e. both = 1 or both  $= \emptyset$ , the result, for that bit position, will be  $\emptyset$ , but if the two contents are not equal, the result for that bit position will be 1.

NOTE: The effect of this instruction will be to make the contents of the Accumulator equal 00(Hex.).

No. of Bytes: 1

Object Code (Hex.): AF

Decimal: 175

| Flag            | Code | Bit | Effect                                                             |
|-----------------|------|-----|--------------------------------------------------------------------|
| Sign            | S    | 7   | SET = 1 if the result is negative, otherwise RESET = $\emptyset$ . |
| Zero            | Z    | 6   | SET = 1 if the result is zero, otherwise RESET = $\emptyset$ .     |
|                 |      | 5   | Not used.                                                          |
| Half Carry      | н    | 4   | $RESET = \emptyset.$                                               |
|                 |      | 3   | Not used.                                                          |
| Parity/Overflow | P/V  | 2   | SET = 1 for Parity Even, RESET = $\emptyset$ for Parity Odd.       |
| Subtract        | N    | 1   | $RESET = \emptyset.$                                               |
| Carry           | С    | Ø   | RESET = Ø                                                          |

#### Example: LD A,F4H

#### XOR A

If the contents of the Accumulator are F4(Hex.), the effect of this instruction will be:

|             |      |   |   |   | B | its |   |   |   |
|-------------|------|---|---|---|---|-----|---|---|---|
|             | Hex. | 7 | 6 | 5 | 4 | 3   | 2 | 1 | Ø |
| Accumulator | F4   | 1 | 1 |   |   |     |   | Ø | Ø |
| Accumulator | F4   | 1 | 1 | 1 | 1 | Ø   | 1 | Ø | φ |
| Result      | ØØ   | Ø | Ø | Ø | Ø | Ø   | Ø | Ø | Ø |

Flags S, N and C are RESET =  $\emptyset$ , while Flags Z, H and P/V are SET = 1.

Addressing Mode: Implicit

| M Cycles | T States | μsec @ 2 MHz. |
|----------|----------|---------------|
| 1        | 4        | 2             |

### XOR r

Exclusive OR Register r with the Accumulator where r is any of the registers B, C, D, E, H or L.

Object Code:

|       | Hex | Decimal |  |
|-------|-----|---------|--|
| XOR B | A8  | 168     |  |
| XOR C | A9  | 169     |  |
| XOR D | AA  | 170     |  |
| XOR E | AB  | 171     |  |
| XOR H | AC  | 172     |  |
| XOR L | AD  | 173     |  |
|       |     |         |  |

Description: Exclusive OR Accumulator with the specified Register r. Contents of Register r unchanged.

No. of Bytes: 1

| Flag            | Code | Bit | Effect                                                             |
|-----------------|------|-----|--------------------------------------------------------------------|
| Sign            | S    | 7   | SET = 1 if the result is negative, otherwise RESET = $\emptyset$ . |
| Zero            | Z    | 6   | SET = 1 if the result is zero, otherwise RESET = $\emptyset$       |
|                 |      | 5   | Not used.                                                          |
| Half Carry      | н    | 4   | $RESET = \emptyset.$                                               |
| —               | -    | 3   | Not used.                                                          |
| Parity/Overflow | P/V  | 2   | SET = 1 for Parity Even, RESET = $\emptyset$ for Parity Odd.       |
| Subtract        | Ν    | 1   | $RESET = \emptyset.$                                               |
| Carry           | С    | Ø   | $RESET = \emptyset.$                                               |

#### Example: LD A,ØC4H LD B,ØA7H XOR B

If the contents of the Accumulator are C4(Hex.), and the contents of Register B are A7(Hex.), the effect of this instruction will be:

|             |      | Bits |   |   |   |   |   |   |   |
|-------------|------|------|---|---|---|---|---|---|---|
|             | Hex. | 7    | 6 | 5 | 4 | 3 | 2 | 1 | Ø |
| Accumulator | C4   | 1    | 1 | Ø | Ø | Ø | 1 | Ø | Ø |
| Register B  | A7   | 1    | Ø | 1 | Ø | Ø | 1 | 1 | 1 |
| Result      | 63   | Ø    | 1 | 1 | Ø | Ø | Ø | 1 | 1 |

Flags S, H, Z, N and C are RESET =  $\emptyset$ , while the P/V flag is SET = 1.

Addressing Mode: Implicit.

| M Cycles | T States | μsec @ 2 MHz. |
|----------|----------|---------------|
| 1        | 4        | 2             |

## XOR (HL)

Description: Performs a Bit by Bit logical Exclusive OR between the contents of the Accumulator and the contents of the memory location whose address is held in Register Pair HL, then stores the result in the Accumulator. For any two corresponding bit positions, if the contents are equal, i.e. both = 1 or both =  $\emptyset$ , the result, for that bit position, will be  $\emptyset$ , but if the two contents are not equal, the result will be 1.

No. of Bytes: 1

Object Code (Hex.): AE

Decimal: 174

| Flag            | Code | Bit | Effect                                                             |
|-----------------|------|-----|--------------------------------------------------------------------|
| Sign            | S    | 7   | SET = 1 if the result is negative, otherwise RESET = $\emptyset$ . |
| Zero            | Z    | 6   | SET = 1 if the result is zero, otherwise RESET = $\emptyset$ .     |
| _               | _    | 5   | Not used.                                                          |
| Half Carry      | н    | 4   | $RESET = \emptyset.$                                               |
| -               | _    | 3   | Not used.                                                          |
| Parity/Overflow | P/V  | 2   | SET = 1 for Parity Even, RESET = $\emptyset$ for Parity Odd.       |
| Subtract        | N    | 1   | $RESET = \emptyset.$                                               |
| Carry           | С    | Ø   | RESET = Ø                                                          |

#### Example: LD HL,ØAD45H LD (HL),ØB6H LD A,9DH XOR (HL)

If the contents of Register Pair HL are AD 45, the contents of memory location AD 45 are B6, and the contents of the Accumulator are 9D(Hex.), the effect of this instruction will be:

|                                      |          | Bits   |   |   |   |        |   |   |   |
|--------------------------------------|----------|--------|---|---|---|--------|---|---|---|
|                                      | Hex.     | 7      | 6 | 5 | 4 | 3      | 2 | 1 | Ø |
| Accumulator<br>Memory Location AD 45 | 9D<br>B6 | 1<br>1 |   |   |   | 1<br>Ø |   |   |   |
| Result                               | 2B       | Ø      | Ø | 1 | Ø | 1      | Ø | 1 | 1 |

Flags S, H, Z, N and C are RESET =  $\emptyset$ , while the P/V flag is SET = 1.

Addressing Mode: Indirect

| M Cycles | T States | μsec @ 2 MHz. |  |  |  |
|----------|----------|---------------|--|--|--|
| 2        | 7        | 3.5           |  |  |  |

# $\begin{array}{l} XOR (IX + d) \\ XOR (IY + d) \end{array}$

Description: Performs a Bit by Bit logical Exclusive OR between the contents of the Accumulator and the contents of the memory location whose address is identified by the contents of Index Register IX or IY (modified by displacement d, which is specified in the instruction), then stores the result in the Accumulator. For any two corresponding bit positions, if the contents are equal, i.e. both = 1 or both =  $\emptyset$ , the result, for that bit position, will be  $\emptyset$ , but if the two contents are not equal, the result for that bit position will be 1.

No. of Bytes: 3

Object Code:

|                      | Hex     | Decimal           |  |  |  |
|----------------------|---------|-------------------|--|--|--|
| XOR (IX + d) DD AE d |         | 221 174 d         |  |  |  |
| XOR(IY + d)          | FD AE d | 253 <b>1</b> 74 d |  |  |  |

Where d is the required displacement from the memory location whose address is held in Index Register IX or IY.

| Flag            | Code | Bit | Effect                                                             |  |  |  |
|-----------------|------|-----|--------------------------------------------------------------------|--|--|--|
| Sign            | S    | 7   | SET = 1 if the result is negative, otherwise RESET = $\emptyset$ . |  |  |  |
| Zero            | Z    | 6   | SET = 1 if the result is zer otherwise RESET = $\emptyset$ .       |  |  |  |
| _               |      | 5   | Not used.                                                          |  |  |  |
| Half Carry      | Н    | 4   | $RESET = \emptyset.$                                               |  |  |  |
| _               |      | 3   | Not used.                                                          |  |  |  |
| Parity/Overflow | P/V  | 2   | SET = 1 for Parity Even, RESET = $\emptyset$ for Parity Odd.       |  |  |  |
| Subtract        | N    | 1   | $RESET = \emptyset.$                                               |  |  |  |
| Carry           | С    | Ø   | RESET = Ø                                                          |  |  |  |

Example: LD HL,45BDH LD (HL),18H LD IX,45ADH LD A,22H XOR (IX+1ØH)

If the contents of Index Register IX are 45 AD, and d in the instruction is 16 (1 $\emptyset$ Hex.), the required memory location is 45 BD. If the contents of the Accumulator are 22(Hex.) and the contents of memory location 45 BD are 18(Hex.), the effect of this instruction will be:

|                                      |          | Bits   |        |   |   |        |   |   |        |
|--------------------------------------|----------|--------|--------|---|---|--------|---|---|--------|
|                                      | Hex.     | 7      | 6      | 5 | 4 | 3      | 2 | 1 | Ø      |
| Accumulator<br>Memory Location 45 BD | 22<br>18 | Ø<br>Ø | Ø<br>Ø |   | - | Ø<br>1 |   |   | Ø<br>Ø |
| Result                               | ЗA       | Ø      | Ø      | 1 | 1 | 1      | Ø | 1 | Ø      |

Flags S, Z, H, N and C are RESET =  $\emptyset$ , while the P/V flag is SET = 1.

Addressing Mode: Indexed

| M Cycles | T States | μsec @ 2 MHz. |  |  |  |  |
|----------|----------|---------------|--|--|--|--|
| 5        | 19       | 9.5           |  |  |  |  |

# **CHAPTER 6**

# Hints and Tips

Experienced programmers frequently develop and use methods of doing things within a program which are unlikely to occur to the newcomer, or indeed, to other skilled programmers. This chapter gives details of some of these which may prove useful to the reader.

## Using a Register Pair as a Loop Counter

Decrementing a Register Pair as a loop counter requires specific code to test for a Zero condition. A simple way of achieving this, using Register Pair BC as the Loop Counter, is:

| DEC BC   | Decrement Register Pair BC (Loop Counter)                 |
|----------|-----------------------------------------------------------|
| LD A,C   | Load the contents of Register C into the Accumulator.     |
| OR B     | Perform a Logical OR between the contents of the          |
|          | Accumulator and the contents of Register B.               |
| JR NZ,nn | Where nn is the address of the DEC BC instruction. This   |
|          | will repeat the loop until a Zero condition exists, which |
|          | will only occur when the contents of both Register B and  |
|          | Register C are Zero.                                      |

## Memory Switching

A convenient way of switching between two different areas of memory is to utilise the XOR (Exclusive OR) instruction:

| XOR A  | Clears the Accumulator to Zero.       |
|--------|---------------------------------------|
| XOR 96 | Makes the Accumulator $= 60$ (Hex.)   |
| XOR 96 | Makes the Accumulator $= \emptyset$ . |

Incorporation in a program of a loop which XORs the Accumulator repeatedly with the same integer changes the contents of the Accumulator to that integer, then to zero, then back to the integer, etc. This can then be used to switch control between different areas of memory.

## Loading a Single Byte into a Register Pair

Sometimes it is necessary to load an 8 Bit number into a Register Pair without knowing the sign of that number. For positive numbers, the Higher Order byte of the Register Pair should contain  $\emptyset\emptyset$ (Hex.), while for negative numbers that byte should contain FF(Hex.). An 8 Bit number in Register E can be loaded into Register Pair BC using the following Code:

LD C,E Loads the contents of Register E into Register C, i.e. the Lower Order byte of Register Pair BC.

- RLE Rotates Left Register E, placing the sign bit into the Carry Flag in the Flag Register.
- SBC A,A Subtracts the contents of the Accumulator from itself, leaving a value of  $\emptyset$  but the sign from the Carry Flag affects the result so that, if the Carry Flag =  $\emptyset$ , the contents of the Accumulator become  $\emptyset\emptyset(\text{Hex.})$ , i.e.  $\emptyset$ , but if the Carry Flag = 1, the contents of the Accumulator become FF(Hex.), i.e.  $-\emptyset$ .
- LD B,A Loads Register B with the contents of the Accumulator, i.e.  $\mathcal{O}(\text{Hex.})$  or FF(Hex.) to match the original sign bit of Register E.

Similarly, if it is necessary to load a 16 Bit number into a 32 Bit field, the sign can be moved into the Carry Flag, then copied throughout Register Pair HL by using the instruction SBC HL,HL.

## Rotating 16-Bit (Two Byte) Register Through the Carry Flag

There is no instruction to rotate a 16 Bit Register Pair Left through the Carry Flag, a facility which is sometimes necessary. This can be achieved, using the Register Pair HL, by using the instruction ADC HL,HL, which adds the contents of Register Pair HL to itself, with carry.

## Converting ASCII Characters from Lower to Upper Case

The only differences between the binary representation of Upper and Lower Case ASCII characters is that the Upper Case character has Bit 5 RESET =  $\emptyset$ , while the equivalent Lower Case character has Bit 5 SET = 1. The instruction AND n, where n = DF(Hex.) - 11011111 Binary, will RESET =  $\emptyset$  Bit 5 regardless of its original value, thus ensuring that the character in the Accumulator is Upper Case.

NOTE: Confusion may be caused when using this tip if the input character is non alphabetic.

## **Quick Division**

The contents of a Register can be divided by any multiple of 2 by using the SRA r instruction (where r is the specified Register) one for each power of 2, e.g. 3 times to divide by 8. After each iteration of the SRA r instruction the remainder is placed in the Carry Flag in the Flag Register.

#### Quick Multiplication

A number can be multiplied by a multiple of 2 by using the appropriate SLA instruction, provided the result will not cause Overflow in the Register or Memory Location.

A number less than 256, contained in a Register Pair (say DE), can be multiplied by 256 by:

LD D,E Loads the contents of Register E (the Lower Order byte of the Register Pair, hence the number less than 256) into the Higher Order byte of the Register Pair.

LD E,  $+\emptyset$  Loads  $\emptyset\emptyset(Hex.)$  into the Lower Order byte of the Register Pair.

# **APPENDIX A**

## **ASCII** Codes

| Hex<br>ØØ<br>Ø1<br>Ø2 | Char                                                                                                                                               | Binar                                                                                                                                                                                                                                                                                                                                                                                                                                                     | <sup>y</sup> LSD                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Hex                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Char                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | Binar<br>MSD                                          | y<br>LSD                                              | Hex                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Char                                                  |
|-----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------|-------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------|
| Ø1                    |                                                                                                                                                    | 0010                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                       |                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | - Cinui                                               |
|                       | 0011                                                                                                                                               | ØØ1Ø                                                                                                                                                                                                                                                                                                                                                                                                                                                      | ØØØØ                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 20                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | SP                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 0100                                                  | 0000                                                  | 40                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | @<br>A                                                |
| Ø2                    | SOH                                                                                                                                                | 0010                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 0001                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 21                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | !                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 0100                                                  | 0001                                                  | 41                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Ă                                                     |
|                       | STX                                                                                                                                                | 0010                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 0010                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 22                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | ,,                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 0100                                                  | 0010                                                  | 42                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | В                                                     |
| ØЗ                    | ETX                                                                                                                                                | ØØ1Ø                                                                                                                                                                                                                                                                                                                                                                                                                                                      | ØØ11                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 23                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | #                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Ø1ØØ                                                  | ØØ11                                                  | 43                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | B<br>C                                                |
| Ø4                    | EOT                                                                                                                                                | ØØ1Ø                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Ø1ØØ                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 24                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | \$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 0100                                                  | 0100                                                  | 44                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | D                                                     |
|                       |                                                                                                                                                    | ØØ1Ø                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Ø1Ø1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | %                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Ø1ØØ                                                  | Ø1Ø1                                                  | 45                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | E                                                     |
| Ø6                    |                                                                                                                                                    | ØØ1Ø                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Ø11Ø                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 26                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | &                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 0100                                                  | 0110                                                  | 46                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | E<br>F                                                |
| Ø7                    | BEL                                                                                                                                                | ØØ1Ø                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Ø111                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 27                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | ,                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Ø1ØØ                                                  | Ø111                                                  | 47                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | G                                                     |
| Ø8                    | BS                                                                                                                                                 | ØØ1Ø                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 1000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 28                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | (                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Ø1ØØ                                                  | 1000                                                  | 48                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | н                                                     |
|                       |                                                                                                                                                    | ØØ1Ø                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | )                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                       |                                                       | 49                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 1                                                     |
| ØA                    |                                                                                                                                                    | ØØ1Ø                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 1010                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 2A                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | *                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Ø1ØØ                                                  | 1010                                                  | 4A                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | J                                                     |
| ØВ                    | VT                                                                                                                                                 | ØØ1Ø                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 1011                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 2B                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | +                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Ø1ØØ                                                  | 1011                                                  | 4B                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | K                                                     |
| ØC                    | FF                                                                                                                                                 | 0010                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 1100                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 2C                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 0100                                                  | 1100                                                  | 4C                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | L                                                     |
| ØD                    | CR                                                                                                                                                 | 0010                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 1101                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 2D                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | _                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 0100                                                  | 1101                                                  | 4D                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | M                                                     |
| ØE                    | SO                                                                                                                                                 | ØØ1Ø                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 1110                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 2E                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Ø1ØØ                                                  | 1110                                                  | 4E                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | N                                                     |
| ØF                    | SI                                                                                                                                                 | ØØ1Ø                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 1111                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 2F                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Ø1ØØ                                                  | 1111                                                  | 4F                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 0                                                     |
| 10                    | DLE                                                                                                                                                | 0011                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 0000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 30                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | Ø                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 0101                                                  | 0000                                                  | 50                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Р                                                     |
| 11                    | DC1                                                                                                                                                | 0011                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 0001                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 0101                                                  | 0001                                                  | 51                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Q                                                     |
| 12                    | DC2                                                                                                                                                | 0011                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 0010                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 0101                                                  | 0010                                                  | 52                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | R                                                     |
| 13                    | DC3                                                                                                                                                | ØØ11                                                                                                                                                                                                                                                                                                                                                                                                                                                      | ØØ11                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 33                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Ø1Ø1                                                  | 0011                                                  | 53                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | S                                                     |
| 14                    | DC4                                                                                                                                                | 0011                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 0100                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 34                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 0101                                                  | 0100                                                  | 54                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | т                                                     |
|                       | NAK                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 5                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                       |                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Ú                                                     |
|                       | SYN                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 6                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                       |                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | v                                                     |
| 17                    | ETB                                                                                                                                                | ØØ11                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Ø111                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 37                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 7                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Ø1Ø1                                                  | Ø111                                                  | 57                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | W                                                     |
| 18                    | CAN                                                                                                                                                | 0011                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 1000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 38                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 8                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 0101                                                  | 1000                                                  | 58                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | X                                                     |
|                       | EM                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 1001                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 39                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                       | 1001                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | X<br>Y                                                |
|                       |                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                       |                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | ż                                                     |
| 1B                    | ESC                                                                                                                                                | ØØ11                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 1011                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 3B                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | ;                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | <b>Ö</b> İÖİ                                          | 1011                                                  | 5B                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Z<br>[                                                |
| 1C                    | FS                                                                                                                                                 | 0011                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 1100                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 3C                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | <                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 0101                                                  | 1100                                                  | 5C                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | /                                                     |
| 1Ď                    |                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | =                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                       |                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | ĵ                                                     |
| 1Ĕ                    | RS                                                                                                                                                 | 0011                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 1110                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 3E                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | >                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 0101                                                  | 1110                                                  | 5E                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | ۲<br>۲                                                |
| 1F                    | US                                                                                                                                                 | 0011                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 1111                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 3F                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | ?                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | <b>Ø101</b>                                           | 1111                                                  | 5F                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                       |
|                       | 05<br>06<br>07<br>08<br>09<br>0A<br>0B<br>0C<br>0D<br>0E<br>0F<br>10<br>11<br>12<br>13<br>14<br>15<br>16<br>17<br>18<br>19<br>1A<br>1B<br>1C<br>1E | 05         ENQ<br>ACK<br>BEL           06         ACK<br>BEL           07         BEL           08         BS<br>09           09         HT<br>0E           00         FF<br>0D           0C         FF<br>0D           0F         SI           10         DLE<br>11           12         DC3           14         DC4<br>NAK<br>16           17         ETB           18         CAN<br>SUB<br>1B           1B         ESC           1C         FS<br>1E | Ø5         ENQ         ØØ1Ø           Ø6         ACK         Ø010           Ø7         BEL         Ø010           Ø8         BS         Ø010           Ø9         HT         Ø010           ØA         LF         Ø010           ØB         VT         Ø010           ØC         FF         Ø010           ØC         FF         Ø010           ØE         SO         Ø010           ØE         SO         Ø010           ØF         SI         Ø011           12         DC2         Ø011           13         DC3         Ø011           14         DC4         Ø011           15         NAK         Ø011           16         SYN         Ø011           18         CAN         Ø011           10         GS         Ø011 | 05         ENQ<br>ACK         0010<br>0010         0110<br>010           07         BEL         0010         0100         0110           07         BEL         0010         0100         0110           07         BEL         0010         0100         0110           09         HT         0010         1000           09         HT         0010         1001           0A         LF         0010         1010           0B         VT         0010         1010           0D         CR         0010         1100           0D         CR         0010         1101           0E         SO         0010         1101           0F         SI         0011         1000           11         DC1         0011         0000           11         DC2         0011         0010           12         DC2         0011         0010           13         DC3         0011         0100           15         NAK         0011         0110           16         SYN         0011         0110           17         ETB         0011         0011 <td>05         ENQ<br/>ACK         0010         0101         25           06         ACK         0010         0110         26           07         BEL         0010         0110         26           07         BEL         0010         0111         27           08         BS         0010         1000         28           09         HT         0010         1001         29           0A         LF         0010         1010         2A           0B         VT         0010         1011         2B           0C         FF         0010         1100         2C           0D         CR         0010         1101         2D           0E         SO         0010         1101         2D           0F         SI         0011         0000         30           11         DC1         0011         0000         30           11         DC1         0011         0010         31           12         DC2         0011         0010         34           13         DC3         0011         0101         35           16         SYN         00</td> <td><math display="block"> \begin{array}{cccccccccccccccccccccccccccccccccccc</math></td> <td><math display="block"> \begin{array}{cccccccccccccccccccccccccccccccccccc</math></td> <td>05         ENQ         0010         0101         25         %         0100         0101         0100         0110         0100         0110         0100         0110         0100         0110         0100         0110         0100         0110         0100         0110         0100         0110         0100         0110         000         0110         000         0111         27         "         0100         0110         000         0111         000         0111         27         "         0100         0100         0101         000         0111         000         0111         000         0101         1000         0000         0100         1000         0000         000         000         0000         0000         0000         0000         0000         0000         0000         0000         0000         0000         0000         0000         0000         0000         0000         0000         0000         0000         0000         0000         0000         0000         0000         0000         0000         0000         0000         0000         0000         0000         0000         0000         0000         0000         0000         0000         0000         0000</td> <td><math display="block"> \begin{array}{cccccccccccccccccccccccccccccccccccc</math></td> | 05         ENQ<br>ACK         0010         0101         25           06         ACK         0010         0110         26           07         BEL         0010         0110         26           07         BEL         0010         0111         27           08         BS         0010         1000         28           09         HT         0010         1001         29           0A         LF         0010         1010         2A           0B         VT         0010         1011         2B           0C         FF         0010         1100         2C           0D         CR         0010         1101         2D           0E         SO         0010         1101         2D           0F         SI         0011         0000         30           11         DC1         0011         0000         30           11         DC1         0011         0010         31           12         DC2         0011         0010         34           13         DC3         0011         0101         35           16         SYN         00 | $ \begin{array}{cccccccccccccccccccccccccccccccccccc$ | $ \begin{array}{cccccccccccccccccccccccccccccccccccc$ | 05         ENQ         0010         0101         25         %         0100         0101         0100         0110         0100         0110         0100         0110         0100         0110         0100         0110         0100         0110         0100         0110         0100         0110         0100         0110         000         0110         000         0111         27         "         0100         0110         000         0111         000         0111         27         "         0100         0100         0101         000         0111         000         0111         000         0101         1000         0000         0100         1000         0000         000         000         0000         0000         0000         0000         0000         0000         0000         0000         0000         0000         0000         0000         0000         0000         0000         0000         0000         0000         0000         0000         0000         0000         0000         0000         0000         0000         0000         0000         0000         0000         0000         0000         0000         0000         0000         0000         0000         0000 | $ \begin{array}{cccccccccccccccccccccccccccccccccccc$ |

|                                                               |                      |                  |                                      |                              |                      | the second second second second second second second second second second second second second second second se |                                      |                              |                      |                  |
|---------------------------------------------------------------|----------------------|------------------|--------------------------------------|------------------------------|----------------------|-----------------------------------------------------------------------------------------------------------------|--------------------------------------|------------------------------|----------------------|------------------|
| Binary<br>MSD LSD                                             | Hex                  | Char             | Binar<br>MSD                         |                              | Hex                  | Char                                                                                                            | Binar<br>MSD                         | y<br>LSD                     | Hex                  | Char             |
| 0110 0000<br>0110 0001<br>0110 0010<br>0110 0010<br>0110 0011 | 6Ø<br>61<br>62<br>63 | a<br>b<br>c      | Ø110<br>Ø110<br>Ø110<br>Ø110<br>Ø110 | 1011<br>1100<br>1101<br>1110 | 6B<br>6C<br>6D<br>6E | k<br>I<br>M<br>n                                                                                                | 0111<br>0111<br>0111<br>0111<br>0111 | Ø11Ø<br>Ø111<br>1000<br>1001 | 76<br>77<br>78<br>79 | v<br>w<br>x<br>y |
| 0110 0100<br>0110 0101<br>0110 0110<br>0110 0110<br>0110 0111 | 64<br>65<br>66<br>67 | d<br>e<br>f<br>g | 0110<br>0111<br>0111<br>0111<br>0111 | 1111<br>ØØØØ<br>ØØØ1<br>ØØ1Ø | 6F<br>7Ø<br>71<br>72 | o<br>p<br>q<br>r                                                                                                | 0111<br>0111<br>0111<br>0111<br>0111 | 1010<br>1011<br>1100<br>1101 | 7A<br>7B<br>7C<br>7D | z<br>{<br>}      |
| 0110 1000<br>0110 1001<br>0110 1010                           | 68<br>69<br>6A       | h<br>i<br>j      | Ø111<br>Ø111<br>Ø111                 | 0011<br>0100<br>0101         | 73<br>74<br>75       | s<br>t<br>u                                                                                                     | Ø111<br>Ø111                         | 1110<br>1111                 | 7E<br>7F             | DEL              |

# **APPENDIX B**

# ASCII/Hexadecimal/Decimal Conversion

| ASCII                    | Hex                  | Dec                  | ASCII            | Hex                  | Dec                  | ASCII            | Hex                  | Dec                  | ASCII            | Hex                  | Dec                      |
|--------------------------|----------------------|----------------------|------------------|----------------------|----------------------|------------------|----------------------|----------------------|------------------|----------------------|--------------------------|
| NUL<br>SOH<br>STX<br>ETX | 00<br>01<br>02<br>03 | Ø<br>1<br>2<br>3     | SP<br>!,<br>#    | 20<br>21<br>22<br>23 | 32<br>33<br>34<br>35 | @<br>А В С       | 40<br>41<br>42<br>43 | 64<br>65<br>66<br>67 | a<br>b<br>c      | 6Ø<br>61<br>62<br>63 | 96<br>97<br>98<br>99     |
| EOT<br>ENQ<br>ACK<br>BEL | Ø4<br>Ø5<br>Ø6<br>Ø7 | 4<br>5<br>6<br>7     | \$<br>%<br>&     | 24<br>25<br>26<br>27 | 36<br>37<br>38<br>39 | D<br>E<br>F<br>G | 44<br>45<br>46<br>47 | 68<br>69<br>7Ø<br>71 | d<br>e<br>f<br>g | 64<br>65<br>66<br>67 | 100<br>101<br>102<br>103 |
| BS<br>HT<br>LF<br>VT     | Ø8<br>Ø9<br>ØA<br>ØB | 8<br>9<br>10<br>11   | ()<br>*<br>+     | 28<br>29<br>2A<br>2B | 40<br>41<br>42<br>43 | НЧЭК             | 48<br>49<br>4A<br>4B | 72<br>73<br>74<br>75 | h<br>i<br>k      | 68<br>69<br>6A<br>6B | 104<br>105<br>106<br>107 |
| FF<br>CR<br>SO<br>SI     | ØC<br>ØD<br>ØE       | 12<br>13<br>14<br>15 | ''<br>;          | 2C<br>2D<br>2E<br>2F | 44<br>45<br>46<br>47 | LMZO             | 4C<br>4D<br>4E<br>4F | 76<br>77<br>78<br>79 | l<br>m<br>n<br>o | 6C<br>6D<br>6E<br>6F | 108<br>109<br>110<br>111 |
| DLE<br>DC1<br>DC2<br>DC3 | 10<br>11<br>12<br>13 | 16<br>17<br>18<br>19 | Ø<br>1<br>2<br>3 | 3Ø<br>31<br>32<br>33 | 48<br>49<br>50<br>51 | P<br>Q<br>R<br>S | 5Ø<br>51<br>52<br>53 | 8Ø<br>81<br>82<br>83 | p<br>q<br>r<br>s | 70<br>71<br>72<br>73 | 112<br>113<br>114<br>115 |
| DC4<br>NAK<br>SYN<br>ETB | 14<br>15<br>16<br>17 | 2Ø<br>21<br>22<br>23 | 4<br>5<br>6<br>7 | 34<br>35<br>36<br>37 | 52<br>53<br>54<br>55 | T<br>U<br>V<br>W | 54<br>55<br>56<br>57 | 84<br>85<br>86<br>87 | t<br>u<br>v<br>w | 74<br>75<br>76<br>77 | 116<br>117<br>118<br>119 |
| CAN<br>EM<br>SUB<br>ESC  | 18<br>19<br>1A<br>1B | 24<br>25<br>26<br>27 | 8<br>9<br>:      | 38<br>39<br>3A<br>3B | 56<br>57<br>58<br>59 | X<br>Y<br>Z<br>[ | 58<br>59<br>5A<br>5B | 88<br>89<br>90<br>91 | x<br>y<br>z<br>{ | 78<br>79<br>7A<br>7B | 120<br>121<br>122<br>123 |
| FS<br>GS<br>RS<br>US     | 1C<br>1D<br>1E<br>1F | 28<br>29<br>30<br>31 | < = > ?          | 3C<br>3D<br>3E<br>3F | 6Ø<br>61<br>62<br>63 | ]                | 5C<br>5D<br>5E<br>5F | 92<br>93<br>94<br>95 | `}<br>}          | 7C<br>7D<br>7E<br>7F | 124<br>125<br>126<br>127 |

## Special Character Codes

| Code | Explanation                  | Code | Explanation           |
|------|------------------------------|------|-----------------------|
| ACK  | Acknowledge                  | FF   | Form Feed             |
| BEL  | Bell or Alarm                | FS   | File Separator        |
| BS   | Backspace                    | GS   | Group Separator       |
| CAN  | Cancel                       | HT   | Horizontal Tabulation |
| CR   | Carriage Return              | LF   | Line Feed             |
| DC1  | Device Control 1             | NAK  | Negative Acknowledge  |
| DC2  | Device Control 2             | NUL  | Null                  |
| DC3  | Device Control 3             | RS   | Record Separator      |
| DC4  | Device Control 4             | SI   | Shift In              |
| DEL  | Delete                       | SO   | Shift Out             |
| DLE  | Data Link Escape             | SOH  | Start of Heading      |
| EM   | End of Medium                | SP   | Space                 |
| ENQ  | Enquiry                      | STX  | Start of Text         |
| EOT  | End of Transmission          | SUB  | Substitute            |
| ESC  | Escape                       | SYN  | Synchronous Idle      |
| ETB  | End of Transmission<br>Block | US   | Unit Separator        |
| ETX  | End of Text                  | VT   | Vertical Tabulation   |

# APPENDIX C Quick Reference to Z80 Instruction Set

#### SINGLE BYTE (8 BIT) LOAD GROUP TABLE

|                                                     |                                                               |                                                    |   |   | FL/ | AGS |   |   | NO.         |             | TIMING      | _              |                                                                                                                                                                                              |                                               |
|-----------------------------------------------------|---------------------------------------------------------------|----------------------------------------------------|---|---|-----|-----|---|---|-------------|-------------|-------------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------|
| SOURCE<br>CODE                                      | OBJECT<br>CODE (HEX)                                          | DECIMAL                                            | s | z | н   | P/V | N | С | OF<br>BYTES | M<br>CYCLES | T<br>STATES | μSEC @<br>2MHZ | COMMENTS                                                                                                                                                                                     | CH.5<br>REF.                                  |
| LD r.r'                                             | Dependent on<br>r(Bits 5.4.3) ar<br>01 ← r →← r'→<br>(Binary) | nd r1(Bits 2, 1, 0)                                | N | Ν | Ν   | Ν   | Ν | Ν | 1           | 1           | 4           | 2              | r and r <sup>1</sup><br>represent<br>Registers A,B,<br>C,D,E,H or L.<br>r and r <sup>1</sup> Bit<br>Pattern is:<br>A = 111<br>B = 000<br>C = 001<br>D = 010<br>E = 011<br>H = 100<br>L = 101 | 189<br>189<br>189<br>189<br>189<br>189<br>189 |
| LDr, n<br>r = A<br>r = C<br>r = D<br>r = E<br>r = H | 3E n<br>06 n<br><b>0E n</b><br>16 n<br>1E n<br>26 n           | 062 n<br>006 n<br>014 n<br>022 n<br>030 n<br>038 n | N | N | N   | N   | N | N | 2           | 2           | 7           | 3.5            |                                                                                                                                                                                              | 188<br>188<br>188<br>188<br>188<br>188<br>188 |

# SINGLE BYTE (8 BIT) LOAD GROUP TABLE (cont.)

|                |                      |                        |   |   | FL/ | AGS |   |   | NO. |             | TIMING      |                |          |              |
|----------------|----------------------|------------------------|---|---|-----|-----|---|---|-----|-------------|-------------|----------------|----------|--------------|
| SOURCE<br>CODE | OBJECT<br>CODE (HEX) | DECIMAL                | s | z | н   | P/V | N | с | OF  | M<br>CYCLES | T<br>STATES | μSEC @<br>2MHZ | COMMENTS | CH.5<br>REF. |
| r = L          | 2E n                 | 046 n                  |   |   |     |     |   |   |     |             |             |                |          | 188          |
| LDr, (HL)      |                      |                        | N | N | N   | N   | N | N | 1   | 2           | 7           | 3.5            |          |              |
| r = A          | 7E                   | 126                    |   |   |     |     |   |   |     |             |             |                |          | 191          |
| r = B          | 46                   | 070                    |   |   |     |     |   |   |     |             |             |                |          | 191          |
| r = C          | 4E                   | 078                    |   |   |     |     |   |   |     |             |             |                |          | 191          |
| r = D          | 56                   | 086                    |   |   |     |     |   |   |     |             |             |                |          | 191          |
| r = E<br>r = H | 5E<br>66             | 094<br>102             |   |   |     |     |   |   |     |             |             |                |          | 191          |
| r = L          | 6E                   | 1102                   |   |   |     |     |   |   |     |             |             |                |          | 191<br>191   |
|                |                      | 110                    |   |   |     |     |   |   |     |             |             |                |          | 191          |
| LD r, (IX + d) | DD 75 4              | 001 100 1              | N | N | N   | N   | N | N | 3   | 5           | 19          | 9.5            |          |              |
| r = A<br>r = B | DD 7E d<br>DD 46 d   | 221 126 d              |   |   |     |     |   |   |     |             |             |                |          | 193          |
| r = D<br>r = C | DD 46 d              | 221 070 d<br>221 078 d |   |   |     |     |   |   |     |             |             |                |          | 193<br>193   |
| r = D          | DD 42 d              | 221 078 d<br>221 086 d |   |   |     |     |   |   |     |             |             |                |          | 193          |
| r = E          | DD 5E d              | 221 000 d              |   |   |     |     |   |   |     |             |             |                |          | 193          |
| r = H          | DD 66 d              | 221 102 d              |   |   |     |     |   |   |     |             |             |                |          | 193          |
| r = L          | DD 6E d              | 221 110 d              |   |   |     |     |   |   |     |             |             |                |          | 193          |
| LD r, (IY + d) |                      |                        | N | N | N   | N   | N | N | 3   | 5           | 19          | 9.5            |          |              |
| r = A          | FD 7E d              | 253 126 d              |   |   |     |     |   |   |     | Ŭ           |             | 0.0            |          | 193          |
| r = B          | FD 46 d              | 253 070 d              |   |   |     |     |   |   |     |             |             |                |          | 193          |
| r = C          | FD 4E d              | 253 078 d              |   |   |     |     |   |   |     |             |             |                |          | 193          |
| r = D          | FD 56 d              | 253 086 d              |   |   |     |     |   |   |     |             |             |                |          | 193          |
| r = E          | FD 5E d              | 253 094 d              |   |   |     |     |   |   |     |             |             |                |          | 193          |
| r = H          | FD 66 d              | 253 102 d              |   |   |     |     |   |   |     |             |             |                |          | 193          |
| r = L          | FD 6E d              | 253 110 d              |   |   |     |     |   |   |     |             |             |                |          | 193          |
| LD (HL), r     |                      |                        | N | N | N   | N   | Ν | N | 1   | 2           | 7           | 3.5            |          |              |
| r = A          | 77                   | 119                    |   |   |     |     |   |   |     |             |             |                |          | 212          |

# SINGLE BYTE (8 BIT) LOAD GROUP TABLE (cont.)

|                |                      |                        |    |   | FL/ | AGS |   |   | NO.         |             | TIMING      |                |          |              |
|----------------|----------------------|------------------------|----|---|-----|-----|---|---|-------------|-------------|-------------|----------------|----------|--------------|
| SOURCE<br>CODE | OBJECT<br>CODE (HEX) | DECIMAL                | S  | z | н   | P/V | N | с | OF<br>BYTES | M<br>CYCLES | T<br>STATES | μSEC @<br>2MHZ | COMMENTS | CH.5<br>REF. |
|                | 70                   | 112                    |    |   |     |     |   |   |             |             |             |                |          | 212          |
|                | 71                   | 113                    |    |   |     |     |   |   |             |             |             |                |          | 212          |
|                | 72                   | 114                    |    |   |     |     |   |   |             |             |             |                |          | 212          |
|                | 73                   | 115                    |    |   |     |     |   |   |             |             |             |                |          | 212          |
|                | 74                   | 116                    |    |   |     |     |   |   |             |             |             |                |          | 212          |
|                | 75                   | 117                    |    |   |     |     |   |   |             |             |             |                |          | 212          |
| LD (IX + d), r |                      |                        | N  | N | N   | N   | N | N | 3           | 5           | 19          | 9.5            |          |              |
| r = A          | DD 77 d              | 221 119 d              |    |   |     |     |   |   |             |             |             |                |          | 215          |
| r = B          | DD 70 d              | 221 112 d              |    |   |     |     |   |   |             |             |             |                |          | 215          |
| r = C          | DD 71 d              | 221 113 d              |    |   |     |     |   |   |             |             |             |                |          | 215          |
| r = D          | DD 72 d              | 221 114 d              |    |   |     |     |   |   |             |             |             |                |          | 215          |
| r = E          | DD 73 d              | 221 115 d              |    |   |     |     |   |   |             |             |             |                |          | 215          |
| r = H          | DD 74 d              | 221 116 d              |    |   |     |     |   |   |             |             |             |                |          | 215          |
| r = L          | DD 75 d              | 221 117 d              |    |   |     |     |   |   |             |             |             |                |          | 215          |
| LD (IY + d), r |                      |                        | Ν  | N | N   | N   | N | N | 3           | 5           | 19          | 9.5            |          |              |
|                | FD 77 d              | 253 119 d              |    |   |     |     |   |   |             |             |             |                |          | 215          |
|                | FD 70 d              | 253 112 d              |    |   |     | 2   |   |   |             |             |             |                |          | 215          |
| r = C          | FD 71 d              | 253 113 d              |    |   |     |     |   |   |             |             |             |                |          | 215          |
| r = D          | FD 72 d              | 253 114 d              |    |   |     |     |   |   |             |             |             |                |          | 215          |
| r = E<br>r = H | FD 73 d<br>FD 74 d   | 253 115 d              |    |   |     |     |   |   |             |             |             |                |          | 215          |
| r = H<br>r = L | FD 74 d<br>FD 75 d   | 253 116 d<br>253 117 d |    |   |     |     |   |   |             |             |             |                |          | 215          |
|                |                      |                        |    |   |     |     |   |   |             |             |             |                |          |              |
| LD (HL), n     | 36 n                 | 054 n                  | N  | N | N   | Ν   | N | N | 2           | 3           | 10          | 5              |          | 211          |
| LD (IX + d), n | DD 36 d n            | 221 054 d n            | Ν  | N | N   | N   | Ν | N | 4           | 5           | 19          | 9.5            |          | 214          |
| LD (IY + d), n | FD 36 d n            | 253 054 d n            | Ν  | N | N   | N   | N | N | 4           | 5           | 19          | 9.5            |          | 214          |
|                | 0A                   | 010                    | Ν  | N | N   | N   | N | N | 1           | 2           | 7           | 3.5            |          | 186          |
|                | 1A                   | 026                    | N  | N |     |     |   |   |             |             |             |                |          |              |
|                |                      | 020                    | IN | N | N   | N   | Ν | N | 1           | 2           | 7           | 3.5            |          | 187          |

### SINGLE BYTE (8 BIT) LOAD GROUP TABLE (cont.)

|                |                      |         |   | 14 | FL/ | AGS |   |   | NO.         |             | TIMING      |                |          |              |
|----------------|----------------------|---------|---|----|-----|-----|---|---|-------------|-------------|-------------|----------------|----------|--------------|
| SOURCE<br>CODE | OBJECT<br>CODE (HEX) | DECIMAL | s | z  | н   | P/V | N | C | OF<br>BYTES | M<br>CYCLES | T<br>STATES | μSEC @<br>2MHZ | COMMENTS | CH.5<br>REF. |
| LDA, (nn)      | 3Ann                 | 050 n n | N | N  | N   | N   | Ν | Ν | 3           | 4           | 13          | 6.5            |          | 185          |
| LD (BC), A     | 02                   | 002     | N | N  | N   | N   | N | Ν | 1           | 2           | 7           | 3.5            |          | 210          |
| LD (DE), A     | 12                   | 018     | N | N  | N   | N   | N | Ν | 1           | 2           | 7           | 3.5            |          | 210          |
| LD (nn), A     | 32 n n               | 050 n'n | N | N  | N   | N   | N | N | 3           | 4           | 13          | 6.5            |          | 205          |
| LDA, I         | ED 57                | 237 087 |   |    | Ø   | IFF | Ø | N | 2           | 2           | 9           | 4.5            |          | 183          |
| LDA, R         | ED 5F                | 237 095 | * | •  | Ø   | IFF | Ø | N | 2           | 2           | 9           | 4.5            |          | 184          |
| LDI, A         | ED47                 | 237 071 | N | N  | N   | N   | N | N | 2           | 2           | 9           | 4.5            |          | 195          |
| LDR, A         | ED4F                 | 237 079 | N | N  | N   | N   | N | N | 2           | 2           | 9           | 4.5            |          | 196          |

FLAG KEY: N - Not affected.

0 - RESET = 0.

1 - SET = 1.

? – Unknown.

\* - Affected according to the result.

IFF - Content of Interrupt Flip Flop 2 copied into flag.

## TWO BYTE (16 BYTE) LOAD GROUP TABLE

|                                                                     |                                                      |                                                             |             |             | FL/      | AGS         |            |                  | NO.              |                  | TIMING              |                    |          |                                 |
|---------------------------------------------------------------------|------------------------------------------------------|-------------------------------------------------------------|-------------|-------------|----------|-------------|------------|------------------|------------------|------------------|---------------------|--------------------|----------|---------------------------------|
| SOURCE<br>CODE                                                      | OBJECT<br>CODE (HEX)                                 | DECIMAL                                                     | S           | z           | н        | P/V         | N          | с                | OF<br>BYTES      | M<br>CYCLES      | T<br>STATES         | μSEC @<br>2MHZ     | COMMENTS | CH.5<br>REF.                    |
| LD, dd, nn<br>dd = BC<br>dd = DE<br>dd = HL<br>dd = SP              | 01 nn<br>11 nn<br>21 nn<br>31                        | 001<br>017<br>033<br>049                                    | Ν           | N           | Ν        | Ν           | Ν          | Ν                | 3                | 3                | 10                  | 5                  |          | 197<br>197<br>197<br>197<br>197 |
| LDIX, nn<br>LDIY, nn<br>LDdd, (nn)<br>dd = BC<br>dd = DE<br>dd = HL | DD21nn<br>FD21nn<br>ED 4B nn<br>ED 5B nn<br>ED 6B nn | 221 033 n n<br>253 033 n n<br>237 075<br>237 091<br>237 107 | N<br>N<br>N | N<br>N<br>N | N N<br>N | N<br>N<br>N | N N<br>N   | N N<br>N         | 4 4 4            | 4<br>4<br>6      | 14<br>14<br>20      | 7<br>7<br>10       |          | 198<br>198<br>199<br>199<br>199 |
| dd = SP $LDIX (nn)$ $LDIY, (nn)$ $LD (nn), dd$                      | ED 7B nn<br>DD 2A n n<br>FD 2A n n                   | 237 123<br>221 042 n n<br>253 042 n n                       | ZZZ         | N N<br>N N  | ZZZ      | N<br>N<br>N | N N<br>N N | N<br>N<br>N<br>N | 4 4 4            | 6<br>6<br>6      | 20<br>20<br>20      | 10<br>10<br>10     |          | 199<br>199<br>201<br>201        |
| dd = BC $dd = DE$ $dd = HL$ $dd = SP$                               | ED 43 nn<br>ED 53 nn<br>ED 63 nn<br>ED 73 nn         | 237 067 n n<br>237 083n n<br>237 099 n n<br>237 115 n n     |             |             |          |             |            |                  |                  |                  |                     |                    |          | 206<br>206<br>206<br>206        |
| LD (nn), IX<br>LD (nn), IY<br>LD SP, HL<br>LD, SP, IX               | DD 22 nn<br>FD 22 nn<br>F9<br>DD F9                  | 221 034 n n<br>253 034 n n<br>249<br>221 249                | N N N N     | Z Z Z       | N N N N  | Z Z Z       | Z Z Z      | N<br>N<br>N<br>N | 4<br>4<br>1<br>2 | 6<br>6<br>1<br>2 | 20<br>20<br>6<br>10 | 10<br>10<br>3<br>5 |          | 208<br>208<br>203<br>204        |

#### TWO BYTE (16 BYTE) LOAD GROUP TABLE (cont.)

|                                                    |                      |                          |        |        | FLA    | AGS    |        |        | NO.         |             | TIMING      |                |          |                                 |
|----------------------------------------------------|----------------------|--------------------------|--------|--------|--------|--------|--------|--------|-------------|-------------|-------------|----------------|----------|---------------------------------|
| SOURCE<br>CODE                                     | OBJECT<br>CODE (HEX) | DECIMAL                  | S      | Z      | н      | P/V    | N      | с      | OF<br>BYTES | M<br>CYCLES | T<br>STATES | μSEC @<br>2MHZ | COMMENTS | CH.5<br>REF.                    |
| LDSP, IY                                           | FDF9                 | 253 249                  | N      | N      | N      | N      | N      | N      | 2           | 2           | 10          | 5              |          | 204                             |
| PUSHrr                                             |                      | 200240                   | N      | N      | N      | N      | N      | N      | 1           | 3           | 11          | 5.5            |          |                                 |
| rr = AF<br>rr = BC<br>rr = DE<br>rr = HL           | F5<br>C5<br>D5<br>E5 | 245<br>197<br>213<br>229 |        |        |        |        |        |        |             |             |             |                |          | 246<br>246<br>246<br>246        |
| PUSHIX                                             | DD E5                | 221 229                  | Ν      | Ν      | N      | N      | Ν      | Ν      | 2           | 4           | 15          | 7.5            |          | 248                             |
| PUSHIY                                             | FDE5                 | 253 229                  | Ν      | Ν      | N      | N      | Ν      | Ν      | 2           | 4           | 15          | 7.5            |          | 248                             |
| POP rr<br>rr = AF<br>rr = BC<br>rr = DE<br>rr = HL | F1<br>C1<br>D1<br>E1 | 241<br>193<br>209<br>225 | N      | N      | Ν      | Ν      | Ν      | Ν      | 1           | 3           | 10          | 5              |          | 242<br>242<br>242<br>242<br>242 |
| POP IX<br>POP IY                                   | DDE1<br>FDE1         | 221 225<br>253 225       | N<br>N | N<br>N | N<br>N | N<br>N | N<br>N | N<br>N | 2<br>2      | 4<br>4      | 14<br>14    | 7<br>7         |          | 244<br>244                      |

FLAG KEY: N - Not affected.

0 - Reset = 0.

1 - Set = 1.

? – Unknown.

Affected according to the result.
 IFF – Content of Interrupt Flip Flop copied into flag.

|                       |                      |         |   |   | FL/ | AGS |   |   | NO.         |             | TIMING      |                |                          |              |
|-----------------------|----------------------|---------|---|---|-----|-----|---|---|-------------|-------------|-------------|----------------|--------------------------|--------------|
| SOURCE<br>CODE        | OBJECT<br>CODE (HEX) | DECIMAL | S | z | н   | P/V | N | с | OF<br>BYTES | M<br>CYCLES | T<br>STATES | μSEC @<br>2MHZ | COMMENTS                 | CH.5<br>REF. |
| EX DE, HL             | EB                   | 235     | N | N | N   | N   | N | N | 1           | 1           | 4           | 2              |                          | 149          |
| EXAF, AF <sup>1</sup> | 08                   | 008     | Ν | N | N   | N   | N | N | 1           | 1           | 4           | 2              |                          | 148          |
| EXX                   | D9                   | 217     | Ν | N | N   | N   | N | Ν | 1           | 1           | 4           | 2              |                          | 154          |
| EX (SP), HL           | E3                   | 227     | Ν | N | N   | N   | N | N | 1           | 5           | 19          | 9.5            |                          | 150          |
| EX (SP), IX           | DD E3                | 221 227 | Ν | N | N   | N   | N | N | 2           | 6           | 23          | 11.5           |                          | 152          |
| EX (SP), IY           | FD E3                | 253 227 | Ν | N | N   | N   | N | N | 2           | 6           | 23          | 11.5           |                          | 152          |
| LDD                   | ED A8                | 237 168 | Ν | N | Ø   | *   | Ø | N | 2           | 4           | 16          | 8              |                          | 217          |
| LDDR                  | ED B8                | 237 184 | Ν | N | 0   | Ø   | Ø | N | 2           | 5           | 21          | 11.5           | If BC ≠ Ø                | 219          |
|                       |                      |         |   |   |     |     |   |   |             | 4           | 16          | 8              | If BC = Ø                |              |
| LDI                   | ED A0                | 237 160 | Ν | N | Ø   | *   | Ø | N | 2           | 4           | 16          | 8              |                          | 221          |
| LDIR                  | ED B0                | 237 176 | Ν | N | Ø   | Ø   | Ø | N | 2           | 5           | 21          | 11.5           | If BC ≠ Ø                | 223          |
|                       |                      |         |   |   |     |     |   |   |             | 4           | 16          | 8              | If BC = Ø                |              |
| CPD                   | ED A9                | 237 169 | * | * | *   | *   | 1 | N | 2           | 4           | 16          | 8              |                          | 129          |
| CPDR                  | ED B9                | 237 185 | * | * | *   | •   | 1 | N | 2           | 5           | 21          | 10.5           | If BC ≠ Øand<br>A ≠ (HL) | 130          |
|                       |                      |         |   |   |     |     |   |   |             | 4           | 16          | 8              | If BC = Ø or A<br>= (HL) |              |
| CPI                   | ED A1                | 237 161 | ٠ | * | *   | *   | 1 | Ν | 2           | 4           | 16          | 8              |                          | 132          |
| CPIR                  | ED B1                | 237 177 | * | * | *   | *   | 1 | Ν | 2           | 5           | 21          | 10.5           | If BC ≠ Øand<br>A ≠ (HL) | 133          |
|                       |                      |         |   |   |     |     |   |   |             | 4           | 16          | 8              | If BC = Ø or A<br>= (HL) |              |

#### EXCHANGE, BLOCK TRANSFER AND SEARCH GROUP TABLE

 $\begin{array}{cccc} \mbox{FLAG KEY:} & \mbox{N} & -\mbox{ Not affected}. & \mbox{1} & -\mbox{SET} = 1. & & \mbox{*} & -\mbox{Affected according to the result.} \\ & \mbox{0} & -\mbox{RESET} = 0. & ? & -\mbox{Unknown.} & & \mbox{IFF} & -\mbox{Content of Interrupt Flip Flop copied into flag.} \\ \end{array}$ 

# SINGLE BYTE (8 BIT) ARITHMETIC GROUP TABLE

|                 |                      |            |   |   | FL/ | AGS |   |   | NO. |             | TIMING      |                |                    |              |
|-----------------|----------------------|------------|---|---|-----|-----|---|---|-----|-------------|-------------|----------------|--------------------|--------------|
| SOURCE<br>CODE  | OBJECT<br>CODE (HEX) | DECIMAL    | S | z | н   | P/V | N | С | OF  | M<br>CYCLES | T<br>STATES | μSEC @<br>2MHZ | COMMENTS           | CH.5<br>REF. |
| ADC A, n        | CEn                  | 206        | * | * | *   | V   | 0 | * | 2   | 2           | 7           | 3.5            | Adds with          | 71           |
| ADC A, r        |                      |            |   | * |     | v   | Ø |   |     |             |             |                | Carry              |              |
| r = A           | 8F                   | 143        |   |   |     | v   | v |   | 1   | 1           | 4           | 2              | Adds with<br>Carry | 73           |
| r = B           | 88                   | 136        |   |   |     |     |   |   |     |             |             |                | Carry              | 74           |
| r = C           | 89                   | 137        |   |   |     |     |   |   |     |             |             |                |                    | 74           |
| r = D           | 8A                   | 138        |   |   |     |     |   |   |     |             |             |                |                    | 74           |
| r = E           | 8B                   | 139        |   |   |     |     |   |   |     |             |             |                |                    | 74           |
| r = H<br>r = L  | 8C<br>8D             | 140<br>141 |   |   |     |     |   |   |     |             |             |                |                    | 74           |
|                 |                      |            |   |   |     |     |   |   |     |             |             |                |                    | 74           |
| ADC A, (HL)     | 8E                   | 142        | * | • | •   | V   | Ø | • | 1   | 2           | 7           | 3.5            |                    | 76           |
| ADC A, (IX + d) | DD 8E d              | 221 142 d  | • | * | *   | V   | Ø | * | 3   | 5           | 19          | 9.5            |                    | 78           |
| ADC A, (IY + d) | FD 8E d              | 253 142 d  | * | * | •   | V   | Ø | * | 3   | 5           | 19          | 9.5            |                    | 78           |
| ADD A, n        | C6 n                 | 198 n      | • | * | ·   | V   | Ø | * | 2   | 2           | 7           | 3.5            |                    | 82           |
| ADD A, r        |                      |            | * | * | •   | V   | Ø | • | 1   | 1           | 4           | 2              |                    |              |
| r = A           | 87                   | 135        |   |   |     |     |   |   |     |             |             |                |                    | 83           |
| r = B           | 80                   | 128        |   |   |     |     |   |   |     |             |             |                |                    | 83           |
| r = C<br>r = D  | 81<br>82             | 129<br>130 |   |   |     |     |   |   |     |             |             |                |                    | 83<br>83     |
| r = E           | 83                   | 131        |   |   |     |     |   |   |     |             |             |                |                    | 83           |
| r = H           | 84                   | 132        |   |   |     |     |   |   |     |             |             |                |                    | 83           |
| r = L           | 85                   | 133        |   |   |     |     |   |   |     |             |             |                |                    | 83           |
| ADD A, (HL)     | 86                   | 134        |   | • | •   | v   | Ø | ٠ | 1   | 2           | 7           | 3.5            |                    | 85           |
| ADD A, (IX + d) | DD 86 d              | 221 134 d  | * | • | •   | V   | Ø | ٠ | 3   | 5           | 19          | 9.5            |                    | 86           |
| ADD A, (IY + D) | FD 86 D              | 253 134 D  | • | • | •   | v   | Ø |   | 3   | 5           | 19          | 9.5            |                    | 86           |
| DECd            |                      |            |   |   |     |     |   |   |     |             |             |                |                    |              |

|                |                      |           |   |   | FL/ | AGS |   |   | NO.         |             | TIMING      |                |               |             |
|----------------|----------------------|-----------|---|---|-----|-----|---|---|-------------|-------------|-------------|----------------|---------------|-------------|
| SOURCE<br>CODE | OBJECT<br>CODE (HEX) | DECIMAL   | S | z | н   | P/V | N | с | OF<br>BYTES | M<br>CYCLES | T<br>STATES | μSEC @<br>2MHZ | COMMENTS      | CH.8<br>REF |
| d = A          | 3D                   | 061       |   |   |     |     |   |   | 1           | 1           | 4           | 2              |               | 138         |
| d = B          | 05                   | 005       |   |   |     |     |   |   | 1           | 1           | 4           | 2              |               | 138         |
| d = C          | OD                   | 013       |   |   |     |     |   |   | 1           | 1           | 4           | 2<br>2         |               | 138         |
| d = D          | 15                   | 021       |   |   |     |     |   |   | 1           | 1           | 4           | 2              |               | 138         |
| d = E          | 1D                   | 029       |   |   |     |     |   |   | 1           | 1           | 4           | 2              |               | 138         |
| d = H          | 25                   | 037       |   |   |     |     |   |   | 1           | 1           | 4           | 2              |               | 138         |
| d = L          | 2D                   | 045       |   |   |     |     |   |   | 1           | 1           | 4           | 2              |               | 138         |
| DEC (HL)       | 35                   | 053       | * | * | •   | V   | 1 | N | 1           | 3           | 11          | 5.5            |               | 140         |
| DEC (IX + d)   | DD 35 d              | 221 053 d | * | * | *   | V   | 1 | N | 3           | 6           | 23          | 11.5           |               | 141         |
| DEC (IY + d)   | FD 35 d              | 253 053 d |   | • | ٠   | V   | 1 | N | 3           | 6           | 23          | 11.5           |               | 141         |
| INCr           |                      |           | * | * | *   | V   | Ø | N | 1           | 1           | 4           | 2              |               |             |
| r = A          | 3C                   | 060       |   |   |     |     | Ū |   | ·           |             |             | -              |               | 162         |
| r = B          | 04                   | 004       |   |   |     |     |   |   |             |             |             |                |               | 162         |
| r = C          | OC                   | 012       |   |   |     |     |   |   |             |             |             |                |               | 162         |
| r = D          | 14                   | 020       |   |   |     |     |   |   |             |             |             |                |               | 162         |
| r = E          | 1C                   | 028       |   |   |     |     |   |   |             |             |             |                |               | 162         |
| r = H          | 24                   | 036       |   |   |     |     |   |   |             |             |             |                |               | 162         |
| r = L          | 2C                   | 044       |   |   |     |     |   |   |             |             |             |                |               | 162         |
| INC (HL)       | 34                   | 052       | * | * | *   | V   | Ø | N | 1           | 3           | 11          | 5.5            |               | 165         |
| INC (IX + d)   | DD 34 d              | 221 052 d | * | * | *   | V   | Ø | N | 3           | 6           | 23          | 11.5           |               | 166         |
| INC (IY + d)   | FD 34 d              | 253 052 d | * | * | *   | V   | Ø | N | 3           | 6           | 23          | 11.5           |               | 166         |
| SBC A, n       | DEn                  | 222 n     | * | * | *   | v   | 1 | * | 2           | 2           | - 7         | 3.5            | Subtract with | 301         |
|                |                      |           |   |   |     |     |   |   |             |             |             | 0.0            | Carry         |             |
| SBC A, r       |                      |           | * | * | *   | V   | 1 | * | 1           | 1           | 4           | 2              | Subtract with |             |
| r = A          | 9F                   | 159       |   |   |     |     |   |   |             |             |             |                | Carry         | 302         |

### SINGLE BYTE (8 BIT) ARITHMETIC GROUP TABLE (cont.)

V 4.

### SINGLE BYTE (8 BIT) ARITHMETIC GROUP TABLE (cont.)

|                                                                           |                                                   |                                                            |   |   | FL/ | AGS    |        |   | NO.         |             | TIMING      |                |          |                                                             |
|---------------------------------------------------------------------------|---------------------------------------------------|------------------------------------------------------------|---|---|-----|--------|--------|---|-------------|-------------|-------------|----------------|----------|-------------------------------------------------------------|
| SOURCE<br>CODE                                                            | OBJECT<br>CODE (HEX)                              | DECIMAL                                                    | S | z | н   | P/V    | N      | с | OF<br>BYTES | M<br>CYCLES | T<br>STATES | μSEC @<br>2MHZ | COMMENTS | CH.5<br>REF.                                                |
| r = B $r = C$ $r = D$ $r = E$ $r = H$ $r = L$ SBC A, (HL) SBC A, (IX + d) | 98<br>99<br>9A<br>9B<br>9C<br>9D<br>9E<br>DD 9E d | 152<br>153<br>154<br>155<br>156<br>157<br>158<br>221 158 d | * | * | *   | v<br>v | 1      | * | 1<br>3      | 2<br>5      | 7<br>19     | 3.5<br>9.5     |          | 303<br>303<br>303<br>303<br>303<br>303<br>303<br>305<br>307 |
| SBC A, (IY + d)<br>SUBn                                                   | FD 9E d<br>D6 n                                   | 253 158 d<br>214 n                                         | * | * | *   |        | 1      | * | 3           | 5<br>2      | 19<br>7     | 9.5<br>3.5     |          | 307<br>334                                                  |
| SUB r<br>r = A<br>r = B<br>r = C<br>r = D<br>r = E<br>r = H<br>r = L      | 97<br>90<br>91<br>92<br>93<br>94<br>95            | 151<br>144<br>145<br>146<br>147<br>148<br>149              | • | * | *   | V      | 1      | * | 1           | 1           | 4           | 2              |          | 336<br>337<br>337<br>337<br>337<br>337<br>337<br>337        |
| SUB (HL)                                                                  | 96                                                | 150                                                        | * | • | *   | V      | 1      | * | 1           | 2           | 7           | 3.5            |          | 339                                                         |
| SUB (IX + d)<br>SUB (IY + d)                                              | DD 96 d<br>FD 96 d                                | 221 150 d<br>253 150 d                                     | * | * | *   |        | 1<br>1 | * | 3<br>3      | 5<br>5      | 19<br>19    | 9.5<br>9.5     |          | 341<br>341                                                  |

FLAG KEY: N - Not affected

P - Contains the Parity of the result (1 = Parity Even)

V - Contains the Overflow of the result (1 = Overflow)

0 - RESET = 0

1 - SET = 1

? – Unknown

\* - Affected according to the result

IFF - Content of Interrupt Flip Flop copied into flag.

|                                                               |                                  |                                          |   |   | FL/ | AGS |   |   | NO.         |             | TIMING      |                |          |                                 |
|---------------------------------------------------------------|----------------------------------|------------------------------------------|---|---|-----|-----|---|---|-------------|-------------|-------------|----------------|----------|---------------------------------|
| SOURCE<br>CODE                                                | OBJECT<br>CODE (HEX)             | DECIMAL                                  | S | z | н   | P/V | N | с | OF<br>BYTES | M<br>CYCLES | T<br>STATES | μSEC @<br>2MHZ | COMMENTS | CH.5<br>REF.                    |
| ADC HL, ss<br>ss = BC<br>ss $\doteq$ DE<br>ss = HL<br>ss = SP | ED 4A<br>ED 5A<br>ED 6A<br>ED 7A | 237 74<br>237 90<br>237 106<br>237 122   | • | * | *   | *   | 0 | • | 2           | 4           | 15          | 7.5            |          | 80<br>80<br>80<br>80            |
| SBC HL, ss<br>ss = BC<br>ss = DE<br>ss = HL<br>ss = SP        | ED 42<br>ED 52<br>ED 62<br>ED 72 | 237 66<br>237 82<br>237 98<br>237 114    | • | * | •   | •   | 1 | • | 2           | 4           | 15          | 7.5            |          | 309<br>309<br>309<br>309<br>309 |
| ADD HL, ss<br>ss = BC<br>ss = DE<br>ss = HL<br>ss = SP        | 09<br>19<br>29<br>39             | 009<br>025<br>041<br>057                 | Ν | Ν | *   | N   | 0 | * | 1           | 3           | 11          | 5.5            |          | 88<br>88<br>88<br>88            |
| ADD IX,pp<br>pp = BC<br>pp = DE<br>pp = IX<br>pp = SP         | DD 09<br>DD 19<br>DD 29<br>DD 39 | 221 009<br>221 025<br>221 041<br>221 057 | Ν | Ν | *   | Ν   | 0 | * | 2           | 4           | 15          | 7.5            |          | 89<br>90<br>91<br>93            |
| ADD IY, rr<br>rr = BC<br>rr = DE<br>rr = IY<br>rr = SP        | FD 09<br>FD 19<br>FD 29<br>FD 39 | 253 009<br>253 025<br>253 041<br>253 057 | Ν | Ν | *   | Ν   | 0 | * | 2           | 4           | 15          | 7.5            |          | 89<br>90<br>92<br>93            |

## TWO BYTE (16 BIT) ARITHMETIC GROUP TABLE

# TWO BYTE (16 BIT) ARITHMETIC GROUP TABLE (cont.)

|                                                                        |                                        |                                                |        |        | FL/    | AGS    |        |          | NO.         |             | TIMING        |                |          |                                        |
|------------------------------------------------------------------------|----------------------------------------|------------------------------------------------|--------|--------|--------|--------|--------|----------|-------------|-------------|---------------|----------------|----------|----------------------------------------|
| SOURCE<br>CODE                                                         | OBJECT<br>CODE (HEX)                   | DECIMAL                                        | S      | z      | н      | P/V    | N      | С        | OF<br>BYTES | M<br>CYCLES | T<br>STATES   | μSEC @<br>2MHZ | COMMENTS | CH.5<br>REF.                           |
| DEC ss<br>ss = BC<br>ss = DE<br>ss = HL<br>ss = SP                     | OB<br>IB<br>2B<br>3B                   | 011<br>027<br>043<br>059                       | N      | N      | Ν      | Ν      | Ν      | Ν        | 1           | 1           | 6             | 3              |          | 143<br>143<br>143<br>143<br>143        |
| DEC IX<br>DEC IY<br>INC ss<br>ss = BC<br>ss = DE<br>ss = HL<br>ss = SP | DD 2B<br>FD 2B<br>03<br>13<br>23<br>33 | 221 043<br>253 043<br>003<br>019<br>035<br>051 | Z Z Z  | Z Z Z  | Z Z Z  | ZZZ    | ZZZ    | Z Z<br>Z | 2<br>2<br>1 | 2<br>2<br>1 | 10<br>10<br>6 | 5<br>5<br>3    |          | 144<br>144<br>164<br>164<br>164<br>164 |
| INCIX<br>INCIY                                                         | DD 23<br>FD 23                         | 221 035<br>253 035                             | N<br>N | N<br>N | N<br>N | N<br>N | N<br>N | N<br>N   | 2<br>2      | 2<br>2      | 10<br>10      | 5<br>5         |          | 168<br>168                             |

FLAG KEY: N - Not affected.

0 - Reset = 0.

1 - Set = 1.

? – Unknown.

\* - Affected according to the result.

#### LOGICAL GROUP TABLE

|                |                      |           |   |   | FL/ | AGS |   |   | NO. |             | TIMING      |                |          |              |
|----------------|----------------------|-----------|---|---|-----|-----|---|---|-----|-------------|-------------|----------------|----------|--------------|
| SOURCE<br>CODE | OBJECT<br>CODE (HEX) | DECIMAL   | S | z | н   | P/V | N | С | OF  | M<br>CYCLES | T<br>STATES | μSEC @<br>2MHZ | COMMENTS | CH.5<br>REF. |
| ANDn           | E6n                  | 230 n     | • | * | 1   | Р   | Ø | 0 | 2   | 2           | 7           | 3.5            |          | 94           |
| ANDr           |                      |           | * | * | 1   | Р   | Ø | 0 | 1   | 1           | 4           | 2              |          |              |
| r = A          | A7                   | 167       |   |   |     |     |   |   |     |             |             |                |          | 95           |
| r = B          | AO                   | 160       |   |   |     |     |   |   |     |             |             |                |          | 95           |
| r = C          | A1                   | 161       |   |   |     |     |   |   |     |             |             |                |          | 95           |
| r = D          | A2                   | 162       |   |   |     |     |   |   |     |             |             |                |          | 95           |
| r = E          | A3                   | 163       |   |   |     |     |   |   |     |             |             |                |          | 95           |
| r = H          | A4                   | 164       |   |   |     |     |   |   |     |             |             |                |          | 95<br>95     |
| r = L          | A5                   | 165       |   |   |     |     |   |   |     |             |             |                |          |              |
| AND (HL)       | A6                   | 166       | ٠ |   | 1   | P   | 0 | 0 | 1   | 2           | 7           | 3.5            |          | 98           |
| AND (IX + d)   | DD A6 d              | 221 166 d | * | * | 1   | Р   | 0 | Ø | 3   | 5           | 19          | 9.5            |          | 99           |
| AND $(IY + d)$ | FD A6 d              | 253 166 d | ٠ |   | 1   | Р   | 0 | Ø | 3   | 5           | 19          | 9.5            |          | 99           |
| CP n           | FEn                  | n         | * | * | *   | v   | 1 | * | 2   | 2           | 7           | 3.5            |          | 122          |
| CPr            | 1.5.                 |           |   | * | *   | v   | 1 | * | 1   | 1           | 4           | 2              |          |              |
| r = A          | BF                   | 181       |   |   |     |     |   |   |     |             |             |                |          | 123          |
| r = B          | B8                   | 184       |   |   |     |     |   |   |     |             |             |                |          | 124          |
| r = C          | B9                   | 185       |   |   |     |     |   |   |     |             |             |                |          | 124          |
| r = D          | BA                   | 186       |   |   |     |     |   |   |     |             |             |                |          | 124          |
| r = E          | BB                   | 187       |   |   |     |     |   |   |     |             |             |                |          | 124          |
| r = H          | BC                   | 188       |   |   |     |     |   |   |     |             |             |                |          | 124          |
| r = L          | BD                   | 189       |   |   |     |     |   |   |     |             |             |                |          | 124          |
| CP (HL)        | BE                   | 190       | * | * | *   | V   | 1 | * | 1   | 2           | 7           | 3.5            |          | 126          |
| CP (IX + d)    | DD BE d              | 221 190 d | * | * | *   | V   | 1 | * | 3   | 5           | 19          | 9.5            |          | 127          |
| CP (IY + d)    | FD BE d              | 253 190 d | ٠ | * | •   | V   | 1 | * | 3   | 5           | 19          | 9.5            |          | 127          |

## LOGICAL GROUP TABLE (cont.)

|              |                 |               |          |        | FL/      | AGS  |   |       | NO.      |        | TIMING  |            |                   |      |
|--------------|-----------------|---------------|----------|--------|----------|------|---|-------|----------|--------|---------|------------|-------------------|------|
| SOURCE       | OBJECT          |               |          | _      |          |      |   |       | OF       | M      | T       | μSEC @     |                   | CH.5 |
| CODE         | CODE (HEX)      |               | S        | Z      | н        | P/V  | N | С     | BYTES    | CYCLES | STATES  | 2MHZ       | COMMENTS          | REF. |
| ORn          | F6 n            | 246 n         | *        | *      | 1        | P    | Ø | 0     | 2        | 2      | 7       | 3.5        |                   | 227  |
| ORr          |                 |               | •        | *      | 1        | Р    | Ø | 0     | 1        | 1      | 4       | 2          |                   |      |
| r = A        | B7              | 183           |          |        |          |      |   |       |          |        |         |            |                   | 229  |
| r = B        | BO              | 176           |          |        |          |      |   |       |          |        |         |            |                   | 229  |
| r = C        | B1              | 177           |          |        |          |      |   |       |          |        |         |            |                   | 229  |
| r = D        | B2              | 178           |          |        |          |      |   |       |          |        |         |            |                   | 229  |
| r = E        | B3              | 179           |          |        |          |      |   |       |          |        |         |            |                   | 229  |
| r = H        | B4              | 180           |          |        |          |      |   |       |          | -      |         |            |                   | 229  |
| r = L        | B5              | 181           |          |        |          |      |   |       |          |        |         |            |                   | 229  |
| OR (HL)      | B6              | 182           | •        | *      | 1        | Р    | Ø | 0     | 1        | 2      | 7       | 3.5        |                   | 231  |
| OR (IX + d)  | DD B6 d         | 221 182 d     | *        | *      | 1        | P    | Ø | 0     | 3        | 5      | 19      | 9.5        |                   | 233  |
| OR (IY + d)  | FD B6 d         | 253 182 d     | ٠        | *      | 1        | Р    | Ø | 0     | 3        | 5      | 19      | 9.5        |                   | 233  |
| XORn         | EEn             | 238 n         | ٠        | *      | 1        | Р    | Ø | 0     | 2        | 2      | 7       | 3.5        |                   | 343  |
| XORr         |                 |               | •        | *      | 1        | Р    | Ø | Ø     | 1        | 1      | 4       | 2          |                   |      |
| r = A        | AF              | 175           |          |        |          |      |   |       |          |        |         |            |                   | 345  |
| r = B        | A8              | 168           |          |        |          |      |   |       |          |        |         |            |                   | 347  |
| r = C        | A9              | 169           |          |        |          |      |   |       |          |        |         |            |                   | 347  |
| r = D        | AA              | 170           |          |        |          |      |   |       |          |        |         |            |                   | 347  |
| r = E        | AB              | 171           |          |        |          |      |   |       |          |        |         |            |                   | 347  |
| r = H        | AC              | 172           |          |        |          |      |   |       |          |        |         |            |                   | 347  |
| r = L        | AD              | 173           |          |        |          |      |   |       |          |        |         |            |                   | 347  |
| XOR (HL)     | AE              | 174           | *        | *      | 1        | P    | Ø | 0     | 1        | 2      | 7       | 3.5        |                   | 349  |
| XOR (IX + d) | DD AE d         | 221 174 d     | ٠        | *      | 1        | P    | Ø | 0     | 3        | 5      | 19      | 9.5        |                   | 351  |
| XOR (IY + d) | FD AE d         | 253 174 d     | ٠        | *      | 1        | Р    | Ø | Ø     | 3        | 5      | 19      | 9.5        |                   | 351  |
| FLAG KEY: N  | - Not affected. |               |          |        |          |      | Ø |       | SET = Ø. | *      | - Affec | ted accord | ding to the resul | t.   |
| Р            | - Contains the  | Parity of the | result ( | 1 = Pa | rity Eve | en). | 1 | – SET | = 1.     |        |         |            |                   |      |

Contains the Parity of the result (1 = Parity Even).
Contains the Overflow of the result (1 = Overflow). V

? – Unknown.

374

|        |            |         |   |   | FLA | AGS |   |   | NO.   |        | TIMING |        |          |      |
|--------|------------|---------|---|---|-----|-----|---|---|-------|--------|--------|--------|----------|------|
| SOURCE | OBJECT     |         |   |   |     |     |   |   | OF    | М      | Т      | μSEC @ |          | CH.5 |
| CODE   | CODE (HEX) | DECIMAL | S | Z | н   | P/V | Ν | С | BYTES | CYCLES | STATES | 2MHZ   | COMMENTS | REF. |
| CCF    | ЗF         | 063     | Ν | Ν | ?   | N   | 0 | * | 1     | 1      | 4      | 2      |          | 121  |
| CPL    | 2F         | 047     | Ν | Ν | 1   | N   | 1 | Ν | 1     | 1      | 4      | 2      |          | 135  |
| DAA    | 27         | 039     | * | * | ٠   | Р   | Ν | ٠ | 1     | 1      | 4      | 2      |          | 136  |
| DI     | F3         | 243     | Ν | Ν | Ν   | N   | Ν | Ν | 1     | 1      | 4      | 2      |          | 145  |
| EI     | FB         | 251     | Ν | Ν | Ν   | N   | Ν | Ν | 1     | 1      | 4      | 2      |          | 147  |
| HALT   | 76         | 118     | Ν | Ν | Ν   | N   | Ν | Ν | 1     | 1      | 4      | 2      |          | 155  |
| IMØ    | ED46       | 237 070 | Ν | Ν | Ν   | N   | Ν | Ν | 2     | 2      | 8      | 4      |          | 156  |
| IM 1   | ED 56      | 237 086 | Ν | Ν | Ν   | N   | Ν | Ν | 2     | 2      | 8      | 4      |          | 157  |
| IM 2   | ED 5E      | 237 094 | Ν | Ν | Ν   | N   | Ν | Ν | 2     | 2      | 8      | 4      |          | 158  |
| NEG    | ED44       | 237 068 | * | * | ٠   | V   | 1 | * | 2     | 2      | 8      | 4      |          | 225  |
| NOP    | 00         | 000     | Ν | Ν | Ν   | N   | Ν | Ν | 1     | 1      | 4      | 2      |          | 226  |
| SCF    | 37         | 055     | * | * | Ø   | *   | Ø | 1 | 1     | 1      | 4      | 2      |          | 311  |

#### GENERAL PURPOSE ARITHMETIC AND C.P.U. CONTROL GROUP TABLE

FLAG KEY: N - Not affected.

P - Contains the Parity of the result (1 = Parity Even).

V - Contains the Overflow of the result (1 = Overflow).

 $\emptyset$  - RESET =  $\emptyset$ .

1 – SET = 1.

? – Unknown.

\* - Affected according to the result.

375

#### **ROTATE AND SHIFT GROUP TABLE**

|                                                                                                                     |                                                             |                                                                                                                               |             |             | FL               | AGS              |                  |       | NO.              |                  | TIMING                   |                               |          |                                                                                  |
|---------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------|-------------|-------------|------------------|------------------|------------------|-------|------------------|------------------|--------------------------|-------------------------------|----------|----------------------------------------------------------------------------------|
| SOURCE<br>CODE                                                                                                      | OBJECT<br>CODE (HEX)                                        | DECIMAL                                                                                                                       | S           | z           | н                | P/V              | N                | с     | OF<br>BYTES      | M<br>CYCLES      | T<br>STATES              | μSEC @<br>2MHZ                | COMMENTS | CH.5<br>REF.                                                                     |
| RLr<br>r = A<br>r = B<br>r = C<br>r = D<br>r = E<br>r = H<br>r = L                                                  | CB 17<br>CB 10<br>CB 11<br>CB 12<br>CB 13<br>CB 14<br>CB 15 | 203 023<br>203 016<br>203 017<br>203 018<br>203 019<br>203 020<br>203 021                                                     | *           | *           | Ø                | P                | 0                | *     | 2                | 2                | 8                        | 4                             |          | 263<br>263<br>263<br>263<br>263<br>263<br>263<br>263                             |
| RLA<br>RL (HL)<br>RL (IX + d)<br>RL (IY + d)<br>RLCr<br>r = A<br>r = B<br>r = C<br>r = D<br>r = E<br>r = H<br>r = L |                                                             | 023<br>203 022<br>221 203 d 022<br>253 203 d 022<br>203 007<br>203 000<br>203 001<br>203 002<br>203 003<br>203 004<br>203 005 | N<br>*<br>* | N<br>•<br>• | 0<br>0<br>0<br>0 | N<br>P<br>P<br>P | 0<br>0<br>0<br>0 | *     | 1<br>2<br>4<br>2 | 1<br>4<br>6<br>2 | 4<br>15<br>23<br>23<br>8 | 2<br>7.5<br>11.5<br>11.5<br>4 |          | 269<br>265<br>267<br>267<br>271<br>271<br>271<br>271<br>271<br>271<br>271<br>271 |
| RLCA<br>RLC (HL)<br>RLC (IX + d)<br>RLC (IY + d)                                                                    |                                                             | 07<br>203 006<br>221 203 d 006<br>253 203 d 006                                                                               | N<br>*<br>* | N<br>*<br>* | 0<br>Ø<br>Ø<br>Ø | N<br>P<br>P      | 0<br>Ø<br>Ø      | * * * | 1<br>2<br>4<br>4 | 1<br>4<br>6<br>6 | 4<br>15<br>23<br>23      | 2<br>7.5<br>11.5<br>11.5      |          | 277<br>273<br>275<br>275                                                         |

# ROTATE AND SHIFT GROUP TABLE (cont.)

|                |                      |                    |   |   | FLA | AGS |   |   | NO. |             | TIMING      |                |          |              |
|----------------|----------------------|--------------------|---|---|-----|-----|---|---|-----|-------------|-------------|----------------|----------|--------------|
| SOURCE<br>CODE | OBJECT<br>CODE (HEX) | DECIMAL            | s | z | н   | P/V | N | С | OF  | M<br>CYCLES | T<br>STATES | μSEC @<br>2MHZ | COMMENTS | CH.5<br>REF. |
| RLD            | ED6F                 | 237 1 1 1          | * | * | Ø   | Р   | Ø | Ν | 2   | 5           | 18          | 9              |          | 279          |
| RRr            |                      |                    | * | * | Ø   | P   | Ø | * | 2   | 2           | 8           | 4              |          |              |
| r = A          | CB1F                 | 203 03 1           |   |   |     |     |   |   |     |             |             |                |          | 281          |
| r = B          | CB 18                | 203 024            |   |   |     |     |   |   |     |             |             |                |          | 281          |
| r = C<br>r = D | CB19<br>CB1A         | 203 025<br>203 026 |   |   |     |     |   |   |     |             |             |                |          | 281<br>281   |
| r = D          | CB1A<br>CB1B         | 203 020            |   |   |     |     |   |   |     |             |             |                |          | 281          |
| r = H          | CB 1C                | 203 028            |   |   |     |     |   |   |     |             |             |                |          | 281          |
| r = L          | CB1D                 | 203 029            |   |   |     |     |   |   |     |             |             |                |          | 281          |
| RRA            | 1F                   | 31                 | Ν | N | 0   | N   | 0 | • | 1   | 1           | 4           | 2              |          | 287          |
| RR (HL)        | CB 1E                | 203 030            | * | * | Ø   | Р   | Ø | * | 2   | 4           | 15          | 7.5            |          | 283          |
| RR(IX + d)     | DD CB d IE           | 221 203 d 030      | * | * | Ø   | Р   | 0 | * | 4   | 6           | 23          | 11.5           |          | 285          |
| RR (IY + d)    | FD CB d IE           | 253 203 d 030      | ٠ | * | Ø   | P   | 0 | • | 4   | 6           | 23          | 11.5           |          | 285          |
| RRCr           |                      |                    | * | * | Ø   | P   | Ø | • | 2   | 2           | 8           | 4              |          |              |
| r = A          | CBOF                 | 203015             |   |   |     |     |   |   |     |             |             |                |          | 289          |
| r = B          | CB 08                | 203 008            |   |   |     |     |   |   |     |             |             |                |          | 289<br>289   |
| r = C<br>r = D | CB09<br>CB0A         | 203009<br>203010   |   |   |     |     |   |   |     |             |             |                |          | 289          |
| r = D          | CBOR                 | 203010             |   |   |     |     |   |   |     |             |             |                |          | 289          |
| r = H          | CBOC                 | 203 0 1 2          |   |   |     |     |   |   |     |             |             |                |          | 289          |
| r = L          | CBOD                 | 203 0 1 3          |   |   |     |     |   |   |     |             |             |                |          | 289          |
| RRCA           | 0F                   | 15                 | N | N | 0   | N   | 0 | • | 1   | 1           | 4           | 2              |          | 295          |
| RRC (HL)       | CBOE                 | 203014             | * | • | 0   | P   | Ø | * | 2   | 4           | 15          | 7.5            |          | 291          |
|                | DD CB dOE            | 221 203 d 014      | * | • | 0   | Р   | Ø | * | 4   | 6           | 23          | 11.5           |          | 293          |
| RRC (IY + d)   | FD CB d 0E           | 253 203 d 014      | * | * | 0   | P   | Ø | * | 4   | 6           | 23          | 11.5           |          | 293          |

## ROTATE AND SHIFT GROUP TABLE (cont.)

|                |                      |               |   |   | FL/ | AGS |   |   | NO. |             | TIMING |                |          |              |
|----------------|----------------------|---------------|---|---|-----|-----|---|---|-----|-------------|--------|----------------|----------|--------------|
| SOURCE<br>CODE | OBJECT<br>CODE (HEX) | DECIMAL       | S | z | н   | P/V | N | с | OF  | M<br>CYCLES | T      | μSEC @<br>2MHZ | COMMENTS | CH.5<br>REF. |
| RRD            | ED67                 | 237 103       | * | * | Ø   | P   | 0 | N | 2   | 5           | 18     | 9              | COMMENTS | 297          |
| SLAr           | 2007                 | 207 100       | * |   | Ø   | P   | 0 |   | 2   |             |        | -              |          | 297          |
| r = A          | CB27                 | 203 039       |   |   | v   | Р   | Ø |   | 2   | 2           | 8      | 4              |          | 316          |
| r = B          | CB 20                | 203 032       |   |   |     |     |   |   |     |             |        |                |          | 316          |
| r = C          | CB21                 | 203 033       |   | 1 |     |     |   |   |     |             |        |                |          | 316          |
| r = D          | CB22                 | 203 034       |   |   |     |     |   |   |     |             |        |                |          | 316          |
| r = E          | CB 23                | 203 035       |   |   |     |     |   |   |     |             |        |                |          | 316          |
| r = H          | CB24                 | 203 036       |   |   |     |     |   |   |     |             |        |                |          | 316          |
| r = L          | CB 25                | 203 037       |   |   |     |     |   |   |     |             |        |                |          | 316          |
| SLA (HL)       | CB 26                | 203 038       | * | * | Ø   | Р   | Ø | • | 2   | 4           | 15     | 7.5            |          | 318          |
| SLA (IY + d)   | FD CB d 26           | 253 203 d 038 | * | * | Ø   | Р   | Ø | • | 4   | 6           | 23     | 11.5           |          |              |
| SRA r          |                      |               | * | * | Ø   | Р   | Ø | • | 2   | 2           | 8      | 4              |          |              |
| r = A          | CB2F                 | 203 047       |   |   |     |     |   |   |     |             |        |                |          | 322          |
| r = B          | CB 28                | 203 040       |   |   |     |     |   |   |     |             |        |                |          | 322          |
| r = C          | CB 29                | 203 04 1      |   |   |     |     |   |   |     |             |        |                |          | 322          |
| r = D          | CB2A                 | 203042        |   |   |     |     |   |   |     |             |        |                |          | 322          |
| r = E          | CB2B                 | 203 0 4 3     |   |   |     |     |   |   |     |             |        |                |          | 322          |
| r = H          | CB2C                 | 203 0 4 4     |   |   |     |     |   |   |     |             |        |                |          | 322          |
| r = L          | CB 2D                | 203 045       |   |   |     |     |   |   |     |             |        |                |          | 322          |
| SRA (HL)       | CB2E                 | 203 046       | • | * | Ø   | Р   | Ø | * | 2   | 4           | 15     | 7.5            |          | 324          |
| SRA (IX + d)   | DD CBd 2E            | 221 203 d 046 | • | * | Ø   | Р   | Ø | * | 4   | 6           | 23     | 11.5           |          | 326          |
| SRA (IY + d)   | FD CBd 2E            | 253 203 d 046 | * | * | Ø   | Р   | Ø | * | 4   | 6           | 23     | 11.5           |          | 326          |
| SRLr           |                      |               | * | * | Ø   | Р   | Ø | * | 2   | 2           | 8      | 4              |          |              |
| r = A          | CB3F                 | 203 063       |   |   | -   |     | - |   | -   | -           | 5      |                |          | 328          |
| r = B          | CB 38                | 203 056       |   |   |     |     |   |   |     |             |        |                |          | 328          |
| r = C          | CB 39                | 203 057       |   |   |     |     |   |   |     |             |        |                |          | 328          |

#### ROTATE AND SHIFT GROUP TABLE (cont.)

|                                          |                              |                                           |     |     | FL/         | AGS         |             |       | NO.         |             | TIMING         |                     |          |                                 |
|------------------------------------------|------------------------------|-------------------------------------------|-----|-----|-------------|-------------|-------------|-------|-------------|-------------|----------------|---------------------|----------|---------------------------------|
| SOURCE<br>CODE                           | OBJEC<br>CODE (H             | CT<br>IEX) DECIMAL                        | S   | z   | н           | P/V         | N           | с     | OF<br>BYTES | M<br>CYCLES | T<br>STATES    | μSEC @<br>2MHZ      | COMMENTS | CH.5<br>REF.                    |
| r = D<br>r = E<br>r = H<br>r = L         | CB3A<br>CB3B<br>CB3C<br>CB3D | 203 058<br>203 059<br>203 060<br>203 061  |     |     |             |             |             |       |             |             |                |                     |          | 328<br>328<br>328<br>328<br>328 |
| SRL (HL)<br>SRL (IX + d)<br>SRL (IY + d) |                              | 203 062<br>221 203 d 062<br>253 203 d 062 | * * | * * | 0<br>0<br>0 | P<br>P<br>P | 0<br>0<br>0 | * * * | 2<br>4<br>4 | 4<br>6<br>6 | 15<br>23<br>23 | 7.5<br>11.5<br>11.5 |          | 330<br>332<br>332               |

FLAG KEY: N - Not affected.

P – Contains the Parity of the result (1 = Parity Even).

V – Contains the Overflow of the result (1 = Overflow).

 $\emptyset$  - RESET =  $\emptyset$ .

1 - SET = 1.

? – Unknown.

\* - Affected according to the result.

|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                         |                                                                                                                                                                              |   |   | FL/ | AGS |   |   | NO.         |             | TIMING      |                |          |                                                                    |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|-----|-----|---|---|-------------|-------------|-------------|----------------|----------|--------------------------------------------------------------------|
| SOURCE<br>CODE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | OBJECT<br>CODE (HEX)                                                                                                                                                    | DECIMAL                                                                                                                                                                      | s | z | н   | P/V | N | с | OF<br>BYTES | M<br>CYCLES | T<br>STATES | μSEC @<br>2MHZ | COMMENTS | CH.5<br>REF.                                                       |
| BIT b, r r = A, b = 0 b = 1 b = 2 b = 3 b = 4 b = 5 b = 6 b = 7 r = B, b = 0 b = 3 b = 4 b = 2 b = 3 b = 4 b = 2 c = 1 c = 1 c = 2 c = 1 c = 2 c = 1 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = 2 c = | CB 47<br>CB 4F<br>CB 57<br>CB 5F<br>CB 67<br>CB 6F<br>CB 77<br>CB 7F<br>CB 40<br>CB 48<br>CB 50<br>CB 58<br>CB 50<br>CB 58<br>CB 60<br>CB 68<br>CB 70<br>CB 78<br>CB 41 | 203 071<br>203 079<br>203 087<br>203 095<br>203 103<br>203 111<br>203 119<br>203 127<br>203 064<br>203 072<br>203 080<br>203 088<br>203 096<br>203 104<br>203 120<br>203 265 | ? | * | 1   | ?   | 0 | N | 2           | 2           | 8           | 4              |          | 101<br>101<br>101<br>101<br>101<br>101<br>101<br>101<br>101<br>101 |
| r = C, b = 0  b = 1  b = 2  b = 3  b = 4  b = 5  b = 6  b = 7  r = D, b = 0  b = 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | CB 41<br>CB 49<br>CB 51<br>CB 59<br>CB 61<br>CB 69<br>CB 71<br>CB 79<br>CB 42<br>CB 4A                                                                                  | 203 065<br>203 073<br>203 081<br>203 089<br>203 097<br>203 105<br>203 113<br>203 121<br>203 066<br>203 074                                                                   |   |   |     |     |   |   |             |             |             |                |          | 101<br>101<br>101<br>101<br>101<br>101<br>101<br>101<br>101<br>101 |

|                                                                                     |                                                                      |                                                                                      |   |   | FL/ | AGS |   |   | NO.         |             | TIMING      |                |          |                                                      |
|-------------------------------------------------------------------------------------|----------------------------------------------------------------------|--------------------------------------------------------------------------------------|---|---|-----|-----|---|---|-------------|-------------|-------------|----------------|----------|------------------------------------------------------|
| SOURCE<br>CODE                                                                      | OBJECT<br>CODE (HEX)                                                 | DECIMAL                                                                              | s | z | н   | P/V | N | с | OF<br>BYTES | M<br>CYCLES | T<br>STATES | μSEC @<br>2MHZ | COMMENTS | CH.5<br>REF.                                         |
| b = 2<br>b = 3<br>b = 4<br>b = 5<br>b = 6<br>b = 7                                  | CB 52<br>CB 5A<br>CB 62<br>CB 6A<br>CB 72<br>CB 7A                   | 203 082<br>203 090<br>203 098<br>203 106<br>203 114<br>203 112                       |   |   |     |     |   |   |             |             |             |                |          | 101<br>101<br>101<br>101<br>101<br>101               |
| r = E, b = 0  b = 1  b = 2  b = 3  b = 4  b = 5  b = 6  b = 7                       | CB 43<br>CB 4B<br>CB 53<br>CB 5B<br>CB 63<br>CB 6B<br>CB 73<br>CB 7B | 203 067<br>203 075<br>203 083<br>203 091<br>203 099<br>203 107<br>203 115<br>203 123 |   |   |     |     |   |   |             |             |             |                |          | 101<br>101<br>101<br>101<br>101<br>101<br>101<br>101 |
|                                                                                     | CB 44<br>CB 4C<br>CB 54<br>CB 5C<br>CB 64<br>CB 6C<br>CB 74<br>CB 7C | 203 068<br>203 076<br>203 084<br>203 092<br>203 100<br>203 108<br>203 116<br>203 124 |   |   |     |     |   |   |             |             |             |                |          | 101<br>101<br>101<br>101<br>101<br>101<br>101<br>101 |
| $ \begin{array}{c} r = L, \ b = 0 \\ b = 1 \\ b = 2 \\ b = 3 \\ b = 4 \end{array} $ | CB 45<br>CB 4D<br>CB 55<br>CB 5D<br>CB 65                            | 203 069<br>203 077<br>203 085<br>203 093<br>203 101                                  |   |   |     |     |   |   |             |             |             |                |          | 101<br>101<br>101<br>101<br>101                      |

|                                                                     |                                                                      |                                                                                      |   |   | FL/ | AGS |   |   | NO.         |             | TIMING      |                |          |                                                      |
|---------------------------------------------------------------------|----------------------------------------------------------------------|--------------------------------------------------------------------------------------|---|---|-----|-----|---|---|-------------|-------------|-------------|----------------|----------|------------------------------------------------------|
| SOURCE<br>CODE                                                      | OBJECT<br>CODE (HEX)                                                 | DECIMAL                                                                              | S | z | н   | P/V | N | с | OF<br>BYTES | M<br>CYCLES | T<br>STATES | μSEC @<br>2MHZ | COMMENTS | CH.5<br>REF.                                         |
| b = 5<br>b = 6<br>b = 7                                             | CB6D<br>CB75<br>CB7D                                                 | 203 109<br>203 117<br>203 125                                                        |   |   |     |     |   |   |             |             |             |                |          | 101<br>101<br>101                                    |
| BIT b, (HL)  b = 0  b = 1  b = 2  b = 3  b = 4  b = 5  b = 6  b = 7 | CB 46<br>CB 4E<br>CB 56<br>CB 5E<br>CB 66<br>CB 6E<br>CB 76<br>CB 7E | 203 070<br>203 078<br>203 086<br>203 094<br>203 102<br>203 110<br>203 118<br>203 126 | ? | • | 1   | ?   | Ø | N | 2           | 3           | 12          | 6              |          | 103<br>103<br>103<br>103<br>103<br>103<br>103<br>103 |
| BIT b, (IX + D) b = 0 b = 1 b = 2 b = 3 b = 4 b = 5 b = 6 b = 7     | DD CB d 46<br>DD CB d 4E<br>DD CB d 56<br>DD CA d 5E<br>DD CB d 66   | -                                                                                    | ? |   | 1   | ?   | Ø | N | 4           | 5           | 20          | 10             |          | 105<br>105<br>105<br>105<br>105<br>105<br>105<br>105 |
| BIT b, (IY + D) b = 0 b = 1 b = 2 b = 3 b = 4                       | FDCBd46<br>FDCBd4E<br>FDCBd56<br>FDCBd5E                             | 253 203 d 078<br>253 203 d 086                                                       | ? | * | 1   | ?   | Ø | N | 4           | 5           | 20          | 10             |          | 105<br>105<br>105<br>105<br>105                      |

|                                                                      |                                                                                                                                      |                                                                                                                                         |   |   | FLA | AGS |   |   | NO.         |             | TIMING      |                |          |                                                                                  |
|----------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------|---|---|-----|-----|---|---|-------------|-------------|-------------|----------------|----------|----------------------------------------------------------------------------------|
| SOURCE<br>CODE                                                       | OBJECT<br>CODE (HEX)                                                                                                                 | DECIMAL                                                                                                                                 | s | z | н   | P/V | N | с | OF<br>BYTES | M<br>CYCLES | T<br>STATES | μSEC @<br>2MHZ | COMMENTS | CH.5<br>REF.                                                                     |
| b = 5b = 6b = 7RESb,rr = A, b = 0b = 1b = 2b = 3b = 4b = 5b = 6b = 7 | FD CB d 6E<br>FD CB d 76<br>FD CB d 76<br>FD CB d 7E<br>CB 87<br>CB 8F<br>CB 97<br>CB 9F<br>CB A7<br>CB AF<br>CB AF<br>CB B<br>CB BF | 253 203 d 110<br>253 203 d 118<br>253 203 d 126<br>203 135<br>203 143<br>203 151<br>203 159<br>203 167<br>203 175<br>203 183<br>203 191 | Ν | Ν | N   | N   | N | N | 2           | 2           | 8           | 4              |          | 105<br>105<br>105<br>250<br>250<br>250<br>250<br>250<br>250<br>250<br>250<br>250 |
| r = B, b = 0  b = 1  b = 2  b = 3  b = 4  b = 5  b = 6  b = 7        | CB 80<br>CB 88<br>CB 90<br>CB 98<br>CB AO<br>CB A8<br>CB BO<br>CB B8                                                                 | 203 128<br>203 136<br>203 144<br>203 152<br>203 160<br>203 168<br>203 176<br>203 184                                                    |   |   |     |     |   |   |             |             |             |                |          | 250<br>250<br>250<br>250<br>250<br>250<br>250<br>250                             |
| r = C, b = 0  b = 1  b = 2  b = 3  b = 4  b = 5  b = 6  b = 7        | CB 81<br>CB 89<br>CB 91<br>CB 99<br>CB A1<br>CB A9<br>CB B1<br>CB B9                                                                 | 203 129<br>203 137<br>203 145<br>203 153<br>203 161<br>203 169<br>203 177<br>203 185                                                    |   |   |     |     |   |   |             |             |             |                |          | 250<br>250<br>250<br>250<br>250<br>250<br>250<br>250                             |

|                                                                             |                                                                      |                                                                                      |   |   | FL/ | AGS | _ |   | NO.         |             | TIMING      |                |          |                                                      |
|-----------------------------------------------------------------------------|----------------------------------------------------------------------|--------------------------------------------------------------------------------------|---|---|-----|-----|---|---|-------------|-------------|-------------|----------------|----------|------------------------------------------------------|
| SOURCE<br>CODE                                                              | OBJECT<br>CODE (HEX)                                                 | DECIMAL                                                                              | S | z | н   | P/V | N | С | OF<br>BYTES | M<br>CYCLES | T<br>STATES | μSEC @<br>2MHZ | COMMENTS | CH.5<br>REF.                                         |
| r = D, b = 0<br>b = 1<br>b = 2<br>b = 3<br>b = 4<br>b = 5<br>b = 6<br>b = 7 | CB 82<br>CB 8A<br>CB 92<br>CB 9A<br>CB A2<br>CB AA<br>CB B2<br>CB BA | 203 130<br>203 138<br>203 146<br>203 154<br>203 162<br>203 170<br>203 178<br>203 186 |   |   |     |     |   |   |             |             |             |                |          | 250<br>250<br>250<br>250<br>250<br>250<br>250<br>250 |
| r = E, b = 0<br>b = 1<br>b = 2<br>b = 3<br>b = 4<br>b = 5<br>b = 6<br>b = 7 | CB 83<br>CB 88<br>CB 93<br>CB 98<br>CB A3<br>CB A8<br>CB B3<br>CB B8 | 203 131<br>203 139<br>203 147<br>203 155<br>203 163<br>203 171<br>203 179<br>203 187 |   |   |     |     |   |   |             |             |             |                |          | 250<br>250<br>250<br>250<br>250<br>250<br>250<br>250 |
| r = H, b = 0<br>b = 1<br>b = 2<br>b = 3<br>b = 4<br>b = 5<br>b = 6<br>b = 7 | CB 84<br>CB 8C<br>CB 94<br>CB 9C<br>CB A4<br>CB AC<br>CB B4<br>CB BC | 203 132<br>203 140<br>203 148<br>203 156<br>203 164<br>203 172<br>203 180<br>203 188 |   |   |     |     |   |   |             |             |             |                |          | 250<br>250<br>250<br>250<br>250<br>250<br>250<br>250 |
| r = L, b = 0<br>b = 1<br>b = 2                                              | CB 85<br>CB 8D<br>CB 95                                              | 203 133<br>203 141<br>203 149                                                        |   |   |     |     |   |   |             |             |             |                |          | 250<br>250<br>250                                    |

|                                                                                                                           |                                                                                                              |                                                                                      |   |   | FL/ | AGS |   |   | NO. |             | TIMING      |                |          |                                                                    |
|---------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------|---|---|-----|-----|---|---|-----|-------------|-------------|----------------|----------|--------------------------------------------------------------------|
| SOURCE<br>CODE                                                                                                            | OBJECT<br>CODE (HEX)                                                                                         | DECIMAL                                                                              | S | z | н   | P/V | N | с | OF  | M<br>CYCLES | T<br>STATES | μSEC @<br>2MHZ | COMMENTS | CH.5<br>REF.                                                       |
| b = 3<br>b = 4<br>b = 5<br>b = 6<br>b = 7                                                                                 | CB 9D<br>CB A5<br>CB AD<br>CB B5<br>CB BD                                                                    | 203 157<br>203 165<br>203 173<br>203 181<br>203 189                                  |   |   |     |     |   |   |     |             |             |                |          | 250<br>250<br>250<br>250<br>250<br>250                             |
| $\begin{array}{c} \text{RES b, (HL)} \\ b = 0 \\ b = 1 \\ b = 2 \\ b = 3 \\ b = 4 \\ b = 5 \\ b = 6 \\ b = 7 \end{array}$ | CB 86<br>CB 8E<br>CB 96<br>CB 9E<br>CB A6<br>CB AE<br>CB B6<br>CB BE                                         | 203 134<br>203 142<br>203 150<br>203 158<br>203 166<br>203 174<br>203 182<br>203 190 | Ν | Ν | Ν   | Ν   | Ν | Ν | 2   | 4           | 15          | 7.5            |          | 251<br>251<br>251<br>251<br>251<br>251<br>251<br>251<br>251        |
| RES b,(IX + d)<br>b = 0<br>b = 1<br>b = 2<br>b = 3<br>b = 4<br>b = 5<br>b = 6<br>b = 7                                    | DD CB d 86<br>DD CB d 8E<br>DD CB d 96<br>DD CB d 9E<br>DD CB d A6<br>DD CB d A6<br>DD CB d AE<br>DD CB d B6 | 221 203 d 166<br>221 203 d 174                                                       | Ν | Ζ | Х   | Х   | Ν | Ν | 4   | 6           | 23          | 11.5           |          | 253<br>253<br>253<br>253<br>253<br>253<br>253<br>253<br>253<br>253 |
| b = 1                                                                                                                     | FD CB d 86<br>FD CB d 8E<br>FD CB d 96                                                                       | 253 203 d 134<br>253 203 d 142<br>253 203 d 150                                      | N | N | Ν   | Ν   | N | N | 4   | 6           | 23          | 11.5           |          | 253<br>253<br>253                                                  |

|                                                                                                                        |                                                                      |                                                                                                    |   |   | FLA | AGS |   |   | NO.         |             | TIMING      |                |          |                                                                    |
|------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------|----------------------------------------------------------------------------------------------------|---|---|-----|-----|---|---|-------------|-------------|-------------|----------------|----------|--------------------------------------------------------------------|
| SOURCE<br>CODE                                                                                                         | OBJECT<br>CODE (HEX)                                                 | DECIMAL                                                                                            | S | z | н   | P/V | N | с | OF<br>BYTES | M<br>CYCLES | T<br>STATES | μSEC @<br>2MHZ | COMMENTS | CH.5<br>REF.                                                       |
| b = 3<br>b = 4<br>b = 5<br>b = 6<br>b = 7                                                                              | FD CB d B6                                                           | 253 203 d 158<br>253 203 d 166<br>253 203 d 174<br>253 203 d 182<br>253 203 d 182<br>253 203 d 190 |   |   |     |     |   |   |             |             |             |                |          | 253<br>253<br>253<br>253<br>253<br>253                             |
| $\begin{array}{c} SET b, r \\ r = A, b = 0 \\ b = 1 \\ b = 2 \\ b = 3 \\ b = 4 \\ b = 5 \\ b = 6 \\ b = 7 \end{array}$ | CBC7<br>CBCF<br>CBD7<br>CBDF<br>CBE7<br>CBEF<br>CBF7<br>CBFF         | 203 199<br>203 207<br>203 215<br>203 223<br>203 231<br>203 239<br>203 247<br>203 255               | Ν | Ν | Ν   | Ν   | Ν | Ν | 2           | 2           | 8           | 4              |          | 312<br>312<br>312<br>312<br>312<br>312<br>312<br>312<br>312        |
| r = B, b = 0  b = 1  b = 2  b = 3  b = 4  b = 5  b = 6  b = 7                                                          | CB CO<br>CB C8<br>CB DO<br>CB D8<br>CB EO<br>CB E8<br>CB FO<br>CB F8 | 203 192<br>203 200<br>203 208<br>203 216<br>203 224<br>203 232<br>203 240<br>203 248               |   |   |     |     |   |   |             |             |             |                |          | 312<br>312<br>312<br>312<br>312<br>312<br>312<br>312<br>312<br>312 |
| r = C, b = 0                                                                                                           | CBC1<br>CBC9<br>CBD1<br>CBD9<br>CBE1                                 | 203 193<br>203 201<br>203 209<br>203 217<br>203 225                                                |   |   |     |     |   |   |             |             |             |                |          | 312<br>312<br>312<br>312<br>312<br>312                             |

|                                                               |                                                                      |                                                                                      |   |   | FL/ | AGS |   |   | NO.         |             | TIMING      |                |          |                                                                    |
|---------------------------------------------------------------|----------------------------------------------------------------------|--------------------------------------------------------------------------------------|---|---|-----|-----|---|---|-------------|-------------|-------------|----------------|----------|--------------------------------------------------------------------|
| SOURCE<br>CODE                                                | OBJECT<br>CODE (HEX)                                                 | DECIMAL                                                                              | S | z | н   | P/V | N | с | OF<br>BYTES | M<br>CYCLES | T<br>STATES | μSEC @<br>2MHZ | COMMENTS | CH.5<br>REF.                                                       |
| b = 5<br>b = 6<br>b = 7                                       | CBE9<br>CBF1<br>CBF9                                                 | 203 233<br>203 241<br>203 249                                                        |   |   |     |     |   |   |             |             |             |                |          | 312<br>312<br>312                                                  |
| r = D, b = 0                                                  | CBC2<br>CBCA<br>CBD2<br>CBDA<br>CBE2<br>CBEA<br>CBF2<br>CBFA         | 203 194<br>203 202<br>203210<br>203 218<br>203 226<br>203 234<br>203 242<br>203 250  |   |   |     |     |   |   |             |             |             |                |          | 312<br>312<br>312<br>312<br>312<br>312<br>312<br>312<br>312<br>312 |
|                                                               | CB C3<br>CB CB<br>CB D3<br>CB DB<br>CB E3<br>CB EB<br>CB F3<br>CB FB | 203 195<br>203 203<br>203 211<br>203 219<br>203 227<br>203 235<br>203 243<br>203 251 |   |   |     |     |   |   |             |             |             |                |          | 312<br>312<br>312<br>312<br>312<br>312<br>312<br>312<br>312        |
| r = H, b = 0  b = 1  b = 2  b = 3  b = 4  b = 5  b = 6  b = 7 | CBC4<br>CBCC<br>CBD4<br>CBDC<br>CBE4<br>CBEC<br>CBF4<br>CBFC         | 203 196<br>203 204<br>203 212<br>203 220<br>203 228<br>203 236<br>203 244<br>203 252 |   |   |     |     |   |   |             |             |             |                |          | 312<br>312<br>312<br>312<br>312<br>312<br>312<br>312<br>312<br>312 |

|                |                      |               |   |   | FL/ | AGS |   |   | NO.         |             | TIMING      |                |          |              |
|----------------|----------------------|---------------|---|---|-----|-----|---|---|-------------|-------------|-------------|----------------|----------|--------------|
| SOURCE<br>CODE | OBJECT<br>CODE (HEX) | DECIMAL       | S | z | н   | P/V | N | с | OF<br>BYTES | M<br>CYCLES | T<br>STATES | μSEC @<br>2MHZ | COMMENTS | CH.5<br>REF. |
| r = L, b = Ø   | CBC5                 | 203 197       |   |   |     |     |   |   |             |             |             |                |          | 312          |
| b = 1          | CBCD                 | 203 205       |   |   |     |     |   |   |             |             |             |                |          | 312          |
| b = 2          | CB D5                | 203213        |   |   |     |     |   |   |             |             |             |                |          | 312          |
| b = 3          | CBDD                 | 203 221       |   |   |     |     |   |   |             |             |             |                | 1        | 312          |
| b = 4          | CBE5                 | 203 229       |   |   |     |     |   |   |             |             |             |                |          | 312          |
| b = 5          | CBED                 | 203 237       |   |   |     |     |   |   |             |             |             |                |          | 312          |
| b = 6          | CBF5                 | 203 245       |   |   |     |     |   |   |             |             |             |                |          | 312          |
| b = 7          | CBFD                 | 203 253       |   |   |     |     |   |   |             |             |             |                |          | 312          |
| SET b, (HL)    |                      |               | Ν | N | N   | N   | N | N | 2           | 4           | 15          | 7.5            |          |              |
| b = Ø          | CBC6                 | 203 198       |   |   |     |     |   |   |             |             |             |                |          | 313          |
| b = 1          | CBCE                 | 203 206       |   |   |     |     |   |   |             |             |             |                |          | 313          |
| b = 2          | CBD6                 | 203214        |   |   |     |     |   |   |             |             |             |                |          | 313          |
| b = 3          | CBDE                 | 203 222       |   |   |     |     |   |   |             |             |             |                |          | 313          |
| b = 4          | CBE6                 | 203 230       |   |   |     |     |   |   |             |             |             |                |          | 313          |
| b = 5          | CBEE                 | 203 238       |   |   |     |     |   |   |             |             |             |                |          | 313          |
| b = 6          | CBF6                 | 203246        |   |   |     |     |   |   |             |             |             |                |          | 313          |
| b = 7          | CBFE                 | 203254        |   |   |     |     |   |   |             |             |             |                |          | 313          |
| SET b,(IX + d) |                      |               | N | N | N   | N   | N | N | 4           | 6           | 23          | 11.5           |          |              |
| b = 0          | DD CB d C6           | 221 203 d 198 |   |   |     |     |   |   |             |             |             |                |          | 314          |
| b = 1          | DD CB d CE           | 221 203 d 206 |   |   |     |     |   |   |             |             |             |                |          | 314          |
| b = 2          | DD CB d D6           | 221 203 d 214 |   |   |     |     |   |   |             |             |             |                |          | 314          |
| b = 3          | DD CB d DE           | 221 203 d 222 |   |   |     |     |   |   |             |             |             |                |          | 314          |
| b = 4          | DD CB d E6           | 221 203 d 230 |   |   |     |     |   |   |             |             |             |                |          | 314          |
| b = 5          |                      | 221 203 d 238 |   |   |     |     |   |   |             |             |             |                |          | 314          |
| b = 6          | DD CB d F6           |               |   |   |     |     |   |   |             |             |             |                |          | 314          |
| b = 7          | DD CB d FE           | 221 203 d 254 |   |   |     |     |   |   |             |             |             |                |          | 314          |

|                 |                      |               |   |   | FL/ | AGS |   |   | NO.         |             | TIMING |                |          |              |
|-----------------|----------------------|---------------|---|---|-----|-----|---|---|-------------|-------------|--------|----------------|----------|--------------|
| SOURCE<br>CODE  | OBJECT<br>CODE (HEX) | DECIMAL       | s | z | н   | P/V | N | с | OF<br>BYTES | M<br>CYCLES |        | μSEC @<br>2MHZ | COMMENTS | CH.5<br>REF. |
| SET b, (IY + d) |                      |               | N | N | N   | N   | N | N | 4           | 6           | 23     | 11.5           |          |              |
| b = 0           |                      | 253 203 d 198 |   |   |     |     |   |   |             |             |        |                |          | 314          |
| b = 1           | FD CB d CE           | 253 203 d 206 |   |   |     |     |   |   |             |             |        |                |          | 314          |
| b = 2           | FD CB d D6           | 253 203 d 214 |   |   |     |     |   |   |             |             |        |                |          | 314          |
| b = 3           | FD CB d DE           | 253 203 d 222 |   |   |     |     |   |   |             |             |        |                |          | 314          |
| b = 4           | FD CB d E6           | 253 203 d 230 |   |   |     |     |   |   |             |             |        |                |          | 314          |
| b = 5           | FD CB d EE           | 253 203 d 238 |   |   |     |     |   |   |             |             |        |                |          | 314          |
| b = 6           | FD CB d F6           | 253 203 d 246 |   |   |     |     |   |   |             |             |        |                |          | 314          |
| b = 7           | FD CB d FE           | 253 203 d 254 |   |   |     |     |   |   |             |             |        |                |          | 314          |

FLAG KEY: N - Not affected.

- N Not affected.
- P Contains the Parity of the result (1 = Parity Even).
- V Contains the Overflow of the result (1 = Overflow).

 $\emptyset$  - RESET =  $\emptyset$ .

1 - SET = 1.

? – Unknown.

\* - Affected according to the result.

## JUMP, (SUB-ROUTINE) CALL AND RETURN GROUP TABLE

|                                                                                       |                                                                      |                                                                              |        |        | FL/    | AGS    |        |        | NO.         |             | TIMING         |                 |                                               |                                                             |
|---------------------------------------------------------------------------------------|----------------------------------------------------------------------|------------------------------------------------------------------------------|--------|--------|--------|--------|--------|--------|-------------|-------------|----------------|-----------------|-----------------------------------------------|-------------------------------------------------------------|
| SOURCE<br>CODE                                                                        | OBJECT<br>CODE (HEX)                                                 | DECIMAL                                                                      | s      | z      | н      | P/V    | N      | с      | OF<br>BYTES | M<br>CYCLES | T<br>STATES    | μSEC @<br>2MHZ  | COMMENTS                                      | CH.5<br>REF.                                                |
| CALL pq<br>CALL cc, pq                                                                | CDpq                                                                 | 205 pq                                                                       | N<br>N | N<br>N | N<br>N | N<br>N | N<br>N | N<br>N | 3<br>3      | 5<br>5<br>3 | 17<br>17<br>10 | 8.5<br>8.5<br>5 | lf cc is true<br>lf cc is false               | 109                                                         |
| cc = NZ $cc = Z$ $cc = NC$ $cc = C$ $cc = PO$ $cc = PE$ $cc = P$ $cc = M$             | C4 pq<br>CC pq<br>D4 pq<br>DC pq<br>E4 pq<br>EC pq<br>F4 pq<br>FC pq | 196 pq<br>204 pq<br>212 pq<br>220 pq<br>228 pq<br>236 pq<br>244 pq<br>252 pq |        |        |        |        |        |        |             |             |                |                 |                                               | 117<br>116<br>112<br>111<br>120<br>119<br>113<br>115        |
| DJNZe                                                                                 | 10e-2                                                                | 16e-2                                                                        | N      | N      | N      | Ν      | Ν      | Ν      | 2           | 2<br>3      | 8<br>13        | 4<br>6.5        | If Register $B = 0$<br>If Register $B \neq 0$ | 146                                                         |
| JPnn                                                                                  | C3 nn                                                                | 195 nn                                                                       | N      | N      | N      | Ν      | N      | N      | 3           | 3           | 10             | 5               |                                               | 175                                                         |
| JP cc, pq $cc = NZ$ $cc = Z$ $cc = NC$ $cc = C$ $cc = PO$ $cc = PE$ $cc = P$ $cc = M$ | C2 qp<br>CA qp<br>D2 qp<br>DA qp<br>E2 qp<br>EA qp<br>F2 qp<br>FA qp | 194 qp<br>202 qp<br>210 qp<br>218 qp<br>226 qp<br>234 qp<br>242 qp<br>250 qp | Ν      | Z      | Ζ      | Z      | Ζ      | Ν      | 3           | 3           | 10             | 5               |                                               | 178<br>178<br>178<br>178<br>178<br>178<br>178<br>178<br>178 |
| JP(HL)                                                                                | E9                                                                   | 233                                                                          | N      | N      | N      | N      | N      | N      | 1           | 1           | 4              | 2               |                                               | 176                                                         |
| JP(IX)                                                                                | DD E9                                                                | 221 233                                                                      | Ν      | N      | Ν      | Ν      | Ν      | Ν      | 2           | 2           | 8              | 4               |                                               | 177                                                         |
| JP(IY)                                                                                | FDE9                                                                 | 253 233                                                                      | Ν      | Ν      | Ν      | Ν      | Ν      | Ν      | 2           | 2           | 8              | 4               |                                               | 177                                                         |
| JRe                                                                                   | 18e-2                                                                | 024 e-2                                                                      | Ν      | Ν      | Ν      | N      | Ν      | Ν      | 2           | 3           | 12             | 6               |                                               |                                                             |

|                   |                      |            |    | FL/ | AGS |     |   | NO. |             | TIMING      |             |                |                      |              |
|-------------------|----------------------|------------|----|-----|-----|-----|---|-----|-------------|-------------|-------------|----------------|----------------------|--------------|
| SOURCE<br>CODE    | OBJECT<br>CODE (HEX) | DECIMAL    | s  | z   | н   | P/V | N | с   | OF<br>BYTES | M<br>CYCLES | T<br>STATES | μSEC @<br>2MHZ | COMMENTS             | CH.5<br>REF. |
| JRC,e             | 38 e-2               | 056 e-2    | N  | Ν   | N   | N   | Ν | N   | 2           | 3           | 12          | 6              | If condition is met  | 180          |
|                   |                      |            |    |     |     |     |   |     |             | 2           | 7           | 3.5            | If condition not met | 181          |
| JRNC, e           | 30 e-2               | 048 e-2    | Ν  | Ν   | N   | N   | N | N   | 2           | 3           | 12          | 6              | If condition is met  |              |
|                   |                      |            |    |     |     |     |   |     |             | 2           | 7           | 3.5            | If condition not met | 181          |
| JRNZ, e           | 20 e-2               | 032 e-2    | Ν  | N   | N   | N   | N | N   | 2           | 3           | 12          | 6              | If condition is met  | 101          |
| JRZ,e             | 28 e-2               | 040 e-2    | N  | N   | N   | N   | N | N   | 2           | 23          | 7<br>12     | 3.5<br>6       | If condition not met | 181          |
| JRZ, e            | 206-2                | 040 8-2    | IN | IN  |     |     |   |     | 2           | 2           | 7           | 3.5            | If condition not met | 181          |
| RET               | C9                   | 201        | N  | N   | N   | N   | N | N   | 1           | 3           | 10          | 5              |                      | 225          |
| RETcc             | 00                   | 201        | N  | N   | N   | N   | N | N   | 1           | 3           | 11          | 5.5            | lfccistrue           | 220          |
|                   |                      |            |    |     |     |     |   |     |             | 1           | 5           | 2.5            | If cc is false       |              |
| cc = NZ           | CO                   | 192        |    |     |     |     |   |     |             |             |             |                |                      | 257          |
| cc = Z            | C8                   | 200        |    |     |     |     |   |     |             |             |             |                |                      | 257          |
| cc = NC<br>cc = C | D0<br>D8             | 208<br>216 |    |     |     |     |   |     |             |             |             |                |                      | 257<br>257   |
| cc = C<br>cc = PO | EO                   | 224        |    |     |     |     |   |     |             |             |             |                |                      | 257          |
| cc = PE           | E8                   | 232        |    |     |     |     |   |     |             |             |             |                |                      | 257          |
| cc = P            | FO                   | 240        |    |     |     |     |   |     |             |             |             |                |                      | 257          |
| cc = M            | F8                   | 248        |    |     |     |     |   |     |             |             |             |                |                      | 257          |
| RETI              | ED4D                 | 237 077    | Ν  | N   | N   | N   | N | N   | 2           | 4           | 14          | 7              |                      | 259          |
| RETN              | ED 45                | 237 069    | N  | N   | N   | N   | N | N   | 2           | 4           | 14          | 7              |                      | 261          |
| RST P             |                      |            | N  | N   | N   | N   | N | N   | 1           | 3           | 11          | 5.5            |                      |              |
| p = 00            |                      |            |    |     |     |     |   |     |             |             |             |                |                      |              |
| (Hex.)            | C7                   | 199        |    |     |     |     |   |     |             |             |             |                |                      | 299          |
| p = 08<br>(Hex.)  | CF                   | 207        |    |     |     |     |   |     |             |             |             |                |                      | 299          |
| (nex.)<br>p = 10  |                      | 201        |    |     |     |     |   |     |             |             |             |                |                      | 235          |

## JUMP, (SUB-ROUTINE) CALL AND RETURN GROUP TABLE (cont.)

## JUMP, (SUB-ROUTINE) CALL AND RETURN GROUP TABLE (cont.)

|                  |                      |         |   |   | FLA | AGS |   |   | NO. TIMING  |             |             |                |          |              |
|------------------|----------------------|---------|---|---|-----|-----|---|---|-------------|-------------|-------------|----------------|----------|--------------|
| SOURCE<br>CODE   | OBJECT<br>CODE (HEX) | DECIMAL | S | z | н   | P/V | N | С | OF<br>BYTES | M<br>CYCLES | T<br>STATES | μSEC @<br>2MHZ | COMMENTS | CH.5<br>REF. |
| (Hex.)<br>p = 18 | D7                   | 215     |   |   |     |     |   |   |             |             |             |                |          | 299          |
| (Hex.)<br>p = 20 | DF                   | 223     |   |   |     |     |   |   |             |             |             |                |          | 299          |
| (Hex.)<br>p = 28 | E7                   | 231     |   |   |     |     |   |   |             |             |             |                |          | 299          |
| (Hex.)<br>p = 30 | EF                   | 239     |   |   |     |     |   |   |             |             |             |                |          | 299          |
| (Hex.)<br>p = 38 | F7                   | 247     |   |   |     |     |   |   |             |             |             |                |          | 299          |
| ρ = 38<br>(Hex.) | FF                   | 255     |   |   |     |     |   |   |             |             |             |                |          | 299          |

FLAG KEY: N - Not affected.

See .

#### INPUT AND OUTPUT GROUP TABLE

|                                                                          |                                                             |                                                                           |   |   | FL | AGS |   |   | NO.         |             | TIMING      |                |                                               |                                                      |
|--------------------------------------------------------------------------|-------------------------------------------------------------|---------------------------------------------------------------------------|---|---|----|-----|---|---|-------------|-------------|-------------|----------------|-----------------------------------------------|------------------------------------------------------|
| SOURCE<br>CODE                                                           | OBJECT<br>CODE (HEX)                                        | DECIMAL                                                                   | s | z | н  | P/V | N | с | OF<br>BYTES | M<br>CYCLES | T<br>STATES | μSEC @<br>2MHZ | COMMENTS                                      | CH.5<br>REF.                                         |
| IN A, (N)                                                                | DBN                                                         | 219N                                                                      | N | N | N  | N   | N | N | 2           | 3           | 11          | 5.5            |                                               | 159                                                  |
| IN r, (C)<br>r = A<br>r = B<br>r = C<br>r = D<br>r = E<br>r = H<br>r = L | ED 78<br>ED 40<br>ED 48<br>ED 50<br>ED 58<br>ED 60<br>ED 68 | 237 120<br>237 064<br>237 072<br>237 080<br>237 088<br>237 096<br>237 104 | * | • | •  | P   | Ø | N | 2           | 3           | 12          | 6              |                                               | 160<br>160<br>160<br>160<br>160<br>160<br>160        |
| IND                                                                      | EDAA                                                        | 237 170                                                                   | ? | * | ?  | ?   | 1 | N | 2           | 4           | 16          | 8              |                                               | 169                                                  |
| INI                                                                      | ED A2                                                       | 237 162                                                                   | ? | * | ?  | ?   | 1 | N | 2           | 4           | 16          | 8              |                                               | 172                                                  |
| INIR                                                                     | ED B2                                                       | 237 172                                                                   | ? | 1 | ?  | ?   | 1 | N | 2           | 5<br>4      | 21<br>16    | 10.5<br>8      | If Register B≠ 0<br>If Register B= 0          | 170                                                  |
| INDR                                                                     | EDBA                                                        | 237 186                                                                   | ? | 1 | ?  | ?   | 1 | N | 2           | 5           | 21<br>16    | 10.5<br>8      | If Register $B \neq 0$<br>If Register $B = 0$ | 235                                                  |
| OTDR                                                                     | ED BB                                                       | 237 187                                                                   | ? | 1 | ?  | ?   | 1 | N | 2           | 5           | 21<br>16    | 10.5<br>8      | If Register $B \neq 0$<br>If Register $B = 0$ | 173                                                  |
| OTIR                                                                     | ED B3                                                       | 237 179                                                                   | ? |   | ?  | ?   | 1 | N | 2           | 5           | 21          | 10.5           | If Register $B \neq 0$                        | 236                                                  |
|                                                                          |                                                             |                                                                           |   |   |    |     |   |   |             | 4           | 16          | 8              | If Register $B = 0$                           |                                                      |
| OUT (n), A                                                               | D3 n                                                        | 211 n                                                                     | N | N | N  | N   | N | N | 2           | 3           | 11          | 5.5            |                                               | 239                                                  |
| OUT (C), r<br>r = A<br>r = B<br>r = C<br>r = D<br>r = E<br>r = H         | ED 79<br>ED 41<br>ED 49<br>ED 51<br>ED 59<br>ED 61          | 237 121<br>237 065<br>237 073<br>237 081<br>237 089<br>237 097            | N | N | N  | N   | N | N | 2           | 3           | 12          | 6              |                                               | 238<br>238<br>238<br>238<br>238<br>238<br>238<br>238 |

#### INPUT AND OUTPUT GROUP TABLE (cont.)

|                |                      |                    | FLAGS  |   |        |        |        |        | NO. TIMING  |             |          |                |          |              |
|----------------|----------------------|--------------------|--------|---|--------|--------|--------|--------|-------------|-------------|----------|----------------|----------|--------------|
| SOURCE<br>CODE | OBJECT<br>CODE (HEX) | DECIMAL            | S      | z | н      | P/V    | N      | С      | OF<br>BYTES | M<br>CYCLES |          | μSEC @<br>2MHZ | COMMENTS | CH.5<br>REF. |
| r = L          | ED69                 | 237 105            |        |   |        |        |        |        |             |             |          |                |          | 238          |
| OUTD<br>OUTI   | ED AB<br>ED A3       | 237 171<br>237 163 | ?<br>? | * | ?<br>? | ?<br>? | 1<br>1 | N<br>N | 2<br>2      | 4<br>4      | 16<br>16 | 8<br>8         |          | 240<br>241   |

FLAG KEY: N - Not affected.

P - Contains the Parity of the result (1 = Parity Even).
 V - Contains the Overflow of the result (1 = Overflow).

 $\emptyset$  - RESET =  $\emptyset$ .

1 - SET = 1.

– Unknown. ? \*

- Affected according to the result.

The Z80 Reference Guide is an essential book for programmers involved in Z80 machine language programming.

The well laid out format of this book will make it clearer for readers to understand the capabilities of the Z80 instruction set.

Many of the instructions which operate on all of the registers have been grouped together, placing all of the opcodes on the one page for easier reference.

All the opcodes are HEX and decimal, making machine language programs for BASIC programmers easier to implement.

The book serves as a quick and informative reference manual.

The effect each instruction has on the status register has been clearly presented for easy reference.

The Z80 Reference Guide is an indispensable book for anyone interested in learning machine language programming skills.

Melbourne ISBN 0-86161-162-4 House 9 780861611621

£9.95







[FRA] Ce document a été préservé numériquement à des fins éducatives et d'études, et non commerciales. [ENG] This document has been digitally preserved for educational and study purposes, not for commercial purposes. [ESP] Este documento se ha conservado digitalmente con fines educativos y de estudio, no con fines comerciales.