### **Y90-180 Microprocessor**

#### **Technical Manual**



#### Disclaimer

Systemyde International Corporation reserves the right to make changes at any time, without notice, to improve design or performance and provide the best product possible. Systemyde International Corporation makes no warrant for the use of its products and assumes no responsibility for any errors which may appear in this document nor does it make any commitment to update the information contained herein.

Systemyde International Corporation products are not authorized for use in life support devices or systems unless a specific written agreement pertaining to such use is executed between the manufacturer and the President of Systemyde International Corporation. Nothing contained herein shall be construed as a recommendation to use any product in violation of existing patents, copyrights or other rights of third parties. No license is granted by implication or otherwise under any patent, patent rights or other rights, of Systemyde International Corporation. All trademarks are trademarks of their respective companies.

Every effort has been made to ensure the accuracy of the information contain herein. If you find errors or inconsistencies please bring them to our attention. In all cases, however, the Verilog HDL source code for the Y90 design defines "proper operation".

Copyright © 2010, 2012, 2013, 2016, Systemyde International Corporation. All rights reserved.

#### Notice:

"Z80", "Z180" and "Zilog" are registered trademarks of Zilog, Inc. All uses of these terms in this document are to be construed as adjectives, whether or not the noun "microprocessor", "CPU" or "device" are actually present.

#### Table of Contents

| 1. Introduction                                        | 3   |
|--------------------------------------------------------|-----|
| 2. Features                                            | 5   |
| 3. Pin Descriptions                                    | 7   |
| 4. External Timing                                     | 13  |
| 5. Instruction Set                                     |     |
| 6. Memory Management Unit (MMU)                        | 135 |
| 7. Interrupt Control                                   | 139 |
| 8. Direct Memory Access (DMA)                          | 141 |
| 9. Asynchronous Serial Communications Interface (ASCI) | 149 |
| 10. Programmable Reload Timer (PRT)                    | 157 |
| 11. Clocked Serial I/O (CSIO)                          | 161 |
| 12. System Functions                                   | 165 |
| 13. I/O Register Addresses                             | 167 |
| 14. Top level Verilog Code                             | 169 |

### **Revison History**

| Date       | Changes                                                                             | Page(s)            |
|------------|-------------------------------------------------------------------------------------|--------------------|
| 11/14/2012 | added nmiack_tran signal, updated top level Verilog code                            | Ch 3, 14           |
| 12/20/2012 | added tend0b and tend1b signal to signal description                                | Ch 3               |
| 12/27/2012 | Typo corrections in DMA registers                                                   | Ch 8               |
| 01/03/2013 | More corrections to DMA, made all signals (except for the reset inputs) active-High | Ch 3, 8, 9, 13, 14 |
| 01/12/2013 | Added table listing valid operating modes                                           | 147                |
| 01/15/2013 | DMA register changes                                                                | Ch 8               |
| 02/04/2013 | tout operation                                                                      | 157, 158           |
| 04/22/2013 | updated top-level code in appendix                                                  | 173                |
| 04/23/2013 | more typo corrections                                                               | 137, 166           |
| 01/16/2015 | type in MLT instruction encoding                                                    | 90                 |

## Introduction

This book documents the operation of the Y90-180 microprocessor. The Y90-180 design is supplied in Verilog HDL and can be implemented in any technology supported by a logic synthesis tool that accepts Verilog HDL. Included in the design package is a test bench that exercises all instructions, flag settings, and representative data patterns. The test patterns should achieve at least 95% fault coverage.

The Y90-180 was designed in a clean-room environment and is an upgrade of the Zilog Z180 series of microprocessors. Only publicly available documentation was used to create this design so there may be minor differences where the public documentation is misleading or lacking. The instruction execution times are not identical between the two designs. The Y90-180 operates with a consistent two-clock-cycle machine cycle, while the Z180 microprocessors use machine cycles that vary from three to seven clock cycles.

The Y90-180 design, depending on the version, may not implement all of the features or operating modes of the Z180 architecture. In particular, almost all of the added peripheral features present in the Z8S180 and Z8L180 are also present in the Y90-180. The Y90-180 contains the peripheral functions present in the original Z80180.

This document should always be used as the final word on the operation of the Y90-180, but it is useful to refer to the Zilog documentation if the description given here is too cryptic. The Z180 architecture is over thirty years old, so it is assumed that it is already at least somewhat familiar to the reader.

The Y90-180 is accompanied by full design documentation, in the form of a large spreadsheet, which describes nearly every facet of the internal operation of the processor. This provides knowledgeable users the opportunity to customize the design for unique application requirements.

### Features

- \* Fully functional synthesizable Verilog HDL version of the Z180 MPU
- \* Vendor and technology independent
- \* 189 instructions, with eight addressing modes
- \* 64K byte (1M byte with MMU) memory addressing capability
- \* Separate 64K byte I/O address space
- \* 16 bit ALU with bit, byte and BCD operations
- \* Powerful vectored interrupt capability with separate interrupt vector input bus
- \* Static, fully synchronous design uses no 3-state buses
- \* Uniform 2 clock-cycle machine cycle
- \* Includes peripheral functions present in the original Z180: Two Direct Memory Access (DMA) channels Two Asynchronous Serial Communications Interface (ASCI) channels Two Programmable Reload Timer (PRT) channels One Clocked Serial I/O (CSIO) channel
- \* Memory interface matches common FPGA and ASIC memory timing
- \* Separate I/O bus, compatible with AMBA Peripheral Bus
- \* Illegal instruction detection
- \* Full design documentation included
- \* Verilog simulation and test suite included

Shown below are the registers visible to the programmer. The main registers have both a primary and an alternate version. The primary register set consists of A, F, B, C, D, E, H, and L, while the alternate register set consists of A', F', B', C', D', E', H', and L'. At any given time only one bank is active, and care must be used when switching between banks, as there is no way for the programmer to check which bank is active. The accumulator, A, is the destination for all 8-bit arithmetic and logic operations, while the Flag register F contains the flag results of arithmetic and logic operations. The other general-purpose registers can be paired, BC or DE or HL, to form 16-bit registers. There are two index registers, IX and IY, used for indexed addressing mode. The I register holds the upper eight bits of the interrupt vector table address for use in Interrupt Mode 2. The R register is left over from the original Z80 architecture, where it was used to hold a refresh address for DRAMs. In the Y90-180 it is just another general purpose register. The Stack pointer, SP, holds the address of the stack, and the Program Counter, PC, holds the address of the currently executing instruction.

| Α  | F |  |  |
|----|---|--|--|
| В  | С |  |  |
| D  | Ε |  |  |
| Н  | L |  |  |
| IX |   |  |  |
| IY |   |  |  |

Main Register Bank

| А' | F' |
|----|----|
| В' | C' |
| D' | Е' |
| Н' | L' |

I R

| SP |  |
|----|--|
| PC |  |

Alternate Register Bank

Special Function Registers

# **Pin Descriptions**

The Y90-180 design does not attempt to match the signals or timing present on the Z180 microprocessor. Rather, the interfaces and signals are optimized for use in either an ASIC or an FPGA.

Memory and I/O use separate address and data buses in addition to the separate control signals. The memory bus is designed to match typical ASIC and FPGA memory timing, although it can be used with stand-alone memory devices just as easily. A separate interrupt vector bus is provided for use with an interrupt controller. If desired, this interrupt vector bus can be tied to either the memory or I/O input bus for operation more closely resembling that of the original Z180.

The original Z180 microprocessor multiplexes a number of pin functions because of package constraints. The Y90-180 makes no attempt to duplicate this signal multiplexing.

The interface signals for the Y90-180 are detailed below. Note that all inputs except the two resets are sampled by the rising edge of the clock and all outputs change in response to the rising edge of the clock.

- **cka0\_in, cka1\_in** (inputs, active-High) The Async Clock In signals are the external clock inputs for the two ASCI channels.
- **cka0\_out, cka1\_out** (outputs, active-High) The Async Clock Out signals are the internal clock outputs for the two ASCI channels.
- **cks\_in** (input, active-High) The Clocked Serial Clock In signal is the external clock input for the CSIO channel.
- **cks\_out** (output, active-High) The Clocked Serial Clock Out signal is the internal clock output for the CSIO channel.
- **clearb** (input, active-Low) The Master (test) Reset signal is used to initialize all of the flip-flops that are not initialized by the user reset signal. Most user-visible registers are not affected by the user reset, so this signal allows full initialization for testing and simulation. This is an asynchronous signal that should be used for Power-On Reset.

clkc (input, active-High) The CPU Clock connects to all flip-flops in the design.

- **cts0, cts1** (inputs, active-High) The Clear To Send signals are the transmit enable modem controls for the two ASCI channels.
- dcd0, dcd1 (inputs, active-High) The Data Carrier Detect signals are the receive enable modem controls for the two ASCI channels.
- dma\_ack (output, active-High) The DMA Acknowledge signal is activated to indicate that the processor has halted to allow another bus master to use the bus. The iack\_tran, io\_addr\_out, io\_data\_out, io\_tran, mem\_addr\_out, mem\_data\_out, mem\_tran, nmiack\_tran, reti\_tran and t1 signals are all inactive (Low) during this time, but the internal DMA controller will drive these signals to perform data transfers. The processor will signal dma\_ack while in the Halt or Sleep state without de-asserting the halt\_tran or sleep\_tran signals. Interrupts are not sampled while the dma\_ack signal is active, so the exit from a coincident Halt or Sleep state will be deferred until the dma\_ack signal is no longer active.
- **dma\_req** (input, active-High) The DMA Request signal requests that the processor halt to allow an external bus master to transfer data on the bus. The processor only releases the bus between instructions, rather than between individual bus transactions. An external bus master has higher priority than the internal DMA controller.
- **dreq0, dreq1** (inputs, active-High) These DMA Request signals are used by the internal DMA controller to trigger or gate DMA transfers. These signals may be programmed to be edge- or level-sensitive.
- **en\_prftch** (input, active-High). The Enable Prefetch signal enables the prefetch operation. Although the prefetch mode can be changed dynamically, it is recommended that this signal be tied either High or Low. The prefetch mechanism increases performance by prefetching an opcode byte during any address calculation time. Only the prefix byte (0xCB, 0xDD, 0xED or 0xFD) of a multi-byte instruction can actually be used after being prefetched.
- halt\_tran (output, active-High) The Halt Transaction signal is activated by the Halt instruction. While in the Halt state the CPU freezes and waits for an interrupt. The iack\_tran, io\_addr\_out, io\_data\_out, io\_tran, mem\_addr\_out, mem\_data\_out, mem\_tran, reti\_tran and t1 signals are all inactive (Low) during this time.
- iack\_tran (output, active-High) The Interrupt Acknowledge Transaction signal is activated to identify an interrupt acknowledge bus transaction. An interrupt

acknowledge occurs in response to an enabled Maskable Interrupt request. During an interrupt acknowledge the interrupt vector data bus is sampled, although the sampled value is only used in Interrupt Mode 0 or 2 with a maskable interrupt request.

- **int0\_req** (input, active-High) The Interrupt 0 Request signal is the highest-priority maskable interrupt request. Maskable interrupts can be enabled and disabled under program control. This interrupt request is not latched, so it should remain active until an interrupt acknowledge transaction occurs. This interrupt request uses an externally-supplied interrupt vector in Interrupt Mode 0 or 2.
- int1\_req, int2\_req (inputs, active-High) The Interrupt 1 (and 2) Request signals are additional maskable interrupt requests. These two interrupt requests use an internally-generated interrupt vector and force Interrupt Mode 2.
- io\_addr\_out (output, 16-bit bus) The I/O Address Output bus carries the address of the I/ O port during an I/O transaction. This bus holds the current value until the next I/O transaction or until the dma\_ack signal is activated.
- **io\_data\_in** (input, 8-bit bus) The I/O Data Input bus is sampled during the various I/O input instructions. A separate bus allows peripherals to be connected without loading the memory data bus.
- **io\_data\_out** (output, 8-bit bus) The I/O Data Output bus carries the output data for I/O output instructions. This bus holds the current value until the next output instruction or until the **dma\_ack** signal is activated.
- **io\_read** (output, active-High) The I/O Read signal indicates the direction of data transfer during I/O transactions. High signals read and Low signals write. This signal is valid only during I/O transactions.
- **io\_strobe** (output, active-High) The I/O Strobe signal is one clock cycle wide (in the absence of Wait states) and identifies the data transfer clock cycle for I/O transactions.
- io\_tran (output, active-High) The I/O Transaction signal is activated for all I/O transactions.
- **ivec\_data\_in** (input, 8-bit bus) The Interrupt Vector Data Input bus is sampled during interrupt acknowledge transactions. If the interrupt acknowledge was for a maskable interrupt and the CPU is in Interrupt Mode 2, this vector is used as a pointer in the interrupt vector table to find the starting address of the interrupt service routine. In Interrupt Mode 0 the vector is a one-byte RST instruction.

- **ivec\_rd** (output, active-High) The Interrupt Vector Read signal is one clock cycle wide (in the absence of Wait states) and identifies the data transfer clock cycle for interrupt acknowledge transactions.
- **mem\_addr\_out** (output, 16-bit bus) The Memory Address Output bus carries the address during memory read and write transactions. This bus holds the current value until the next memory transaction.
- **mem\_data\_in** (input, 8-bit bus) The Memory Data Input bus is sampled during memory read transactions. A separate bus allows peripherals to be connected without loading the memory data bus.
- **mem\_data\_out** (output, 8-bit bus) The Memory Data Output bus carries the output data for memory write transactions. This bus holds the current value until the next output instruction.
- **mem\_rd** (output, active-High) The Memory Read signal is one clock cycle wide (in the absence of Wait states) and identifies the data transfer clock cycle for memory read transactions.
- **mem\_tran** (output, active-High) The Memory Transaction signal is activated for memory read and write transactions. The **mem\_tran** signal is active during the Halt state but is inactive during the Sleep state and during DMA transfers.
- **mem\_wr** (output, active-High) The Memory Write signal is one clock cycle wide (in the absence of Wait states) and identifies the data transfer clock cycle for memory write transactions.
- nmi\_req (input, active-High) The Non-Maskable Interrupt Request signal unconditionally interrupts the CPU. This request is internally latched, so that it can be as short as one clock cycle wide.
- **nmiack\_tran** (output, active-High) The NMI Acknowledge Transaction signal is activated to identify an NMI acknowledge bus transaction. An NMI acknowledge occurs in response to a Non-Maskable Interrupt request.
- **resetb** (input, active-Low) The User Reset signal is used to initialize all state flip-flops and some user registers (the I, R, PC and SP registers). This is an asynchronous signal.
- **reti\_tran** (output, active-High) The Return From Interrupt transaction signal is activated immediately after the second stack read transaction during the Return From Interrupt (RETI) instruction. This signal may be used by an external interrupt controller to re-enable interrupts, for example.

- rts0, rts1 (outputs, active-High) The Request To Send signals are modem control outputs from the two ASCI channels.
- **rxa0, rxa1** (inputs, active-High) The Asynchronous Receive Data signals are the serial data inputs for the two ASCI channels.
- **rxs** (inputs, active-High) The Synchronous Receive Data signal is the serial data input for the CSIO channel.
- sleep\_tran (output, active-High) The Sleep Transaction signal is activated by the Sleep
  instruction. While in the Sleep state the CPU freezes and waits for an interrupt. The iack\_tran, io\_addr\_out, io\_data\_out, io\_tran, mem\_addr\_out,
   mem\_data\_out, mem\_tran, reti\_tran and t1 signals are all inactive (Low)
   during this time.
- **t1** (output, active-High) The T1 signal is active during the first clock cycle of a bus transaction. This signal is inactive during the Halt and Sleep states.
- tend0, tend1 (outputs, active-High) The DMA End Count Output signals are the terminalcount outputs from the two DMA channels.
- tout0, tout1 (outputs, active-High) The Terminal Count Output signals are the terminalcount outputs from the two PRT channels.
- **txa0, txa1** (outputs, active-High) The Asynchronous Transmit Data signals are the serial data outputs for the two ASCI channels.
- **txs** (output, active-High) The Synchronous Transmit Data signal is the serial data output for the CSIO channel.
- wait\_req (input, active-High) The Wait Request signal temporarily halts the CPU, usually
  to wait for memory access time to be met. The wait request is not honored
  while the dma\_ack, halt\_tran or sleep\_tran signals are active.

# **External Timing**

The Y90-180 uses a uniform two-clock-cycle machine cycle. This consistent timing simplifies the design of logic external to the CPU makes it easier to track the state of the CPU.

The memory interface timing and signals are designed to make it easy to interface to standard ASIC and FPGA memories. It uses separate read and write strobes.

The I/O interface is very close to the AMBA Peripheral Bus (APB) to allow connection to APB peripherals with a minimum of logic. It uses a single strobe with a separate direction control. The only difference relative to the APB is the setup time for the write data. In the APB the write data is setup one clock before the strobe; in this interface the write data changes coincident with the leading edge of the strobe. In most cases this will not be a problem.

The separate interrupt vector bus provides an easy way to connect to the optional interrupt controller. The interrupt vector bus is used for Mode 0 and Mode 2 maskable interrupts, so if these modes are not used the vector input bus can be tied to ground and the vector strobe output ignored.

In the diagrams below only the relevant signals are shown for each transaction. All other signals are either inactive or hold the previous value. Note that only one of the transaction identifiers (mem\_tran, io\_tran, iack\_tran, nmiack\_tran, reti\_tran, halt\_tran and sleep\_tran) can be active at a time. If all are inactive, an idle bus transaction (usually for address calculation) is in progress. If prefetch is enabled most address calculation idle transactions are replaced by memory transactions. The dma\_ack signal also indicates that the bus is idle, in response to the dma\_req signal. The dma\_ack signal can be active while either halt\_tran or sleep\_tran is active.

The **wait\_req** input is only sampled for memory, I/O and interrupt acknowledge transactions and is ignored in all other cases. Wait states will disrupt the two-clock-cycle machine cycle rule. If this feature is important but wait states must be used, two wait states per transaction is recommended. If memory access time is an issue it might be better to stretch the first clock cycle of a transaction rather than add Wait states. The uniform two-clock machine cycle makes it relatively straightforward to do this.

#### **Memory Read**

The figure below shows the memory read transaction, without Wait states and with one Wait state. Memory read transactions are used for both instruction and data fetch. There is no separate instruction/data status indicator, although this status exists internally if it is needed.



#### **Memory Write**

The figure below shows the memory write transaction, without Wait states and with one Wait state.



#### I/O Read

The figure below shows an I/O read transaction, without Wait states and with one Wait state.



#### I/O Write

The figure below shows an I/O write transaction, without Wait states and with one Wait state.



#### **Interrupt Acknowledge**

The figure below shows the interrupt acknowledge transaction, without Wait states and with one Wait state.



#### Prefetch

The figure below shows a typical instruction (a memory write) without the prefetch enabled and with the prefetch enabled. The prefetch logic uses address calculation machine cycles to look at the next opcode byte. If this opcode byte is one of the "prefix" bytes (0xCB, 0xDD, 0xED or 0xFD) the logic buffers this byte and will not re-fetch it when the current instruction completes. Only these four prefix bytes will be buffered, even though there are other multi-byte opcodes. Attempting to prefetch for every multi-byte opcode would be significantly more complicated, with marginal performance improvement.

In practice, enabling the prefetch can improve execution time by about 5%, although this obviously depends on the exact code being executed. If Wait states are being used prefetch may not provide any performance gain, because of the Wait states added when prefetching bytes that may later be discarded.

Note that even though an instruction may execute faster when the prefetch is enabled, this instruction will still complete at the same time. However, the next instruction (the one with the first byte prefetched) will complete earlier. This is shown in the diagrams below.

The prefetch can be enabled and disabled on the fly, because the **en\_prftch** signal is sampled during the **t1** time of the fetch of the first byte of an instruction.



#### **Illegal Instruction (2nd byte) Trap**

The timing of an undefined second byte opcode trap is shown below. The fetch of the undefined opcode is followed by three machine cycles that flush the pipeline and rewind the Program Counter, an interrupt acknowledge cycle, and two writes to push the PC of the undefined opcode to the stack. The processor then jumps to location 0x0000 and starts fetching instructions.



Information about the trap is latched in the INT/TRAP Control Register. The start of the illegal instruction in this case is the stacked PC value minus one.

#### **Illegal Instruction (3rd byte) Trap**

The timing of an undefined third byte opcode trap is shown below. The fetch of the undefined opcode is followed by the normal Read cycle (all three-byte instructions use indexed addressing), two machine cycles that flush the pipeline and rewind the Program Counter, an interrupt acknowledge cycle, and two writes to push the PC of the undefined opcode to the stack. The processor then jumps to location 0x0000 and starts fetching instructions.



Information about the trap is latched in the INT/TRAP Control Register. The start of the illegal instruction in this case is the stacked PC value minus two.

#### **Non-maskable Interrupt**

The timing of a non-maskable interrupt acknowledge transaction is shown below. The **nmi\_req** input cannot be masked by software. This input must be sampled active by a rising edge of **clkc** to be recognized by the processor, but does not need to remain active until the interrupt acknowledge transaction. In fact, to prevent an endless loop of acknowledges, the **nmi\_req** input must be de-asserted before the start of the fetch of the first instruction of the service routine. The acknowledge sequence consists of an aborted instruction fetch, the interrupt acknowledge, and two writes to push the contents of the program counter onto the stack. Execution then begins at 0x0066 with an instruction fetch. The non-maskable interrupt service routine must end with the RETN instruction to properly restore the state of the interrupt enable flag prior to the non-maskable interrupt.



#### **Interrupt Mode 0**

The timing of a Mode 0 maskable interrupt acknowledge is shown below. The **int0\_req** signal needs to remain active until the interrupt acknowledge transaction. The acknowledge sequence consists of an aborted instruction fetch, the interrupt acknowledge, and two writes to push the contents of the program counter onto the stack. Execution then begins at the restart address specified by the RST instruction fetched during the interrupt acknowledge with an instruction fetch.



The use of an RST instruction is enforced by the hardware, which only uses bits 5-3 of the **ivec\_data\_in** bus to decode one of the eight possible RST instructions.

#### **Interrupt Mode 1**

The timing of a Mode 1 interrupt acknowledge cycle is shown below. The **int0\_req** input needs to remain active until the interrupt acknowledge transaction. The acknowledge sequence consists of an aborted instruction fetch, the interrupt acknowledge, and two writes to push the contents of the program counter onto the stack. Execution then begins at address 0x0038 with an instruction fetch.



#### **Interrupt Mode 2**

The timing of a Mode 2 maskable interrupt acknowledge is shown below. The **int0\_req**, **int1\_req** or **int2\_req** input needs to remain active until the interrupt acknowledge transaction. The acknowledge sequence consists of an aborted instruction fetch, the interrupt acknowledge, an address calculation cycle, two reads of the interrupt vector table and two writes to push the contents of the program counter onto the stack. The processor automatically jumps to the address fetched from the interrupt vector table for the service routine. The upper eight bits of the interrupt vector table starting address are held in the I register in the processor. Note that the vector must be an even number. That is, the least significant bit of the vector must be a zero.



### **DMA Request/Acknowledge**

The timing of a DMA request and acknowledge is shown below. Note that like an interrupt, the **dma\_req** signal is only sampled at the end of instructions. This guarantees that all instructions are atomic.

The delay from the **dma\_req** signal to the **dma\_ack** signal is always at least one bus cycle, irrespective of whether the processor is running, in the Halt state or in the Sleep state. This implies that it is more efficient to transfer multiple bytes each time that the **dma\_req** signal is activated.

The **dma\_req** signal can be asserted during the Halt or Sleep states. In this case the active **dma\_req** signal will take precedence over **int\_req** or **nmi\_req** and inhibit either of these signals from causing an exit from the Halt or Sleep state. Once the **dma\_req** signal is deasserted any pending or future interrupt request will cause the exit from the Halt or Sleep state.



#### Halt state

The Halt state is entered when the HALT instruction is executed, as shown below. In the Halt state the processor freezes, for an unlimited number of two clock cycle machine cycles, with the **halt\_tran** output active. The only way to exit the Halt state is with either an interrupt (either **nmi\_req**, **int\_req** or an internal interrupt) or via reset. Note that **int\_req** or an internal interrupt can only be used to exit the Halt mode if interrupts are enabled when the HALT instruction is executed. The timing for exiting the Halt state with an interrupt is also shown below.

If the Halt state is exited by an interrupt, the processor will resume instruction execution (after the interrupt service routine) at the address of the instruction following the HALT instruction. The minimum width of the **halt\_tran** signal is two clock cycles.



The Halt state in this design is slightly different from that in the Z80 or Z180 microprocessors. In those designs the processor continues to fetch the Halt instruction during the Halt state, leading to continued power dissipation. Since this operation requires the special step of "rewinding" the PC, no attempt was made to match this operation. Rather, the Halt state and the Sleep state are essentially identical, reducing the power consumption to a minimum by minimizing the number of signals that are transitioning during these states.

The Halt state differs from the Sleep state only for the case where interrupts are disabled. In the Halt state, if interrupts are disabled only the **nmi\_req** or a reset (from any of the various sources) will cause an exit from this state. In the Sleep state if interrupts are disabled a rising edge on the **int\_req** will force an exit from the Sleep state, with execution continuing with the instruction following the SLP instruction.

#### **Sleep state**

The Sleep state is entered when the SLP instruction is executed, as shown below. In the Sleep state the processor freezes, for an unlimited number of two clock cycle machine cycles, with the **sleep\_tran** output active. The only way to exit the Sleep state is with either an interrupt (either **nmi\_req**, **int\_req** or an internal interrupt) or via reset. The **int\_req** signal or an internal interrupt can be used to exit the Sleep mode irrespective of whether or not interrupts are enabled when the SLP instruction is executed.

The timing for exiting the Sleep state with an enabled interrupt or non-maskable interrupt is shown below. In this case the processor will resume instruction execution (after the interrupt service routine) at the address of the instruction following the SLP instruction.



In the case where the Sleep state exit is caused by a maskable interrupt while interrupts are disabled the processor merely resumes execution at the address of the instruction following the SLP instruction, without going through an interrupt service routine. Note that the minimum width of the **sleep\_tran** signal is two clock cycles.



#### Reset

The Reset state is entered immediately when the **resetb** signal goes Low, independent of the current state, and this state continues until the first rising edge of **clkc** after the **resetb** signal is de-asserted. At this rising edge there is a one clock cycle transient state to set up the internal pipeline controls, and on the next clock the processor begins fetching the first instruction from address 0x0000.

