## **OPERATION MANUAL**

USER'S GUIDE SOFTWARE SPECIFICATION GUIDE

# IN-CIRCUIT DEBUGGER



## Preliminary

## **ICD 278**

FOR

## **Z80**

## OPERATION MANUAL

Copyright© 1984, ZAX Corporation. All Rights Reserved under International and Pan-American Copyright Conventions. No part of this publication may be reproduced in any manner whatsoever without written permission from ZAX Corporation.

Prepared by

ZAX Corporation 2572 White Road, Irvine, California 92714

Operation Manual: Part No. 20-100-06, Rev.B includes;

User's Guide (278/Z80) : Part No. 20-100-XX Software Specification Guide (278/Z80): Part No. 20-100-XX Command Reference Guide : Part No. 20-100-03

Printed: June 1984

### LIST OF EFFECTIVE PAGES

THE TOTAL NUMBER OF PAGES IN THIS PUBLICATION IS 151, CONSISTING OF:

PAGE NO.

ISSUE DATE/REVISION LEVEL

| TITLE JUNE              | 1984/REV.B |
|-------------------------|------------|
| B JUNE                  | 1984/REV.B |
| I THROUGH VII JUNE      | 1984/REV.B |
| I THROUGH VII JUNE      | 1984/REV.B |
| I-1 THROUGH 1-6 JUNE    | 1984/REV.B |
| 2-1 THROUGH 2-8 JUNE    | 1984/REV.B |
| 3-1 THROUGH 3-40 JUNE   | 1984/REV.B |
| 4-1 THROUGH 4-2 JUNE    | 1984/REV.B |
| 4A-1 THROUGH 4A-4 JUNE  | 1984/REV.B |
| 4B-1 THROUGH 4B-2 JUNE  | 1984/REV.B |
| 4B-1 THROUGH 4B-2 JUNE  | 1984/REV.B |
| 4D-1 THROUGH 4D-4 JUNE  | 1984/REV.B |
| 4E-1 THROUGH 4E-12 JUNE | 1984/REV.B |
| 4F-1 THROUGH 4F-4 JUNE  | 1984/REV.B |
| 4G-1 THROUGH 4F-4 JUNE  | 1984/REV.B |
| 11 JUNE                 | 1984/REV.B |
| 5-1 THROUGH 5-12 JUNE   | 1984/REV.B |
| 6-1 THROUGH 6-20 JUNE   | 1984/REV.B |
|                         |            |

NOTE: THE PAGES AFFECTED BY CHANGES ARE NOTED BY \* AND INDICATED BY ISSUE DATES AND REVISION LETTERS PRINTED NEXT TO THE PAGE NUMBER. THE ORIGINAL ISSUE OF THIS PUBLICATION IS REVISION B, JUNE 1984.

## TABLE OF CONTENTS

PART I - USER'S GUIDE

.

Section

Page

| I   | INTRODUCTION and DESCRIPTION<br>Introduction<br>Description<br>ICD Major Components<br>Specifications (General)<br>Specifications (Emulation)                                                                                                                                                      | 1 – 1<br>1 – 2<br>1 – 3                                     |
|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------|
| II  | CONTROLS and COMPONENTS<br>Introduction<br>ICD Control and Component<br>Description<br>Top View<br>Side View<br>End View (A)<br>Baud Rate Switch Settings<br>End View (B)<br>External Break Connector<br>Event Trigger Connector<br>CPU Plug Probe<br>External Break Cable<br>External Break Cable | 2-1<br>2-1<br>2-2<br>2-3<br>2-4<br>2-5<br>2-5<br>2-6<br>2-7 |
| III | SYSTEM CONFIGURATION/START-UP<br>SEQUENCE and COMMAND GUIDE<br>Introduction<br>System Configuration<br>Start-up Sequence<br>Command Guide                                                                                                                                                          | 3-2<br>3-3                                                  |
| IV  | TECHNICAL REFERENCES<br>Introduction<br>A - Emulation Select Switch<br>B - Data Bus Emulation Connector                                                                                                                                                                                            | 4A-1                                                        |
|     | C - Serial Interface<br>S-791 SIO Module Description<br>Transmission Format Switch                                                                                                                                                                                                                 |                                                             |
|     | Serial Interface<br>Specifications<br>RS-232C Interface (Terminal)<br>RS-232C Interface (Host/Aux)<br>Current Loop Interface<br>TTL Interface (Terminal)<br>TTL Interface (Host/Aux)<br>Control Signal Timing                                                                                      | 4C-3<br>4C-4<br>4C-5<br>4C-7<br>4C-9<br>4C-10<br>4C-12      |

i

Page

Section

IV (cont.)

| D | - | ICD Program Memory<br>User Memory<br>Memory Mapping                                                                                                                                                                                            | 4D-1<br>4D-2<br>4D-3                                                    |
|---|---|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------|
| E | - | CPU Emulation<br>ICD Program Memory Cycle<br>Z80 Machine Cycles<br>Clock Switch<br>Monitor Switch (Interrupt)<br>Bus Control<br>REFRESH Signal<br>Signal Timing                                                                                | 4E - 1 4E - 2 4E - 3 4E - 5 4E - 7 4E - 7 4E - 8 4E - 9 4E - 10 4E - 11 |
| F | - | Probes<br>Event Trigger Probe<br>Emulation Qualify<br>Output Probe<br>Map Control Probe                                                                                                                                                        | 4F-1<br>4F-2<br>4F-3                                                    |
| G | - | Control Modules<br>Introduction and Description<br>S-730 Indicator Panel<br>S-791 Serial Interface Output<br>S-795 Realtime Trace Storage<br>S-793 Central Processing Unit<br>S-792 Emulation Memory Unit<br>ICD Disassembly/Module<br>Removal | 4G-1<br>4G-2<br>4G-3<br>4G-4<br>4G-5<br>4G-6<br>4G-7                    |

### PART II - SOFTWARE SPECIFICATION GUIDE

Section

Page

| -  | INTRODUCTION and DESCRIPTION<br>Introduction<br>Description                                                                                                        |                                           |
|----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------|
| V  | SOFTWARE COMMANDS<br>Introduction<br>ZICE Keywords<br>ZICE Format<br>Load Command<br>Save Command<br>Verify Command<br>Quit Command<br>Z Subcommands               | 5-2<br>5-3<br>5-5<br>5-6<br>5-7           |
|    | Z Log Subcommand<br>Z Batch Subcommand<br>Z Comment<br>Z Wait Subcommand<br>Directory Subcommand<br>Z Help Subcommand<br>Z Repeat Subcommand<br>Z Print Subcommand | 5-8<br>5-9<br>5-9<br>5-10<br>5-10<br>5-11 |
| VI | HOST COMPUTER SYSTEM COMMUNICATION<br>Introduction<br>Communication Terminology<br>System Configuration<br>Idle                                                    | 6-2<br>6-3                                |
|    | Idle Program<br>Idle Program Flowchart                                                                                                                             | 6-4<br>6-5                                |
|    | Display Text<br>Display Text Sequence<br>Display Text Sequence Diagram<br>Display Text Program<br>Display Text Flowchart<br>Command Input Request Program          | 6-6<br>6-7                                |
|    | Command Input Request Sequence<br>Command Input Request                                                                                                            | 6-8                                       |
|    | Sequence Diagram<br>Command Request Program<br>Command Request Flowchart<br>Object File Load/Verify                                                                |                                           |
|    | Object File Load/Verify<br>Sequence                                                                                                                                | 6-10                                      |
|    | Object File Load/Verify<br>Sequence Cont<br>Object File Load/Verify                                                                                                | 6-11                                      |
|    | Sequence Diagram                                                                                                                                                   | 6-11                                      |

Section

VI (cont.)

| Object File Save<br>Object File Save Sequence<br>Object File Save Sequence<br>Diagram                     |                              |
|-----------------------------------------------------------------------------------------------------------|------------------------------|
| Z Command<br>Z Command Sequence<br>Z Command Sequence Diagram<br>Z Command Program<br>Z Command Flowchart | 6-14<br>6-14<br>6-15<br>6-15 |
| Quit                                                                                                      |                              |
| Quit Sequence<br>Quit Sequence Diagram<br>Quit Program<br>Quit Flowchart<br>Display Symbolic Text         | 6-17<br>6-17<br>6-17<br>6-17 |
| Display Symbolic Text Sequence<br>Display Symbolic Text                                                   | 6-18                         |
| Sequence Diagram                                                                                          | 6-18                         |
| Display Symbolic Text Program                                                                             |                              |
| Display Symbolic Text Flowchart<br>Console Key Check                                                      | 6-19                         |
| Console Key Check Sequence<br>Console Key Check                                                           | 6-20                         |
| Sequence Diagram                                                                                          | 6-20                         |

Page

## LIST OF ILLUSTRATIONS

| Figure                                                      | Title                                                                                                                                                                                                       | Page.                                                 |
|-------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------|
| 2 - 1<br>2 - 2<br>2 - 3<br>2 - 4<br>2 - 5<br>2 - 6          | ICD Controls and Components<br>ICD Controls and Components, cont<br>ICD Controls and Components, cont<br>CPU Plug Probe<br>External Break Cable Diagram<br>Event Trigger Cable Diagram                      | 2-2<br>2-4<br>2-6                                     |
| 4-A.1<br>4-A.2<br>4-A.3<br>4-A.4<br>4-A.5<br>4-B.1          | Emulation Select Switch<br>E. S. Switch Factory Settings<br>Emulation Data Bus Block Diagram<br>Emulator READ Signal Block Diagram<br>Wait States<br>DB. EMUL (Data Bus Emulation)                          | 4A - 1<br>4A - 1<br>4A - 2<br>4A - 3<br>4A - 4        |
| 4-B.2<br>4-C.1<br>4-C.2<br>4-C.3<br>4-C.4                   | Connector<br>DB. EMUL Connector Configuration<br>S-791 SIO Module<br>Transmission Format Switch<br>RS-232C Standard Jumper Settings<br>CLI Standard Jumper Settings                                         | 4B-1<br>4B-2<br>4C-1<br>4C-2<br>4C-6<br>4C-8          |
| 4-C.5<br>4-C.6<br>4-C.7<br>4-C.8                            | TTL Standard Jumper Settings<br>BUSY and DTR Input Signal Diagram<br>BUSYOUT and DSR Output Signal<br>Diagram<br>RSTP Output Signal Diagram                                                                 | 4C-11<br>4C-12<br>4C-13<br>4C-13                      |
| 4-C.9<br>4-C-10                                             | S-771 SIO Interface Circuit<br>Diagram (Terminal)<br>Diagram (Host/Aux)                                                                                                                                     | 4C-14                                                 |
| 4-D.1<br>4-D.2<br>4-D.3                                     | ICD Program Memory Diagram<br>User Memory Timing Diagram<br>Mapping Configuration                                                                                                                           | 4D-1<br>4D-2<br>4D-3                                  |
| 4-E.1<br>4-E.2<br>4-E.3<br>4-E.4<br>4-E.5<br>4-E.6<br>4-E.7 | Emulator/Target System Interface<br>Clock Configuration<br>Setting of Internal Clock<br>Reset Configuration<br>Interrupt Signal Configuration<br>BUSRQ Signal Configuration<br>REFRESH Signal Configuration | 4E-1<br>4E-5<br>4E-6<br>4E-7<br>4E-8<br>4E-9<br>4E-10 |
| 4-F.1<br>4-F.2<br>4-F.3                                     | Event Trigger Output Timing Diagram<br>Emulation Qualify Output Timing<br>Diagram<br>Map Control Timing Configuration                                                                                       | 4F-1<br>4F-2<br>4F-3                                  |
|                                                             |                                                                                                                                                                                                             |                                                       |

Figure

### Title

| <ul> <li>6-5 Command Input Request<br/>Sequence Diagram</li></ul>      |
|------------------------------------------------------------------------|
| 6-6 Command Input Request Flowchart 6-9<br>6-7 Object File Load/Verify |
| 6-7 Object File Load/Verity                                            |
|                                                                        |
| Sequence Diagram                                                       |
| 6-9 Object File Save Sequence Diagram 6-13                             |
| 6-11 Z Command Sequence Diagram                                        |
| 6-12 Z Command Flowchart                                               |
| 6-13 Quit Sequence Diagram 6-17                                        |
| 6-14 Quit Flowchart                                                    |
| 6-15 Display Symbolic Text                                             |
| Sequence Diagram                                                       |
| 6-16 Display Symbolic Text Flowchart 6-19                              |
| 6-17 Console Key Check Sequence Diagram 6-20                           |

## LIST OF TABLES

| Table             | Title                                                                 | Page                                  |
|-------------------|-----------------------------------------------------------------------|---------------------------------------|
| 2-1<br>2-2<br>2-3 | ICD Baud Rates<br>External Break Connector<br>Event Trigger Connector | 2-5                                   |
| 3-1<br>3-2        | System Configuration<br>Start-Up Sequence                             |                                       |
| 4-C.1             | RS232C Interface Pin Designation<br>(Terminal)                        | 4C-4                                  |
| 4-C.2             | RS232C Interface Pin Designation<br>(Host/Aux)                        |                                       |
| 4-C.3             | Current Loop Interface Pin<br>Designation (Term/Host/Aux)             | · · · · · · · · · · · · · · · · · · · |
| 4-C.4             | TTL Interface Pin Designation<br>(Terminal)                           |                                       |
| 4-C.5             | TTL Interface Pin Designation<br>(Host/Aux)                           |                                       |
| 4-C.1             | Emulator Bus Connector -<br>Pin Assignment                            |                                       |
| 4-E.1             | ICD-278 Signal Timing Diagram                                         |                                       |

## SECTION I

#### INTRODUCTION and DESCRIPTION

#### INTRODUCTION

This Operation Manual contains information concerning the ZAX ICD-278 for Z80 IN-CIRCUIT EMULATOR. Revision and update information is contained in supplements issued periodically to Operation Manual recipients.

Part I of this manual acts as a USER'S GUIDE and describes the ICD-278, including controls, system configuration, and start-up sequence. A system command guide with general examples is included in Part I. This guide illustrates and explains the basic command syntax parameters and functions of the ICD commands. A complete listing of Technical References may also be found in Part I. ICD communication with a Host Computer system is contained in Part II; SOFTWARE SPECIFICATION GUIDE, and describes the proper connection, communication protocol and program construction.

Always refer to the specific information you are concerned with, as general knowledge of certain operations and procedures may not prove fully satisfactory in obtaining the desired results; moreover, the design engineer is highly encouraged to become familiar with the entire contents of this manual in order to thoroughly realize the ICD-278's capabilities.

#### DESCRIPTION

The ZAX ICD-278 IN-CIRCUIT EMULATOR functions as a standalone device for developing and maintaining hardware and software of Z80B microprocessors. The ICD-278 comes standard with 64K Bytes of static memory for mapping, displays in HEX/ASCII or disassembled Intel code with a 2K by 40 real time trace buffer and 29 major software commands.

For field applications, the ICD-278 can be connected to any communications device that has either RS232C or 20 mA current loop input.



## ICD Major Components

#### SPECIFICATIONS (General)

Dimensions

Probe Length

Weight

Power Requirements

Operating Temperature Storage Temperature Humidity

Processors

Memory Size

Memory Mapping

Real Time Trace Buffer

System Commands

Usable I/O Ports

Breakpoints

Communication Ports

Baud Rates

Operating Temperature Storage Temperature Humidity :300mm (11.8in) wide :210mm (8.2in) deep : 80mm (3.2in) high

:510mm (20in) long

:3.3kg (7.31b)

:115VAC/230VAC;50/60Hz

:0°C to 45°C :-10°C to 55°C :30% to 85%, relative (non-condensing)

:Z80 (to 6MHz) :i8085 (6MHz)

:64K-Bytes static RAM

:Full 64K byte

:2K x 32 bits

:29

:256

- :3(hardware), 8(software)
  1(external probe)
- :2 RS232C/20ma current loop/TT1
- :14 usable to 19,200bps (factory set at 9,600bps)

:0°C to 45°C :-10°C to 55°C :30% to 85%

#### SPECIFICATIONS (Emulation)

#### Applied CPU

| z80  | : | 500K, | 2 | • 5 | MHz |
|------|---|-------|---|-----|-----|
| Z80A | : | 500K, | 4 | MB  | Ηz  |
| Z80B | : | 500K, | 6 | MB  | Ηz  |

Memory Area

- Program memory :The entire area of the program memory (64K-bytes) is open. This memory is composed of high-speed static RAM.
- User memory :The entire area of 64K-byte memory space is open to the target system.

Mapping :Both the program and user memory can be mapped in 1K-byte units. Four types of mapping modes are available;

:All 256 ports are open.

User Memory Emulation Read/Write Memory Emulation Read Only Memory Non Memory

I/O Port

Breakpoints

:3 Hardware, 8 Software and External trigger break.

Hardware Break : specification :

A,B,C Breaks

 :A,B,C and Event trigger
 :Specify enable/disable of A,B,C and Event breakpoints.
 :Address 16 bits, BHE. Each bit may be

specified 0,1 or "don't care."

| Status: | OP code fetch<br>Memory access<br>Memory read<br>Memory write<br>I/O access<br>I/O read<br>I/O write<br>Execution of instruction |
|---------|----------------------------------------------------------------------------------------------------------------------------------|
| Arm:    | Break occurs only at the                                                                                                         |

m: Break occurs only at the breakpoint after an event trigger is generated.

Event Trigger :Address 16 bits, BHE. Each bit may be break specified 0,1 or "don't care." Status: OP code fetch Memory access Memory write Memory read I/O access I/O read I/O write Instruction execution Data: 8 bits. Each bit may be specified 0,1 or "don't care." External Trigger break :Breakpoint; 1 channel - TTL level Functional specification; HIGH edge or LOW edge. Software Break :8 points; 0 - 7 User breakpoint :Any point may be specified by using the LDA, A instruction. Specification :Specify enable/disable of all software points. Function :A break is caused in the target system when the CPU reads 7FH as an OP code (which represents a LDA, A instruction). Its execution does not effect the registers or flags. Software breaks are suppressed when disabled. Realtime trace :The addresses, data and status during emulation may be stored in storage memory in realtime. Trace capacity :2K x 32 bits Fixed trace data :A0-15, D0-7, MREQ; IORQ, RD; WR, MI Trigger function :End monitor Begin monitor End event Begin event Center event Multiple event Realtime counter : Count bit width; 32 bit Count time; 716 sec, 6 MHz .





## **SECTION II**

#### **CONTROLS and COMPONENTS**

#### INTRODUCTION

This section introduces the various controls, components and functions of the ICD-278. The system controls are represented by four different views of the unit. The user may also wish to examine the photographs of the ICD-278 found at the beginning of Section I.



2 CLOCK select switch. This switch is used to select between the external target (EXT) and the internal clock (INT).

3 RESET switch. This momentary switch is used to reset the ICD-278 monitor. It is activated when the MONITOR lamp is on.

4 MONITOR break switch. This momentary switch is used to return control to the ICD monitor during emulation.

5 HALT lamp. This LED comes on when the ICD CPU has stopped after executing a HALT instruction or when BUSY ACKNOWLEDGE (BUSAK) is in progress.

6 MONITOR lamp. This LED comes on to indicate that control is currently in the ICD monitor. It is off during emulation.

7 ICE (In-circuit Enable) lamp. This LED comes on when the ICD is operating in the incircuit mode (I1 or I2) with the target system.

8 POWER lamp. This LED comes on when the ICD is on.