Software starting at location 0x0000 must be able to distinguish between reset, execution of an RST 0 instruction or a trap. All of these cases cause the Program Counter to be reset to 0x0000.

The minimum width of the **resetb** signal is set by the flip-flops used in the design. The setup time for the **resetb** signal to the rising edge of the **clkc** signal is likewise determined by the flip-flops used in the design.

The **clearb** signal has the same timing requirements as the **resetb** signal. The **clearb** signal should only be used in the power-on case, and only affects those flip-flops not affected by the **resetb** signal.



# **Instruction Set**

This chapter presents the assembly language syntax, addressing modes, flag settings, binary encoding, and execution time for the Y90-180 instruction set. The entire instruction set is presented in alphabetical order.

The assembly language syntax is identical to that used by the original Zilog assembler. Different assembler programs may or may not use identical syntax. The syntax is presented generically at the beginning of each instruction, with the details presented for each addressing mode later in each entry.

The operation of each instruction is specified in a format similar to Verilog HDL for minimum ambiguity, but no descriptive text or examples are included.

The effect of the instruction on each flag is listed, with a brief description. Normally the flags are updated by the main operation of the instruction, but for some complex instructions different flags may be affected by different parts of the instruction. This is specified in the description. The flags are organized as below in the F (Flag) register:

| S | Z | U5 | Н | U3 | P/V | Ν | С |
|---|---|----|---|----|-----|---|---|
|---|---|----|---|----|-----|---|---|

These flags have the following meanings:

| Flag | Meaning                                                                                    |
|------|--------------------------------------------------------------------------------------------|
| S    | Sign (a copy of the MSB of the result).                                                    |
| Z    | Zero (indicating that the result was zero).                                                |
| U5   | Unused Bit 5 (an unused Flag register bit).                                                |
| Н    | Half-Carry (carry out of the lower nibble, used for BCD math).                             |
| U3   | Unused Bit 3 (an unused Flag register bit).                                                |
| P/V  | Parity/Overflow (parity of the result, or arithmetic overflow; depends on the instruction) |
| Ν    | Negative (add/subtract flag, necessary for BCD math)                                       |
| С    | Carry (arithmetic carry, or shift linkage bit)                                             |

Fields in the instruction are listed using shortcuts for common fields. These shortcuts should be self-explanatory in most cases, but will be detailed here for completeness.

The most common field in the instruction specifies a CPU register, employing the following encoding:

| rrr | <b>Register Selected</b> |
|-----|--------------------------|
| 000 | В                        |
| 001 | С                        |
| 010 | D                        |
| 011 | E                        |
| 100 | Н                        |
| 101 | L                        |
| 111 | A (Accumulator)          |

Word registers are similarly encoded, although the exact encoding depends on the instruction:

| dd, ss, tt, xx or yy | dd, ss Register | tt Register | xx Register | yy Register |
|----------------------|-----------------|-------------|-------------|-------------|
| 00                   | BC              | BC          | BC          | BC          |
| 01                   | DE              | DE          | DE          | DE          |
| 10                   | HL              | HL          | IX          | IY          |
| 11                   | SP              | AF          | SP          | SP          |

The execution time for instructions is always a multiple of two clocks. Any number in parentheses is the execution time when the prefetch is enabled, via the **en\_prftch** signal into the core. When enabled, the prefetch operation uses any address calculation time to look at the first byte of the next instruction. If this instruction byte can be pre-decoded the byte will be buffered for use when the current instruction finishes. This results in the execution time in parentheses. Only instructions that require more than one machine cycle to execute can be pre-decoded.

| ADC A, src | src: R, IM, IR, X                                                                                                                                                                                                                                                                                                                                      |
|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Operation: | A <= A + src + CF                                                                                                                                                                                                                                                                                                                                      |
| Flags:     | <ul> <li>S: Set if result is negative; cleared otherwise.</li> <li>Z: Set if result is zero; cleared otherwise.</li> <li>H: Set if arithmetic carry out of bit 3; cleared otherwise.</li> <li>P/V: Set if arithmetic overflow; cleared otherwise.</li> <li>N: Cleared.</li> <li>C: Set if arithmetic carry out of bit 7; cleared otherwise.</li> </ul> |

| Addressing<br>Modes | Assembly Syntax                | Encoding      | Clocks |
|---------------------|--------------------------------|---------------|--------|
| R:                  | ADC A, r                       | 10001rrr      | 2      |
| IM:                 | ADC A, n                       | 11001110      | 4      |
|                     | l                              | n             |        |
| IR:                 | ADC A, (HL)                    | 10001110      | 6 (4)  |
| X:                  | ADC A, (IX+d) or ADC A, (IY+d) | 11y11101      | 10 (8) |
|                     |                                | 10001110<br>d |        |

1. The **rrr** field uses the standard register select encoding

| src: RR                                                                                                                                                  |                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                             |
|----------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| HL <= HL + src + CF                                                                                                                                      |                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                             |
| <ul><li>Z: Set if result is zero; cleared othe</li><li>H: Set if arithmetic carry out of bit</li><li>P/V: Set if arithmetic overflow; cleared.</li></ul> | rwise.<br>11; cleared otherwise.<br>ared otherwise.                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                             |
| Assembly Syntax                                                                                                                                          | Encoding                                                                                                                                                                                                                                                                                                     | Clocks                                                                                                                                                                                                                                                                                                                                                                                      |
| ADC HL, ss                                                                                                                                               | 11101101<br>01ss1010                                                                                                                                                                                                                                                                                         | 4                                                                                                                                                                                                                                                                                                                                                                                           |
|                                                                                                                                                          | <ul> <li>S: Set if result is negative; cleared of</li> <li>Z: Set if result is zero; cleared other</li> <li>H: Set if arithmetic carry out of bit</li> <li>P/V: Set if arithmetic overflow; cleared.</li> <li>N: Cleared.</li> <li>C: Set if arithmetic carry out of bit</li> <li>Assembly Syntax</li> </ul> | S: Set if result is negative; cleared otherwise.         Z: Set if result is zero; cleared otherwise.         H: Set if arithmetic carry out of bit 11; cleared otherwise.         P/V: Set if arithmetic overflow; cleared otherwise.         N: Cleared.         C: Set if arithmetic carry out of bit 15; cleared otherwise.         Assembly Syntax         Encoding         ADC HL, ss |

1. The **ss** field uses the standard word register encoding.

# ADD

Add

| ADD A, src | src: R, IM, IR, X                                                                                                                                                                                                                                                                                                                                      |
|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Operation: | A <= A + src                                                                                                                                                                                                                                                                                                                                           |
| Flags:     | <ul> <li>S: Set if result is negative; cleared otherwise.</li> <li>Z: Set if result is zero; cleared otherwise.</li> <li>H: Set if arithmetic carry out of bit 3; cleared otherwise.</li> <li>P/V: Set if arithmetic overflow; cleared otherwise.</li> <li>N: Cleared.</li> <li>C: Set if arithmetic carry out of bit 7; cleared otherwise.</li> </ul> |

| Addressing<br>Modes | Assembly Syntax                | Encoding | Clocks |
|---------------------|--------------------------------|----------|--------|
| R:                  | ADD A, r                       | 10000rrr | 2      |
| IM:                 | ADD A, n                       | 11000110 | 4      |
|                     |                                | n        |        |
| IR:                 | ADD A, (HL)                    | 10000110 | 6 (4)  |
| X:                  | ADD A, (IX+d) or ADD A, (IY+d) | 11y11101 | 10 (8) |
|                     |                                | 10000110 |        |
|                     |                                | d        |        |

Notes:

1. The  ${\bf rrr}$  field uses the standard register select encoding.

| ADC dst, src        |                                                                                                                                                                                        | dst: HL, IX, IY<br>src: RR |        |
|---------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------|--------|
| Operation:          | dst <= dst + src                                                                                                                                                                       |                            |        |
| Flags:              | <ul> <li>S: Unaffected.</li> <li>Z: Unaffected.</li> <li>H: Set if arithmetic carry out of P/V: Unaffected.</li> <li>N: Cleared.</li> <li>C: Set if arithmetic carry out of</li> </ul> |                            |        |
| Addressing<br>Modes | Assembly Syntax                                                                                                                                                                        | Encoding                   | Clocks |
| RR:                 | ADD HL, ss                                                                                                                                                                             | 00ss1001                   | 2      |
|                     | ADC IX, xx                                                                                                                                                                             | 11011101<br>01xx1001       | 4      |
|                     | ADC IY, yy                                                                                                                                                                             | 11111101<br>01yy1001       | 4      |

1. The ss, xx and yy fields use the standard word register select encodings.

| AND A, src | src: R, IM, IR, X                                                                                                                                                                                                                                    |
|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Operation: | A <= A & src                                                                                                                                                                                                                                         |
| Flags:     | <ul> <li>S: Set if result is negative; cleared otherwise.</li> <li>Z: Set if result is zero; cleared otherwise.</li> <li>H: Set.</li> <li>P/V: Set if parity of result even; cleared otherwise.</li> <li>N: Cleared.</li> <li>C: Cleared.</li> </ul> |

| Addressing<br>Modes | Assembly Syntax                | Encoding | Clocks |
|---------------------|--------------------------------|----------|--------|
| R:                  | AND A, r                       | 10100rrr | 2      |
| IM:                 | AND A, n                       | 11100110 | 4      |
|                     |                                | n        |        |
| IR:                 | AND A, (HL)                    | 10100110 | 6 (4)  |
| X:                  | AND A, (IX+d) or AND A, (IY+d) | 11y11101 | 10 (8) |
|                     |                                | 10100110 |        |
|                     |                                | d        |        |

1. The **rrr** field uses the standard register select encoding.

# BIT

Bit Test

| BIT b, src | src: R, IR, X                                                      |
|------------|--------------------------------------------------------------------|
| Operation: | $Z \leq -src[b]$                                                   |
| Flags:     | S: Unaffected.<br>Z: Set if tested bit is zero; cleared otherwise. |
|            | H: Set.                                                            |
|            | P/V: Unaffected.                                                   |
|            | N: Cleared.                                                        |
|            | C: Unaffected.                                                     |
|            |                                                                    |
|            |                                                                    |

| Addressing<br>Modes | Assembly Syntax                | Encoding  | Clocks |
|---------------------|--------------------------------|-----------|--------|
| R:                  | BIT b, r                       | 11001011  | 4      |
|                     |                                | 01bbbrrr  |        |
| IR:                 | BIT b, (HL)                    | 10100110  | 8 (6)  |
|                     |                                | 01bbb1110 |        |
| X:                  | BIT b, (IX+d) or BIT b, (IY+d) | 11y11101  | 10     |
|                     |                                | 11001011  |        |
|                     |                                | d         | _      |
|                     |                                | 01bbb110  |        |

Notes:

1. The **rrr** field uses the standard register select encoding.

- 3. The **bbb** field uses normal binary encoding.
- 4. For the original Z80, the **S** and **C** flags are undefined.

# CALL Call Subroutine

| CALL dst            |                                                                                                                                                              | dst: DA            |        |
|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------|--------|
| Operation:          | SP <= SP - 2<br>(SP) <= PC<br>PC <= dst                                                                                                                      |                    |        |
| Flags:              | <ul> <li>S: Unaffected.</li> <li>Z: Unaffected.</li> <li>H: Unaffected.</li> <li>P/V: Unaffected.</li> <li>N: Unaffected.</li> <li>C: Unaffected.</li> </ul> |                    |        |
| Addressing<br>Modes | Assembly Syntax                                                                                                                                              | Encoding           | Clocks |
| DA:                 | CALL mn                                                                                                                                                      | 11001101<br>n<br>m | 10     |

# CALL Conditional Call Subroutine

|                                                                                                                                                              | dst: DA                                                                                                                                                                      |                                                                                                                                                                                    |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| if (cc = true) begin<br>SP <= SP - 2<br>(SP) <= PC<br>PC <= dst<br>end                                                                                       |                                                                                                                                                                              |                                                                                                                                                                                    |
| <ul> <li>S: Unaffected.</li> <li>Z: Unaffected.</li> <li>H: Unaffected.</li> <li>P/V: Unaffected.</li> <li>N: Unaffected.</li> <li>C: Unaffected.</li> </ul> |                                                                                                                                                                              |                                                                                                                                                                                    |
| Assembly Syntax                                                                                                                                              | Encoding                                                                                                                                                                     | Clocks                                                                                                                                                                             |
| CALL cc, mn                                                                                                                                                  | 11fff100<br>n<br>m                                                                                                                                                           | 10/6<br>(taken/not taken)                                                                                                                                                          |
|                                                                                                                                                              | SP <= SP - 2<br>(SP) <= PC<br>PC <= dst<br>end<br>S: Unaffected.<br>Z: Unaffected.<br>H: Unaffected.<br>N: Unaffected.<br>N: Unaffected.<br>C: Unaffected.<br>C: Unaffected. | if (cc = true) begin<br>$SP <= SP - 2$<br>$(SP) <= PC$<br>$PC <= dstendS: Unaffected.Z: Unaffected.H: Unaffected.H: Unaffected.P/V: Unaffected.N: Unaffected.Call cc, mn11fff100n$ |

| 1. | Mnemonic | Encoding (fff) | Meaning     | Flag case        |
|----|----------|----------------|-------------|------------------|
|    | NZ       | 000            | Non-zero    | $\mathbf{Z} = 0$ |
|    | Ζ        | 001            | Zero        | Z = 1            |
|    | NC       | 010            | Non-carry   | C = 0            |
|    | С        | 011            | Carry       | C = 1            |
|    | PO       | 100            | Parity Odd  | P/V = 0          |
|    | PE       | 101            | Parity Even | P/V = 1          |
|    | Р        | 110            | Plus        | $\mathbf{S} = 0$ |
|    | М        | 111            | Minus       | S = 1            |
|    |          |                |             |                  |

| CCF                 |                                                                                                                                                                                              |          |        |
|---------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|--------|
| Operation:          | CF <= ~CF                                                                                                                                                                                    |          |        |
| Flags:              | <ul> <li>S: Unaffected.</li> <li>Z: Unaffected.</li> <li>H: Copy of previous value of Ca</li> <li>P/V: Unaffected.</li> <li>N: Cleared.</li> <li>C: Set if previous Carry flag wa</li> </ul> |          |        |
| Addressing<br>Modes | Assembly Syntax                                                                                                                                                                              | Encoding | Clocks |
| IM:                 | CCF                                                                                                                                                                                          | 00111111 | 2      |
|                     |                                                                                                                                                                                              |          |        |

1. The default operation of the **H** flag for this instruction matches that of the original Z80 CPU. The original Z180 CPU behaves differently, clearing the **H** flag for this instruction. To enable Z180 compatibility, use the 'define Z180\_CCF option in the Verilog source code file version.v.

| CP A, src  | src: R, IM, IR, X                                                                                                                                                                                                                                                                                                                                    |
|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Operation: | A - src                                                                                                                                                                                                                                                                                                                                              |
| Flags:     | <ul> <li>S: Set if result is negative; cleared otherwise.</li> <li>Z: Set if result is zero; cleared otherwise.</li> <li>H: Set if arithmetic borrow out of bit 3; cleared otherwise.</li> <li>P/V: Set if arithmetic overflow; cleared otherwise.</li> <li>N: Set.</li> <li>C: Set if arithmetic borrow out of bit 7; cleared otherwise.</li> </ul> |

| Addressing<br>Modes | Assembly Syntax           | Encoding      | Clocks |
|---------------------|---------------------------|---------------|--------|
| R:                  | CP A, r                   | 10111rrr      | 2      |
| IM:                 | CP A, n                   | 11111110      | 4      |
|                     | L                         | n             |        |
| IR:                 | CP A, (HL)                | 10111110      | 6 (4)  |
| X:                  | CP A, (IX+d) or CP (IY+d) | 11y11101      | 10 (8) |
|                     | -                         | 10111110<br>d |        |

1. The  ${\bf rrr}$  field uses the standard register select encoding

| CPD                 |                                                                                                                                                                                                                                    |                                                            |           |
|---------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------|-----------|
| Operation:          | A - (HL)<br>HL <= HL - 1<br>BC <= BC - 1                                                                                                                                                                                           |                                                            |           |
| Flags:              | <ul> <li>Set if result of compare is nega</li> <li>Z: Set if result of compare is zero</li> <li>H: Set if arithmetic borrow out of</li> <li>P/V: Set if result of BC decrement</li> <li>N: Set.</li> <li>C: Unaffected.</li> </ul> | o; cleared otherwise.<br>f bit 3 during compare; cleared o | therwise. |
| Addressing<br>Modes | Assembly Syntax                                                                                                                                                                                                                    | Encoding                                                   | Clocks    |
|                     | CPD                                                                                                                                                                                                                                | 11101101<br>10101001                                       | 10 (8)    |

# **CPDR**

**Compare, Decrement and Repeat** 

## CPDR

| Operation: | A - (HL)<br>HL <= HL - 1<br>BC <= BC - 1<br>repeat if BC != 0 and A - (HL) != 0 |
|------------|---------------------------------------------------------------------------------|
|            |                                                                                 |
| Flags:     | S: Set if result of compare is negative, cleared otherwise.                     |
|            | Z: Set if result of compare is zero; cleared otherwise.                         |
|            | H: Set if arithmetic borrow out of bit 3 during compare; cleared otherwise.     |
|            | P/V: Set if result of BC decrement is non-zero; cleared otherwise.              |
|            | N: Set.                                                                         |
|            | C: Unaffected.                                                                  |
|            |                                                                                 |
|            |                                                                                 |

| Addressing<br>Modes | Assembly Syntax | Encoding | Clocks |
|---------------------|-----------------|----------|--------|
| С                   | PDR             | 11101101 | 8 + 4i |
|                     |                 | 10111001 |        |
|                     | L               |          |        |

### Notes:

1. This instruction can be interrupted after each iteration. The address saved on the stack in this case is the address of this instruction, allowing completion of the instruction after the interrupt service routine.

2. Interrupts are sampled during each memory read operation.

| CPI                 |                                                                                                                                                            |                             |               |
|---------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------|---------------|
| Operation:          | A - (HL)                                                                                                                                                   |                             |               |
| •                   | $HL \leq HL + 1$                                                                                                                                           |                             |               |
|                     | BC <= BC - 1                                                                                                                                               |                             |               |
| Flags:              | <ul> <li>S: Set if result of compare is negative</li> <li>Z: Set if result of compare is zero; of</li> <li>H: Set if arithmetic borrow out of b</li> </ul> | cleared otherwise.          | otherwise.    |
|                     | <b>P/V:</b> Set if result of decrementing BC is non-zero; cleared otherwise.                                                                               |                             |               |
|                     | N: Set.<br>C: Unaffected.                                                                                                                                  |                             |               |
|                     | C. Onanected.                                                                                                                                              |                             |               |
|                     |                                                                                                                                                            |                             |               |
| Addressing<br>Modes | Assembly Syntax                                                                                                                                            | Encoding                    | Clocks        |
| -                   | Assembly Syntax                                                                                                                                            | <b>Encoding</b><br>11101101 | <b>Clocks</b> |

# CPIR

**Compare, Increment and Repeat** 

## CPIR

| Operation: | A - (HL)<br>HL <= HL + 1<br>BC <= BC - 1<br>repeat if BC != 0 and A - (HL) != 0                                                                                                                                                                                                                                                                               |
|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Flags:     | <ul> <li>S: Set if result of compare is negative, cleared otherwise.</li> <li>Z: Set if result of compare is zero; cleared otherwise.</li> <li>H: Set if arithmetic borrow out of bit 3 during compare; cleared otherwise.</li> <li>P/V: Set if result of decrementing BC is non-zero; cleared otherwise.</li> <li>N: Set.</li> <li>C: Unaffected.</li> </ul> |

| Addressing<br>Modes | Assembly Syntax | Encoding | Clocks |
|---------------------|-----------------|----------|--------|
| (                   | CPIR            | 11101101 | 8 + 4i |
|                     |                 | 10110001 |        |
|                     |                 |          | -      |

#### Notes:

1. This instruction can be interrupted after each iteration. The address saved on the stack in this case is the address of this instruction, allowing completion of the instruction after the interrupt service routine

2. Interrupts are sampled during each memory read operation.

| CPL                 |                                                                                                                                                |          |        |
|---------------------|------------------------------------------------------------------------------------------------------------------------------------------------|----------|--------|
| Operation:          | A <= ~A                                                                                                                                        |          |        |
| Flags:              | <ul> <li>S: Unaffected.</li> <li>Z: Unaffected.</li> <li>H: Set.</li> <li>P/V: Unaffected.</li> <li>N: Set.</li> <li>C: Unaffected.</li> </ul> |          |        |
| Addressing<br>Modes | Assembly Syntax                                                                                                                                | Encoding | Clocks |
|                     | CPL                                                                                                                                            | 00101111 | 2      |

## DAA

| Operation: | A <= Decimal Adjust A                                  |
|------------|--------------------------------------------------------|
| Flags:     | S: Set if result is negative; cleared otherwise.       |
|            | <b>Z</b> : Set if result is zero; cleared otherwise.   |
|            | H: See table below.                                    |
|            | P/V: Set if result has even parity; cleared otherwise. |
|            | N: Unaffected.                                         |
|            | C: See table below.                                    |
|            |                                                        |
| Addressing |                                                        |

| Addressing<br>Modes | Assembly Syntax | Encoding | Clocks |
|---------------------|-----------------|----------|--------|
| DAA                 |                 | 00100111 | 2      |

Notes:

| Instruction          | C before | A[7:4]     | H before | A[3:0]     | Number     | C after |
|----------------------|----------|------------|----------|------------|------------|---------|
| Instruction          | DAA      | before DAA | DAA      | before DAA | added to A | DAA     |
|                      | 0        | 0-9        | 0        | 0-9        | 00         | 0       |
|                      | 0        | 0-8        | 0        | A-F        | 06         | 0       |
|                      | 0        | 0-9        | 1        | 0-3        | 06         | 0       |
| ADC, ADD or INC      | 0        | A-F        | 0        | 0-9        | 60         | 1       |
|                      | 0        | 9-F        | 0        | A-F        | 66         | 1       |
|                      | 0        | A-F        | 1        | 0-3        | 66         | 1       |
|                      | 1        | 0-2        | 0        | 0-9        | 60         | 1       |
|                      | 1        | 0-2        | 0        | A-F        | 66         | 1       |
|                      | 1        | 0-3        | 1        | 0-3        | 66         | 1       |
|                      | 0        | 0-9        | 0        | 0-9        | 00         | 0       |
| DEC, NEG, SUB or SBC | 0        | 0-8        | 1        | 6-F        | FA         | 0       |
|                      | 1        | 7-F        | 0        | 0-9        | A0         | 1       |
|                      | 1        | 6-F        | 1        | 6-F        | 9A         | 1       |

| DEC dst    | dst: R, IR, X                                                                                                                                                                                                                                                                                          |
|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Operation: | dst <= dst - 1                                                                                                                                                                                                                                                                                         |
| Flags:     | <ul> <li>S: Set if result is negative; cleared otherwise.</li> <li>Z: Set if result is zero; cleared otherwise.</li> <li>H: Set if arithmetic borrow out of bit 3; cleared otherwise.</li> <li>P/V: Set if arithmetic overflow; cleared otherwise.</li> <li>N: Set.</li> <li>C: Unaffected.</li> </ul> |

| Addressing<br>Modes | Assembly Syntax          | Encoding      | Clocks  |
|---------------------|--------------------------|---------------|---------|
| R:                  | DEC r                    | 00rrr101      | ] 2     |
| IR:                 | DEC (HL)                 | 00110101      | 8 (6)   |
| X:                  | DEC (IX+d) or DEC (IY+d) | 11y11101      | 12 (10) |
|                     |                          | 00110101<br>d |         |

1. The **rrr** field uses the standard register select encoding

# **DEC** Decrement (Word)

| dst - 1<br>ffected.<br>ffected.<br>ffected. |                 |                                                           |                                   |
|---------------------------------------------|-----------------|-----------------------------------------------------------|-----------------------------------|
| ffected.<br>ffected.                        |                 |                                                           |                                   |
| naffected.<br>ffected.<br>ffected.          |                 |                                                           |                                   |
| Assembly Syntax                             | Encodir         | ng                                                        | Clocks                            |
| 1                                           | 00dd101         | 11                                                        | 2                                 |
| K or DEC IY                                 |                 |                                                           | 4                                 |
| 1                                           | Assembly Syntax | Assembly Syntax Encodin<br>000dd10<br>C or DEC IY 11y1110 | Assembly Syntax Encoding 00dd1011 |

Notes:

1. The **dd** field uses the standard word register encoding.

| DI                  |                                                                                                                                                              |          |        |
|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|--------|
| Operation:          | IFF1 <= 0<br>IFF2 <= 0                                                                                                                                       |          |        |
| Flags:              | <ul> <li>S: Unaffected.</li> <li>Z: Unaffected.</li> <li>H: Unaffected.</li> <li>P/V: Unaffected.</li> <li>N: Unaffected.</li> <li>C: Unaffected.</li> </ul> |          |        |
| Addressing<br>Modes | Assembly Syntax                                                                                                                                              | Encoding | Clocks |
|                     | DI                                                                                                                                                           | 11110011 | 2      |
|                     |                                                                                                                                                              |          |        |

1. Interrupts are last sampled during the machine cycle that fetches this instruction.

# DJNZ

Decrement, Jump if Non-zero

### **DJNZ** e

| Operation:          | B <= B - 1<br>if (B != 0) PC <= PC + e (where PC is the PC of this instruction)<br>S: Unaffected.<br>Z: Unaffected.<br>H: Unaffected.<br>P/V: Unaffected.<br>N: Unaffected.<br>C: Unaffected. |                    |        |  |
|---------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------|--------|--|
| Flags:              |                                                                                                                                                                                               |                    |        |  |
| Addressing<br>Modes | Assembly Syntax                                                                                                                                                                               | Encoding           | Clocks |  |
|                     | DJNZ e                                                                                                                                                                                        | 00010000<br>(e-2)- | 6      |  |

### Notes:

1. Relative to the address of this instruction, the jump range is -126 to +129. Relative to the address of the next instruction, the jump range is -128 to +127.

| EI                  |                                                                                                                                                              |          |        |
|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|--------|
| Operation:          | IFF1 <= 1<br>IFF2 <= 1                                                                                                                                       |          |        |
| Flags:              | <ul> <li>S: Unaffected.</li> <li>Z: Unaffected.</li> <li>H: Unaffected.</li> <li>P/V: Unaffected.</li> <li>N: Unaffected.</li> <li>C: Unaffected.</li> </ul> |          |        |
| Addressing<br>Modes | Assembly Syntax                                                                                                                                              | Encoding | Clocks |
|                     | EI                                                                                                                                                           | 11111011 | 2      |
|                     |                                                                                                                                                              |          |        |

1. Interrupts are first sampled during the fetch of the next instruction. If an interrupt is pending this instruction fetch will be ignored and an interrupt acknowledge cycle started.

# EX

## Exchange with Top-of-Stack

| EX (SP), src        |                                                                                                                                                              | src: HL, IX, IY      |         |
|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------|---------|
| Operation:          | (SP) <=> L or IXL or IYL<br>(SP+1) <=> H or IXH or IYH                                                                                                       |                      |         |
| Flags:              | <ul> <li>S: Unaffected.</li> <li>Z: Unaffected.</li> <li>H: Unaffected.</li> <li>P/V: Unaffected.</li> <li>N: Unaffected.</li> <li>C: Unaffected.</li> </ul> |                      |         |
| Addressing<br>Modes | Assembly Syntax                                                                                                                                              | Encoding             | Clocks  |
|                     | EX (SP), HL                                                                                                                                                  | 11100011             | 12 (10) |
|                     | EX (SP), IX or EX (SP), IY                                                                                                                                   | 11y11101<br>11100011 | 14 (12) |

Notes:

EX AF, AF' Exchange Accumulator

|                     | EX AF, AF'                                                                                                                                                                                                           | 00001000 | 2      |
|---------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|--------|
| Addressing<br>Modes | Assembly Syntax                                                                                                                                                                                                      | Encoding | Clocks |
|                     | <ul> <li>Z: Replaced by alternate flag.</li> <li>H: Replaced by alternate flag.</li> <li>P/V: Replaced by alternate flag.</li> <li>N: Replaced by alternate flag.</li> <li>C: Replaced by alternate flag.</li> </ul> |          |        |
| Flags:              | S: Replaced by alternate flag.                                                                                                                                                                                       |          |        |
| Operation:          | AF <=> AF'                                                                                                                                                                                                           |          |        |
| EX AF, AF'          |                                                                                                                                                                                                                      |          |        |

## Notes:

1. No data is actually moved. Instead the registers are renamed.

## EX DE, HL

| Operation:          | DE <=> HL                                                                                                                                                    |          |        |
|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|--------|
| Flags:              | <ul> <li>S: Unaffected.</li> <li>Z: Unaffected.</li> <li>H: Unaffected.</li> <li>P/V: Unaffected.</li> <li>N: Unaffected.</li> <li>C: Unaffected.</li> </ul> |          |        |
| Addressing<br>Modes | Assembly Syntax                                                                                                                                              | Encoding | Clocks |
|                     | EX DE, HL                                                                                                                                                    | 11101011 | ] 2    |

|                     | EXX                                | 11011001 | 2      |
|---------------------|------------------------------------|----------|--------|
| Addressing<br>Modes | Assembly Syntax                    | Encoding | Clocks |
|                     | N: Unaffected.<br>C: Unaffected.   |          |        |
|                     | H: Unaffected.<br>P/V: Unaffected. |          |        |
| 8                   | <b>Z:</b> Unaffected.              |          |        |
| Flags:              | S: Unaffected.                     |          |        |
|                     | HL <=> HL'                         |          |        |
|                     | DE <=> DE'                         |          |        |
| Operation:          | BC <=> BC'                         |          |        |
|                     |                                    |          |        |

1. No data is actually moved. Instead the registers are renamed.

# HALT

Halt

## HALT

| Operation:          | activate Halt signal and wait for                                                                                                                            | r interrupt |        |
|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------|
| Flags:              | <ul> <li>S: Unaffected.</li> <li>Z: Unaffected.</li> <li>H: Unaffected.</li> <li>P/V: Unaffected.</li> <li>N: Unaffected.</li> <li>C: Unaffected.</li> </ul> |             |        |
| Addressing<br>Modes | Assembly Syntax                                                                                                                                              | Encoding    | Clocks |
|                     | HALT                                                                                                                                                         | 01110110    | 4 + 2n |

### Notes:

1. The CPU halts with an idle bus until an interrupt is requested. The address pushed to the stack during the interrupt acknowledge is the address of the next instruction. During Halt the **mem\_addr\_bus** and **io\_addr\_bus** are driven with 0x0000, and the **mem\_data\_bus** and **io\_data\_bus** are driven with 0x000.

### IM i

| Operation: | Set Interrupt Mode i |
|------------|----------------------|
| Flags:     | S: Unaffected.       |
| 8          | Z: Unaffected.       |
|            | H: Unaffected.       |
|            | P/V: Unaffected.     |
|            | N: Unaffected.       |
|            | C: Unaffected.       |
|            |                      |

| Addressing<br>Modes | Assembly Syntax | Encoding | Clocks |
|---------------------|-----------------|----------|--------|
| IM                  | 0               | 11101101 | 4      |
|                     |                 | 01000110 |        |
|                     |                 |          |        |
| IM                  | 1               | 11101101 | 4      |
|                     |                 | 01010110 |        |
|                     |                 |          |        |
| IM                  | 2               | 11101101 | 4      |
|                     |                 | 01011110 |        |
|                     |                 |          |        |

#### Notes:

1. Interrupt Mode 0 expects an RST instruction on the **ivec\_bus** during the interrupt acknowledge cycle. Only an RST instruction is allowed.

2. Interrupt Mode 1 always jumps to location 0x0038 in response to a maskable interrupt request.

3. Interrupt Mode 2 uses the interrupt vector returned on the **ivec\_bus** during an interrupt acknowledge cycle, along with the contents of the I register, to access an interrupt vector table in memory. The address stored at the selected location in the interrupt vector table is the starting addess of the interrupt service routine. Note that the least-significant bit of the interrupt vector must be zero to account for the two-byte entries in the interrupt vector table.

IN

## Input

| IN A, src           |                         | src: DA  |        |
|---------------------|-------------------------|----------|--------|
| Operation:          | $A \le I/O(A:n)$        |          |        |
| Flags:              | S: Unaffected.          |          |        |
| 8                   | Z: Unaffected.          |          |        |
|                     | H: Unaffected.          |          |        |
|                     | <b>P/V:</b> Unaffected. |          |        |
|                     | N: Unaffected.          |          |        |
|                     | C: Unaffected.          |          |        |
| Addressing<br>Modes | Assembly Syntax         | Encoding | Clocks |
|                     | IN A, (n)               | 11011011 | 8 (6)  |
|                     |                         | n        |        |

| <b>IN</b> r, (C)    | dst: R                                                                                                                                                                                                                                                                                     |                      |        |  |
|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------|--------|--|
| Operation:          | r <= I/O(BC)                                                                                                                                                                                                                                                                               |                      |        |  |
| Flags:              | <ul> <li>S: Set if the input data is negative; cleared otherwise.</li> <li>Z: Set if the input data is zero; cleared otherwise.</li> <li>H: Cleared.</li> <li>P/V: Set if the parity of the input data is even; cleared otherwise.</li> <li>N: Cleared.</li> <li>C: Unaffected.</li> </ul> |                      |        |  |
| Addressing<br>Modes | Assembly Syntax                                                                                                                                                                                                                                                                            | Encoding             | Clocks |  |
|                     | IN r, (C)                                                                                                                                                                                                                                                                                  | 11101101<br>01rrr000 | 8 (6)  |  |
|                     |                                                                                                                                                                                                                                                                                            |                      |        |  |

1. The **rrr** field uses the standard register select encoding

# IN0

Input (page 0)

| dst: R                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                              |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| r <= I/O(0:n)                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                              |
| <ul> <li>S: Set if input byte is negative; cleared otherwise.</li> <li>Z: Set if input byte is zero; cleared otherwise.</li> <li>H: Cleared.</li> <li>P/V: Set if parity of input byte is even; cleared otherwise.</li> <li>N: Cleared.</li> <li>C: Unaffected.</li> </ul> |                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                              |
| Assembly Syntax                                                                                                                                                                                                                                                            | Encoding                                                                                                                                                                                                       | Clocks                                                                                                                                                                                                                                                                       |
| IN0 r, (n)                                                                                                                                                                                                                                                                 | 11101101<br>00rrr000<br>n                                                                                                                                                                                      | 10 (8)                                                                                                                                                                                                                                                                       |
|                                                                                                                                                                                                                                                                            | r <= I/O(0:n)<br>S: Set if input byte is negative; clear<br>Z: Set if input byte is zero; cleared<br>H: Cleared.<br>P/V: Set if parity of input byte is ev<br>N: Cleared.<br>C: Unaffected.<br>Assembly Syntax | r <= I/O(0:n)<br>S: Set if input byte is negative; cleared otherwise.<br>Z: Set if input byte is zero; cleared otherwise.<br>H: Cleared.<br>P/V: Set if parity of input byte is even; cleared otherwise.<br>N: Cleared.<br>C: Unaffected.<br>IN0 r, (n) III01101<br>00rrr000 |

### Notes:

1. The **rrr** field uses the standard register select encoding

2. This instruction is not present in the original Z80, but is a feature of the Z180.

| INC dst    | dst: R, IR, X                                                                                                                                                                                                                                                                                             |
|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Operation: | $dst \ll dst + 1$                                                                                                                                                                                                                                                                                         |
| Flags:     | <ul> <li>S: Set if result is negative; cleared otherwise.</li> <li>Z: Set if result is zero; cleared otherwise.</li> <li>H: Set if arithmetic carry out of bit 3; cleared otherwise.</li> <li>P/V: Set if arithmetic overflow; cleared otherwise.</li> <li>N: Cleared.</li> <li>C: Unaffected.</li> </ul> |

| Addressing<br>Modes | Assembly Syntax          | Encoding | Clocks  |
|---------------------|--------------------------|----------|---------|
| R:                  | INC r                    | 00rrr100 | 2       |
| IR:                 | INC (HL)                 | 00110100 | 8 (6)   |
| X:                  | INC (IX+d) or INC (IY+d) | 11y11101 | 12 (10) |
|                     |                          | 00110100 |         |
|                     |                          | u        |         |

1. The **rrr** field uses the standard register select encoding

# INC Increment (Word)

| INC dst             |                                                                                                                                                              | dst: RR, IX, IY      |        |
|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------|--------|
| Operation:          | $dst \leq dst + 1$                                                                                                                                           |                      |        |
| Flags:              | <ul> <li>S: Unaffected.</li> <li>Z: Unaffected.</li> <li>H: Unaffected.</li> <li>P/V: Unaffected.</li> <li>N: Unaffected.</li> <li>C: Unaffected.</li> </ul> |                      |        |
| Addressing<br>Modes | Assembly Syntax                                                                                                                                              | Encoding             | Clocks |
| RR:                 | INC ss                                                                                                                                                       | 00dd0011             | 2      |
| IX, IY              | INC IX or INC IY                                                                                                                                             | 11y11101<br>00100011 | 4      |

Notes:

1. The **dd** field uses the standard word register encoding.

| IND        |                                                                                  |           |        |
|------------|----------------------------------------------------------------------------------|-----------|--------|
| Operation: | (HL) <= I/O(BC)                                                                  |           |        |
|            | B <= B - 1                                                                       |           |        |
|            | HL <= HL -1                                                                      |           |        |
|            | S. Unoffected                                                                    |           |        |
| Flags:     | S: Unaffected.<br>Z: Set if result of decrementing B is zero; cleared otherwise. |           |        |
|            | H: Unaffected.                                                                   |           |        |
|            | P/V: Unaffected.                                                                 |           |        |
|            | N: Set.                                                                          |           |        |
|            | C: Unaffected.                                                                   |           |        |
| Addressing | Assembly Syntax                                                                  | Encoding  | Clocks |
| Modes      | Assembly Syntax                                                                  | Elicounig | CIUCKS |
|            |                                                                                  |           |        |
|            | IND                                                                              | 11101101  | 10 (8) |

# INDR

**Input, Decrement and Repeat** 

## INDR

| Operation: | (HL) <= I/O(BC)<br>B <= B - 1<br>HL <= HL -1                           |
|------------|------------------------------------------------------------------------|
|            | repeat if B != 0                                                       |
|            |                                                                        |
| Flags:     | S: Unaffected.                                                         |
|            | <b>Z</b> : Set if result of decrementing B is zero; cleared otherwise. |
|            | H: Unaffected.                                                         |
|            | P/V: Unaffected.                                                       |
|            | N: Set.                                                                |
|            | C: Unaffected.                                                         |
|            |                                                                        |

| Addressing<br>Modes | Assembly Syntax | Encoding | Clocks |
|---------------------|-----------------|----------|--------|
|                     | INDR            | 11101101 | 8 + 4i |
|                     |                 | 10111010 |        |
|                     |                 |          |        |

#### Notes:

1. This instruction can be interrupted after each iteration. The address saved on the stack in this case is the address of this instruction, allowing completion of the instruction after the interrupt service routine

2. Interrupts are sampled during each I/O read operation.

| INI        |                                                                                                                                  |                            |        |  |  |
|------------|----------------------------------------------------------------------------------------------------------------------------------|----------------------------|--------|--|--|
| Operation: | $(HL) \leq I/O(BC)$ $B \leq B - 1$                                                                                               |                            |        |  |  |
| -          |                                                                                                                                  |                            |        |  |  |
|            | HL <= HL + 1                                                                                                                     |                            |        |  |  |
| Fleese     |                                                                                                                                  |                            |        |  |  |
| Flags:     | S: Unaffected.<br>7: Set if result of decrementing B                                                                             | is zero: cleared otherwise |        |  |  |
|            | <ul><li>Z: Set if result of decrementing B is zero; cleared otherwise.</li><li>H: Unaffected.</li><li>P/V: Unaffected.</li></ul> |                            |        |  |  |
|            |                                                                                                                                  |                            |        |  |  |
|            | N: Set.                                                                                                                          |                            |        |  |  |
|            | C: Unaffected.                                                                                                                   |                            |        |  |  |
| Addressing |                                                                                                                                  |                            |        |  |  |
| Modes      | Assembly Syntax                                                                                                                  | Encoding                   | Clocks |  |  |
|            | INI                                                                                                                              | 11101101                   | 10 (8) |  |  |
|            |                                                                                                                                  | 10100010                   |        |  |  |
|            |                                                                                                                                  |                            |        |  |  |

# INIR

**Input, Increment and Repeat** 

### INIR

| Operation: | $(HL) \le I/O(BC)$<br>B <= B - 1<br>HL <= HL + 1               |  |  |
|------------|----------------------------------------------------------------|--|--|
|            | repeat if B != 0                                               |  |  |
|            |                                                                |  |  |
| Flags:     | S: Unaffected.                                                 |  |  |
|            | Z: Set if result of decrementing B is zero; cleared otherwise. |  |  |
|            | H: Unaffected.                                                 |  |  |
|            | P/V: Unaffected.                                               |  |  |
|            | N: Set.                                                        |  |  |
|            | C: Unaffected.                                                 |  |  |
|            |                                                                |  |  |

| Addressing<br>Modes | Assembly Syntax | Encoding | Clocks |
|---------------------|-----------------|----------|--------|
| II                  | VIR             | 11101101 | 8 + 6i |
|                     |                 | 10110010 |        |
|                     |                 |          |        |

### Notes:

1. This instruction can be interrupted after each iteration. The address saved on the stack in this case is the address of this instruction, allowing completion of the instruction after the interrupt service routine

2. Interrupts are sampled during each I/O read operation.

| JP dst              |                                                                                                                                                              | dst: IM, IR |        |
|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------|
| Operation:          | PC <= dst                                                                                                                                                    |             |        |
| Flags:              | <ul> <li>S: Unaffected.</li> <li>Z: Unaffected.</li> <li>H: Unaffected.</li> <li>P/V: Unaffected.</li> <li>N: Unaffected.</li> <li>C: Unaffected.</li> </ul> |             |        |
| Addressing<br>Modes | Assembly Syntax                                                                                                                                              | Encoding    | Clocks |
| IR:                 | JP (HL)                                                                                                                                                      | 11101001    | 4      |

| 1 | Л; | JF (FIL)           | 11101001 | 4 |
|---|----|--------------------|----------|---|
|   |    |                    |          |   |
|   |    | JP (IX) or JP (IY) | 11y11101 | 6 |
|   |    |                    | 11101001 |   |
|   |    | -                  |          |   |
| Ι | M: | JP mn              | 11000011 | 8 |
|   |    |                    | n        |   |
|   |    |                    | m        |   |
|   |    | -                  |          |   |

1. The indirect jumps use the contents of the register directly for the jump address.

#### JP cc, mn

if (cc = true) PC <= mn **Operation:** Flags: S: Unaffected. **Z:** Unaffected. H: Unaffected. **P/V:** Unaffected. N: Unaffected. C: Unaffected. Addressing Assembly Syntax Encoding Clocks Modes 11fff010 IM: JP cc, mn 8 (taken) 6 (not taken) ----n--------m----

#### Notes:

| 1. | Mnemonic | Encoding (fff) | Meaning     | Flag case        |
|----|----------|----------------|-------------|------------------|
|    | NZ       | 000            | Non-zero    | $\mathbf{Z} = 0$ |
|    | Z        | 001            | Zero        | Z = 1            |
|    | NC       | 010            | Non-carry   | C = 0            |
|    | С        | 011            | Carry       | C = 1            |
|    | РО       | 100            | Parity Odd  | P/V = 0          |
|    | PE       | 101            | Parity Even | P/V = 1          |
|    | Р        | 110            | Plus        | $\mathbf{S} = 0$ |
|    | М        | 111            | Minus       | S = 1            |

#### JR e

| Operation: | $PC \le PC + e$ (where PC is the PC of this instruction) |          |        |  |
|------------|----------------------------------------------------------|----------|--------|--|
| Flags:     | S: Unaffected.                                           |          |        |  |
| C          | Z: Unaffected.                                           |          |        |  |
|            | H: Unaffected.                                           |          |        |  |
|            | P/V: Unaffected.                                         |          |        |  |
|            | N: Unaffected.                                           |          |        |  |
|            | C: Unaffected.                                           |          |        |  |
| Addressing |                                                          |          |        |  |
| Modes      | Assembly Syntax                                          | Encoding | Clocks |  |
|            |                                                          |          |        |  |
|            | JR e                                                     | 00011000 | 6      |  |

#### Notes:

1. Relative to the address of this instruction, the jump range is -126 to +129. Relative to the address of the next instruction, the jump range is -128 to +127.

#### JR cc, e

| Operation:          | if (cc = true) $PC \le PC + e$ (where PC is the PC of this instruction) |          |           |  |
|---------------------|-------------------------------------------------------------------------|----------|-----------|--|
| Flags:              | S: Unaffected.                                                          |          |           |  |
| 8                   | Z: Unaffected.                                                          |          |           |  |
|                     | H: Unaffected.                                                          |          |           |  |
|                     | P/V: Unaffected.                                                        |          |           |  |
|                     | N: Unaffected.                                                          |          |           |  |
|                     | C: Unaffected.                                                          |          |           |  |
| Addressing<br>Modes | Assembly Syntax                                                         | Encoding | Clocks    |  |
|                     | JR cc, e                                                                | 001cc000 | 6 (taken) |  |
|                     |                                                                         |          |           |  |

#### Notes:

1. Relative to the address of this instruction, the jump range is -126 to +129. Relative to the address of the next instruction, the jump range is -128 to +127.

| 1. | Mnemonic | Encoding (cc) | Meaning   | Flag case        |
|----|----------|---------------|-----------|------------------|
|    | NZ       | 00            | Non-zero  | $\mathbf{Z} = 0$ |
|    | Z        | 01            | Zero      | Z = 1            |
|    | NC       | 10            | Non-carry | C = 0            |
|    | С        | 11            | Carry     | C = 1            |

## LD Load Accumulator from Memory

| LD A, src           |                                                                                                                                                              | src: DA, IR        |        |  |
|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------|--------|--|
| Operation:          | A <= src                                                                                                                                                     |                    |        |  |
| Flags:              | <ul> <li>S: Unaffected.</li> <li>Z: Unaffected.</li> <li>H: Unaffected.</li> <li>P/V: Unaffected.</li> <li>N: Unaffected.</li> <li>C: Unaffected.</li> </ul> |                    |        |  |
| Addressing<br>Modes | Assembly Syntax                                                                                                                                              | Encoding           | Clocks |  |
| DA:                 | LD A, (mn)                                                                                                                                                   | 00111010<br>n<br>m | 10 (8) |  |
| IR:                 | LD A, (BC)                                                                                                                                                   | 00001010           | 6 (4)  |  |
|                     | LD A, (DE)                                                                                                                                                   | 00011010           | 6 (4)  |  |

### Load Accumulator from Special Register

| LD A, src           | src: special register                                                                                                                                                                                                                                                                                                              |                      |        |  |  |
|---------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------|--------|--|--|
| Operation:          | A <= src                                                                                                                                                                                                                                                                                                                           |                      |        |  |  |
| Flags:              | <ul> <li>S: Set if the contents of the Special Register is negative; cleared otherwise.</li> <li>Z: Set if the contents of the Special Register is zero; cleared otherwise.</li> <li>H: Cleared.</li> <li>P/V: Loaded with the contents if the IFF2 interrupt enable flag.</li> <li>N: Cleared.</li> <li>C: Unaffected.</li> </ul> |                      |        |  |  |
| Addressing<br>Modes | Assembly Syntax                                                                                                                                                                                                                                                                                                                    | Encoding             | Clocks |  |  |
|                     | LD A, I                                                                                                                                                                                                                                                                                                                            | 11101101<br>01010111 | 4      |  |  |
|                     | LD A, R                                                                                                                                                                                                                                                                                                                            | 11101101<br>01011111 | 4      |  |  |

### LD Load Memory from Accumulator

| LD dst, A           |                                                                                                                                                              | dst: DA, IR        |        |
|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------|--------|
| Operation:          | dst <= A                                                                                                                                                     |                    |        |
| Flags:              | <ul> <li>S: Unaffected.</li> <li>Z: Unaffected.</li> <li>H: Unaffected.</li> <li>P/V: Unaffected.</li> <li>N: Unaffected.</li> <li>C: Unaffected.</li> </ul> |                    |        |
| Addressing<br>Modes | Assembly Syntax                                                                                                                                              | Encoding           | Clocks |
| DA:                 | LD (mn), A                                                                                                                                                   | 00110010<br>n<br>m | 10 (8) |
| IR:                 | LD (BC), A                                                                                                                                                   | 00000010           | 6 (4)  |
|                     | LD (DE), A                                                                                                                                                   | 00010010           | 6 (4)  |

## LD Load Memory with Immediate

|                                                                                                                                                              | dst: IR, X                                                                                                                                  |                                                                                                                                                                                                                                                                                         |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| $dst \ll n$                                                                                                                                                  |                                                                                                                                             |                                                                                                                                                                                                                                                                                         |
| <ul> <li>S: Unaffected.</li> <li>Z: Unaffected.</li> <li>H: Unaffected.</li> <li>P/V: Unaffected.</li> <li>N: Unaffected.</li> <li>C: Unaffected.</li> </ul> |                                                                                                                                             |                                                                                                                                                                                                                                                                                         |
| Assembly Syntax                                                                                                                                              | Encoding                                                                                                                                    | Clocks                                                                                                                                                                                                                                                                                  |
| LD (HL), n                                                                                                                                                   | 00110110<br>n                                                                                                                               | 6                                                                                                                                                                                                                                                                                       |
| LD (IX+d), n or LD (IY+d), n                                                                                                                                 | 11y11101<br>00110110<br>d<br>n                                                                                                              | 10                                                                                                                                                                                                                                                                                      |
|                                                                                                                                                              | S: Unaffected.<br>Z: Unaffected.<br>H: Unaffected.<br>P/V: Unaffected.<br>N: Unaffected.<br>C: Unaffected.<br>Assembly Syntax<br>LD (HL), n | S: Unaffected.         Z: Unaffected.         H: Unaffected.         P/V: Unaffected.         N: Unaffected.         C: Unaffected.         C: Unaffected.         LD (HL), n         00110110        n         LD (IX+d), n or LD (IY+d), n         11y11101         00110110        d |

Notes:

| LD dst, r           |                                                                                                                                                              | dst: IR, X           |        |
|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------|--------|
| Operation:          | dst <= r                                                                                                                                                     |                      |        |
| Flags:              | <ul> <li>S: Unaffected.</li> <li>Z: Unaffected.</li> <li>H: Unaffected.</li> <li>P/V: Unaffected.</li> <li>N: Unaffected.</li> <li>C: Unaffected.</li> </ul> |                      |        |
| Addressing<br>Modes | Assembly Syntax                                                                                                                                              | Encoding             | Clocks |
| IR:                 | LD (HL), r                                                                                                                                                   | 01110rrr             | 6 (4)  |
| Х:                  | LD (IX+d), r or LD (IY+d), r                                                                                                                                 | 11y11101<br>01110rrr | 10 (8) |

1. The **rrr** field uses the standard register select encoding

| LD (mn), src        |                                                                                                                                                              | src: HL, RR, IX, IY       |         |
|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------|---------|
| Operation:          | (mn) <= src                                                                                                                                                  |                           |         |
| Flags:              | <ul> <li>S: Unaffected.</li> <li>Z: Unaffected.</li> <li>H: Unaffected.</li> <li>P/V: Unaffected.</li> <li>N: Unaffected.</li> <li>C: Unaffected.</li> </ul> |                           |         |
| Addressing<br>Modes | Assembly Syntax                                                                                                                                              | Encoding                  | Clocks  |
| HL:                 | LD (mn), HL                                                                                                                                                  | 00100010<br>n<br>m        | 12 (10) |
| RR:                 | LD (mn), ss                                                                                                                                                  | 11101101<br>01ss0011<br>n | 14 (12) |

----m----

11y11101

00100010 ----n---- 14 (12)

#### Notes:

IX, IY:

1. The **ss** field uses the standard word register encoding.

LD (mn), IX or LD (mn), IY

| LD r, src  |                  | dst: R, IM, IR, X |  |
|------------|------------------|-------------------|--|
| Operation: | r <= src         |                   |  |
| Flags:     | S: Unaffected.   |                   |  |
| 0          | Z: Unaffected.   |                   |  |
|            | H: Unaffected.   |                   |  |
|            | P/V: Unaffected. |                   |  |
|            | N: Unaffected.   |                   |  |
|            | C: Unaffected.   |                   |  |
|            |                  |                   |  |
|            |                  |                   |  |