9 POWER select switch. This switch is used to select the proper power requirements for the ICD. Set the switch to 110/117V to run on a power supply of 110-120VAC or select 200/240V to run on a power supply of 200-240VAC. Set this switch BEFORE connecting the power plug.

10 Power connector. This connector is for the AC power plug.



Figure 2-1. ICD Controls and Components

10 TERMINAL port connector. This connector attaches a console to the ICD-278. In a standalone configuration (LOCAL), it is used to input or output ICD operator commands. In REMOTE mode it is used for an auxiliary I/O.

HOST/AUX (Host/Auxiliary) port connector. This connector is used to connect a Host Computer system or auxiliary I/O to the ICD-278. In a standalone configuration (LOCAL), objects, registers or memory dumps interface to a host computer, printer, teletypewriter, etc., thru this port. In REMOTE mode it can be used to input or output ICD operator commands under control of the host computer.

12 LOCAL/REM (Local/Remote) select switch. This switch is used to select the ports through which the ICD operator commands are entered.

13 DCE/DTE select switch. This switch is used to set the HOST/AUX port to RS232C data terminal equipment(DTE) or data circuit-terminating equipment(DCE). Factory setting is DTE.





14 BAUDRATE set switch. This switch is used to set the baud rates for the TERMINAL and the HOST/AUX port (Table 2-1). To set the baud rate, turn dial using flat-head screwdriver or equivalent.

NOTE: There are 14 usable baud rates available. Baud rate switch numbers E and F are not recommended.

Factory setting = 1(9600bps) for TERMINAL and HOST/AUX ports.

| TERMINAL                    | HOST/AUX       |  |
|-----------------------------|----------------|--|
|                             |                |  |
| BAUD RATE SET<br>SWITCH NO. | BAUD RATE(BPS) |  |
| 0                           | 19, 200        |  |
| 1                           | 9, 600         |  |
| 2                           | 4, 800         |  |
| 3                           | 2, 400         |  |
| 4                           | 1, 200         |  |
| 5                           | 600            |  |
| 6                           | 300            |  |
| . 7                         | 150            |  |
| 8                           | 75             |  |
| 9                           | 110            |  |
| Α                           | 134. 5         |  |
| В                           | 200            |  |
| С                           | 1, 800         |  |
| D                           | 2, 000         |  |
| E                           |                |  |
| F                           |                |  |
|                             |                |  |



15 CPA In-circuit probe plug connector.

16 CPB In-circuit probe plug connector.

NOTE: It is not necessary to connect the in-circuit when running the ICD in the IO mode (in-circuit mode 0) only.

CAUTION: DO NOT REVERSE PLUG PROBE CONNECTIONS. CPA/CPB MISMATCH WILL CAUSE DAMAGE TO THE ICD-278.

17 DB. EMUL (Data Bus Emulator) connector. This connects directly to the data bus of a target system (in-circuit) when decoding the 'RET I' instruction (See Technical References).

BEXT. BRK. (External Break) connector. This is used to connect an external break cable to the ICD (Table 2-2).

(Event Trigger) connector. This is used to 19 EVENT TRG. connect an event trigger cable to the ICD (Table 2-3).

**20**E.M.SEL (Emulation Select) switch. This switch is used to set the machine cycle operation of the target system (See Technical References).







Table 2-2. External Break Connector Diagram



Table 2-3. Event Trigger Connector Diagram

CSA/CSB In-circuit Probe Socket Connector (Figure 2-4) Connects CPA to CSA and CPB to CSB.



21 CSA In-circuit Socket A.

22 CSB In-circuit Socket B.

23 Pin #1 Plugs into CPU socket. Note proper polarity.

24 Polarity mark.

25 Pin #1.





External Break Cable (Figure 2-5). Connects to the EXT. BRK. socket of the unit.

26 External Break Probe (red).

27 Map Control Probe (yellow).

28 Ground clip (black).



#### Figure 2-5. External Break Cable

Event Trigger Cable (Figure 2-6). Connects to the Event TRG. socket of the unit.

29 Event Trigger Probe (green).

**30** Emulation Qualifier Probe (white).

**31** Ground clip (black).







## SECTION III

#### SYSTEM CONFIGURATION / START-UP / COMMAND GUIDE

This section introduces the user to the various ICD system configurations, including communication with host computer systems. Refer to this section when interfacing the ICD-278 to other devices. This sections also shows the correct startup procedure for the ICD-278.

Additionally, a complete listing of emulator commands and examples are included in this section. Before using the emulator, first construct the the proper system configuration for the ICD-278 and then execute the start-up sequence.

The ICD-278 may be set up to run in one of three different system configurations:

1) LOCAL Basis (standalone configuration)

In this mode the ICD-278 is connected to a console terminal thru which commands may be entered. The Host/ Aux port may be used to connect a printer, teletypewriter. Etc. Hardcopy operations may then be produced by issuing a "Print" command.

2) LOCAL Basis (standalone with host computer)

In this mode the ICD-278 performs object file input/ output with a host computer. ICD operator commands may be entered from the console terminal. The "User" command enables direct communication between the ICD console terminal and the host computer.

3) REMOTE Basis

In this mode input/output from the host computer is performed by the utility software program; ZICE. The ICD-278 may be furnished with the ZICE command for batch processing and other applications (see Part II, Software Specification Guide).

The three system configurations are illustrated by symbolic notation (Table 3-1). The start-up sequence is then performed (Table 3-2) after constructing the proper system configuration. The ICD-278 is initialized when its mainframe is first powered up or when the RESET switch is pressed after powering up.



Table 3-1. System Configuration

System Configuration Description

Use Table 3-1 to establish the correct system configuration for the LOCAL or REMOTE modes. Before constructing the system make sure that the power to each component is OFF.

First set the LOCAL/REM and DCE/DTE switches to the positions specified in the configuration diagram.

The ICD-278 uses three cables to connect it to various communication devices and the target system. The two blue-colored ribbon cables are used to connect the ICD to; 1) a console terminal through the TERMINAL port connector, and 2) an auxiliary printer or a host computer (Figure 2-2). Connect these cables to the device selected and then to the ICD HOST/AUX or TERMINAL port male sockets.

The CPU Plug Probe cable (Figure 2-4) connects the ICD to the target processor socket. Remove the existing CPU (Z80) from the target system and insert the plug probe (Z80 40-pin end) into the adaptor socket and then carefully insert the assembly into the target system CPU socket. Do not bend the pins.

NOTE: Do not place the cables close to the power supply or interference will result.

Next connect the CSA/CSB Incircuit sockets to the ICD CPA/ CPB connectors (Figure 2-3 and 2-4). The cable with the longest length (CSB socket B) MUST be connected to the UPPER (CPB) Incircuit plug probe connector on the ICD.

NOTE: THE CABLE WITH THE LONGEST LENGTH (CSB) MUST BE CON-NECTED TO THE UPPER INCIRCUIT PLUG PROBE CONNECTOR (CPB).

CAUTION: DO NOT REVERSE PLUG PROBE CONNECTIONS. MISMATCH OF CSA/CSB AND CPA/CPB WILL CAUSE SEVERE DAMAGE TO THE ICD-278.

Once the system is constructed, refer to the ICD start-up sequence illustrated in Table 3-2.



#### Table 3-2. ICD Start-up Sequence

#### COMMAND GUIDE

The information contained in this COMMAND GUIDE relates to the ZAX ICD-278 for Z80 series emulators.

This Command Guide contains two parts. Part one acts as a reference guide and details the format and parameters of each command. Part two is a quick-reference guide that omits the parameter explanations for the experienced operator.

The ICD-278 for Z80 is capable of executing 29 major software commands. A portion of these commands are divided into various sub-groups for a total of 61 different command formats.

\*Example of command format structure: History format display - displays in disassembled or machine cycle format; B M D , int.point , term.point (cr) <sup>M</sup> 4 :display in machine cycle format. D **Z**:display with assembled codes. int.point :display or search initiation storage 5 pointer [decimal 1 to 2047] term.point :display or search termination storage pointer [decimal 1 (default to 2047]

Where -

1 - Command name.

- 2 Command description.
- 3 Command format including available parameters.
- 4 User supplied keywords, showing input choices.
- 5 User supplied address/data keywords.
- 6 Address/data parameters.
- 7 Keyword/address/data explanations.

Z80 Command Reference Guide -Commands: 61

#### Assemble

Break status Hardware Break specification Hardware Break designation Software Break specification Software Break designation Software Break op code specification External Break op code specification External Break on/off designation External Break on/off designation Event Break designation Timeout Break designation Write protect Break designation Hardware arm/individual designation Break initialize Break event with passcount

Calculation Compare Disassemble Dump

Event status Event specification Event designation

Examine only Examine and change Fill Go

History - realtime trace status History - realtime trace counter reset History - monitor trigger storage History - event trigger History - format display History - search Identification Incircuit status Incircuit specification Load Move Mapping status Mapping specification Next

Offset status Offset specification Pin status Pin specification

Port examination Port examination and change Print Quit Register status Register reset Register change

Save Search Supervisor status Supervisor specification

Trace status Trace designation Trace specification

User Verify Zice

#### Command Notes:

- \*Keywords/key characters are displayed as; M / , etc, or as BOLD characters. They represent words, letters, and characters which must be entered. Any combination of upper/lower case letters may be used.
- \*Lowercase letters show items which the user must supply, such as "filename" in which the user would enter the name of a selected file.
- \*A vertical line "|" is shown to indicate a choice between separated information which must be selected, such as;

ON OFF

ON or OFF may be entered, but not both.

\*Include all punctuation such as commas, equal signs, colons, slashes, feature keys. Etc.

\*Available address/data parameters are given at the end of the explanations and grouped as "[hex16/hexdata/ L byte/ASCII 32, etc]."

These address/data parameters include;

| [hex16]<br>[hexdata] | <pre>:hexadecimal 16-bit memory address. :word or byte data (8/16 bit). Valid</pre> |
|----------------------|-------------------------------------------------------------------------------------|
| [nexuala]            | range is 0-F and X.                                                                 |
| [L byte]             | <pre>:number of bytes. Hexadecimal 16-bit,<br/>0-F.</pre>                           |
| [ASCII 32]           | :ASCII codes. All ASCII A thru Z char-<br>acters(32) are available.                 |
| decimal              | :decimal values are specified within the brackets.                                  |

\*Commands are divided into different sub-groups based on their operation. This is shown whenever one command can perform several different functions, such as the Event Command. In this case such sub-groups as Status, Designation and Specification are used.

Status means; COMMAND name (cr). Designation means; COMMAND name ON/OFF or ON/OFF/CLR. Specification means; COMMAND name address, data, etc.

Other sub-groups are individually identified by selective titles (i.e. COMMAND: change, reset, display, etc).

#### INTERRUPTION Process

Emulation stop with GO command :press MONITOR swith on Operator Panel.

Stop :pressing <ESC> key on console keyboard stops the corresponding command.

- Interrupt (SP) :pressing the (space) bar on the console keyboard interrupts sequence after one line is displayed on screen. To restart display, press (space) bar again.
  - <DC3> :pressing the (CTR-S) key on the console keyboard immediately interrupts display.

#### INPUT STATEMENT CORRECTION

| Correction of<br>one character | : <del>(delete) Data is cancelled by the<br/>number of Rub out specifications and<br/>the corresponding characters are dis-<br/>played.</del> |
|--------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------|
| Backspace                      | : <bs>(backspace) Backspace operation is<br/>performed by the specified number and<br/>corresponding data cancelled.</bs>                     |

Cancellation of all data entry :<NAK> Pressing (CTL-U) cancels all entry data.

## Error Messages

| ERROR MESSAGE                   | COMMAND OCCURRENCE                      | DISPLAYED WHEN;                                                          |
|---------------------------------|-----------------------------------------|--------------------------------------------------------------------------|
| UNABLE BREAK ADDRESS            | Break<br>Go                             | a software break is specified<br>in the non-RAM area                     |
| MULTI BREAK ADDRESS             | Break<br>Go                             | a software break is duplicated<br>at the same address                    |
| WARNING UNABLE SOFT BREAK       | Break                                   | a software break is set at the<br>address presently not mapped<br>in RAM |
| *** FILE NOT FOUND              | All                                     | no file exists                                                           |
| *** DISK READ ERROR             | All                                     | a disk read error occurs                                                 |
| *** DISK WRITE ERROR            | All                                     | a sum check error occurs                                                 |
| *** NO DIRECTORY SPACE          | All                                     | no blank area available                                                  |
| C?>                             | All                                     | a command code error occurs                                              |
| P?>                             | All                                     | a parameter code error occurs                                            |
| /?>                             | All                                     | a modifier code error occurs                                             |
| MEMORY WRITE ERROR AT XXX       | Assemble,Examine<br>Load,Move,Fill      | there is a memory modification error.                                    |
| MEMORY TIMEOUT ERROR AT<br>XXXX | Assemble,Dump,Fill<br>Examine,Load,Move | memory I/O in the target system does not respond to ICD access.          |
| I/O TIMEOUT ERROR AT XX         | Port,Verify,Save<br>Compare,Search      | timeouts a waitstate                                                     |
| XXXX INPUT ERROR                | Examine,Assemble,<br>Port               | as an input error                                                        |
| BREAK BUSY                      | Break,Go                                | the break specification exceeds the limit                                |

#### THIS PAGE INTENTIONALLY BLANK

#### Commands

ASSEMBLE specification - changes Z80 assemble codes to Z80 machine codes and modifies the storage contents;

●>A mem.addr (cr)
xxxx (Z80 assemble code) (cr)
xxxx (cr)

mem.addr :memory address [hex16].
xxxx :ICD displays address then input Z80
assemble code.

EXAMPLE:

Move the data that resides in the Target System memory Ø-ØFFF, to the Emulator memory. Start at the ICD address,Ø;

>MØ, FFF,Ø,UP

BREAK status - displays the existing break status;

●>B (cr)

\_\_\_\_\_

Hardware BREAK specification - sets a hardware break;

●>B/ A|B|C stat , addr , passcount (cr)

A B C :hardware break name.

| stat >>> b | reak status;                                                      |
|------------|-------------------------------------------------------------------|
| М          | :memory access                                                    |
| Р          | :port access                                                      |
| MR         | :memory read                                                      |
| MW         | :memory write                                                     |
| PW         | :port write                                                       |
| PR         | :port read                                                        |
| OF         | :operation code fetch                                             |
| IA         | :interrupt acknowledge                                            |
|            |                                                                   |
| addr       | :break address [hex16].                                           |
| passcount  | <pre>:break passing count [decimal 1 (default)   to 65535].</pre> |

Hardware BREAK designation - turns on, off or clears a specified hardware breakpoint;

 $\Rightarrow$  B/ A B C ON OFF CLR (cr)

A B C :hardware breakpoint name.

Software BREAK specification - sets a software break;

●>B/\_0-7 addr , passcount (cr)

0-7 :software break name

addr :break address [hex16]. passcount :specifies break passing count (loop counter) [decimal 1 (default) to 65535].

Software BREAK designation - turns on, off or clears a specified software break;

 $\Rightarrow$  B/ 0-7 ON OFF CLR (cr)

0-7 :software break name

Software BREAK op code specification - specifies to place a software break in the enable (EN) state or the disabled (DI) state;

●>B S= EN DI (cr)

External BREAK hi/low designation - specifies an external break to occur at the HI or LOw edge;

●>B/X HI|LO (cr)

External BREAK designation - turns on, off or clears an external break;

●>B/X ON|OFF|CLR (cr)

Event BREAK designation - turns an event break on or off;

●>B/E ON OFF (cr)

\_\_\_\_\_

Timeout BREAK designation - turns a timeout break on or off;

●>B/T ON OFF (cr)

\_\_\_\_\_

Write protect BREAK designation - turns a write protect break on or off;

●>B/W ON OFF (cr)

\_\_\_\_\_

Hardware arm/individual BREAK specification - used with a specified hardware break name (A,B or C). Arm enables a break to occur after an event trigger takes place. INDividual allows a break to occur without regard to an event trigger;

 $\rightarrow$  B/ A|B|C ARM IND (cr)

A|B|C :hardware break name

BREAK initialize - clears the event passing condition and resets the ARM specification;

●>B INI (cr)

BREAK event with passcount - specifies the number of software pass counts;

●>B/E passcount (cr)

### EXAMPLES (BREAK command):

DISPLAY BREAK STATUS WITHOUT HARDWARE BREAK ON;

DISPLAY A BREAK STATUS WITH HARDWARE BREAK ON;

SET BREAK STATUS WITH A 16-BIT PHYSICAL ADDRESS AND ISSUE A BREAK STATUS COMMAND;

>B/A M,000X\_111X\_XXX\_00000 >B A (ON) M XXX0 1 Ø IND (0000X\_111X\_XXX\_00000) T (ON) S (DI) W (OFF)

SET A SOFTWARE BREAK USING A HEXADECIMAL ADDRESS;

| >B/7 123<br>>B   | 84 |              |   |   |                             |
|------------------|----|--------------|---|---|-----------------------------|
| A (ON)<br>7 (ON) | Μ  | XXXØ<br>1234 | 1 | Ø | IND (0000X_111X_XXXX_00000) |
| T (ON)<br>S (DI) |    | 1234         | • | b |                             |
| W (OFF)          |    |              |   |   |                             |

SET ARM BREAK FOR HARDWARE BREAK A;

| >B/A ARM<br>>B<br>A (ON) M XXXØ<br>7 (ON) 1234<br>T (ON)<br>S (DI) | 1 | Ø | ARM (ØØØX_111X_XXXX_ØØØØ) |
|--------------------------------------------------------------------|---|---|---------------------------|
| W (OFF)                                                            |   |   |                           |

ENABLE A SOFTWARE BREAK;

| 7 (ON)  | XXXØ<br>1234 | 1 | Ø | ARM (ØØØX_111X_XXXX_ØØØØ) |
|---------|--------------|---|---|---------------------------|
| T (ON)  |              |   |   |                           |
| S (EN)  |              |   |   |                           |
| W (OFF) |              |   |   |                           |

CALCULATION - allows subtraction and addition of hex and decimal numbers. Both subtraction and addition operations can be performed on the same line.

●>C data ± data ± data ... (cr)

data

:operation data. Decimal valid for -8388608 to 8388607, hex valid for 0 to FFFFFF(H).

EXAMPLE:

EXECUTE MULTIPLE HANDLING OF SUBTRACTION AND ADDITION USING HEX AND DECIMAL DATA INTERCHANGABLY;

>C 1234+1234 H: ØØØ9A4 D: 2468

>C 1000H-FFFH H: 000001 D: 1

COMPARE - compares the contents of a specified memory and displays the unmatching data;

O beg.addr , end addr , comp.addr , UP PU (cr)

beg.addr :comparison beginning address [hex16]. end addr :ending comparison address [hex16/L byte]. comp.addr :memory address to be compared [hex16].

UP :use beg.addr for the user memory and comp.addr for the ICD program memory.PU :use beg.addr for the ICD program memory and comp.addr for the user memory.

EXAMPLE:

0001

Ø6

0001

8F

MEMORY COMPARISON ● NOTE: OF THE RANGE; Ø TO ØØØ1 1 - TARGET SYS MEMORY ADDRESS >00 Ø,FFF,ØØØ1,UP <CR> 2 - TARGET SYS MEMORY CONTENTS 3 - EMULATOR MEMORY ADDRESS 2 M 3 ADDRESS 4<sub>M</sub> ADDRESS 4 - EMULATOR MEMORY CONTENTS ØØØØ C3 ØØØØ FF

DISASSEMBLE - disassembles the memory contents and displays it;

●>DI beg.addr , end addr (cr)

| beg.addr | :beginning memory | y address [hex16].     |
|----------|-------------------|------------------------|
| end addr | :ending memory ad | ddress [hex16/L byte]. |

#### EXAMPLE:

| A, (HL)<br>A<br>NZ, Ø3ØØH<br>O (DE), A<br>C HL<br>C DE<br>Ø1Ø6H<br>P<br>A, (3AØØH) |
|------------------------------------------------------------------------------------|
|                                                                                    |

\_\_\_\_\_

DUMP - displays the memory contents in either byte or word units. The contents is represented by a hex number or ASCII code;

### ●>D/ W beg.addr , end addr (cr)

W :dump memory contents on a word basis (default is a byte basis).

beg.addr :beginning memory address [hex16].
end.addr :ending memory address [hex16/L byte].

EXAMPLE:

DUMP MEMORY CONTENTS FROM Ø TO 30;

>DØ,3Ø

0 1 2 3 4 5 6 7 8 9 A B C D E F 21 FF 00 11 34 12 77 12 13 23 B7 C2 06 00 C3 00 Ø 2 3 4 5 ASCII CODE ØØØ0 !...4.w..#7B..C. ði ØØ ØØ1Ø ØØ2Ø ØØ ØØ ØØ ..... . . . . . . . . . . . . . . . . . ØØ Ø..... . . . . . . . . . . . . . . . . ØØ3Ø ØØ

DUMP MEMORY CONTENTS INTO WORD;

| >D/W                         | AØØØ,                            | L4Ø |                                   |                                   |              |                                   |                                   |                                   |                                                                            |
|------------------------------|----------------------------------|-----|-----------------------------------|-----------------------------------|--------------|-----------------------------------|-----------------------------------|-----------------------------------|----------------------------------------------------------------------------|
| AØØØ<br>AØ1Ø<br>AØ2Ø<br>AØ3Ø | Ø<br>FØ7F<br>FØ17<br>DØØ<br>FØØD | 2   | 4<br>F8Ø5<br>FØØ5<br>FØØ9<br>FØØ5 | 6<br>9ØØF<br>24ØF<br>Ø1ØF<br>ØØØF | FØØ5<br>D21F | A<br>AFAF<br>BDAF<br>A74F<br>A7AF | C<br>FØØD<br>FØED<br>FØ25<br>FØ45 | E<br>ØØ1C<br>18ØF<br>Ø21F<br>52ØF | ASCII CODE<br>.P.!.XP//.P<br>.P/E.P.\$.P/=MP<br>.P/PRO'%P<br>.P%!.PS/'EP.R |

EVENT status - displays the current event status; >EV (cr) EVENT specification - sets or releases an event trigger; >EVST=stat A=addr D=data (cr) stat >>> event trigger status; М :memory access MR :memory read MW :memory write Ρ :port access PR :port read PW :port write OP :operation code fetch IA :interrupt acknowledge addr :directs event trigger at a specified break address [hex16]. data :specifies event data [hexdata]. \_\_\_\_ \_\_\_\_\_ EVENT designation - turns on, off or clears an event trigger; >EV ON OFF CLR (cr) EXAMPLES (EVENT command): SPECIFY AN EVENT HEX ADDRESS USING 'DON'T CARE'; >EV A=AXXØ >EV (0N)STATUS = ANYADDRESS = AXX0 (1010\_XXXX\_XXX\_00000)  $(XXXX_XXXX)$ DATA = XX SPECIFY EVENT DATA; >EV D=0010\_11XX >EV (ON) STATUS = 0FADDRESS = AXXØ (1010\_XXXX\_XXXX\_0000) = 2X DATA  $(\emptyset\emptyset\overline{1}\emptyset_11\overline{X}X)$ SET EVENT COMMAND USING ADDRESS, DATA AND STATUS: >EV A=00FF D=12 ST=MR >EV (ON) STATUS = MR ADDRESS = ØØFF (000\_0000\_1111\_1111)

= 12

Data

(0001\_001)

EXAMINE only - examines the memory contents and displays it in either ASCII or hex data;

●>E/ W addr (cr)

Ŵ

:examine memory contents on a word basis (the default is a byte basis).

addr :beginning address of examined memory [hex16].

EXAMINE and change - examines and changes the memory contents to either ASCII or hex data;

●>E/ W beg.addr = mod.data (cr)

| W           | <pre>:change memory contents on a word basis (the<br/>default is a byte basis).</pre> |
|-------------|---------------------------------------------------------------------------------------|
| beg.addr    | <pre>:beginning memory address to be changed [hex16].</pre>                           |
| mod.data    | :memory modification data [hexdata/ASCII32].                                          |
| note: multi | -display of data;                                                                     |
| xxxx xx=dat | a (cr) :displays data at next address after change.                                   |
|             | ,(cr) :displays data at same address<br>after change.                                 |
|             | $\bigwedge$ cr) : displays data at address decre-                                     |