| Addressing<br>Modes | Assembly Syntax              | Encoding | Clocks |
|---------------------|------------------------------|----------|--------|
| R:                  | LD rd, rs                    | 01rdrrsr | 2      |
| IM                  | LD r, n                      | 00rrr110 | 4      |
|                     |                              | n        |        |
| IR:                 | LD r, (HL)                   | 01rrr110 | 6 (4)  |
| X:                  | LD r, (IX+d) or LD r, (IY+d) | 11y11101 | 10 (8) |
|                     |                              | 01rrr110 |        |
|                     |                              | d        |        |

1. The  $\mathbf{rdr},\mathbf{rsr}$  and  $\mathbf{rrr}$  fields use the standard register select encoding

## LD Load Register Immediate (Word)

| LD dst, mn          |                                                                                                                                                              | dst: RR, IX, IY           |        |
|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------|--------|
| Operation:          | dst <= mn                                                                                                                                                    |                           |        |
| Flags:              | <ul> <li>S: Unaffected.</li> <li>Z: Unaffected.</li> <li>H: Unaffected.</li> <li>P/V: Unaffected.</li> <li>N: Unaffected.</li> <li>C: Unaffected.</li> </ul> |                           |        |
| Addressing<br>Modes | Assembly Syntax                                                                                                                                              | Encoding                  | Clocks |
| IM:                 | LD dd, mn                                                                                                                                                    | 00dd0001<br>n             | 6      |
|                     | LD IX, mn or LD IY, mn                                                                                                                                       | 11y11101<br>00100001<br>n | 8      |

Notes:

1. The **dd** field uses the standard word register encoding.

| LD dst, (mn) |                                                                                                                                                              | dst: RR, IX, IY |  |
|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|--|
| Operation:   | dst <= (mn)                                                                                                                                                  |                 |  |
| Flags:       | <ul> <li>S: Unaffected.</li> <li>Z: Unaffected.</li> <li>H: Unaffected.</li> <li>P/V: Unaffected.</li> <li>N: Unaffected.</li> <li>C: Unaffected.</li> </ul> |                 |  |
| Addressing   |                                                                                                                                                              |                 |  |

| Modes | Assembly Syntax            | Encoding | Clocks  |
|-------|----------------------------|----------|---------|
| DA:   | LD HL, (mn)                | 00101010 | 12 (10) |
|       |                            | n        |         |
|       |                            | m        |         |
|       |                            |          |         |
|       | LD dd, (mn)                | 11101101 | 14 (12) |
|       |                            | 01dd1011 |         |
|       |                            | n        |         |
|       |                            | m        |         |
|       | _                          |          | _       |
|       | LD IX, (mn) or LD IY, (mn) | 11y11101 | 14 (12) |
|       |                            | 00101010 |         |
|       |                            | n        |         |
|       |                            | m        |         |

1. The **dd** field uses the standard word register encoding.

# LD

### Load Special Register from Accumulator

| LD dst, A           |                                                                                                                                                              | dst: special register |        |
|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|--------|
| Operation:          | dst <= A                                                                                                                                                     |                       |        |
| Flags:              | <ul> <li>S: Unaffected.</li> <li>Z: Unaffected.</li> <li>H: Unaffected.</li> <li>P/V: Unaffected.</li> <li>N: Unaffected.</li> <li>C: Unaffected.</li> </ul> |                       |        |
| Addressing<br>Modes | Assembly Syntax                                                                                                                                              | Encoding              | Clocks |
|                     | LD I, A                                                                                                                                                      | 11101101<br>01000111  | 4      |
|                     | LD R, A                                                                                                                                                      | 11101101<br>01001111  | 4      |

| LD SP, src          |                                                                                                                                                              | src: HL, IX, IY      |        |  |
|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------|--------|--|
| Operation:          | SP <=src                                                                                                                                                     |                      |        |  |
| Flags:              | <ul> <li>S: Unaffected.</li> <li>Z: Unaffected.</li> <li>H: Unaffected.</li> <li>P/V: Unaffected.</li> <li>N: Unaffected.</li> <li>C: Unaffected.</li> </ul> |                      |        |  |
| Addressing<br>Modes | Assembly Syntax                                                                                                                                              | Encoding             | Clocks |  |
|                     | LD SP, HL                                                                                                                                                    | 11111001             | ] 2    |  |
|                     | LD SP, IX or LD SP, IY                                                                                                                                       | 11y11101<br>11111001 | 4      |  |

# LDD

Load and Decrement

#### LDD

| <b>Operation:</b> | $(DE) \le (HL)$                                                       |
|-------------------|-----------------------------------------------------------------------|
|                   | $BC \le BC - 1$                                                       |
|                   | $DE \leq DE - 1$                                                      |
|                   | $HL \leq HL - 1$                                                      |
|                   |                                                                       |
| Flags:            | S: Unaffected.                                                        |
|                   | Z: Unaffected.                                                        |
|                   | H: Cleared.                                                           |
|                   | P/V: Set if result of decrementing BC is non-zero; cleared otherwise. |
|                   | N: Cleared.                                                           |
|                   | C: Unaffected.                                                        |

| Addressing<br>Modes | Assembly Syntax | Encoding | Clocks |
|---------------------|-----------------|----------|--------|
|                     | LDD             | 11101101 | 10 (8) |
|                     |                 | 10101000 |        |
|                     | -               |          | _      |

#### LDDR

- Operation:  $(DE) \le (HL)$ BC  $\le$  BC - 1 DE  $\le$  DE - 1 HL  $\le$  HL -1 repeat if BC != 0
- Flags:
   S: Unaffected.

   Z: Unaffected
   H: Cleared.

   P/V: Set if result of decrementing BC is non-zero; cleared otherwise.
   N: Cleared.

   N: Cleared.
   C: Unaffected.

| Addressing<br>Modes | Assembly Syntax | Encoding | Clocks |
|---------------------|-----------------|----------|--------|
|                     | LDDR            | 11101101 | 8 + 4i |
|                     |                 | 10111010 |        |
|                     |                 |          |        |

#### Notes:

1. This instruction can be interrupted after each iteration. The address saved on the stack in this case is the address of this instruction, allowing completion of the instruction after the interrupt service routine

2. Interrupts are sampled during each memory read operation.

# LDI

### Load and Increment

#### INI

| <b>Operation:</b> | (DE) <= (HL)                                                          |
|-------------------|-----------------------------------------------------------------------|
|                   | BC <= BC - 1                                                          |
|                   | $DE \le DE + 1$                                                       |
|                   | $HL \leq HL + 1$                                                      |
|                   |                                                                       |
| Flags:            | S: Unaffected.                                                        |
|                   | Z: Unaffected.                                                        |
|                   | H: Cleared.                                                           |
|                   | P/V: Set if result of decrementing BC is non-zero; cleared otherwise. |
|                   | N: Cleared.                                                           |
|                   | C: Unaffected.                                                        |

| Addressing<br>Modes | Assembly Syntax | Encoding | Clocks |
|---------------------|-----------------|----------|--------|
| I                   | .DI             | 11101101 | 10 (8) |
|                     |                 | 10100000 |        |
|                     |                 |          |        |

#### LDIR **Operation:** $(DE) \leq (HL)$ BC <= BC - 1 $DE \le DE + 1$ $HL \leq HL + 1$ repeat if BC != 0 Flags: S: Unaffected. Z: Unaffected. H: Cleared. P/V: Set if result of decrementing BC is non-zero; cleared otherwise. N: Cleared. C: Unaffected. Addressing **Assembly Syntax** Encoding Clocks Modes LDIR 11101101 8 + 4i

#### Notes:

1. This instruction can be interrupted after each iteration. The address saved on the stack in this case is the address of this instruction, allowing completion of the instruction after the interrupt service routine

10110000

2. Interrupts are sampled during each memory read operation.

# MLT

### Multiply

| MLT src             |                         | src: R   |          |
|---------------------|-------------------------|----------|----------|
| Operation:          | src <= srch * srcl      |          |          |
| Flags:              | S: Unaffected.          |          |          |
|                     | Z: Unaffected.          |          |          |
|                     | H: Unaffected.          |          |          |
|                     | <b>P/V:</b> Unaffected. |          |          |
|                     | N: Unaffected.          |          |          |
|                     | C: Unaffected.          |          |          |
| Addressing<br>Modes | Assembly Syntax         | Encoding | Clocks   |
|                     |                         | 11101101 |          |
| R:                  | MLT ss                  | 11101101 | 14       |
|                     |                         | 01ss1100 | (note 3) |

#### Notes:

1. The ss field uses the standard word register encoding.

2. This is an unsigned multiply.

3. A compile-time option exists to change the execution time to 4 clock cycles. This option should only be selected if the technology supports fast carry chains, as it uses a parallel 8x8 multiplier.

4. This instruction is not present in the original Z80, but is a feature of the Z180.

### NEG **Operation:** A <= 0 - A Flags: S: Set if result is negative; cleared otherwise. Z: Set if result is zero; cleared otherwise. H: Set if arithmetic borrow out of bit 3; cleared otherwise. **P/V:** Set if arithmetic overflow (A was 0x80 before inst); cleared otherwise. N: Cleared. C: Set if arithmetic borrow out of bit 7 (A was not 0x00 before inst); cleared otherwise. Addressing **Assembly Syntax** Encoding Clocks Modes 11101101 NEG 4 00100100

## NOP

**No Operation** 

#### NOP

| Operation:          | none                    |          |        |
|---------------------|-------------------------|----------|--------|
| Flags:              | S: Unaffected.          |          |        |
| 1 1465.             | <b>Z:</b> Unaffected.   |          |        |
|                     | <b>H:</b> Unaffected.   |          |        |
|                     | <b>P/V:</b> Unaffected. |          |        |
|                     | N: Unaffected.          |          |        |
|                     | C: Unaffected.          |          |        |
| Addressing<br>Modes | Assembly Syntax         | Encoding | Clocks |
|                     | NOP                     | 0000000  | 2      |
|                     |                         |          |        |

| <b>OR</b> A, src | src: R, IM, IR, X                                               |
|------------------|-----------------------------------------------------------------|
| Operation:       | $A \le A \mid src$                                              |
| Flags:           | S: Set if result is negative; cleared otherwise.                |
|                  | <b>Z</b> : Set if result is zero; cleared otherwise.            |
|                  | H: Cleared.                                                     |
|                  | <b>P/V:</b> Set if parity of result is even; cleared otherwise. |
|                  | N: Cleared.                                                     |
|                  | C: Cleared.                                                     |
|                  |                                                                 |

| Addressing<br>Modes | Assembly Syntax              | Encoding | Clocks |
|---------------------|------------------------------|----------|--------|
|                     |                              |          |        |
| R:                  | OR A, r                      | 10110rrr | 2      |
|                     |                              | 11110110 |        |
| IM:                 | OR A, n                      | 11110110 | 4      |
|                     |                              | n        |        |
|                     |                              |          |        |
| IR:                 | OR A, (HL)                   | 10110110 | 6 (4)  |
|                     |                              |          |        |
| <b>X:</b>           | OR A, (IX+d) or OR A, (IY+d) | 11y11101 | 10 (8) |
|                     |                              | 10110110 |        |
|                     |                              | d        |        |
|                     |                              |          |        |

1. The **rrr** field uses the standard register select encoding

# OTDM

**Output and Decrement Multiple** 

#### OTDM

| Operation:          | I/O(0,C) <= (HL)<br>B <= B - 1<br>C <= C - 1<br>HL <= HL -1                                   |                                                                          |               |
|---------------------|-----------------------------------------------------------------------------------------------|--------------------------------------------------------------------------|---------------|
| Flags:              | <b>Z:</b> Set if result of decrementing <b>I</b><br><b>H:</b> Set if there is a borrow out of | bit 3 while decrementing B; clear<br>t of decrementing B is even; cleare | ed otherwise. |
| Addressing<br>Modes | Assembly Syntax                                                                               | Encoding                                                                 | Clocks        |
|                     | OTDM                                                                                          | 11101101<br>10001011                                                     | 10 (8)        |

#### Notes:

1. This instruction is not present in the original Z80, but is a feature of the Z180.

### **OTDMR** Output, Decrement Multiple and Repeat

#### **OTDMR Operation:** $I/O(BC) \le (HL)$ B <= B - 1 C <= C - 1 $HL \leq HL -1$ repeat if B != 0Flags: S: Set if the result of decrementing B is negative; cleared otherwise. Z: Set if result of decrementing B is zero; cleared otherwise. H: Set if there is a borrow out of bit 3 while decrementing B; cleared otherwise. **P/V:** Set if the parity of the result of decrementing B is even; cleared otherwise. N: Set if the byte transferred is negative; cleared otherwise. C: Unaffected. Addressing Clocks **Assembly Syntax** Encoding Modes OTDMR 11101101 8 + 4i

#### Notes:

1. This instruction can be interrupted after each iteration. The address saved on the stack in this case is the address of this instruction, allowing completion of the instruction after the interrupt service routine

10011011

2. Interrupts are sampled during each memory read operation.

# OTDR

**Output, Decrement and Repeat** 

#### OTDR

| Operation: | I/O(BC) <= (HL)<br>B <= B - 1<br>HL <= HL -1<br>repeat if B != 0                                                                                                                                      |
|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Flags:     | <ul> <li>S: Unaffected.</li> <li>Z: Set if result of decrementing B is zero; cleared otherwise.</li> <li>H: Unaffected.</li> <li>P/V: Unaffected.</li> <li>N: Set.</li> <li>C: Unaffected.</li> </ul> |

| Addressing<br>Modes | Assembly Syntax | Encoding | Clocks |
|---------------------|-----------------|----------|--------|
|                     | OTDR            | 11101101 | 8 + 4i |
|                     |                 | 10111011 |        |
|                     |                 | <u> </u> |        |

#### Notes:

1. This instruction can be interrupted after each iteration. The address saved on the stack in this case is the address of this instruction, allowing completion of the instruction after the interrupt service routine

2. Interrupts are sampled during each memory read operation.

3. For the original Z80, the S, H and P/V flags are undefined.

### OTIM **Operation:** $I/O(BC) \le (HL)$ B <= B - 1 $C \le C + 1$ $HL \leq HL + 1$ Flags: S: Set if the result of decrementing B is negative; cleared otherwise. Z: Set if result of decrementing B is zero; cleared otherwise. H: Set if there is a borrow out of bit 3 while decrementing B; cleared otherwise. **P/V:** Set if the parity of the result of decrementing B is even; cleared otherwise. N: Set if the byte transferred is negative; cleared otherwise. C: Unaffected. Addressing **Assembly Syntax** Encoding Clocks Modes

| OTIM | 11101101 | 10 (8) |
|------|----------|--------|
|      | 10000011 | _      |
|      |          |        |

#### Notes:

1. This instruction is not present in the original Z80, but is a feature of the Z180.

# OTIMR

**Output, Increment Multiple and Repeat** 

#### OTIMR

| Operation:          | I/O(BC) <= (HL)<br>B <= B - 1<br>C <= C + 1<br>HL <= HL + 1<br>repeat if B != 0                                                                                                                                                                                     |                                                                                                          |                |
|---------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------|----------------|
| Flags:              | <ul> <li>S: Set if the result of decrementin</li> <li>Z: Set if result of decrementing E</li> <li>H: Set if there is a borrow out of</li> <li>P/V: Set if the parity of the result</li> <li>N: Set if the byte transferred is no</li> <li>C: Unaffected.</li> </ul> | B is zero; cleared otherwise.<br>bit 3 while decrementing B; clear<br>t of decrementing B is even; clear | red otherwise. |
| Addressing<br>Modes | Assembly Syntax                                                                                                                                                                                                                                                     | Encoding                                                                                                 | Clocks         |
|                     | OTIMR                                                                                                                                                                                                                                                               | 11101101<br>10010011                                                                                     | 8 + 4i         |

#### Notes:

1. This instruction can be interrupted after each iteration. The address saved on the stack in this case is the address of this instruction, allowing completion of the instruction after the interrupt service routine

2. Interrupts are sampled during each memory read operation.

3. This instruction is not present in the original Z80, but is a feature of the Z180.

| OTIR                |                                             |                             |        |
|---------------------|---------------------------------------------|-----------------------------|--------|
|                     |                                             |                             |        |
| <b>Operation:</b>   | I/O(BC) <= (HL)                             |                             |        |
|                     | B <= B - 1                                  |                             |        |
|                     | $HL \leq HL + 1$                            |                             |        |
|                     | repeat if B != 0                            |                             |        |
|                     |                                             |                             |        |
|                     |                                             |                             |        |
| Flags:              | S: Unaffected.                              |                             |        |
|                     | <b>Z:</b> Unaffected.                       |                             |        |
|                     | H: Unaffected.                              |                             |        |
|                     | <b>P/V:</b> Set if result of decrementing B | is zero; cleared otherwise. |        |
|                     | N: Cleared.                                 |                             |        |
|                     | C: Unaffected.                              |                             |        |
|                     |                                             |                             |        |
| Addressing<br>Modes | Assembly Syntax                             | Encoding                    | Clocks |

| OTUD | 11101101 |        |
|------|----------|--------|
| OTIR | 11101101 | 8 + 4i |
|      | 10110011 |        |

1. This instruction can be interrupted after each iteration. The address saved on the stack in this case is the address of this instruction, allowing completion of the instruction after the interrupt service routine

2. Interrupts are sampled during each memory read operation.

3. For the original Z80, the **S**, **H** and **P/V** flags are undefined.

# OUT

### Output

| OUT dst, A          |                       | dst: DA  |        |
|---------------------|-----------------------|----------|--------|
| Operation:          | I/O(A:n) <= A         |          |        |
| Flags:              | S: Unaffected.        |          |        |
| 8                   | <b>Z:</b> Unaffected. |          |        |
|                     | H: Unaffected.        |          |        |
|                     | P/V: Unaffected.      |          |        |
|                     | N: Unaffected.        |          |        |
|                     | C: Unaffected.        |          |        |
| Addressing<br>Modes | Assembly Syntax       | Encoding | Clocks |
|                     | OUT (n), A            | 11010011 | 8 (6)  |
|                     |                       |          | -      |

## OUT Output

| <b>OUT</b> (C), r   |                                                                                                                                      | src: R               |        |
|---------------------|--------------------------------------------------------------------------------------------------------------------------------------|----------------------|--------|
| Operation:          | I/O(BC) <= r                                                                                                                         |                      |        |
| Flags:              | <ul> <li>S: Unaffected.</li> <li>Z: Unaffected.</li> <li>H: Unaffected.</li> <li>P/V: Unaffected.</li> <li>N: Unaffected.</li> </ul> |                      |        |
|                     | N: Unaffected.<br>C: Unaffected.                                                                                                     |                      |        |
| Addressing<br>Modes | Assembly Syntax                                                                                                                      | Encoding             | Clocks |
|                     | OUT (C), r                                                                                                                           | 11101101<br>01rrr001 | 8 (6)  |
|                     |                                                                                                                                      |                      |        |

#### Notes:

1. The **rrr** field uses the standard register select encoding

## OUT0

### Output (page 0)

| <b>OUT0</b> (n), r  |                  | src: R   |        |
|---------------------|------------------|----------|--------|
| Operation:          | I/O(0,n) <= r    |          |        |
| Flags:              | S: Unaffected.   |          |        |
|                     | Z: Unaffected.   |          |        |
|                     | H: Unaffected.   |          |        |
|                     | P/V: Unaffected. |          |        |
|                     | N: Unaffected.   |          |        |
|                     | C: Unaffected.   |          |        |
| Addressing<br>Modes | Assembly Syntax  | Encoding | Clocks |
|                     | OUT0 (n), r      | 11101101 | 10 (8) |
|                     | × / /            |          | - (0)  |
|                     |                  | 00rrr001 |        |

#### Notes:

1. The **rrr** field uses the standard register select encoding

2. This instruction is not present in the original Z80, but is a feature of the Z180.

| OUTD             |                                                                                                         |          |        |  |
|------------------|---------------------------------------------------------------------------------------------------------|----------|--------|--|
| Operation:       | I/O(BC) <= (HL)                                                                                         |          |        |  |
|                  | B <= B - 1                                                                                              |          |        |  |
|                  | HL <= HL -1                                                                                             |          |        |  |
| Flage            | S. Unoffected                                                                                           |          |        |  |
| Flags:           | <ul><li>S: Unaffected.</li><li>Z: Set if result of decrementing B is zero; cleared otherwise.</li></ul> |          |        |  |
|                  | H: Unaffected.                                                                                          |          |        |  |
| P/V: Unaffected. |                                                                                                         |          |        |  |
|                  | N: Set.                                                                                                 |          |        |  |
|                  | C: Unaffected.                                                                                          |          |        |  |
| Addressing       | Assembly Syntax                                                                                         | Encoding | Clocks |  |
| Modes            |                                                                                                         |          |        |  |
|                  | OUTD                                                                                                    | 11101101 | 10 (8) |  |
|                  | 0012                                                                                                    | 10101011 |        |  |
|                  |                                                                                                         |          |        |  |

1. For the original Z80, the **S**, **H** and **P/V** flags are undefined.

## **OUTI** Output and Increment

#### OUTI

| Operation: | I/O(BC) <= (HL)<br>B <= B - 1<br>HL <= HL + 1                                                                                                                               |                               |        |
|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------|--------|
| Flags:     | <ul> <li>S: Unaffected.</li> <li>Z: Unaffected.</li> <li>H: Unaffected.</li> <li>P/V: Set if result of decrementing</li> <li>N: Cleared.</li> <li>C: Unaffected.</li> </ul> | B is zero; cleared otherwise. |        |
| Addressing | Accombly Syntox                                                                                                                                                             | Encoding                      | Clocks |

| Addressing<br>Modes | Assembly Syntax | Encoding | Clocks |
|---------------------|-----------------|----------|--------|
| JO                  | OUTI            | 11101101 | 10 (8) |
|                     | -               | 10100011 |        |
|                     | L               |          |        |

#### Notes:

1. For the original Z80, the **S**, **H** and **P/V** flags are undefined.

### **POP** Pop from Stack

| POP dst             |                                                                                                                                                              | dst: RR, IX, IY      |        |
|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------|--------|
| Operation:          | dst[lsb] <= (SP)<br>dst[msb] <= (SP+1)<br>SP <= SP + 2                                                                                                       |                      |        |
| Flags:              | <ul> <li>S: Unaffected.</li> <li>Z: Unaffected.</li> <li>H: Unaffected.</li> <li>P/V: Unaffected.</li> <li>N: Unaffected.</li> <li>C: Unaffected.</li> </ul> |                      |        |
| Addressing<br>Modes | Assembly Syntax                                                                                                                                              | Encoding             | Clocks |
| RR:                 | POP tt                                                                                                                                                       | 11tt0001             | 8 (6)  |
| IX, IY              | POP IX or POP IY                                                                                                                                             | 11y11101<br>11100001 | 10 (8) |

#### Notes:

1. The **tt** field uses the standard word register encoding.

# PUSH

**Push to Stack** 

| PUSH src            | src: RR, IX, IY                                                                                                                                              |                      |        |
|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------|--------|
| Operation:          | (SP-1) <= src[msb]<br>(SP-2) <= src[lsb]<br>SP <= SP - 2                                                                                                     |                      |        |
| Flags:              | <ul> <li>S: Unaffected.</li> <li>Z: Unaffected.</li> <li>H: Unaffected.</li> <li>P/V: Unaffected.</li> <li>N: Unaffected.</li> <li>C: Unaffected.</li> </ul> |                      |        |
| Addressing<br>Modes | Assembly Syntax                                                                                                                                              | Encoding             | Clocks |
| RR:                 | PUSH tt                                                                                                                                                      | 11tt0101             | 8 (6)  |
| IX, IY              | PUSH IX or PUSH IY                                                                                                                                           | 11y11101<br>11100101 | 10 (8) |

Notes:

1. The **tt** field uses the standard word register encoding.

| RES b, dst | src: R, IR, X                                                                                              |
|------------|------------------------------------------------------------------------------------------------------------|
| Operation: | dst[b] <= 0                                                                                                |
| Flags:     | S: Unaffected.<br>Z: Unaffected.<br>H: Unaffected.<br>P/V: Unaffected.<br>N: Unaffected.<br>C: Unaffected. |

| Addressing<br>Modes | Assembly Syntax             | Encoding  | Clocks  |
|---------------------|-----------------------------|-----------|---------|
| R:                  | RES b, r                    | 11001011  | 4       |
|                     |                             | 10bbbrrr  |         |
| IR:                 | RES b, (HL)                 | 10100110  | 10 (8)  |
|                     |                             | 10bbb1110 |         |
| X:                  | RES b, (IX+d) or RES (IY+d) | 11y11101  | 12 (10) |
|                     |                             | 11001011  |         |
|                     |                             | d         | _       |
|                     |                             | 10bbb110  |         |

- 1. The **rrr** field uses the standard register select encoding.
- 2.  $\mathbf{y} = 0$  selects IX and  $\mathbf{y} = 1$  selects IY.
- 3. The **bbb** field uses normal binary encoding.

# RET

# **Return from Subroutine**

### RET

| Operation:          | PC[lsb] <= (SP)<br>PC[msb] <= (SP+1)<br>SP <= SP + 2                                                                                                         |          |        |
|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|--------|
| Flags:              | <ul> <li>S: Unaffected.</li> <li>Z: Unaffected.</li> <li>H: Unaffected.</li> <li>P/V: Unaffected.</li> <li>N: Unaffected.</li> <li>C: Unaffected.</li> </ul> |          |        |
| Addressing<br>Modes | Assembly Syntax                                                                                                                                              | Encoding | Clocks |
|                     | RET                                                                                                                                                          | 11001001 | 10     |