mented by 1 after change.
/(cr) :terminates Examine command after
change.

When data is omitted, memory contents remain unchanged.

EXAMPLE:

EXAMINE AND CHANGE MEMORY IN EXAMINE AND CHANGE MEMORY IN BYTE DATA; WORD DATA; >E 0100 <CR> >E/W 100 <CR> 0100 FA = CHANGE DATA <cr> 0100 03FA = CHANGE DATA <CR>  $0101 \ 03 =$  $0102 \ 1F21 =$ 0102 21 = 0103 1F = 0104 FD = 0102 1121 = 0104 11FD = 0106 FDAB = 0108 200E =  $0105 \ 11 =$ 010A FECD =0106 AB =0107 FD =

FILL - used to fill memory with either hex or ASCII codes;

>F W beg.addr , end addr , data (cr)

W :fill memory contents on a word basis (the default is a byte basis).

beg.addr :beginning address to be filled [hex16]. end addr :end memory address [hex16/L byte]. (default = data to be filled from the beginning address is written).

data :specifies data to be filled [hexdata/ASCII32].

EXAMPLE:

FILL MEMORY WITH "Ø" FROM ADDRESS ØØØØ TO ØØFF;

>F ØØØ,ØØFF,Ø

FILL MEMORY WITH ASCII CHARACTER FROM Ø TO FF;

F ØØØ, ØFF, ZAX'

GO - executes the user program;

●>G beg.addr , end addr , end addr\* (cr)

beg.addr :beginning executable address [hex16].
end addr :ending executable address [hex16].
end addr\* :optional second end address [hex16].

EXAMPLE:

EXECUTE A USER PROGRAM STARTING AT OH;

>G Ø,₿

IF(SP) PC MC OP BC IY DF IX н ØØØB 11ØØBØ LD DE.ØBØØØH BØØØ FFFC ØØØØ AØØØ ØØØØ ØØØØ ØØ ØØØØ Ø Ø4ØØ <br />
<b

CONTINUE THE EXECUTION AFTER BREAK;

>G

PC. MC 0P SP AF BC IX IF(SP)DE IY HL 15DC 3AØØ3A LD A, (3AØØH) FFB6 3AØØ 141Ø BØØ1 9FØ1 ØØØØ ØØØØ ØØ Ø Ø 3ØØ <BREAK MONITOR>

HISTORY - implements the trigger modes (6 types) for realtime tracing, and displays or searches for the user program operation to be traced.

Realtime trace status (HISTORY) - displays the current trace status;

●>H (cr)

Realtime trace counter reset (HISTORY) - clears (resets) the realtime trace counter;

●>H CLR (cr)

Monitor trigger storage (HISTORY) - specifies the begin, end, center or multiple monitor trigger;

●>H BM EM CE ME , range (cr)

BM :begin monitor trigger storage. Trace section is initiated by emulation start and terminated at a predetermined breakpoint specified by the range.

- EM :end monitor trigger storage. After initiating emulation with the Go or Next command, the monitor will respond with a break when the trace is terminated. Maximum range is 2048.
- CE :center event trigger. Trace section is recognized both before and after the event point.
- ME :multiple event trigger. Trace is performed each time an event point is passed during loop processing.

range :trace range [decimal 1 to 2047]

End trigger (HISTORY) - sets the end monitor or end event trace specification;

●>H EM EE (cr)

ΕM :end monitor trigger. Emulation begins using the GO or NEXT command to start trace and ends when control returns to monitor by passing a breakpoint. EΕ :end event. Terminates trace after event point is passed. Trace range is 2047. HISTORY format display - displays in disassembled or machine cycle format; >H M D , int.point , term.point (cr) Μ :display in machine cycle format. D :display data with assemble codes. int.point :display or search initiation storage pointer [decimal 1 to 2047]. term.point :display or search termination storage pointer [decimal 1 (default) to 2047]. HISTORY search - searches for the contents of the real time trace buffer; ●>HS,/addr/data/cycle , int.point , term.point (cr) :search address [hex] (word address="addr W") addr data :search data [hexdata]. cycle >>> specifies the type of machine cycle; IA :interrupt acknowledge MR :memory read MW :memory write :port read PRΡW :port write :operation code fetch OF ΗA :halt acknowledge int.point :search initiation storage pointer [decimal 1 to 2047]. term.point :search termination storage pointer [decimal 1 (default) to 2047].

### EXAMPLES (HISTORY command):

DISPLAY THE HISTORY STATUS;

>H CLOCK COUNTER = ØØØØØØAA/ STORAGE MODE = EM STORAGE SIZE = 14/ 14

DISPLAY THE REAL TIME TRACE IN MACHINE CYCLE;

| >HM, 20<br>POINT<br>ØØ2Ø<br>ØØ19<br>ØØ18<br>ØØ17<br>ØØ16<br>ØØ15<br>ØØ14<br>ØØ13<br>ØØ14<br>ØØ13<br>ØØ12<br>ØØ11<br>ØØ10<br>ØØ09<br>ØØØ8<br>ØØØ5<br>ØØØ4 | ADDR<br>ØØØ3<br>ØØØ4<br>ØØØ5<br>ØØØ6<br>ØØØ85<br>ØØØ84<br>ØØØ82<br>ØØØ82<br>ØØØ8<br>ØØØ8<br>ØØØ8<br>ØØØ8<br>Ø | DT<br>11<br>Ø<br>Ø<br>Ø<br>Ø<br>Ø<br>Ø<br>Ø<br>Ø<br>Ø<br>Ø<br>Ø<br>Ø<br>Ø<br>Ø<br>Ø<br>Ø<br>Ø<br>Ø | ፚኯ፟፟፟፟፟ቘቘኯኯኯኯኯኯኯኯኯኯኯኯኯኯኯኯኯኯኯኯኯኯኯኯኯኯኯኯኯኯ |  |
|----------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------|-----------------------------------------|--|
|                                                                                                                                                          |                                                                                                               |                                                                                                    |                                         |  |
| ØØØ6<br>ØØØ5<br>ØØØ4<br>ØØØ3                                                                                                                             | ØØØD<br>ØØØE<br>AØØØ<br>ØØØFi                                                                                 | BØ<br>7E<br>3A<br>77                                                                               | MR<br>M1<br>MR<br>M1                    |  |

.....

DISPLAY THE REALTIME TRACE IN MACHINE CYCLE AND DISASSEMBLE CODE;

| >H D<br>POINT<br>ØØ23<br>ØØ2Ø<br>ØØ17 | ADDR<br>ØØØØ<br>ØØØ3<br>ØØØ6 | DT<br>21ØØØ3<br>11ØØØ4<br>E5 | ST | OP<br>LD<br>LD<br>PUSH | HL,Ø3ØØH<br>DE,Ø4ØØH<br>HL |
|---------------------------------------|------------------------------|------------------------------|----|------------------------|----------------------------|
| ØØ16                                  | ØØ85                         | Ø3                           | MW |                        |                            |
| ØØ15<br>ØØ14                          | ØØ84<br>ØØØ7                 | ØØ<br>D5                     | MW | LD                     | HL.ØAØØØH                  |
| ØØ13                                  | ØØ83                         | Ø4                           | MW | -                      |                            |
| 0012                                  | ØØ82                         | ØØ                           | MW | 10                     | u daddau                   |
| ØØ11<br>ØØØ8                          | ØØØ8<br>ØØØB                 | 2100A0<br>1100B0             |    |                        | HL,ØAØØØH<br>DE,ØBØØØH     |
| ØØØ5                                  | ØØØE                         | 7E                           |    | ĽĎ                     | A, (HL)                    |
| 0004                                  | AØØØ                         | 3A                           | MR |                        | (1.11.) .                  |
| ØØØ3<br>ØØØ2                          | ØØØF<br>AØØØ                 | 77<br>3A                     | MW | LD                     | (HL).A                     |
|                                       |                              |                              |    |                        |                            |

SEARCH FOR THE CONTENTS OF REAL TIME TRACE FOR A MEMORY READ;

| >H S,///MR |         |    |
|------------|---------|----|
| POINT T    | Addr DT | ST |
| ØØ13       | Ø1Ø1 ØØ | MR |
| ØØ12       | Ø1Ø2 AØ | MR |
| ØØ1Ø       | 0104 00 | MR |
| 0009       | Ø1Ø5 BØ | MR |
| ØØØ7       | AØØØ FF | MR |

IDENTIFICATION - displays an ICD device name and a version of the installed firmware;

●>ID (cr)

INCIRCUIT status - displays the current incircuit mode;

●>I (cr)

INCIRCUIT specification - sets the ICD mapping mode;

●>I 0|1|2 (cr)

0

:System mode enables debugging (software only) using the ICD program memory. In this mode the target system I/O and interrupt signals are ignored.

:Partial mode. Enables debugging using the ICD program and target system memories. In this mode the specified mapping, I/O and interrupt signals all become valid.

2

1

:All mode. Enables debugging using only the target system memory. R/W and RO memories are operated as user memory (US).

note: default = current state displayed

LOAD - loads either a hex file on diskette or the object program (Intel format) from the specified port; ●>L/ T P A H filename , bias (cr) т :terminal port (ignore software handshake) P :terminal port (perform software handshake) А :auxiliary port Н :host port filename :(available with ZICE software only). :if omitted, starting address is specified bias [L byte]. EXAMPLE: LOAD THE TEST HEX FILE ON DISKETTE: > L TEST 100 >L/T ,100 200 MOVE - moves memory between the ICD and target system; ●>M beg.addr , end addr , mov.addr , UP|PU (cr) beg.addr :beginning memory address [hex16]. :ending memory address [hex16/L byte]. end addr :beginning address where data is transferred mov.addr to [hex16]. UP PU >>> optional parameter; UP :data is moved from the target memory to the ICD program memory. ΡU :data is moved from the ICD program memory to the target memory. EXAMPLE: MOVE MEMORY OF OH THROUGH FFFH: >M Ø.FFF.Ø.UP

MAPPING status - displays the current map status;

●>MA (cr)

```
_____
```

MAPPING specification - sets the ICD memory map. The target system or ICD program memory is specified on a 1K byte basis;

●>MA beg.addr , end addr = RO RW NO US (cr)

beg.addr :beginning address of mapping [hex16].

end addr :ending address of mapping [hex16/L byte]
 note: default (beg.addr/end addr)=1K byte.

| RO | read only memory:  |
|----|--------------------|
| DW | .road/write memory |

| RW | :read/write memory                       |
|----|------------------------------------------|
| NO | :non memory area (a break occurs in this |
|    | area if accessed by a program)           |
| US | user (target system) memory:             |

EXAMPLE:

SPECIFY Ø TO FFF AS THE USER MEMORY;

>MA Ø, FFF = US

DISPLAY THE STATUS OF THE MEMORY MAP;

>MA IN-CIRCUIT MODE 1 (US=RW) ØØØØ-ØFFF = US 1ØØØ-FFFF = RW

DISPLAY THE STATUS OF THE MEMORY MAP WHEN THE INCIRCUIT MODE IS NOT 1;

>MA IN-CIRCUIT MODE Ø (US=RW) ØØØØ-ØFFF = US 1ØØØ-FFFF = RW NEXT - executes n-step All trace display from the current pointer;

●>N steps (cr)

steps

:specifies number of single steps [decimal 1
 (default=1) to 15535].

EXAMPLE:

PERFORM A SINGLE STEP TRACE, FIVE STEPS FROM THE CURRENT PC;

>N 5

| PC   | MC      | OP |              | SP      | AF      | BC      | DE   | HL      | IX      | IY      | 1  | IF(SP) |
|------|---------|----|--------------|---------|---------|---------|------|---------|---------|---------|----|--------|
| Ø1Ø  | 3aøøaø  | LD | A, (ØAØØØH)  | ØØ2E    | Ø5ØE    | A5ØE    | Ø3Ø1 | 4312    | ØØØØ    | ØØØØ    | ØØ | Ø ØØ1A |
| Ø1Ø3 | 77      | цр | (HL),A       |         |         |         |      | • • • • |         | • • • • |    |        |
| 0104 | FEØ5    | CP | 5            |         | Ø542    | • • • • |      | • • • • |         | • • • • | •• |        |
| 0106 | C20001  | JP | NZ.0100H     | • • • • |         |         |      | iddd    | • • • • | ••••    | •• |        |
| 0109 | z iddad | Ш  | HL, DAOIOIDH | • • • • | • • • • |         |      | AØØØ    | • • • • | • • • • |    |        |

PERFORM A SINGLE STEP TRACE FOR FIVE STEPS CHANGING PC;

>R PC,200 >N 5

| PC MC<br>Ø2ØØ 3AØØ3A                       | OP<br>LD A, (3AØØH)        | SP<br>ØØ2E | AF<br>3A42 | BC<br>A5ØE | DE<br>Ø3Ø1 | HL<br>AØØØ         | 1X<br>ØØØ0 | IY<br>ØØØØ | l<br>ØØ | 1F(SP)<br>Ø ØØØØ |
|--------------------------------------------|----------------------------|------------|------------|------------|------------|--------------------|------------|------------|---------|------------------|
| 102103 100<br>102104 3A0103A<br>102107 100 | NOP<br>LD A,(3AØØH)<br>NOP | ••••       | ••••       | ••••       | ••••       | • • • •<br>• • • • | ••••       | ••••       | ••      | • • • • • •      |
| Ø2Ø8 3AØØ3A                                | LD A, (3AØØH)              | ••••       | ••••       | ••••       | ••••       | ••••               | ••••       | ••••       | •••     | · · · · · ·      |

OFFSET status - displays the current offset set value;

●>0 (cr)

OFFSET specification - sets a value (1 of 4) in an offset register for relative addressing. All offset registers can be used for ICD memory addressing parameters;

 $\bullet$ >0 &1 &2 &3 &4 = addr (cr)

PIN status - displays the current pin status;

●>PI (cr)

\_\_\_\_\_

PIN specification - masks or unmasks the target system interruption signal when the incircuit mode is I1. Interruptions are ignored in the I1 mode and accepted in the I2 mode.

>PI level=EN DI (cr)

level >>> specifies bus request or interrupt level;

| BUSRQ | :bus request  |
|-------|---------------|
| NMI   | :non-maskable |
| INTR  | :interrupt    |
|       |               |

EN :interruption or hold signal enable. DI :interruption or hold signal disable.

note: default = current specification and mask states
 are displayed.

EXAMPLE:

DISPLAY PIN STATUS;

>PI IN-CIRCUIT MODE 1 NMI (EN) = Ø BUSRQ (EN) INTR (EN) = Ø

DISABLE BUSREQUEST AND DISPLAY THE STATUS;

>PI BUSRQ = DI >PI IN-CIRCUIT MODE 1 NMI (EN) = Ø BUSRQ (DI) INTR (EN) = Ø PORT examination - examines the current port contents;

●>P port (cr)

port :conversion start port address [hex16/Lbyte].

PORT examination and change;

>P port = data (cr)

port :conversion start port address [hex16/Lbyte].

data

:port conversion data [hex16/ASCII 32].

note: multi-display of data is possible using the formats below;

| xxxx | xx : data | (cr) - display data at next address  |
|------|-----------|--------------------------------------|
|      |           | after change.                        |
|      |           | ,(cr) - display data at same address |
| •    |           | after change.                        |
|      |           | (cr) - display data at address that  |
|      |           | is decremented by 1 after the        |
|      |           | change.                              |

EXAMPLE:

EXAMINE AND WRITE OUT A PORT;

>P FF=12 12 34 56 78

READ AND CHANGE PORT IN BYTES USING MULTI-DISPLAY FORMAT;

>P 55 55 55:12 56 56:23 57 57:'B' 58 58:'D', 58 58:00, 59 59:12 58 58:/

READ AND CHANGE PORT IN WORDS USING MULTI-DISPLAY FORMAT;

>P 23 23 23:00 24 24:12 25 25:33 26 26:/ PRINT - outputs data sent from the ICD to the Terminal or Host/Aux ports simultaneously.

.

●>PR ON OFF (cr)

ON :output data to both Terminal and Host/Aux ports.

OFF :output data to the console only.

QUIT - returns control to the host system (valid when used with ZICE software only);

●>Q (cr)

\_\_\_\_\_

REGISTER status - displays the current register status;

●>R (cr)

EXAMPLE:

DISPLAY REGISTER WITH TITLES;

>R

| PC<br>ØØØØ | SP<br>ØØØØ | SZHPNC<br>ØØØØØØ | A<br>ØØ | BC<br>ØØØØ | DE<br>ØØØØ | ••••• |  | IF (SP)(HL)<br>Ø ØØ21 21 |  |
|------------|------------|------------------|---------|------------|------------|-------|--|--------------------------|--|
|------------|------------|------------------|---------|------------|------------|-------|--|--------------------------|--|

\_\_\_\_\_\_

REGISTER RESET - initializes all registers to 0 by pushing the RESET switch on the Operator Panel;

●>R (push)RESET (cr)

REGISTER change - changes the Z80 CPU register and program counter; ●>R reg = data (cr) req >>> register name; Α F С В D Ē Н L Т A' F' в' C! D' E۱ H ' L' I' ВC DH HLIX IΥ SP BC' DH' HL' CY S z HC P N IF(IFFI) :register change data [hexdata]. data EXAMPLE: CHANGE HL TO A VALUE OF ADDO; >R HL=A000 >R SP IF (SP)(HL) PC SZHPNC BC DE ØØØØ ØØØØ ØØ ØØØØ ØØØØ ØØ21 3A ØØØØØØ ØØ Ø \_\_\_\_ -----SAVE - saves a user program on diskette (HEX file) or dumps the user program to a specified port; ●>SA/ T|P|A|H filename, beg.addr, end addr, user addr, (cr) Т :terminal port (ignore software handshake) Ρ :terminal port (perform software handshake) Α :auxiliary port :host port Η filename :(available with ZICE software only). :beginning memory address [hex16]. beg.addr end addr :ending memory address [hex16/L byte]. user addr :beginning user program address [hex16]. EXAMPLE: GENERATE THE TEST. HEX FILE ON DISKETTE;

>SA TEST,Ø, 37FF,Ø

SEARCH - searches for the memory contents and displays the matched or unmatched address; ●>S/W /D beg.addr , end addr , data (cr) :search on a word basis (default is a byte /W basis). /D :search for unmatched data (default searches for matched data). beg.addr :beginning memory search address [hex16]. :ending memory search address [hex16/L byte]. end addr data :search data [hexdata/ASCII32]. EXAMPLE: >S Ø,L3Ø,12 ØØ12 >S/W 100,110,1234 >S/D Ø,10,00 ØØØ1 ØØØ2 0003 - -- ---ØØØ9 ØØØA ØØØB .... - ---\_ \_ ØØ1Ø

\_\_\_\_\_

SUPERVISOR status - displays the current supervisor state;

●>SU (cr)

SUPERVISOR specification - sets a breakpoint as a supervisor call. When executed, data is directly trans-ferred between the program being emulated and the ICD;

### $\Rightarrow$ SU/ C 7 U ON OFF (cr)

| С         | hardware break C as a supervisor call.                                               |
|-----------|--------------------------------------------------------------------------------------|
| 7         | software break 7 as a supervisor call.                                               |
| U         | :user software break as a supervisor call.                                           |
| ON<br>OFF | <pre>:set if used as a supervisor call. :set is not used as a supervisor call.</pre> |

EXAMPLE:

CHECK THE TERMINAL PORT INPUT STATE;

>DI 9000,900C 9000 1E01 LD E,1 9002 00 NOP OR A JP Z,90002H LD (HL),A 9ØØ3 B7 9004 CA0290 9007 77 INC B CP ØDH 9008 04 9009 FE0D RET Z LD (HL),A 9ØØB C8 9ØØC 77 >SU/7 ON >B/7 9002 >G 9000.9008

IF(SP)PC MC 0P SP AF BC DE IX IY 9008 04 INC B ØØ2E FFØ8 10ØE Ø3Ø1 ØØØØ 00 0 0000 AØØØ ØØØØ <br />
<b

TRACE status - displays the current trace mode;

●>T (cr)

\_\_\_\_\_

TRACE designation - makes the current trace mode valid invalid or clears the trace setting;

●>T ON OFF CLR (cr)

TRACE specification - sets the ICD trace mode;

>T/S A|J, beg.addr, end addr (cr)

/S :single step mode. In this mode the All or Jump trace is executed each time the space bar or (cr) is pressed.

all commands are traced and displayed.
 jump trace (only branch command is traced and displayed).

beg.addr :beginning trace address [hex16]. end addr :ending trace address [hex16/] (default=FFFF).

EXAMPLE:

SET THE TRACE MODE;

>T A,1ØØ,4Ø5

DISPLAY TRACE STATUS;

>T (ON) ALL Ø1ØØ-Ø3ØØ

EXECUTE TRACE EXAMPLE;

>G 1ØØ

| PC MC<br>Ø1ØØ 21ØØAØ | OP<br>LD HL.ØAØØØH           | SP      | AF<br>ØØ23 | BC   | DE           | HL IX     | IY      | 1   | IF(SP)      |
|----------------------|------------------------------|---------|------------|------|--------------|-----------|---------|-----|-------------|
| Ø1Ø3 11ØØBØ          | LD HL,ØAØØØH<br>LD DE,ØBØØØH | ØØØ2    | 0023       | 1481 | 15Ø1<br>BØØØ | AØØØ ØØØØ | ØØØØ    | ØØ  | Ø 8185      |
| Ø1Ø6 D5              | PUSH DE                      | ØØØØ    | ••••       | •••• | DIDIDID      | ••••      | • • • • | ••  | 0000        |
| 0107 110003          |                              | 0000    | ••••       | •••• | Ø3ØØ         | ••••      | ••••    | ••  | . 8000      |
| Ø1ØA 7E              | LD A. (HL)                   | ••••    | FF23       | •••• | UJUU         | ••••      | • • • • | ••  | • ••••      |
| Ø1ØB 12              | LD (DE) A                    |         |            |      |              |           | ••••    | ••  | • ••••      |
| Ø1ØC 13              | INC DE                       |         |            |      | Ø3Ø1         |           |         | ••  | • • • • • • |
| Ø1ØD C1              | POP BC                       | ØØØ2    |            | BØØØ |              |           |         |     | . 8185      |
| Ø1ØE C3ØØØ4          | JP Ø4ØØH                     |         | • • • •    | •••• | • • • •      | ••••      | • • • • | • • |             |
| 0400 018016          | LD BC, 1680H                 | ••••    | ::::       | 168Ø |              | ••••      | ••••    | ••  |             |
| Ø4Ø3 8Ø              | ADD A.B                      | • • • • | 1511       |      | ••••         | ••••      | ••••    | ••  | • ••••      |
| Ø4Ø4 Ø3<br>Ø4Ø5 FØ   | INC BC                       | ••••    | ••••       | 1681 | ••••         | ••••      | ••••    | ••  | • ••••      |

RELEASE THE TRACE MODE;

>T CLR

NOTE: TRACE DISPLAYS ">" WITH THE <ESC> KEY TO ACCEPT A COMMAND.
 NOTE: TRACE IS EXECUTED BY THE "GO" COMMAND, WHICH STARTS THE DISPLAY.

USER - allows the console terminal (connected to the ICD Terminal port) to be used as the terminal for the host system;

●>U code (cr)

code :terminator code

note: <ESC>,<NAK>,<SP>,<BS> and <cr> cannot be used as terminator codes.

#### EXAMPLE:

USER COMMAND WITH DESIGNATED TERMINATOR;

| >U !                         |                         |                            |                            |
|------------------------------|-------------------------|----------------------------|----------------------------|
| >A DIR B:<br>B: PIP<br>B: ED | COM : STAT<br>COM : ASM | COM : DUMP<br>COM : SYSGEN | COM : LOAD<br>COM : MOVCPM |

VERIFY - compares the object in the Intel format (from the host computer file or specified port) with the ICD memory contents;

## ●>V/ T|P|A|H filename, bias (cr)

| T<br>P<br>A<br>H                                                  | <pre>:terminal port (ignore software handshake) :terminal port (perform software handshake) :auxiliary port :host port</pre> |  |  |  |  |  |
|-------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| filename :object name to compare (valid with ZICE software only). |                                                                                                                              |  |  |  |  |  |
| bias                                                              | :bias of file or object to compare [hexdata].                                                                                |  |  |  |  |  |
| EXAMPLE:                                                          |                                                                                                                              |  |  |  |  |  |
| COMPARE THE                                                       | TEST.HEX FILE ON NOTE: "ADRS", "M" AND "O"                                                                                   |  |  |  |  |  |

DISKETTE WITH THE MEMORY CONTENTS; NUIL: "ADRS", "M" AND "U" INDICATE THE MEMORY ADDRESS, CONTENTS OF THE MEMORY ADDRESS AND OBJECT, RESPECTIVELY.

>V TEST ADRS M 0 ØØØØ

>V/T ,1000 ADRS M 0 02000

#### ZICE command

The Zice command is used exclusively for ZICE. When the ICD is used in the remote operation (host computer) the ZICE utility software is required for controlling the ICD. ZICE expands the commands not built into the ICD (see software specification for details).

#### ●>Z (Z command & parameter)

- Z commands include;
- ZB :batch processing. Executes commands of the filename. BAT file in the host system by batch processing.
- ZC :comment. Inserts a comment in a batch file
   of the host system or in the middle of
   repeat processing and outputs it to the
   console.
- ZD :directory. Displays a directory of the \*.BAT
   or \*.HEX file in the host system by directory
   format.
- ZH :help. Displays command list.
- ZM :menu. Enter data by command menu method.
- ZP :print. Outputs the contents displayed on the console screen to a list device.
- ZR :repeat. Repeats a specified command.
- ZW :wait. Places a temporary pause in a repeat or batch subcommand.

## Quick-Commands

ASSEMBLE specification: >A mem.addr (cr) xxxx (Z80 assemble code) (cr) xxxx (cr)

BREAK status: >B (cr)

Hardware BREAK specification: >B/ A|B|C  $\underset{P}{MW}|_{PR}^{PW}|_{IA}^{OF}$ , addr, passcount (cr)

Hardware BREAK designation: >B/ A|B|C ON|OFF|CLR (cr)

Software BREAK specification: >B/ 0-7 addr, passcount (cr)

Software BREAK designation: >B/ 0-7 ON|OFF|CLR (cr)

Software BREAK op code specification: >B S= EN DI (cr)

External BREAK hi/low designation: >B/X HI LO (cr)

External BREAK designation: >B/X ON|OFF|CLR (cr)

Event BREAK designation: >B/E ON|OFF (cr)

Timeout BREAK designation:
>B/T ON|OFF (cr)

Write protect BREAK designation: >B/W ON|OFF (cr)

Hardware arm/individual BREAK specification: >B/ A|B|C ARM|IND (cr)

BREAK initialize: >B INI (cr)

BREAK event with passcount: >B/E passcount (cr)

```
CALCULATION:
>C data ± data ± data ... (cr)
COMPARE:
>CO beg.addr , end addr , comp.addr , UP PU (cr)
DISASSEMBLE:
>DI beg.addr , end addr (cr)
DUMP:
>D/ B|W|L beg.addr , end addr (cr)
EVENT status:
>EV (cr)
EVENT specification:
>EVST= M|MR|PR|OP A=addr D=data (cr)
       PMWPWIA
EVENT designation:
>EV ON OFF CLR (cr)
EXAMINE only:
>E/ W addr (cr)
EXAMINE and change:
>E/ W beg.addr = mod.data (cr)
FILL:
>F W beg.addr , end addr , data (cr)
GO:
>G beg.addr , end addr , 2nd end addr (cr)
Realtime trace status (HISTORY):
>H (cr)
Realtime trace counter reset (HISTORY):
>H CLR (cr)
Monitor trigger storage (HISTORY):
>H BM \mid EM \mid CE \mid ME , range (cr)
Event trigger (HISTORY):
>H EM EE (cr)
HISTORY format display:
>H M D , int.point , term.point (cr)
HISTORY search:
>HS,/addr/data/ IA_MR_PR_OF , int.pointer , term.pointer (cr)
                   MW PW HA
```

```
IDENTIFICATION:
 >ID (cr)
 INCIRCUIT status:
 >I (cr)
 INCIRCUIT specification:
 >I 0|1|2 (cr)
 LOAD:
 >L/ T P A H filename, bias (cr)
 MAPPING status:
 >MA (cr)
 MAPPING specification:
 >MA beg.addr , end addr = RO | RW | NO | US (cr)
 MOVE:
 >M beg.addr , end addr , mov.addr , UP PU (cr)
 NEXT:
 >N steps (cr)
 OFFSET status:
 >0 (cr)
 OFFSET specification:
 >0 &1 \&2 \&3 \&4 = addr (cr)
 PIN status:
 >PI (cr)
 PIN specification:
. >PI BUSRQ NMI INTR = EN DI (cr)
 PORT examination:
 >P beg.addr (cr)
 PORT examination and change:
 >P beg.addr = data (cr)
 PRINT:
 >PR ON OFF (cr)
 QUIT:
 >Q (cr)
 REGISTER:
 >R (cr)
 REGISTER reset:
 >R (push)RESET (cr)
```

```
REGISTER change:
>R reg = data (cr)
(reg>>> A F B C D E H L I
       A'F'B'C'D'E'H'L'I'
        BC DH HL IX IY SP
        BC'DH'HL'
        CY S Z HC P N IF(IFFI)
SAVE:
>SA/ T|P|A|H filename , beg.addr , end addr , user addr (cr)
SEARCH:
>S/ W / D beg.addr , end addr , data (cr)
SUPERVISOR status:
>SU (cr)
SUPERVISOR specification:
>SU/ C 7 U ON OFF (cr)
TRACE status:
>T (cr)
TRACE specification:
>T /S A J, beg.addr , end addr (cr)
TRACE designation:
>T ON OFF CLR (cr)
USER:
>U code
VERIFY:
>V/ T|P|A|H filename, bias (cr)
Zice command:
>Z B C D H M P R W (Z command & parameter) (cr)
```

THIS PAGE INTENTIONALLY BLANK

SECTION IV

## **TECHNICAL REFERENCES**

### INTRODUCTION

This section contains specific technical information on the ICD-278 and is included to allow the user to become familiar, in detail, with specific emulator operations, techniques and procedures. The areas covered in this section relate to; A) Emulation Select switch, B) Data Bus Emulation connector, C) Serial Interface, D) Memory Emulation, E) CPU Emulation, F) Probes, G) Control Modules.

A comprehensive listing of the specific headings for each chapter may be found in the Table of Contents located at the beginning of this manual.

Section IV Technical References

- A Emulation Select switch Describes the various settings and functions of the 4-bit emulation switch.
- B Data Bus Emulation connector

Describes the function and use of the Data Bus Emulation connector.

**C** Serial Interface

Describes the components and functions of the S-791 Serial Interface module. Includes the procedure to connect the ICD-278 to a console terminal or host computer.

### **D** Memory Emulation

Describes the relationship between the ICD and Target System with regard to memory transfer and mapping.

E CPU Emulation

Highlights differences between the Z80 microprocessor and the emulator. Also describes prerequisite conditions for integrating the ICD-278 with a target system.

### F Probes

Describes the functions of the various plug probes used with the ICD-278.

### **G** Control Modules

Describes and illustrates the four Control Modules within the ICD-278 and details their removal and installation.

### THIS PAGE INTENTIONALLY BLANK

# A EMULATION SELECT SWITCH

The Emulation Select switch allows the user to implement specialized conditions for the ICD-278 by modifying the machine cycle operation to the target system. The information contained here shows the various settings and functions of this switch (Figure 4-A.1) including the factory setting (Figure 4-A.2).

The Emulation Select switch is a 6-bit, ON/OFF type switch that is located on the CPA/CPB In-circuit connector side of the ICD-278. To change the bit settings, insert a small, pointed tool and set accordingly.



Figure 4-A.1. Emulation Select Switch



## Figure 4-A.2. Factory Setting

4A-1



- OFF Disables emulator data bus D0-D7 from the target system data bus.
- ON Normal setting. D0-D7 outputs to target system from the emulator data bus.



Figure 4-A.3. Emulation Data Bus Block Diagram

| ON<br>OFF         | Bit TWO   |
|-------------------|-----------|
| ON<br>OFF 1 2 3 4 | BIT THREE |

2 ON - RD signal outputs to the target system independently 3 OFF of the Mapping command.

2 OFF - Use in the I1 mode only. Map command dependent. 3 ON

| Example: | >I1 | (cr)         |
|----------|-----|--------------|
|          | >MA | 0,0FFF=RW    |
|          | >MA | 1000,FFFF=US |

[ICD memory]
[target memory]

RD signal does not output to the target system when executing out of emulator memory (RD signal outputs to the target system when executing from the target memory).



Figure 4-A.4. Emulator READ Signal Block Diagram



ON - 1, 2 or 3 clock wait is inserted in each machine cycle.

OFF - No clock wait is inserted in machine cycle.

The wait state produced by the ICD-278 can hold for a period of two (optional one or three) clocks (wait states) by connecting the WT, 1C and 2C points on the S-793 CPU module.

Setting the wait state;

| 1 CLOCK CYCLE | WAIT · 2 | CLOCK C              | YCLE V | WAIT            | 3 сгоск | CYCLE   | WAIT    |
|---------------|----------|----------------------|--------|-----------------|---------|---------|---------|
| 1C WT         |          | O<br>1C W<br>Factory | •••••• | ≥<br>2C<br>ING) | 0<br>1C | O<br>WT | O<br>2C |

## Figure 4-A.5. Wait States

The DB (Data bus) Emulation connector is used to forcibly output the "RETI" (return from interrupt) instruction to I/O devices on the target system (used in the I1 mode only). This connector is used when executing the RETI instruction out of emulator memory (absence of MREQ from data bus direction control).

Connect the DB Emulation connector directly (in-circuit) to the outside of the data bus buffer (memory and I/O side) of the target system.



Figure 4–B.1. DB. EMUL Connector



Figure 4-B.2. DB. EMUL Connector Configuration

# C SERIAL INTERFACE