| RET cc              |                                                                                                |                                                   |                                                                 |                                                          |            |
|---------------------|------------------------------------------------------------------------------------------------|---------------------------------------------------|-----------------------------------------------------------------|----------------------------------------------------------|------------|
| Operation:          | if (cc = true)<br>PC[lsb] <=<br>PC[msb] <<br>SP <= SP<br>end                                   | = (SP)<br><= (SP+1)                               |                                                                 |                                                          |            |
| Flags:              | S: Unaffecte<br>Z: Unaffecte<br>H: Unaffecte<br>P/V: Unaffecte<br>N: Unaffecte<br>C: Unaffecte | ed.<br>ed.<br>cted.<br>ed.                        |                                                                 |                                                          |            |
|                     |                                                                                                |                                                   |                                                                 |                                                          |            |
| Addressing<br>Modes | Ass                                                                                            | embly Syntax                                      | Er                                                              | ncoding                                                  | Clocks     |
|                     | Ass<br>RET cc                                                                                  | embly Syntax                                      |                                                                 | ncoding<br>1fff000                                       | Clocks     |
|                     | ASS                                                                                            | embly Syntax                                      |                                                                 |                                                          | 10 (taken) |
| Modes<br>Notes:     | RET cc<br>Mnemonic                                                                             | Encoding (fff)                                    | Meaning                                                         | Ifff000<br>Flag case                                     | 10 (taken) |
| Modes<br>Notes:     | RET cc<br>Mnemonic<br>NZ                                                                       | Encoding (fff)<br>000                             | Meaning<br>Non-zero                                             | Ifff000<br>Flag case<br>Z = 0                            | 10 (taken) |
| Modes<br>Notes:     | RET cc<br>Mnemonic<br>NZ<br>Z                                                                  | Encoding (fff)<br>000<br>001                      | Meaning<br>Non-zero<br>Zero                                     | Flag case<br>Z = 0<br>Z = 1                              | 10 (taken) |
| Modes<br>Notes:     | RET cc<br>Mnemonic<br>NZ<br>Z<br>NC                                                            | Encoding (fff)<br>000<br>001<br>010               | Meaning<br>Non-zero<br>Zero<br>Non-carry                        | Flag case<br>Z = 0<br>Z = 1<br>C = 0                     | 10 (taken) |
| Modes<br>Notes:     | RET cc<br>Mnemonic<br>NZ<br>Z<br>NC<br>C                                                       | Encoding (fff)<br>000<br>001<br>010<br>011        | Meaning<br>Non-zero<br>Zero<br>Non-carry<br>Carry               | Flag case<br>Z = 0<br>Z = 1<br>C = 0<br>C = 1            | 10 (taken) |
| Modes<br>Notes:     | RET cc<br>Mnemonic<br>NZ<br>Z<br>NC<br>C<br>PO                                                 | Encoding (fff)<br>000<br>001<br>010<br>011<br>100 | Meaning<br>Non-zero<br>Zero<br>Non-carry<br>Carry<br>Parity Odd | Flag case<br>Z = 0<br>Z = 1<br>C = 0<br>C = 1<br>P/V = 0 | 10 (taken) |
| Modes               | RET cc<br>Mnemonic<br>NZ<br>Z<br>NC<br>C                                                       | Encoding (fff)<br>000<br>001<br>010<br>011        | Meaning<br>Non-zero<br>Zero<br>Non-carry<br>Carry               | Flag case<br>Z = 0<br>Z = 1<br>C = 0<br>C = 1            | 10 (taken) |

# RETI

# **Return from Interrupt**

### RETI

| Operation:          | PC[lsb] <= (SP)<br>PC[msb] <= (SP+1)<br>SP <= SP + 2                                                                                                         |                      |        |
|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------|--------|
| Flags:              | <ul> <li>S: Unaffected.</li> <li>Z: Unaffected.</li> <li>H: Unaffected.</li> <li>P/V: Unaffected.</li> <li>N: Unaffected.</li> <li>C: Unaffected.</li> </ul> |                      |        |
| Addressing<br>Modes | Assembly Syntax                                                                                                                                              | Encoding             | Clocks |
|                     | RETI                                                                                                                                                         | 11101101<br>01001101 | 12     |

#### Notes:

1. This instruction activates the dedicated RETI signal out of the core.

# **RETN** Return from Non-Maskable Interrupt

| RETN                |                                                                                                                                                              |                      |        |
|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------|--------|
| Operation:          | PC[lsb] <= (SP)<br>PC[msb] <= (SP+1)<br>SP <= SP + 2<br>IFF2 <= IFF1                                                                                         |                      |        |
| Flags:              | <ul> <li>S: Unaffected.</li> <li>Z: Unaffected.</li> <li>H: Unaffected.</li> <li>P/V: Unaffected.</li> <li>N: Unaffected.</li> <li>C: Unaffected.</li> </ul> |                      |        |
| Addressing<br>Modes | Assembly Syntax                                                                                                                                              | Encoding             | Clocks |
|                     | RETN                                                                                                                                                         | 11001001<br>01000101 | 12     |

| RL src     | src: R, IR, X                                                                                                                                                                                                                                                       |
|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Operation: | {CF, src} <= {src, CF}                                                                                                                                                                                                                                              |
| Flags:     | <ul> <li>S: Set if result is negative; cleared otherwise.</li> <li>Z: Set if result is zero; cleared otherwise.</li> <li>H: Cleared.</li> <li>P/V: Set if parity of result is even; cleared otherwise.</li> <li>N: Cleared.</li> <li>C: Data from bit 7.</li> </ul> |

| Addressing<br>Modes | Assembly Syntax        | Encoding | Clocks  |
|---------------------|------------------------|----------|---------|
| R:                  | RLr                    | 11001011 | 4       |
|                     |                        | 00010rrr |         |
| IR:                 | RL (HL)                | 10100110 | 10 (8)  |
|                     |                        | 00010110 |         |
| X:                  | RL (IX+d) or RL (IY+d) | 11y11101 | 12 (10) |
|                     |                        | 11001011 |         |
|                     |                        | d        | 1       |
|                     |                        | 00010110 | 1       |

1. The  ${\bf rrr}$  field uses the standard register select encoding.

# RLA **Operation:** $\{CF, A\} <= \{A, CF\}$ Flags: S: Unaffected Z: Unaffected. H: Cleared. **P/V:** Unaffected. N: Cleared. **C:** Data from bit 7. Addressing Assembly Syntax Encoding Clocks Modes 00010111 2 RLA

| RLC src    | src: R, IR, X                                                                                                                                                                                                                                                       |
|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Operation: | $\{CF, src\} \le \{src, src[7]\}$                                                                                                                                                                                                                                   |
| Flags:     | <ul> <li>S: Set if result is negative; cleared otherwise.</li> <li>Z: Set if result is zero; cleared otherwise.</li> <li>H: Cleared.</li> <li>P/V: Set if parity of result is even; cleared otherwise.</li> <li>N: Cleared.</li> <li>C: Data from bit 7.</li> </ul> |

| Addressing<br>Modes | Assembly Syntax          | Encoding | Clocks  |
|---------------------|--------------------------|----------|---------|
| R:                  | RLC r                    | 11001011 | 4       |
|                     |                          | 00000rrr |         |
| IR:                 | RLC (HL)                 | 10100110 | 10 (8)  |
|                     |                          | 00000110 |         |
| X:                  | RLC (IX+d) or RLC (IY+d) | 11y11101 | 12 (10) |
|                     |                          | 11001011 |         |
|                     |                          | d        | _       |
|                     |                          | 00000110 | 1       |

1. The  ${\bf rrr}$  field uses the standard register select encoding.

#### RLCA

| Operation:          | $\{CF, A\} \le \{A, A[7]\}$ |          |        |
|---------------------|-----------------------------|----------|--------|
|                     |                             |          |        |
| Flags:              | S: Unaffected               |          |        |
|                     | Z: Unaffected.              |          |        |
|                     | H: Cleared.                 |          |        |
|                     | P/V: Unaffected.            |          |        |
|                     | N: Cleared.                 |          |        |
|                     | C: Data from bit 7.         |          |        |
| Addressing<br>Modes | Assembly Syntax             | Encoding | Clocks |
|                     | RLCA                        | 00000111 | 2      |
|                     |                             |          |        |

# RLD

| Operation:          | {A, (HL)} <= {A[7:4], (HL), A[3:0]                                                                                                                                                                                                                                                                         | }                    |        |
|---------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------|--------|
| Flags:              | <ul> <li>S: Set if A is negative after the operation; cleared otherwise.</li> <li>Z: Set if A is zero after the operation; cleared otherwise.</li> <li>H: Cleared.</li> <li>P/V: Set if parity of A is even after the operation; cleared otherwise.</li> <li>N: Cleared.</li> <li>C: Unaffected</li> </ul> |                      |        |
| Addressing<br>Modes | Assembly Syntax                                                                                                                                                                                                                                                                                            | Encoding             | Clocks |
|                     | RLD                                                                                                                                                                                                                                                                                                        | 11101101<br>01101111 | 10 (8) |

| <b>RR</b> src | src: R, IR, X                                                                                                                                                                                                                                                       |
|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Operation:    | $\{src, CF\} \leq \{CF, src\}$                                                                                                                                                                                                                                      |
| Flags:        | <ul> <li>S: Set if result is negative; cleared otherwise.</li> <li>Z: Set if result is zero; cleared otherwise.</li> <li>H: Cleared.</li> <li>P/V: Set if parity of result is even; cleared otherwise.</li> <li>N: Cleared.</li> <li>C: Data from bit 0.</li> </ul> |

| Addressing<br>Modes | Assembly Syntax        | Encoding | Clocks  |
|---------------------|------------------------|----------|---------|
| R:                  | RR r                   | 11001011 | 7 4     |
| к.                  |                        | 00011rrr |         |
|                     |                        |          | -       |
| IR:                 | RR (HL)                | 10100110 | 10 (8)  |
|                     |                        | 00011110 | ]       |
|                     |                        |          |         |
| X:                  | RR (IX+d) or RR (IY+d) | 11y11101 | 12 (10) |
|                     |                        | 11001011 |         |
|                     |                        | d        |         |
|                     |                        | 00011110 | ]       |
|                     |                        | 00011110 | ]       |

1. The  ${\bf rrr}$  field uses the standard register select encoding.

# RRA

**Rotate Right Accumulator** 

## RRA

| Operation:          | ${A, CF} \le {CF, A}$                                                                                                                                      |          |        |
|---------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|--------|
| Flags:              | <ul> <li>S: Unaffected</li> <li>Z: Unaffected.</li> <li>H: Cleared.</li> <li>P/V: Unaffected.</li> <li>N: Cleared.</li> <li>C: Data from bit 0.</li> </ul> |          |        |
| Addressing<br>Modes | Assembly Syntax                                                                                                                                            | Encoding | Clocks |
|                     | RRA [                                                                                                                                                      | 00011111 | 2      |

| RRC src    | src: R, IR, X                                                                                                                                                                                                                                                       |
|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Operation: | {src, CF} <= {src[0], src}                                                                                                                                                                                                                                          |
| Flags:     | <ul> <li>S: Set if result is negative; cleared otherwise.</li> <li>Z: Set if result is zero; cleared otherwise.</li> <li>H: Cleared.</li> <li>P/V: Set if parity of result is even; cleared otherwise.</li> <li>N: Cleared.</li> <li>C: Data from bit 0.</li> </ul> |

| Addressing<br>Modes | Assembly Syntax          | Encoding | Clocks  |
|---------------------|--------------------------|----------|---------|
| R:                  | RRC r                    | 11001011 | 4       |
| I.                  |                          | 00001rrr |         |
| IR:                 | RRC (HL)                 | 10100110 | 10 (8)  |
| IX.                 | KKC (IIL)                | 00001110 | 10 (0)  |
|                     |                          |          | 7       |
| <b>X:</b>           | RRC (IX+d) or RRC (IY+d) | 11y11101 | 12 (10) |
|                     |                          | 11001011 |         |
|                     |                          | d        |         |
|                     |                          | 00001110 |         |

1. The **rrr** field uses the standard register select encoding.

### RRCA

| Operation:          | $\{A, CF\} \le \{A[0], A\}$                                                                                                                                |          |        |
|---------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|--------|
| Flags:              | <ul> <li>S: Unaffected</li> <li>Z: Unaffected.</li> <li>H: Cleared.</li> <li>P/V: Unaffected.</li> <li>N: Cleared.</li> <li>C: Data from bit 0.</li> </ul> |          |        |
| Addressing<br>Modes | Assembly Syntax                                                                                                                                            | Encoding | Clocks |
|                     | RRCA                                                                                                                                                       | 00001111 | 2      |

| RRD                 |                                                                                                                                                                                                                           |                          |        |
|---------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------|--------|
| Operation:          | {A, (HL)} <= {A[7:4], (HL)[3:0]                                                                                                                                                                                           | , A[3:0], (HL)[7:4]}     |        |
| Flags:              | <ul> <li>S: Set if A is negative after the op</li> <li>Z: Set if A is zero after the operation</li> <li>H: Cleared.</li> <li>P/V: Set if parity of A is even after</li> <li>N: Cleared.</li> <li>C: Unaffected</li> </ul> | tion; cleared otherwise. | 3e.    |
| Addressing<br>Modes | Assembly Syntax                                                                                                                                                                                                           | Encoding                 | Clocks |
|                     | RRD                                                                                                                                                                                                                       | 11101101<br>01100111     | 10 (8) |
|                     | κκ <i>υ</i>                                                                                                                                                                                                               |                          |        |

# RST

# Restart

# RST v

| Operation:          | SP <= SP - 2<br>(SP) <= PC<br>PC <= v                                                                                                                        |          |        |
|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|--------|
| Flags:              | <ul> <li>S: Unaffected.</li> <li>Z: Unaffected.</li> <li>H: Unaffected.</li> <li>P/V: Unaffected.</li> <li>N: Unaffected.</li> <li>C: Unaffected.</li> </ul> |          |        |
| Addressing<br>Modes | Assembly Syntax                                                                                                                                              | Encoding | Clocks |
|                     | RST v                                                                                                                                                        | 11vvv111 | 8      |

#### Notes:

| 1. | Mnemonic | Encoding (vvv) | Restart Address |
|----|----------|----------------|-----------------|
|    | 0        | 000            | 0x0000          |
|    | 0x8      | 001            | 0x0008          |
|    | 0x10     | 010            | 0x0010          |
|    | 0x18     | 011            | 0x0018          |
|    | 0x20     | 100            | 0x0020          |
|    | 0x28     | 101            | 0x0028          |
|    | 0x30     | 110            | 0x0030          |
|    | 0x38     | 111            | 0x0038          |

| SBC A, src | src: R, IM, IR, X                                                                                                                                                                                                                                                                                                                                        |
|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Operation: | A <= A - src - CF                                                                                                                                                                                                                                                                                                                                        |
| Flags:     | <ul> <li>S: Set if result is negative; cleared otherwise.</li> <li>Z: Set if result is zero; cleared otherwise.</li> <li>H: Set if arithmetic borrow out of bit 3; cleared otherwise.</li> <li>P/V: Set if arithmetic overflow; cleared otherwise.</li> <li>N: Cleared.</li> <li>C: Set if arithmetic borrow out of bit 7; cleared otherwise.</li> </ul> |

| Addressing<br>Modes | Assembly Syntax                | Encoding      | Clocks |
|---------------------|--------------------------------|---------------|--------|
| R:                  | SBC A, r                       | 10011rrr      | 2      |
| IM:                 | SBC A, n                       | 11011110      | 4      |
|                     |                                | n             |        |
| IR:                 | SBC A, (HL)                    | 10011110      | 6 (4)  |
| <b>X:</b>           | SBC A, (IX+d) or SBC A, (IY+d) | 11y11101      | 10 (8) |
|                     |                                | 10011110<br>d |        |

1. The **rrr** field uses the standard register select encoding

| SBC HL, src         |                                                                                                                                                                                                                                                              | src: RR                                                 |        |
|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------|--------|
| Operation:          | HL <= HL - src - CF                                                                                                                                                                                                                                          |                                                         |        |
| Flags:              | <ul> <li>S: Set if result is negative; cleared of</li> <li>Z: Set if result is zero; cleared othe</li> <li>H: Set if arithmetic borrow out of b</li> <li>P/V: Set if arithmetic overflow; cleared.</li> <li>C: Set if arithmetic carry out of bit</li> </ul> | rwise.<br>bit 11; cleared otherwise.<br>ared otherwise. |        |
|                     |                                                                                                                                                                                                                                                              |                                                         |        |
| Addressing<br>Modes | Assembly Syntax                                                                                                                                                                                                                                              | Encoding                                                | Clocks |

1. The ss field uses the standard word register encoding.

# CCF Operation: CF <= 1 Flags: S: Unaffected. Z: Unaffected. H: Cleared. P/V: Unaffected. N: Cleared. C: Set.

| Addressing A<br>Modes A | ssembly Syntax | Encoding | Clocks |
|-------------------------|----------------|----------|--------|
| SCF                     | Γ              | 00110111 | 2      |

# SET

Bit Set

| SET b, dst | src: R, IR, X                                                                                                                                                |
|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Operation: | dst[b] <= 1                                                                                                                                                  |
| Flags:     | <ul> <li>S: Unaffected.</li> <li>Z: Unaffected.</li> <li>H: Unaffected.</li> <li>P/V: Unaffected.</li> <li>N: Unaffected.</li> <li>C: Unaffected.</li> </ul> |

| Addressing<br>Modes | Assembly Syntax                | Encoding  | Clocks  |
|---------------------|--------------------------------|-----------|---------|
| R:                  | SET b, r                       | 11001011  | 4       |
|                     |                                | 11bbbrrr  |         |
| IR:                 | SET b, (HL)                    | 10100110  | 10 (8)  |
|                     |                                | 11bbb1110 |         |
| X:                  | SET b, (IX+d) or SET b, (IY+d) | 11y11101  | 12 (10) |
|                     |                                | 11001011  |         |
|                     |                                | d         |         |
|                     |                                | 11bbb110  |         |

Notes:

1. The **rrr** field uses the standard register select encoding.

2.  $\mathbf{y} = 0$  selects IX and  $\mathbf{y} = 1$  selects IY.

3. The **bbb** field uses normal binary encoding.

| SLA src    | src: R, IR, X                                                                                                                                                                                                                                                       |
|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Operation: | $\{CF, src\} \le \{src, 0\}$                                                                                                                                                                                                                                        |
| Flags:     | <ul> <li>S: Set if result is negative; cleared otherwise.</li> <li>Z: Set if result is zero; cleared otherwise.</li> <li>H: Cleared.</li> <li>P/V: Set if parity of result is even; cleared otherwise.</li> <li>N: Cleared.</li> <li>C: Data from bit 7.</li> </ul> |

| Addressing<br>Modes | Assembly Syntax          | Encoding | Clocks  |
|---------------------|--------------------------|----------|---------|
| R:                  | SLA r                    | 11001011 | - 4     |
| к.                  | SLAT                     | 00100rrr | - 4     |
|                     |                          |          |         |
| IR:                 | SLA (HL)                 | 10100110 | 10 (8)  |
|                     |                          | 00100110 |         |
|                     |                          |          | -       |
| <b>X:</b>           | SLA (IX+d) or SLA (IY+d) | 11y11101 | 12 (10) |
|                     |                          | 11001011 |         |
|                     |                          | d        |         |
|                     |                          | 00100110 |         |
|                     |                          |          | _       |

1. The **rrr** field uses the standard register select encoding.

# SLP

Sleep

#### SLP

| Operation:          | activate SLEEP signal and wait for interrupt |          |        |
|---------------------|----------------------------------------------|----------|--------|
| Floore              | S. Unaffected                                |          |        |
| Flags:              | S: Unaffected.                               |          |        |
|                     | Z: Unaffected.                               |          |        |
|                     | H: Unaffected.                               |          |        |
|                     | P/V: Unaffected.                             |          |        |
|                     | N: Unaffected.                               |          |        |
|                     | C: Unaffected.                               |          |        |
| Addressing<br>Modes | Assembly Syntax                              | Encoding | Clocks |
|                     | SLP                                          | 11101101 | 6 + 2n |
|                     |                                              | 01110110 |        |
|                     |                                              |          |        |

#### Notes:

1. The CPU halts, with an idle bus, until an interrupt is requested. During Sleep the **mem\_addr\_bus** and **io\_addr\_bus** are driven with 0x0000, and the **mem\_data\_bus** and **io\_data\_bus** are driven with 0x00.

2. In the case of an NMI or enabled maskable interrupt the address pushed to the stack during the interrupt acknowledge is the address of the next instruction.

3. If interrupts are disabled a maskable interrupt request during Sleep causes the CPU to resume execution with the next instruction. This saves time when restarting from Sleep.

4. This instruction is not present in the original Z80, but is a feature of the Z180.

| SRA src    | src: R, IR, X                                                                                                                                                                                                                                                       |
|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Operation: | {src, CF} <= {src[7], src}                                                                                                                                                                                                                                          |
| Flags:     | <ul> <li>S: Set if result is negative; cleared otherwise.</li> <li>Z: Set if result is zero; cleared otherwise.</li> <li>H: Cleared.</li> <li>P/V: Set if parity of result is even; cleared otherwise.</li> <li>N: Cleared.</li> <li>C: Data from bit 0.</li> </ul> |

| Addressing<br>Modes | Assembly Syntax          | Encoding | Clocks  |
|---------------------|--------------------------|----------|---------|
|                     |                          | 11001011 | 1 .     |
| <b>R</b> :          | SRA r                    | 11001011 | 4       |
|                     |                          | 00101rrr |         |
|                     |                          |          |         |
| IR:                 | SRA (HL)                 | 10100110 | 10 (8)  |
|                     |                          | 00101110 |         |
|                     |                          |          | •       |
| <b>X:</b>           | SRA (IX+d) or SRA (IY+d) | 11y11101 | 12 (10) |
|                     |                          | 11001011 |         |
|                     |                          | d        |         |
|                     |                          | 00101110 |         |
|                     |                          |          |         |

1. The **rrr** field uses the standard register select encoding.

# SRL Shift Right Logical

| SRL src    | src: R, IR, X                                                                                                                                                                                                                                                       |
|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Operation: | $\{src, CF\} \le \{0, src\}$                                                                                                                                                                                                                                        |
| Flags:     | <ul> <li>S: Set if result is negative; cleared otherwise.</li> <li>Z: Set if result is zero; cleared otherwise.</li> <li>H: Cleared.</li> <li>P/V: Set if parity of result is even; cleared otherwise.</li> <li>N: Cleared.</li> <li>C: Data from bit 0.</li> </ul> |

| Addressing<br>Modes | Assembly Syntax          | Encoding | Clocks  |
|---------------------|--------------------------|----------|---------|
| R:                  | SRL r                    | 11001011 | 4       |
|                     |                          | 00111rrr |         |
| IR:                 | SRL (HL)                 | 10100110 | 10 (8)  |
|                     |                          | 00111110 |         |
| X:                  | SRL (IX+d) or SRL (IY+d) | 11y11101 | 12 (10) |
|                     |                          | 11001011 |         |
|                     |                          | d        | _       |
|                     |                          | 00111110 | 1       |

Notes:

1. The **rrr** field uses the standard register select encoding.

| SUB A, src | src: R, IM, IR, X                                                                                                                                                                                                                                                                                                                                        |
|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Operation: | $A \leq A - src$                                                                                                                                                                                                                                                                                                                                         |
| Flags:     | <ul> <li>S: Set if result is negative; cleared otherwise.</li> <li>Z: Set if result is zero; cleared otherwise.</li> <li>H: Set if arithmetic borrow out of bit 3; cleared otherwise.</li> <li>P/V: Set if arithmetic overflow; cleared otherwise.</li> <li>N: Cleared.</li> <li>C: Set if arithmetic borrow out of bit 7; cleared otherwise.</li> </ul> |

| Addressing<br>Modes | Assembly Syntax                | Encoding      | Clocks |
|---------------------|--------------------------------|---------------|--------|
| R:                  | SUB A, r                       | 10010rrr      | 2      |
| IM:                 | SUB A, n                       | 11010110      | 4      |
|                     |                                | n             | ]      |
| IR:                 | SUB A, (HL)                    | 10010110      | 6 (4)  |
| X:                  | SUB A, (IX+d) or SUB A, (IY+d) | 11y11101      | 10 (8) |
|                     |                                | 10010110<br>d |        |

1. The  ${\bf rrr}$  field uses the standard register select encoding

# TST

Test

| TST src    | src: R, IM, IR                                                                                                                                                                                                                                          |
|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Operation: | A & src                                                                                                                                                                                                                                                 |
| Flags:     | <ul> <li>S: Set if result is negative; cleared otherwise.</li> <li>Z: Set if result is zero; cleared otherwise.</li> <li>H: Set.</li> <li>P/V: Set if parity of result is even; cleared otherwise.</li> <li>N: Cleared.</li> <li>C: Cleared.</li> </ul> |

| Addressing<br>Modes | Assembly Syntax | Encoding | Clocks |
|---------------------|-----------------|----------|--------|
| R:                  | TST r           | 11101101 | 4      |
|                     |                 | 00rrr100 |        |
| IM:                 | TST n           | 11101101 | 6      |
|                     | -               | 01100100 | _      |
|                     |                 | n        |        |
| IR:                 | TST (HL)        | 11101101 | 8 (6)  |
|                     |                 | 00110100 |        |

Notes:

1. The **rrr** field uses the standard register select encoding

2. This instruction is not present in the original Z80, but is a feature of the Z180.

# TSTIO

Test I/O

#### TSTIO n

| Operation:          | I/O(0,C) & n                                                                                                                                                                                                                                         |                   |        |  |  |  |
|---------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|--------|--|--|--|
| Flags:              | <ul> <li>Set if result is negative; cleared otherwise.</li> <li>Z: Set if result is zero; cleared otherwise.</li> <li>H: Set.</li> <li>P/V: Set if parity of result is even; cleared otherwise.</li> <li>N: Cleared.</li> <li>C: Cleared.</li> </ul> |                   |        |  |  |  |
| Addressing<br>Modes | Assembly Syntax                                                                                                                                                                                                                                      | Encoding          | Clocks |  |  |  |
|                     | TSTIO n                                                                                                                                                                                                                                              | 11101101 01110100 | 10     |  |  |  |

----n----

#### Notes:

1. This instruction is not present in the original Z80, but is a feature of the Z180.

| XOR A, src | src: R, IM, IR, X                                                                                                                                                                                                                                           |  |  |  |
|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Operation: | A <= A ^ src                                                                                                                                                                                                                                                |  |  |  |
| Flags:     | <ul> <li>S: Set if result is negative; cleared otherwise.</li> <li>Z: Set if result is zero; cleared otherwise.</li> <li>H: Cleared.</li> <li>P/V: Set if parity of result is even; cleared otherwise.</li> <li>N: Cleared.</li> <li>C: Cleared.</li> </ul> |  |  |  |