1 Option jumper socket - JA is an optional jumper socket to connect the interface signal of the Terminal port to the current loop and TTL. 2 JB is an optional jumper socket to connect the interface signal of the Host/Aux port to the current loop and TTL. (RS-232C interface is standard) 3 Terminal and Host/Aux line drivers - SN75188 is mounted in the RS-232C and current loop interface. For TTL interface, JA3,4 & 5 or JB3,4 & 5 must be changed for replacement with SN7438. 4 Terminal line driver 5 Host line driver 6 JA3,4 & 5 power supply jumpers - used for Terminal line driver IC. JA3 and 5 supplies +12V to SN75188. JA4 supplies +5V to SN7438. 7 JB3,4 & 5 power supply jumpers - used for Host/Aux line driver IC. JB3 and 5 supplies +12V to SN75188. JB4 supplies +5V to SN7438. 89 Transmission format switch - used to set data and stop bits for Terminal and Host/Aux ports (Figure 4-B.1, B.2). 8 Sets transmission format of the Terminal port 9 Sets transmission format of the Host/Aux port



# Figure 4-C.1. S-791 SIO Module



Figure 4-C.2. Transmission Format Switch

When the Transmission Format switch is set to OFF (TBMT\* & TEOC\*), the ICD sends data in the signal buffer and monitors the BUSY signal. When set to ON (TBMT), the ICD sends data in the double buffer and does not monitor the BUSY signal.

Factory settings;

| Terminal: | 8 data bits<br>2 stop bits<br>no parity bit | Host/Aux: | 8 data bits<br>2 stop bits<br>no parity bit |
|-----------|---------------------------------------------|-----------|---------------------------------------------|
|           | bit 8=0                                     |           | bit 8=0<br>TMBT* & TEOC*                    |

- \* TBMT Transmitted Buffer Empty. The transmitted buffer empty flag goes to a logic "1" when the data bits holding register may be loaded with another character.
- \* TEOC Transmitted End of Character. This line goes to a logic "1" each time a full character is transmitted. It remains at this level until the start of transmission of the next character.

# SERIAL INTERFACE SPECIFICATIONS

| Interface channel:    | Two channels (Terminal & Host/Aux)                                                                                                                                                                                                                   |
|-----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Interface signals:    | RS-232 C (standard specifications)<br>20mA current loop<br>TTL                                                                                                                                                                                       |
|                       | The current loop and TTL can be set<br>according to Terminal and Host/Aux<br>by changing jumper sockets JA and<br>JB on the S-791 board or line driver<br>IC.                                                                                        |
| Communication method: | Full-duplex, asynchronization                                                                                                                                                                                                                        |
| Transmission format:  | <pre>Start bit - 1 Data bits - 7 or 8 (factory; 8) Stop bits - 1 or 2 (factory; 2) Parity bit- Odd/Even or none                          (factory; none) The data, stop and parity bits are set by dip switches DSW3 and 4 on the S-791 board.</pre> |
| Transmission codes:   | ASCII codes                                                                                                                                                                                                                                          |
| Baud Rate:            | 19,200 9,600 4,800 2,400<br>2,000 1,200 1,800 600<br>300 200 134.5 110 75                                                                                                                                                                            |
|                       | The baud rate is set by the Baud<br>Rate switch on the communication                                                                                                                                                                                 |

panel (Figure 4-C.1).

-

#### RS-232C INTERFACE (TERMINAL)

| Pin<br>NO.                            | SIGNAL<br>NAME                                   | MEANING                                                                                                                          | In/Out                                                   | JA No.                                            |
|---------------------------------------|--------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------|---------------------------------------------------|
| 1<br>2<br>3<br>4<br>5<br>6<br>20<br>7 | FG<br>SD<br>RD<br>RTS<br>CTS<br>DSR<br>DTR<br>SG | FRAME GROUND<br>SEND DATA<br>RECEIVE DATA<br>REQUEST<br>CLEAR TO SEND<br>DATA SEND READY<br>DATA TERMINAL READY<br>SIGNAL GROUND | IN<br>OUT<br>IN <b>* 1</b><br>OUT <b>*1</b><br>OUT<br>IN | SN 75188N <b>*3</b><br>J6,J20 <b>*2</b><br>J6,J20 |

Table 4–C.1. RS–232C Interface Pin Designation (Terminal)



\*2 DTR and DSR are looped back (null modem) within the ICD by connecting JA6 and 20 (pins 15 & 16) together. DTR is used as the BUSY signal for an ICD terminal by connecting JA20. DSR may be used as the BUSY signal by connecting JB6.

When JA6 is connected, the loopback jumper between JA6 and 20 (pins 15 & 16) is prohibited. The standard connection = JA6/20 and JA20.

\*3 SN75188N is installed for the TERMINAL line driver. In this configuration, JB3 and JB5 are connected with a jumper plug to supply ±12V to SN75188N. JA4 may NOT be connected. The standard connection = JB3 and JB5.

| Pin<br>NO.                            | SIGNAL                                                     | MEANING                                                                                                                                  | In/Out                                                               | JA No.                                             |
|---------------------------------------|------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------|----------------------------------------------------|
| 1<br>2<br>3<br>4<br>5<br>6<br>20<br>7 | FG<br>SD<br>RD<br>RTS <b>*2</b><br>CTS<br>DSR<br>DTR<br>SG | FRAME GROUND<br>SEND DATA<br>RECEIVE DATA<br>REQUEST TO SEND<br>CLEAR TO SEND<br>DATA SEND READY<br>DATA TERMINAL READY<br>SIGNAL GROUND | *1<br>OUT(IN)<br>IN(OUT)<br>OUT(IN)<br>IN(OUT)<br>IN(OUT)<br>OUT(IN) | <b>*4</b><br>sn 75188N<br>J6,20 <b>*3</b><br>J6,20 |

# RS-232C INTERFACE (HOST/AUX)

and the state of the

Table 4–C.2. RS–232C Interface Pin Designation (Host/Aux)



- \*2 CTS and RTS are looped back (null modem) within the ICD by connecting JB6 and 20 (pins 15 & 16) together.
- \*3 DTR and DSR are looped back (null modem) within the ICD by connecting JB6 and 20 (pins 15 & 16) together.

DTR is used as the BUSY signal for the ICD terminal by connecting JB20. DSR may also be used as the BUSY signal for the ICD terminal by connecting JB6. When JB6 is connected, the loopback jumper between JB6 and 20 (pins 15 & 16) is prohibited. Standard connection = JB6/20 and JB20.

\*4 SN75188N is installed for the HOST/AUX line driver. In this configuration, JB3 and JB5 are connected with a jumper plug to supply ±12V to SN75188N. JB4 may NOT be connected. Standard connection = JB3 and JB5.



Figure 4-C.3. RS-232C Standard Jumper Settings

### CURRENT LOOP INTERFACE

| Pin<br>NO. | SIGNAL<br>NAME | MEANING             | In/Out        | JA No.            |
|------------|----------------|---------------------|---------------|-------------------|
| 24         | LOUT+          | CURRENT LOOP OUT(+) | IN <b>*1</b>  | J24               |
| 25         | LOUT-          | CURRENT LOOP OUT(-) | IN            | J25               |
| 17         | LIN+           | CURRENT LOOP IN(+)  | OUT <b>*2</b> | J17               |
| 18         | LIN-           | CURRENT LOOP IN(-)  | OUT           | J18/220 <b>*3</b> |
| 15         | RSTP+          | READER STEP(+)      | OUT <b>*2</b> | J15               |
| 16         | RSTP-          | READER STEP(-)      | OUT           | J16 <b>*4</b>     |

Table 4-C.3. Current Loop Interface Pin Designation (Term/Host/Aux)

- \*1 Current source pin used for current loop input signals, -12V pull-down.
- \*2 Current source pin used for current loop input signals, +12V pull-up.
- \*3 Jumpers JA and JB18 are connected with a current limiting resistance of 220 ohms-1/4W -or- the resistance is altered to suit the associated circuit.
- \*4 Jumpers JA and JB18 are connected with a current limiting resistance of 47 ohms-1/4W.

With a current loop interface, the HOST/AUX port is used only at the DCE setting (DCE/DTE select switch).

The baud rates over the current loop interface must NOT exceed 600bps.



Figure 4-C.4. CLI Standard Jumper Settings

# TTL INTERFACE (TERMINAL)

| Pin<br>NO.                         | SIGNAL<br>NAME                                  | MEANING                                                                                                | In/Out                        | JA No.                                              |
|------------------------------------|-------------------------------------------------|--------------------------------------------------------------------------------------------------------|-------------------------------|-----------------------------------------------------|
| 1<br>2<br>3<br>19<br>13<br>16<br>7 | FG<br>SD<br>RD<br>BUSY<br>BUSYOUT<br>RSTP<br>SG | FRAME GROUND<br>SEND DATA<br>RECEIVE DATA<br>BUSY INPUT<br>BUSY OUTPUT<br>READER STEP<br>SIGNAL GROUND | IN<br>OUT<br>IN<br>OUT<br>OUT | SN 7438 <b>*2</b><br>J19<br>J13, 6 <b>*1</b><br>J16 |

Table 4–C.4. TTL Interface Pin Designation (Terminal)

- \*1 The BUSYOUT signal becomes a TTL level signal when JA6 and JA13 (pins 8 & 9) are joined together and then connected to JA13.
- \*2 The Terminal line driver contains an SN7438N. JA4 is connected with a jumper plug to supply +5V to SN7438N. JA3 and 5 must NOT be jumped.

CAUTION: JA20 MAY NOT BE CONNECTED WHERE JA19 IS CONNECTED.

# TTL INTERFACE (HOST/AUX)

| Pin<br>NO.                         | SIGNAL<br>NAME                                  | MEANING                                                                                                | In/Out                                       | JA No.                                              |
|------------------------------------|-------------------------------------------------|--------------------------------------------------------------------------------------------------------|----------------------------------------------|-----------------------------------------------------|
| 1<br>2<br>3<br>19<br>13<br>16<br>7 | FG<br>SD<br>RD<br>BUSY<br>BUSYOUT<br>RSTP<br>SG | FRAME GROUND<br>SEND DATA<br>RECEIVE DATA<br>BUSY INPUT<br>BUSY OUTPUT<br>READER STEP<br>SIGNAL GROUND | *1<br>OUT(IN)<br>IN(OUT)<br>IN<br>OUT<br>OUT | SN 7438 <b>*3</b><br>J19<br>J13, 6 <b>*2</b><br>J16 |

Table 4-C.5. TTL Interface Pin Designation (Host/Aux)

- \*1 When the DCE/DTE switch is set to DCE, signals are routed in the directions indicated in ().
- \*2 The BUSYOUT signal becomes a TTL signal when JB6 and JB 13 (pins 8 & 9) are connected, then outputs to the pin when JB13 is connected.
- \*3 The HOST/AUX line driver contains SN7438N. JB4 is connected with a jumper plug to supply +5V to SN7438N. JB3 and 5 must NOT be connected together.

CAUTION: JB20 MAY NOT BE CONNECTED WHERE JB19 IS CONNECTED.



Figure 4–C.5. TTL Standard Jumper Settings

#### SERIAL INTERFACE CONTROL SIGNAL TIMING

XON and XOFF Protocol

When the host computer or terminal cannot receive data sent from the ICD because of a high baud rate, the data from the ICD may be controlled with XON and XOFF.

XOFF ... DC3 (CTR-S: 12HO)

XON ... DC1 (CTR-Q: 10H)

The host computer or terminal sends XOFF to the ICD before the reception buffer overruns. After sending XOFF, the host computer/terminal sends XON to the ICD if the reception buffer is ready.

The ICD stops transmitting data when it receives XOFF and ignores any incoming code other than XON thereafter. The ICD then resumes data transmission after receiving XON.

BUSY and DTR Inputs

The ICD can stop data transmission if a BUSY signal is detected from a low-speed terminal. Normally, the terminal sets the BUSY signal to L, from the leading edge of the receive data (RD) starting bit to the completion of data processing. The ICD suspends its data transmission to the terminal as long as the BUSY signal is at L (Figure 4-C.6).



Figure 4-C.6. BUSY and DTR Input Signal Diagram

#### BUSYOUT and DSR Outputs

When the host computer system sends data at a higher rate of speed than that of the internal ICD monitor processor, the BUSYOUT signal of the ICD must be monitored. The ICD sets the BUSYOUT signal to L until the ICD monitor reads transmitted data (SD) from the host system. During this time, the host computer waits for data transmission to the ICD (Figure 4-C.7).



Figure 4-C.7. BUSYOUT and DSR Output Signal Diagram

RSTP Output

The ICD can transmit a RSTP signal to terminals that require a step signal on each data transmission. The ICD sets RSTP to L when data reading is requested. It then returns RSTP to H upon detection of the start bit in the transmitted data (SD) from the terminals being set (Figure 4-C.8).



Figure 4-C.8. RSTP Output Signal Diagram







Figure 4-C.10. S-771 SIO Interface Circuit Diagram (Host/Aux)

.

THIS PAGE INTENTIONALLY BLANK

## D ICD PROGRAM MEMORY

The ICD incorporates 64K-bytes of high speed RAM for target programs as emulation memory (Figure 4-D.1). This memory is referred to as ICD program memory (or emulation memory), in relation to user memory (target system memory).

The ICD program memory consists of high-speed static RAM, enabling support of multi-speed target systems. Also, ICD program memory differs from the usual program memory area in that it is contained within the Z80 processor, and not on a separate module. The address/data/control bus pins must assume three states during a BUSAK cycle. This prohibits DMA transfer between the target system and ICD program memory, however, DMA transfer within addressed spaces is permitted.





#### USER MEMORY

User memory is memory that is installed in the target system as opposed to ICD program memory. The ICD-278 will address up to 64K bytes of target system memory (user memory).

The access time required to write to the target system memory from the ICD-278 is the same as the processors, however, the access time needed to read from the target system memory is slightly shorter than that available with the processor. Therefore, certain access time conditions must be met. These are shown in Figure 4-D.2.





#### MEMORY MAPPING

When target system emulation is in progress during in-circuit mode I1, it is possible to specify either user memory or ICD program memory in 1K bytes (Figure 4-D.3). This specification is met using the "Map" command.

When using the ICD program memory, RW (read/write) and RO (read/only) areas can be specified in 1K-byte increments. Also, the NO (non-memory) status can also be specified on the emulation CPU memory map.

See Figure 4-D.3 for application of the following 'Memory Area' references;

- READ ONLY : Specifies that the ICD program memory can be (RO) used in place of the target system ROM. It is NOT permitted to Write into this memory area. The "Break" command may be used to force a break if writing in this area is attempted during an emulation break. The WAIT signal from the target system is ignored when this memory area is accessed.
- USER (US) : Specifies to use the memory mounted in the target system. The WAIT signal from the target system is ignored when this memory is accessed.
- NON (NO) : This specifies to use memory not mounted in the memory map. Read/Write is not possible with this memory during emulation. If access to this memory area is attempted, a break will occur.

4D-3



Figure 4–D.3. Mapping Configuration

# E CPU EMULATION





#### ICD PROGRAM MEMORY CYCLE

The ICD program memory read/write cycles do not access memory in the target system while memory mapping or during an emulation break. During the ICD program memory cycle, the MREQ-WR output signal is prohibited and therefore the memory area in the target system is unaccessible. Furthermore, the MREQ output signal which occurs during the ICD program memory write cycle is prohibited.

The data bus is specified both in the ICD program memory read and write cycles. The data then read from or written into the ICD program memory outputs to the target system.

In conventional Z80 systems, the output of the RD signal cannot be disabled because of the following:

- 1) The appearance of M1 without RD and MREQ causes the Z80 peripheral LSIs (mainly Z80 PIO) to reset.
- 2) Since the "RETI" instruction is detected by the Z80, peripheral LSIs such as PIO, CTC, SIO, DMA. Therfore, M1, RD, and D0 thru D7 signals must be present at the peripheral chip. If they are not available at the peripheral, the interrupt operation cannot be performed.

For application with any target system, the ICD uses the Emulation Select switch (or emulation method select switch) to specify the operation on the ICD program memory read cycle. Two settings are available;

 During the ICD program memory read cycle, the RD signal output is inhibited by setting the Emulation Select switch as follows:

Bit 3 = ON Bit 3 = OFF

2) During the ICD program memory read cycle, D0 thru D7 are made tristate by setting the Emulation Select switch to Bit 1 = OFF

4E-2

**Z80 MACHINE CYCLE** 







Memory Read or Write Cycle

# Input or Output Cycles











#### CLOCK SWITCH

The CLOCK switch specifies the use of the ICD Internal Clock (4MHz) or the External Target Clock.

Internal Clock

The ICD Internal clock is specified by CLOCK=INT.

The internal clock runs at a speed of 4 MHz with a 50% duty cycle. The frequency may be changed to either 2 MHz or 4 MHz by utilizing the jumpers CX, H, and L provided on the S-793 board (Figure 4-E.3).

NOTE: The internal clock is used by the microprocessor only, it cannot be used by the target system.



Figure 4–E.2. Clock Configuration

| n fa san dan kan kan kan kan kan kan kan kan kan k | an yan san yan yan yan yan yan yan yan yan yan y | gen gen en e |
|----------------------------------------------------|--------------------------------------------------|-----------------------------------------------|
|                                                    | 4 MHz                                            | 2 MHz                                         |
|                                                    | H CX L                                           | O O O O O O O O O O O O O O O O O O O         |
|                                                    | (Setup at shipment)                              | · · · · · · · · · · · · · · · · · · ·         |
|                                                    | •                                                |                                               |

Figure 4-E.3. Setting of Internal Clock

#### External Clock

The External clock is specified by CLOCK=EXT.

If the external clock is used, it is possible for the target system peripheral LSI and the emulation CPU to be operated simultaneously.

NOTE: To insure accurate operation of the emulation CPU, 50% duty cycle is required for high speed clocks equal to or greater than 2.5 MHz.

The Z80 CPU requires the "H" level of the target clock to be in access of Vcc-0.6V. If a glitch equal to or higher than 0.45V at a "L" level of the target clock appears, the M1-RD signal of the processor occurs by a glitch of the clock. If this takes place during emulation, the ICD break will have no effect. Recovery to the normal state is achieved by resetting the target system using the RESET switch.

NOTE: If this condition occurs frequently, the drive capacity of the clock driver (target system) must be improved by increasing drive levels.

### **RESET SWITCH**

The RESET switch on the ICD Operator Panel resets the ICD only, it does NOT reset the target system. The reset switch is effective when the emulation CPU is in a break status. Target system breaks are activated using the MONITOR switch. The target system, in most cases, will have a manual reset switch that resets the entire system.

When the emulation CPU runs the target system, a manual reset of the target system causes a hardware reset of the emulation CPU or the registers in the CPU. If the emulation CPU is in an emulation break, resetting the target system will NOT cause a hardware reset of the emulation CPU. The CPU register must be reset by the "Register RES" command of the ICD monitor.





#### MONITOR SWITCH (Interrupt Signal)

The MONITOR switch places the emulation CPU (executing the target system) in an emulation break status. This switch causes a monitor NMI interrupt which is assigned a higher priority than the target NMI. The "Break" command also causes the monitor NMI to occur.

If an emulation break occurs between NMI and the execution of the "RETN," "LD A,I" or "LD A,R" command, the pre-NMI state cannot be guaranteed if IFF2 is seen from the target program. This problem is corrected with the "Register" command.

The NMI interrupt signal is masked when the emulation CPU is in an emulation break. However, during an emulation break the NMI from the target system is latched by an edgetrigger circuit. Thus, if an NMI interrupt occurs during an emulation break, an interrupt sequence is generated at the transition from the ICD monitor run to the target system run.

The INT interrupt signal is masked when the emulation CPU is in an emulation break. The target interrupt signals, INT and NMI, can perform enable and disable operations respectively using the "Pin" command.





### **BUS CONTROL**

The ICD can accept the BUSRQ signal any time the in-circuit mode is I1/I2. Therefore, DMA operation may be performed during an emulation break even if the target system is executing an break.

The BUSRQ signal from the target system is enabled and disabled by using the "Pin" command. This operation allows emulation regardless of the BUSRQ signal state.

The WAIT signal is effective when the target memory or I/O is accessed. The WAIT signal will generate two wait states (optional one or three) per memory cycle are automatically generated by setting the Emulation Select switch bit 4 = ON (see Technical References; A-Emulation Select switch).

This action allows the target system to operate at a higher clock speed and permits emulation even when the access time of the system or the setup time of WAIT is short.

If the WAIT signal is in a wait state for equal to or longer than 128 clocks, the access occurs as a break time-out. This condition is set using the "Break" command of the ICD monitor. The setting of a WAIT time-out introduces a break during emulation.



Figure 4-E.6. BUSRQ Signal Configuration

#### **REFRESH SIGNAL**

The RFSH signal outputs to the target system in any of the I1, I2 or I3 in-circuit modes. The MREQ signal for refresh is then synchronized with the RFSH signal independent of the in-circuit mode or mapping. This procedure allows refresh timing of the target system D-RAM to be synchronized with the CPU.



Figure 4-E.7. REFRESH Signal Configuration

# Table 4-E.1. ICD-278 SIGNAL TIMING

| Signal            | Symbol                                                                                                                                                                                       | Parameter                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Z ·                          | - 80                     | Z -                        | 80 A                 | 0A Z                       |                      | íor                        | 278<br>Z 80          | Uni                              |
|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------|--------------------------|----------------------------|----------------------|----------------------------|----------------------|----------------------------|----------------------|----------------------------------|
| 5                 |                                                                                                                                                                                              | Mi                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                              | Max                      | Min.                       | Max                  | Min.                       | Max.                 | Min.                       | Max.                 |                                  |
| ø                 | <sup>t</sup> c<br><sup>t</sup> w(øH)<br><sup>t</sup> w(øL)<br><sup>t</sup> r,f                                                                                                               | Check Period<br>Check Pulse Width, Clock High<br>Clock Pulse Width, Clock Low<br>Clock Rise and Fall Tims                                                                                                                                                                                                                                                                                                                                                   | 4<br>180<br>180              | 30<br>2000<br>30         | 25<br>110<br>110           | 2000<br>30           | 165<br>65<br>65            | 2000<br>20           | 165<br>65<br>65            | 2000<br>20           | μse<br>ns<br>ns                  |
| A <sub>0-15</sub> | <sup>t</sup> d (AD)<br><sup>t</sup> F(AD)<br><sup>t</sup> acm<br><sup>t</sup> aci<br><sup>t</sup> ca                                                                                         | Address Output Delay<br>Delay to Float<br>Address Stable Prior to MREQ (Memory Cycle)<br>Address Stable Prior to IORQ (IO Cycle)<br>Address Stable from RD, WR, IORQ or MREQ                                                                                                                                                                                                                                                                                | 125<br>320<br>160            | 145<br>1 10              | 65<br>180<br>80            | 1 10<br>90           | 35<br>100<br>35            | 90<br>80             | 35<br>110<br>35            | 105<br>120           | ns<br>ns<br>ns<br>ns             |
| D <sub>0-7</sub>  | <sup>t</sup> D(D)<br><sup>t</sup> F(D)<br><sup>t</sup> S¢(D)<br><sup>t</sup> S¢(D)<br><sup>t</sup> dcm<br><sup>t</sup> dci<br><sup>t</sup> cdi                                               | Data Output Delay<br>Delay Float During Write Cycle<br>Data Setup Time to Rsing Edge of Clock During M Cycle<br>Data Setup Time to Falling Edge of Clock During M 2 to M 5<br>Data Stable Prior to $\overline{WR}$ (Memory Cycle)<br>Data Stable Prior to $\overline{WR}$ (I/O Cycle)<br>Data Stable From $\overline{WR}$                                                                                                                                   | 50<br>60<br>190<br>20<br>120 | 230<br>90                | 35<br>50<br>80<br>10<br>60 | 150<br>90            | 30<br>40<br>25<br>55<br>30 | 130<br>80            | 45<br>55<br>25<br>55<br>30 | 145<br>120           | ns<br>ns<br>ns<br>ns<br>ns<br>ns |
|                   | ۱H                                                                                                                                                                                           | Any Hold Time for Setup Time                                                                                                                                                                                                                                                                                                                                                                                                                                | 0                            |                          |                            | 0                    |                            | 0                    |                            | 0                    | ns                               |
| MREQ              | <sup>t</sup> DL <del></del> $\phi$ (MR)<br><sup>t</sup> DH $\phi$ (MR)<br><sup>t</sup> DH $\phi$ (MR)<br><sup>t</sup> W( <u>MRL</u> )<br><sup>t</sup> w( <u>MRL</u> )<br><sup>t</sup> w(MRH) | MREQ         Delay         From         Falling         Edge of         Clock,         MREQ         Low           MREQ         Delay         From         Rising         Edge of         Clock,         MREQ         High           MREQ         Delay         From         Falling         Edge of         Clock,         MREQ         High           Pulse         Width,         MREQ         Low         Pulse         Width,         MREQ         High | 360<br>170                   | 100<br>100<br>100        | 220<br>1 10                | 85<br>85<br>85       | 135<br>65                  | 70<br>70<br>70       | 135<br>65                  | 85<br>85<br>85       | ns<br>ns<br>ns<br>ns<br>ns       |
| IORQ              | <sup>1</sup> DL¢(IR)<br><sup>1</sup> DL¢(IR)<br><sup>1</sup> DH¢(IR)<br><sup>1</sup> DH¢(IR)                                                                                                 | IORQ Delay From Falling Edge of Clock, IORQ Low<br>IORQ Delay From Rising Edge of Clock, IORQ High                                                                                                                                                                                                                                                                                                                                                          |                              | 90<br>110<br>100<br>110  |                            | 75<br>85<br>85<br>85 |                            | 65<br>70<br>70<br>70 |                            | 80<br>85<br>85<br>85 | ns<br>ns<br>ns<br>ns             |
| RD                | <sup>1</sup> DLø(RD)<br><sup>1</sup> DLø(RD)<br><sup>1</sup> DHø(RD)<br><sup>1</sup> DHø(RD)                                                                                                 | RD Delay From Rising Edge of Clock, RD High                                                                                                                                                                                                                                                                                                                                                                                                                 |                              | 100<br>130<br>100<br>110 |                            | 85<br>95<br>85<br>85 |                            | 70<br>80<br>70<br>70 |                            | 85<br>95<br>85<br>85 | ns<br>ns<br>ns<br>ns             |
| WR                | <sup>1</sup> DL¢(WR)<br><sup>1</sup> DLð(WR)<br><sup>1</sup> DHð(WR)<br><sup>1</sup> w(WRL)                                                                                                  | $\overline{WR}$ Delay From Falling Edge of Clock, $\overline{WR}$ Low                                                                                                                                                                                                                                                                                                                                                                                       | 360                          | 80<br>90<br>100          | 220                        | 65<br>80<br>80       | 135                        | 60<br>70<br>70       | 135                        | 75<br>85<br>85       | ns<br>ns<br>ns<br>ns             |
| MI                | 'DL(M1)<br>'DH(M1)                                                                                                                                                                           | MI Delay From Rising Edge of Clock, MI Low<br>MI Delay From Rising Edge of Clock, MI High                                                                                                                                                                                                                                                                                                                                                                   |                              | 130<br>130               |                            | 100<br>100           |                            | 80<br>80             |                            | 95<br>95             | ns<br>ns                         |
| RFSH              | <sup>t</sup> DL(RF)<br><sup>t</sup> DH(RF)                                                                                                                                                   | RFSH Delay From Rising Edge of Clock, RFSH Low<br>RFSH Delay From Rising Edge of Clock, RFSH High                                                                                                                                                                                                                                                                                                                                                           |                              | 180<br>150               |                            | 130<br>120           |                            | 110<br>100           |                            | 125<br>115           | ns<br>ns                         |
| WAIT              | <sup>t</sup> s(WT)                                                                                                                                                                           | WAIT Setup Time to Falling Edge of Clock                                                                                                                                                                                                                                                                                                                                                                                                                    | 70                           |                          | 70                         |                      | 60                         |                      | 80                         |                      | ns                               |
| HALT              | 'D(HT)                                                                                                                                                                                       | HALT Delay Time From Falling Edge of Clock                                                                                                                                                                                                                                                                                                                                                                                                                  |                              | 300                      |                            | 300                  |                            | 260                  |                            | 275                  | ns                               |
| ĪNT               | <sup>t</sup> s(IT)                                                                                                                                                                           | INT Setup Time to Rising Edge of Clock                                                                                                                                                                                                                                                                                                                                                                                                                      | 80                           |                          | 80                         |                      | 70                         |                      | 100                        |                      | ns                               |
| NMI               | w (NML)                                                                                                                                                                                      | Pulse Width, NMI Low                                                                                                                                                                                                                                                                                                                                                                                                                                        | 80                           |                          | 80                         |                      | 70                         |                      | 30                         |                      | ns                               |
| BUSRQ             | <sup>t</sup> s(BQ)                                                                                                                                                                           | BUSRQ Setup Time to Rising Edge of Clock                                                                                                                                                                                                                                                                                                                                                                                                                    | 80                           |                          | 50                         |                      | 50                         |                      | 65                         |                      | ns                               |
| BUSAK             | <sup>t</sup> DL(BA)<br><sup>t</sup> DH(BA)                                                                                                                                                   | BUSAK Delay From Rising Edge of Clock, BUSAK Low<br>BUSAK Delay From Falling Edge of Clock, BUSAK High                                                                                                                                                                                                                                                                                                                                                      |                              | 120<br>110               |                            | 100<br>100           |                            | 90<br>90             |                            | 105<br>105           | ns<br>ns                         |
| RESET             | <sup>i</sup> s(RS)                                                                                                                                                                           | RESFT Setup Time to Rising Edge of Clock                                                                                                                                                                                                                                                                                                                                                                                                                    | 90                           |                          | 60                         |                      | 60                         |                      | 75                         |                      | ns                               |
|                   | <sup>t</sup> F(C)                                                                                                                                                                            | Delay to Float $(\overline{MREQ}, \overline{IORQ}, \overline{RD} \text{ and } \overline{WR})$                                                                                                                                                                                                                                                                                                                                                               |                              | 100                      |                            | 80                   |                            | 70                   |                            | 120                  | ns                               |
|                   | <sup>t</sup> mt                                                                                                                                                                              | MI Stable Prior to IORQ (Interrupt Ack.)                                                                                                                                                                                                                                                                                                                                                                                                                    | 920                          |                          | 565                        |                      | 365                        |                      | 365                        |                      | ns                               |

4E-11

#### THIS PAGE INTENTIONALLY BLANK



#### EVENT TRIGGER PROBE

The Event trigger probe detects a LOW pulse (TTL) signal when an event point is passed during the emulation process.

The duration of the pulse is 250ns (minimum) from the moment at which the RD/WR rises in a cycle with matching event conditions - to the point at which the RD/WR signal in the next cycle rises. A LOW pulse synchronized with the RD/WR signal outputs if "Don't care" has been specified as an event condition.



## Figure 4-F.1. Event Trigger Output Timing Diagram

#### EMULATION QUALIFY OUTPUT

The Emulation Qualify probe determines the status of ICD emulation. The HIGH level (TTL) signal is sent from the point at which the target program is executed (with the "GO" command) to the breakpoint. Unwanted signals can be cut by connecting the Emulation Qualify output to the enable or qualify input of a logic analyzer or similar device.





#### MAP CONTROL PROBE

The Map Control probe enables the user memory to be used over the entire memory area (64K bytes) when a TTL signal is received by the MAP CTL. probe (in-circuit mode I1). This input is ignored during an emulation break (Figure 4-F.3).

The Map Control probe must be set to a LOW level (minimum 125ns) before the RD or WR signal is generated (Figure 4-F.3).

The Map Control signal is useful to develop/debug a system which uses phantom ROM (ROM that operates for the system bootstrap procedure and then hides behind the main memory). If a program is executed when mapping the address of the phantom ROM into the ICD program memory, the ICD cannot select the user memory with same address as the phantom ROM. However, it is possible to input the signal of the main memory to the ICD's Map Control. The phantom ROM then uses the ICD program memory and the main memory accesses the user memory with the same address.







Figure 4-F.4. Map Control Timing Diagram

## G CONTROL MODULES

There are five control modules located within the ICD-278 in addition to the power supply. These modules are listed in their order of position starting from the top (Operator Panel) of the ICD;

| PANEL | S-730C | Indicator Panel           |    |
|-------|--------|---------------------------|----|
| *SIO  | S-791B | Serial Interface (C)      |    |
| RTS   | S-795A | Realtime Trace            |    |
| *CPU  | S-793A | Central Processing Unit ( | E) |
| EMU   | S-792A | Emulation Memory Unit     |    |

Note: These modules (\*) are identified and described in detail elsewhere in this section. See the reference letter at the end of these module names for their location in this section or refer to the Table of Contents.

Each module is linked by the Mother Bus cable. Power is supplied to each module by a 5-pin, plug-type power connector cable (except for the S-730C module which uses the 60-pin Mother Bus connector cable).

The modules are attached to the ICD chassis by brackets which are screw-mounted (two or four screws) to secure them in place. Removing any one of the control modules necessitates some disassembly of the ICD (see Disassembly Procedure located at the end of this chapter).



S-730 Indicator Panel



# S-791 Serial Interface Output (SIO)



# S-795 Realtime Trace Storage (RTS)



S-793 Central Processing Unit (CPU)



## S-792 Emulation Memory Unit (EMU)

### ICD DISASSEMBLY / MODULE REMOVAL

WARNING: HAZARDOUS VOLTAGE IS PRESENT WITHIN THE ICD-278. DISCONNECT THE AC POWER PLUG BEFORE BEGINNING ANY INTERNAL WORK ON THE ICD-278.

Disassembly Procedure

 Begin disassembly by inverting the ICD-278, placing the Operator Panel side; down. Access to the bottom panel is now possible.

NOTE: Place the ICD-278 on a soft foam-type pad to protect the case and components.

Remove the four large screws that hold the bottom panel to the chassis but do not detach the panel. Remove the four counter-sunk screws at each end (eight total) that hold the side panels in place.

2) Gently turn over the ICD-278, placing the Operator Panel side; up. Remove the two round-head screws at each end (four total) that join the top and side panels. Detach the side panels and the top panel.

The control modules are now accessible for removal.

3) IMPORTANT: Note the position of the power connectors before removing. Both the socket and plug have a blackcolored identification label for proper positioning during reconnection.

Free the power cable by disconnecting its five-pin socket (CN4) from the module then detach the mother bus cable from its location on the module (CN1).

4) Remove the screws which hold the module to the chassis:

A) The top and bottom (S-730C and S-795A) modules are mounted directly to the chassis with four and six screws respectively. Remove these screws to detach the modules.

B) The three remaining modules (S-791A, S-793A and S-792A) are connected to brackets which screw mount to the ICD chassis at one end and slide into holders at the other end. To detach these modules, remove the screws and then carefully slide the modules away from the chassis.

## Module Installation

Installation is the reverse of removal.

CAUTION: DO NOT REVERSE POWER CONNECTOR POSITION DURING INSTALLATION. CONNECTOR MISPLACEMENT WILL CAUSE DAMAGE TO THE ICD-278.

NOTE: When replacing the side panels, position all the screws in place loosely to allow the panels to align properly before tightening.

## **PART II**

## SOFTWARE SPECIFICATION GUIDE

### INTRODUCTION

Part II of this Operation Manual contains software information for the ICD-278. This information relates to the various software commands (including the Z commands) as well as the necessary protocol for communication with a host computer system.

A detailed analysis of the user commands is explained in Section V; Software Commands. Emulator handshaking with the host computer is described in Section VI; Host Computer System Communication.

Before beginning communication with the host computer, select and construct the proper system configuration (REMOTE or LOCAL: standalone with host computer). The two system configurations are detailed in Section III; System Configuration and Start-up Sequence, and reprinted in Section VI for convenience.

| PART II S | OFTWARE | SPECIFICATION | GUIDE | Page |
|-----------|---------|---------------|-------|------|
|-----------|---------|---------------|-------|------|

Section V Software Commands

| Load        | 5-5  |
|-------------|------|
| Save        | 5-6  |
| Verify      | 5-7  |
| Quit        | 5-8  |
| Z Log       | 5-8  |
| Z Batch     | 5-8  |
| Z Comment   |      |
| Z Wait      | 5-9  |
| Z Directory | 5-10 |
| Z Help      |      |
| Z Repeat    |      |
| Z Print     |      |
|             |      |

Section VI Host Computer System Communication

| Idle Program            | 6-4  |
|-------------------------|------|
| Display Text            | 6-6  |
| Command Input Request   | 6-8  |
| Object File Load/Verify | 6-10 |
| Object File Save        | 6-12 |
| Z Command               | 6-14 |
| Quit                    | 6-17 |
| Display Symbolic Text   |      |
| Console Key Check       | 6-20 |

11

#### THIS PAGE INTENTIONALLY BLANK

SECTION V SOFTWARE COMMANDS

### INTRODUCTION

This section explains the use of the ZICE utility software commands. The ZICE commands are used to interface the ICD-278 to other microprocessors and microcomputers for testing programs under development. Additionally, the ZICE utility supports four user commands; Load, Save, Verify and Quit. These four commands, including address parameters and application notes, are described in detail in Part III: COMMAND REFERENCE GUIDE.

## ZICE KEYWORDS

The following user-supplied keywords are used with the ZICE commands;

portspec :specifies input/output port to consider, either;

T (Terminal port/ignore software handshake)
P (Terminal port/perform handshake)
A (Auxiliary port)
H (Host port)

filename :name of the operation file.

- bias :hexadecimal (16-bit, 0-F) address that is added to start address of each program or data address.
- message :input data, ASCII 32 or hexadecimal.

beg.addr :beginning address, physical 16-bit.

end addr :ending address, physical 16-bit or L byte.

- user addr :starting address of user program, physical 16bit or hexadecimal 16-bit address.
- obj.name :file name, all standard CPM files are available (hex, assembly, etc.)
- display :used with the Directory command, specifies the type of directory display.
- range :an integer number used with the Repeat command.
- name :the name of a specific command; Go, Map, etc.
- nth-name :the last command name to be used during the repeat process.

comment :a displayed user supplied comment or statement.

## ZICE FORMAT

Note the following format when entering the ZICE commands.

\*Keywords/key characters are displayed as; C / 9 etc, or as BOLD characters. They represent words/letters/ characters which must be entered. Any combination of upper/lower case letters may be used.

- \*Lowercase italicized letters show items which the user must supply, such as "filename" in which the user would enter the name of a selected file.
- \*A vertical line "|" is shown to indicate a choice between separated information which must be selected, such as;

ON OFF

ON or OFF may be entered, but not both.

\*Include all punctuation such as commas, equal signs, colons, slashes, feature keys. Etc.

\*Available address/data parameters are given at the end of the explanations and grouped as; [phy 16, L byte, ASCII 32, etc].

Example: REPEAT (R) command;



## THIS PAGE INTENTIONALLY BLANK

.