| Addressing<br>Modes | Assembly Syntax                | Encoding             | Clocks |  |
|---------------------|--------------------------------|----------------------|--------|--|
| R:                  | XOR A, r                       | 10101rrr             | 2      |  |
| IM:                 | XOR A, n                       | 11101110             | 4      |  |
|                     | l                              | n                    |        |  |
| IR:                 | XOR A, (HL)                    | 10101110             | 6 (4)  |  |
| X:                  | XOR A, (IX+d) or XOR A, (IY+d) | 11y11101<br>10101110 | 10 (8) |  |
|                     | [                              | d                    |        |  |

1. The  ${\bf rrr}$  field uses the standard register select encoding

# **Memory Management Unit**

The Memory Management Unit (MMU) expands the logical address space of 64K bytes (16-bit address) to a physical address space of 1M bytes (20-bit address), using variable-sized segments.

# **MMU Features:**

- Three memory segments, aligned on 4k boundaries
- Two eight-bit base registers, one implied base register of 0x00

### **MMU Registers**

| Register Name                 | Mnemonic | I/O address | R/W | Reset    |
|-------------------------------|----------|-------------|-----|----------|
| MMU Common Base Register      | CBR      | 0x0038      | R/W | 00000000 |
| MMU Bank Base Register        | BBR      | 0x0039      | R/W | 00000000 |
| MMU Common/Bank Area Register | CBAR     | 0x003A      | R/W | 11110000 |

# **MMU Register Descriptions**

| Common Base Register |       | Base Register                                              | (CBR)             | (Address = 0x0038) |  |
|----------------------|-------|------------------------------------------------------------|-------------------|--------------------|--|
| Bit(s)               | Value | Description                                                |                   |                    |  |
| 7:0                  |       | Eight bits of physical address<br>CBAR[7:4] <= Addr[15:12] | offset to use if: |                    |  |

| Bank Base Register |       | se Register                                                                              | (BBR) | (Address = 0x0039) |
|--------------------|-------|------------------------------------------------------------------------------------------|-------|--------------------|
| Bit(s)             | Value | Description                                                                              |       |                    |
| 7:0                |       | Eight bits of physical address offset to use if:<br>CBAR[3:0] <= Addr[15:12] < CBAR[7:4] |       |                    |

| MMU Common/Bank Area Register |       | (CBAR)                                                         | (Address = 0x003A) |  |  |  |
|-------------------------------|-------|----------------------------------------------------------------|--------------------|--|--|--|
| Bit(s)                        | Value | Description                                                    |                    |  |  |  |
| 7:4                           | Write | Boundary value for switching from BBR to CBR for translation.  |                    |  |  |  |
| 3:0                           | Write | Boundary value for switching from none to BBR for translation. |                    |  |  |  |

# **MMU Operation Details**

The Memory Management Unit divides the 64K logical address space into three variablesized segments, with each segment a multiple of 4K bytes. Depending on the MMU programming one, two, or all three segments may be used at once.

Only two of the segments can be relocated, using a base register in the MMU. The third segment always starts at logical address 0x0000. The figure below shows the typical case of three segments:

|                                                                        |               | 0xFFFFF |
|------------------------------------------------------------------------|---------------|---------|
| Physical Address[19:12] = Addr[15:12] + CBR                            | Common Area 1 |         |
| CBAR[7:4] sets boundary                                                |               |         |
| Physical Address[19:12] = Addr[15:12] + BBR<br>CBAR[3:0] sets boundary | Bank Area     |         |
|                                                                        | Common Area 0 | 0x00000 |

# **Interrupt Control**

The Interrupt Control (ICTL) manages all of the on-chip and external interrupt requests. It automatically prioritizes interrupt requests and generates interrupt vectors where appropriate.

# **Interrupt Control Features:**

- Fixed prioritization of all interrupt requests.
- Relocatable interrupt vectors for all on-chip peripherals.
- Individual enables for external interrupt requests (int0\_req, int1\_req and int2\_req).
- Automatic selection of Interrupt Mode 2 for internal and two external interrupt requests.

### **Interrupt Control Registers**

| Register Name                   | Mnemonic | I/O address | R/W | Reset    |
|---------------------------------|----------|-------------|-----|----------|
| Interrupt Vector Low Register   | IL       | 0x0033      | R/W | 00000000 |
| Interrupt/Trap Control Register | ITC      | 0x0034      | R/W | 00111001 |

# **Interrupt Control Register Descriptions**

| Interrupt Vector Low Re |       |                                                                                                                      | gister                                                                                                                     | (IL)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | (Address = 0x0033)                                                          |  |
|-------------------------|-------|----------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------|--|
| Bit(s)                  | Value | Description                                                                                                          |                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                             |  |
| 7:5                     |       | an interrupt<br>int1_req an<br>int1_req<br>int2_req<br>prt0:<br>prt1:<br>dma0:<br>dma1:<br>csio:<br>asci0:<br>asci1: | acknowledge<br>ad <b>int2_req</b> inp<br>: 00000<br>: 00010<br>00100<br>00110<br>01000<br>01010<br>01100<br>01110<br>10000 | ignificant bits of the transaction for the o buts. The other bits of the bits of the other bits of the other bits of the other bits of the | e interrupt vector returned during<br>n-chip interrupts, as well as for the |  |
|                         |       |                                                                                                                      | -                                                                                                                          | request it must be ex                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | -                                                                           |  |
| 4:0                     |       | These bits a                                                                                                         | are reserved an                                                                                                            | d should always be                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | written with zeros.                                                         |  |

| Inte   | errupt/Trap | Control Register (ITC) (Address = 0x0034)                                                                                                                                 |  |  |  |  |
|--------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| Bit(s) | Value       | Description                                                                                                                                                               |  |  |  |  |
| 7      | 0           | No illegal instruction fetch since last write of zero to this bit.An illegal instruction has been fetched. This status is latched until this bit is<br>written with zero. |  |  |  |  |
|        | 1           |                                                                                                                                                                           |  |  |  |  |
| 6      | 0           | Last illegal instruction fetch was a two-byte opcode.                                                                                                                     |  |  |  |  |
|        | 1           | Last illegal instruction fetch was a three-byte opcode.                                                                                                                   |  |  |  |  |
| 5:3    |             | These bits are reserved. Reads always return ones.                                                                                                                        |  |  |  |  |
| 2      | 0           | Disable <b>int2_req</b> interrupt request.                                                                                                                                |  |  |  |  |
|        | 1           | Enable <b>int2_req</b> interrupt request.                                                                                                                                 |  |  |  |  |
| 1      | 0           | Disable <b>int1_req</b> interrupt request.                                                                                                                                |  |  |  |  |
|        | 1           | Enable int1_req interrupt request.                                                                                                                                        |  |  |  |  |
| 0      | 0           | Disable int0_req interrupt request.                                                                                                                                       |  |  |  |  |
|        | 1           | Enable <b>int0_req</b> interrupt request.                                                                                                                                 |  |  |  |  |

# **Direct Memory Access**

Two Direct memory Access (DMA) channels provide memory-to-memory, memory-to-I/ O and I/O-to-memory data transfers in parallel with CPU operation. The two channels are not identical, but have similar capabilities.

# **DMA Features:**

- 20-bit physical memory address, 16-bit I/O address
- Channel 0 supports memory-memory and memory-I/O transfers
- Channel 1 supports only memory-I/O transfers
- Memory address increment, decrement, or fixed
- I/O address always fixed
- Maximum transfer length of 65,536 bytes
- dreq (external request) input for each channel, programmable edge- or level-sensitive
- tend (Transfer End or DMA Complete) output for each channel
- Mode to toggle between channels, which allows simulating scatter/gather operation

# **DMA Registers**

| Register Name                           | Mnemonic | I/O address | R/W | Reset    |
|-----------------------------------------|----------|-------------|-----|----------|
| DMA Source Address Register 0 Low       | SAR0L    | 0x0020      | R/W | XXXXXXXX |
| DMA Source Address Register 0 High      | SAR0H    | 0x0021      | R/W | XXXXXXXX |
| DMA Source Address Register 0 Page      | SAR0P    | 0x0022      | R/W | 00000000 |
| DMA Destination Address Register 0 Low  | DAR0L    | 0x0023      | R/W | XXXXXXXX |
| DMA Destination Address Register 0 High | DAR0H    | 0x0024      | R/W | XXXXXXXX |
| DMA Destination Address Register 0 Page | DAR0P    | 0x0025      | R/W | 00000000 |
| DMA Byte Count Register 0 Low           | BCR0L    | 0x0026      | R/W | XXXXXXXX |
| DMA Byte Count Register 0 High          | BCR0H    | 0x0027      | R/W | XXXXXXXX |
| DMA Memory Address Register 1 Low       | MAR1L    | 0x0028      | R/W | XXXXXXXX |
| DMA Memory Address Register 1 High      | MAR1H    | 0x0029      | R/W | XXXXXXXX |
| DMA Memory Address Register 1 Page      | MAR1P    | 0x002A      | R/W | 0000xxxx |
| DMA I/O Address Register 1 Low          | IAR1L    | 0x002B      | R/W | XXXXXXXX |
| DMA I/O Address Register 1 High         | IAR1H    | 0x002C      | R/W | XXXXXXXX |
| DMA I/O Address Register 1 Page         | IAR1P    | 0x002D      | R/W | 00000000 |
| DMA Byte Count Register 1 Low           | BCR1L    | 0x002E      | R/W | XXXXXXXX |
| DMA Byte Count Register 1 High          | BCR1H    | 0x002F      | R/W | XXXXXXXX |
| DMA Status Register                     | DSTAT    | 0x0030      | R/W | 00110010 |
| DMA Mode Register                       | DMODE    | 0x0031      | R/W | 11000001 |
| DMA/Wait Control Register               | DCNTL    | 0x0032      | R/W | 11110000 |

**Note:** The reset value for bit 7-4 in the DMA/Wait Control Register can be changed using a compile option. The default, shown here, selects the maximum number of internally-generated Wait states for both memory and I/O. A compile option exists to disable all internally-generated Wait states as a result of a Reset.

#### **DMA Register Descriptions**

| DM     | A Source A                      | Address Register 0                                       | (SAR0L) | (Address = 0x0020) |
|--------|---------------------------------|----------------------------------------------------------|---------|--------------------|
|        |                                 |                                                          | (SAR0H) | (Address = 0x0021) |
|        |                                 |                                                          | (SAR0P) | (Address = 0x0022) |
| Bit(s) | Value                           | Description                                              |         |                    |
| 23:20  |                                 | These bits are reserved and will always be read as zero. |         |                    |
| 19:16  | 19:16DMA 0 source address page. |                                                          |         |                    |
| 15:8   |                                 | DMA 0 source address MSByte.                             |         |                    |
| 7:0    |                                 | DMA 0 source address LSByte.                             |         |                    |

**Note:** When the DMA 0 Source Address is an I/O address, two bits of the SAR0P register select the source for the DMA Request signal, according to the table below. The corresponding address of the ASCI Receive Data Register must be written to the DMA Source Address Register when DMA 0 is connected to an ASCI Receive Data Ready signal. Modifying the source of the DMA Request signal should only be done while the DMA channel is disabled.

| SAR0P[17:16] | DMA Request when SAR is I/O |  |
|--------------|-----------------------------|--|
| 00           | dreq0                       |  |
| 01           | ASCI0 Receive Data Ready    |  |
| 10           | ASCI1 Receive Data Ready    |  |
| 11           | dreq1                       |  |

| DMA [  | Destination                          | n Address Register 0                                     | (DAR0L) | (Address = 0x0023) |
|--------|--------------------------------------|----------------------------------------------------------|---------|--------------------|
|        |                                      |                                                          | (DAR0H) | (Address = 0x0024) |
|        |                                      |                                                          | (DAR0P) | (Address = 0x0025) |
| Bit(s) | Value                                | Description                                              |         |                    |
| 23:20  |                                      | These bits are reserved and will always be read as zero. |         |                    |
| 19:16  | 19:16DMA 0 destination address page. |                                                          |         |                    |
| 15:8   |                                      | DMA 0 destination address MSB.                           |         |                    |
| 7:0    |                                      | DMA 0 destination address LSB.                           |         |                    |

**Note:** When the DMA 0 Destination Address is an I/O address, two bits of the DAR0P register select the source for the DMA Request signal, according to the table below. The corresponding address of the ASCI Transmit Data Register must be written to the DMA Destination Address Register when DMA 0 is connected to an ASCI Transmit Data Ready signal. Modifying the source of the DMA Request signal should only be done while the DMA channel is disabled.

| DAR0P[17:16] | DMA Request when DAR is I/O |  |
|--------------|-----------------------------|--|
| 00           | dreq0                       |  |
| 01           | ASCI0 Transmit Data Ready   |  |
| 10           | ASCI1 Transmit Data Ready   |  |
| 11           | dreq1                       |  |

| D      | MA Byte C | ount Register 0       | (BCR0L)     | (Address = 0x0026) |
|--------|-----------|-----------------------|-------------|--------------------|
|        |           |                       | (BCR0H)     | (Address = 0x0027) |
| Bit(s) | Value     |                       | Description |                    |
| 15:8   |           | DMA 0 byte count MSB. |             |                    |
| 7:0    |           | DMA 0 byte count LSB. |             |                    |

| DMA    | Memory / | Address Register 1         | (MAR1L)               | (Address = 0x0028) |
|--------|----------|----------------------------|-----------------------|--------------------|
|        |          |                            | (MAR1H)               | (Address = 0x0029) |
|        |          |                            | (MAR1P)               | (Address = 0x002A) |
| Bit(s) | Value    |                            | Description           |                    |
| 23:20  |          | These bits are reserved an | d will always be read | as zero.           |
| 19:16  |          | DMA 1 memory address page. |                       |                    |
| 15:8   |          | DMA 1 memory address       | MSB.                  |                    |
| 7:0    |          | DMA 1 memory address       | LSB.                  |                    |

| D                                                                                                        | MA I/O Ad | dress Register 1                                                                                                      | (IAR1L)     | (Address = 0x002B)                 |  |  |
|----------------------------------------------------------------------------------------------------------|-----------|-----------------------------------------------------------------------------------------------------------------------|-------------|------------------------------------|--|--|
|                                                                                                          |           |                                                                                                                       | (IAR1H)     | (Address = 0x002C)                 |  |  |
|                                                                                                          |           |                                                                                                                       | (IAR1P)     | (Address = 0x002D)                 |  |  |
| Bit(s)                                                                                                   | Value     |                                                                                                                       | Description |                                    |  |  |
| 23                                                                                                       | 0         | DMA channels are indep                                                                                                | endent.     |                                    |  |  |
|                                                                                                          | 1         | Toggle between channels<br>internal request between                                                                   |             | tomatically switches selected      |  |  |
| 22                                                                                                       | 0         | DMA 0 is the currently selected channel. This bit is valid only when the toggle function is enabled in this register. |             |                                    |  |  |
| 1 DMA 1 is the currently selected channel. This bit is val toggle function is selected in this register. |           |                                                                                                                       |             | bit is valid only when the channel |  |  |
| 21:18                                                                                                    |           | These bits are reserved, but are R/W.                                                                                 |             |                                    |  |  |
| 17:16                                                                                                    | 00        | DMA 1 is controlled by <b>dreq1</b> .                                                                                 |             |                                    |  |  |
|                                                                                                          | 01        | DMA 1 connected to ASCI0 (receive if DMA 1 source is I/O, transmit if DMA destination is I/O).                        |             |                                    |  |  |
|                                                                                                          | 10        | 10 DMA 1 connected to ASCI1 (receive if DMA 1 source is I/O, transmit if DM destination is I/O).                      |             |                                    |  |  |
| 11 DMA 1 is controlled by <b>dreq0</b> .                                                                 |           |                                                                                                                       |             |                                    |  |  |
| 15:8                                                                                                     |           | DMA 1 I/O address MSI                                                                                                 | 3.          |                                    |  |  |
| 7:0                                                                                                      |           | DMA 1 I/O address LSB.                                                                                                |             |                                    |  |  |

**Note:** Modifying the source of the DMA Request signal should only be done while the DMA channel is disabled.

| D      | DMA Byte Count Register 1 |                       |                    | (Address = 0x002E) |
|--------|---------------------------|-----------------------|--------------------|--------------------|
|        |                           | (BCR1H)               | (Address = 0x002F) |                    |
| Bit(s) | Value                     | Description           |                    |                    |
| 15:8   |                           | DMA 1 byte count MSB. |                    |                    |
| 7:0    |                           | DMA 1 byte count LSB. |                    |                    |

|           | DMA Sta | tus Register (DSTAT) (Address = 0x0030)                                                                                                              |  |  |  |
|-----------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Bit(s)    | Value   | Description                                                                                                                                          |  |  |  |
| 7         | 0       | Disable DMA 1. An interrupt will be requested while this bit is cleared and DMA 1 interrupts are enabled.                                            |  |  |  |
|           | 1       | Enable DMA 1. Note that this bit can only be updated if bit 5 is cleared during the write.                                                           |  |  |  |
| 6         | 0       | Disable DMA 0. An interrupt will be requested while this bit is cleared and DMA 0 interrupts are enabled.                                            |  |  |  |
|           | 1       | Enable DMA 0. Note that this bit can only be updated if bit 4 is cleared during the write.                                                           |  |  |  |
| 5         | 0       | Allow bit 7 of this register to be updated with this write.                                                                                          |  |  |  |
| (wr-only) | 1       | Do not allow bit 7 of this register to be updated with this write. This bit always returns one when read.                                            |  |  |  |
| 4         | 0       | Allow bit 6 of this register to be updated with this write.                                                                                          |  |  |  |
| (wr-only) | 1       | Do not allow bit 6 of this register to be updated with this write. This bit always returns one when read.                                            |  |  |  |
| 3         | 0       | Disable DMA 1 interrupt.                                                                                                                             |  |  |  |
|           | 1       | Enable DMA 1 interrupt.                                                                                                                              |  |  |  |
| 2         | 0       | Disable DMA 0 interrupt.                                                                                                                             |  |  |  |
|           | 1       | Enable DMA 0 interrupt.                                                                                                                              |  |  |  |
| 1         |         | This bit is reserved and always returns one when read.                                                                                               |  |  |  |
| 0         | 0       | DMA is disabled. This bit is cleared by a Non-maskable Interrupt request ( <b>nmi_req</b> ) to inhibit DMA operation during the NMI service routine. |  |  |  |
| (rd-only) | 1       | DMA is enabled. This bit is not set directly, but will be set whenever either bit 7 or bit 6 of this register are written with 1.                    |  |  |  |

|        | DMA Mo | ode Register (DMODE) (Address = 0x0031)                                              |  |  |  |
|--------|--------|--------------------------------------------------------------------------------------|--|--|--|
| Bit(s) | Value  | Description                                                                          |  |  |  |
| 7:6    |        | These bits are reserved and always return one when read.                             |  |  |  |
| 5:4    | 00     | DMA 0 destination is memory. Auto-increment destination address after each transfer. |  |  |  |
|        | 01     | DMA 0 destination is memory. Auto-decrement destination address after each transfer. |  |  |  |
|        | 10     | DMA 0 destination is memory, with a fixed address.                                   |  |  |  |
|        | 11     | DMA 0 destination is I/O, with a fixed address.                                      |  |  |  |
| 3:2    | 00     | DMA 0 source is memory. Auto-increment source address after each transfer.           |  |  |  |
|        | 01     | DMA 0 source is memory. Auto-decrement source address after each transfer.           |  |  |  |
|        | 10     | DMA 0 source is memory, with a fixed address.                                        |  |  |  |
|        | 11     | DMA 0 source is I/O, with a fixed address.                                           |  |  |  |
| 1      | 0      | DMA 0 memory-to-memory transfers are one byte at a time.                             |  |  |  |
|        | 1      | DMA 0 memory-to-memory transfers burst for the entire byte count.                    |  |  |  |
| 0      |        | This bit is reserved and always returns one when read.                               |  |  |  |

**Note:** The DMA Mode Register should only be modified while DMA 0 is disabled. Not all combinations of source and destination are valid. See the table below:

| DMODE[5:4] | DMODE[3:2] | Transfer type                              |
|------------|------------|--------------------------------------------|
| 00         | 00         | Memory (autoinc) -> Memory (autoinc)       |
| 00         | 01         | Memory (autodec) -> Memory (autoinc)       |
| 00         | 10         | Memory (fixed address) -> Memory (autoinc) |
| 00         | 11         | I/O (fixed address) -> Memory (autoinc)    |
| 01         | 00         | Memory (autoinc) -> Memory (autodec)       |
| 01         | 01         | Memory (autodec) -> Memory (autodec)       |
| 01         | 10         | Memory (fixed address) -> Memory (autodec) |
| 01         | 11         | I/O (fixed address) -> Memory (autodec)    |
| 10         | 00         | Memory (autoinc) -> Memory (fixed address) |
| 10         | 01         | Memory (autodec) -> Memory (fixed address) |
| 10         | 10         | Invalid                                    |
| 10         | 11         | Invalid                                    |
| 11         | 00         | Memory (autoinc) -> I/O (fixed address)    |
| 11         | 01         | Memory (autodec) -> I/O (fixed address)    |
| 11         | 10         | Invalid                                    |
| 11         | 11         | Invalid                                    |

| DMA/Wait Contro |       | Control Register                                                                                                                                                                                                                                                                                   | (DCNTL)              | (Address = 0x0032   |  |  |
|-----------------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------|---------------------|--|--|
| Bit(s)          | Value |                                                                                                                                                                                                                                                                                                    | Description          |                     |  |  |
| 7:6             | 00    | Memory transfers have 0 wa                                                                                                                                                                                                                                                                         | ait states.          |                     |  |  |
|                 | 01    | Memory transfers have 1 wait state.                                                                                                                                                                                                                                                                |                      |                     |  |  |
|                 | 10    | Memory transfers have 2 wait states.                                                                                                                                                                                                                                                               |                      |                     |  |  |
|                 | 11    | Memory transfers have 3 wa                                                                                                                                                                                                                                                                         | ait states.          |                     |  |  |
| 5:4             | 00    | I/O transfers have 0 wait sta                                                                                                                                                                                                                                                                      | ates.                |                     |  |  |
|                 | 01    | I/O transfers have 1 wait sta                                                                                                                                                                                                                                                                      | ate.                 |                     |  |  |
|                 | 10    | I/O transfers have 2 wait sta                                                                                                                                                                                                                                                                      | ates.                |                     |  |  |
|                 | 11    | I/O transfers have 3 wait sta                                                                                                                                                                                                                                                                      | ates.                |                     |  |  |
| 3               | 0     | <b>dreq1</b> is level-sensitive. DMA transfers continue as long as the <b>dreq1</b> signal is active. To terminate on a particular DMA transfer, the <b>dreq1</b> signal should be de asserted before the start of the final DMA write transfer.                                                   |                      |                     |  |  |
|                 | 1     | <b>dreq1</b> is edge-sensitive. One DMA transfer per inactive-to-active edge on <b>dreq1</b> .<br>Note that inactive-to-active edges must not occur more often that the DMA channel is capable of transferring a byte. The edge-detector is cleared during the last clock of a DMA write transfer. |                      |                     |  |  |
| 2               | 0     | <b>dreq0</b> is level-sensitive. DMA transfers continue as long as the <b>dreq0</b> signal is active. To terminate on a particular DMA transfer, the <b>dreq0</b> signal should be deasserted before the start of the final DMA write transfer.                                                    |                      |                     |  |  |
|                 | 1     | <b>dreq0</b> is edge-sensitive. One DMA transfer per inactive-to-active edge on <b>dreq0</b> .<br>Note that inactive-to-active edges must not occur more often that the DMA channel is capable of transferring a byte. The edge-detector is cleared during the last clock of a DMA write transfer. |                      |                     |  |  |
| 1               | 0     | DMA 1 transfers are memory-to-I/O.                                                                                                                                                                                                                                                                 |                      |                     |  |  |
|                 | 1     | DMA 1 transfers are I/O-to-memory.                                                                                                                                                                                                                                                                 |                      |                     |  |  |
| 0               | 0     | DMA 1 memory address au                                                                                                                                                                                                                                                                            | to-increments and I/ | O address is fixed. |  |  |
|                 | 1     | DMA 1 memory address au                                                                                                                                                                                                                                                                            | to-decrements and I/ | O address is fixed. |  |  |

**Note:** Bits 3-0 of the DMA/Wait Control Register should only be modified while the DMA is disabled.

# **Async Serial**

Each of the two Async Serial Communications Interface (ASCI) channels provide asynchronous communications capabilities.

#### **ASCI Features:**

- Full-duplex, 7 or 8 bits/character
- Optional odd or even parity
- Optional multiprocessor bit
- One or two transmit Stop bits (receive is always one Stop bit)
- One byte of buffering in each receiver and transmitter
- Automatic operation with on-chip DMA
- Overrun Error, Framing Error and Parity Error detection
- 16x or 64x sampling clock (does not support 1x sampling clock of Z8L180)
- cts, dcd and rts modem control signals for both channels
- Detect and send Break
- External clock input, dedicated divider, or programmable 16-bit divider for baud-rate

### **ASCI Registers**

| Register Name                               | Mnemonic | I/O address | R/W | Reset    |
|---------------------------------------------|----------|-------------|-----|----------|
| ASCI Control Register A, Channel 0          | CNTLA0   | 0x0000      | R/W | 0001x000 |
| ASCI Control Register A, Channel 1          | CNTLA1   | 0x0001      | R/W | 0001x000 |
| ASCI Control Register B, Channel 0          | CNTLB0   | 0x0002      | R/W | x0x00111 |
| ASCI Control Register B, Channel 1          | CNTLB1   | 0x0003      | R/W | x0x00111 |
| ASCI Status Register, Channel 0             | STAT0    | 0x0004      | R/W | 00000xx0 |
| ASCI Status Register, Channel 1             | STAT1    | 0x0005      | R/W | 00000xx0 |
| ASCI Transmit Data Register, Channel 0      | TDR0     | 0x0006      | R/W | XXXXXXXX |
| ASCI Transmit Data Register, Channel 1      | TDR1     | 0x0007      | R/W | XXXXXXXX |
| ASCI Receive Data Register, Channel 0       | RDR0     | 0x0008      | R/W | XXXXXXXX |
| ASCI Receive Data Register, Channel 1       | RDR1     | 0x0009      | R/W | XXXXXXXX |
| ASCI Extension Control Register, Channel 0  | ECNTL0   | 0x0012      | R/W | 00000000 |
| ASCI Extension Control Register, Channel 1  | ECNTL1   | 0x0013      | R/W | 00000000 |
| ASCI Time Constant Low Register, Channel 0  | TCL0     | 0x001A      | R/W | 00000000 |
| ASCI Time Constant High Register, Channel 0 | TCH0     | 0x001B      | R/W | 00000000 |
| ASCI Time Constant Low Register, Channel 1  | TCL1     | 0x001C      | R/W | 00000000 |
| ASCI Time Constant High Register, Channel 1 | TCH1     | 0x001D      | R/W | 00000000 |

### **ASCI Register Descriptions**

|         | ASCI Con | trol Register A                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | (CNTLA0)                                                                                                    | (Address = 0x0000)             |  |
|---------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------|--------------------------------|--|
|         |          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | (CNTLA1)                                                                                                    | (Address = 0x0001)             |  |
| Bit(s)  | Value    | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                             |                                |  |
| 7       | 0        | Never filter receive by                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | tes based on the state of t                                                                                 | he MP bit.                     |  |
|         | 1        | If multiprocessor mode transferred to the received to the rece |                                                                                                             | with the MP bit set to one are |  |
| 6       | 0        | Disable the receiver. T                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | his selection is forced by                                                                                  | IOSTOP mode.                   |  |
|         | 1        | Enable the receiver.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                             |                                |  |
| 5       | 0        | Disable the transmitter                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | . This selection is forced                                                                                  | by IOSTOP mode.                |  |
|         | 1        | Enable the transmitter.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Enable the transmitter.                                                                                     |                                |  |
| 4       | 0        | Drive the corresponding                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Drive the corresponding <b>rts</b> output active (High).                                                    |                                |  |
|         | 1        | Drive the corresponding <b>rts</b> output inactive (Low).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                             |                                |  |
| 3       | 0        | Either multiprocessor mode is disabled, or the last received MP bit was set to zero.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                             |                                |  |
| (read)  | 1        | Multiprocessor mode i                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | s enabled and the last rec                                                                                  | eived MP bit was set to one.   |  |
| 3       | 0        | Clear all receive error                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | flags (Overrun, Framing                                                                                     | Error and Parity Error).       |  |
| (write) | 1        | No effect.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                             |                                |  |
| 2       | 0        | 7 bits per character.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                             |                                |  |
|         | 1        | 8 bits per character.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                             |                                |  |
| 1       | 0        | 1 . 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Disable parity generation and parity checking. This bit is ignored when the multiprocessor mode is enabled. |                                |  |
|         | 1        | Enable parity generation and parity checking.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                             |                                |  |
| 0       | 0        | Transmit 1 Stop bit. Th                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | ne receiver always checks                                                                                   | s for one Stop bit.            |  |
|         | 1        | Transmit 2 Stop bits.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                             |                                |  |

|         | ASCI Con | trol Register B                                 | (CNTLB0)                                                                                                                                                                                  | (Address = 0x0002)                |  |  |
|---------|----------|-------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------|--|--|
|         |          |                                                 | (CNTLB1)                                                                                                                                                                                  | (Address = 0x0003)                |  |  |
| Bit(s)  | Value    | Description                                     |                                                                                                                                                                                           |                                   |  |  |
| 7       | 0        | In multiprocessor mod                           | e, transmit a zero (signify                                                                                                                                                               | ing data) in the MP bit position. |  |  |
|         | 1        | In multiprocessor mod position.                 | e, transmit a one (signifyi                                                                                                                                                               | ing an address) in the MP bit     |  |  |
| 6       | 0        | Disable multiprocessor                          | r mode.                                                                                                                                                                                   |                                   |  |  |
|         | 1        | parity bit location is us                       | Enable multiprocessor mode. In multiprocessor mode there is no parity, but the parity bit location is used to tag the data as either data (MP bit is zero) or an address (MP bit is one). |                                   |  |  |
| 5       | 0        | The corresponding <b>cts</b>                    | input is active (High).                                                                                                                                                                   |                                   |  |  |
| (read)  | 1        | The corresponding <b>cts</b>                    | input is inactive (Low).                                                                                                                                                                  |                                   |  |  |
| 5       | 0        | System clock divided                            | by 10 drives the internal d                                                                                                                                                               | lata rate selection.              |  |  |
| (write) | 1        | System clock divided                            | by 30 drives the internal d                                                                                                                                                               | lata rate selection.              |  |  |
| 4       | 0        | Even parity.                                    |                                                                                                                                                                                           |                                   |  |  |
|         | 1        | Odd parity.                                     |                                                                                                                                                                                           |                                   |  |  |
| 3       | 0        | Sampling clock rate of                          | 16x.                                                                                                                                                                                      |                                   |  |  |
|         | 1        | Sampling clock rate of                          | 64x.                                                                                                                                                                                      |                                   |  |  |
| 2:0     | 000      | Data rate set by interna                        | al clock, used directly.                                                                                                                                                                  |                                   |  |  |
|         | 001      | Data rate set by interna                        | al clock, divided by 2.                                                                                                                                                                   |                                   |  |  |
|         | 010      | Data rate set by interna                        | al clock, divided by 4.                                                                                                                                                                   |                                   |  |  |
|         | 011      | Data rate set by internal clock, divided by 8.  |                                                                                                                                                                                           |                                   |  |  |
|         | 100      | Data rate set by internal clock, divided by 16. |                                                                                                                                                                                           |                                   |  |  |
|         | 101      | Data rate set by internal clock, divided by 32. |                                                                                                                                                                                           |                                   |  |  |
|         | 110      | Data rate set by interna                        | al clock, divided by 64.                                                                                                                                                                  |                                   |  |  |
|         | 111      | Data rate set by extern                         | al clock ( <b>cka_in</b> ), used di                                                                                                                                                       | rectly.                           |  |  |

|           | ASCI Sta | tus Register                                                                                                                                                                                                                                                                                                                                  | (STAT0)                                             | (Address = 0x0004)                                                                                           |
|-----------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------|--------------------------------------------------------------------------------------------------------------|
|           |          |                                                                                                                                                                                                                                                                                                                                               | (STAT1)                                             | (Address = 0x0005)                                                                                           |
| Bit(s)    | Value    | Description (Async mode only)                                                                                                                                                                                                                                                                                                                 |                                                     |                                                                                                              |
| 7         | 0        | The receive buffer is empty.                                                                                                                                                                                                                                                                                                                  |                                                     |                                                                                                              |
|           | 1        | Register, while the correspon                                                                                                                                                                                                                                                                                                                 | nding <b>dcd</b> input is i<br>terrupts are enabled | l, an interrupt is requested while                                                                           |
| 6         | 0        | The receive buffer was not o                                                                                                                                                                                                                                                                                                                  | overrun.                                            |                                                                                                              |
|           | 1        |                                                                                                                                                                                                                                                                                                                                               |                                                     | red while the corresponding <b>dcd</b> and by writing a 0 to bit 3 of the                                    |
| 5         | 0        | The received byte did not ha                                                                                                                                                                                                                                                                                                                  | ve a parity error.                                  |                                                                                                              |
|           | 1        | The received byte had a parity error. This bit is cleared while the corresponding <b>dcd</b> input is inactive (Low), during IOSTOP mode, and by writing a 0 to bit 3 of teh ASCI Control Register A.                                                                                                                                         |                                                     |                                                                                                              |
| 4         | 0        | The received byte did not ha                                                                                                                                                                                                                                                                                                                  | ve a framing error.                                 |                                                                                                              |
|           | 1        | The received byte had a framing error. This bit is cleared while the corresponding <b>dcd</b> input is inactive (Low), during IOSTOP mode, and by writing a 0 to bit 3 of the ASCI Control Register A.                                                                                                                                        |                                                     |                                                                                                              |
| 3         | 0        | Disable receive interrupts.                                                                                                                                                                                                                                                                                                                   |                                                     |                                                                                                              |
|           | 1        | buffer is full, any of the rece                                                                                                                                                                                                                                                                                                               | ive error bits are se                               | requested whenever the receive<br>et, or the <b>dcd</b> signal went from<br>d'whether or not the receiver is |
| 2         | 0        | The corresponding <b>dcd</b> inpu                                                                                                                                                                                                                                                                                                             | t is active (High).                                 |                                                                                                              |
| (rd-only) | 1        | The corresponding <b>dcd</b> input is inactive (Low). This bit remains set for the first read of this register after a Low-to-High transition on the dcd input so that software can always register that this transition has occurred.                                                                                                        |                                                     |                                                                                                              |
| 1         | 0        | The transmit buffer is full.                                                                                                                                                                                                                                                                                                                  |                                                     |                                                                                                              |
|           | 1        | The transmit buffer is empty. This bit is cleared by writing to the ASCI Transmit<br>Data Register. This bit is set while the corresponding <b>cts</b> input is inactive (Low)<br>and during IOSTOP mode. If enabled, an interrupt is requested while this bit is<br>set. The transmit interrupt is cleared when the transmit buffer is full. |                                                     |                                                                                                              |
| 0         | 0        | Disable transmit interrupts.                                                                                                                                                                                                                                                                                                                  |                                                     |                                                                                                              |
|           | 1        | Enable transmit interrupts. A<br>transmit buffer is empty. A b<br>be transferred to the transmit<br>empty condition.                                                                                                                                                                                                                          | byte written to the t                               | ransmit buffer may immediately                                                                               |

| AS     | ASCI Transmit Data Register |                                                                                                                                                                                     | (TDR0) | (Address = 0x0006) |
|--------|-----------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|--------------------|
|        |                             |                                                                                                                                                                                     | (TDR1) | (Address = 0x0007) |
| Bit(s) | Value                       | Description                                                                                                                                                                         |        |                    |
| 7:0    | Read                        | Returns the contents of the transmit buffer, independent of whether or not the byte has been transmitted. Reading the transmit buffer does not affect the transmission of the byte. |        |                    |
|        | Write                       | Loads the transmit buffer with a data byte for transmission.                                                                                                                        |        |                    |

| A      | ASCI Receive Data Register |                                                                                  | (RDR0) | (Address = 0x0008) |
|--------|----------------------------|----------------------------------------------------------------------------------|--------|--------------------|
|        |                            |                                                                                  | (RDR1) | (Address = 0x0009) |
| Bit(s) | Value                      | Description                                                                      |        |                    |
| 7:0    | Read                       | Returns the contents of the receive buffer.                                      |        |                    |
|        | Write                      | Loads the receive buffer with a byte, but only if the buffer is currently empty. |        |                    |

| ASC    | ASCI Time Constant Low Register |                                                                                                                                                            | (TCL0)      | (Address = 0x001A) |  |
|--------|---------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------------|--|
|        |                                 |                                                                                                                                                            | (TCL1)      | (Address = 0x001C) |  |
| Bit(s) | Value                           |                                                                                                                                                            | Description |                    |  |
| 7:0    |                                 | Eight LSBs of the divider that generates the serial clock for the channel. This divider is not used unless enabled in the ASCI Extension Control Register. |             |                    |  |

| ASCI   | ASCI Time Constant High Register |                                                                                                                                                                                                                 | (TCH0) | (Address = 0x001B) |
|--------|----------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|--------------------|
|        |                                  |                                                                                                                                                                                                                 | (TCH1) | (Address = 0x001D) |
| Bit(s) | Value                            | Description                                                                                                                                                                                                     |        |                    |
| 7:0    |                                  | Eight MSBs of the divider that generates the serial clock for the channel. This divider is not used unless enabled in the ASCI Extension Control Register. The divider counts with a period of 2*({TCH,TCL}+2). |        |                    |

| ASC       | I Extensio | n Control Register                                                                                                                                                                                              | (ECNTL0)                      | (Address = 0x0012)                         |
|-----------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------|--------------------------------------------|
|           |            |                                                                                                                                                                                                                 | (ECNTL1)                      | (Address = 0x0013)                         |
| Bit(s)    | Value      |                                                                                                                                                                                                                 | Description                   |                                            |
| 7         | 0          | Normal operation for rece                                                                                                                                                                                       | eive data interrupt: inte     | rrupt while receive buffer full.           |
|           | 1          | No interrupt while receiv                                                                                                                                                                                       | e buffer full. Used with      | n receive DMA transfers.                   |
| 6         | 0          | Enable the corresponding backwards-compatible or                                                                                                                                                                | 6                             | e auto-enable. This is default,            |
|           | 1          | Disable the corresponding<br>to setting the <b>dcd</b> signal a                                                                                                                                                 |                               | e auto-enable. This is equivalent          |
| 5         | 0          | Enable the corresponding <b>cts</b> signal as a transmit auto-enable. This is the default, backwards-compatible operation.                                                                                      |                               |                                            |
|           | 1          | Disable the corresponding <b>cts</b> signal as a transmit auto-enable. This is equivalent to setting the <b>cts</b> signal active (High).                                                                       |                               |                                            |
| 4         |            | This bit is reserved and should always be written as zero.                                                                                                                                                      |                               |                                            |
| 3         | 0          | Disable 16-bit baud rate g                                                                                                                                                                                      | generator counter.            |                                            |
|           | 1          | Enable 16-bit baud rate g internal divider or externa                                                                                                                                                           |                               | overrides the selection for the ITLB[2:0]. |
| 2         | 0          | Disable the Break feature                                                                                                                                                                                       | . This is the default, ba     | ckwards-compatible operation.              |
|           | 1          | Enable the Break feature                                                                                                                                                                                        | (detection and generati       | on of Break).                              |
| 1         | 0          | No Break detected.                                                                                                                                                                                              |                               |                                            |
| (rd-only) | 1          | Break Detected. This bit remains set for the duration of the Break condition. A receive interrupt will be generated at the start of the break condition as the first byte is transferred to the receive buffer. |                               |                                            |
| 0         | 0          | No effect.                                                                                                                                                                                                      |                               |                                            |
|           | 1          | Send Break, by forcing the duration of the break.                                                                                                                                                               | e corresponding <b>txa</b> si | gnal Low. Software must time               |

# **Prog. Reload Timer**

The Programmable Reload Timer (PRT) provides two identical, independent 16-bit timers for pulse or waveform generation.

#### **PRT Features:**

- 16-bit down-counter with automatic reload on terminal count
- clocked at clkc/20 rate
- **tout0** (Timer Out 0) signal is always toggled by timer terminal count

- **tout1** (Timer Out 1) signal can be set or cleared by software, and toggled by timer terminal count

#### **PRT Registers**

| Register Name            | Mnemonic | I/O address | R/W | Reset    |
|--------------------------|----------|-------------|-----|----------|
| Timer Data Register 0L   | TMDR0L   | 0x000C      | R/W | 11111111 |
| Timer Data Register 0H   | TMDR0H   | 0x000D      | R/W | 11111111 |
| Timer Reload Register 0L | RLDR0L   | 0x000E      | R/W | 11111111 |
| Timer Reload Register 0H | RLDR0H   | 0x000F      | R/W | 11111111 |
| Timer Control Register   | TCR      | 0x0010      | R/W | 00000000 |
| Timer Data Register 1L   | TMDR1L   | 0x0014      | R/W | 11111111 |
| Timer Data Register 1H   | TMDR1H   | 0x0015      | R/W | 11111111 |
| Timer Reload Register 1L | RLDR1L   | 0x0016      | R/W | 11111111 |
| Timer Reload Register 1H | RLDR1H   | 0x0017      | R/W | 11111111 |

### **PRT Register Descriptions**

|           | Timer Co | ntrol Register                                                                                       | (TCR)                      | (Address = 0x0010)                |  |
|-----------|----------|------------------------------------------------------------------------------------------------------|----------------------------|-----------------------------------|--|
| Bit(s)    | Value    | Description                                                                                          |                            |                                   |  |
| 7         | 0        | This bit is cleared by first r<br>TMDR1L or TMDR 1H.                                                 | reading the TCR, fol       | lowed by a reading either         |  |
| (rd-only) | 1        | Timer 1 has decremented t while this bit is set.                                                     | o 0x0000. If enabled       | l, an interrupt will be requested |  |
| 6         | 0        | This bit is cleared by first r<br>or TMDR 0H.                                                        | eading the TCR, fol        | lowed by reading either TMDR0L    |  |
| (rd-only) | 1        | Timer 0 has decremented to 0x0000. If enabled, an interrupt will be requested while this bit is set. |                            |                                   |  |
| 5         | 0        | Disable Timer 1 interrupt.                                                                           | Disable Timer 1 interrupt. |                                   |  |
|           | 1        | Enable Timer 1 interrupt.                                                                            | Enable Timer 1 interrupt.  |                                   |  |
| 4         | 0        | Disable Timer 0 interrupt.                                                                           |                            |                                   |  |
|           | 1        | Enable Timer 0 interrupt.                                                                            |                            |                                   |  |
| 3:2       | 00       | No effect <b>tout</b> signal.                                                                        |                            |                                   |  |
|           | 01       | tout1 signal toggles on cor                                                                          | responding count re        | aches 0x0000.                     |  |
|           | 10       | tout1 signal is set Low.                                                                             |                            |                                   |  |
|           | 11       | tout1 signal is set High.                                                                            |                            |                                   |  |
| 1         | 0        | Disable Timer 1 counting.                                                                            |                            |                                   |  |
|           | 1        | Enable Timer 1 counting.                                                                             |                            |                                   |  |
| 0         | 0        | Disable Timer 0 counting.                                                                            | Disable Timer 0 counting.  |                                   |  |
|           | 1        | Enable Timer 0 counting.                                                                             |                            |                                   |  |

|        | Timer Data Register Low |                                                                                                                                                                    | (TMDR0L) | (Address = 0x000C) |
|--------|-------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|--------------------|
|        |                         |                                                                                                                                                                    | (TMDR1L) | (Address = 0x0014) |
| Bit(s) | Value                   | Value Description                                                                                                                                                  |          |                    |
| 7:0    | Read                    | Returns the LSB of the current count value. Reading this register latches the MSB for reading in the TMDRH, so the count should always be read LSB-first.          |          |                    |
|        | Write                   | Loads the LSB of the counter. Used to set the initial value for the counter. The counter will automatically reload from the RLDR after reaching a count of 0x0000. |          |                    |

|        | Timer Data Register High |             | (TMDR0H) | (Address = 0x000D)                                           |
|--------|--------------------------|-------------|----------|--------------------------------------------------------------|
|        |                          |             | (TMDR1H) | (Address = 0x0015)                                           |
| Bit(s) | Value                    | Description |          |                                                              |
| 7:0    | Read                     |             |          | ding the TMDRL automatically arantee a valid 16-bit value.   |
|        | Write                    |             |          | itial value for the counter. The R after reaching a count of |

| Т      | Timer Reload Register Low |                                                    | (RLDR0L)    | (Address = 0x000E)               |  |
|--------|---------------------------|----------------------------------------------------|-------------|----------------------------------|--|
|        |                           |                                                    | (RLDR1L)    | (Address = 0x0016)               |  |
| Bit(s) | Value                     |                                                    | Description |                                  |  |
| 7:0    |                           | LSB of the reload value into the counter after the |             | ad value is automatically loaded |  |

| Т      | Timer Reload Register High |                                                      | (RLDR0H)    | (Address = 0x000F)               |  |
|--------|----------------------------|------------------------------------------------------|-------------|----------------------------------|--|
|        |                            |                                                      | (RLDR1H)    | (Address = 0x0017)               |  |
| Bit(s) | Value                      |                                                      | Description |                                  |  |
| 7:0    |                            | MSB of the reload value<br>loaded into the counter a |             | oad value is automatically<br>). |  |

# **Clocked Serial I/O**

The Clocked Serial I/O (CSIO) port provides simple high-speed half-duplex serial communications.

#### **CSIO Features:**

- Half-duplex, 8 bits/character
- Common transmit/receive data register
- External clock input or dedicated divider
- Separate cks\_in (CSIO Clock In) and cks\_out (CSIO Clock Out) signals.

#### **CSIO Registers**

| Register Name                  | Mnemonic | I/O address | R/W | Reset    |
|--------------------------------|----------|-------------|-----|----------|
| CSIO Control/Status Register   | CNTR     | 0x000A      | R/W | 0000x111 |
| CSIO Transmit/Receive Register | TRDR     | 0x000B      | R/W | 00000000 |

## **CSIO Register Descriptions**

| CS        | IO Contro | I/Status Register                                           | (CNTR)                      | (Address = 0x000A)                                                 |
|-----------|-----------|-------------------------------------------------------------|-----------------------------|--------------------------------------------------------------------|
| Bit(s)    | Value     |                                                             | Description                 |                                                                    |
| 7         | 0         | Transmit or receive operate<br>TRDR. This bit is also clear |                             | s cleared by a read or write of the le.                            |
| (rd-only) | 1         | Transmit or receive operat while this bit is set.           | ion complete. If enab       | oled, an interrupt is requested                                    |
| 6         | 0         | Disable CSIO interrupt.                                     |                             |                                                                    |
|           | 1         | Enable CSIO interrupt.                                      |                             |                                                                    |
| 5:4       | 00        | 1                                                           | 1                           | bits are cleared by the CSIO to<br>s complete. These bits are also |
|           | 01        | Start receive operation.                                    |                             |                                                                    |
|           | 10        | Start transmit operation.                                   |                             |                                                                    |
|           | 11        | This bit combination is inv                                 | valid and will be igno      | ored if written.                                                   |
| 3         |           | This bit is reserved and she                                | ould always be writte       | en as zero.                                                        |
| 2:0       | 000       | Internal clock, clkc/20 rate                                | 2.                          |                                                                    |
|           | 001       | Internal clock, clkc/40 rate                                | 2.                          |                                                                    |
|           | 010       | Internal clock, clkc/80 rate                                | 2.                          |                                                                    |
|           | 011       | Internal clock, clkc/160 ra                                 | te.                         |                                                                    |
|           | 100       | Internal clock, clkc/320 ra                                 | te.                         |                                                                    |
|           | 101       | Internal clock, clkc/640 ra                                 | te.                         |                                                                    |
|           | 110       | Internal clock, clkc/1280 r                                 | ate.                        |                                                                    |
|           | 111       | External clock (must be slo                                 | ower than <b>clkc</b> /20). |                                                                    |

| CSIO 1 | Transmit/R | eceive Data Register | (TRDR)              | (Address = 0x000B)                                                                    |
|--------|------------|----------------------|---------------------|---------------------------------------------------------------------------------------|
| Bit(s) | Value      |                      | Description         |                                                                                       |
| 7:0    | Read       |                      | nalled complete. No | buffered, so data is not valid until<br>te that the <b>rxs</b> input is still shifted |
|        | Write      |                      | U U                 | ot buffered, so data written to this<br>in progress will corrupt the                  |

#### Timing

The CSIO port uses a clock that is synchronized to the **clkc** signal, which means the clock signal is not used directly for either transmit or receive data. The falling edge of the CSIO clock (whether external or internal) is used to both send the transmit data and sample the receive data. The figure below shows the timing for the external clock case. Note that the CSIO clock is limited to a maximum rate of **clkc**/13 in this case.



The timing for the internal clock case is shown in the figure below. Note that the CSIO clock is limited to a maximum rate of clkc/11 in this case. Note that the register selection available to the programmer limit the maximum rate to clkc/20.



# **System Functions**

The System Functions block contains three of the four system-level functions present in the original Z80180. The Memory Refresh function is not included, as modern DRAMs usually contain internal refresh circuitry.

#### **SYS Features**

- Relocatable on-chip I/O (starting at address 0x0000, 0x0040, 0x0080 or 0x00C0)
- Free Running Counter counts down at **clkc**/10 rate
- I/O Stop mode

#### **SYS Registers**

| Register Name        | Mnemonic | I/O address | R/W | Reset    |
|----------------------|----------|-------------|-----|----------|
| Free Running Counter | FRC      | 0x0018      | R/W | 11111111 |
| I/O Control Register | ICR      | 0x003F      | R/W | 111xxxxx |

### **SYS Register Descriptions**

|        | Free Running Counter |                                     | (FRC)         | (Address = 0x0018)                      |
|--------|----------------------|-------------------------------------|---------------|-----------------------------------------|
| Bit(s) | Value                |                                     | Descriptio    | n                                       |
| 7:0    |                      | Current value of Free Running rate. | Counter. This | counter decrements at a <b>clkc</b> /10 |

|        | I/O Cont | rol Register                                                                           | (BBR)                 | (Address = 0x0039)                                        |  |  |
|--------|----------|----------------------------------------------------------------------------------------|-----------------------|-----------------------------------------------------------|--|--|
| Bit(s) | Value    |                                                                                        | Description           |                                                           |  |  |
| 7:6    | 00       | Internal I/O address range is                                                          | 0x0000 - 0x003F.      |                                                           |  |  |
|        | 01       | nternal I/O address range is 0x0040 - 0x007F.                                          |                       |                                                           |  |  |
|        | 10       | Internal I/O address range is 0x0080 - 0x00BF.                                         |                       |                                                           |  |  |
|        | 11       | Internal I/O address range is                                                          | 0x00C0 - 0x00FF.      |                                                           |  |  |
| 5      | 0        | Normal I/O operation.                                                                  |                       |                                                           |  |  |
|        | 1        | I/O Stop mode. This mode d<br>ASCI channels, immediately<br>timers in the PRT and FRC. |                       | transmitter and BRG in the , and immediately disables the |  |  |
| 4:0    |          | These bits are reserved and v                                                          | vill always be read a | s ones.                                                   |  |  |

## **Register Addresses**

The table below lists all of the on-chip I/O registers in the Y90-180 along with their mnemonic, I/O address and reset state.

| Register Name                              | Mnemonic | I/O address | R/W | Reset    |
|--------------------------------------------|----------|-------------|-----|----------|
| ASCI Control Register A, Channel 0         | CNTLA0   | 0x0000      | R/W | 0001x000 |
| ASCI Control Register A, Channel 1         | CNTLA1   | 0x0001      | R/W | 0001x000 |
| ASCI Control Register B, Channel 0         | CNTLB0   | 0x0002      | R/W | x0x00111 |
| ASCI Control Register B, Channel 1         | CNTLB1   | 0x0003      | R/W | x0x00111 |
| ASCI Status Register, Channel 0            | STAT0    | 0x0004      | R/W | 00000xx0 |
| ASCI Status Register, Channel 1            | STAT1    | 0x0005      | R/W | 00000xx0 |
| ASCI Transmit Data Register, Channel 0     | TDR0     | 0x0006      | R/W | XXXXXXXX |
| ASCI Transmit Data Register, Channel 1     | TDR1     | 0x0007      | R/W | XXXXXXXX |
| ASCI Receive Data Register, Channel 0      | RDR0     | 0x0008      | R/W | XXXXXXXX |
| ASCI Receive Data Register, Channel 1      | RDR1     | 0x0009      | R/W | XXXXXXXX |
| CSIO Control/Status Register               | CNTR     | 0x000A      | R/W | 0000x111 |
| CSIO Transmit/Receive Register             | TRDR     | 0x000B      | R/W | 00000000 |
| Timer Data Register 0L                     | TMDR0L   | 0x000C      | R/W | 11111111 |
| Timer Data Register 0H                     | TMDR0H   | 0x000D      | R/W | 11111111 |
| Timer Reload Register 0L                   | RLDR0L   | 0x000E      | R/W | 11111111 |
| Timer Reload Register 0H                   | RLDR0H   | 0x000F      | R/W | 11111111 |
| Timer Control Register                     | TCR      | 0x0010      | R/W | 00000000 |
| Reserved                                   |          | 0x0011      |     |          |
| ASCI Extension Control Register, Channel 0 | ECNTL0   | 0x0012      | R/W | 00000000 |
| ASCI Extension Control Register, Channel 1 | ECNTL1   | 0x0013      | R/W | 00000000 |
| Timer Data Register 1L                     | TMDR1L   | 0x0014      | R/W | 11111111 |
| Timer Data Register 1H                     | TMDR1H   | 0x0015      | R/W | 11111111 |
| Timer Reload Register 1L                   | RLDR1L   | 0x0016      | R/W | 11111111 |
| Timer Reload Register 1H                   | RLDR1H   | 0x0017      | R/W | 11111111 |
| Free Running Counter                       | FRC      | 0x0018      | R/W | 11111111 |
| Reserved                                   |          | 0x0019      |     |          |

| ASCI Time Constant Low Register, Channel 0  | TCL0  | 0x001A | R/W | 00000000 |
|---------------------------------------------|-------|--------|-----|----------|
| ASCI Time Constant High Register, Channel 0 | TCH0  | 0x001B | R/W | 00000000 |
| ASCI Time Constant Low Register, Channel 1  | TCL1  | 0x001C | R/W | 00000000 |
| ASCI Time Constant High Register, Channel 1 | TCH1  | 0x001D | R/W | 00000000 |
| Reserved                                    |       | 0x001E |     |          |
| Reserved                                    |       | 0x001F |     |          |
| DMA Source Address Register 0 Low           | SAR0L | 0x0020 | R/W | XXXXXXXX |
| DMA Source Address Register 0 High          | SAR0H | 0x0021 | R/W | XXXXXXXX |
| DMA Source Address Register 0 Page          | SAR0P | 0x0022 | R/W | 00000000 |
| DMA Destination Address Register 0 Low      | DAR0L | 0x0023 | R/W | XXXXXXXX |
| DMA Destination Address Register 0 High     | DAR0H | 0x0024 | R/W | XXXXXXXX |
| DMA Destination Address Register 0 Page     | DAR0P | 0x0025 | R/W | 00000000 |
| DMA Byte Count Register 0 Low               | BCR0L | 0x0026 | R/W | XXXXXXXX |
| DMA Byte Count Register 0 High              | BCR0H | 0x0027 | R/W | XXXXXXXX |
| DMA Memory Address Register 1 Low           | MAR1L | 0x0028 | R/W | XXXXXXXX |
| DMA Memory Address Register 1 High          | MAR1H | 0x0029 | R/W | XXXXXXXX |
| DMA Memory Address Register 1 Page          | MAR1P | 0x002A | R/W | 0000xxxx |
| DMA I/O Address Register 1 Low              | IAR1L | 0x002B | R/W | XXXXXXXX |
| DMA I/O Address Register 1 High             | IAR1H | 0x002C | R/W | XXXXXXXX |
| DMA I/O Address Register 1 Page             | IAR1P | 0x002D | R/W | 00000000 |
| DMA Byte Count Register 1 Low               | BCR1L | 0x002E | R/W | XXXXXXXX |
| DMA Byte Count Register 1 High              | BCR1H | 0x002F | R/W | XXXXXXXX |
| DMA Status Register                         | DSTAT | 0x0030 | R/W | 00110010 |
| DMA Mode Register                           | DMODE | 0x0031 | R/W | 11000001 |
| DMA/Wait Control Register                   | DCNTL | 0x0032 | R/W | 11110000 |
| Interrupt Vector Low Register               | IL    | 0x0033 | R/W | 00000000 |
| Interrupt/Trap Control Register             | ITC   | 0x0034 | R/W | 00111001 |
| Reserved                                    |       | 0x0035 |     |          |
| Reserved (Refresh Control not implemented)  |       | 0x0036 |     |          |
| Reserved                                    |       | 0x0037 |     |          |
| MMU Common Base Register                    | CBR   | 0x0038 | R/W | 00000000 |
| MMU Bank Base Register                      | BBR   | 0x0039 | R/W | 00000000 |
| MMU Common/Bank Area Register               | CBAR  | 0x003A | R/W | 11110000 |
| Reserved                                    |       | 0x003B |     |          |
| Reserved                                    |       | 0x003C |     |          |
| Reserved                                    |       | 0x003D |     |          |
| Reserved                                    |       | 0x003E |     |          |
| I/O Control Register                        | ICR   | 0x003F | R/W | 00000000 |

## **Top Level Verilog Code**

The Verilog code for the y90-180 is shown below to illustrate how the individual modules connect.

\*\*/ /\*\* COPYRIGHT (C) 2013, SYSTEMYDE INTERNATIONAL CORPORATION, ALL RIGHTS RESERVED \*\*/ /\*\* \*\*/ /\*\* z180-style mpu Rev 0.0 04/17/2013 \*\*/ /\*\* \*\*/ module y90\_180 (cka0\_out, cka1\_out, cks\_ext, cks\_out, dma\_ack, halt\_tran, iack\_tran, io\_addr\_out, io\_data\_out, io\_read, io\_strobe, io\_tran, ivec\_rd, mem\_addr\_out, mem\_data\_out, mem\_rd, mem\_tran, mem\_wr, nmiack\_tran, reti\_tran, rts0, rts1, sleep\_tran, t1, tend0, tend1, tout0, tout1, txa0, txa1, txs, cka0\_in, ckal\_in, cks\_in, clearb, clkc, cts0, cts1, dcd0, dcd1, dma\_req, dreq0, dreq1, en\_prftch, int0\_req, int1\_req, int2\_req, io\_data\_in, ivec\_data\_in, mem\_data\_in, nmi\_req, resetb, rxa0, rxa1, rxs, wait\_req); /\* asci 0 clock input input cka0\_in; /\* asci 0 clock input /\* csio clock input ckal\_in; input input cks\_in; /\* master (test) reset clearb; input clkc; cts0; cts1; /\* main cpu clock input /\* cts 0 input \*/ \*/ \*/ \*/ \*/ \*/ input /\* cts 1 input input dcd0; dcd1; /\* dcd 0 input input /\* dcd 1 input input /\* dma request dma\_req; dreq0; dreq1; input /\* dma0 external request input /\* dmal external request input /\* prefetch enable /\* ext interrupt 0 /\* ext interrupt 1 en\_prftch; input int0\_req; input int1\_req; input int1\_req; /\* ext interrupt 1
int2\_req; /\* ext interrupt 2
nmi\_req; /\* nmi request
resetb; /\* internal (user) reset
rxa0; /\* asci 0 data input
rxa1; /\* asci 1 data input
rxs; /\* csio data input input \*/ \*/ input input input input /\* csio data input /\* wait request input rxs; wait\_req; input [7:0] io\_data\_in; /\* i/o input data bus input [7:0] ivec\_data\_in; /\* int vector bus input [7:0] mem\_data\_in; /\* memory input bus input cka0\_out; /\* asci 0 clock output cka1\_out; /\* asci 1 clock output cks\_ext; /\* csio clock external cks\_out; /\* csio clock output dma\_ack; /\* dma acknowledge output output output output output halt\_tran; /\* halt transaction iack\_tran; /\* interrupt acknowledge transaction \*/ \*\*/ \*// // output output /\* i/o read enable output io\_read; /\* i/o data strobe io\_strobe; output io\_tran; /\* i/o data strobe ivec\_rd; /\* i/o transaction ivec\_rd; /\* interrupt vector enable output output /\* memory read enable /\* memory transaction mem\_rd; output mem\_tran; output /\* memory write enable output mem\_wr; nmiack\_tran; /\* nmi acknowledge transaction output output reti\_tran; /\* return from interrupt transaction

| output           | rts0;                               | /*    | rts 0 output                             |            |                                                | */         |
|------------------|-------------------------------------|-------|------------------------------------------|------------|------------------------------------------------|------------|
| output           |                                     |       | rts 1 output                             |            |                                                | */         |
| output           |                                     |       | sleep transaction                        |            |                                                | */         |
| output           |                                     |       | first clock of transaction               | 1          |                                                | */         |
| output           |                                     |       | dma0 end pulse                           |            |                                                | */         |
| output           |                                     |       | dmal end pulse<br>prt 0 timer output     |            |                                                | */<br>*/   |
| output<br>output |                                     |       | prt 0 timer output<br>prt 1 timer output |            |                                                | */         |
| output           |                                     |       | asci 0 data output                       |            |                                                | */         |
| output           |                                     |       | asci 1 data output                       |            |                                                | */         |
| output           |                                     |       | csio data output                         |            |                                                | */         |
|                  |                                     |       | i/o output data bus                      |            |                                                | */         |
|                  |                                     |       | memory output data bus                   |            |                                                | */         |
| output [15:0]    |                                     |       | i/o address bus                          |            |                                                | */         |
|                  |                                     |       | memory address bus                       |            |                                                | */         |
| ,                | * * * * * * * * * * * * * * * * * * | **1   | *****                                    | * * *      | *****                                          | ,          |
| /* /* signal dec | larations                           |       |                                          |            |                                                | */         |
| /*               |                                     | +++   | ****                                     |            | ****                                           | /*<br>+++/ |
| wire             |                                     | ~ ^ 3 |                                          |            | asci 0 interrupt                               | ***/       |
| wire             | asci0_int;<br>asci1_int;            |       |                                          |            | asci 1 interrupt                               | */         |
| wire             | asci0_rxreq;                        |       |                                          |            | asci 1 interrupt<br>asci 0 rx request          | */         |
| wire             | asci0_txreq;                        |       |                                          |            | asci 0 tx request                              | */         |
| wire             | ascil_rxreq;                        |       |                                          |            | asci 1 rx request                              | */         |
| wire             | ascil_txreq;                        |       |                                          |            | asci 1 tx request                              | */         |
| wire             | cka0_out;                           |       |                                          |            | asci 0 clock output                            | */         |
| wire             | ckal_out;                           |       |                                          |            | asci 1 clock output                            | */         |
| wire             | cks_ext;                            |       |                                          |            | csio clock external                            | */         |
| wire             | cks_out;                            |       |                                          |            | csio clock output                              | */         |
| wire             | clk10c;                             |       |                                          |            | clkc/10 clock enable                           | */         |
| wire             | clk10cs;                            |       |                                          |            | clkc/10 symmetric                              | */         |
| wire             | clk20c;                             |       |                                          |            | clkc/20 clock enable                           | */         |
| wire             | clk30c;                             |       | /                                        | *          | clkc/30 clock enable                           | */         |
| wire             | clk30cs;                            |       |                                          |            | clkc/30 symmetric                              | */         |
| wire             | csio_int;                           |       |                                          |            | csio interrupt                                 | */         |
| wire             | dma_ack;                            |       | /                                        | / <b>*</b> | dma acknowledge (sys)                          | */         |
| wire             | dma_ack_s;                          |       |                                          |            | dma acknowledge                                | */         |
| wire             | dma_req;                            |       | /                                        | *          | dma request                                    | */         |
| wire             | dma_req_s;                          |       | /                                        | *          | dma request (sys)                              | */         |
| wire             | dma0_int;                           |       | /                                        | *          | dma 0 interrupt                                | */         |
| wire             | dma1_int;                           |       | /                                        | *          | dma 1 interrupt                                | */         |
| wire             | ftch_tran;                          |       | /                                        | *          | inst fetch transaction                         | */         |
| wire             | frc_imd2;                           |       |                                          |            | force int mode 2                               | */         |
| wire             | halt_tran;                          |       |                                          |            | halt transaction                               | */         |
| wire             | iack_tran;                          |       |                                          |            | int ack transaction                            | */         |
| wire             | inst2_trap;                         |       |                                          |            | illegal 2-byte instruction                     | */         |
| wire             | inst3_trap;                         |       |                                          |            | illegal 3-byte instruction                     | */         |
| wire             | int_req;                            |       |                                          |            | interrupt request                              | */         |
| wire             | io_read;                            |       |                                          |            | i/o read enable                                | */         |
| wire             | io_read_c;                          |       |                                          |            | i/o read enable (cpu)                          | */         |
| wire             | io_read_d;                          |       |                                          |            | i/o read enable (dma)                          | */         |
| wire             | io_stop;                            |       |                                          |            | i/o stop mode                                  | */         |
| wire             | io_strobe;<br>io_strobe_c;          |       |                                          |            | i/o data strobe<br>i/o data strobe (cpu)       | */         |
| wire             | io_strobe_d;                        |       |                                          |            | i/o data strobe (cpu)<br>i/o data strobe (dma) | */         |
| wire             | io_tran;                            |       |                                          |            | i/o transaction                                | */         |
| wire             | io_tran_c;                          |       |                                          |            | i/o transaction (cpu)                          | */         |
| wire             | io_tran_d;                          |       |                                          |            | i/o transaction (dma)                          | */         |
| wire             | ivec_rd;                            |       |                                          |            | interrupt vector enable                        | */         |
| wire             | ld_if1;                             |       |                                          |            | load inst byte 1                               | */         |
| wire             | ld_mem_addr;                        |       |                                          |            | update memory address                          | */         |
| wire             | mem rd;                             |       |                                          |            | memory read enable                             | */         |
| wire             | mem_rd_c;                           |       | /                                        | *          | memory read enable (cpu)                       | */         |
| wire             | mem_rd_d;                           |       |                                          |            | memory read enable (dma)                       | */         |
| wire             | mem_tran;                           |       |                                          |            | memory transaction                             | */         |
| wire             | <pre>mem_tran_c;</pre>              |       | /                                        | *          | memory transaction (cpu)                       | */         |
| wire             | <pre>mem_tran_d;</pre>              |       |                                          |            | memory transaction (dma)                       | */         |
| wire             | mem_wr;                             |       | /                                        | *          | memory write enable                            | */         |
| wire             | mem_wr_c;                           |       | /                                        | *          | memory write enable (cpu)                      | */         |
| wire             | mem_wr_d;                           |       |                                          |            | memory write enable (dma)                      | */         |
| wire             | nmiack_tran;                        |       |                                          |            | nmi ack transaction                            | */         |
| wire             | output_inh;                         |       |                                          |            | disable cpu outputs                            | */         |
| wire             | prt0_int;                           |       |                                          |            | prt ch0 interrupt                              | */         |
| wire             | prt1_int;                           |       |                                          |            | prt chl interrupt                              | */         |
| wire             | rd_peri;                            |       |                                          |            | peripheral read                                | */         |
| wire             | reti_tran;                          |       | /                                        | *          | reti transaction                               | */         |

```
wire
            rts0;
                                                   /* rts 0 output
wire
           rts1;
                                                   /* rts 1 output
                                                                                */
                                                   /* sleep transaction
wire
            sleep_tran;
                                                   /* first clock of transaction
wire
           t1;
                                                   /* first clock of trans (cpu)
wire
            t1 c;
                                                   /* first clock of trans (dma)
wire
            t1_d;
                                                   /* dma 0 end pulse
            tend0;
wire
                                                   /* dma 1 end pulse
wire
            tend1;
                                                   /* prt 0 timer output
            tout0;
wire
wire
            tout1;
                                                   /* prt 1 timer output
                                                   /* asci 0 data output
wire
            txa0;
                                                   /* asci 1 data output
wire
            txa1;
                                                   /* csio data output
wire
            txs;
                                                   /* wait request (sys)
wire
            wait_req_s;
                                                   /* wait state identifier
wire
            wait_st;
                                                   /* peripheral write
wire
            wr peri;
                                                   /* interrupt enable bits
      [2:0] inten_reg;
wire
                                                   /* logical address page
wire
      [3:0] log_addr_page;
                                                   /* asci read data
wire
      [7:0] asci_data;
                                                   /* csio read data
      [7:0] csio data;
wire
                                                   /* dma read data
wire
       [7:0] dma_data;
                                                   /* int read data
wire
       [7:0] int_data;
                                                   /* i/o input data bus (sys)
wire
      [7:0] io_data_in_s;
wire
       [7:0] io_data_out;
                                                   /* i/o output data bus
wire
      [7:0] io_data_out_c;
                                                   /* i/o output data bus (cpu)
       [7:0] io_data_out_d;
                                                   /* i/o output data bus (dma)
wire
                                                   /* int vector bus (sys)
wire
      [7:0] ivec_data_in_s;
       [7:0] mem_data_out;
                                                   /* memory output data bus
wire
wire
       [7:0] mem_data_out_c;
                                                   /* memory output data bus (cpu)
       [7:0] mem_data_out_d;
                                                   /* memory output data bus (dma)
wire
wire
      [7:0] mmu_data;
                                                   /* mmu read data
                                                                                */
wire
       [7:0] prt_data;
                                                   /* prt read data
                                                   /* processor logical address
wire
      [15:0] addr_reg_in;
                                                   /* i/o address bus
wire
      [15:0] io_addr_out;
                                                   /* i/o address bus (cpu)
wire
      [15:0] io_addr_out_c;
                                                   /* i/o address bus (dma)
wire
      [15:0] io_addr_out_d;
                                                   /* memory address bus
wire
      [19:0] mem_addr_out;
                                                   /* memory address bus (cpu)
      [19:0] mem_addr_out_c;
wire
     [19:0] mem_addr_out_d;
                                                   /* memory address bus (dma)
wire
                                        *****
/*
/* processor
/*
y90_core CPU
             ( .addr_reg_in(addr_reg_in), .burst_done(), .ctr_reg(),
                  .dma_ack(dma_ack_s), .fault_detect(), .ftch_tran(ftch_tran),
                  .halt_tran(halt_tran), .iack_tran(iack_tran), .imd2_reg(),
                  .inst2_trap(inst2_trap), .inst3_trap(inst3_trap),
                  .io_addr_out(io_addr_out_c), .io_data_out(io_data_out_c),
                  .io_read(io_read_c), .io_strobe(io_strobe_c), .io_tran(io_tran_c),
                  .ivec_rd(ivec_rd), .ld_if1(ld_if1), .ld_init(),
                  .ld_mem_addr(ld_mem_addr),
                  .mem_addr_out({log_addr_page, mem_addr_out_c[11:0]}),
                  .mem_data_out(mem_data_out_c), .mem_rd(mem_rd_c),
                  .mem_tran(mem_tran_c),
                  .mem_wr(mem_wr_c), .mmu_msb(), .mmu_swap(),
                  .mwr_tran(), .nmiack_tran(nmiack_tran), .output_inh(output_inh),
                  .reti_tran(reti_tran), .sleep_tran(sleep_tran), .stk_tran(), .tl(tl_c),
                  .wait_st(wait_st), .wdt_arm(), .wdt_hit(), .wr_brst(), .clearb(clearb),
                  .clkc(clkc), .dma_req(dma_req_s), .en_prftch(en_prftch),
                  .frc_imd2(frc_imd2), .int_req(int_req), .io_data_in(io_data_in_s),
                  .ivec_data_in(ivec_data_in_s), .mem_data_in(mem_data_in),
                  .nmi_req(nmi_req), .resetb(resetb), .wait_req(wait_req_s) );
     *****
/* memory management unit
                                                                                * /
( .mmu_addr_out(mem_addr_out_c[19:12]), .mmu_data(mmu_data),
mmu seq MMU
                 .addr_reg_in(addr_reg_in[15:12]), .clkc(clkc),
                  .io_addr_out(io_addr_out[5:0]), .io_data_out(io_data_out),
                 .ld_mem_addr(ld_mem_addr), .output_inh(output_inh),
                  .resetb(resetb), .wr_peri(wr_peri) );
        /*
```

```
/* system management
                                                                                * /
sys_180 SYS
               (.clk10c(clk10c), .clk10cs(clk10cs), .clk20c(clk20c), .clk30c(clk30c),
                  .clk30cs(clk30cs), .inten_reg(inten_reg), .io_stop(io_stop),
                  .rd_peri(rd_peri), .io_data_in_s(io_data_in_s),
                  .wait_req_s(wait_req_s), .wr_peri(wr_peri), .asci_data(asci_data),
                  .clkc(clkc), .csio_data(csio_data), .dma_data(dma_data),
                  .iack_tran(iack_tran), .inst2_trap(inst2_trap),
.inst3_trap(inst3_trap), .int_data(int_data),
                  .io_addr_out(io_addr_out), .io_data_in(io_data_in),
                  .io_data_out(io_data_out), .io_read(io_read), .io_strobe(io_strobe),
                  .io_tran(io_tran), .mem_tran(mem_tran), .mmu_data(mmu_data),
                  .prt_data(prt_data), .resetb(resetb), .t1(t1), .wait_req(wait_req) );
                        *****
.
/*
/* dma
                                                                                 * /
/*
                     *****
/**
               ( .bus_ack(dma_ack), .dma_data(dma_data), .dma_req(dma_req_s),
dma_180 DMA
                  .dma0_int(dma0_int), .dma1_int(dma1_int),
                  .io_addr_out_d(io_addr_out_d), .io_data_out_d(io_data_out_d),
                  .io_read(io_read_d), .io_strobe(io_strobe_d), .io_tran(io_tran_d),
                  .mem_addr_out_d(mem_addr_out_d), .mem_data_out_d(mem_data_out_d),
                  .mem_rd(mem_rd_d), .mem_tran(mem_tran_d), .mem_wr(mem_wr_d), .tl(t1_d),
                  .tend0(tend0), .tend1(tend1), .asci0_rxreq(asci0_rxreq),
                  .asci0_txreq(asci0_txreq), .asci1_rxreq(asci1_rxreq),
                  .ascil_txreq(ascil_txreq), .bus_req(dma_req), .clearb(clearb),
                  .clkc(clkc), .dma_ack(dma_ack_s), .dreq0(dreq0), .dreq1(dreq1),
                  .io_addr_out(io_addr_out[5:0]), .io_data_in(io_data_in_s),
                  .io_data_out(io_data_out), .mem_data_in(mem_data_in),
                  .nmi_req(nmi_req), .resetb(resetb), .sleep_tran(sleep_tran),
                  .wait_req(wait_req_s), .wr_peri(wr_peri) );
assign io_addr_out = io_addr_out_c
                                   io_addr_out_d;
assign io_data_out = io_data_out_c
                                   io_data_out_d;
                                 assign io read
                 = io read c
                                   io read d;
assign io strobe
                 = io strobe c
                                   io strobe d;
                 = io_tran_c
                                   io tran d;
assign io tran
                                   mem_addr_out d;
assign mem_addr_out = mem_addr_out_c
assign mem_data_out = mem_data_out_c |
                                   mem data out d;
assign mem_rd
               = mem_rd_c
                                   mem rd d;
                                   mem_tran_d;
assign mem tran
                 = mem_tran_c
assign mem_wr
                 = mem_wr_c
                                   mem_wr_d;
assign tl
                 = t1_c
                                 | t1_d;
  /*
                                                                                */
/* interrupt control
                                                                                */
/*
( .frc_imd2(frc_imd2), .int_data(int_data), .int_req(int_req),
int_180 INT
                  .ivec_data_out(ivec_data_in_s), .asci0_int(asci0_int),
                  .ascil_int(ascil_int), .clkc(clkc), .csio_int(csio_int),
                  .dma0_int(dma0_int), .dma1_int(dma1_int), .ftch_tran(ftch_tran),
                  .iack_tran(iack_tran), .inst2_trap(inst2_trap),
                  .inst3_trap(inst3_trap), .int0_req(int0_req), .int1_req(int1_req),
                  .int2_req(int2_req), .inten_reg(inten_reg),
                  .io_addr_out(io_addr_out[5:0]), .io_data_out(io_data_out),
                  .ivec_data_in(ivec_data_in), .ivec_rd(ivec_rd),
                  .prt0_int(prt0_int), .prt1_int(prt1_int), .resetb(resetb),
                  .reti_tran(reti_tran), .wait_st(wait_st), .wr_peri(wr_peri) );
          *****
/*
  async serial comm interface
         /***
asci 180 ASCI
               ( .asci_data(asci_data), .asci0_int(asci0_int),
                  .asci0_rxreq(asci0_rxreq), .asci0_txreq(asci0_txreq),
                  .ascil_int(ascil_int), .ascil_rxreq(ascil_rxreq),
                  .ascil_txreq(ascil_txreq), .cka0_out(cka0_out), .cka1_out(cka1_out),
                  .rts0(rts0), .rts1(rts1), .txa0(txa0), .txa1(txa1),
                  .cka0_in(cka0_in), .cka1_in(cka1_in), .clk10c(clk10c),
                  .clk10cs(clk10cs), .clk30c(clk30c), .clk30cs(clk30cs), .clkc(clkc),
                  .cts0(cts0), .cts1(cts1), .dcd0(dcd0), .dcd1(dcd1),
                  .io_addr_out(io_addr_out[5:0]), .io_data_out(io_data_out),
```

172

.io\_stop(io\_stop), .rd\_peri(rd\_peri), .resetb(resetb), .rxa0(rxa0), .rxal(rxal), .wr\_peri(wr\_peri) ); /\* \*/ /\* programmable reload timer \*/ /\* \*/ ( .prt\_data(prt\_data), .prt0\_int(prt0\_int), .prt1\_int(prt1\_int), .tout0(tout0), .tout1(tout1), .clk20c(clk20c), .clkc(clkc), .io\_addr\_out(io\_addr\_out[5:0]), .io\_data\_out(io\_data\_out), prt\_180 PRT .rd\_peri(rd\_peri), .resetb(resetb), .wr\_peri(wr\_peri) ); /\* \*/ /\* clocked serial i/o \*/ , \* \*/ \*\*/ csio\_180 CSIO ( .cks\_ext(cks\_ext), .cks\_out(cks\_out), .csio\_data(csio\_data), .csio\_int(csio\_int), .txs(txs), .cks\_in(cks\_in), .clk10c(clk10c), .clkc(clkc), .io\_addr\_out(io\_addr\_out[5:0]), .io\_data\_out(io\_data\_out), .io\_stop(io\_stop), .rd\_peri(rd\_peri), .resetb(resetb), .rxs(rxs), .wr\_peri(wr\_peri) );

endmodule