THE LOAD COMMAND IS USED TO LOAD A HEXADECIMAL FILE ONTO A DISKETTE OR THE OBJECT PROGRAM (INTEL FORMAT), FROM EITHER SPECIFIED PORT IN MEMORY.

/ portspec filename 🤉 bias 🤉 message <-L

portspec - PORT SPECIFICATION;

| Т | :TERMINAL PORT (IGNORE SOFTWARE HANDSHAKE).  |
|---|----------------------------------------------|
| Ρ | :Terminal port (perform software handshake). |
| Α | :AUXILIARY PORT (IGNORE SOFTWARE HANDSHAKE). |
| н | :HOST PORT (PERFORM SOFTWARE HANDSHAKE).     |

filename :NAME OF THE FILE TO LOADED.

| bias | BIAS OF THE OBJECT TO BE LOADED LL BYTE |  |
|------|-----------------------------------------|--|
|      | (DEFAULT = OBJECT STARTING ADDRESS).    |  |

message :LOAD MESSAGE [ASCII 32, HEX DATA].

EXAMPLE - LOAD FILE PROG3.HEX FROM DRIVE B OF THE BOX;

L B:PROG3.HEX (cr)

THE SAVE COMMAND IS USED TO CREATE A USER PROGRAM ON A DISKETTE AS THE HEX FILE -OR- DUMP THE USER PROGRAM TO A SPECIFIED PORT USING THE INTEL FORMAT.

| S A / portspec | filename <b>9</b> beg.addr | 9 end | addr 9 user | addr 9 message | <b>\</b> |
|----------------|----------------------------|-------|-------------|----------------|----------|
|                |                            |       |             |                |          |

portspec - PORT SPECIFICATION;

| Т | :Terminal port (ignore software handshake)  |
|---|---------------------------------------------|
| Ρ | :Terminal port (perform software handshake) |
| Α | :AUXILIARY PORT (IGNORE SOFTWARE HANDSHAKE) |
| Н | :HOST PORT (PERFORM SOFTWARE HANDSHAKE)     |

filename :NAME OF FILE TO CREATE.

| beg.addr  | BEGINNING MEMORY ADDRESS [PHY 16].                                              |
|-----------|---------------------------------------------------------------------------------|
| end addr  | ENDING MEMORY ADDRESS [PHY 16].<br>BEGINNING USER PROGRAM ADDRESS [PHY 16,HEX]. |
| user addr |                                                                                 |
| message   | SAVE MESSAGE [ASCII 32, HEX DATA].                                              |

EXAMPLE - GENERATE THE TEST. HEX FILE ON DISKETTE;

>SA TEST,Ø,37FF,Ø

THE VERIFY COMMAND IS USED TO COMPARE A HOST COMPUTER FILE OR OBJECT PROGRAM (INTEL FORMAT) WITH THE CONTENTS IN MEMORY.

| V | / | portspec | 9 | obj.name | 9 | bias | 9 | message | + |
|---|---|----------|---|----------|---|------|---|---------|---|
|---|---|----------|---|----------|---|------|---|---------|---|

portspec - PORT SPECIFICATION;

| Т | :Terminal port (Ignore software handshake)  |
|---|---------------------------------------------|
| Ρ | :Terminal port (perform software handshake) |
| Α | :AUXILIARY PORT (IGNORE SOFTWARE HANDSHAKE) |
| Н | :Host port (perform software handshake)     |

obj.name :OBJECT NAME TO COMPARE.

| bias | - | :BIAS OF THE FILE OR OBJECT TO COMPARE<br>(DEFAULT = OBJECT STARTING ADDRESS). |
|------|---|--------------------------------------------------------------------------------|
|      |   | (DEFAULT = OBJECT STARTING ADDRESS).                                           |

message :VERIFY MESSAGE [ASCII 32, HEX DATA].

EXAMPLE - COMPARE XASM WITH MEMORY;

V XASM,(cr)

| · ADRS | Μ  | 0  |
|--------|----|----|
| 020F   | 0B | 67 |
| 105C   | 78 | 00 |
| 105D   | B7 | 00 |
| 0100   |    |    |

THE LOG SUBCOMMAND ECHOES THE CONSOLE OUTPUT TO A DISK FILE (ON) OR TURNS OFF THE ECHO FEATURE (OFF).

# Z L ON OFF <--

THE BATCH SUBCOMMAND IS USED TO LOAD AND EXECUTE A FILE CONTAINING ZICE COMMANDS WHICH WERE PREVIOUSLY CREATED USING THE EDITOR. THE COMMANDS ARE EXECUTED IN THE ORDER IN WHICH THEY APPEAR IN THE TEXT FILE. A CTRL-C INTERRUPTS THE COMMAND SEQUENCE DURING THE EXECUTION OF A BATCH COM-MAND FILE.



filename

SPECIFIES THE FILE NAME

THE QUIT COMMAND IS USED TO TERMINATE THE ICD-278 EMULATOR AND RETURN CONTROL BACK TO THE HOST COMPUTER SYSTEM.



THE COMMENT SUBCOMMAND IS USED TO OUTPUT COMMENTS DURING A SUBCOMMAND PROCESS.



comment

COMMENT STRING WHICH APPEARS ON THE CONSOLE DURING THE EXECUTION OF THE BATCH OR REPEAT PROCESS.

EXAMPLE;

Z C, \*\*\* FD TEST START \*\*\* L FDTEST G O, FF Z C, \*\*\* MEMORY TEST START \*\*\* L MENTEST

THE WAIT SUBCOMMAND IS USED TO PLACE A TEMPORARY PAUSE IN A REPEAT OR BATCH SUBCOMMAND PROCESS. THE EXECUTION IS THEN HALTED UNTIL THE 'SPACE' BAR IS PRESSED - RESTARTING THE PROCESS.

Z W 9 comment <-

comment

FIELD TO BE USED FOR DOCUMENTATION OF A WAIT COMMAND.

#### EXAMPLE;

Z R, 10/G X, X/D X, X/Z W(cr)

REPEAT PROCESS TEN TIMES EXECUTE INSTRUCTION DISPLAY RESULTS WAIT FOR OPERATOR RESPONSE THE DIRECTORY SUBCOMMAND IS USED TO DISPLAY A DISKETTE DI-RECTORY WHILE USING THE ZICE UTILITY.

display Ζ D

display - SPECIFIES;

.

:DISPLAY THE DIRECTORY OF HEXADECIMAL FILES.

:DISPLAY THE LIST OF ALL .BAT FILES.

:DISPLAY A LIST OF ALL .HEX FILES (DEFAULT PARAMETER).

:DRIVE ON WHICH THE DIRECTORY RESIDES.

THE HELP SUBCOMMAND IS USED TO DISPLAY THE FORMAT OF A COM-MAND BY SPECIFYING A PARTICULAR COMMAND -OR- DISPLAYS THE COMPLETE COMMAND LISTING



name

COMMAND FOR WHICH THE HELP REQUEST IS DIRECTED.

EXAMPLE;

Z H, V (CR)

V 1/0, FILE NAME (CR)

THE REPEAT SUBCOMMAND IS USED TO PROVIDE A METHOD OF REPEAT-ING A COMMAND OR A STRING OF COMMANDS. THIS SUBCOMMAND IS USEFUL WHEN TESTING SUBROUTINES AS SHOWN IN THE EXAMPLE.

Z R 9 range name nth-name

range :THE NUMBER OF TIMES THE STRING OF COMMANDS ARE TO BE REPEATED. THE RANGE OF N IS 1 TO 9999 (DEFAULT IS INFINITE REPETITION).

name :COMMAND NAME TO BE EXECUTED DURING THE REPETITION PROCESS.

*nth-name* :NTH COMMAND NAME TO BE EXECUTED DURING THE REPETITION PROCESS.

#### EXAMPLE;

Z R, 427/G X, X/Z P, ON/D X, X/Z P, OFF/G X, X/ (cr)

REPEAT 427 TIMES EXECUTE INSTRUCTIONS PRINT CONSOLE MESSAGES DISPLAY SUBROUTINE RESULTS TURN OFF PRINTING CONSOLE MESSAGES EXECUTE INSTRUCTION

THE PRINT SUBCOMMAND PROVIDES THE USER WITH A HARDCOPY OF THE COMMAND DIALOG AND DATA DISPLAYED ON THE CONSOLE DURING A ZICE UTILITY SESSION (ON) OR TURNS OFF THE HARDCOPY PRINT FEATURE (OFF) [DEFAULT CONDITION AT INITIALIZATION.



## THIS PAGE INTENTIONALLY BLANK

## **SECTION VI**

## HOST COMPUTER SYSTEM COMMUNICATION

#### INTRODUCTION

This section details the communication protocol to be observed when interacting the ICD-278 with a host computer system. Seven communication sequences are illustrated by protocol diagrams showing program analysis and flowcharts. Additionally, Idle program and Function Analyze program flowcharts are included.

Both Local and Remote mode configurations are examined.

#### LOCAL Mode

The Local (standalone with host computer) mode allows object I/O between the ICD-278 and the host computer system. Once configured, the ICD-278 operation commands are executed through the console terminal. The Local mode enables the user commands; Load, Save, Verify and Quit. Object downloading from the host computer to the ICD-278 maybe accomplished in this mode also.

#### REMOTE Mode

The Remote mode allows file transfer between the ICD-278 and host computer via the support software program of the host computer system. It is also possible to add the batch processing function for batch files and to use symbolic debugging in this mode.

Before data transfer begins, proper ICD system configuration must be selected and constructed. The LOCAL and REMOTE (standalone with host computer) modes are illustrated here (Figure 6-1). A detailed explanation of system configuration and start-up procedure may be found in Section III.

## COMMUNICATION TERMINOLOGY

The communication sequences used in this section are illustrated by protocol diagrams with definitions. The following data communication terminology is used in the diagram explanations;

- SOH Start Of Heading Precedes a block of heading characters which provide auxiliary information, such as routing and priority.
- ACK Acknowledge An acknowledge to indicate the successful reception of a message segment.
- NAK Not Acknowledge An acknowledge to indicate the unsuccessful reception of a message segment.
- STX Start of Text

ETX - End of Text

- TEXT That part of the message which contains the substantive information to be conveyed.
- CR Call Request or Carriage Return



Figure 6-1. System Configuration

## IDLE PROGRAM

IDLE PROGRAM

- 1) THE HOST SYSTEM WAITS FOR AN INPUT FROM THE ICD. THE HOST SYSTEM IS PROVIDED WITH AN INPUT BUFFER FOR INPUT CODES FROM THE ICD.
- 2) THE HOST SYSTEM ENTERS THE CODES RECEIVED FROM THE ICD IN THE INPUT BUFFER.

| IF RECEIVED CODE IS; | HOST SYSTEM EXECUTES; |
|----------------------|-----------------------|
| <cr></cr>            | DISPLAY TEXT PROGRAM  |
|                      |                       |

<SOH>

FUNCTION ANALYZE PROGRAM





## DISPLAY TEXT

THE DISPLAY TEXT SEQUENCE IS USED TO DISPLAY TEXTS, SENT FROM THE ICD, ON THE HOST COMPUTER CONSOLE.

(TEXT) <CR> : TEXT RECORD THIS RECORD IS THE ASCII TEXT SENT TO THE HOST SYSTEM TO BE DISPLAYED ON THE HOST CONSOLE. TEXT RECORDS MAY NOT INCLUDE; <ACK>, <NAK> OR <SOH> CONTROL CODES. THE HOST SYSTEM DISPLAYS A LINE UP TO <CR> WHENEVER THE TEXT RECORD ON THE HOST SYSTEM IS DISPLAYED. AFTER DISPLAYING A LINE OF RECORDS, THE CURSOR MOVES TO THE NEXT LINE.

<ACK>

: DISPLAY END CODE THIS CODE IS SENT TO THE ICD WHEN NO MORE DISPLAY TEXT RECORD EXISTS.

<NAK>

: DISPLAY HALT CODE THIS CODE IS SENT TO THE ICD TO HALT THE TEXT RECORD TRANSMISSION DURING THE DISPLAY OF 'DUMP' 'TRACE' ETC.



### Figure 6-3. Display Text Sequence

DISPLAY TEXT PROGRAM

- 1) THE ICD SENDS LF(TEXT)<CR>LF TO THE HOST SYSTEM WHEN A TEXT IS DISPLAYED.
- 2) IF A TEXT 1 RECORD IS RECEIVED FROM THE ICD, THE HOST SYSTEM DISPLAYS THE TEXT 1 RECORD ON THE HOST SYSTEM CONSOLE.
- 3) THE HOST SYSTEM NOW CHECKS THE INPUT STATE OF THE HOST SYSTEM CONSOLE;
  - A) IF THERE IS NO INPUT FROM THE HOST SYSTEM CONSOLE, THE HOST SYSTEM WILL SEND <ACK> TO THE ICD AND THEN RETURN TO THE IDLE PROGRAM.
  - B) IF THERE IS INPUT FROM THE HOST SYSTEM CONSOLE AND THE INPUT CODE IS <ESC>, THE HOST SYSTEM WILL SEND <NAK> TO THE ICD AND THEN RETURN TO THE IDLE PROGRAM.
  - C) IF THERE IS INPUT FROM THE HOST SYSTEM CONSOLE BUT THE INPUT CODE IS NOT <ESC>, THE HOST SYSTEM WILL SEND <ACK> TO THE ICD AND THEN RETURN TO THE IDLE PROGRAM. IN THIS MODE, ONLY THE <ESC> KEY (DISPLAY HALT) IS EFFECTIVE.



Figure 6-4. Display Text Flowchart

## COMMAND INPUT REQUEST PROGRAM

COMMAND INPUT REQUEST SEQUENCE

(Text)<ack> : Command Request Record This Record is sent when the icd has requested a command from the host system. The command request Record also includes an ascii text to display on the host system console. Command request records May NOT include; <ack>, <nak>, <cr> or <soh> control codes.

IF THE HOST SYSTEM DISPLAYS A TEXT ON THE HOST SYSTEM CONSOLE, THE DATA IN THE INPUT BUFFER (SENT FROM ICD) WILL BE DISPLAYED UNTIL <ACK> IS ISSUED.

THE HOST SYSTEM MAY NOT OUTPUT DATA ON THE HOST SYS-TEM CONSOLE. AFTER THE TEXT IS DISPLAYED, THE CURSOR MUST REMAIN AT THAT POSITION.

(COMMAND)<CR> : COMMAND RECORD THIS RECORD IS A TEXT THAT IS SENT FROM THE HOST SYSTEM TO THE ICD AS A COMMAND. THE COMMAND RECORD MAY NOT BE TERMINATED WITH <CR> - NOR MAY IT INCLUDE ANY CONTROL CODES.

> WHEN THE HOST SYSTEM ENTERS A COMMAND RECORD THROUGH THE HOST SYSTEM CONSOLE, A LINE OF DATA (UP TO <CR>) IS ENTERED WHICH IS DISPLAYED ON THE CONSOLE WITH ECHOBACK. AFTER A LINE OF COMMAND RECORD IS DIS-PLAYED, THE CURSOR IS MOVED TO THE NEXT LINE.



Figure 6-5. Command Input Request Sequence

COMMAND REQUEST PROGRAM

- 1) THE ICD SENDS LF(TEXT)<ACK>LF TO THE HOST SYSTEM IN RESPONSE TO A COMMAND REQUEST.
- 2) IF <ACK> IS RECEIVED FROM THE ICD, THE HOST SYSTEM WILL DISPLAY THE DATA IN THE INPUT BUFFER (SENT FROM THE ICD) ON THE HOST SYSTEM CONSOLE AND THEN WAIT FOR INPUT FROM THE HOST CONSOLE.
- 3) IF A COMMAND 1 RECORD IS INPUT FROM THE HOST SYSTEM CONSOLE, THE HOST SYSTEM WILL SEND THE 1 RECORD OF THE INPUT COMMAND TO THE ICD, AND THEN RETURN TO THE IDLE PROGRAM.



Figure 6-6. Command Request Flowchart

## OBJECT FILE LOAD/VERIFY

· OBJECT FILE LOAD/VERIFY SEQUENCE

THE FOLLOWING IS THE SEQUENCE FOR TRANSMISSION OF THE OBJECT FILE FROM THE HOST COMPUTER SYSTEM IN RESPONSE TO THE LOAD/VERIFY REQUEST FROM THE ICD.

NOTE: DURING OBJECT FILE TRANSMISSION, THE TEXT DISPLAY REQUEST FROM THE ICD OR CONSOLE KEY CHECK SEQUENCE, MAY BE INSERTED.

<soh>"00"(file name)<cr> : Load Request Record

THIS RECORD TRANSMITS TO THE HOST SYSTEM WHENEVER THE ICD LOADS THE OBJECT FILE. IT IS POSSIBLE TO USE THE (FILE NAME) FIELD AS THE USER DEFINITION LOAD MESSAGE.

<soh>"01"(file name)<cr> : Verify Request Record

THIS RECORD TRANSMITS TO THE HOST SYSTEM A VERIFICATION OF THE OBJECT FILE AND MEMORY SENT FROM THE ICD. IT IS POSSIBLE TO USE THE (FILE NAME) FIELD AS THE USER DEF-INITION VERIFY MESSAGE.

(INTEL-HEX 1 RECORD)<CR> : OBJECT FILE RECORD

THIS INTEL-HEX 1 RECORD IS TRANSMITTED TO THE ICD FROM THE HOST SYSTEM. TERMINATION AT THE END OF THE OBJECT FILE RECORD MUST BE SPECIFIED WITH <CR>. ADDITIONALLY, THE CONTROL RECORD MUST NOT ENTER INTO OBJECT FILE CODE.

<ack> : OBJECT FILE REQUEST CODE

THIS CODE IS TRANSMITTED WHEN THE ICD MAKES A REQUEST FOR THE INTEL-HEX 1 RECORD FROM THE HOST SYSTEM.

<NAK> : OBJECT FILE RETRANSMISSION REQUEST CODE

THIS CODE IS TRANSMITTED WHEN THE ICD REQUESTS THE OBJECT FILE TRANSMISSION IN REGARD TO THE HOST SYSTEM. RETRANS-MISSION REQUESTS ARE PRIMARILY FOR MEMORY WRITE-IN ERRORS WHICH OCCUR DURING LOADING. AS A RESULT, THE HOST SYSTEM WILL NOT CARRY OUT THE RETRANSMISSION, BUT WILL TRANSMIT <NAK> TO THE ICD AND HALT THE OBJECT LOAD/VERIFY SEQUENCE.

(TEXT)<CR> : TEXT RECORD

THE TEXT RECORD IS PRIMARILY A VERIFY ERROR MESSAGE WHICH OCCURS DURING VERIFY. HOWEVER, IF THE ICD IS CONFIGURED IN THE LOCAL MODE, NO TEXT RECORDS ARE TRANSMITTED TO THE HOST SYSTEM (SEE TEXT DISPLAY SEQUENCE). <ack> : DISPLAY TERMINATION CODE

· (SEE TEXT DISPLAY SEQUENCE)

<NAK> : LOAD/VERIFY SEQUENCE - HALT INSTRUCTION CODE

IF THE HOST SYSTEM TRANSMITS <NAK> TO THE ICD IN REGARD TO A TEXT RECORD TRANSMISSION, THIS CODE EFFECTS A HALT IN THE LOAD/VERIFY SEQUENCE.

<soh>"09"<cr> : Console Key Input Check Request Code

THE PRIMARY PURPOSE OF THIS CODE IS TO SUSPEND THE VERIFY ERROR MESSAGE DISPLAY -OR- AS THE RESUMPTION OF AN INQUIRY. IN THE ICD LOCAL MODE, THIS REQUEST IS NOT POSSIBLE (SEE CONSOLE KEY CHECK SEQUENCE).

<ack> : Console Code Minus Input

(SEE CONSOLE KEY CHECK SEQUENCE)

<ack> : Console Input Code

ASCII CODE

(SEE CONSOLE KEY CHECK SEQUENCE)

<NAK> : LOAD/VERIFY SEQUENCE HALT INSTRUCTION CODE CONSOLE KEY INPUT CHECK

> HALTS THE OBJECT LOAD/VERIFY SEQUENCE WHEN HOST SYSTEM TRANSMITS <NAK> TO ICD IN REGARD TO A CONSOLE KEY IN-PUT CHECK.

<ETX>

LOAD/VERIFY TERMINATOR CODE

THIS CODE IS TRANSMITTED TO THE ICD AFTER THE HOST SYS-TEM CLOSES A FILE. IT IS USED WHEN A FILE RECORD TRANS-MISSION TO THE ICD CEASES. OBJECT LOAD/VERIFY SEQUENCE IS TERMINATED.

<NAK> : LOAD/VERIFY SEQUENCE - HALT INSTRUCTION CODE

THIS CODE INSTRUCTS THE ICD TO HALT THE OBJECT LOAD/VERIFY SEQUENCE. THE HALT CODE IS USED WHEN THE HOST SYSTEM HAS DETECTED FILE READ ERRORS, ICD AND HANDSHAKE ERRORS, ETC. THE HALT INSTRUCTION CODE MAY BE TRANSMITTED AT ANY TIME.





6-11

# **OBJECT FILE SAVE PROGRAM**

OBJECT FILE SAVE SEQUENCE

THE FOLLOWING IS THE SEQUENCE FOR TRANSMISSION OF THE OBJECT FILE FROM THE HOST COMPUTER SYSTEM IN RESPONSE TO THE SAVE REQUEST FROM THE ICD.

<soh>"02"(file name)<cr> : Save Request Code

THIS RECORD TRANSMITS TO THE HOST SYSTEM WHENEVER THE ICD SAVES A FILE. IT IS POSSIBLE TO USE THE (FILE NAME) FIELD AS THE USER DEFINITION SAVE MESSAGE.

: OBJECT FILE REQUEST CODE <ACK> FILE WRITE

THIS CODE IS TRANSMITTED WHEN THE HOST SYSTEM REQUESTS A HALT IN THE OBJECT SAVE SEQUENCE. THE OBJECT SAVE REQUEST IS USEFUL FOR EITHER A TARGET MEMORY TIMING OUTPUT, OR NON-MEMORY ACCESS. AFTER THE HOST SYSTEM CLOSES THE FILE, <ACK> IS TRANSMITTED AND HALTS THE OBJECT SAVE SEQUENCE.

(INTEL-HEX 1 RECORD)<CR> : OBJECT FILE RECORD

THIS IS AN INTEL-HEX 1 RECORD RECEIVED BY THE ICD.

: FILE TERMINATION CODE <ETX>

> THIS CODE IS TRANSMITTED TO HOST SYSTEM WHEN A FILE RECORD TRANSMISSION IS LOST. AFTER THE HOST SYSTEM CLOSES THE FILE, IT TRANSMITS <ACK> AND TERMINATES THE OBJECT SAVE SEQUENCE.

<NAK>

: SAVE SEQUENCE HALT INSTRUCTION CODE

THIS CODE INSTRUCTS THE ICD TO HALT THE OBJECT SAVE SE-QUENCE. THE HALT CODE IS USED PRIMARILY FOR A TARGET MEM-ORY TIMEOUT OR NON-MEMORY ACCESS. ONCE THE FILE IS CLOSED THE HOST SYSTEM TRANSMITS <ACK>, HALTING THE OBJECT FILE SAVE SEQUENCE.

: FILE CLOSE TERMINATION CODE <ACK>

FILE CLOSE

THIS CODE IS SENT TO THE ICD WHEN A FILE IS ABLE TO BE CLOSED.

<NAK>

: SAVE SEQUENCE HALT INSTRUCTION CODE

HIS CODE INSTRUCTS THE ICD TO HALT THE OBJECT SAVE SE-QUENCE. IT IS USED WHEN THE HOST SYSTEM HAS DETECTED FILE READ, ICD AND HANDSHAKE ERRORS, ETC. IT IS POSSIBLE TO TRANSMIT <NAK> AND HALT THE SEQUENCE AT ANY TIME.



Figure 6-9. Object File Save Sequence

## Z COMMAND

'Z' COMMAND SEQUENCE

THIS SEQUENCE EXECUTES THE 'Z' COMMAND PROCESS DEPENDING ON PARAMETERS SENT FROM THE ICD.

<soh>"03"(parameter)<cr> : 'Z' Command Record

THIS RECORD IS SENT FROM THE ICD TO ENABLE THE HOST SYSTEM TO EXECUTE THE 'Z' COMMAND PROCESS.

<ACK>

: 'Z' COMMAND NORMAL TERMINATION CODE THIS CODE IS SENT FROM THE HOST SYSTEM TO THE ICD WHEN THE 'Z' COMMAND PROCESS IS TERMINATED IN THE NORMAL MANNER. THE ICD IS UNAWARE OF THE 'Z' COMMAND PROCESS IN THE HOST SYSTEM.

<NAK>

: 'Z' COMMAND ABNORMAL TERMINATION CODE THIS CODE IS SENT FROM THE HOST SYSTEM TO THE ICD WHEN THE 'Z' COMMAND PROCESS IS TERMINATED IN AN ABNORMAL MAN-NER. THE ICD IS UNAWARE OF THE 'Z' COMMAND PROCESS IN THE HOST SYSTEM.



Figure 6-11. Z Command Sequence

'Z' COMMAND PROGRAM

· · · · ·

• • •

1) The ICD SENDS <SOH>"03"(PARAMETER)<CR> TO THE HOST SYSTEM BY THE 'Z' COMMAND.

· · · · · ·

- 2) IF <SOH>"03"(PARAMETER)<CR> IS RECEIVED, THE HOST SYSTEM WILL EXECUTE THE APPROPRIATE 'Z' COMMAND PROCESS.
  - A) IF AN ERROR OCCURS IN THE 'Z' COMMAND PROCESS, THE HOST SYSTEM WILL SEND <NAK> TO THE ICD AND THEN RETURN TO THE IDLE PROGRAM.
  - B) IF NO ERROR OCCURS IN THE 'Z' COMMAND PROCESS, THE HOST SYSTEM WILL SEND <ACK> TO THE ICD AND THEN RETURN TO THE IDLE PROGRAM.

-



Figure 6–12. Z Command Flowchart

THIS PAGE INTENTIONALLY BLANK

QUIT

QUIT SEQUENCE

THIS SEQUENCE RETURNS THE HOST SYSTEM UNDER THE CONTROL OF THE OS VIA CODES SENT FROM THE ICD.

<soh>"04"<cr> : Quit Record This record is sent from the icd to return the host system under the control of the os. The icd is unaware of the Quit command process in the host system.



## Figure 6-13. Quit Sequence

- QUIT PROGRAM
- 1) THE ICD SENDS <SOH>"04"<CR> TO THE HOST SYSTEM WITH THE QUIT COMMAND .
- 2) IF <SOH>"04"<CR> IS RECEIVED, THE HOST SYSTEM RETURNS UNDER CONTROL OF THE OS.



Figure 6-14. Quit Flowchart

~

## DISPLAY SYMBOLIC TEXT

DISPLAY SYMBOLIC TEXT SEQUENCE

THIS SEQUENCE CHANGES A PARAMETER SENT FROM THE ICD TO A SYMBOL AND THEN DISPLAYS IT ON THE HOST SYSTEM CONSOLE.

,...<soh>"1x"(parameter)...<cr> : Symbol Change Record

: THIS RECORD IS SENT TO HOST SYSTEM WHEN ICD CHANGES A PARAMETER TO A SYMBOL. THE SYMBOLIC TEXT RECORDS, INCLUD-ING SYMBOL CHANGE RECORDS, ARE SIMILAR TO ASCII TEXT. MORE THAN ONE SYMBOL CHANGE CODE MAY BE INCLUDED IN A SYMBOLIC TEXT RECORD, EXCLUDING <ACK> OR <NAK> CONTROL CODES.

THE SYMBOL CHANGE RECORD PARAMETER, SPECIFIED AS "1X", ALLOWS VALUES BETWEEN "10" AND "1F" TO BE INSERTED. IF THE SYMBOLIC DISPLAY IS NOT PERFORMED, THE CHARACTERS (EXCEPT <SOH>) ARE DISPLAYED ON THE HOST SYSTEM CONSOLE.

<ACK>

- : DISPLAY TERMINATION CODE THIS CODE IS SENT FROM THE HOST SYSTEM TO THE ICD WHEN THE SYMBOL AND TEXT DISPLAY OF SYMBOLIC TEXT RECORD HAS BEEN DISPLAYED.
- <NAK> : DISPLAY HALT CODE THIS CODE IS SENT FROM THE HOST SYSTEM TO THE ICD TO HALT THE TRANSMISSION OF SYMBOLIC TEXT RECORDS FROM THE ICD DURING THE DISPLAY OF "TRACE" ETC.





DISPLAY SYMBOLIC TEXT PROGRAM

- 1) THE ICD SENDS <SOH>"1x"(PARAMETER)<CR> TO THE HOST SYSTEM WHEN THERE ARE PARAMETERS THAT MUST BE REPRESENTED WITH SYMBOLS.
- 2) THE HOST SYSTEM ALLOWS BUFFERING OF ALL DATA UP TO <CR> IN THE ICD INPUT BUFFER.
- 3) The host system then searches the input buffer for <soh>"1x" (parameter);
  - A) IF <SOH>"1x"(PARAMETER) CANNOT BE FOUND, THE HOST SYSTEM WILL DISPLAY THE CONTENTS OF THE INPUT BUFFER (SYMBOLIC DISPLAY ON THE HOST SYSTEM CONSOLE), THEN SEND <ACK> TO THE ICD AND RETURN TO THE IDLE PROGRAM.
  - B) IF <SOH>"1x" (PARAMETER) CAN BE FOUND, THE HOST SYSTEM WILL SEARCH THE SYMBOL TABLE FOR THE PARAMETER.
    - 1) IF THE (PARAMETER) CANNOT BE FOUND IN THE SYMBOL TABLE, THE HOST SYSTEM WILL TRANSFORM <SOH>"1X"(PARAMETER) TO THE PARAMETER AND THEN RETURN TO STEP 3).
    - 2) IF THE (PARAMETER) CAN BE FOUND IN THE SYMBOL TABLE, THE HOST SYSTEM WILL TRANSFORM <SOH>"1x"(PARAMETER) IN THE INPUT BUFFER, TO THE SYMBOL AND THEN RETURN TO STEP 3).



Figure 6-16. Display Symbolic Text Flowchart

# CONSOLE KEY CHECK PROGRAM

CONSOLE KEY CHECK SEQUENCE

:

THIS SEQUENCE ENABLES THE ICD TO CHECK THE HOST SYSTEM CONSOLE INPUT FOR THE SUSPENSION AND RESUMPTION OF TRACE OR DUMP OUTPUT AND HALT INQUIRY.

<SOH>"09"<CR> : CONSOLE KEY INPUT CHECK REQUEST

THE ICD REQUESTS THE CONSOLE KEY INPUT CHECK IN REGARD TO THE HOST SYSTEM.

<ACK>

CONSOLE CODE MINUS INPUT

THIS CODE IS TRANSMITTED TO THE ICD WHENEVER THERE IS NO CONSOLE KEY INPUT.

<ANY ASCII CODE>: CONSOLE INPUT CODE

WHEN A CONSOLE KEY INPUT OCCURS, THE HOST SYSTEM TRANS-MITS ONLY THE 1 CODE OF THE ASCII DATA TO THE ICD.



Figure 6-17. Console Key Check Sequence

## POWER/GROUNDING REQUIREMENTS

Power Requirements :

100-120VAC ± 10% (100V - 117V) 200-240VAC ± 10% (200V - 240V)

Fuse : 2A

POWER

The ICD-278 can be used with a single phase power supply of 100 - 240 VAC by selecting the proper switch settings. The ICD-278 uses the same primary supply as the target system. This power supply contains filters that reduce the AC line noise.

The JVCC jumper is used to connect the target system and the +5V line of the ICD. In most cases, this jumper should be removed. The ICD logic GND is connected with the Terminal, SG.FG of the Host/Aux and the twisted pair shield of the in-circuit probe.

#### GROUND

The GND of the target system, twisted pair shield and the ICD ground, are connected through the plug probe. This arrangement is necessary for precise emulation quality.

When configuring an ICD development system, be aware of the following;

- Use the same primary power source to power the ICD, target system, console terminal, host computer system etc.
- Common frame grounding will improve the system performance.
- 3) The in-circuit probe may pick up noise from electromagnetic devices such as relays and motors. If this becomes a problem, additional shielding of the incircuit probes may be necessary.

а

# REALTIME TRACE ACQUISITION

During realtime tracing, storage of the data bus signals occur on the leading edge of the RD, WR, M1 or IORQ signals.

The ICD-2178 ensures positive storing of the address, status and data bus signals while emulating with ICD program memory. However, read data cannot be stored when the data setup time is shorter than 90ns.



b

ZAX

TECHNICAL BULLETIN

200 -08

DATE: 12/14/83

TO: All ICD 178-8086/88 and 278 users

SUBJECT: Communication Protocol Verification Method

The following procedure will aid the ICD user in understanding the correct communication protocol (object upload/down load) between the Emulator and the Host Computer. The example shown may be used in conjunction with Sequence Flow Charts located in the Software Specification section of the Operation Manual.

The example discussed utilizes two Televideo Model 925 terminals and one ZAX ICD-178 8086/88.

1) Configure the Figure 1;

| ICD | TERMINAL<br>HOST/AUX | CRT 1<br>CRT 2 |
|-----|----------------------|----------------|
|     |                      | J              |

Figure 1

2) Set the DCE/DTE ICD switch to - DCE.

3) Set the baud rate of the ICD to - 9600bps.

4) Set the Local/Remote switch to - LOCAL.

NOTE: CRT 1 is used as a normal terminal. CRT 2 is used as a host computer, that is, it is used to receive and send data to the ICD. For this operation, CRT 2 must be set in the Half Duplex and Monitor mode. The Half Duplex mode is selected by setting pins 7 & 8 of switch S2 (Function) to the bottom (down) position (Figure 2).





The Monitor mode setting allows display of all characters received from the computer or entered into the keyboard, including escape and control sequences (The escape and control sequences provide visual cues during long program routines). The Monitor mode is accomplished by entering "ESC U <cr>" to the keyboard. Entering "ESC X <cr>," will return the terminal back to normal operation.

#### OPERATION PROCEDURE

The verification operation procedure of this example will be illustrated by both, Flow Chart and Sequence Diagram.



### SEQUENCE DIAGRAM

Object File Load/Verify Sequence



NOTE 1) If ICD model 178 8086/88 is used, the code segment must be set to  $\emptyset$  by the "Register" command; ">RCS= $\emptyset$ ".

\*NOTE 2) Control character "ETX" is generated by entering in "(control) C" on CRT 2.

NOTE 3) VT52 Terminal or equivalent, will display the following letters;

| Start of Heading | - SOH | = A |
|------------------|-------|-----|
| End of Text      | - ETX | = C |
| Acknowledge      | - ACK | = F |
| Carriage Return  | - cr  | = M |



TECHNICAL BULLETIN

200-07

DATE: 12/15/83

**TO:**All ICD 278/Z80 & 278/8085 Users

SUBJECT: RANGE BREAKING

ITEM ONE:

The following examples display the ICD 278/280's Range Breaking Conditions using different combinations of the 3 available hardware breakpoints. Two examples are shown.

NOTE: In Examples 1 and 2, Addresses are divisible by 2 and 16-bit binary address is used for Range Breaking.

EXP.1 <<Range Break Address A=ØØ2ØH,ØØ21H,ØØ3ØH,ØØ31H>> <<Range Break Address B=ØØ4ØH,ØØ6ØH>>

>IØ >F  $\emptyset$ , FFFF,  $\emptyset$  (fills emulator memory with NOP) >B/A OF,ØØØØ ØØØØ ØØ1X ØØØX >B/B OF,ØØØØ\_ØØØØ Ø1XØ\_ØØØØ >B A(ON)OF $\phi\phi$ XX ( $\phi\phi\phi\phi_{\phi}\phi\phi_{\phi}\phi$  $B(ON)OFØØXØ (ØØØØ^<math>\overline{0}01X0^{\overline{0}}000)$ >GØ PC ØØ2ØH NOP <Break Hardware A> ۶G PC ØØ21 NOP <Break Hardware A> >G PC ØØ3Ø NOP <Break Hardware A> >G PC ØØ31 NOP <Break Hardware A> >G PC ØØ4Ø NOP <Break Hardware B> >G PC ØØ6Ø NOP 

End EXAMPLE 1

ZA

TECHNICAL BULLETIN

EXP.2 <<Break Between Addresses 1000H and 7FFH>> <<Break Range A=1000H to 1FFF & 3000H-7FFFH>> <<Break Range B=2000H to 3000H>>

>F,Ø,FFFF,Ø (used to fill emulator with NOP)
>B/A OF,ØXX1\_XXXX\_XXXX\_XXXX
>B/B OF,ØØ1Ø\_XXXX\_XXXX\_XXXX

| >B<br>A ( ON )<br>B ( ON )                                                                | XXXX<br>2XXX              |        | xxxx_xxxx<br>xxxx_xxxx |  |
|-------------------------------------------------------------------------------------------|---------------------------|--------|------------------------|--|
| >A 1ØØØ<br>1ØØØ<br>1ØØ3                                                                   | JP 1FF<br><cr></cr>       | FH #   |                        |  |
| >A 1FFF<br>2ØØØ<br>2ØØ3<br>>                                                              | NOP<br>JP 2F<br><cr></cr> | FFH #  |                        |  |
| >A 2FFF                                                                                   | JP 7F                     | FFH #  |                        |  |
|                                                                                           | JP 1FFF<br>ak Hardwa      |        |                        |  |
| >G<br>PC<br>1FFF                                                                          | NOP<br>ak Hardwa          |        |                        |  |
| <brea< td=""><td>JP 7FFF<br/>ak Hardwa</td><td></td><td></td><td></td></brea<>            | JP 7FFF<br>ak Hardwa      |        |                        |  |
| 2FFF<br><bre< td=""><td>NOP<br/>ak Hardwa</td><td>re B&gt;*</td><td></td><td></td></bre<> | NOP<br>ak Hardwa          | re B>* |                        |  |
|                                                                                           | JP7FFFH<br>ak Hardwa      | re A>  |                        |  |

\*NOTE: Both A & B breakpoints are enabled #NOTE: NOP can be used in place of JMP and JP instructions but must use different >G (Address) to observe various range break addresses. NOTE: For 278/8085 use JMP in place of JP instruction

End EXAMPLE 2

# ZAX

TECHNICAL BULLETIN

ITEM TWO:

Below is the procedure for using an address range NOT divisible by 2.

- Specify H/W or S/W breakpoint at beginning of range.
- 2. Execute program until breakpoint occurs.
- 3. Set 2 additional breakpoints;
  - A. H/W or S/W breakpoint for ending address of break range.
  - B. H/W breakpoint using "don't care" conditions to cover entire address range.
- 4. Execute program from current location. NOTE: Breakpoint should occur between specified address range.

