

AFIT/GE/ENG/88D-63

and the second second



8755 EMULATOR DESIGN THESIS John L Woods Captain, USAF AFIT/GE/ENG/88D-63

Approved for public release; distribution unlimited

Г

AFIT/GE/ENG/88D-63

A LONG THE REPORT OF THE ADDRESS OF

8755 EMULATOR DESIGN

#### Thesis

Presented to the Faculty of the School of Engineering

of the Air Force Institute of Technology

Air University

In Partial Fulfillment of the

Requirement for the Degree of

Master of Science in Computer Engineering

John L Woods

Captain, U.S. Air Force

December 1988

| NTIS<br>DTIC | to mend              |           |  |
|--------------|----------------------|-----------|--|
|              | 41.000 J             |           |  |
| م<br>        | eaenery:<br>T⊼ — — — |           |  |
| Dist         | Alica and<br>Citeria | l or<br>I |  |
| A·I          |                      |           |  |

DTIC OCPY NSPECTER

Approved for public release; distribution unlimited

#### Preface

The purpose of this design project was to design and  $\exists \mu \forall i \in L$ build a device which could replace the 8755 microchip in experimental circuit designs. The 8755 emulator provides the standard input/output ports and 2048 bytes of memory. It also provides the ability to load this memory from the Z-100, to single-step a target circuit, break on a specified address, and control the I/O ports from the Z-100.  $\rightarrow \mu \in m$ 

In designing and building this device I received support from several sources. I would like to acknowledge the members of the AFIT Electrical Engineering office for their support in helping me to acquire the parts and test equipment which were imperative to my thesis effort. I would like to thank LtC Charles Bisbee for his patience and guidance, as well as LtC Bert Garcia and Major Joe DeGroat for their support. Most of all I would like to thank my wife and children for their patience and support.

Captain John L Woods

ii

# Table of Contents

.

and a state of the second s

Ē

|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | rage   |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|
| Preface                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | ii     |
| List of Figures                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | v      |
| List of Tables                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | vi     |
| Abstract                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | vii    |
| I. Introduction                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 1      |
| Background                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 1<br>2 |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |        |
| Thesis Objective                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 2      |
| Current Knowledge                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 2      |
| Assumptions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 4      |
| Scope                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 5      |
| Standards                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 5      |
| Approach                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 6      |
| User Module                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 7      |
| Emulator Module                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 8      |
| Target Module                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 9      |
| larger mouther and a second se | 9      |
| II. Literature Review                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 11     |
| Introduction                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 11     |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |        |
| Emulation Process                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 12     |
| Hardware Design Techniques                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 14     |
| Software Design Techniques                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 16     |
| Conclusion                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 19     |
| III. Theory of Operation: Hardware                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 21     |
| Introduction                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 21     |
| Block Diagram                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 22     |
| Central Processor Section                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 23     |
| Emulator Memory                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 26     |
| Target Memory                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 27     |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 29     |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 31     |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |        |
| Break Address Section                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 33     |
| Target 40 pin Section                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 37     |
| Special Function Section                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 39     |

| IV. Theory of Operation: Software | 42  |
|-----------------------------------|-----|
| Introduction                      | 42  |
| Bootup Software                   |     |
| Main Emulator Software            |     |
| User Memory Control               |     |
| Emulator Mode Control             | 50  |
| Single-step control               |     |
| Break Control                     |     |
| 8755 I/O Control                  |     |
| Z-100 Control Software            |     |
|                                   |     |
| Pass User Memory                  |     |
| Break Control Module              |     |
| Parallel Port Control             | 62  |
| Main Menu Control                 | 64  |
| V. Recommendations                |     |
| Appendix A: Hardware Diagrams     | 69  |
| Appendix B: Net Wiring List       | 84  |
| Appendix C: Software Flowcharts   | 115 |
| Appendix D: Source Code           | 131 |
| Appendix E: User Guide            | 193 |
| Bibliograhy                       | 195 |
| Vita                              | 196 |

the second s

And the areas

# List of Figures

1. State and the second s

E

E

-----

.

| Figur | ce la | Page |
|-------|-------------------------------------------|------|
| 1.    | Emulator Block Diagram                    | 69   |
| 2.    | Emulator Schematic Diagram                | 70   |
| 3.    | Bootup Flowchart                          | 115  |
| 4.    | Emulator Main Flowchart                   | 116  |
| 5.    | Emulator User Memory Flowchart            | 117  |
| 6.    | Emulator Single-step Flowchart            | 118  |
| 7.    | Emulator Break Control Flowchart          | 119  |
| 8.    | Emulator Break Interrupt Flowchart        | 120  |
| 9.    | Emulator Parallel I/O Flowchart           | 121  |
| 10.   | 2-100 Main Flowchart                      | 122  |
| 11.   | Z-100 User Memory Flowchart               | 124  |
| 12.   | Z-100 Break Control Flowchart             | 126  |
| 13.   | Z-100 Parallel Port Flowchart             | 127  |
| 14.   | Z-100 Single-step Flowchart               | 128  |
| 15.   | Z-100 Target Control Flowchart            | 129  |

V

# List of Tables

the second state of the second s

| Table | e                               | Page |
|-------|---------------------------------|------|
| 1.    | Parts List                      | 82   |
| 2.    | Emulator Address Map            | 130  |
| 3.    | Register/Comparator Truth Table | 35   |

#### AFIT/GE/ENG/88D-63

# Abstract

The

This paper discusses the requirements to develop and build an electronic device to emulate the 8755 microchip. The design had  $_{h}^{5}$  five basic objectives: (1) Allow the user to download 8755 emulation memory; (2) Allow control of the microcomputer; (3) Provide a single step capability; (4) Provide breaking at a specified address. (5) Allow the user to set or change the emulated 8755 input/output ports. True for the

It describes the standard memory and input/output capabilities of the 8755. It describes in detail the emulator enhancement features to the standard 8755. The hardware circuits used to implement the emulator are discussed at the block diagram, component, and signal levels. It concludes with a detail description of the emulator software used to control the hardware. Keywerds (consider and configure to the Margary Confider Programma Theory edd) of

#### 8755 EMULATOR DESIGN

I. Introduction

# Background

The Air Force Institute of Technology (AFIT) offers Advanced Microcomputer Engineering (EENG 687) as a primary course in its digital engineering curriculum. As a course requirement students must design and build a coprocessor board capable of interfacing to a Zenith Z-100 microcomputer. The coprocessor must be able to take control of the Z-100 upon command from a software routine. During the design and fabrication of the coprocessor, the software routine must be programmed into an Intel 8755 microchip. The 8755 is needed because it provides 16 input/output lines as well as the memory for the software routine. To program the 8755, the student must perform the following sequence of operations:

1. Load the software routine into a specified Z-100.

2. Erase the 8755 memory with an ultraviolet light.

3. Set-up the 8755 programming device.

4. Connect and adjust a power supply for the programming device.

5. Program the 8755.

6. Verify that the 8755 is properly programmed.

If the student finds errors in the 8755 software routine, the entire process must be repeated. The sequence takes a minimum of an hour to complete. Over the last several

quarters, the instructors have received numerous complaints regarding the time wasted as a result of this programming sequence (1). Eliminating this problem will allow EENG 687 students to concentrate on the specific course objectives.

### Problem Statement

The current hardware and software available in EENG 687 are inefficient and hinder the students ability to successfully design and build the required Z-100 coprocessor within the course time constraints.

#### Thesis Objective

The purpose of this thesis is to design and build an 8755 emulator. The emulator will be a microprocessor based system that connects to a host computer  $v_{\perp}a$  an RS232 interface. The user must be able to download 8755 emulation memory, cause the target processor to execute, single step, or break on access of specified memory locations, and set or change the emulated 8755 input/output ports.

### Current Knowledge

Currently, the 8755 is available only from the Intel corporation. The 8755 provides 16, bit defineable, input/out lines and is directly compatible with the requirements defined for the Z-100 coprocessor board. In as the 8755 provides 2048 bytes (2 kbytes) of eraseable programmable read only memory (EPROM) for program storage. EPROM allows the user to store a program in the device and remove the device from the power source without a loss of

data. In contrast, random access memory (RAM) allows the user to load a program but will lose its data if the power source is removed. The coprocessor board will need to be installed and removed from the Z-100 on a frequent basis to allow all students equal time on the Z-100 systems. The requirement for bit definable input/output lines and non-volatile memory can only be satisfied by the 8755 or an 8755 emulator.

To eliminate the problems associated with the 8755 programming process, the emulator must replace the EPROM section with RAM. The emulator must appear to be a standard 8755 to the circuit into which it is installed. As a result the emulator must provide additional control circuitry to load and modify the target system's memory. Additionally, circuitry will also be required to provide additional features, which will further enhance the student's design and troubleshooting ability. Enhancements to the standard 8755 are transparent to the target system but will be very useful to the user. All enhancement features will be initialized and invoked from a host computer, but carried out by the emulator board. Currently designed enhancement features of the emulator board are:

 A means of stopping the target system after the execution of each instruction. The user is able to disable this mode via the host computer keyboard.
 Special registers monitor all address bus accesses from the target system. When a previously defined address

is detected, the emulator will halt the target system and advise the user of the halt condition and halt address. 3. The user may edit a software program on the host computer, while the target system is simultaneously executing the program in target memory. When the user is ready to load the new program into the target memory space, the emulator will halt the target system and perform the memory download.

4. The ability to change the 8755 port configuration without modifying the target memory.

Currently, literature from the 8755 manufacturer indicates that none of the enhanced features are available (2). The exact means of implementing these enhancements is discussed in chapters three and four.

#### Assumptions

A CARLES AND A CARDINE STOLLAR STOLLAR AND A CARDINAL AND A C

The following assumptions have been made with respect to the design of the 8755 emulator project.

1. Users of the 8755 emulator are thoroughly familiar with the proper operations of the standard 8755 microchip. This is essential since the emulator will functionally appear to be an 8755.

2. Users are familiar with the operations of the host microcomputer and the MS-DOS operating system. This is required because the emulator will be controlled via the host computer serial port.

3. The user possesses the ability to write software routines in assembly language code and convert this code to machine readable format.

#### Scope

. ..

.

La la la la la la la la la la

This project will investigate applicable hardware and software resources, then design and build an 8755 emulator. The specific goals of this project are to:

1. Provide a device which will meet all timing constraints of the 8755.

2. Provide two 8 bit input/output ports, with individual bit direction control.

3. Provide 2048 bytes of random access memory.

4. Provide the ability to perform single-step operations, with control via the host computer.

5. Provide the ability for the user to download control software from the host computer to the emulator board.6. Allow the user to set break addresses to stop program execution when accessed.

7. Allow the user to reconfigure or read the 16 input/output ports from the host computer.

8. Provide documentation of all hardware and software associated with the emulator.

### Standards

The emulator device and its control software must meet the following criteria:

1. The external electrical functions of the emulator must:

a. Respond to all 8755 control signals.

b. Meet or exceed the timing parameters of the 8755.

c. Provide the same output power drive capability as an 8755.

2. The software used to control the emulator must be properly documented. This will allow future students to modify or update the device as required.

3. The device must perform each function listed in the scope section of this paper.

# Approach

Constant and had been been and a state of the second second

A practical solution to this problem is to develop an emulation device using commercially available hardware and in-house software to mimic all standard 8755 operations.

The emulator board, design is separated into three major functional sections. Each section is then designed and implemented with its unique set of hardware and software resources. The first section is the user module and refers to the host microcomputer, its operator input keyboard, and its serial input/output port. The operator issues all commands to the rest of the system via the computer keyboard and software routines.

The second section is the emulator module and consists of the hardware and software used by the 8755 emulator to communicate with the user as well as with an attached circuit. The last section is the target module and refers to

the hardware which is attached to the emulator via a 40 pin plug. The 40 pin plug represents a standard 8755 and plugs directly into the target circuit. Some portions of the emulator and target module are controlled, mutually exclusively, by both modules. A three module approach was selected in order to establish small, functionally cohesive, manageable modules.

Each module will be self-contained, with limited input and output paths. Controlling access to each module will ease the design, troubleshooting, and maintenance of the system. A brief description of each module and the interrelationship between modules follows.

#### User Module:

مداليد البداقير الجها المحد لعطائهم

This section of the emulator consists of software which resides on a host computer. The hardware used is the host computer and will not require any modifications. The user software will provide instructions and menus to control the emulator module. The host computer will download the emulator control program to the emulator board automatically. This software is the emulator system monitor and controls all aspects of the emulator with the exception of the boot-up routine. The boot-up routine will reside on the emulator board at all times. After bootup is finished, a setup menu will be displayed. Each item on this menu should be invoked in sequence. The setup menu consists of the following list of options:

- a. Pass target memory.
- b. Set break addresses.
- c. Configure ports.
- d. Return to main menu.

Option (a) of the setup menu downloads the 2048 byte target software to the emulator. This software is used exclusively by the target system, but may be modified by the user module. Option (b), the set break address function, downloads a file containing 1 to 5 memory addresses to the appropriate registers on the emulator board. Option (c), the configure port function, defines the direction of data flow through each bit of the emulated 8755 ports. The last option, return to main menu, simply displays menu 2.

The main menu will be the starting point of all actions atfer system startup. The main menu consists of the following options:

a. Start or stop target system.

- b. Enable/disable break detector.
- c. Change break addresses
- d. Enable/disable single-step
- e. Edit/view/download user memory
- f. Edit/view parallel ports
- g. Exit to DOS

Emulator Module:

This module of the emulator contains all emulator hardware components. It interfaces with the host computer via an RS232 serial port and the target system via an extended 40 pin ribbon cable. To implement this module, a separate microcomputer was designed and constructed. This microcomputer consists of an 8088 central processing unit (CPU) and its associated memory devices. A read only memory module contains the software necessary to initialize the hardware upon power on. To communicate with the Z-100, a universal asnychronous serial receiver/transmitter (UART) is used. The UART receives parallel data from the CPU and converts it to a serial bit stream. This serial data is transmitted to the host computer via a serial port. This process is reversed when data is transmitted from the host computer to the emulator board. The emulator and user software, as well as all system commands, are received via this path. The emulator exercises control over the target system and the input/output ports. Control of the target system is implemented by connecting the emulator to the control lines of the ports and target system. When the emulator's CPU is controlling the system, the target system is inhibited. When a requested function is completed, the target system is restarted. The emulator may communicate with the host computer while the target system is in its operational mode without conflict.

# Target Module:

is an analysis and submany the trip and day the first state

This section of the emulator is located on the emulator board. The break on address function is invoked by the user, implemented by the emulator, and receives all necessary data

from the target. The target module functions in a passive mode and does not invoke any commands relative to the user and emulator modules. All control, address, and data lines of the target are monitored by the emulator. Depending on the data received, the emulator will invoke a number of responses and prompt the user for additional input when required.

and the second second second second

#### II. Literature Review

#### Introduction

Real and the fait of the second states

This literature search reviews an emulation system design for the Intel 8755 microchip. This device provides erasable programmable read only memory (EPROM) and input/output ports to peripheral devices (1). The 8755 is used in microcomputers and in industrial applications. The compatibility of this device with the 8088 CPU has prompted its use in educating students at the Air Force Institue of Technology (AFIT). In the school environment at AFIT, the 8755 must be programmed and reprogrammed during the course of laboratory exercises. Frequent changes to the software programs waste time because the 8755 must be erased, reprogrammed, and verified with each change. The entire process can take a significant amount of time and if one piece of code is incorrect, the entire process must be repeated. To increase the effective use of class time and resources, an 8755 emulator is needed (1). The emulator must provide program memory, the ability to singlestep through a program, input/output ports, and reduce the time required to program or reprogram the device. Sound hardware and software development techniques must be used to design, fabricate, and test the 8755 emulator. This literature search addresses digital emulation techniques currently used.

# Emulation Process

The second state of the second state of the second second

The emulation process starts with performing an in-depth requirement analysis, to ensure that what the user wants is clearly understood and documented (5:35-36). Pressman states that the system designer begins with customer-defined goals and constraints, and devises a representation of function performance, interfaces, design constraints, and information structures. Booch believes the systems engineer must bound the system by determining the scope of what is to be accomplished (3:76). Wilcox states that the requirement analysis process is an interactive one which is completed when the customer and system designer agree on exactly what is to be done (9:27).

Following the requirement analysis, the requirements are organized into tasks which are then alloted to teams with specified due dates (6:50). Each task is approached as a separate module with a set of input and output parameters. Each module may be accomplished independent of other modules as long as the boundary specifications are adhered to. If, during the course of developing the modules, the boundary parameters must change, then the change must be approved and coordinated by the system engineer (3:121). Modules may perform strictly hardware or software functions, but most perform a combination. Regardless of how the external processing is accomplished, the system engineer is only concerned with the system module at the interface level.

An alternate process for producing an emulation device is to perform a preliminary requirement analysis, which intentionally leaves many questions unanswered. (10:400-402). The goal is to start working as quickly as possible on a prototype of the desired system. The customer is then given a demonstration illustrating the strengths and weaknesses of the proposed design. Wilcox states that in many cases the user will make suggestions to add or delete features as a result of having a real model to base his decision on (9:63-64). The primary benefit gained from prototyping is the reduced likelihood of changes in requirements after the design process has begun. A disadvantage of prototyping is the cost in time and material to develop, build, and rebuild the demonstration model. The decision as to which emulation approach to take is made by the system engineer. The user only defines the end product performance specifications and the format of data entering the system from an external source (10:405). The implementation of the modules is determined by the hardware and software engineers. The emulation process suggested by Pressman lends itself to the 8755 emulator design. The time restraints imposed by AFIT prevent the use of rapid prototyping. A thorough requirement analysis will prevent late changes to the emulator performance goals and also save the time and material required to build a prototype. The requirement analysis is only the first step in an emulator design project. The requirement will eventually have to be implemented with

hardware and software . When the customer and system engineer have a firm set of requirements, the design engineer and software engineer may start system the development process (8:87-88). Initially, hardware and software engineers must work together to determine which modules pertain to hardware and which pertain to software. Both areas have a variety of design techniques which may be used to develop the modules.

# Hardware Design Techniques

Engineering design is a creative process of devising a product to fill requirements specified by the customer (7:379). The problem-solving approach is one creative design technique and involves defining the problem, selecting a possible solution, evaluating the solution, generating other possible solutions, and selecting the best solution. Central to successfully using the problem-solving approach is the ability to plan a project. Objectives must be clearly stated, and time schedules developed and adhered to. Strategies to achieve objectives must be developed and a specific plan of action developed (4:185-186).

Top down design is another technique often used in hardware, as well as software, design (3:76-85). Top down design decomposes the problem at hand into seperate but functionally similar modules. Each module is decomposed further until the original complex task has been reduced to several small manageable tasks. Top-down design incorporates

heuristic design rules when the lowest level modules are implemented.

a state and the set of the set

Ι.

Regardless of the design technique used, the actual hardware components must be selected. This selection process will again include software engineers since their software will have to run on the hardware selected (6:100-110). Offthe-shelf components should be used whenever possible to save the cost of creating these components. Review and modifications are recommended at this stage since any change beyond this point will be costly.

The top-down design technique provides an excellent approach to the 8755 emulator design. At its highest level of abstraction, the emulator must appear as an 8755 microchip with enhanced features. This level of abstraction may then be broken down to a user module, emulator control module, and target system module. Each module may be broken into still lower level modules until each subfunction is represented as a separate module. When this level of abstraction is reached, the heuristic design rules may be applied to implement each subfunction. This approach to the problem provides a direct path to design and implementation.

The hardware design process is an important segment of the overall design effort, but equally important is the software needed to control the hardware. Hardware and software design must take place in parallel and in reaction to each other. Software design techniques exist which allow

the interactive development of software and hardware, but still addresses the special needs of the software designer.

# Software Design Techniques

F

Any digital emulator project requires the extensive use of software design techniques and methods. Modern software design is an outgrowth of hardware and system engineering. It encompasses methods, tools, and procedures that enable the designer to control the process of software development (4:188). Software design methods encompass a broad array of tasks that include: software requirements analysis, design of data structures, program architecture and algorithm procedures, coding, testing and maintenance. Software design tools provide automated support for these methods. Software design procedures provide the sequence in which methods will be applied, the deliverables that are required, the controls that help assure quality, and the milestones to assess progress. The steps necessary for software design are referred to as software design paradigms (6:110-118). The paradigm chosen is based on the nature of the project and application, the methods and tools to be used, and the controls that are required.

The classic life cycle paradigm is the oldest and most widely used . Software design using the classic life cycle demands a systematic sequential approach that begins at the system level and progresses through analysis, design, coding, testing, and maintenance. Software analysis starts with the

system requirements analysis to allow the software designer to understand the nature of the programs to be written. The software designer must also be familiar with hardware to be sure the system components are compatible. Software design translates requirements into a representation of the software that can be assessed for quality before coding begins. During coding, the software design is translated into machine readable code. Software testing focuses on the internal logic of the software and the external functions of the system to ensure that a defined input will produce the desired output. Software maintenance applies each of the preceding life cycle steps to an existing program rather than to a new one.

المحاج والمتحود المعولة المعولية المرا

The classic life cycle paradigm is not without its criticism in some situations (3:87). Booch points out that real projects rarely follow the sequential flow proposed by the classic life cycle, and often it is difficult in the beginning for the customer to state all requirements explicitly. Further, Booch suggests using the protyping paradigm in situations where these criticisms are valid. The prototype paradigm is best suited for situations where the customer does not have a complete understanding of system requirements.

Prototyping is a process that enables the developer to create a model of the software to be built. The model can take one of three forms: a paper prototype that depicts human-machine interaction in a form that enables the user to understand how such interactions will occur, a working

prototype that implements some subset of the functions required of the software, or an existing program that performs part or all of the functions desired but has other features to be improved upon in the new development effort. All prototyping approaches begin with the customer and designer defining overall objectives for the software, identifying whatever requirements are known, and outlining areas where further definition will be required.

فيطرح فيعار وحاصا تعالما تعاديا

A quick design is then initiated and focuses on a representation of those aspects of the software visible to the user. The quick design leads to the construction of a prototype. The prototype is evaluated by the customer and is used to refine requirements for the software to be developed. A process of interaction occurs as the prototype is refined to satisfy the needs of the customer, while simultaneously enabling the designer to better understand what needs to be done. The prototype is usually a first try, throw away model and may cause some problems.

A problem associated with the protype paradigm is that when the customer is informed that the device must still be built from scratch, he usually objects. The appearance of needless waste is a problem with this approach. If the customer demands a few quick fixes to the prototype instead of a complete design and fabricaton, problems with quality and reliability may result (9:122-125).

The 8755 emulator is well suited to aspects of the classic life cycle and the prototyping paradigm. A thorough analysis and design will ensure minimal redesign problems as the project progresses, and prototyping will ensure that no important design considerations were overlooked. The combined application of these techniques provides a direct and reliable approach to designing the emulator software. When the software is completed, it must be tested on the hardware it was designd for, and receive final approval from the system designer.

### Conclusion

and the first market was first for the second se

A clear need exists for the development of an enhanced 8755 microchip. Currently, there is not a commercially available digital device to satisfy the needs of AFIT (1). The emulator will provide memory to match that available on the 8755 and a complete set of I/O ports. Enhancement features include the ability to reconfigure ports from an attached microcompter, to stop the emulater at any given time, and to allow easy reprogramming of the 8755 memory. The process of designing the emulator begins with a thorough requirements analysis involving the customer and system designer. The requirements will be divided into modules which will be small and manageable. The modules will be implemented using current hardware and software design techniques.

The engineering design process is a creative process which involves making all the decisions necessary to

implement the design requirements successfully. The designer could use the problem-solving approach, heuristic design rules, or top-down design. For the 8755 emulator, the topdown design is most compatible since this approach requires fewer initial designs and matches the requirement analysis process closely. By aligning each requirement with a module to be implemented and then decomposing the modules into subfunctions, an accurate design is probable. The subfunctions are implemented at the hardware interface level and require close coordination between software and hardware designers.

- Marthashilarista, 622 to . Sheat & ......

E

The software design must be conducted simultaneously and interactively with the hardware design. A combination of the classical life cycle and protyping paradigms provide the most effective approach to implement the requirements defined in the requirement analysis. This approach also provides the interaction needed between the hardware and software development efforts. Each paradigm individually has problems and limitations which can be avoided by selective application at the appropriate time. Together these paradigms provide rapid but accurate software development and implementation.

#### III. THEORY OF OPERATION: HARDWARE

# Introduction

This chapter provides detailed information on the hardware devices used in the 8755 emulator. The software to control the system is presented in chapter 4.

The 8755 EPROM/I-O device is produced by the Intel corporation. Intel produces a family of micro devices which are all designed to work together with minimum support logic and driver chips. To ensure maximum compatibility between the emulator and the actual timing and power parameters of the 8755, Intel chips are used when possible.

The overall purpose of the emulator system is to provide all the features available on a standard 8755, and the additional capability to single step, load the user memory directly, break on specified memory addresses, and control this process via an RS232 serial link to a host computer microcomputer. The user circuit must also be able to use the standard 8755 features when desired, while the emulator circuit remains transparent in terms of timing constraints.

In order to accomplish the requirements listed above the 8755 I/O and memory hardware were broken into two separate sections of hardware. The additonal special features required were accomplish through the use of several subsections which are described in the remainder of this chapter. Many of the devices used in the emulator circuits require software inputs

to initialize and control them. When a device requiring software is discussed, the discussion will be brief and the full explaination reserved until chapter 4.

Each major functional section of the emulator will be discussed separately so that all details of that subsection are presented as a package to the reader of this paper. The block diagram (figure 1) and schematic daigram (figure 2) referred to in this section may be found in Appendix A.

### Block Diagram

P

Condinal address that the many one should be the to do the dealer the bards

The block diagram for the 8755 emulator is shown in figure 1. This diagram breaks the emulator circuit into eight functional areas. The central processor section processor exercises control over all over parts of the system. The emulator memory section contains all system memory which is used exclusively by the central processor. The target memory section contains the user 2 kilobyte static ram which is used primarily by the target, but is also accessible by the central processor. The serial port section is built around an Intel 8251A Universal Asynchronous Synchronous Transceiver (UART) and contains all the hardware necessary to support serial communications. The parallel port section contains an 8755-2 I/O memory chip and the necessary support devices. The parallel section is accessible by either the target or central processor. The break section monitors the target address bus for memory address loaded from the host computer via the central processor. Upon detection of a memory access

by the target which matches any of the stored addresses in the break registers the target is halted and the central processor is sent an interrupt request. The break section may be disabled through software control from the host computer. If the break section is in its enable mode the interrupt request will advise the host computer of which address has been detected. The target system remains halted until restarted by a command from the host computer. The target module contains a 40 pin socket plug which replaces the 8755 in the application circuit. All pins are identical and all 8755 features may been accessed by the target through the plug. The target section also contains additional hardware to support the enhanced features of the emulator listed in the introduction. The special features section includes the harware necessary to provide the emulator single-step, target single-step, and mode control functions. The mode control function is used to control whether the emulator or target system has access to user memory and parallel I/O ports at any given time. Access to these two section is mutual exclusive under all circumstances. The remainder of this chapter provides a detail discussion of each section of the block diagram.

#### Central Processor Section

System timing is provided by U9, an 8284A clock generator and driver. The 8284A is driven by a 14.3 MHZ crystal oscillator. The CPU operating frequency is 4.77 MHZ at the

output of U9 pin 8. The PCLK output is used as the internal CLK signal to the UART(U3) and is 2.39 MHZ. The 8284 provides synchronization of the ready input signal and the system clock. The RDY output is a synchronized signal generated by the into at pin 4. This input is used to halt the CPU during single-step operations, by driving U8 (8088) pin 22 low. The system reset is input to the 8284 as a low on the RES\* pin when switch S1 is pressed. This signal is synchronized and inverted then output at U9 pin 10 as a high. The CPU, UART, and 8755 are reset by this signal. For a system reset the signal at U8-21 must be high for a minimum of 50 microseconds. Capacitor C1 and resistor R5 ensure that the minimum timing requirement is satisfied. When this happens U8 will clear its status flags, DS, SS, and IP registers. The CS register is set to FFFFh, thus FFFFO is the address at which the CPU restarts when reset returns to a low state.

the start chilling the second start in the

The heart of the emulator is the 8088-2 (U8) central processor unit (CPU). The 8088 provides the address, data, status, and control signals to direct the emulator operations. The address lines ADO through AD7 and A16 through A19 are multiplexed to also function as data and status pins, respectively. These signals must be latched in order to be available for an entire machine cycle. Address latches U6 and U7 are used to latch the address bus during T1 of each cycle. The signal used as a latch strobe is the address latch enable (ALE). During each bus cycle from the 8088-2, ADO

through AD7 and A16 through A19 change to valid data and status during T2. This data remains valid until the middle of T4. Address lines A8 - A15 are not multiplexed and are valid for the entire machine cycle. This timing arrangement of the ALE is important in the implementation of the target and emulator single step features. The ouput of U6 and U7, plus A8 through A15 form the address bus used to drive all emulator devices (figure 2a). The latched address remains valid until the falling edge of the next ALE, at which time the new address is strobed into U6 and U7.

The 8088-2 control lines used by the emulator include the RD\*, WR\*, ALE, IO/M\*, Reset, MN/MX\*, DT/R\*, DEN\*, and Ready. The RD\* and WR\* controls lines are buffered through U60 (7407), because the fanout capability of both lines is exceeded, the other control lines of U8 did not require buffering. The RD\* signal is used to turn on the output drivers of a selected device. When the RD\* line is low the data bus is strobed into U8 (8088). When WR\* is low the data present on AD0 through AD7 are strobed into an addressed device. The ALE is also used to strobe U36 (8755) control signals and to reset the emulator single step flipflop. If the current machine cycle is accessing memory the IO/M\* pin will be low. If the machine cycle is an IO access then this pin will be high. For the emulator the 8088-2 is configured to operate in the minimum mode by tying the MN/MX\* to VCC. The DT/R pin controls the direction of data flow through U14 (74F245) and U35 (74F245) during each machine cycle. When

DT/R\* is high data is transferred from the CPU and when the pin is low data is moves toward the CPU. The DEN\* output is used to control the outputs of the data transceivers when the user RAM and 8755 are accessed. Finally, the INTR pin is used to detect when the break section has detected a break address. This pin may be disable with a software instruction, but if it is enabled the CPU outputs a interrupt acknowledge on INTA. Following each break detection the INTR input is disabled and must be reset by the interrupt handler routine.

# Emulator Memory

The emulator memory space is addressable only by U8, and therefore does not require any multiplexed address and controls lines (figure 2c). All addresses discussed in this paper are in hexidecimal format. The emulator memory is controlled by U5, an Intel 8205 3-to-8 decoder. Address lines A16, A17, and A18 are used to drive the decoder input. Output U5-15 is ORed with A15 to control U15 (MSM62256) and ORed with A15\* to control U16 (MSM62256) chip enable inputs. These two static RAM chips form page 0 of the 8088 memory space. Addresses (00000-07FFF) are located on U16 and addresses (08000-0FFFF) are located on U15. The emulator memory map is shown in table 2. Output U5-7 provides the emulator clip select to U17 (2716), which is page 7 of the memory space. A 2716 EPROM was used because it was readily available in the engineering laboratory. The system ROM is located on U17 with addresses 70000 - 707FF. Since A16-A18 are all ones

after a reset, and the lower 11 address bits are 7F0, the emulator begins its operation from the address 707F0. Decoder output U5-13 is used to control the system mode flipflop U39-B (7474). Decoder output U5-12 and U5-13 control the target system single-step circuits U65 (7474). Both of these control lines will be discussed in greater detail later. Finally, output U5-9 controls U18 (UM6116), which is page 6 of the emulator memory space. Static ram U18 may be addressed by the target system also and will be discussed in detail in the next section.

The emulator I/O address space is controlled by U38 (74154) a 4-to-16 decoder. Each output of U38 will be discuss in the functional section where it is used. The control inputs to U38 consist of address lines A4 - A7 and an inverted IO/M\* control signal. The IO/M\* signal ensures that U38 and U5 (8205) are never active at the same time. This separation of memory and IO space is necessary since the A4 through A7 are used throughout the emulator.

### Target Memory

The live the entries live time the live ?

Another user requirement is for the emulator to eliminate the 8755 ROM, and to provide the target with equivalent user RAM. Additionally, access to the user by the emulator system and the user's CPU ram must be mutually exclusive. To accomplish this requirement, the address lines A0 through A10 are multiplexed using 74F157A 2-to-1 multiplexers. Each multiplexer has two sets of four inputs and one set of four

outputs. Address lines A0 through A3, A4 through A7, and A8 through A10, and CS\* are applied to U10, U11, and U12, respectively (figure 2c). One set of these signals come from the emulator and an identical set comes from the user circuit. The output of U10, U11, and U12 are applied to U18 (UM6116). The select line pin 1 of U10 through U12 controls which set of input signals are connected to the output. When select is high the emulator is in control of the SRAM. Conversely, when select lines of all multiplexers in the emulator are control by the output of the mode flipflop U39-A (7474). The write enable input (U18-21) is enabled only by the emulator. This limited access to the write enable is necessary because the a real 8755 does not have a write capability.

and an Cast Lar Sec.

E

The output of U18 is connected to U14 and U13. These devices are 74F245 transceivers and are required to isolate the SRAM from the system data bus. The output enable input on U14 is controlled by the ORing of chip select of U18 and data enable of U8. The output of U41-A (7432) is low only when DEN\* and CS\* are both active. The direction of data flow through U14 is controlled by the CPU RD\* signal. Transceiver U13 performs a similar function for the target circuit's access to U18 (UM6116), except data flow is only allowed from U18 into port B and out of port A. This prevents the user from inadvertently writing to U18. Output enable of U13

(74f245) is controlled by ORing IO/M\* (MISC1-7), CE1\* (MISC1-1), and the target RD\* (MISC1-9) signals. When all three inputs are low U40-D will produce a low when U18 is accessed by the target. The 74F157A and 74F245 devices were selected to limit the amount of delay introduced, while allowing a flexible means of gaining access to U18. The multiplexertransceiver combination adds only 14 ns delay, and is transparent to the user.

## Serial Port

A primary requirement of the emulator system is the ability to communicate serially with the host computer microcomputer. This is accomplished via the serial port J2 on the rear of the host computer. The emulator uses U3 an 8251A universal asynchronous receiver transmitter (UART) as its serial port. The 8251A is capable of being programmed for asynchronous or synchronous communications. This project uses only the asynchronous mode, and operates at 9600 baud, with odd parity, and one stop bit. The specific software required to configure the UART is discussed in the next chapter. Data transferred between the CPU and UART is in an eight bit parallel format. An 8286 transceiver (U4) is used to isolate the UART from the CPU. The outputs of U4 are tri-stated unless the UART's chip select is low. The direction of data flow through U4 (8286) is controlled by an inverted RD\* from the CPU. The UART converts the parallel data to a serial string and inserts start, stop, and parity bits. This string

is transmitted serially on the TXD pin U3-19 (8251A). The UART output is standard TTL output, which must be converted to RS232C signal specifications. The 1488 line driver (U1) converts the TTL levels OV and 5V to -12 and +12, respectively. The output of U1 is connected to the RS232C cable and received by the host computer. Data terminal ready (DTR\*) and request to send (RTS\*) signals are also provided by the UART and passed through the 1488 driver. To receive data from the host computer the RS232C signals must be converted to TTL prior to being applied to the UART. Line receiver U2 (1489) converts the input data string, clear to send (CTS\*), and data set ready (DSR\*) signals. The use of the DTR\*, RTS\*, CTS\*, DSR\* handshking signals will be discussed in the next chapter. The RS232 cable also provides a ground return path between the host computer and emulator.

The receive and transmit clock is provided by an external function generator via connector J2. At 9600 baud the required clock frequency is 153.6 Khz when the baud rate factor is programmed for 16 (see chapter 4). For proper operation U3 (8215A) requires a minimum clock period of 310 ns. The system clock of the cpu has a period of 210ns, but the PCLK (U9-2) satisfies this requirement with a period of 420ns.

The control signals of the 8251A are the CS\*, RD\*, WR\*, and C/D\* inputs. The CS\* and RD\* must be low to transfer data from the UART to the CPU. The CS\* and WR\* must be low to transter data from the CPU to the UART. The C/D\* input is

connected to A0 on the address bus and determines which internal register is being accessed. A detailed description of register control is covered in the next chapter.

# Parallel Port

An 8755 has 2 kbytes of EPROM and two 8 bit data ports (figure 2j). The data ports may by used as inputs or outputs and each bit is individually defineable through software. Software requirements for the 8755 are covered in the next chapter. The literature review found that the 8755 is the only commmercially available device with bit-defineable ports. To implement this feature the emulator is using an 8755-2 (U36), the the memory section of this device was not used in this application. Since the emulator and the user must have access to the 8755 ports three more 74F157A multiplexers, U31, U32, and U33 are used to control access to this chip. Multiplxer U31 directs ALE, RESET, RD\*, and WR\*; U32 directs CLK, VDD, A0, and A1; U33 directs CE2, I0/M\*, CE1, and IOR\* from the emulator or user CPU control lines. The active set of inputs at any given time is determined by the mode flipflop U39-A (7474). All outputs of the multiplexers go to U36 to allow control of this device by either source.

When CE1\* and CE2 are active the 8755 will strobe the address and IO/M\* lines on the falling edge of ALE. To prevent extraneous data during an access to user ram, the CE2 input is ANDed with the target IO/M\* control line before being applied to U33 (74F157). The output of this gate will

drive CE2 low during each memory access by the target system. This will inhibit the 8755-2, thus preventing an I/O operation. The 8755 does not strickly require the use of the IO/M\* line to perform an I/O operation. The I/O may be accessed by using only the IOR\* and IOW\* lines. This option is still available to the target user, but the emulator was not designed using these lines. If this approach were taken the possibility of bus contention would exist when the user tried to perform a normal memory access. This problem only exists from the target system, because to it the 8755 uses the same chip enables for its memory and I/O operations. The emulator directly accesses the user memory and the 8755, because from its perspective theses devices have separate chip select addresses. The clock input to U36 was routed through the multiplexer to allow the user the option of inserting wait states, but the 8755 typically does not require wait states with Intel microprocessors. The clock is only used to drop the ready line U36-6 during each bus cycle. The emulator system does not use the ready line with its operations with the 8755. The 8755 I/O ports are controllable by the emulator or the target, but the port outputs are connected only to the target system. Thus when the user performs an I/O operation through the ports the data is receive and transmitted directly to his circuit application. The user may also drive these ports from the emulator, but the output will still be applied to the target circuit. If

G

Γ.

the user desires to read the I/O ports via the emulator the data may be displayed at the host computer terminal. The emulator may also be used to reconfigure the data direction registers while the target is in its halt state. This feature allows the user to trouble shoot a circuit without having to change the user program which could also be used to do the reconfiguration.

The key hardware which provides the user with these flexible features are U34 (74F245) and U35 (74F245). These are 5 ns maximum delay data transceivers used to provide isolation between the emulator and target data busses. Transceiver U34 is connected to the target and is only enabled when the mode flipflop is set to the target mode and the target is performing an I/O operation. These two signals are combined with AND gate U56-C (7400), with this output applied to the OE\* input of U34. The emulator transceiver U35 is controlled by ORing U36 chip select with the DEN\* output of the emulator CPU.

## Break Address Section

Another key requirement of the emulator is to provide the capability for the target system to break (halt) on specified memory addresses. In order to provide this feature the emulator must store the break address, monitor the target system address bus, detect a valid match, halt the target at before the address changes, and interrupt the emulator so it can handle the break condition. Additionally, the emulator

must allow the user to disable the break section if desired, and clear the break condition on command.

The break circuit consists of two primary hardware sections. First, the ability to store and monitor the address bus is provided by a set of ten 74F524 register/comparator chips (figure 2e). These devices are eight bits wide and can perform serial or parallel reads and writes. The parallel mode is used in this application, in order to allow direct a connection between the break circuits and the emulator CPU data bus. Since the address bus of the target is 11 bits wide two 74F524s are cascaded to form a 16 bit combination. The highest five bits are tied to ground and not used. The 74F524 retains the desired break address in an internal register and compares this address with the target address during each bus cycle. When a match is detected the equal (EQ) output goes low. This output is open collector and both cascaded EQ lines are tied together and connect to VCC through a 1k resistor. The clock input (CP) to the 74F524 is used for internal synchronization and is applied at pin 11. This signal must be provided by the CPU that is reading or writing to the chip. The data inputs which receive the desired break address from the emulator are also used to monitor the target address bus. Therefore, the address and clock lines are multiplexed using U42, U43, and U44 which are 74F157A chips (figure 2d). The control lines for this type of multiplexer was discussed earlier. The break addresses are label break 1 through break 5, but the actual chips are broken out as break 1A and

break\_1B through break\_5A and break\_5B. This was necessary because the data bus is only eight bits wide and each break address requires two write addresses. During the address monitoring process all address bits are applied simutaneously to the comparators from the output of U29 (8282) and U30 (8282). In order for each comparator to be individually addressable, each chip required its own chip enable address. All chip selects are located in the emulator I/O address space and controlled by U38 (74154). Each comparator also requires combinational logic to drive its SO (Pin 1) and S1 (Pin 19) inputs. Figures (2f-2h) shows specific connections for each control block, but each block performs according to the following truth table.

# Table 3. Register/Comparator Truth Table

| <u>s0</u> | <u>S1</u>    | Operation                                           |
|-----------|--------------|-----------------------------------------------------|
| L         | L            | Hold - Retains data in shift register.              |
| L         | Н            | Read - Read contents in register onto data.<br>bus. |
| H         | $\mathbf{L}$ | Shift - Allows serial shifting on next clock        |
| H         | н            | Load - Load data on bus into register               |

The second hardware section is the break detect interrupt circuits (figure 2k). This section is built around an 8259A (U58) interrupt controller chip. This device is produced by Intel and is compatible with the emulator CPU. The 8259A is software programmable and must be intialized by the CPU. The

specific software requirements are discussed in chapter 4. The data bus of the 8259A is connected directly the CPU. It uses the RD\*, WR\*, A0 lines to determine which internal register is being accessed. This chip handles a maximum of eight interrupts based on its programmed priority scheme. Each cascaded break comparator is connected to the interrupt controller through an invertor. When a break is detected the open collector output of the comparator is pulled low, inverted, and applied to U58 (8251A). The low to high transition causes the INT pin to go high. If the CPU's interrupt flag is set the high on its INTR line will initiate an interrupt sequence. The CPU responses by sending two interrupt acknowledge pulses on its INTA line. The 8259A will return a byte after the first interrupt acknowledge specifying which interrupt type has occurred. The second interrrupt acknowledge received is used by the 8259A for internal housekeeping. The CPU uses the interrupt type to determine the address of the break handling routine.

St. M. Hard Sold Street and water of the street at the day

When any one of the break detectors outputs go low the target system must be halted. To accomplish this the output of the break detectors are ANDed together through U62A (7411) and U62B. The output of these gates is ORed with the break control flipflop output and fed through an open collector buffer (U61-B) to the target ready line. If the output of the break control flipflop is low when a break is detected the target system is halted by forcing its ready low. The break control flipflop is controlled by the emulator CPU by setting

and resetting U66-A (7474). To enable the break section an I/O operation is performed to address 00h to clear the break flipflop. To disable the flipflop and I/O operation is perform to address 10h, which sets the flipflop. When the flipflop is set its output is high, which makes U63-B (7432) go high. This prevents the open collector buffer from going low regardless of what the rest of the break detection section is doing. After a break operation has occurred the break detectors automatically clear themselves upon the arrival of the next target address. The CPU interrupt clearing process is handled with software and will be discuss in chapter 4.

### Target 40 Pin Section

The address lines from the target plug MISC1 (12-19 and 21-23) are the output of the target CPU. The 8755 address lines are strobed by the ALE signal and normally do not require latching. Since the 8755 memory section is not being used, two 8282 latches are placed between the MISC1 lines and U10, U11, and U12 address inputs . Target address lines A0 through A7 flow through U29 (8282) and A8 through A10 flow through U30 (8282) (figure 2i). Both latches are strobed by the target CPU ALE (MISC1-11) at the beginning of each cycle. Memory access by the target system is similar to I/O circuit access. When the target system reads memory the control signals are not directed to the 8755, but instead are fed to the user memory chip U18 (UM6116). To allow access by the

target or the emulator multiplexers U10 - U12 (74F157) are used as described in the user memory section. The output enable line is multiplexed through U31, using the read line that also drives the 8755 read input. This provides an accurate control arrangement because the mode flipflop ensures that only one set of control lines are applied to the user memory and 8755 control lines. To ensure that the target system cannot write to the user static ram, the chip select CE1 is ORed with the IO/M\* signal before being applied to the multiplexer input. This controlled chip select is only active when the target is performing a memory read cycle. Since the IOW\* is high during a read cycle this ensures that the ram write enable is at its required inactive state during each read cycle. The write enable signal must be low when the emulator performs a memory write cycle, therefore the WR\* control from U8 (8088) must have access to the ram device. When the mode flipflop is set to allow emulator access, the emulator may read and write the user ram or the parallel ports of the 8755. To prevent bus contention when the target system accesses the ram while the emulator is performing other operations, separate tranceivers were required at the data output of the ram device. The data direction control input to U13 (74F245) is tied to ground so that data may not be moved from the target system to the ram chip. This prevents anyone from maliciously performing a memory write from the target system. The output enable of U13 (74F245) is

controlled by the target read line, which is qualified by the memory chip select described earlier. The normal memory access time of the 8755 is 450 ns and 300 ns for a 8755-2. The 8755-2 is used in the emulator design to ensure that the user may use any currently available version of the 8755 in a circuit design. The control signals and data from the target CPU must flow through a number of support devices for either a memory or I/O operation. For a memory operation U29 and U30 (8282) introduce a 30 ns delay, U10 - U12 (74F157) introduce a 6.5 ns, and U13 (74F245) introduces a 7.5 ns delay. Since U18 is a 150 ns access time static ram, the total memory access time is a maximum of 194 ns. Therefore, the additional hardware is transparent to the target system. During an I/O operation to U36 (8755-2) the additional hardware includes U31 - U33 (74F157) with 6.5 ns delay, and U34 (74F245) with 7.5 ns delay. The 8282 U29 and U30 delay is not encountered during I/O operations, because U36 only requires the A0 address line and this is taken directly off of the target plug.

### Special Function Section

F

The final requirement of the emulator is to provide the user with the ability to single-step the target from the host computer. This process required both hardware and software support. The single-step ability of the emulator is limited to either a step mode or a free-run mode. If the user desires to single-step from a specific location in memory this must

be done by first breaking at that address and then entering the single-step mode.

The target single-step mode is entered when the CPU performs a memory operation to address 40000, thus clearing the single-step mode flipflop U65-B (figure 21). By placing a low on the Q output of U65-B and ORing this with the output of the stepper flipflop U65-A the target is halted after each bus cycle. The stepper flipflop is stepped by an I/O operation at address 20h by the emulator CPU. This signal is used to clock U66-A (7474), which then pulses U63-A (7432). If the single-step mode flipflop output is low, this signal will force the target ready line high. The ready line will remain high until the next target ALE signal goes high. The ALE signal is inverted and applied to the clear input of U65A, which drives the stepper output low. When the stepper output goes low this forces the target ready line low and halts the target CPU. To put the target system in the freerun mode, the emulator CPU performs an memory operation to location 30000. This sets flipflop U65-B and prevents the stepper flopflip from driving the target ready line low.

An additional single-step circuit was built to allow the emulator CPU to be single-stepped (figure 21). This circuit is not used in the normal operation of the emulator, but is provided for the convenience of maintenance to the system. The operation of this stepper is similar to that described for the target. However, the clock pulse for this stepper is generated by switch S2. When S2 is depressed the pulse is

debounced and used to trigger a one-shot multivibrator U45 (74121). Each pulse from S2 produces a positive going squarewave at the output of U45, which then clocks the stepper flipflop U39-A. The stepper flipflop is cleared each bus cycle by the ALE signal. The output of U39-A is Ored with the output of switch S3. If S3 is set to ground the CPU is controlled by the stepper flipflop and halts after each cycle. If S3 is set to VCC the stepper flipflop has no effect since the output of U41-D (7432) is held high. The output of U41-D is fed to the clock generator (U9), synchronized, and applied to the CPU.

a white a second s

The emulator is built on two perforated project boards as which are connected by a 40 pin ribbon cable. The pin connections at both ends of the cable, MISC2 and MISC3, are listed in appendix A. Additionally, table 1 of appendix A lists the parts used to build the emulator. The net wiring list is shown in appendix B.

### IV. THEORY OF OPERATION: SOFTWARE

#### INTRODUCTION

Man Andrew Market States and States

One of the primary enhancement features of the emulator when compared to a standard 8755 is its capability to be controlled from a host computer microcomputer. The hardware to provide this ability was discussed in the last chapter. In this chapter the software to control the emulator system is discussed in detail.

The software necessary to control the emulator may be broken into three separate sections. The first section to be discussed is the emulator bootup routine. The software is situated in the emulator address space such that it is the first code encountered upon system startup. The bootup routine has the responsibility to initialize the emulator. This is accomplished through a series of read and write operations to the proper pieces of hardware. The bootup routine also performs a self-test on its static ram prior to making contact with the host computer. Likewise, the user static ram is tested and any problems reported to the host computer. Finally, the bootup routine must download the main emulator control software and verify to the host computer that the program was received accurately.

The second section of software is the main emulator control software. This program is initially located on the host computer, but is downloaded to the emulator. This

section is responsible for all emulator activity after the initial bootup routine has terminated. The emulator code contains all the flag and message smybols used between the emulator and the host computer. It also contains the software necessary to change any of the hardware originally configured by the bootup routine. The emulator does not actually alter any subsystems without receiving instructions from the host computer. Once the emulator is downloaded it is passed control by the bootup routine. The emulator then awaits further instruction from the user via the host computer.

and the state of the

.

E

E

The third section of software is the host computer emulator control software. This code resides on the host computer and is only usable by the host computer. This program contains all the flags used by the emulator and uses them to pass desired action commands to emulator. Each transaction between the emulator and host computer is preceded by an attention signal, contains a positive or negative acknowledge, and ends with the EOT signal. If the acknowledge message is negative the appropriate error message is display to the user by the host computer.

Each software program has a corresponding flowchart in appendix C and these should be used by the reader during the discussion which follows. The source code listing for each section is in appendix D. The source code contains explanatory comments to aid the reader in interpreting the assembly language code.

#### Bootup Software

Upon startup the CPU outputs address FFFF0 (Table 2) as described in the hardware discussion. This address equates to 707F0 in the emulator address space. At this location the emulator branches to address 70000 and begins its initialization process (figure 3).

The first task accomplished is to halt the target system to ensure that no interference is created between the two CPUs. This is accomplished by performing a memory write cycle to address 40000, which puts the target in its singlestep mode. Here the single-step mode is equivalent to a halt, because the target system cannot advance without a step pulse, which must come from the emulator. The second task to be accomplished is to put the break circuits into their off state. This is accomplished by performing an I/O write cycle to address 0030, which masks out the state of the break detector circuits. This is done to ensure that an erroneous break detect does not occur before the break registers are properly configured. The break section remains disabled until changed by the main emulator program. At this point the target circuits are isolated from the emulator.

The bootup routine now begans to initialize itself for operations with the host computer. The serial port is programmed for asynchronous communication by writing three consecutive zero bytes to put the UART in its worst case

configuration (2). This causes the UART to be set for synchronous operation with two zero bytes for SYNC characters. At this point the UART is reset by writing 40h to the control register. Next, the mode register is loaded with 5Eh, which configures the UART for asynchronous transmission, one stop bit, odd parity, eight data bits, and a baud rate factor of 16. The baud rate factor is used to determine the required clock frequency as:

E

ŗ

Clock frequency = baud rate factor X baud rate (1)

For the emulator the baud rate is 9600 baud, therefore the UART clock frequency is 153.6 Khz. This clock is only used to clock the serial shift registers in the UART. The next byte written to UART goes into the control register. The receiver and transmitter are enabled, error flags cleared, and the data terminal ready pin activated by outputting 37h. At this point the UART may be used to communicate with the host computer.

Before sending or receiving data through the UART its status register must be read and analyzed. Before each transmit operation the status register is read and compared with 01h to see if the transmit register is empty. Prior to each read operation the status register is compared with 02h two see if a new data byte has been received. Bits three four, and five indicate whether a framing, overrun, or parity error has occurred. These flags are used with any transmit or

receive operation to ensure accurate data transfer. For file transfers, proper transmission and receiption of data is also verified by using a checksum counter. The checksum value follows the end-of-file (EOT) during each communication between the emulator and host computer.

المراجع المستحيرة فالمتحالي المتدر فستتكف والمتحال

Į.

Ľ

.

Following the initialization of the UART, the static ram on page zero is tested. To test the ram alternate 00h and FFh bytes are written to all 64 kbytes. At the conclusion of the write cycles each location is read and tested to see if the proper data is there. If an error is found an error counter is incremented and the NACK signal sent to the host computer at the conclusion of the test. If all is well this is sent to the host computer and an acknowledge reply is returned. Once the emulator memory has been tested the user static ram is scanned in the same manner and the results reported to the host computer. If problems are reported the host computer is responsible for advising the user. The bootup routine must have three failures of a given memory section before an error message is sent. At this point the emulator should be reset and the bootup routine run again.

When the all clear is sent to the host computer this is used as a signal to download the emulator program. The starting address for storage is set at 00000 and the emulator will loop until the host computer responds with the download signal. The next byte to be received by the emulator is stored at the first memory location. All subsequent bytes are

stored sequentially until the EOT signal is detected. Each byte received must be tested and also added to the checksum register. When the EOT is found the next byte is compared with the checksum value an if a match is found an acknowledge signal is sent to the host computer. If the checksums do not match the host computer will retransmit the emulator, in response to a NACK signal, and the process is repeated. After three attempts to pass the emulator memory the host computer will display an error message and the emulator resumes testing its memory. If the acknowledge signal was returned the emulator passes control to address 00400 and the bootup routine is terminated.

#### Main Emulator Software

ی برای د در کار به رود شد

The emulator routine starts by waiting in a loop for the host computer to communicate the desires of the user. The host computer provides a series of menus and prompts to communicate with the user. The emulator operates in a passive mode, except that it will signal the host computer if a break condition occurs.

The emulator software provides four basic functions which may be requested by the host computer. Figure 4 shows the basic flow chart arrangement of the emulator code. The emulator waits for the attention signal (++) followed by an ascii character. If a 'U', ascii 55h, is received the user memory procedure is activated and controls the interaction between the host computer and the user memory. If a 'S',

ascii 53h, is received the single-step control procedure is activated. If a 'B', ascii 42h, is received the break control procedure is activated. Finally, if a 'P', ascii 50h, is received the 8755 control procedure is activated. Each procedure returns control to the wait loop upon termination.

## User Memory Control

The user memory procedure allows the user to download the target program to U18, write to a particular location, or read a particular location. All user memory functions must be initiated by and coordinated with the host computer.

When the emulator loop receives a (++U) string the user memory procedure is called (figure 5). Upon activation the procedure returns a ready signal to the host computer. The host computer returns a string which contains a direction flag and the starting address. The emulator stores this string in the user instruction buffer. Next, this string is analyzed to determine what actions to take. If the direction flag is for a download the emulator clears the transmit attempt counter and the checksum register. The emulator then sends the ready signal to the host computer. At this time the host computer begins to download the data. Each byte received is stored in a temporary data buffer until the entire file is verified at the end of the transfer. With each byte received the value of the data is added to the checksum register. This process is continued until the EOT is received. When the EOT

is received the next byte received is interpreted to be the checksum value calculated by the host computer. This value is compared to the emulators checksum and if they match the host computer is sent the acknowledge signal. The emulator then stops the target sytem and changes the user ram circuits to the emulator mode. The data received is transferred to the user ram and the target restarted. If the checksums do not match the NACK signal is returned and the transmit counter is incremented. The transmit counter is compared to three, if the count exceeds three the user procedure is exited. If the transmit counter is less than three the download is repeated. The emulator does not send a retransmit signal to the host computer, because the host computer keeps a separate count of its transmission attempts.

If the string stored after the emulator returns its ready signal is an upload the emulator will follow a course opposite to the one just described. The start address and number of bytes to upload are received from the host computer. The emulator clears its transmit counter and checksum register. Next, the target is halted and the data loaded into the temporary buffer area. The purpose of the buffer is to keep the data on hand for a repeat transmission if an error occurs during the upload. The data is held in the buffer until over written by future transfer operations. After the data is in the data buffer the target is returned to its previous status. The emulator sends the acknowledge

signal to the host computer to indictate that the data is next. Each byte is sent to the host computer and the checksum is tabulated until the proper number of bytes have been uploaded. When the byte limit is reached the emulator will send the EOT, which is then followed by the checksum value. The emulator then waits until an ACK or NACK is received. If the ACK is received the user procedure is exited. If the NACK is received the emulator will increment the transmit counter. If the flag now exceeds three the procedure is exited. The emulator does not handle this error condition since the host computer handles all errors. If the transmit count is less than three the ACK is sent and the data retransmitted. This process is repeated until the data is accurately transferred or the transmit count exceeds three.

# Emulator Mode Control

The emulator mode control procedure is not explicitly called by a host computer command. This routine is accessible only by the emulator, but provides service to various host computer commands. For example, the user memory operation uses this procedure during the its memory reads and writes to disable the target section. This procedure simply uses the mode flag to either put the emulator multiplexers in the target or emulator mode. If the target mode is desired a memory 20001 write is executed. Conversely, if the emulator mode is desired the memory write goes to 20000. In either case the mode flag is set to the proper status and the

procedure is exited, with control returning to the calling procedure.

# Single-step Control

States and the second

Г

Ł

The single-step procedure is called when the emulator waiting loop receives the (++S) string (figure 6). The procedure responds by sending the ready signal. The host computer then sends the desired action code, which may be to enable the stepper, to put the target in the free-run mode, or to step the target. If the enable code is received the emulator performs a memory write to address 40000, updates the single-step flag, sends the ACK signal, and returns to the waiting loop. If the free-run code is received the emulator performs a memory write to address 30000, updates the single-step flag, sends the ACK signal, and returns to the waiting loop. If the action code is to step the target circuit the emulator checks the single-step status to ensure that the stepper is in the step mode. If the mode is set to step the emulator writes to I/O address 0020, returns the ACK signal, and then returns to the waiting loop. If the mode is set to free-run the emulator returns the NACK signal and exits the procedure.

#### Break Control

The emulator break circuits are controlled by a combination of the bootup routine and this emulator procedure. The bootup routine took care of initializing the

8259A and inhibiting the break circuits. This procedure is used to load the break registers, enable or disable the break circuits.

When the emulator waiting loop receives the (++B) string it calls this procedure (figure 7). A ready signal is immediately returned to the host computer. The host computer then sends a code to enable, disable, or download to the break registers. If the action desired is to enable the break detection circuits the emulator writes to I/O address 0000. The break flag is updated and then the ACK signal is returned. If the action desired is to disable the break circuits the emulator will write to I/O address 0010. The break status flag will then be updated and the procedure exited.

If the user desires to load the break registers the download signal is used. Following the ready signal to the host computer the emulator clears its checksum register and sends another ready signal. The data bytes received will be placed in the break address buffer until the EOT is detected. Once this flag is received the next byte will be compared to the emulator checksum value. If the checksums match the break circuits are disabled, the break register are loaded, and the break circuits then enabled. Next, the break status flag is updated and the ACK signal returned to the host computer. The procedure then returns to the waiting loop. If the checksums

do not match the NACK signal is returned and the procedure is exited.

When the 8259A receives an interrupt from the break detectors it must direct the response of the CPU. Regardless of which break address is detected the 8259A will respond with an interrupt request to the emulator CPU. The CPU responds by sending two interrupt acknowledge signals, which causes the 8259 to output the interrupt type number. The type ranges from 8 through 12 and is calculated by the 8259A based on the setting of its IRO-IR2 bits (figure 8). These bits are combined with 00001b to indicated the proper type number. Each interrupt type is used to vector to the interrupt handler code address. Each interrupt handler simply moves its type number to the interrupt hold register. The interrupt hold register is simply a memory location used for parameter passing. Each interrupt handler then passes control to the break reporting procedure. This procedure sends the (++B) string and waits for the ACK signal. When the ACK is received the emulator sends the interrupt number in the interrupt hold register. The emulator will wait for instructions from the emulator before resetting the break circuits. If the host computer indicates that the break procedure should be left as is the circuits are disabled and the status flag updated. If the reset command is received the break circuit is disabled and then enabled to reset them. The the enable/disable sequence is required to allow the break address comparators

to overwrite the last address. With either of the above actions the break loading procedure is exited.

# 8755 I/O Control

The emulator initiates a call to the 8755 control procedure upon receiving the (++P) control signal. This procedure is used to read or write to the target circuit ports and to reconfigure the bit assignments (figure 9). The procedure responds to its call by returning the ready signal to the host computer. Next, the host computer sends the direction flag followed by a port number. If the direction flag indicates an upload, the port number will be to port A or B only. In either case the emulator will hold this infomation in a temporary register. The target system is halted and the mode changed to the emulator. The selected port is read, the data is moved to the temporary register, and the target restarted. The emulator clears its checksum and the transmit counter, then sends the ready signal. The data byte is then uploaded, followed by the EOT and checksum. The emulator then waits for the ACK from the host computer. If the ACK is received the procedure is exited. In the event the NACK is received the transmit counter is increment and compared to three. If the count does not exceed three the transmission process is repeated. If the count does exceed three the procedure is simply exited. When the direction flag indicates a download it is possible for the data to go to the ports or to the data direction registers. The host computer

sends the port number after receiving the ready signal. The emulator halts the target, clears its checksum, and clears the transmit counter. The emulator sends the ready signal again to indicate it is ready for the data byte. The data is received and held until after the checksum is verified. After verification the data is loaded into the appropriate register and the ACK signal is returned. The emulator then restarts the target and returns control to the waiting loop. If the checksum is not correct the emulator performs the usual three tries then terminates.

### Host Computer Control Software

The host computer program serves as the interface between the emulator and the user. Most of the actions taken by the host computer will be initiated by the user. However, there are two cases when this is not true. When the system is started the emulator memory is downloaded without user intervention. The other case is in the event of a break address detection. In general the user is prompted for an input and the response is then transmitted to the emulator. The flowchart for this portion of the system programs is located in figure 10.

Upon startup the host computer program displays a welcome message and advises the user to standby. The program then monitors the serial port for two ACK signals from the emulator. One ACK is for the emulator SRAM and the other is

for the target SRAM. If either signal is replaced by the NACK signal the host computer displays an error message and the user should reboot.

When the ACK signals are received the emulator clears its transmit and checksum counters. The host computer sends the download signal, followed by the emulator program. The emulator program is then verified using the checksum method. If the program receives the NACK instead of the ACK, the transmit counter is incremented and the emulator code retransmitted. This is repeated up to three times before an error condition is assumed. If an error condition does turn out to be the case the program displays an error message advising the user to reset the emulator and host computer program. If the emulator program is successfully downloaded the wait prompt is removed and the setup menu is displayed. The display will also contain the status of the single-step, system mode, and break circuits. The single-step will be in the step mode, the system mode set to system, and the break circuits disabled. This is the initial system configuration. These statuses will be displayed anytime the setup or main menus are displayed. They are also displayed individually when their corresponding submenus are displayed.

The user must address each section of the setup menu that is intended to be used. Generally, all three areas should be setup, but this is not required if only partial operations are planned. In any case the program waits for the user

selection and then branches to the proper procedure. Each procedure will return control to the setup menu and the user will eventually need to select item (d) to escape the setup menu. Selections a, b, and c each handle a specific emulator feature and their operation are discussed next.

# Pass User Memory

When item (a) is selected the user memory module is called (figure 11). The program sets a flag which indicates which menu was currently in used prior to the call. This flag will be used later to ensure the user display contains the same menu when the module is exited. The user is then given the following set of options.

User Memory Menu:

a. Down load target memory

b. View target memory location

c. Edit target memory location

d. Exit

Which offers the choice of downloading the target memory, viewing a particular memory location, or edit a target location. When the download target option is chosen the user is prompted for the filename, starting and ending addresses. The starting address is use to inform the emulator of which address in the user ram to load the program. The ending address is used to determine when the EOT should be sent to the emulator, but this address is never sent to the emulator.

After receiving this information the procedure uses MS-DOS function calls to open and read the user program into a temporary 2 kbyte buffer. This buffer is maintain at all times after the initial data read. The user must have this buffer loaded before option (b) may be accurately employed. The reason for this restraint is that if the view option is selected the user is shown what is in the temporary user buffer and not what is in the user memory chip. Once the buffer is loaded the program will clear its transmit counter and checksum register. The emulator is sent the (++U) signal and the program then waits on the ready response. The emulator responds with the ready signal and then awaits the direction flag and starting address. When this information is received the emulator sends another ready and the download is accomplished. When the byte count has been reached the program inserts the EOT, and then sends the checksum value. If all went well the emulator will return the ACK signal and the transfer is terminated. In this case the calling menu is displayed. If the NACK signal is received the download is attemped two more times. If the download still has not succeeded the user is informed via an error message display. At this point the entire system should be reset an the download attempted again.

The view target memory option is provided so that the user can look at changes which may have been made to the user memory. It is not designed to alter the user memory since

this requires the target to be halted. If the user does desire to alter the user memory the edit option should be used. The best way for the user to keep track of all changes is to keep the code listing available and to annotate all changes. When the viewing option is selected the user is again prompted for the starting address within the user memory (buffer) area and ending address. The user may view a maximum of 20 consecutive locations at a time. The information will be displayed by location and content. The edit option allows the user to change the data at a given location within the target memory. The maximum number of locations which may be edited is ten. This number is arbitrary, but should be adequate for testing purposes. If the user wishes to do extensive editing the most efficient method is to make the changes at the assembly level and reload the user program. When the edit option is selected the user is prompted for the starting address and byte count. The program setups up the temporary edit buffer and clears its byte counter. The user is then prompted for the new data, which must be entered in consecutive locations. If more than five bytes are attempted the user is informed of the error and the calling menu is displayed. In order for the user to accomplish additional editing the same sequence of steps just described must be accomplished. After the user has entered the new data the carriage return is require to download the data. The download procedure is the same from here on as in

and the second states and a second state of the second states

the case of a total user memory download. The temporary user buffer is updated with these changes and the procedure returns control to the calling menu. If the user is performing the original user download it is suggested that the break circuits are configured next. This procedure is discussed in the next section.

#### Break Control Module

С

If the user selects item (b) from the setup menu or items (b) or (c) of the main menu, the break control procedure is entered (figure 12). The procedure displays the following break menu.

Break Control Menu:

- a. Enable break detection
- b. Disable break detection
- c. View break addresses
- d. Change break addresses
- e. Exit break menu

If the user is still setting up the emulator then item (d) should be selected. This is the option to choose to edit the the break registers at any time. When item (d) is selected the user is prompted for the register number, which ranges from 1 to 5. When the desired register is entered the user is prompted for the break address. The break registers consist of two separate registers, but the user may simply enter a three character hex address. This address will be

separated by the program and stored in the break buffer area. All break addresses must fall within the legal memory space of the target ram. These addresses range from XX7FF to XX000 from the target perspective. After each address is entered the user is asked if further address changes are desired. If the reply is yes the process is repeated as many times as the user desires. If the ceply is no the emulator is sent the (++B) signal and the normal download process is carried out. The break control menu is displayed and the user may select another option or exit this menu. If the break register download was unsuccessful the user is informed and the break menu exited. The user may try again from the original calling menu. Whenever the break menu is displayed the current status of the break circuit on the emulator is automatically displayed and any changes to the status are automatically updated. To enable the break circuits to monitor the target, the user simply selects item (a) from the break menu. The user must ensure that the break registers have be previously set because the emulator will break on any address match it detects. To disable the break circuits the user simply selects item (b) and the rest is handled automatically. For the enable or disable option the host computer sends the emulator the break control signal, which is followed by the desired change flag. If the user desires to view the current break register contents then option (c) is entered and the local break addresses are displayed. The user should always

note the current status of the break circuits before sending changes to the emulator. There final option on the setup menu is to configure the parallel I/O ports. This setup is not necessary for normal operations, since the user program will do this. The option is provide to give the user added flexiblility and is discussed in the next section.

### Parallel Port Control

The user of a normal 8755 I/O chip often uses the device for its flexible ports, rather than for the memory it contains. To allow the user full flexibility during circuit testing, the emulator allows all of the original 8755 capabilities and also permits altering the target ports while the target CPU is in a halt state. This feature will be useful for pulsing circuits connected to the target, reading the data at the ports after execution of an instruction, and changing the data direction registers.

To access the parallel port procedure the user may select item (c) of the setup menu or item (d) from the main menu. When activated the procedure displays the port menu:

Port Menu:

- a. Read port A
- b. Read port B
- c. Write port A
- d. Write port B
- e. View/Reconfigure port A DDR

f. View/Reconfigure port B DDR

g. Exit port control memu

State manta water and an end of the second of a second

If the user selects items (a) or (b) the host computer sends the (++P) signal and awaits the ready signal from the emulator (figure 13). When the ready is received the port number corresponding to the user selection is sent. The emulator responds with a byte of data retrieved from the 8755 port. The host computer then sends the ACK signal and displays the port number and data to the user. If item (c), (d), (e), or (f) is selected the user is prompted for the data to send to the emulator. The data is placed in a temporary buffer and the emulator is sent the port operation flag. The emulator returns the ready flag and waits on the direction flag and returns the ready signal. The host computer now sends the data and port number. When the write operation is complete the emulator returns the ACK and the transaction is complete. The port menu will be displayed and the user may enter the next selection. If item (g) is selected the user is returned to the calling menu. After the setup process is initially completed the user does not need to return to this menu. The main menu has access to all the submenus discussed thus far and this is where normal operations are initiated.

#### Main Menu Control

The main menu is entered from the setup menu and may control the entire emulator during a session. The reason for the setup menu was simply to ensure the user remembers to go through the setup procedure. The main menu uses the same procedures as the setup menu, but the user may not go from the main menu to setup menu. The main menu maintains the status of the target (system/target) the break detectors (enabled/disabled), and the stepper circuit (step/free-run).

When the system is brought up the target is halted by the bootup routine and the break circuits are configured during the host computer initializtion of the target. Both should be left disabled until after the setup operation is complete. Therefore, when the main menu is initially displayed the user should enable the break detects before enabling the target. This ensures that the target is still at its starting address when the break monitoring begans. After the initial start the breaks may be enabled or disabled at any time, but the user will have to keep track of the target address. One way to do this is to enter the single step mode before enabling the break detectors. Other than these precautions the user may select from the main menu freely.

Only options (a), (b), and (d) have not been discussed from the host computer perspective. Option (a) allows the user to start or stop the target at any time (figure 14). To do this the user is prompted for the desired action after (a)

is entered. The command is sent to the emulator and executed. The emulator returns the ACK signal to verify the completion of the requested action. The host computer informs the user of the completion, updates target status flag, and returns to the main menu. If item (b) is entered the user is again prompted for the desired mode and the command is carried out. If item (d) is entered the process is a bit more involved.

In response to the single step selection the host computer displays the single-step menu:

Single-step Menu:

- a. Start single-step mode
- b. Step target
- c. Exit single-step mode
- d. Main menu

From this menu the user may enable or disable the stepper circuits, single-step the target if the stepper is enabled, or return to the main menu. The user should note the status of the target before attempting to single step it. If the user selects item (a) or (c) the host computer checks the status flag and if it is the opposite of the requested mode the command is executed. If the requested status already exists the program simply displays the single-step menu. If the user desires to step the target, the mode should be checked an set to "step" if not already in that mode. If the user fails to do this then an error message will be displayed

and the single-step menu displayed after a brief delay. If the target is in the step mode, a request to step will be executed on command. The host computer sends the (++S) flag and receives the ready reply. The step flag is then sent to the emulator, which executes one step and returns the ACK signal for verification. After each step the host computer informs the user and loops back to the single-step menu. The user may select item (d) if other options on the main menu are desired while in the single-step mode. The other options may then be executed and the main menu used to get back to the single-step menu. For example, if the user has entered the single step mode and now desires to disable the break circuit the following action is require. Enter (d) on the single-step menu, select (b) on the main menu, then select (b) on break menu, select (e) on the break menu, and (d) on the main menu to return to the single-step menu. This type of process is necessary if something besides the single-step options is desired while in the single-step mode. Normally, the user would only need to enter (b) to step the target from the single-step mode. Once the user leaves the single-step mode the single-step menu is removed and control is returned to the main menu. From the main menu all emulator features may again be accessed. Figure 15 maintains the current status of the mode flag and informs the emulator of any desired change to the emulator's mode setting.

กระเพิ่มรับสินที่สาย และ เพราะ เกมา เป

#### V. Recommendations

and and the first test have been all all and and and a set

The 8755 emulator provides the user with several features which are not available with the standard 8755 device. These features allow the user of the emulator to test and troubleshoot circuits more efficiently. The emulator's usefulness could be increased still further with some additional changes.

One aspect of using the emulator which needs to be improved involves its hardware setup. This involves making connections to several external devices. The +5 VDC, +12 VDC, and -12VDC power supplies should be built into the emulator to increase the mobility of the device. The 5 volt supply requires 4.2 amperes, which has required connecting two power supplies in parallel in the past. This could be annoying to students moving the emulator from one work station to another. The emulator currently does not need forced air cooling, but this is recommended if a built-in power supply is added.

The UART's transmit and receive clock signals are also provided by an external source. These signals are currently running at the same frequency and are tied together inside the emulator. For convenience this signal could be derived from an onboard oscillator or clock chip. For still greater flexibility the receive and transmit clocks should be independent of each other. These changes to the serial port section would allow the emulator to connect to a wider variety of devices. The emulator hardware and software is not

Z-100 dependent and will work with any device which sends the proper flags and messages. One limitation of the serial port is the requirement for asynchronous communications. The UART used is capable of synchronous operations, but this will require modification to the serial port initialization routine and minor hardware changes.

مراجع المراجع المراجع

The number of break addresses which may be monitored simultaneously is currently five. While this is a limited number of addresses, it is not recommend that additional address monitors be added. Each break address requires the addition of two register/comparators and ten logic gates. Additionally, if more than three address monitors are added an additional interrupt handler is required. Therefore, if a significant number of new break address handlers are desired the user should considered a different approach.

Finally, future units of the emulator should use printed circuit boards instead of the wire wrapping method. The emulator uses a large number of microchips and the density of the interconnect wiring is high. This caused crosstalk problems during the design of the emulator. With a well designed printed circuit board this problem would be less noticeable and hence the emulator more reliable.

# Appendix A: Hardware Diagram

حة فترشع عربدهما عمامه

and the second



and the second second

Figure 1. Emulator Block Diagram



and a second second

E

Þ

•





Manual and an added the Case and Income an Income

the first





الله الرودية المرابعة مريد فسيتعط

Ľ

Ŧ

Figure 2c. Schematic Diagram

\_

\_



المحادية والمشاولين بدائا عطر ممكنهما وهواريها و

E

Ľ

Figure 2d. Schematic Diagram

73

2

Ī

Ī

-



Figure 2e. Schematic Diagram



Contraction diversion of the

-

.

Figure 2f. Schematic Diagram



and and the second of the second second second second





وأحبدت بالقصيدات وللمساد فاصبط

Figure 2h. Schematic Diagram



and a start of the start of the

Figure 2i. Schematic Diagram



°\_ · ·

the stand in the second states and the second states at the

·..

Figure 2j. Schematic Diagram



العامد والمعمقصا معتما المح

.





Same and the second second

Ę

C.

ľ

.

, ,

Figure 21. Schematic Diagram

| PART                       | NAME                               | BOARD       | PINS     |
|----------------------------|------------------------------------|-------------|----------|
| U1 1488                    | RS232 DRIVER                       | 2           | 14       |
|                            | RS232 RECEIVER                     | 2           | 14       |
|                            | UART                               | 2           | 28       |
|                            | TRANSCEIVER                        | 2           | 20       |
| U5 8205                    | DECODER                            | 1           | 16       |
|                            | LATCH                              | 1           | 20       |
|                            | LATCH                              | 1           | 20       |
|                            | CPU                                | ĩ           | 40       |
|                            | CLOCK                              | 1           | 18       |
|                            | 2-TO-1 MULTIPLEXOR                 |             | 16       |
| U11 74F157A                | 2-TO-1 MULTIPLEXOR                 |             | 16       |
| U12 74F157A                | 2-TO-1 MULTIPLEXOR                 |             | 16       |
| U13 74F245                 | FAST TRANSCEIVER                   | 1           | 20       |
| U14 74F245                 | FAST TRANSCEIVER                   | 1           | 20       |
| U15 MSM51257               | 32Kv8 SRAM                         | 1           | 28       |
| U16 MSM51257               | 32Kx8 SRAM<br>32Kx8 SRAM           | 1           | 28       |
| U17 2716                   | 2Kx8 EEPROM                        | 1           | 24       |
|                            | 2Kx8 SRAM                          | 1           | 24       |
|                            | FAST REG/COMPARATOR                | 1<br>2      | 24       |
|                            | FAST REG/COMPARATOR                | 2           | 20       |
|                            | FAST REG/COMPARATOR                | 2           | 20       |
|                            | FAST REG/COMPARATOR                |             | 20       |
|                            | FAST REG/COMPARATOR                | 2           | 20       |
|                            | •                                  | 2           |          |
|                            | FAST REG/COMPARATOR                |             | 20       |
| U28 74F524                 | FAST REG/COMPARATOR                | 2<br>1      | 20       |
| U29 8282                   | LATCH                              | 1           | 20       |
|                            | LATCH                              | 1           | 20       |
| U31 74F157A<br>U32 74F157A | FAST 2-TO-1 MUX                    | 1           | 16       |
|                            | FAST 2-TO-1 MUX<br>FAST 2-TO-1 MUX |             | 16       |
|                            | FAST 2-TO-1 MUX                    | 1           | 16       |
| U34 /4F240<br>N25 742045   | FAST TRANSCEIVER                   | 1<br>1<br>1 | 20       |
| U35 74F245<br>U36 8755     | FAST TRANSCEIVER<br>I/O ROM        | 1           | 20<br>40 |
| U37 7404                   | HEX INVERTOR                       | 1           | 14       |
| U38 74154                  | 4-TO-16 DECODER                    | 2           | 24       |
| U39 7474                   | DUAL D-FF                          | 1           | 14       |
| U40 7432                   | QUAD-2 INPUT OR                    | 1           | 14       |
| U41 7432                   | QUAD-2 INPUT OR                    | 1           | 14       |
| U42 74F157                 | 2-TO-1 MUX                         | 1           | 16       |
| U43 74F157                 | 2-TO-1 MUX                         | 1           | 16       |
| U44 74F157                 | 2-TO-1 MUX                         | 1           | 16       |
|                            | E TO T MOX                         | ±           | 10       |

a para na serie de la companya de la

Table 1a. Parts List

| U45 74121         | ONE SHOT MULTI       | 1      | 14 |
|-------------------|----------------------|--------|----|
| U46 7400          | QUAD 2-IN NAND       | 2      | 14 |
| U47 7404          | HEX INVERTOR         | 2      | 14 |
| U48 7404          | HEX INVERTOR         | 2      | 14 |
| U49 7408          | QUAD-2 IN AND        | 2      | 14 |
| U50 7 <b>4</b> 08 | QUAD-2 IN AND        | 2      | 14 |
| <b>U51 7408</b>   | QUAD-2 IN AND        | 2      | 14 |
| U52 7400          | QUAD-2 IN NAND       | 2      | 14 |
| <b>U53 7408</b>   | QUAD-2 IN AND        | 2      | 14 |
| <b>U54 7408</b>   | QUAD-2 IN AND        | 2      | 14 |
| <b>U55 7408</b>   | QUAD-2 IN AND        | 2      | 14 |
| U56 7 <b>4</b> 00 | QUAD-2 IN NAND       | 2      | 14 |
| U57 7 <b>4</b> 08 | QUAD-2 IN AND        | 2      | 14 |
| U58 8259A         | INTERRUPT CONTROLLER | 2      | 28 |
| <b>U59 7408</b>   | QUAD-2 IN AND        | 2      | 14 |
| U60 7 <b>4</b> 07 | HEX BUFFER (OC)      | 2      | 14 |
| U61 7 <b>4</b> 09 | QUAD-2 IN AND (OC)   | 1      | 14 |
| U62 7 <b>4</b> 11 | TRIPLE-3 IN AND      | 2      | 14 |
| U63 7 <b>4</b> 32 | QUAD-2 IN OR         | 1      | 14 |
| U64 7404          | HEX INVERTER         | 2<br>1 | 14 |
| U65 7474          | DUAL D FLIPFLOP      |        | 14 |
| U66 7474          | DUAL D FLIPFLOP      | 2      | 14 |

· · ·

### MISCELLANEOUS PARTS

| MISC1 | 40 PIN USER PLUG SOCKET         |
|-------|---------------------------------|
| MISC2 | 40 PIN BOARD CONNECTOR # 1      |
| MISC3 | 40 PIN BOARD CONNECTOR # 2      |
| MISC4 | 20 PIN COMPONENT HOLDER BOARD 1 |
| MISC5 | 20 PIN COMPONENT HOLDER BOARD 2 |
| J1    | RS232 CONNECTOR                 |
| J2    | +5 VOLT INPUT                   |
| J3    | +12 VOLT INPUT                  |
| J4    | -12 VOLT INPUT                  |
| J5    | COMMON GROUND INPUT             |
| S1    | RESET SWITCH                    |
| S2    | EMULATOR STEPPER CONTROL        |
| S3    | EMULATOR STEPPER SWITCH         |
|       |                                 |

Table 1b. Parts List

Appendix B: Net Wiring List

E

P.

F

. . .

| U-1                                                                     | 1488 DRIVER   |                                                                                                                             |
|-------------------------------------------------------------------------|---------------|-----------------------------------------------------------------------------------------------------------------------------|
| 1<br>2<br>3<br>4<br>5<br>6<br>7<br>8<br>9<br>10<br>11<br>12<br>13<br>14 |               | -12 VDC<br>U3-19<br>RE232-2<br>U3-23<br>U3-23<br>RS232-4<br>GND<br>NC<br>NC<br>NC<br>RS232-20<br>U3-24<br>U3-24<br>+12 VDC  |
| U-2                                                                     | 1489 RECEIVER |                                                                                                                             |
| 1<br>2<br>3<br>4<br>5<br>6<br>7<br>8<br>9<br>10<br>11<br>12<br>13<br>14 |               | RS232-5,MISC5-1<br>NC<br>U3-17<br>RS232-3<br>NC<br>U3-3<br>GND<br>NC<br>U3-22<br>RS232-6<br>NC<br>NC<br>NC<br>NC<br>+12 VDC |
| U-3                                                                     | 8251A UART    |                                                                                                                             |
| 1<br>2<br>3<br>4<br>5<br>6<br>7<br>8<br>9<br>10<br>11                   |               | U4-3<br>U4-4<br>U2-6<br>GND<br>U4-5<br>U4-6<br>U4-7<br>U4-8<br>153.6 Khz<br>CT2-19<br>U38-6                                 |

| 1.0 |             |
|-----|-------------|
| 12  | CT2-19      |
| 13  | CT2-20      |
| 14  | NC          |
| 15  | NC          |
| 16  | NC          |
| 17  | U2-3        |
| 18  | NC          |
| 19  | U1-2        |
| 20  | CT2-16      |
| 21  | CT2-18      |
| 22  | U2-9        |
| 23  | U1-4,U1-5   |
| 24  | U1-12,U1-13 |
| 25  | 153.6 Khz   |
| 26  | +5 VDC      |
| 27  | U4-1        |
| 28  | U4-2        |
|     |             |

ي والأند الأكس

| U-4                                                                                                         | 8286 | TRANSCEIVER |                                                                                                                                                                                                         |
|-------------------------------------------------------------------------------------------------------------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1<br>2<br>3<br>4<br>5<br>6<br>7<br>8<br>9<br>10<br>11<br>12<br>13<br>14<br>15<br>16<br>17<br>18<br>19<br>20 |      |             | $\begin{array}{c} U3-27\\ U3-28\\ U3-1\\ U3-2\\ U3-5\\ U3-6\\ U3-7\\ U3-8\\ U38-6\\ GND\\ U48-10\\ CT2-8\\ CT2-9\\ CT2-10\\ CT2-11\\ CT2-12\\ CT2-13\\ CT2-13\\ CT2-14\\ CT2-15\\ +5 \ VDC \end{array}$ |
| U-5                                                                                                         | 8205 | DECODER     |                                                                                                                                                                                                         |
| 1                                                                                                           |      |             | U7-19                                                                                                                                                                                                   |

| 1 | U7-19  |
|---|--------|
| 2 | U7-18  |
| 3 | U7-17  |
| 4 | GND    |
| 5 | U8-28  |
| 6 | +5 VDC |
| 7 | U17-18 |
|   |        |

\_

| 8  | GND         |
|----|-------------|
| 9  | U12-10      |
| 10 | NC          |
| 11 | NC          |
| 12 | NC          |
| 13 | NC          |
| 14 | NC          |
| 15 | U40-1,U40-4 |
| 16 | +5 VDC      |
|    |             |

#### U-6 8282 LATCH

· .

E

| 1  | CT1-15 |
|----|--------|
| 2  | CT1-14 |
| 3  | CT1-13 |
| 4  | CT1-12 |
| 5  | CT1-11 |
| 6  | CT1-10 |
| 7  | CT1-9  |
| 8  | CT1-8  |
| 9  | GND    |
| 10 | GND    |
| 11 | U8-25  |
| 12 | CT1-28 |
| 13 | CT1-27 |
| 14 | CT1-26 |
| 15 | CT1-25 |
| 16 | CT1-24 |
| 17 | CT1-23 |
| 18 | CT1-22 |
| 19 | CT1-21 |
| 20 | +5 VDC |
|    |        |

| U-7    | 8282 LATCH |               |
|--------|------------|---------------|
| 1      |            | U8-38         |
| 2      |            | U8-37         |
| 3      |            | U8-36         |
| 4      |            | NC            |
| 4<br>5 |            | NC            |
| 6      |            | NC            |
| 7      |            | NC            |
| 8      |            | NC            |
| 9      |            | GND           |
| 10     |            | GND           |
| 11     |            | <b>U8-</b> 25 |
| 12     |            | NC            |
| 13     |            | NC            |
| 14     |            | NC            |

| 15 | NC     |
|----|--------|
| 16 | NC     |
| 17 | U5-3   |
| 18 | U5-2   |
| 19 | U5-1   |
| 20 | +5 VDC |

.

U-8 8088-2 CPU

و المراجع المحمول المحمول المحمول

C

C

1.

I

| 1  | GND                           |
|----|-------------------------------|
| 2  | U15-1,U16-1                   |
| 3  | U15-26,U16-26                 |
| 4  | U15-2, U16-2                  |
| 5  | U15-23, U16-23                |
| 6  | U17-19,U15-21,U16-21,U12-3    |
| 7  | U17-22, U15-24, U16-24, U12-6 |
| 8  | 017-23,012-13,015-25,016-25   |
| 9  | U6-8, U4-12, U14-9, U35-9     |
| 10 |                               |
| 11 | U6-7, U4-13, U14-8, U35-8     |
| 12 | U6-6, U4-14, U14-7, U35-7     |
|    | U6-5, U4-15, U14-6, U35-6     |
| 13 | U6-4,U4-16,U14-5,U35-5        |
| 14 | U6-3,U4-17,U14-4,U35-4        |
| 15 | U6-2,U4-18,U14-3,U35-3        |
| 16 | U6-1,U4-19,U14-2,U35-2        |
| 17 | GND                           |
| 18 | CT1-22                        |
| 19 | U9-8                          |
| 20 | GND                           |
| 21 | U9-10                         |
| 22 | U9-5                          |
| 23 | GND                           |
| 24 | CT1-23                        |
| 25 | 06-11,07-11,037-11            |
| 26 | U41-1                         |
| 27 | U35-1,U14-1                   |
| 28 |                               |
| 29 | U33-6,U5-5,CT1-17             |
| 30 | CT1-19                        |
|    | NC                            |
| 31 | GND                           |
| 32 | CT1-20                        |
| 33 | +5 VDC                        |
| 34 | NC                            |
| 35 | NC                            |
| 36 | U7-1                          |
| 37 | U7-2                          |
| 38 | U7-3                          |
| 39 | U37-1,U40-4                   |
| 40 | +5 VDC                        |
|    |                               |

-

| U-9                                                                                             | 8284 CLOCK          |                                                                                                                                                                                |
|-------------------------------------------------------------------------------------------------|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1<br>2<br>3<br>4<br>5<br>6<br>7<br>8<br>9<br>10<br>11<br>12<br>13<br>14<br>15<br>16<br>17<br>18 |                     | GND<br>CT1-16<br>GND<br>U41-11<br>U8-22<br>GND<br>+5VDC<br>U8-19,U32-3<br>GND<br>U8-21,U31-6,CT1-18<br>MISC4-16 & 17<br>NC<br>GND<br>NC<br>GND<br>CRYSTAL<br>CRYSTAL<br>+5 VDC |
| U-10                                                                                            | 74F157A MULTIPLEXER |                                                                                                                                                                                |
| 1<br>2<br>3<br>4<br>5<br>6<br>7<br>8<br>9<br>10<br>11<br>12<br>13<br>14<br>15<br>16             |                     | U39-8<br>U29-19<br>U6-19<br>U18-8<br>U29-18<br>U6-18<br>U18-7<br>GND<br>U18-5<br>U6-16<br>U29-16<br>U18-6<br>U6-17<br>U29-17<br>GND<br>+5VDC                                   |
| U-11                                                                                            | 74F157A MULTIPLEXER |                                                                                                                                                                                |
| 1<br>2<br>3<br>4<br>5<br>6<br>7<br>8<br>9<br>10                                                 |                     | U39-8<br>U29-15<br>U6-15<br>U18-4<br>U29-14<br>U6-14<br>U18-3<br>GND<br>U18-1<br>U6-12                                                                                         |

\*\*

τ.

| U29-12 |
|--------|
| U18-2  |
| U6-13  |
| U29-13 |
| GND    |
| +5VDC  |
|        |

# U-12 74F157A MULTIPLEXER

| 1  | U39-8  |
|----|--------|
| 2  | U30-19 |
| 3  | U8-8   |
| 4  | U18-23 |
| 5  | U30-18 |
| 6  | U8-7   |
| 7  | U18-22 |
| 8  | GND    |
| 9  | U18-18 |
| 10 | U5-9   |
| 11 | U40-8  |
| 12 | U18-19 |
| 13 | U8-6   |
| 14 | U30-17 |
| 15 | GND    |
| 16 | +5VDC  |

### U-13 74F245 DATA LATCH

| 1<br>2<br>3<br>4<br>5<br>6<br>7<br>8<br>9<br>10<br>11<br>12<br>13<br>14<br>15 | GND<br>MISC1-12<br>MISC1-13<br>MISC1-14<br>MISC1-15<br>MISC1-16<br>MISC1-17<br>MISC1-18<br>MISC1-19<br>GND<br>U18-17,U34-9<br>U18-16,U34-8<br>U18-15,U34-7<br>U18-14,U34-6<br>U18-13,U34-5 |
|-------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                                               |                                                                                                                                                                                            |
|                                                                               |                                                                                                                                                                                            |
|                                                                               |                                                                                                                                                                                            |
| 16                                                                            | U18-11,U34-4                                                                                                                                                                               |
| 17                                                                            | U18-10,U34-3                                                                                                                                                                               |
| 18                                                                            | U18- 9,U34-2                                                                                                                                                                               |
| 19                                                                            | U40-11                                                                                                                                                                                     |
| 20                                                                            | +5VDC                                                                                                                                                                                      |
|                                                                               |                                                                                                                                                                                            |

## U-14 74F245 DATA LATCH

| 1<br>2<br>3<br>4<br>5<br>6<br>7<br>8<br>9<br>10<br>11<br>12<br>13<br>14<br>15<br>16<br>17<br>18<br>19<br>20                                                 |          |      | U8-27<br>U8-16<br>U8-15<br>U8-14<br>U8-13<br>U8-13<br>U8-12<br>U8-11<br>U8-10<br>U8-9<br>GND<br>U18-17<br>U18-16<br>U18-15<br>U18-14<br>U18-13<br>U18-11<br>U18-10<br>U18-9<br>U41-6<br>SVDC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| U-15                                                                                                                                                        | MSM51257 | SRAM |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 1<br>2<br>3<br>4<br>5<br>6<br>7<br>8<br>9<br>10<br>11<br>12<br>13<br>14<br>15<br>16<br>17<br>16<br>19<br>20<br>22<br>23<br>24<br>56<br>27<br>28<br>27<br>28 |          |      | y8-2         y8-4         y6-12         y6-13         y6-14         y6-15         y6-16         y8-16         y8-16         y8-16         y8-17         y8-18         y8-19         y8-10         y8-12         y8-13         y8-14         y8-15         y8-16         y8-17         y8-18         y8-19         y8-10         y8-13         y8-14         y8-15         y8-16         y8-17         y8-18         y8-19         y8-10         y8-10         y8-11         y8-10         y8-10         y8-11         y8-10         y8-10 </td |

and the second state of th

بهاجهريا أناج المأا بالرفد بالا

8

Þ

Start day in a subsect france in a constant of the sector of the

#### U-16 MSM51257 SRAM

\_\_\_\_\_

| 1           | U8-2         |
|-------------|--------------|
| 2           | U8-4         |
| 3           | U6-12        |
| 4           | U6-13        |
| 5           | U6-14        |
|             | U6-15        |
| 6<br>7<br>8 | U6-16        |
| 8           | U6-17        |
| 9           | U6-18        |
| 10          | U6-19        |
| 11          | U8-16        |
| 12          | <b>U8-15</b> |
| 13          | U8-14        |
| 14          | GND          |
| 15          | U8-13        |
| 16          | U8-12        |
| 17          | U8-11        |
| 16          | U8-10        |
| 19          | U8-9         |
| 20          | U40-6        |
| 21          | U8-6         |
| 22          | U60-8        |
| 23          | <b>U8-5</b>  |
| 24          | U8-7         |
| 25          | U8-8         |
| 26          | U8-3         |
| 27          | U60-4        |
| 28          | +5VDC        |

.

U-17 2716 EPROM

| 1  | U6-12 |
|----|-------|
| 2  | U6-13 |
| 3  |       |
|    | U6-14 |
| 4  | U6-15 |
| 5  | U6-16 |
| 6  | U6-17 |
| 7  | U6-18 |
| 8  | U6-19 |
| 9  | U8-16 |
| 10 | U8-15 |
| 11 | U8-14 |
| 12 | GND   |
| 13 | U8-13 |
| 14 | U8-12 |
| 15 | U8-11 |
| 16 | U8-10 |
| 17 | U8-9  |
| 18 | U5-7  |
| 19 | U8-6  |
| 17 | 00-0  |

| 20 | U8-32 |
|----|-------|
| 21 | +5VDC |
| 22 | U8-7  |
| 23 | U8-8  |
| 24 | +5VDC |

U-18 MSM5128 SRAM

The State of State & Low States of States

| 1   | U11-9         |
|-----|---------------|
| 2 3 | U11-12        |
|     | U11-7         |
| 4   | U11-4         |
| 5   | U10-9         |
| 6   | U10-12        |
| 7   | U10-7         |
| 8   | U10-4         |
| 9   | U13-18,U14-18 |
| 10  | U13-17,U14-17 |
| 11  | U13-16,U14-16 |
| 12  | GND           |
| 13  | U13-15,U15-15 |
| 14  | U13-14,U14-14 |
| 15  | U13-13,U14-13 |
| 16  | U13-12,U14-12 |
| 17  | U13-11,U14-11 |
| 18  | U12-9         |
| 19  | U12-12        |
| 20  | U31-12        |
| 21  | U36-10        |
| 22  | U12-7         |
| 23  | U12-4         |
| 24  | +5VDC         |

### U-19 74F524 REGISTER/COMPARATOR

| 1  | U59-3         |
|----|---------------|
| 2  | U42-4         |
| 3  | U42-7         |
| 4  | U42-12        |
| 5  | U42-9         |
| 6  | U43-4         |
| 7  | U43-7         |
| 8  | U43-12        |
| 9  | U43-9         |
| 10 | GND           |
| 11 | U44-9         |
| 12 | GND           |
| 13 | NC            |
| 14 | NC            |
| 15 | U24-15,U64-13 |

| 16 | U2 <b>4-</b> 17 |
|----|-----------------|
| 17 | +5VDC           |
| 18 | U24-17          |
| 19 | U49-3           |
| 20 | +5VDC           |

### U-20 74F524 REGISTER/COMPARATOR

and and the family of the second s

| 1<br>2<br>3<br>4<br>5<br>6<br>7<br>8<br>9<br>10<br>11<br>12<br>13<br>14<br>15<br>16 | U50-6<br>U42-4<br>U42-7<br>U42-12<br>U42-9<br>U43-4<br>U43-7<br>U43-12<br>U43-9<br>GND<br>U43-9<br>GND<br>U44-9<br>GND<br>NC<br>NC<br>U25-15, U64-3<br>U25-17 |
|-------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                                                     |                                                                                                                                                               |
| 17                                                                                  |                                                                                                                                                               |
|                                                                                     | +5VDC                                                                                                                                                         |
| 18                                                                                  | U25-17                                                                                                                                                        |
| 19                                                                                  | U50-8                                                                                                                                                         |
| 20                                                                                  | +5VDC                                                                                                                                                         |

# U-21 74F524 REGISTER/COMPARATOR

| 1             | U51-3        |
|---------------|--------------|
| 2             | U42-4        |
| 3             | U42-7        |
| <b>4</b><br>5 | U42-12       |
|               | U42-9        |
| 6             | U43-4        |
| 7             | U43-7        |
| 8             | U43-12       |
| 9             | U43-9        |
| 10            | GND          |
| 11            | U44-9        |
| 12            | GND          |
| 13            | NC           |
| .14           | NC           |
| 15            | U26-15,U64-5 |
| 16            | U26-17       |
| 17            | +5VDC        |
| 18            | U26-17       |
| 19            | U53-3        |

20

-

F

and the second states and the second second

+5VDC

٠.

#### U-22 74F524 REGISTER/COMPARATOR

| 1 2 | U54-6<br>U42-4 |
|-----|----------------|
| 3   | U42-7          |
| 4   | U42-12         |
| 5   | U42-9          |
| 6   | U43-4          |
| 7   | U43-7          |
| 8   | U43-12         |
| 9   | U43-9          |
| 10  | GND            |
| 11  | U <b>44-</b> 9 |
| 12  | GND            |
| 13  | NC             |
| 14  | NC             |
| 15  | U27-15,U64-9   |
| 16  | U27-17         |
| 17  | +5VDC          |
| 18  | U27-17         |
| 19  | U54-8          |
| 20  | +5VDC          |

٠., •

#### U-23 74F524 REGISTER/COMPARATOR

| 1<br>2<br>3<br>4<br>5<br>6<br>7<br>8<br>9<br>10<br>11<br>12<br>13<br>14<br>15<br>16<br>17 | U55-11<br>U42-4<br>U42-7<br>U42-12<br>U42-9<br>U43-4<br>U43-7<br>U43-12<br>U43-9<br>GND<br>U43-9<br>GND<br>U44-9<br>GND<br>NC<br>NC<br>U28-15,U64-11<br>U28-17<br>+5VDC |
|-------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                                                           |                                                                                                                                                                         |
|                                                                                           |                                                                                                                                                                         |
| 18                                                                                        | U28-17                                                                                                                                                                  |
| 19                                                                                        | U57-3                                                                                                                                                                   |
| 20                                                                                        | +5VDC                                                                                                                                                                   |

#### U-24 74F524 REGISTER/COMPARATOR

وسلاحت بالمحاصر عطان

| 1 2           | U49-8<br>U44-4 |
|---------------|----------------|
| 3             | U44-7          |
| 4             | U44-12         |
| <b>4</b><br>5 | GND            |
| 6             | GND            |
| 7             | GND            |
| 8             | GND            |
| 9             | GND            |
| 10            | GND            |
| 11            | U44-9          |
| 12            | GND            |
| 13            | NC             |
| 14            | NC             |
| 15            | U19-15         |
| 16            | NC             |
| 17            | U19-16,U19-18  |
| 18            | GND            |
| 19            | U49-11         |
| 20            | +5VDC          |

### U-25 74F524 REGISTER/COMPARATOR

| 1  | U51-3         |
|----|---------------|
| 2  | U44-4         |
| 3  | U44-7         |
| 4  | U44-12        |
| 5  |               |
| 5  | GND           |
| e  | GND           |
| 7  | GND           |
| 8  | GND           |
| 9  | GND           |
| 10 | GND           |
| 11 | U44-9         |
| 12 | GND           |
| 13 | NC            |
| 14 | NC            |
| 15 | U20-15        |
| 16 | NC            |
| 17 | U20-16,U20-18 |
| 18 | GND           |
| 19 |               |
|    | U51-6         |
| 20 | +5VDC         |
|    |               |

#### U-26 74F524 REGISTER/COMPARATOR

| 1 | U53-8 |
|---|-------|
| 2 | U44-4 |

| 3<br>4<br>5<br>6<br>7<br>8<br>9<br>10<br>11<br>12<br>13<br>14<br>15<br>16<br>17<br>18<br>19<br>20           |        | U44-7<br>U44-12<br>GND<br>GND<br>GND<br>GND<br>GND<br>U44-9<br>GND<br>NC<br>U21-15<br>NC<br>U21-16,U21-18<br>GND<br>U53-11<br>+5VDC                                  |
|-------------------------------------------------------------------------------------------------------------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| U-27                                                                                                        | 74F524 | REGISTER/COMPARATOR                                                                                                                                                  |
| 1<br>2<br>3<br>4<br>5<br>6<br>7<br>8<br>9<br>10<br>11<br>12<br>13<br>14<br>15<br>16<br>17<br>18<br>19<br>20 |        | U55-3<br>U44-4<br>U44-7<br>U44-12<br>GND<br>GND<br>GND<br>GND<br>GND<br>U44-9<br>GND<br>U44-9<br>GND<br>NC<br>U22-15<br>NC<br>U22-16,U22-18<br>GND<br>U55-6<br>+5VDC |
| U-28                                                                                                        | 74F524 | REGISTER/COMPARATOR                                                                                                                                                  |
| 1<br>2<br>3<br>4<br>5<br>6<br>7<br>8<br>9                                                                   |        | U57-8<br>U44-4<br>U44-7<br>U44-12<br>GND<br>GND<br>GND<br>GND<br>GND<br>GND                                                                                          |

And the summer in the

. . .

· •

ς.

•.

10 GND 11 U44-9 12 GND 13 NC 14 NC 15 U23-15 16 NC 17 U23-16,U23-18 18 GND 19 U57-11 20 +5VDC U-29 8282 LATCH

بالمندير بشتقيت

1 MISC1-12 2 MISC1-13 3 MISC1-14 4 MISC1-15 5 MISC1-16 6 MISC1-17 7 MISC1-18 8 MISC1-19 9 GND 10 GND 11 MISC1-11 12 U43-11,U11-11 13 U43-14,U11-14 14 U43-5 ,U11-5 U43-2 ,U11-2 15 16 U42-11,U10-11 17 U42-14,U10-14 18 U42-5 ,U10-5 U42-2,U10-2 +5 VDC 19 20

U-30 8282 LATCH 1 MISC1-21 2 MISC1-22 3 MISC1-23 4 NC 5 NC 6 NC 7 NC 8 NC 9 GND 10 GND 11 MISC1-11 12 NC 13 NC

| 14<br>15<br>16<br>17<br>18<br>19<br>20                                              |                     | NC<br>NC<br>U44-14,U12-14<br>U44-5,U12-5<br>U44-2,U12-2<br>+5 VDC                                                                                                         |
|-------------------------------------------------------------------------------------|---------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| U-31                                                                                | 74F157A MULTIPLEXER |                                                                                                                                                                           |
| 1<br>2<br>3<br>4<br>5<br>6<br>7<br>8<br>9<br>10<br>11<br>12<br>13<br>14<br>15<br>16 |                     | U39-8<br>MISC1-11<br>U8-25<br>U36-11<br>MISC1-4<br>U9-10<br>U36-4<br>GND<br>U36-10<br>U8-29<br>MISC1-10<br>U8-29<br>MISC1-10<br>U36-9<br>U8-32<br>MISC1-9<br>GND<br>+5VDC |
| U-32                                                                                | 74F157A MULTIPLEXER |                                                                                                                                                                           |
| 1<br>2<br>3<br>4<br>5<br>6<br>7<br>8<br>9<br>10<br>11<br>12<br>13<br>14<br>15<br>16 |                     | U39-8<br>MISC1-3<br>U9-8<br>U36-3<br>MISC1-5<br>+5VDC<br>U36-5<br>GND<br>U36-13<br>U8-15<br>MISC1-13<br>U36-12<br>U8-16<br>MISC1-12<br>GND<br>+5VDC                       |
| U-33                                                                                | 74F157A MULTIPLEXER |                                                                                                                                                                           |
| 1<br>2<br>3                                                                         |                     | U39-8<br>U61-3<br>+5VDC                                                                                                                                                   |

.

· . .

.

. . .

•

98

| 4  | U36-2   |
|----|---------|
| 5  | MISC1-7 |
| 6  | U8-28   |
| 7  | U36-7   |
| 8  | GND     |
| 9  | U36-8   |
| 10 | +5VDC   |
| 11 | MISC1-8 |
| 12 | U36-1   |
| 13 | U38-5   |
| 14 | MISC1-1 |
| 15 | GND     |
| 16 | +5VDC   |

## U-34 74F245 LATCH

E

Ľ

۰L

I

| 1  | MISC1-9 |
|----|---------|
| 2  | U13-2   |
| 3  | U13-3   |
| 4  | U13-4   |
| 5  | U13-5   |
| 6  | U13-6   |
| 7  | U13-7   |
| 8  | U13-8   |
| 9  | U13-9   |
| 10 | GND     |
| 11 | U36-19  |
| 12 | U36-18  |
| 13 | U36-17  |
| 14 | U36-16  |
| 15 | U36-15  |
| 16 | U36-14  |
| 17 | U36-13  |
| 18 | U36-12  |
| 19 | CT1-4   |
| 20 | +5 VDC  |
|    |         |

# U-35 74F245 LATCH

| 1  | U8-32        |
|----|--------------|
| 2  | U8-16        |
| 3  | U8-15        |
| 4  | U8-14        |
| 5  | U8-13        |
| 6  | U8-12        |
| 7  | U8-11        |
| 8  | <b>U8-10</b> |
| 9  | U8-9         |
| 10 | GND          |
| 11 | U36-19       |
| 12 | U36-18       |

13 U36-17 14 U36-16 15 U36-15 16 U36 - 1417 U36-13 18 U36-12 19 U41-8 20 +5 VDC U-36 8755 I/O PORTS 1 U33-12 2 U33-4 3 U32-4 4 U31-7 5 U32-7 6 R-16 7 U33-7 8 U33-9 9 U31-12 10 U31-9 11 U31-4 12 U32-12, U34-18, U35-18 13 U32- 9,U34-17,U35-17 14 U34-16,U35-16 15 U34-15, U35-15 16 U34-14, U35-14 17 U34-13, U35-13 U34-12,U35-12 18 19 U34-11, U34-11 20 GND 21 NC 22 NC 23 NC 24 MISC1-24 25 MISC1-25 26 MISC1-26 27 MISC1-27 28 MISC1-28 29 MISC1-29 30 MISC1-30 31 MISC1-31 32 MISC1-32 33 MISC1-33 34 MISC1-34 35 MISC1-35 36 MISC1-36 37 MISC1-37 38 MISC1-38 39 MISC1-39 40 +5 VDC

and week with the constant of the second second

## U-37 7404 HEX INVERTER

- ·

.

Rear second and the contraction second reaction

| 1  | MISC1-11      |
|----|---------------|
| 2  | U65-1         |
| 3  | U8-39         |
| 4  | U40-1         |
| 5  | U37-8,U45-5   |
| 6  | U37-9,MISC4-7 |
| 7  | GND           |
| 8  | U37-5,U45-5   |
| 9  | U37-6,MISC4-7 |
| 10 | U39-1         |
| 11 | U7-11         |
| 12 | U39-11        |
| 13 | U5-13         |
| 14 | +5VDC         |

ncc a

#### U-38 74154 4 TO 16 DECODER

| 1             | U66-1         |
|---------------|---------------|
| 2             | U66-4         |
| 3             | U56-13        |
| 4             | U58-1         |
| <b>4</b><br>5 | U41-10,U33-13 |
| 6             | U4-9,U3-11    |
| 7             | U47-1         |
| 8             | U47-3         |
| 9             | U47-5         |
| 10            | U47-9         |
| 11            | U47-11        |
| 12            | GND           |
| 13            | U47-13        |
| 14            | U48-1         |
| 15            | U48-3         |
| 16            | U48-5         |
| 17            | U48-9         |
| 18            | GND           |
| 19            | U48-12        |
| 20            | CT2-28        |
| 21            | CT2-27        |
| 22            | CT2-26        |
| 23            | CT2-25        |
| 24            | +5VDC         |
|               |               |

# U-39 7474 DUAL D FLIP-FLOP

| T | 03/-10      |
|---|-------------|
| 2 | U39-4,+5VDC |
| 3 | U45-6       |
| 4 | U39-2,+5VDC |
|   |             |

| 5  | U41-13                  |
|----|-------------------------|
| 6  | NC                      |
| 7  | GND                     |
| 8  | U10-1,U11-1,U12-1,U32-1 |
|    | U31-1,U64-1,CT1-2,U33-1 |
| 9  | U41-5                   |
| 10 | U39-13,+5VDC            |
| 11 | U37-12                  |
| 12 | U6-19                   |
| 13 | U39-10,+5VDC            |
| 14 | +5VDC                   |
|    |                         |

## U-40 7408 QUAD 2-INPUT AND

المحالية المحالية فريقته فريقه المراجع والمراجع توادعه مراجع فالمحالية والمعالية والمحالية والمحالية والمحالية

. . .

| 1  | U37-4         |
|----|---------------|
| 2  | U5-15         |
| 3  | U15-20        |
| 4  | U8-39         |
| 5  | U5-15         |
| 6  | <b>U16-20</b> |
| 7  | GND           |
| 8  | U12-11        |
| 9  | MISC1-7       |
| 10 | MISC1-1       |
| 11 | U13-19        |
| 12 | MISC1-9       |
| 13 | U40-8         |
| 14 | +5VDC         |
|    |               |

| U-41           | 7432 | QUAD | 2-INPUT | OR |               |
|----------------|------|------|---------|----|---------------|
| 1              |      |      |         |    | U8-26         |
| 2              |      |      |         |    | U12-9         |
| 3              |      |      |         |    | U41-4         |
| 4              |      |      |         |    | U41-3         |
| 5              |      |      |         |    | U39-9         |
| 6              |      |      |         |    | U14-19        |
| 7              |      |      |         |    | GND           |
| 8              |      |      |         |    | U35-19        |
| 9              |      |      |         |    | U8-26         |
| 10             |      |      |         |    | <u>U38-</u> 5 |
| 10<br>11<br>12 |      |      |         |    | U9-4<br>S3    |
| 13             |      |      |         |    | U39-5         |
| 14             |      |      |         |    | GND           |
| <b>* *</b>     |      |      |         |    | GND           |

## U-42 74F157A MULTIPLEXER

| 1  | U60-10     |
|----|------------|
| 2  | U29-19     |
| 3  | U8-16      |
| 4  | U(19-23)-2 |
| 5  | U29-18     |
| 6  | U8-15      |
| 7  | U(19-23)-3 |
| 8  | GND        |
| 9  | U(19-23)-5 |
| 10 | U8-13      |
| 11 | U29-16     |
| 12 | U(19-23)-4 |
| 13 | U8-14      |
| 14 | U29-17     |
| 15 | GND        |
| 16 | +5VDC      |
|    |            |

#### U-43 74F157A MULTIPLEXER

| 1  | U60-10       |
|----|--------------|
| 2  | U29-15       |
| 3  | U8-12        |
| 4  | U(19-23)-6   |
| 5  | U29-14       |
| 6  | U8-11        |
| 7  | U(19-23)-7   |
| 8  | GND          |
| 9  | U(19-23)-9   |
| 10 | U8-9         |
| 11 | U29-12       |
| 12 | Ŭ(19−23)−8   |
| 13 | <b>U8-10</b> |
| 14 | U29-13       |
| 15 | GND          |
| 16 | +5VDC        |

#### U-44 74F157A MULTIPLEXER

| 1  | U60-10       |
|----|--------------|
| 2  | U30-19       |
| 3  | U8-16        |
| 4  | U(24-28)-2   |
| 5  | U30-18       |
| 6  | <b>U8-15</b> |
| 7  | U(24-28)-3   |
| 8  | GND          |
| 9  | V(19-28)-11  |
| 10 | U9-8         |
| 11 | MISC1-3      |
| 12 | U(24-28)-4   |
| 13 | U8-14        |

| 14 | U30-17 |
|----|--------|
| 15 | GND    |
| 16 | +5VDC  |

· · ·

#### U-45 74121 ONE SHOT

a a statistica e ter

Andres that Den theretand a first a service of the

کا

÷

| 1  | NC                |
|----|-------------------|
| 2  | NC                |
| 3  | <b>U45-4</b> ,GND |
| 4  | U45-3,GND         |
| 5  | U37-8             |
| 6  | U39-3             |
| 7  | GND               |
| 8  | NC                |
| 9  | +5VDC             |
| 10 | +80 pf cap        |
| 11 | -80 pf cap        |
| 12 | NC                |
| 13 | NC                |
| 14 | +5VDC             |

## U-46 7400 QUAD 2-INPUT NAND

| 1  | U60-8  |
|----|--------|
| 2  | U60-4  |
| 3  | U59-1  |
| 4  | U60-8  |
| 5  | U60-4  |
| 6  | U49-5  |
| 7  | GND    |
| 8  | U50-2  |
| 9  | U60-4  |
| 10 | U60-8  |
| 11 | U50-12 |
| 12 | U60-4  |
| 13 | U60-8  |
| 14 | +5VDC  |

#### U-47 7404 HEX INVERTER

| 1  | U38-7              |
|----|--------------------|
| 2  | U59-1,U49-2        |
| 3  | U38-8              |
| 4  | U49-9,U49-12       |
| 5  | U38-9              |
| 6  | <b>U50-5,U50-9</b> |
| 7  | GND                |
| 8  | U51-2,U51-5        |
| 9  | U38-10             |
| 10 | U51-12,U53-2       |

| 11<br>12<br>13<br>14                                                    |                       | U38-11<br>U53-9,U53-12<br>U38-13<br>+5VDC                                                                                                        |
|-------------------------------------------------------------------------|-----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------|
| U-48                                                                    | 7404 HEX INVERTER     |                                                                                                                                                  |
| 1<br>2<br>3<br>4<br>5<br>6<br>7<br>8<br>9<br>10<br>11<br>12<br>13<br>14 |                       | U38-14<br>U54-5,U54-9<br>U38-15<br>U55-2,U55-5<br>U38-16<br>U55-12,U57-2<br>GND<br>U57-9,U57-12<br>U38-17<br>U4-11<br>U3-13<br>NC<br>NC<br>+5VDC |
| U-49                                                                    | 7408 QUAD 2-INPUT AND |                                                                                                                                                  |
| 1<br>2<br>3<br>4<br>5<br>6<br>7<br>8<br>9<br>10<br>11<br>12<br>13<br>14 |                       | U46-3<br>U47-2<br>U19-19<br>U60-12<br>U46-6<br>U49-10<br>GND<br>U24-1<br>U47-4<br>U49-6<br>U24-19<br>U47-4<br>U46-6<br>+5VDC                     |
| U-50                                                                    | 7408 QUAD 2-INPUT AND |                                                                                                                                                  |
| 1<br>2<br>3<br>4<br>5<br>6<br>7<br>8<br>9<br>10                         |                       | U60-12<br>U46-8<br>U50-4<br>U50-3<br>U47-6<br>U20-1<br>GND<br>U20-19<br>U47-6<br>U46-8                                                           |

.

...\*...

| 11 | U51-1  |
|----|--------|
| 12 | U46-11 |
| 13 | U60-12 |
| 14 | +5VDC  |

U-51 7408 QUAD 2-INPUT AND

the surger in all the second break to be stick and an and the

Ĭ

| 1<br>2<br>3<br>4<br>5<br>6<br>7<br>8<br>9<br>10<br>11<br>12<br>13<br>14 |      |      |         |      | U50-11<br>U47-8<br>U25-1<br>U46-11<br>U47-8<br>U25-19<br>GND<br>U51-13<br>U52-3<br>U60-12<br>U21-1<br>U47-10<br>U51-8<br>+5VDC |
|-------------------------------------------------------------------------|------|------|---------|------|--------------------------------------------------------------------------------------------------------------------------------|
| U-52                                                                    | 7400 | QUAD | 2-INPUT | NAND |                                                                                                                                |
| 1<br>2<br>3<br>4<br>5<br>6<br>7<br>8<br>9<br>10<br>11<br>12<br>13<br>14 |      |      |         |      | U60-6<br>U60-2<br>U51-9<br>U60-6<br>U53-5<br>GND<br>U54-2<br>U60-2<br>U60-6<br>U54-12<br>U60-2<br>U60-6<br>+5VDC               |

## U-53 7408 QUAD 2-INPUT AND

| 1  | U52-3         |
|----|---------------|
| 2  | U47-10        |
| 3  | U21-19        |
| 4  | U60-6         |
| 5  | U52-6         |
| 6  | <b>U53-10</b> |
| 7  | GND           |
| 8  | U26-1         |
| 9  | U47-12        |
| 10 | U53-6         |

11 U26-19 12 U47-12 13 U53-6 14 +5VDC U-54 7408 QUAD 2-INPUT AND 1 U60-12 2 U52-8 3 U54-4 4 U54-3 5 U48-2 6 U22-1 7 GND 8 U22-19 9 U48-2 10 U52-8 11 U55-1 U60-2 12 13 U60-6 14 +5VDC U-55 7408 QUAD 2-INPUT AND 1 U54-11 2 U48-4 3 U27-1 4 U52-11 5 U48-4 6 U27-19 7 GND 8 U55-13 9 U56-3 10 U60-12 11 U23-1 12 U48-6 13 U55-8 14 +5VDC U-56 7400 QUAD 2-INPUT NAND 1 U60-8 2 U60-4 3 U55-9,U57-1 4 U60-8 5 U60-4 6 U57~5 7 GND 8 U34-19

• • •

and the second second

107

MISC1-7

9

. . . . . .

| 10 | U64-2        |
|----|--------------|
| 11 | CT2-24       |
| 12 | U56-13,U38-3 |
| 13 | U56-12,U38-3 |
| 14 | +5VDC        |
|    |              |

U-57 7408 QUAD 2-INPUT AND

| 1 2 | U56-3<br>U48-6 |
|-----|----------------|
| 3   | U23-19         |
| 4   | U60-12         |
| 5   | U56-6          |
| 6   | U57-10         |
| 7   | GND            |
| 8   | U28-1          |
| 9   | U48-8          |
| 10  | U57-6          |
| 11  | U28-19         |
| 12  | U48-8          |
| 13  | U56-6          |
| 14  | +5VDC          |

| 9       CT         10       CT         11       CT         12       NC         13       NC         14       GN         15       NC         16       +5         17       CT         18       U6 | D    |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|
| 17 CT                                                                                                                                                                                          | 2-22 |
|                                                                                                                                                                                                |      |
|                                                                                                                                                                                                |      |
|                                                                                                                                                                                                | 4-6  |
|                                                                                                                                                                                                | 4-8  |
|                                                                                                                                                                                                | 4-10 |
| 23 GN                                                                                                                                                                                          |      |
| 24 GN                                                                                                                                                                                          | D    |

 25
 GND

 26
 CT2-23

 27
 CT2-21

 28
 +5V

U-59 7408 QUAD 2-INPUT AND

المارا الالالمان الماسطين التحديا فللدو المساطعين

| 1<br>2<br>3<br>4<br>5<br>6<br>7<br>8<br>9<br>10<br>11<br>12 | U46-3<br>U60-12<br>U59-4<br>U59-3<br>U47-2<br>U19-1<br>GND<br>NC<br>NC<br>NC<br>NC<br>NC |
|-------------------------------------------------------------|------------------------------------------------------------------------------------------|
| 12                                                          | NC                                                                                       |
| 13                                                          | NC                                                                                       |
| 14                                                          | +5VDC                                                                                    |

| U-60 7407 | HEX BUFFER |
|-----------|------------|
|-----------|------------|

| 1  | CT2-19                         |
|----|--------------------------------|
| 2  | U52-(2,5,9,12),U3-10           |
| 3  | CT2-19                         |
| 4  | U46-(2,5,9,12),U56-(2,5)       |
| 5  | CT2-20                         |
| 6  | U52-(1,4,10,13)                |
| 7  | GND                            |
| 8  | U3-13, U46-(1,4,10,13),        |
|    | U56-(1,4)                      |
| 9  | CT2-20                         |
| 10 | U42-1,U43-1,U44-1              |
| 11 | CT2-2                          |
| 12 | U49-4,U59-2,U50-(1,13),U51-10, |
|    | U53-4,U54-(1,13),U55-10,U57-4  |
| 13 | CT2-20                         |
| 14 | +5VDC                          |
|    |                                |

U-61 7409 QUAD 2-INPUT AND (OC)

| 1 | MISC1-2     |
|---|-------------|
| 2 | MISC1-7     |
| 3 | U33-2       |
| 4 | U63-6,U61-5 |
| 5 | U63-6,U61-4 |
|   |             |

| 6<br>7<br>8<br>9<br>10<br>11<br>12<br>13<br>14                          |                         | MISC1-6<br>GND<br>MISC1-6<br>U63-3,U61-10<br>U63-3,U61-9<br>NC<br>NC<br>NC<br>+5VDC                                                            |
|-------------------------------------------------------------------------|-------------------------|------------------------------------------------------------------------------------------------------------------------------------------------|
| U-62                                                                    | 7411 TRIPLE-3-INPUT-AND |                                                                                                                                                |
| 1<br>2<br>3<br>4<br>5<br>6<br>7<br>8<br>9<br>10<br>11<br>12<br>13<br>14 |                         | U19-15<br>U20-15<br>U62-12<br>U22-15<br>U23-15<br>CT2-5<br>GND<br>NC<br>NC<br>NC<br>NC<br>NC<br>NC<br>U62-3<br>U21-5<br>+5VDC                  |
| U-63                                                                    | 7432 QUAD-2-INPUT OR    |                                                                                                                                                |
| 1<br>2<br>3<br>4<br>5<br>6<br>7<br>8<br>9<br>10<br>11<br>12<br>13<br>14 |                         | U65-5<br>U65-9<br>U61-9,U61-10<br>U66-5<br>CT2-5<br>U61-4,U61-5<br>GND<br>NC<br>NC<br>NC<br>NC<br>NC<br>NC<br>NC<br>NC<br>NC<br>NC<br>NC<br>NC |
| U-64                                                                    | 7404 HEX INVERTER       |                                                                                                                                                |
| 1<br>2<br>3<br>4                                                        |                         | CT2-2<br>U56-10<br>U20-15<br>U58-19                                                                                                            |

distance and in same

÷.•.

-

| 5<br>6<br>7<br>8<br>9<br>10<br>11<br>12<br>13<br>14                     | U21-15<br>U58-20<br>GND<br>U58-21<br>U22-15<br>U58-22<br>U23-15<br>U58-18<br>U19-15<br>+5VDC                                    |
|-------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------|
| U-65 7474 DUAL D FLIPFLOP                                               |                                                                                                                                 |
| 1<br>2<br>3<br>4<br>5<br>6<br>7<br>8<br>9<br>10<br>11<br>12<br>13<br>14 | U37-2<br>+5V,U65-4<br>CT1-24<br>+5V,U64-2<br>U63-1<br>NC<br>GND<br>NC<br>U63-2<br>U5-12<br>GND<br>NC<br>U5-11<br>+5VDC          |
| U-66 7474 DUAL D FLIPFLOP                                               |                                                                                                                                 |
| 1<br>2<br>3<br>4<br>5<br>6<br>7<br>8<br>9<br>10<br>11<br>12<br>13<br>14 | U38-1<br>NC<br>GND<br>U38-2<br>U63-4<br>NC<br>GND<br>NC<br>NC<br>NC<br>NC<br>NC<br>NC<br>NC<br>NC<br>NC<br>NC<br>NC<br>NC<br>NC |
| MISC1 TARGET PLUG                                                       |                                                                                                                                 |

MISC1 TARGET PLUG

And a second data to a date bit she is a star of a star star

| 1 | U33-14 |
|---|--------|
| 2 | U33-2  |

3 U32-2 4 U31-5 5 6 U32-5 U61-8,U61-6 7 U33-5 8 U33-11 9 U31-14 10 U31-11 11 U31-2 12 U32-14,U29-1,U13-2 13 U32-11,U29-2,U13-3 14 U29-3,U13-4 15 U29-4,U13-5 16 U29-5,U13-6 17 U29-6,U13-7 18 U29-7,U13-8 19 U29-8,U13-9 20 GND 21 U30-1 22 U30-2 23 U30-3 24 U36-24 25 **U36-25** 26 **U36-26** 27 **U36-27** 28 **U36-28** 29 **U36-29** 30 U36-30 31 U36-31 32 U36-32 33 U36-33 34 U36-34 35 36 U36-35 U36-36 37 U36-37 38 U36-38 39 U36-39 40 +5 VDC MISC2 CONNECTOR BOARD-1 1 U33-13 2 34 5 U39-8 MISC1-7 U34-19 U63-5 6 U63-4 7 U9-8 8 U8-9,U6-8,U17-8 9 U8-10, U6-7, U17-7 10 U8-11, U6-6, U17-6 11 U8-12, U6-5, U17-5

and a second second

....

. .

| 12       |                    |
|----------|--------------------|
|          | U8-13,U6-4,U17-4   |
| 13       | U8-14, U6-3, U17-3 |
| 14       | U8-15, U6-2, U17-2 |
| 15       | U8-16, U6-1, U17-1 |
| 16       | U9-2               |
| 17       | U8-28              |
| 18       |                    |
| 19       | U8-21              |
| 20       | U8-29              |
| 20       | U8-32              |
|          | U6-19              |
| 22       | U8-18              |
| 23       | U8-24              |
| 24       | U65-15             |
| 25       | U6-15              |
| 26       | U6-14              |
| 27<br>28 | U6-13              |
|          | U6-12              |
| 29       | U29-19             |
| 30       | U29-18             |
| 31       |                    |
| 32       | U29-17             |
| 33       | U29-16             |
| 34       | U29-15             |
|          | U29-14             |
| 35       | U29-13             |
| 36       | U29-12             |
| 37       | U30-19             |
| 38       | U30-18             |
| 39       | U30-17             |
| 40       |                    |
|          | MISC1-3            |

MISC3 CONNECTOR BOARD-2

and a second s

Ē

1

í.

Ì

I

| 1      |                |
|--------|----------------|
| 1      | <b>U38-5</b>   |
| 2<br>3 | U60-11         |
| 3      | U56-9          |
| 4      | U56-8          |
| 5      | U62-6          |
| 6      | U66-5          |
| 7      |                |
| 8      | U44-10         |
| 9      | U4-12          |
|        | U4-13          |
| 10     | U4-14          |
| 11     | U <b>4-1</b> 5 |
| 12     | U4-16          |
| 13     | U4-17          |
| 14     | U4-18          |
| 15     |                |
| 16     | U4-19          |
| 17     | U3-20          |
| -      | U48-13         |
| 18     | U3-21          |
| 19     | U60-1,3        |
| 20     | U60-5,9,13     |
|        |                |

| 21 | U3-10   |
|----|---------|
| 22 |         |
|    | U58-17  |
| 23 | U58-26  |
| 24 | U56-11  |
| 25 | U38-23  |
| 26 | U38-22  |
| 27 | U38-21  |
| 28 | U38-20  |
| 29 | U42-2   |
| 30 | U42-5   |
| 31 | U42-14  |
| 32 | U42-11  |
| 33 |         |
|    | U43-2   |
| 34 | U43-5   |
| 35 | U43-14  |
| 36 | U43-11  |
| 37 | U44-2   |
| 38 | U44-5   |
| 39 | · · · · |
|    | U44-14  |
| 40 | U44-11  |
|    |         |

...

الود المذكرة مدوسو كالف والعد

See. in

....



الوالية بالالترابة الروفيا بالتصفيكيو فلسر بالبادة ستبي



-

المتحر المراجع المحالية المحافظة المحاد المحادية المحافة المحافة المحافة المحافة المحافة المحافة المحافة المحافة

Figure 3. Bootup Flowcharts



. .

and and the second and the second states and the second states and the second states and the second states and the

Figure 4. Emulator Main Flowchart



المراجع المراجع المراجع المراجع المسترين والمراجع المراجع المحمد والمحمد والمحمد والمحمد والمحمد والم

Figure 5. Emulator User Memory Flowchart



.

the third in the way have need in the the need being a set of the

- - -

Figure 6. Emulator Single-step Flowchart



E

ł

~ "

1. The state of the state of the second second





Carl and the state and the second state of the

Figure 8. Emulator Break Interrupt Flowchart



The second s

--

S. . . .

Figure 9. Emulator Parallel I/O Flowchart



.

Ξ.

A service and the service of the ser





water and a start of the start of the start of the

- ., .**\*** :

.

Figure 10b. Z-100 Main Flowchart



Believe and we are and as the second second second

Figure 11a. Z-100 User Memory Flowchart



Lee Carlos and an

.

Contra a seconda de se

-----

.....

.



E

r.

I



Figure 12. Z-100 Break Control Flowchart



الفافاف الانسفانات تسويك

.

Ľ

**1** 

Þ

E

× 2

Figure 13. Z-100 Parallel Port Flowchart



.

Figure 14. Z-100 Single-step Flowchart



a - 1 a 2 a 2 a a

and a second second second and the second second

Figure 15. Z-100 Target Control Flowchart

## Memory Map

## Address

بداء الدابا فاح المعصوصف معتبه معتامور والعطو فقيد

<u>Use</u>

| FFFF0 - 80000        | Not Used                  |
|----------------------|---------------------------|
| 7FFFF - 70800        | Not Used                  |
| 707FF - 70000        | U17 Monitor Rom           |
| 6FFFF - 60800        | Not Used                  |
| 607FF - 60000        | U18 Target Ram            |
| 5FFFF - 50000        | Not Used                  |
| 4FFFF - 40001        | Not Used                  |
| 40000                | Enable Stepper Mode       |
| <b>3FFFF - 30001</b> | Not Used                  |
| 30000                | Return Stepper to Freerun |
| 2FFFF - 20002        | Not Used                  |
| 20001                | Enable Target Mode        |
| 20000                | Enable Emulator Mode      |
| 1FFFF - 10000        | Not Used                  |
| <b>OFFFF - 00000</b> | U15 and U16 Emulator Ram  |
|                      |                           |
|                      | I/O MAP                   |

<u>1/0 MAP</u>

| 00F0 | Break Reg 5b, U28    |
|------|----------------------|
| 00E0 | Break Reg 5a, U23    |
| 00D0 | Break Reg 4b, U27    |
| 00C0 | Break Reg 4a, U22    |
| 00B0 | Break Reg 3b, U26    |
| 00A0 | Break Reg 3a, U21    |
| 0090 | Break Reg 2b, U25    |
| 0080 | Break Reg 2a, U20    |
| 0070 | Break Reg 1b, U24    |
| 0060 | Break Reg 1a, U19    |
| 0050 | Serial Data Port     |
| 0051 | Serial Control Port  |
| 0040 | Parallel Port A      |
| 0041 | Parallel Port        |
| 0042 | Data Direction Reg A |
| 0043 | Data Direction Reg B |
| 0030 | Interrupt Port 1     |
| 0031 | Interrupt Port 2     |
| 0020 | Step Trigger         |
| 0010 | Break Disable        |
| 0000 | Break Enable         |
|      |                      |

Table 2. Emulator Address Map

#### Appendix D: Source Code

#### TITLE EMULATOR BOOTUP PROGRAM

page 60,132

÷.,

\*\*\*\*\*\* ; This program initializes emulator hardware and downloads ; the MAIN EMULATOR program \*\*\*\*\* \*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\* cseg segment assume cs:cseg, ds:cseg, ss:cseg, es:cseg ax,cs start: mov ds,ax mov The bootup program starts here ;halt target ax,4000h ;set es to page 4 mov mov es,ax es:[bx],al ;set stepper to step mode mov ; (i.e halt target) ;set mode ax,2000h ;set es to page 2 mov es,ax mov bx,0 mov es:[bx],al ;set mode to emulator mov ;disable break detectors ;set break flipflop to off out Bk off,al ;setup 8259A interrupt controller mov al,13h ;set ICW1 out port0,al al,18h ;set ICW2 mov port1,al out al,0dh ;set ICW4 mov

; initialize 8251 serial port

port1,al

out

Ľ

|           |              |                | ;configure 8251A                        |
|-----------|--------------|----------------|-----------------------------------------|
|           | mov          | al,0           | ;put UART into worst                    |
|           |              | -              | ;case mode                              |
|           | out          | 51h,al         | ;sync mode, with 2                      |
|           |              |                | ; characters                            |
|           | out          | 51h,al         |                                         |
|           | out          | 51h,al         |                                         |
|           | mov          | al, reset      | ;reset UART                             |
|           | mov          | dx, msc reg    |                                         |
|           | out          | dx,al          |                                         |
|           | mov          | al, set mode   | ;set UART for async mode                |
|           | out          | dx,al —        | ;odd parity, 8 bit data                 |
|           |              |                | ; baud factor 16                        |
|           | mov          | al,set control | ;set control register as                |
|           | out          | dx,al          | ;transmit & receive                     |
|           |              |                | ;enabled, DTR* enabled,                 |
|           |              |                | ;clear error bits,                      |
|           |              |                | ;set RTR*, no reset or                  |
|           |              |                | ;hunt                                   |
|           |              |                |                                         |
| ;*******  | ******       |                | ******                                  |
|           | lator ra     |                |                                         |
| ;*******  | *******      | *************  | *******                                 |
|           |              |                |                                         |
|           | <b>mol</b> 1 | dw 0100b       | along wat counton and out               |
|           | mov          | dx,0100h       | ;clear xmt counter and set              |
| toot fake |              | 0000b          | ;test # to 64k                          |
| test_64k: | mov          | ax,0000h       | ;setup extra segment                    |
|           | mov          | es,ax          |                                         |
|           | mov          | bx,0           |                                         |
| loop1:    | MOV          | cx,0<br>al,0   | ;write all zeroes to ram                |
| 10001.    | mov<br>mov   | es:[bx],al     | ; write all zeroes to ram               |
|           | inc          | bx             |                                         |
|           | cmp          | bx,0           | ;check for all done                     |
|           | je           | chk read       | ; if done then read                     |
|           | mov          | al, Offh       | ;write all 1's to ram                   |
|           | mov          | es:[bx],al     | , write all 1 5 to lan                  |
|           | inc          | bx             |                                         |
|           | cmp          | bx,0           |                                         |
|           | je           | chk read       |                                         |
|           | jmp          | loopl          |                                         |
| chk read: |              | bx,0           |                                         |
| 10072:    | mov          | al,es:[bx]     | ;read zero bytes                        |
|           | inc          | bx             | ficuu bere si coo                       |
|           | cmp          | al,0           | ;test data against zero                 |
|           | je           | no err         | ; skip counter if match is              |
|           | J -          |                | ; found                                 |
|           | inc          | сх             |                                         |
| no err:   | mov          | al,es:[bx]     | ;read all one bytes                     |
|           | inc          | bx             | ,                                       |
|           | cmp          | al,Offh        | ;test data against ones                 |
|           | je           | counter        | ; skip if match is found                |
|           | -            |                | • • • • • • • • • • • • • • • • • • • • |

State of the state

مشادعه 

ć.

|                                               | inc         | сх                                  |                                            |  |  |  |
|-----------------------------------------------|-------------|-------------------------------------|--------------------------------------------|--|--|--|
| counter:                                      | cmp         | bx,0                                | ;test for end of memory                    |  |  |  |
| 000.002.0                                     | jne         | 100p2                               | ; continue if not done                     |  |  |  |
|                                               | Je          | 10025                               | feeneinde in not done                      |  |  |  |
| ;******                                       | *******     | ******                              | ******                                     |  |  |  |
| ;look at 64k error count and send ack or nack |             |                                     |                                            |  |  |  |
|                                               |             |                                     | *******                                    |  |  |  |
|                                               |             |                                     |                                            |  |  |  |
|                                               |             |                                     |                                            |  |  |  |
|                                               | mov         | ax,0                                | ;compare total errors                      |  |  |  |
|                                               | cmp         | cx,ax                               |                                            |  |  |  |
|                                               | jz          | skip                                |                                            |  |  |  |
|                                               | jmp         | error                               |                                            |  |  |  |
| <b>.</b> .                                    |             |                                     |                                            |  |  |  |
| <pre>skip: mov di,offset ack_stg</pre>        |             |                                     |                                            |  |  |  |
| buf_full_                                     |             |                                     | • • • • •                                  |  |  |  |
|                                               | in          | al,msc_reg                          | read status register;                      |  |  |  |
|                                               | test        | al,tx_rdy                           | ;test for empty register                   |  |  |  |
|                                               | jz          | buf_full_1                          | ;loop until UART is free                   |  |  |  |
|                                               | moti        | -1 (dil                             | . load asknowladge shows ton               |  |  |  |
|                                               | mov         | al,[di]                             | ;load acknowledge character                |  |  |  |
|                                               | out         | data rog al                         | ;signals all clear on ram<br>;test to Z100 |  |  |  |
|                                               | inc         | data_reg,al<br>di                   | ;send ++ ack EOT string                    |  |  |  |
|                                               |             |                                     | Send ++ ack Eor Scring                     |  |  |  |
|                                               | cmp         | al,eot<br>cx,01ffh                  |                                            |  |  |  |
| slow:                                         | mov         | Cx,01111                            |                                            |  |  |  |
| SIOM:                                         | nop         |                                     |                                            |  |  |  |
|                                               | loop<br>jne | slow<br>buf full 1                  |                                            |  |  |  |
|                                               | Jile        |                                     |                                            |  |  |  |
| *******                                       | *******     | * * * * * * * * * * * * * * * * * * | *****                                      |  |  |  |
| ;test use                                     | er ram me   | emory                               |                                            |  |  |  |
|                                               |             |                                     | ******                                     |  |  |  |
| -                                             |             |                                     |                                            |  |  |  |
|                                               |             |                                     |                                            |  |  |  |
|                                               | mov         | dx,0200h                            | ;clear xmt counter and set                 |  |  |  |
|                                               |             |                                     | ;test # to 2k                              |  |  |  |
| test_2k:                                      | mov         | <b>ax,</b> 6000h                    | ;setup extra segment                       |  |  |  |
|                                               | mov         | es,ax                               |                                            |  |  |  |
|                                               | mov         | bx,0                                |                                            |  |  |  |
|                                               | mov         | cx,0                                |                                            |  |  |  |
| loop3:                                        | mov         | al,0                                | ;write all zeroes to ram                   |  |  |  |
|                                               | mov         | es:[bx],al                          |                                            |  |  |  |
|                                               | inc         | bx                                  |                                            |  |  |  |
|                                               | cmp         | bx,07ffh                            | ;check for all done                        |  |  |  |
|                                               | je          | chk_read2                           | ; if done then read                        |  |  |  |
|                                               | mov         | al, 0ffh                            | ;write all 1's to ram                      |  |  |  |
|                                               | mov         | es:[bx],al                          |                                            |  |  |  |
|                                               | inc         | bx                                  |                                            |  |  |  |
|                                               | cmp         | bx,07ffh                            | ;check for all done                        |  |  |  |
|                                               | je          | chk_read2                           |                                            |  |  |  |
|                                               | jmp         | 100p3                               |                                            |  |  |  |
| chk_read2:                                    |             |                                     |                                            |  |  |  |
|                                               |             |                                     |                                            |  |  |  |

. My the Alexandra

•

•

••

\_\_\_\_

•

•

.

1

E

and one was she was the about the fait for the first set of

. s .

|           | mov       | bx,0              |                                    |
|-----------|-----------|-------------------|------------------------------------|
| 100p4:    | mov       | al,es:[bx]        | ;read zero bytes                   |
| •         | inc       | bx                |                                    |
|           | cmp       | bx,07ffh          |                                    |
|           | je        | eval              |                                    |
|           | cmp       | al,0              | ;test data against zero            |
|           | je        | no_err2           | skip counter if match is           |
|           | inc       | cx <sup>–</sup>   | ;found                             |
| no err2:  | mov       | al,es:[bx]        | ;read all one bytes                |
|           | inc       | bx                | -                                  |
|           | cmp       | al,Offh           | ;test data against ones            |
|           | je        | counter2          | ;skip if match is found            |
|           | inc       | сх                |                                    |
| counter2: | cmp       | bx,07ffh          | ;test for end of memory            |
|           | j1        | 100p4             | continue if not done;              |
|           |           |                   |                                    |
| ******    |           |                   | ******                             |
| ;look at  | 2k user : | ram error count a | and send ack or nack               |
| ;*******  | *******   | **************    | *******                            |
|           |           |                   |                                    |
| •••••1 •  |           | 0                 |                                    |
| eval:     | mov       | ax,0              | ;compare total errors              |
|           | cmp       | cx,ax             |                                    |
|           | je<br>jen | skip4             |                                    |
|           | jmp       | error             |                                    |
| skip4:    | mov       | di,offset ack s   | ta                                 |
| onipi.    |           | aryon bee uer_b   |                                    |
| buf full  | 3:        |                   |                                    |
|           | in        | al,msc reg        | ;read status register              |
|           | test      | al,tx rdy         | ;test for empty register           |
|           | jz        | buf full 3        | ;loop until UART is free           |
|           |           |                   | ,                                  |
|           | mov       | al,[di]           | ;load acknowledge character        |
|           |           | · -               | ;signals all clear on ram          |
|           | out       | data reg,al       | ;test to 2100                      |
|           | inc       | di                | <pre>;send ++ ack EOT string</pre> |
|           | cmp       | al,eot            | ;when end of string get            |
|           | mov       | cx,01ffh          |                                    |
| slow1:    | nop       |                   |                                    |
|           | loop      | slow1             |                                    |
|           |           |                   |                                    |
|           | jne       | buf_full_3        | ;download string                   |
|           | <b></b>   | ****              | *****                              |
| ,         |           |                   |                                    |
|           |           |                   | dw eot, download signal            |
|           |           |                   |                                    |
|           |           |                   |                                    |
|           | mov       | ax,0              |                                    |
|           | mov       |                   |                                    |

mov es,ax mov es,ax mov bx,0400h get\_char\_1:

a construction and the second of the second second and the second second second second second second second sec

|                   | in<br>test<br>jz                                                                    | al,msc_reg<br>al,char_rdy<br>get_char_1                                                                            | ;read status register<br>;check for a character<br>;loop until character available                                                                                                                           |
|-------------------|-------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| skip1:            | in<br>mov<br>cmp<br>je                                                              | al,data_reg<br>es:[bx],al<br>al,EOT<br>done                                                                        | ;read character<br>;save Z-100 response                                                                                                                                                                      |
|                   | inc<br>jmp                                                                          | bx<br>get_char_1                                                                                                   |                                                                                                                                                                                                              |
| done:             | cld<br>mov<br>lea<br>mov<br>repe<br>cmp<br>jne                                      | cx,04<br>si,down_1d<br>di,0400h<br>cmpsb<br>cx,0<br>error                                                          | ;test for download string<br>;point to download string<br>;point to received string<br>;compare strings                                                                                                      |
| ;******           | ******                                                                              | *****                                                                                                              | *****                                                                                                                                                                                                        |
|                   |                                                                                     | tor memory<br>*********                                                                                            | *****                                                                                                                                                                                                        |
| ; ~ ~ ~ ~ ~ ~ ~ ~ | ~ ~ ~ ~ ~ ~ ~ ~ ~ ~                                                                 | ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~                                                                            | *******                                                                                                                                                                                                      |
|                   | mov                                                                                 | dx,0300h                                                                                                           | clear xmt counter and;<br>set test # to emulator;                                                                                                                                                            |
| emul_cod          | e:<br>mov                                                                           | ax,0                                                                                                               | ;point to page zero of ram                                                                                                                                                                                   |
| emul:             | mov<br>mov<br>in<br>test<br>jz                                                      | es,ax<br>bx,0<br>cl,0<br>al,msc_reg<br>al,char_rdy<br>emul                                                         | ;point to 00000h memory<br>;use cl as checksum register<br>;read status register<br>;check for a character<br>;loop until character<br>;available                                                            |
| emul2:<br>emul3:  | in<br>cmp<br>je<br>mov<br>add<br>inc<br>jmp<br>mov<br>in<br>test<br>jz<br>in<br>cmp | <pre>al,data_reg al,ETB emul2 es:[bx],al cl,al bx emul ah,al al,msc_reg al,char_rdy emul3 al,data_reg al,ETB</pre> | <pre>;read character<br/>;check for end of download<br/>;if end get checksum<br/>;store the emulator program<br/>;add to checksum<br/>;save first byte of<br/>;terminator<br/>;if yes then end of file</pre> |
|                   | je<br>mov                                                                           | emul1<br>es:[bx],ah                                                                                                | ;else save the first data                                                                                                                                                                                    |
|                   |                                                                                     |                                                                                                                    |                                                                                                                                                                                                              |

.

| emul1:    | inc<br>add<br>mov<br>add<br>inc<br>jmp<br>in<br>test<br>jz<br>in<br>cmp<br>jne | <pre>bx cl,ah es:[bx],al cl,al bx emul al,msc_reg al,char_rdy emul1 al,data_reg cl,al error</pre> | <pre>;update chk_sum<br/>;save second byte<br/>;update chk_sum<br/>;read status register<br/>;check for a character<br/>;loop until character<br/>;available<br/>;read character<br/>;test checksum</pre> |
|-----------|--------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|           | *******                                                                        | ******                                                                                            | *****                                                                                                                                                                                                     |
| ; Send ac | knowledg                                                                       | e to Z-100 for en                                                                                 | nulator memory download                                                                                                                                                                                   |
| ;******   | ******                                                                         | *****                                                                                             | *****                                                                                                                                                                                                     |
|           |                                                                                |                                                                                                   |                                                                                                                                                                                                           |
|           | mov                                                                            | di,offset ack_s                                                                                   | tg ;load ack character                                                                                                                                                                                    |
| buf_full_ | 2:<br>in<br>test<br>jz                                                         | al,msc_reg<br>al,tx_rdy<br>buf_full_2                                                             | <pre>;read status register ;test for empty register ;loop until UART is free</pre>                                                                                                                        |
|           |                                                                                |                                                                                                   |                                                                                                                                                                                                           |
| slow2:    | mov<br>out<br>inc<br>cmp<br>mov<br>nop                                         | al,[di]<br>data_reg,al<br>di<br>al,eot<br>cx,01ffh                                                | <pre>;signals all clear ;test to host computer ;send ++ ack EOT string</pre>                                                                                                                              |
|           | loop                                                                           | slow2                                                                                             |                                                                                                                                                                                                           |
|           | jne                                                                            | buf_full_2                                                                                        |                                                                                                                                                                                                           |
| •         |                                                                                |                                                                                                   | ********                                                                                                                                                                                                  |
|           |                                                                                | main emulator p:                                                                                  | rogram<br>************************                                                                                                                                                                        |
| ,         |                                                                                |                                                                                                   |                                                                                                                                                                                                           |
|           | jmp                                                                            | far ptr emulato:                                                                                  | r ;pass control to main<br>;emulator program                                                                                                                                                              |
| •         |                                                                                |                                                                                                   | *********                                                                                                                                                                                                 |
|           |                                                                                | acknowledge NAC                                                                                   | K to 2-100                                                                                                                                                                                                |
| ,         |                                                                                |                                                                                                   |                                                                                                                                                                                                           |
| error:    | mov                                                                            | bx,dx                                                                                             | ;save test number and<br>;current xmt count value                                                                                                                                                         |
|           | mov                                                                            | di,offset nack_                                                                                   | stg ;load nack character                                                                                                                                                                                  |

......

| error1:                 | in         | al,msc reg           | ;read status register       |
|-------------------------|------------|----------------------|-----------------------------|
|                         | test       | al,tx rdy            | ;test for empty register    |
|                         | jz         | errorl               | ;loop until UART is free    |
|                         | <b>J</b> = |                      | ,                           |
|                         | mov        | al,[di]              |                             |
|                         | out        | data reg,al          |                             |
|                         | inc        | di                   | ;send ++ nack EOT string    |
|                         | cmp        | al,eot               | ,                           |
|                         | mov        | cx,01ffh             |                             |
| slow3:                  | nop        | 0, 0.12.2            |                             |
| 01000.                  | loop       | slow3                |                             |
|                         | 1005       | 01000                |                             |
|                         | jne        | errorl               |                             |
|                         | Jiie       | 011011               |                             |
|                         | mov        | dx,bx                | ;restore test number and    |
|                         | into v     |                      | ;current xmt count          |
|                         | inc        | d1                   | , current Ame count         |
|                         | cmp        | d1,03h               | .tost for three attempts    |
|                         | je         | fail                 | ;test for three attempts    |
|                         | -          | dh,01h               | ;go to infinite loop        |
|                         | cmp        |                      |                             |
|                         | jne        | skip2                | that CAN anon anoin         |
|                         | jmp        | test 64k             | ;test 64k sram again        |
| skip2:                  | cmp        | $dh, 0\overline{2}h$ |                             |
|                         | jne        | skip3                |                             |
|                         | jmp        | test_2k              |                             |
| skip3:                  | cmp        | dh,0 <u>3</u> h      |                             |
|                         | jmp        | emul_code            |                             |
|                         |            |                      |                             |
|                         |            |                      |                             |
| ; infinit               | e 100p w   | which waits for a    | hardware reset              |
| 6                       |            |                      |                             |
| fail:                   | nop        | c · · ·              |                             |
|                         | jmp        | fail                 |                             |
|                         |            |                      |                             |
| ;                       |            | 401                  |                             |
| reset                   | equ        | 40h                  | ;reset UART code            |
| err_chk                 | equ        | 38h                  | ;code for PE,OF,FE errors   |
| char_rdy                | equ        | 02h                  | ;test for full input        |
|                         |            | <u></u>              | ;register                   |
| tx_rdy                  | equ        | 01h                  | ;test for empty transmit    |
|                         |            | 4 .                  | ;register                   |
| set_mode                | equ        | 4eh                  | ;code for mode select       |
| set_contr               |            | 37h                  | ;control parameters         |
| dat <mark>a</mark> _reg | equ        | 50h                  | ;data register              |
| msc_reg                 | equ        | 51h                  | ;mode,status,control reg    |
| EOT                     | equ        | 2fh                  | ;code for end of file       |
| ETB                     | equ        | 1bh                  | ;end block transfer         |
| no_ack                  | equ        | 15h                  | ;for error during data read |
| ack                     | equ        | 06h                  | ;acknowledge code           |
| attn                    | equ        | 2bh                  | ; attention definition      |
| nack                    | equ        | 15h                  | ;negative acknowledge code  |
| portB                   | equ        | 41h                  | ;8755 port B                |
| portA                   | equ        | 40h                  | ;8755 port A                |
|                         | -          |                      | _                           |

عدندت

Þ

١.

|      | <br>equ<br>equ<br>equ<br>equ<br>equ<br>equ<br>db<br>db<br>db<br>db |                                        | ot ;down next from Z-100<br>eot ;negative ack string |
|------|--------------------------------------------------------------------|----------------------------------------|------------------------------------------------------|
| cseg | org<br>jmp<br>org<br>nop<br>ends<br>end                            | 7f0h<br>far ptr start<br>7ffh<br>start | ;go to top of program                                |

Barta and a secure correct & were a surright a

E

Ľ

...

## TITLE EMULATOR main program

; This program must be downloaded to page zero of the ; emulator address space to be functional.

, ·

Ł

| cseg   | segmen                   | t                                                                      |
|--------|--------------------------|------------------------------------------------------------------------|
|        | assume                   | cs:cseg,ds:cseg,ss:cseg,es:cseg                                        |
|        | org                      | 0                                                                      |
|        | db                       | 0                                                                      |
|        | org                      | 0400h                                                                  |
| start: | mov<br>mov               | ax,cs<br>ds,ax                                                         |
|        | mov<br>mov<br>mov        | ax,0effh ;ss address<br>ss,ax ;set stack<br>ax,1000h ;segment<br>sp,ax |
|        |                          | ;setup stack;vector                                                    |
|        | mov<br>mov<br>mov<br>mov | bx,0<br>di,0020h ;type 8 IP<br>ax,offset type8<br>[di],ax<br>di,0022h  |
|        | mov                      | [di],bx ;cs to 0000                                                    |
|        | mov<br>mov<br>mov<br>mov | di,0024h ;type 9 IP<br>ax,offset type9<br>[di],ax<br>di,0026h          |
|        | mov                      | [di],bx ;cs to 0000                                                    |
|        | mov<br>mov<br>mov        | di,0028h ;type A IP<br>ax,offset typeA<br>[di],ax<br>di,002Ah          |
|        | mov                      | [di],bx ;cs to 0000                                                    |
|        | mov<br>mov<br>mov        | di,002Ch ;type B IP<br>ax,offset typeB<br>[di],ax<br>di,002Eh          |
|        | mov                      | [di],bx ;cs to 0000                                                    |
|        | mov                      | di,0030h ;type C IP                                                    |

| mov<br>mov<br>mov<br>mov | ax,offse<br>[di],ax<br>di,00321<br>[di],bx |              | ;cs to 0000              |
|--------------------------|--------------------------------------------|--------------|--------------------------|
| jmp                      | waiting                                    |              |                          |
|                          |                                            |              |                          |
| ;*********               | * * * * * * * * * * * * *                  | ******       | *****                    |
| reset                    | equ                                        | 40h          | ;reset UART code         |
| err chk                  | equ                                        | 38h          | ;code for PE,OF,FE       |
| <u>-</u>                 | - 1                                        |              | ;errors                  |
| char rdy                 | equ                                        | 02h          | ;test for full input     |
|                          | -                                          |              | ;register                |
| tx_rdy                   | equ                                        | 04h          | ;test for empty          |
|                          |                                            |              | ;transmit register       |
| set_mode                 | equ                                        | 5eh          | ;code for mode select    |
| set_control              | equ                                        | 37h          | ;code for control        |
| _                        |                                            |              | ;parameters              |
| data_reg                 | equ                                        | 50h          | ;data register           |
| msc_reg                  | equ                                        | 51h          | • · · • •                |
|                          |                                            |              | ;mode,status,control     |
| DOM                      |                                            | 2 <b>6</b> 2 | ;register address        |
| EOT                      | equ                                        | 2fh          | ;code for end of         |
| nack                     | 000                                        | 15h          | ;file<br>;code for error |
| Hack                     | egu                                        | 1.211        | during data read         |
| ack                      | equ                                        | 06h          | acknowledge code         |
| plus                     | equ                                        | 2bh          | ; attention definition   |
| rd err                   | equ                                        | 18h          | ;serial read error       |
| 14_011                   | equ                                        | 2011         | ;code                    |
| rdy                      | equ                                        | 1ah          | ;ready code              |
| portA                    | equ                                        | 40h          | ;8755 port A             |
| portB                    | equ                                        | 41h          | ;8755 port B             |
| ddra                     | equ                                        | 42h          | ;8755 port A DDR         |
| ddrb                     | equ                                        | 43h          | ;8755 port B DDR         |
| port1                    | equ                                        | 31h          | ;8259 port 1             |
| port0                    | equ                                        | 30h          | ;8259 port 0             |
| step                     | equ                                        | 20h          | ;perform step            |
|                          | - 1-                                       |              | ; increment              |
| down                     | equ                                        | 09h          | ;down transfer           |
|                          | - 1                                        |              | direction flag           |
| up                       | equ                                        | 08h          | ;upload direction        |
| -                        | •                                          |              | ;flag                    |
| on                       | equ                                        | 4eh          | ;on flag                 |
| off                      | equ                                        | 4fh          | ;off flag                |
| bk_off                   | equ                                        | 10h          | ;disable break           |
| -                        |                                            |              | ;registers               |
| bk_on                    | equ                                        | 00h          | ;enable break            |
|                          |                                            |              | ;detectors               |
|                          |                                            |              |                          |

E

Γ.

ь.

1

1

| ack_stg              | db         | 2bh,2bh,06h,2fh                                                    |
|----------------------|------------|--------------------------------------------------------------------|
| down ld              | 4 h        | ;acknowledge string                                                |
| down_ld              | db         | 2bh,2bh,09h,2fh<br>;data from Z-100                                |
|                      |            | ;next                                                              |
| nack stg             | db         | 2bh,2bh,15h,2fh                                                    |
| _ *                  |            | ;negative ack string                                               |
| user_stg             | db         | 2bh,2bh,55h,2fh                                                    |
|                      |            | ;user memory function flag                                         |
| break_stg            | db         | 2bh,2bh,42h,2fh                                                    |
| stop sta             | đb         | ;break function flag                                               |
| step_stg             | db         | 2bh,2bh,53h,2fh                                                    |
| port stg             | db         | stepper function flag;<br>2bh,2bh,50h,2fh                          |
| •                    |            | ;port function flag                                                |
| mode_stg             | db         | 2bh,2bh,4dh,2fh                                                    |
| _                    |            | ;mode function flag                                                |
| rdy_stg              | db         | 2bh,2bh,1ah,2fh                                                    |
|                      |            | ;ready response string                                             |
| emulator             | equ        | 0                                                                  |
| target               | equ        | 1                                                                  |
| brk stat             | db         | ?                                                                  |
| -                    |            | ;break is initially off                                            |
| user                 | đb         | 2049 dup (?)                                                       |
|                      |            | juser memory buffer                                                |
| brk buf              | dw         | 5 dup (?)                                                          |
| -                    |            | ;break address buffer                                              |
| work                 | đb         | 100 dup (?)                                                        |
| modo fla             | <u>م</u> 1 | ;working buffer area                                               |
| mode_flg             | db         | ? ;mode flag                                                       |
| <pre>step_flg</pre>  | db         | ;00=emulator, ff=target<br>?       ;flag for step or freerun       |
|                      | 42         | ;00=freerun, ff=stepper                                            |
| u_start              | dw         | ? ;starting address                                                |
| _                    |            | ; of user memory download                                          |
| byte_num             | dw         | ? ;byte count storage                                              |
| temp_buf             | db         | 10 dup (?)                                                         |
| chk sum              | db         | ;user read buffer                                                  |
| xmt                  | đb         | <pre>? ;checksum count buffer<br/>? ;retransmit count buffer</pre> |
| int brk num          | db         | ? ;interrupt type buffer                                           |
|                      |            | , and the type bullet                                              |
| break_1a             | equ        | 60h ;register 1 part A                                             |
| break_1b             | equ        | 70h ;register 1 part B                                             |
| break_2a             | equ        | 80h ;register 2 part A                                             |
| break_2b             | equ        | 90h ;register 2 part B                                             |
| break_3a<br>break_3b | equ        | 0A0h ;register 3 part A                                            |
| break 4a             | equ<br>equ | OBOh ;register 3 part B<br>OCOh ;register 4 part A                 |
| break 4b             | equ        | ODOh ;register 4 part A                                            |
| break 5a             | equ        | OEOh ;register 5 part A                                            |
| —                    | -          |                                                                    |

E

1

ľ

break 5b OFOh equ ;register 5 part B ; ; This macro compares the contents of two strings. The source ; and destination offset must be provide and the CX register ; must contain the string length. For a match the AX register ; will return zero. Any other value means no match. \*\*\*\*\*\*\*\*\*\*\* string1, string2 compare macro push si di push push сх cld mov cx,4 lea si,string1 ; point to input string di,string2 ;point to test string lea repe cmpsb ;compare strings mov ax,cx ;set al to the value of ;cx. If cx equal zero ;strings match сх ;restore original string pop di pop ;length si pop endm ; ; This macro sets the user memory U-18 to either the emulator ; access or target access. ul8 to macro system push ax call set step ;halt the target mov al,system mode\_flg,al ;set mode flag mov call mode pop ax endm

. . .

the second and all all and the second have a share to be the

\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\* This macro clears the memory location designated as "slot". ; clear slot macro mov slot,0 endm This macro transmits the designated flag to the Z-100. \*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\* send macro flag name lea di,flag\_name call send flag endm ; This procedure sets and resets the mode flipflop. ; The mode is determined by the value in the mode flag, ; which must be set prior to calling this procedure. \*\*\*\*\*\*\*\* mode proc near push ax push bx mov bx,0 ;clear bx ax,2000h mov ;set es to page 2 es,ax mov mov bl, mode flg ;set IP mov es:[bx],al ;set mode to emulator bl=0h ;or target bl=01h pop bx ax pop ret mode endp

1.4° X.

; This procedure reads in a string of characters from the ; serial port and stores it in the working buffer. The string ; length is returned in the CX register. \*\*\*\*\* get flag proc near push di mov di, offset work ; point to working buffer mov cx,0 ;clear character counter morel: call serial rd ;read serial port [di],al mov ;save data cmp al,eot ; check for end of string all\_done je inc di inc СХ ;at the end of the string jmp morel ;cx contains the count all done: pop di ret get flag endp ; This procedure sends a string of characters from the ; serial port to the Z-100. The string offset must be ; in the DI register when the call is made. \*\*\*\*\*\*\*\*\*\* send flag proc near push ax continue: mov al,[di] ;load a byte of data call serial wr ;transmit the data cmp al,eot ; check for end of string je return inc di ;point to next byte jmp continue ;repeat process return: pop ax ret send flag endp ;

the product of the martine but the read and the

\$ 4

Ľ

Į.

Į\_

; This procedure sets the emulator to the single-step mode ; and updates the stepper status flag set step proc near push ax bx push mov bx,0 **ax,4**000h mov ;set es to page 4 es,ax mov es:[bx],al ;set stepper to step mode mov b1,0ffh mov ;set step flag to ff = step mov step\_flg,bl pop bx pop ax ret set step endp ; This procedure sets the emulator to the freerun mode and ; updates the stepper status flag \*\*\*\*\*\*\*\*\*\* freerun proc near push ax bx push mov bx,0 movax,3000h ;set es to page 3 mov es,ax es:[bx],al ;set stepper to free run mov ;set flag to 00 = freerun mov step flg,bl pop bx ax pop ret freerun endp ; This procedure simply pulses the target ready line. inc\_step proc near

المحاجبة المحمدة والمستحد فالسائد فالمستجد ببوار العاديون

المحمقة بالالتفاعية الالمنتاب بالالالتين ونفق فتقتدها

out step,al ; pulses the target step ;circuit ret inc\_step endp \*\*\*\*\*\* ; This procedure disables the break detectors and ; updates the break status flag \*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\* brk off proc near pk\_off,al ;set break flipflop to off brk\_stat,off ;store break stat; push out mov pop ax ret brk off endp \*\*\*\*\*\*\*\*\*\*\* ; This procedure enables the break detectors and ; updates the break status flag. \*\*\*\*\*\* brk on proc near out Bk on,al ;set break flipflop to on mov brk stat, on ;store break status ret brk on endp \*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\* ; ; This procedure moves the data pointed to by "Start" and the ; amount specified by "Byte" from the user buffer to the ; target ram in the same locations. Start and byte# must be ; updated prior to the call. \*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\* load proc near push аx push bx

ala de la calendar de

t

C

ŧ

Ł

push СХ dx push cld ax,6000h ; point to user ram mov mov es,ax di,u\_start ;set starting address of mov ;memory in target ram ;number of bytes to move mov cx, byte num mov si,offset user ; point to starting address add si,u start ; of user buffer data repe movsb ;transfer data dx pop pop СХ bx pop ax pop ret load endp This procedure retrieves a specified of number bytes from ; user memory and places them in the temporary buffer ; user rd proc near push ax push di push bx push СХ clear chk sum mov ax,6000h ; point to user memory es,ax mov cx,0 mov cx, byte num ;load byte counter mov mov bx, offset temp buf ; setup temporary buffer ;at the specified location di,u start mov rd loop: mov al,es:[di] ;read the byte mov [bx],al ; put data in the holding ;buffer add chk sum,al ;update checksum inc di inc bx loop rd\_loop inc bx ;tack on the eot to buffer mov al,eot

and the stand the stand the second stand and the

· • • • •

ا المعام مصار ال

[bx],al mov pop сх bx pop di pop pop ax ret user rd endp ; This procedure reads the 8755 ports A and B, and returns ; the results in the AL register. Which port to read is ; placed in the DX register prior to the call. \*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\* in\_8755 proc near push ax ul8 to ;halt target emulator ;read 8755 port in al,dx mov chk sum,al ;save data in checksum ; because in this case ;data = checksum ul8 to target ;restart target call freerun pop ax ret in 8755 endp \*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\* ; This procedure performs output operations to 8755 data and ; data direction ports. The port to access is loaded in DX ; and the data out is in AL prior to the call. out 8755 proc near ul8 to emulator ;halt target out ;write to 8755 port dx,al ul8 to target ;restart target call freerun ret out 8755 endp

and the second second second second second

This procedure performs a serial read of port 50h. The ; data is returned in the AL register. Each data read is ; preceded by a status check of the receiver. ; serial rd proc near push dx get char 1: mov dx,msc\_reg in al,dx ;read status register test al, char rdy ; check for a character jΖ get\_char\_1 ;loop until character ;available test ;check for errors al,err chk jnz exit mov ;read data byte and return dx,data reg in al,dx ; in al register jmp exit1 exit: mov al, rd err ;set read error ;flag call serial wr jmp get char 1 exit1: pop dx ret serial rd endp ; This procedure performs a serial output to port 50h. The ; data to be transmitted must be in the AL register prior ; to the call. Each data output is preceded by a status check ; of the UART to ensure its availability. serial wr proc near push ax ;save data buf full 1: in al, msc reg ;read status register ;test for empty transmit test al,tx\_rdy ;register

بالمالة المالية ومحملا بمعالية والمراجع والمعظم

;loop until UART is free buf full 1 jΖ ;restore data pop ax data reg,al out ; pass the data to Z100 ret serial wr endp \*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\* ; This procedure loads the break detection registers. The ; break detect address buffer must be loaded prior to the : call. \*\*\*\*\*\*\*\*\* brk addr proc near di push dx push push сх cx,0Ah mov di, offset brk buf ; point to break address mov ;buffer dx,60h;load first break address mov al,[di] ;output one byte of next1: mov ;address out dx,al ;at a time. Two bytes are ;required for each address inc di add dx, 10h; move to next byte next1 100p сх pop pop dx pop di ret brk addr endp \*\*\*\*\*\*\*\*\*\*\* ; ; This procedure handles all emulator functions involving ; the user ram U18. The user code may be downloaded or the ; user may upload up to ten consecutive bytes. user\_pro proc near ;send the ready string send rdy stg

الم المراجعة الحد الم المحمومة ا

I

|           | call        | get_flag                 | ;get the direction flag<br>;for next operation       |
|-----------|-------------|--------------------------|------------------------------------------------------|
|           | compare     | work,down_ld             | ; if equal go to upload                              |
|           | cmp         | al,0 –                   |                                                      |
|           | je          | leap                     |                                                      |
|           | jmp         | up_data                  | ;else download was                                   |
| •         |             |                          | requested                                            |
| leap:     | call        | serial_rd                | ;get high byte of user                               |
|           |             | hh -1                    | start address                                        |
|           | mov<br>call | bh,al<br>serial rd       | ;move high byte to AH                                |
|           | mov         | bl,al                    | ;store the starting address                          |
|           | mov         | u start,bx               | store the starting address                           |
|           | clear       | xmt                      | clear retransmit counter;                            |
|           |             |                          | ,                                                    |
| user_loop | :           |                          |                                                      |
|           | clear       | chk_sum                  | ;clear check sum                                     |
|           | call        | serial_rd                | ;get byte count                                      |
|           | mov         | bh,al                    |                                                      |
|           | call        | serial_rd                |                                                      |
|           | mov         | bl,al                    |                                                      |
|           | mov         | byte_num,bx<br>bx,bx     |                                                      |
|           | xor<br>send | rdy stg                  |                                                      |
|           | senu        | Idy_sty                  |                                                      |
|           | lea         | di,user                  | ;point to top of user                                |
|           |             | <b>-</b> • • •           | ;buffer                                              |
|           | add         | di,u_start               | ;point to starting location<br>;of desired data move |
| continuel | :           |                          |                                                      |
|           | call        | serial_rd                | ;get the data                                        |
|           | mov         | [di],al                  | ;store the data in the                               |
|           |             | able aver all            | ;user buffer                                         |
|           | add         | chk_sum,al               | ;update check sum                                    |
|           | inc<br>cmp  | bx<br>bx,07ffh           |                                                      |
|           | je          | no more                  | ; if all done test chk sum                           |
|           | inc         | di                       | , iii uiii uone eese on <u>n</u> _bum                |
|           | jmp         | continue1                |                                                      |
|           |             |                          |                                                      |
| no_more:  | call        | serial_rd                | ;get checksum                                        |
|           | jmp         | johnny                   |                                                      |
|           | cmp         | chk_sum,al               | ;test checksum                                       |
|           | jne         | retrans                  |                                                      |
| johnny:   | send        | ack stg                  | ;send Z-100 the acknowledge                          |
| Jonniy.   | ul8 to      |                          | ;allow access to user ram                            |
|           |             | ~1114 # W V V L          | Farton accord to about tam                           |
|           | call        | load                     | ;move data to user memory                            |
|           |             | target                   | ;restart target                                      |
|           | call        | freerun                  |                                                      |
|           | jmp         | <pre>exit_user_pro</pre> | return to waiting loop;                              |
|           |             |                          |                                                      |

and the second state of the second

Ľ

ĺ.

Þ

Ľ

144. At 1125

| retrans:  | add           | xmt,1                    | ; increment xmt counter                  |
|-----------|---------------|--------------------------|------------------------------------------|
|           | cmp<br>je     | xmt,3<br>exit user pro   | ; if three tries exit                    |
|           | send          | nack stg                 | ;inform 2-100 bad data                   |
|           | jmp           | user loop                | ; miorm 2-100 bad data<br>; was received |
|           | JP            | uber_100p                | , as received                            |
|           | 11            |                          |                                          |
| up_data:  | call          | serial_rd                | ;get high byte of user<br>;start address |
|           | mov           | bx,offset u sta          |                                          |
|           | mov           | [bx]+1,a1                | ;move high byte to AH                    |
|           | call          | serial rd                |                                          |
|           | mov           | [bx],al                  | ;store the starting address              |
|           | call          | serial rd                | ;get number of bytes                     |
|           |               | -                        | ;desired                                 |
|           | mov           | <pre>byte_num,ax</pre>   | ;and store it                            |
|           | clear         | xmt                      | clear retransmit counter;                |
|           | CICUI         | Ant                      | cieal reclammit counter                  |
|           | u18_to        | emulator                 | grants emulator access;                  |
|           |               | _                        |                                          |
|           | call          | user_rd                  | ;get the specified bytes                 |
|           | 11            | £ maanun                 | ;and store in buffer                     |
| retrans1: | call          | freerun                  | ;restart target                          |
| recransr: | send          | ack_stg<br>temp buf      | upload lata                              |
|           | mov           | al, chk sum              | ;upload Jata<br>;send check sum          |
|           | call          | serial wr                | ; send check sum                         |
|           | call          | get flag                 | ;read Z-100 response                     |
|           |               | work,ack stg             | ; if not ack then error                  |
|           | cmp           | ax,0                     | , II NOT ACK CHEM EIIOI                  |
|           | jne           | skip_it                  |                                          |
|           | jmp           | exit user pro            | ;transaction complete, exit              |
|           |               |                          | -                                        |
| skip_it:  | add           | xmt,1                    | ; increment xmt counter                  |
|           | cmp           | xmt,3                    | ; if three tries exit                    |
|           | je            | <pre>exit_user_pro</pre> |                                          |
|           | jmp           | retrans1                 | ;was received                            |
| exit user | pro:          | ret                      |                                          |
| user_pro  | endp          |                          |                                          |
|           | *******       | ****                     |                                          |
| •         |               |                          |                                          |
| · This pr |               | enables or disab         | les the single-step                      |
|           |               |                          | -step status flag. It                    |
|           |               | target upon demai        |                                          |
| ;         | • • • • • • • |                          |                                          |
| ;******   | *******       | ******                   | *********                                |
| <b></b>   |               |                          |                                          |
| step_pro  | proc          | near                     |                                          |

F

|           | send | rdy_stg<br>serial_rd  | ;send ready<br>;get desired mode      |
|-----------|------|-----------------------|---------------------------------------|
|           |      |                       | ; check for turn on                   |
|           | cmp  |                       | ; check for curn on                   |
|           |      | skip_over<br>set step | .sot to single-stop                   |
|           |      |                       | ;set to single-step                   |
| -1        |      | exit_step_pro         |                                       |
| skip_over |      |                       |                                       |
|           |      | al,off                | ;check for turn off                   |
|           | jne  | skip_over1            |                                       |
|           | call | freerun               | ;set to freerun                       |
|           | jmp  | exit step pro         |                                       |
| skip over |      |                       |                                       |
|           |      | al,step               | ;check for step                       |
|           |      | out pro               | -                                     |
|           |      | step flg,on           | ;makes sure in single step            |
|           | jne  | stepnack              | _                                     |
|           |      | inc step              | ;step the target                      |
|           | jmp  | exit step pro         |                                       |
| step nack |      | _ · _ ·               |                                       |
| •_        | send | nack_stg              | ;return nack signal                   |
|           | jmp  | out pro               | · · · · · · · · · · · · · · · · · · · |
| exit step |      |                       |                                       |
|           | send | ack stg               | ;return ack signal                    |
|           | Sena | acr_scy               | ficturn uck bighai                    |
| out pro:  | ret  |                       |                                       |
| ~~~P10.   | 100  |                       |                                       |

step\_pro endp

.

1

19 A.

port\_pro proc near

|            | send<br>call | rdy_stg<br>serial rd | ;return ready         |
|------------|--------------|----------------------|-----------------------|
|            | cmp          | al,up                | ;test direction flag  |
|            | jne          | wr_port              | ;branch on down flag  |
|            | call         | serial rd            | ;get port number      |
|            | cmp          | al,porta             | ;test for port A read |
|            | jne          | read portb           |                       |
|            | mov          | dx, porta            |                       |
|            | jmp          | read porta           |                       |
| read_porth | <b>.</b> .   |                      |                       |
|            | mov          | dx,portb             | ;point to port B      |
| read_porta | 1:           |                      |                       |
|            | call         | in_8755              | ;read port A data     |

| <pre>retrans3:<br/>bad_try:</pre> | nov<br>call<br>mov<br>call<br>mov<br>call<br>call | <pre>xmt<br/>rdy_stg<br/>al,chk_sum<br/>serial_wr<br/>al,eot<br/>serial_wr<br/>al,chk_sum<br/>serial_wr<br/>get_flag<br/>work,ack_stg<br/>ax,0<br/>bad_try<br/>exit_port_pro<br/>xmt,1<br/>xmt,3<br/>:xit_port_pro<br/>retrans3</pre> | <pre>;checksum = data here<br/>;send data to Z-100<br/>;send eot<br/>;send checksum<br/>;get response<br/>;data transferred<br/>;increment counter</pre> |
|-----------------------------------|---------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
| wr_port:<br>retrans4:             | clear                                             | xmt<br>chk_sum                                                                                                                                                                                                                        |                                                                                                                                                          |
| get_more:                         | mov<br>cmp<br>je<br>add                           | <pre>serial_rd [di],al al,eot thats_it chk_sum,al</pre>                                                                                                                                                                               | ;return ready<br>;point to working buffer<br>;read serial port<br>;save data<br>;check for end of string                                                 |
| thats_it:                         | inc<br>jmp<br>call<br>cmp<br>jne                  | di<br>get_more<br>serial_rd<br>al,chk_sum<br>too_bad                                                                                                                                                                                  | ;get checksum                                                                                                                                            |
|                                   | mov<br>mov<br>mov                                 | di,offset work<br>dx,0<br>dl,[di]                                                                                                                                                                                                     | ;clear dx<br>;point to port number                                                                                                                       |
|                                   | inc<br>mov<br>call<br>send<br>jmp                 | di<br>al,[di]<br>out_8755<br>ack_stg<br>exit_port_pro                                                                                                                                                                                 | ;load data byte<br>;send data byte                                                                                                                       |
| too_bad:                          | send<br>add<br>cmp<br>je<br>jmp                   | <pre>nack_stg xmt,1 xmt,3 exit_port_pro retrans4</pre>                                                                                                                                                                                | ;return nack signal<br>;increment counter                                                                                                                |
| exit_port                         | _pro: r                                           | et                                                                                                                                                                                                                                    |                                                                                                                                                          |
| port_pro                          | endp                                              |                                                                                                                                                                                                                                       |                                                                                                                                                          |

....

Ľ

.

-

Ľ

I

المراجعة والعيادية

\*\*\*\*\*\*\*\*\*\* ; This procedure enables or disables the emulator break ; detection circuits. It also downloads the break address ; file from the Z-100 and loads it into the break registers. break pro proc near push ax push di send rdy stg ;return ready call serial\_rd ;get instruction cmp al, on ; check for turn break on jne chk off call brk on ;turn break on ack\_stg send ;return ack signal exit break pro jmp chk\_off: cmp al, off ; check for turn break off jne load brk brk off call ;turn break off ack\_stg send ;return ack signal exit break pro jmp load brk: mov  $xmt, \overline{0}$ chk sum clear ;get break addresses load brk 1: rdy stg send di, offset brk buf ;setup break address mov mov cx,10 ;buffer next brk: call serial rd ;get byte mov [di],al ;store data add chk sum,al inc di loop next brk ;get checksum all here: call serial rd Cmp chk sum,al ; and test jne no\_good call brk off ;disable break circuits call brk addr ;load break registers call brk on ;enable break circuits send ;return ack signal ack\_stg jmp exit break pro no good: send nack stg ;return nack signal clear chk sum xmt,1 add cmp xmt,3 jne load brk 1 exit break pro:

and a start of the start of the second starts and the second starts and the second starts and the second starts

3

à.

Ľ

.

Į

I

| рор | di |
|-----|----|
| рор | ax |
| ret |    |

break pro endp

والمراجع وأردار والمراكز فراريا والمتحارية المعادية المحاجية المتعاطية

\*\*\*\*\*\*\*\*\*\*\*\* ; This procedure processes the emulator break detect ; interrupt response. The break address type number is ; passed to the Z-100. The break condition is cleared and ; the break circuits restarted on command. \*\*\*\*\*\*\*\*\*\*\*\*\* brk handler proc near clear xmt retrans11: send break stq call get flag compare work,ack stg ;get the ack signal cmp ax,0 jne retrans11 mov al, int brk num ; get the type number chk sum,al mov call serTal wr ;send break type mov al,eot call serial wr ;send eot al, chk sum mov call serial wr ;send checksum call get flag compare work, ack stg ;get the ack signal cmp ax,0 je done11 add xmt,1 cmp xmt,3 jle retrans11 done11: ret brk handler endp \*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\* \*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\* ; This is the main waiting loop of the emulator code. Its ; function is to monitor the Z-100 and call the approriate ; subroutine to handle a given request.

| ;<br>; *********************************** |                                        |                                                        |                                                                                          |
|--------------------------------------------|----------------------------------------|--------------------------------------------------------|------------------------------------------------------------------------------------------|
| waiting:                                   | mov<br>mov                             | di,offset work<br>cx,0                                 | point to working buffer;<br>clear character counter;                                     |
| more_w:                                    | call<br>mov<br>cmp<br>je<br>inc<br>inc | <pre>serial_rd [di],al al,eot all_in di cx</pre>       | ;read serial port<br>;save data<br>;check for end of string<br>;at the end of the string |
|                                            | jmp                                    | more_w                                                 | ;cx contains the count                                                                   |
| all_in:                                    | cmp                                    | work,user_stg<br>al,0<br>skip1                         | ;determine which instr<br>;was received                                                  |
|                                            | call<br>jmp                            | user_pro<br>waiting                                    | ;pass control to user<br>;memory module, the return<br>;main waiting loop                |
| skip1:                                     | cmp<br>jne<br>call                     | work,break_stg<br>al,0<br>skip2<br>break_pro           | ;pass control to<br>;break module                                                        |
|                                            | jmp                                    | waiting                                                |                                                                                          |
| skip2:                                     | compare<br>cmp<br>jne<br>call<br>jmp   | <pre>work,step_stg al,0 skip3 step_pro waiting</pre>   | ;pass control to stepper<br>;control module                                              |
| skip3:                                     | compare<br>cmp<br>jmp<br>call<br>jmp   | <pre>work,port_stg al,0 waiting port_pro waiting</pre> | ;pass control to port<br>;control module                                                 |
|                                            | 51                                     |                                                        | ,                                                                                        |
| type8:                                     | mov<br>call<br>iret                    | int_brk_num,08h<br>brk_handler                         | ;set pointer                                                                             |
| type9:                                     | mov<br>call<br>iret                    | int_brk_num,09h<br>brk_handler                         | ;set pointer                                                                             |

and the second second second second second

| typeA: | mov<br>call<br>iret | int_brk_num,0Ah<br>brk_handler | ;set pointer |
|--------|---------------------|--------------------------------|--------------|
| typeB: | mov<br>call<br>iret | int_brk_num,0Bh<br>brk_handler | ;set pointer |
| typeC: | mov<br>call<br>iret | int_brk_num,0Ch<br>brk_handler | ;set pointer |
| cseg   | ends                |                                |              |
|        | end                 |                                |              |

----

A.1.

## TITLE EMULATOR Z100 CONTROL PROGRAM

Sec. Sec.

. .

| page 60,132                                                                                       |                                                                    |                                                                                             |                                                                                                                                                                                                                                                               |  |
|---------------------------------------------------------------------------------------------------|--------------------------------------------------------------------|---------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| dseg                                                                                              | segment                                                            | segment                                                                                     |                                                                                                                                                                                                                                                               |  |
| ;define v<br>;*******                                                                             | aribles                                                            | and labels<br>**************                                                                | *****                                                                                                                                                                                                                                                         |  |
| cls                                                                                               | db                                                                 | 26 dup (13,10),                                                                             | " \$ "                                                                                                                                                                                                                                                        |  |
| xlat_asci                                                                                         | i_char_2                                                           | _hex_value labe                                                                             | l byte ;hex lookup table                                                                                                                                                                                                                                      |  |
|                                                                                                   | db<br>db<br>db<br>db                                               | 7 dup (0ffh),0a                                                                             | ,1,2,3,4,5,6,7,8,9<br>h,0bh,0ch,0dh,0eh,0fh<br>ah,0bh,0ch,0dh,0eh,0fh                                                                                                                                                                                         |  |
| ascii_tabl                                                                                        | e label                                                            | byte                                                                                        | ;ascii lookup table                                                                                                                                                                                                                                           |  |
|                                                                                                   | db<br>db<br>db<br>db<br>db<br>db<br>db                             | 41h,42h,43h,44h<br>31h,15 dup (?),<br>15 dup (?),34h,<br>36h,15 dup (?),<br>15 dup (?),39h, | 32h,15 dup (?),33h<br>15 dup (?),35h,15 dup (?)<br>37h,15 dup (?),38h<br>15 dup (?),41h,15 dup (?)<br>43h,15 dup (?),44h                                                                                                                                      |  |
| cr<br>lf<br>EOT<br>ETB<br>nack<br>ack<br>plus<br>err_flg<br>rdy<br>portA<br>portB<br>ddra<br>ddrb | equ<br>equ<br>equ<br>equ<br>equ<br>equ<br>equ<br>equ<br>equ<br>equ | 13<br>10<br>2fh<br>1bh<br>15h<br>06h<br>2bh<br>18h<br>1ah<br>40h<br>41h<br>42h<br>43h       | <pre>;code for end of file<br/>;end of block transfer<br/>;code for error<br/>;during data read<br/>;acknowledge code<br/>;attention definition<br/>;error code<br/>;ready code<br/>;8755 port A<br/>;8755 port B<br/>;8755 port B<br/>;8755 port B DDR</pre> |  |
| step<br>down<br>up<br>on<br>off<br>bk_off                                                         | equ<br>equ<br>equ<br>equ<br>equ<br>equ                             | 20h<br>09h<br>08h<br>4eh<br>4fh<br>10h                                                      | <pre>;perform step increment<br/>;down transfer direction<br/>;flag<br/>;upload direction flag<br/>;on flag<br/>;off flag<br/>;disable break registers</pre>                                                                                                  |  |
| bk_off<br>bk_on                                                                                   | equ<br>equ                                                         | 10h<br>00h                                                                                  | ;disable break registers<br>;enable break detectors                                                                                                                                                                                                           |  |

| ack_stg            | db             | 2bh,2bh,06h,2fh   | <b></b>                                                    |
|--------------------|----------------|-------------------|------------------------------------------------------------|
| down_1d            | db             | 2bh,2bh,09h,2fh   | ;acknowledge string                                        |
| nack_stg           | đb             | 2bh,2bh,15h,2fh   | ;data from Z-100 next                                      |
| user_stg           | đb             | 2bh,2bh,55h,2fh   | ;negative ack string                                       |
| break_stg          | db             | 2bh,2bh,42h,2fh   | ;user memory function flag                                 |
|                    | db             | 2bh,2bh,53h,2fh   | ;break function flag                                       |
| -<br>port stg      | db             | 2bh,2bh,50h,2fh   | ;stepper function flag                                     |
| mode stg           | db             | 2bh,2bh,4dh,2fh   | ;port function flag                                        |
| rdy stg            | db             | 2bh,2bh,1ah,2fh   | ;mode function flag                                        |
|                    |                | ,                 | ;ready response string                                     |
| emulator<br>target | equ<br>equ     | 0h<br>01h         | <pre>;emulator identification ;target identification</pre> |
| user_code          | label<br>db    | byte<br>(?)       | ;user filename buffer<br>;maximum length                   |
| char_ct            | db             | (?)               | ;actual length                                             |
| user_file          | db             | 15 dup (?)        | ;filename<br>;buffer for user filename                     |
| filnam             | db             | 'EMULATOR.BIN',   |                                                            |
| user               | db             | 2048 dup (?)      | ;filename for emulator                                     |
| brk buf            | db<br>db       | (?)<br>10 dup (?) | ;user memory buffer                                        |
| DIX_Dui            | ab             | 10 dup (1)        | ;break address buffer                                      |
| work               | dw             | ?                 | working buffer area                                        |
| mode_flg           | db             | ?                 | ;flag for target or                                        |
|                    |                |                   | ;emulator                                                  |
| break_flg          | db             | ?                 | hungh singuit status flas                                  |
|                    |                |                   | <pre>;break circuit status flag ;on or off</pre>           |
| step flg           | db             | ?                 | ;on or off                                                 |
| 000F_119           |                | •                 | ;off = freerun, on =                                       |
|                    |                |                   | ;stepper                                                   |
| _                  | dw             | ?<br>?            |                                                            |
| u_start            | dw             | ?                 | ;starting address of user                                  |
| u stop             | dw             | ?                 | ;memory download<br>;stop address of user                  |
| a_scop             | u <del>n</del> | é                 | ; memory download                                          |
| byte_num           | dw             | ?                 | ;byte count storage                                        |
| temp_buf           | label          | byte              | ;temporary                                                 |

مراجع والمراجع والمراجع والمحاصر والمحاصر والمحاصر والمحاصر والمحاصر والمحاصر والمحاص والمحاص والمحاص

. . .

| bytes_in<br>byte_1                             | db<br>db<br>db | (?)<br>(?)<br>10 dup (?)                 | user read buffer;                                               |
|------------------------------------------------|----------------|------------------------------------------|-----------------------------------------------------------------|
| view_buf<br>view_addr                          | db<br>db       | 5 dup (" ")<br>3 dup (?)<br>10 dup (" ") |                                                                 |
| view_data<br>msg_buf                           | db<br>db<br>db | 2 dup (?)<br>cr,lf,"\$"<br>10 dup (?)    | ;string control buffer                                          |
| porta_sto<br>portb_sto<br>ddra_sto<br>ddrb_sto | db<br>db       | (?)<br>(?)<br>(?)<br>(?)                 | ;parallel port holding<br>;buffers                              |
| chk_sum<br>xmt<br>addr_hold                    | db<br>db<br>dw | ?<br>?<br>?                              | ;chksum buffer<br>;retransmit count buffer<br>;temporary buffer |
| break_1                                        | dw             | ?                                        | ;register 1 part A                                              |
| break_2                                        | dw             | ?                                        | ;register 1 part B<br>;register 2 part A<br>;register 2 part B  |
| break_3                                        | dw             | ?                                        | ;register 3 part A                                              |
| break_4                                        | dw             | ?                                        | ;register 3 part B<br>;register 4 part A                        |
| break_5                                        | dw             | ?                                        | ;register 4 part B<br>;register 5 part A<br>;register 5 part B  |
| ; message                                      | definit        | ion area                                 |                                                                 |
| ;******                                        | ******         | *****                                    | ******                                                          |
| disk_err                                       | db<br>db       | "Disk read error<br>"must be on the      | r: Emulator.bin "<br>default drive",cr,lf,"\$"                  |
| port_err                                       | db             | "Port circuit d:                         | id not respond",cr,lf,"\$"                                      |
| chg_ddr                                        | đb             | cr,lf,"Change DI                         | DR (y/n): ","\$"                                                |
| step_erro                                      | r db           | "Step circuit d:                         | id not respond",cr,lf,"\$"                                      |
| bad_step                                       | db             | "Stepper must be                         | e enabled",cr,lf,"\$"                                           |
| stepped                                        | db             | "Step Action Cor                         | mplete",cr,lf,"\$"                                              |
| ddr_out                                        | db             | "DDR downloaded                          | ",cr,lf,"\$"                                                    |
| <pre>port_cont port_view</pre>                 |                | <pre>cr,lf,lf,"Select (?)</pre>          | ted port content is: "                                          |

db cr, lf, "\$" port data db cr, lf, "Please enter the port data :", "\$" port hold db brk head db cr, lf, lf, "Current break address listing" db cr,lf,cr,lf db "Break Number",10 dup (" ") db "Break Address", cr, lf, cr, lf, "\$" view brk label byte ; break display format 5 dup (" "),"1",20 dup (" ") db brk addr1 db 3 dup (?),cr,1f 5 dup (" "),"2",20 dup (" ") db brk addr2 db 3 dup (?), cr, 1f 5 dup (" "),"3",20 dup (" ") db brk addr3 db 3 dup (?),cr,lf 5 dup (" "),"4",20 dup (" ") db brk addr4 db 3 dup (?),cr,lf db 5 dup (" "),"5",20 dup (" ") brk addr5 db 3 dup (?),cr,lf,"\$" edit data db location db "Enter data for location " 3 dup (?) db view head db "User memory buffer contents", cr, lf, cr, lf db Address Data", cr, lf, "\$" view nr db cr, lf, "Please enter the last address to view" db cr, lf, "Note: Maximum length is 20 bytes!!" db cr, lf, ": ", "\$" edit nr db cr, lf, "Please enter the last address to edit" db cr, lf, "Note: Maximum length is 10 bytes!!" db cr, lf," : ","\$" dw err db "ERROR :: During memory download !!!" db cr,lf,"\$" dw brk err db "ERROR :: During break download !!!" db cr, lf, "\$" start addr db cr, lf, "Please enter the starting " db "address as (XXXh): ","\$" stop addr db cr, lf, "Please enter the ending " db "address as (XXXh): ","\$" file db cr, lf, lf, 10 dup (" ") db "Please enter the name of your file," db cr,1f,10 dup (" ") db "this must be a binary file: ","\$"

Baus Baus ha - Sea - Charita and - Charles and - Charles

| data_out              | db                                     | "User Memory has been downloaded",13,10,"\$"                                                                                                                                                                                                                                                                                                                                                 |
|-----------------------|----------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bad_sel               | db<br>db                               | cr,lf,10 dup (" ")<br>"Invalid Selection : Enter <return>","\$"</return>                                                                                                                                                                                                                                                                                                                     |
| enter_3               | db<br>db                               | <pre>cr,lf,"Enter 3 hexidecimal digits only!" cr,lf,"\$"</pre>                                                                                                                                                                                                                                                                                                                               |
| enter_2               | db<br>db                               | <pre>cr,lf,"Enter 2 hexidecimal digits only!" cr,lf,"\$"</pre>                                                                                                                                                                                                                                                                                                                               |
| standby               | db<br>db                               | " STANDBY EMULATOR INITIALIZING !!!"<br>cr,lf,"\$"                                                                                                                                                                                                                                                                                                                                           |
| sram_err              | db<br>db                               | "EMULATOR RAM ERROR: RESET EMULATOR", cr, lf<br>"\$"                                                                                                                                                                                                                                                                                                                                         |
| setup_men             | u db<br>db<br>db<br>db<br>db           | <pre>10 dup (" "),"SETUP MENU",cr,lf,cr,lf<br/>10 dup (" "),"a. Pass User Memory",cr,lf<br/>10 dup (" "),"b. Set Break Address",cr,lf<br/>10 dup (" "),"c. Configure Ports",cr,lf<br/>10 dup (" "),"d. Main Menu",cr,lf,"\$"</pre>                                                                                                                                                           |
| main_menu             | db<br>db<br>db<br>db<br>db<br>db<br>db | <pre>10 dup (" "),"MAIN MENU",cr,lf,cr,lf<br/>10 dup (" "),"a. Start/Stop Target",cr,lf<br/>10 dup (" "),"b. Enable/Disable Break",cr,lf<br/>10 dup (" "),"c. Change Break Address",cr,lf<br/>10 dup (" "),"d. Access Single-step",cr,lf<br/>10 dup (" "),"e. Access User Memory",cr,lf<br/>10 dup (" "),"f. Access Parallel Ports",cr,lf<br/>10 dup (" "),"g. Exit to Dos",cr,lf,"\$"</pre> |
| user_menu             | db<br>db<br>db<br>db<br>db             | <pre>10 dup (" "), "User Memory Menu",cr,lf,cr,lf<br/>10 dup (" "),"a. Download User Memory",cr,lf<br/>10 dup (" "),"b. View User Memory",cr,lf<br/>10 dup (" "),"c. Edit User Memory",cr,lf<br/>10 dup (" "),"d. Exit ",cr,lf,lf,"\$"</pre>                                                                                                                                                 |
| select                | db                                     | cr,lf,10 dup (" "),"Make a selection: ","\$"                                                                                                                                                                                                                                                                                                                                                 |
| break_men             | u db<br>db<br>db<br>db<br>db<br>db     | <pre>10 dup (" "),"BREAK MENU",cr,lf,cr,lf<br/>10 dup (" "),"a. Enable Break",cr,lf<br/>10 dup (" "),"b. Disable Break",cr,lf<br/>10 dup (" "),"c. View Break Address",cr,lf<br/>10 dup (" "),"d. Change Break Address",cr,lf<br/>10 dup (" "),"e. Exit ",cr,lf,lf,"\$"</pre>                                                                                                                |
| sel_brk_r             | db                                     | cr,lf,lf,"Select break register (1-5): "<br>"\$"                                                                                                                                                                                                                                                                                                                                             |
| new_brk_a<br>more_brk | ddr db<br>db                           | "Enter new break address: ","\$"<br>"Change another address (Y/N): ","\$"                                                                                                                                                                                                                                                                                                                    |
| brk_now               | db                                     | "Break address "                                                                                                                                                                                                                                                                                                                                                                             |

in.

| brk_sel                                                                    | db                                                 | ? " = "                                                                                                                                                                                                                                                                                                                                                                         |  |
|----------------------------------------------------------------------------|----------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| brk_sel_da                                                                 | db<br>ata db                                       | 3 dup (?),cr,lf,"\$"                                                                                                                                                                                                                                                                                                                                                            |  |
| port_menu                                                                  | db<br>db<br>db<br>db<br>db<br>db<br>db<br>db<br>db | <pre>10 dup (" "),"PORT MENU",cr,lf,cr,lf<br/>10 dup (" "),"a. Read port A",cr,lf<br/>10 dup (" "),"b. Read port B",cr,lf<br/>10 dup (" "),"c. Write port A",cr,lf<br/>10 dup (" "),"d. Write port B",cr,lf<br/>10 dup (" "),"e. View/Reconfigure DDR-A"<br/>cr,lf<br/>10 dup (" "),"f. View/Recongigure DDR-B"<br/>cr,lf<br/>10 dup (" "),"g. Exit port menu",cr,lf,"\$"</pre> |  |
| step_menu                                                                  | db<br>db<br>db<br>db<br>db<br>db                   | <pre>10 dup (" "),"SINGLE-STEP MENU",cr,lf,cr,lf<br/>10 dup (" "),"a. Start single-step mode"<br/>cr,lf<br/>10 dup (" "),"b. Step target",cr,lf<br/>10 dup (" "),"c. Exit single-step mode",cr,lf<br/>10 dup (" "),"d. Main menu",cr,lf,lf,"\$"</pre>                                                                                                                           |  |
| Brk_stat_<br>Brk_stat_<br>step_stat<br>step_stat<br>emul_stat<br>emul_stat | on<br>_off<br>_on<br>_on                           | <pre>db "Break = Disable",cr,lf,"\$" db "Break = Enable",cr,lf,"\$" db "Stepper = off",cr,lf,lf,lf,"\$" db "Stepper = Freerun",cr,lf,lf,lf,"\$" db "Mode = System",cr,lf,"\$" db "Mode = Target",cr,lf,"\$"</pre>                                                                                                                                                               |  |
| continue<br>waiting<br>port_done                                           | db                                                 | 10,13,"Press Enter to continue: ","\$"<br>10,13,"Standing by for Emulator data","\$"<br>"Port data downloaded",cr,lf,"\$"                                                                                                                                                                                                                                                       |  |
| dseg                                                                       | ends                                               |                                                                                                                                                                                                                                                                                                                                                                                 |  |
| *******                                                                    | ******                                             | *********                                                                                                                                                                                                                                                                                                                                                                       |  |
| sseg                                                                       | segment                                            | stack                                                                                                                                                                                                                                                                                                                                                                           |  |
|                                                                            | db                                                 | 100 dup (?)                                                                                                                                                                                                                                                                                                                                                                     |  |
| sseg                                                                       | ends                                               |                                                                                                                                                                                                                                                                                                                                                                                 |  |
| • * * * * * * * *                                                          | ******                                             | *****                                                                                                                                                                                                                                                                                                                                                                           |  |
| ,<br>cseg                                                                  | segment                                            |                                                                                                                                                                                                                                                                                                                                                                                 |  |
|                                                                            | assume                                             | cs:cseg,ds:dseg,ss:sseg,es:cseg                                                                                                                                                                                                                                                                                                                                                 |  |
| ;*******                                                                   | ******                                             | ***********                                                                                                                                                                                                                                                                                                                                                                     |  |
| ; Macro COMPARE - This macro compares the contents of two                  |                                                    |                                                                                                                                                                                                                                                                                                                                                                                 |  |

```
; strings. The soucre and destination offset must be provide
; and the CX register must contain the string length. For a
; match the AX register will return zero. Any other value
; means no match.
                          *****
compare
          macro
                  string1, string2
          lea
                  si,string1
                                  ; point to input string
          lea
                  di,string2
                                  ;point to test string
          call
                  cmp strg
          endm
; Macro BUF SIZE - This macro setups function call 08h by
; setting the maximum length and passing the buffer name.
                                 *****************
buf size macro length, identity ; variable lentgh buffer
          push
                  ax
          push
                  dx
          lea
                  dx, identity
          mov
                  identity, length ; the max length
          mov
                  ah,0ah
                                   ; is 255 characters
          int
                  21h
                  dx
          pop
                  ax
          pop
          endm
                           *******
  Subroutine CMP STRG - This procedure compares two strings.
cmp strg
         proc
                  near
          push
                  сх
                  cx,04
          mov
chk_it:
          mov
                  ah,[si]
                  al,[di]
          mov
          cmp
                  ah,al
                  no match
          jne
                  si
          inc
                  di
          inc
```

and the second second

loop chk it no match: mov ax, cx ;compare strings ;set al to the value of ;cx. If cx equal zero ;strings match pop сх ;restore original string ;length ret cmp strg endp ; ; Subroutine CLR - This procedure clears the crt display. clr proc push dx push ax dx, offset cls mov ah,09h mov int 21h pop ax dx pop ret clr endp \*\*\*\*\* ; ; Subroutine DISPLAY - This procedure displays the message ; string pointed to by the dummy variable "string". \*\*\*\*\*\*\* display macro string push dx dx, offset string mov mov ah,09h 21h int dx pop endm \*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\* ; Subrountine READ-KEY - This procedure reads the Z-100 ; keyboard and echoes it to the crt. \*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*

Catholica and a construction

È

ļ

Į

. n.

read key proc

and a state of the

|          | mov  | ah,01h |
|----------|------|--------|
|          | int  | 21h    |
|          | ret  |        |
| read_key | endp |        |

 \_

1

1

ł

1

\_\_\_\_

1

rcv B proc

|       | mov  | ah,03h | ;preform serial read |
|-------|------|--------|----------------------|
|       | int  | 21h    | ;data returned in al |
|       | ret  |        |                      |
| rcv_B | endp |        |                      |

send b proc

send b

| push                      | cx              |
|---------------------------|-----------------|
| push                      | ax              |
| mov<br>mov                | dl,al<br>ah,04h |
| int                       | 21h             |
| mov                       | al,dl           |
| pop<br>pop<br>ret<br>endp | ax<br>cx        |

;transmit serial byte
;data must be in the dl

;register

disp stat proc near push аx mov al, on ; load the on flag ; check mode of emulator cmp al,mode\_flg jne skip z1 display emul stat on skip\_z21 jmp skip\_z1: display emul stat off skip z21: mov al, on cmp al, break flg jne skip z2 display brk stat on jmp skip\_z22 skip\_z2: display brk stat off skip\_z22: mov al, on  $\mathtt{cmp}$ al, step\_flg skip\_z3 jne display step\_stat\_on jmp skip z31 skip\_z3: display step stat off skip\_z31: pop ax ret disp stat endp \*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\* ; Macro CONVERT - This macro sets up the parameters ; to the hex to ascii procedure which converts an hex value ; to ascii. convert macro bits, destination, data info mov bx,data info ;load the data pointer mov di, offset destination ;load the destination •pointer cx, bits mov call hex to ascii ;call the converter endm \*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\* Subroutine GET FLG - This procedure reads in a string ;

and and the set is a

Sec. P. L.

get flg proc near push bx mov bx, offset msg buf get next 1: rcv b call ;read emulator port [bx],al mov al,eot ; if not end of string cmp ;store the data je done1 ; and get the next byte dl,al ;look at data mov ah,02h mov int 21h inc bx get next 1 jmp done1: bx pop ret get flg endp \*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\* This macro transmits the designated flag to the emuulator. \*\*\*\*\*\*\*\*\*\*\* send macro flag\_name lea di,flag name send\_flag call endm ; Subroutine SEND\_FLAG - This procedure sends a string of ; characters from thethe 2-100 to the serial port the string ; offset must be in the DI register when the call is made.

| send flag                                                | proc                                  | near                                                     |                                                                                                                  |
|----------------------------------------------------------|---------------------------------------|----------------------------------------------------------|------------------------------------------------------------------------------------------------------------------|
| send_11ay                                                | proc                                  | near                                                     |                                                                                                                  |
|                                                          | push                                  | ax                                                       |                                                                                                                  |
| continuel                                                | call<br>cmp<br>je<br>inc<br>jmp       | al,[di]<br>send_b<br>dl,eot<br>return<br>di<br>continue1 | ;load a byte of data<br>;transmit the data<br>;check for end of string<br>;point to next byte<br>;repeat process |
| return:                                                  | рор                                   | ax                                                       |                                                                                                                  |
| send_flag                                                | ret<br>endp                           |                                                          |                                                                                                                  |
| ; * * * * * * * *                                        | *****                                 | *****                                                    | *****                                                                                                            |
| ;<br>; MODULE<br>; MODULE<br>; FUNCTIO<br>;<br>; INPUTS: | NUMBER:<br>N:                         |                                                          | transfer a designated<br>to a temporary storage area.                                                            |
| ; OUTPUTS<br>; MODULES<br>;                              | CALLED:                               |                                                          | ****                                                                                                             |
| •                                                        |                                       |                                                          |                                                                                                                  |
| load_buf                                                 | proc                                  | near                                                     |                                                                                                                  |
|                                                          | push<br>push                          | ax<br>cx                                                 |                                                                                                                  |
|                                                          | lea<br>mov<br>int                     | dx,user_file<br>ax,3d00h<br>21h                          | ;point to user file<br>;open the file for reading<br>;pointer at beginning                                       |
|                                                          | jc<br>mov<br>lea<br>mov<br>mov<br>int | <pre>load_error bx,ax dx,user cx,2048 ah,3fh 21h</pre>   | ;store file handle in BX<br>;destination buffer<br>;load number of bytes                                         |
| load_erro<br>no_ld_err                                   | jmp                                   | ah,3eh<br>21h<br>no_ld_err<br>no_way<br>cx               | ;close the file                                                                                                  |
|                                                          | pop<br>ret                            | ax                                                       |                                                                                                                  |

, • •

A. . . . . . .

load\_buf endp

enderstation and the second states

send\_buf proc near

| <pre>send user_stg ;call send1: call get_flg ;get r compare msg_buf,rdy_stg cmp ax,0</pre> | to start of data<br>emulator<br>esponse |
|--------------------------------------------------------------------------------------------|-----------------------------------------|
| jne send1<br>send down ld ;send                                                            | download flag                           |
|                                                                                            | to start address                        |
|                                                                                            | first byte of                           |
|                                                                                            | -                                       |
|                                                                                            | tart address                            |
| mov al,bl ;send<br>call send b                                                             | second byte                             |
| <u> </u>                                                                                   | byte count                              |
| mov al,bh                                                                                  | byte count                              |
| call send b                                                                                |                                         |
| mov al, tl                                                                                 |                                         |
| call send b                                                                                |                                         |
| send2: call get flg                                                                        |                                         |
| compare msg_buf,rdy_stg ;get r                                                             | eady signal                             |
| compare msg_bur, ruy_sty, get r<br>cmp ax,0                                                | eauy signal                             |
| jne send2                                                                                  |                                         |
| -                                                                                          | checksum                                |
|                                                                                            | to code                                 |
| mov bx,0 ;set c                                                                            |                                         |
| send next:                                                                                 | ouncer                                  |
| mov al,[si] ;load                                                                          | data                                    |
| call send b ;send                                                                          |                                         |
|                                                                                            | e checksum                              |
| inc bx                                                                                     | e oncorbum                              |
| cmp bx,byte num                                                                            |                                         |
| je x send buf                                                                              |                                         |
|                                                                                            | to the next byte                        |
| jmp send next                                                                              | te the heat ofte                        |

x send buf: mov al, chk sum call send b ;send checksum ret send buf endp ; ; MODULE NAME: INPUT DATA ; MODULE NUMBER: ; FUNCTION: This procedure gets an ascii data byte from the Z-100 keyboard, converts it to ; hex and stores it in the location pointed ; to by SI. 2 ; INPUTS: ; OUTPUTS: ; MODULES CALLED: input data proc near di push push bx сх push push dx again2: buf size 3, temp buf ;accept 2 characters + cr mov al, bytes in cmp al,2 ie passed 11 display enter 2 ;display an error message jmp again1 passed 11: dx,dx xor mov c1,4 lea di,byte 1 bx,xlat\_ascii\_char\_2\_hex\_value lea mov al, [di] ;get the first byte xlat ;exchange a hex character ;with its binary value al,0ffh cmp jne passed 12 display enter  $\overline{2}$ ;enter 2 hex characters jmp  $again\overline{2}$ passed 12: dl,al or shl dx,cl ;shift the byte by one ;nibble mov al,[di+1] ;get second byte xlat

and a series for and and

Ę

Ľ

ľ

cmp al,0ffh jne passed\_13 display enter  $\overline{2}$ jmp  $again\overline{2}$ passed 13: dl,al ;shift the byte by one or ;nibble [si],d1 mov ;store the hex data dx pop сх pop bx pop di pop ret input data endp \*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\* ; MODULE NAME: HEX TO ASCII ; MODULE NUMBER: : FUNCTION: This procedure converts the data in the BX, register from hexidecimal to ascii and stores it in the location pointed to by the DI register. ; ; INPUTS: ; OUTPUTS: ; MODULES CALLED: hex\_to\_ascii proc near push сх push bx push ax ax,bx ;load the data in ax mov bx,ascii\_table lea push ax ;save the data cmp cx,2 ;test for size of the data je byte only mov al,ah and al,0fh ;convert low nibble of ;high byte xlat mov [di],al ;save fisrt character di inc byte only: pop ax ;retrieve second byte mov ah,al ;hold low byte

E

Þ

Į

|                                                                          | and          | al,OfOh                                   | ;select high nibble                                           |  |
|--------------------------------------------------------------------------|--------------|-------------------------------------------|---------------------------------------------------------------|--|
|                                                                          | xlat         |                                           |                                                               |  |
|                                                                          | mov<br>inc   | [di],al<br>di                             | ;save the character                                           |  |
|                                                                          | mov          | al,ah                                     | ;store low byte                                               |  |
|                                                                          | and          | al,0fh                                    | ;select low nibble                                            |  |
|                                                                          | xlat         |                                           |                                                               |  |
|                                                                          | mov          | [di],al                                   | ;save the character                                           |  |
|                                                                          | рор          | ax                                        |                                                               |  |
|                                                                          | pop          | bx                                        |                                                               |  |
|                                                                          | рор          | сх                                        |                                                               |  |
|                                                                          | ret          |                                           |                                                               |  |
| hex to as                                                                | cii endp     |                                           |                                                               |  |
|                                                                          | •            |                                           |                                                               |  |
|                                                                          |              |                                           |                                                               |  |
| ;******                                                                  | ******       | *****                                     | ******                                                        |  |
| ; MODULE NAME:<br>; MODULE NUMBER:<br>; FUNCTION:<br>;<br>;<br>; INPUTS: |              | GET_ADDR                                  |                                                               |  |
|                                                                          |              | This procedur                             | e retrieves a three byte hex<br>the key board and converts it |  |
|                                                                          |              | to its binary equivalent. The results are |                                                               |  |
|                                                                          |              | returned in the addr_hold buffer.         |                                                               |  |
|                                                                          |              |                                           |                                                               |  |
| ; OUTPUTS                                                                |              |                                           |                                                               |  |
| ; MODULES                                                                | CALLED:      |                                           |                                                               |  |
| ;<br>;******                                                             | ******       | ******                                    | *****                                                         |  |
| get addr                                                                 | proc         | near                                      |                                                               |  |
| -                                                                        |              | at                                        |                                                               |  |
|                                                                          | push<br>push | di<br>bx                                  |                                                               |  |
|                                                                          | push         | CX                                        |                                                               |  |
|                                                                          | push         | dx                                        |                                                               |  |
| again1:                                                                  | buf siz      | e 4,temp buf                              | ;accept 3 characters + cr                                     |  |
|                                                                          | mov          | al, bytes in                              | , 2000 Fr & 0000 2000 200                                     |  |
|                                                                          | cmp          | al,3                                      |                                                               |  |
|                                                                          | je           | passed_1                                  |                                                               |  |
|                                                                          | display      |                                           | display an error message;                                     |  |
| passed 1:                                                                | jmp          | againl —                                  |                                                               |  |
|                                                                          | xor          | dx,dx                                     |                                                               |  |
|                                                                          | mov          | c1,4                                      |                                                               |  |
|                                                                          | lea          | di,byte_1                                 |                                                               |  |
|                                                                          | lea          |                                           | _char_2_hex_value                                             |  |
|                                                                          | mov          | al,[di]                                   | ;get the first byte                                           |  |
|                                                                          | xlat         |                                           | ;exchange a hex character                                     |  |
|                                                                          |              |                                           |                                                               |  |

والعارية المحمدة المعالية والمحمد المراد المحمد فالمحمد فالمحمد

;with its binary value al,0ffh cmp jne passed 2 display enter  $\overline{3}$ ;enter 3 hex characters again1 jmp passed 2: dl,al or shl dx,cl ;shift the byte by one ;nibble al,[di+1] mov ; get second byte xlat al,0ffh cmp passed 3 jne display enter  $\overline{3}$ jmp again1 passed 3: or dl,al shl dx,cl ;shift the byte by one ;nibble mov al,[di+2] ;get third byte xlat al,0ffh cmp passed 4 jne display enter  $\overline{3}$ passed 4: or dl,al addr hold,dx ;save the converted mov ;address dx pop сх pop pop bx di рор ret get addr endp ; USER\_PRO MODULE NAME: ; ; MODULE NUMBER: FUNCTION: This procedure handles the user requests from the Z-100 keyboard. And carries out the required functions with the emulator. ; INPUTS: ; OUTPUTS: MODULES CALLED: user pro proc near user rep: call clr display user\_menu ;prompt the user for

والمراجع والمتحد المراكب والمحاصرة والمتعادية والمتعاد المعاد

Ľ.

|                | display     | select                    | ;a selection               |
|----------------|-------------|---------------------------|----------------------------|
|                | call        | read key                  | ;get the option number     |
|                | cmp         | al,'a'                    |                            |
|                | je          | over_t                    |                            |
|                | jmp         | opt user b                |                            |
|                | call        | clr –                     |                            |
| over_t:        | display     |                           | ;request filename          |
|                | buf_siz     | e 15,user_code            |                            |
|                | mov         |                           | File ;may include drive id |
|                | add         | bl,char_ct                |                            |
|                | mov         | al,0                      |                            |
|                |             | [bx],al                   | ;add zero for dos call     |
|                | call        | load_buf                  | ;move file from disk to    |
|                |             |                           | ;the buffer area           |
|                | mov         | bx, offset user           |                            |
|                | add         | bx,2049                   |                            |
|                | mov         | al,eot                    |                            |
|                | mov         | [bx],al                   | ;flag end of user file     |
|                | mov         | xmt,0                     | ;clear counter             |
|                | mov         | u_start,0                 |                            |
| used           | mov<br>call | byte_num,2048<br>send_buf | ;download the file         |
| used:          | call        | get flg                   | ;see if transfer was       |
|                | Call        | get_rig                   | ;successful                |
|                | compare     | msg buf,ack stg           | , successiui               |
|                | cmp         |                           |                            |
|                | jne         | retry                     |                            |
|                | -           | data out                  | ;advise user of the        |
|                | arefial     |                           | ;download success          |
|                | display     | continue                  | ,                          |
| not yet:       | call        | read key                  |                            |
| _ <del>-</del> | cmp         |                           |                            |
|                | jne         | not_yet                   |                            |
|                | jmp         | exit_user_pro             |                            |
| retry:         | add         | xmt,1                     | ; increment counter        |
|                | cmp         | xmt,3                     |                            |
|                | jne         | skip_a                    |                            |
|                | jmp         | err_user_pro              |                            |
| skip_a:        | jmp         | used                      |                            |
| opt_user_      |             |                           |                            |
|                | cmp         | al,'b'                    |                            |
|                | je          | skip b<br>opt User C      |                            |
| skip b:        | jmp<br>call | opt_User_c<br>clr         |                            |
| •              |             | start_addr                | ;prompt for view address   |
|                | call        | get addr                  | ;get the address           |
|                | mov         | áx,āddr_hold              | -                          |
|                | mov         | u_start,ax                | ;save the address          |
|                | mov         | si, offset user           |                            |
|                | add         | si,ax                     |                            |
|                | call        | clr                       | and last sidness to side   |
|                |             | view_nr                   | ;get last address to view  |
|                | call        | get_addr                  |                            |

2.25%

E

Þ

Ľ

- ----

mov ax, addr hold mov u stop,ax ; save the converted ;stop address ax, u start mov mov bx,u stop sub bx,ax ;calculate byte count mov byte num, bx ;store byte count  $cx, b\overline{x}$ mov ;load byte counter cmp cx,20 ;see if bytes > 20 jle skip\_c no no ; if so display error msg jmp skip c: call clr display view head see it: push СХ convert 3, view addr, u start ; convert address to ;display format convert 2, view data, [si] ;get desired byte ; convert to display format display view buf ;display the location ;address and contents inc si ; increment data pointer add u start,1 ; increment address pointer pop CX loop see it display continue ;wait for continue say\_1: call read key cmp al,cr jne say 1 jmp exit user pro opt user\_c: al,'c' cmp jne opt user d call clr ;prompt for edit address display start addr call get addr ;get the address mov ax, addr hold mov u start,ax ;save the address mov u start1,ax mov si, offset user add si,ax call clr display edit nr ;get last address to edit call get addr mov ax, addr hold mov u\_stop,ax ;save the converted ;stop address mov ax, u start mov bx,u stop sub ;calculate byte count bx,ax

المدد بالأخوف بالإنبادي

A Sheet and a start of the start of the start of the

|                                         | mov<br>mov<br>cmp<br>jg<br>call      | byte_num,bx<br>cx,bx<br>cx,10<br>no_no<br>clr            | ;store byte count<br>;load byte counter<br>;see if bytes > 10<br>;if so display error msg |  |
|-----------------------------------------|--------------------------------------|----------------------------------------------------------|-------------------------------------------------------------------------------------------|--|
| edit_in:                                | push<br>convert<br>call              | сх                                                       | art ;setup address display<br>;prompt for the data<br>;read the data and store            |  |
|                                         | inc<br>pop<br>add<br>loop<br>mov     | si<br>cx<br>u_start,1<br>edit_in<br>xmt,0                | <pre>;convert data from ascii ;to hexidecimal format ;send user file</pre>                |  |
|                                         | mov<br>mov<br>jmp                    | ax,u_start1<br>u_start,ax<br>used                        | ;reset start address<br>;download new data                                                |  |
| opt_user_d:                             | cmp<br>je                            | al,'d'<br>exit_user_pro                                  |                                                                                           |  |
| no_no:                                  | display<br>call<br>cmp<br>jne<br>jmp | bad_sel<br>read_key<br>al,cr<br>no_no<br>user_rep        | display invalid input;                                                                    |  |
| err_user_p<br>no_way:                   | call<br>display                      | clr<br>dw_err<br>continue<br>read_key<br>al,cr<br>no_way |                                                                                           |  |
| exit_user_<br>user_pro                  |                                      | ret                                                      |                                                                                           |  |
| ; * * * * * * * * * * * * * * * * * * * |                                      |                                                          |                                                                                           |  |
| ; MODULE 1<br>; MODULE 1<br>; FUNCTION  | NUMBER:                              | between the user                                         | serves as the interface<br>r and break options. The<br>disable, view or change            |  |
| ;<br>; INPUTS:<br>; OUTPUTS:            | :                                    | the break detect                                         | , disable, view or change<br>tors.                                                        |  |

•

; MODULES CALLED: break pro proc near di push dx push push сх brk top: clr call call disp stat display break menu display select call read key ;get the option number al,'ā' cmp jne opt brk b ;see if already enabled break flg,on cmp skip d jne no go jmp skip d: send break stg ;send string to emulator call get flg compare msg buf, rdy stg cmp ax,0 je skip e jmp brk\_error skip e: moval, on ;send on flag call send b break\_flg,al mov ;update the break flag get flg call compare msg buf, ack stg ; check for acknowledge ax, 0 cmp skip f je brk error jmp skip f: brk top jmp opt\_brk\_b: al, 'b' cmp je skip g jmp opt brk c break flg,off ;see if already off skip g: cmp jne skip\_h jmp no go skip h: ;send string to emulator send break stg call get flg compare msg buf, rdy stg cmp ax,0 je skip i jmp brk error skip\_i: mov al, off ;send on flag call send b mov break\_flg,al ;update the break flag get flg call compare msg buf, ack stg ; check for acknowledge

atte des ans de la contrat

cmp ax,0 skip\_j je jmp brk\_error skip j: brk top jmp opt\_brk c: al,'c' cmp opt\_brk\_d jne call clr display brk head ;display break header convert 3,brk\_addr1,break\_1 ;load the break convert 3,brk\_addr2,break\_2 ;display with convert 3,brk\_addr3,break\_3 ;current data convert 3, brk\_addr4, break\_4 convert 3, brk addr5, break 5 display view brk display continue no way b: call read key cmp al,cr jne no way b  $brk_top$ jmp opt\_brk\_d: al,'d' cmp je back 1 opt\_brk\_e jmp back 1: call clr display sel brk reg ;get break register call read key mov brk sel,al ;store ascii register # al, **T**1' ;determine break address cmp chk 2 jne ;to display convert 3,brk\_sel\_data,break\_1 di, offset break\_1 mov jmp put out al, 72' chk 2: cmp chk 3 jne convert 3, brk sel data, break 2 di, offset break 2 mov jmp put\_out al, 73' chk 3: cmp jne chk 4 convert 3, brk sel data, break 3 mov di, offset break\_3 put out jmp chk 4: al, 74' cmp chk 5 jne convert 3, brk sel data, break 4 mov di, offset break 4 ;set storage addr put\_out
a1,'5' jmp chk 5: cmp skip\_k je no go jmp skip k: convert 3, brk\_sel\_data, break\_5

| put_out:                 | mov<br>display                                   | di,offset break_<br>brk_now                                                         | _5<br>;display current break<br>;address                    |
|--------------------------|--------------------------------------------------|-------------------------------------------------------------------------------------|-------------------------------------------------------------|
|                          | display<br>call<br>mov                           | ax,addr_hold                                                                        | ;prompt for new address<br>;get the address                 |
|                          | mov<br>mov                                       | [di],ax<br>xmt,0                                                                    | store the new data;<br>clear retransmit counter;            |
| skip_l:                  | display<br>call<br>cmp<br>je<br>cmp<br>je        | more_brk<br>read_key<br>al,'y'<br>skip_m<br>al,'Y'<br>skip_m                        |                                                             |
| skip_m:                  | jmp<br>jmp                                       | breaking<br>back_1                                                                  | ;change another break addr                                  |
| breaking:                | call                                             | <pre>break_flg get_flg msg_buf,rdy_stg ax,0 brk_error al,down</pre>                 | ;pass break address                                         |
| retry_brk:               |                                                  | <pre>send_b get_flg msg_buf,rdy_stg ax,0 retry_brk cx,10 chk_sum,0 di_brook_1</pre> |                                                             |
| brk_out:                 | mov<br>call<br>inc<br>add<br>loop<br>mov<br>call | <pre>di, break_1 al, [di] send_b di chk_sum,al brk_out al, chk_sum send_b</pre>     | ;point to top of break<br>;string<br>;send the break buffer |
| <b>b</b>                 | cmp<br>jne                                       | <pre>get_flg msg_buf,ack_stg ax,0 brk_retry</pre>                                   | ;check for acknowledge                                      |
| brk_retry:<br>opt_brk_e: | jmp<br>add<br>cmp<br>je<br>jmp                   | <pre>brk_top xmt,1 xmt,3 brk_error retry_brk al,'e'</pre>                           |                                                             |
|                          |                                                  | exit_brk_pro                                                                        |                                                             |

call clr no go: display bad sel ;display invalid input call read key cmp al, cr jne no go brk top jmp brk error: call clr display dw brk err ;display error message display continue no gol: call read key cmp al,cr jne no gol jmp brk top ;try again exit brk pro: ret break pro endp ; MODULE NAME: STEP PRO ; ; MODULE NUMBER: ; FUNCTION: This procedure signals the emulator to enables or disables the single-step function and updates the single-step ; status flag. It also steps the target upon demand. ; INPUTS: ; OUTPUTS: ; MODULES CALLED: step pro proc near step top: call clr call disp\_stat display step\_menu display select call read key ;get the option number al,'ā' cmp jne opt step b cmp ;see if already on step flg,on je step top step\_stg send call get flg wait\_step: compare msg buf, rdy stg ; wait for ready signal cmp ax,0 jne wait step

Service and the second of the second se

Ľ

L

al, on ;load on flag mov call send b get flq call compare msg buf, ack stg ; check for acknowledge cmp ax, Ū je skip\_ac jmp step\_err ;update the step flag skip\_ac: mov step flg,on jmp step\_top opt step b: al,'b' cmp opt\_step\_c jne mov bl,on ;see if set to on cmp step\_flg,bl je skip<sup>n</sup> jmp can not do ; contact emulator skip n: send step\_stg wait step3: call get flg compare msg buf, rdy stg ; wait for ready signal cmp ax,0 jne wait step3 al, step mov call send b ;send step flag get  $\overline{f}$ lg call compare msg buf, ack stg ; check for acknowledge cmp ax,0 je skip o step\_err jmp ;target was stepped skip o: display stepped display continue wait step5: call read key cmp al,cr jne wait\_step5 jmp step top opt\_step\_c: al,'c' cmp je skip p opt step d jmp skip\_p: step flg, on ;see if already on cmp je hump step top jmp hump: send step\_stg call get flg wait step1: compare msg buf, rdy stg  $ax,\overline{0}$ cmp jne wait step1 mov al, off ;load off flag call send b get flg call

ر با المحمد ا المحمد المحمد

compare msg buf, ack\_stg  $ax,\overline{0}$ cmp jne step err mov step flg,off ;update the step flag step\_top jmp can not do: ;stepper must be enabled display bad step display continue ;try again wait step2: call read key cmp al, cr jne wait step2 step\_top jmp step err: ;circuit has a problem display step\_error display continue ;try again wait step21: call read key cmp al, cr jne wait\_step21 jmp step top opt step d: ret step\_pro endp ; MODULE NAME: PORT PRO ; ; MODULE NUMBER: FUNCTION: This procedure prompts the user for an ; selection and then carries out the command. ; The user may read, write, or view the ; target's 8755 ports. ; ; INPUTS: ; OUTPUTS: MODULES CALLED: : port pro proc near port\_top: call clr call disp stat display port\_menu display select ;get the option number call read key cmp al, 'ā' jе rd a opt port b:

an and the last is the second at the second

b:

|                  | cmp      | al,'b'                   |                           |
|------------------|----------|--------------------------|---------------------------|
|                  | je       | skip_q                   |                           |
|                  | jmp      | opt port c               |                           |
| skip q:          | mov      | cl,'b'                   | ;flag port B              |
| ovib-d.          | jmp      | over rd a                | /ling pole b              |
| rd a:            | mov      | cl,'a'                   | ;flag port A              |
| over rd a        |          | CI, a                    | , ring port A             |
| over_ru_a        | mov      | xmt,0                    |                           |
|                  | send     | port stg                 | ;call emulator board      |
| p wait:          | call     | get flg                  | , call emulator board     |
| P_wait.          |          | msg_buf,rdy_stg          |                           |
|                  |          | ax,0                     |                           |
|                  | cmp      | -                        |                           |
|                  | jne      | p_wait                   | cond up flog              |
|                  | mov      | al,up                    | ;send up flag             |
|                  | call     | send b                   |                           |
|                  | cmp      | cl,'a'                   |                           |
|                  | je       | do_rd_a                  | and we ask D wood         |
|                  | mov      | al, portB                | ;set up port B read       |
|                  | jmp      | do_rd_b                  |                           |
| do_rd_a:         |          | al, portA                | ;send port identification |
| do_rd_b:         |          | send_b                   |                           |
| p_wait1:         |          | get_flg                  |                           |
|                  | -        |                          | ;wait for ready signal    |
|                  | cmp      | ax,0                     |                           |
|                  | jne      | p_wait1                  | · · · · ·                 |
|                  | call     | rcv_B                    | ;get the data             |
|                  | mov      | chk_sum,al               | ;save the data            |
|                  | call     | rcv_B                    |                           |
|                  | cmp      | al,eot                   |                           |
|                  | je       | skip_r                   |                           |
|                  | jmp      | <pre>exit_port_pro</pre> |                           |
| skip_r:          | call     | rcv_B _                  | ;get checksum             |
| _                | cmp      | al, chk_sum              |                           |
|                  | je       | skip_s                   |                           |
|                  | add      | $xmt,\overline{1}$       |                           |
|                  | cmp      | xmt,3                    |                           |
|                  | jne      | p wait1                  |                           |
|                  | jmp      | exit port pro            | ; if no match try again   |
| skip_s:          | send     | ack stg                  |                           |
|                  | mov      | ax,0                     |                           |
|                  | mov      | al, chk sum              |                           |
|                  | mov      | work, ax                 |                           |
|                  | convert  | 2, port view, work       | <                         |
|                  |          | port cont                | display the port data;    |
|                  |          | continue                 |                           |
| p_hold:          | call     | read key                 |                           |
| • _              | cmp      | al, cr                   |                           |
|                  | jne      | p hold                   |                           |
|                  | jmp      | port top                 |                           |
|                  | 3E       | • = ·· <u> </u>          |                           |
| opt_port_        | c:       |                          |                           |
| - + - <u>_</u> F | mov      | xmt,0                    |                           |
|                  | cmp      | al,'c'                   |                           |
|                  | <b>E</b> |                          |                           |

Contraction and a second second second second

-----

. . . . .

|             | je          | wr a                 |                           |
|-------------|-------------|----------------------|---------------------------|
| opt port d: |             |                      |                           |
|             | cmp         | al,'d'               |                           |
|             | je          | skip_t               |                           |
|             | jmp         | opt_port_e           |                           |
| skip_t:     | MOV         | cl, 'b' -            | ;flag port B              |
|             | jmp         | over_a               |                           |
| wr_a:       | mov         | cl,'ā'               | ;flag port A              |
| over_a:     | display     | port_data            | ;prompt for new data      |
|             | lea         | si,port_hold         | ;point to data buffer     |
|             | call        | input_data           | ;get the data             |
|             | send        | port_stg             | ;call emulator board      |
| p_wait4:    | call        | get_flg              |                           |
|             |             | msg_buf,rdy_stg      |                           |
|             | cmp         | ax,0                 |                           |
|             | jne         | p_wait4              | and Jam flag              |
|             | mov         | al,down              | ;send down flag           |
|             | call        | send_b               | along checkeup            |
| p wait5:    | mov<br>call | chk_sum,0<br>get_flg | ;clear checksum           |
| P_warts.    |             | · _ ·                | ;wait for ready signal    |
|             | compare     | ax,0                 | , wait for ready signar   |
|             | jne         | p wait5              |                           |
|             | cmp         | cl,'a'               |                           |
|             | je          | do a                 |                           |
|             | mov         | al,portB             | ;set up port B write      |
|             | mov         | dl,port hold         | ;store new data in the    |
|             | mov         | portb sto,dl         | ;port holding buffer B    |
|             | jmp         | do b                 |                           |
| do_a:       | mov         | al, portA            | ;send port identification |
| _           | mov         | dl,port_hold         | ;store new data in the    |
|             | nov         | porta_sto,dl         | ;port holding buffer A    |
| do_b:       | call        | send_b               |                           |
|             | mov         | chk_sum,al           |                           |
|             | mov         | al,port_hold         | ;send the data            |
|             | call        | send_b               |                           |
|             | add         | chk_sum,al           |                           |
|             | mov         | al,eot               | . sond oot                |
|             | call        | send_b<br>al,chk_sum | ;send eot                 |
|             | mov<br>call | send b               | ;send checksum            |
|             | call        | get flg              | Sena Checksum             |
|             |             | msg_buf,ack_stg      |                           |
|             | cmp         | ax,0                 | ;check for acknowledge    |
|             | je          | skip u               | , oneon for dominatedyc   |
|             | add         | xmt,1                |                           |
|             | cmp         | xmt,3                |                           |
|             | jne         | p wait5              |                           |
|             | jmp         | exit_port_pro        |                           |
| skip_u:     |             | port_done_           |                           |
| _           |             | continue             |                           |
| p_hold2:    | call        | read_key             |                           |
|             | cmp         | al,cr                |                           |
|             |             |                      |                           |

a Salar in S

and in the last with the street here the

Section of the

-

| <pre>opt_port_e:<br/>cmp al,'e'<br/>je skip_ad<br/>jmp opt_port_f<br/>skip_ad: mov xmt,0<br/>mov ax,0<br/>mov ax,0<br/>mov work,ax<br/>convert 2,port_view,work ;convert ddr data<br/>display port_cont ;display the port data<br/>display port_data ;do you want to change<br/>call read_key ;the ddr<br/>cmp al,'y'<br/>je skip_v<br/>jmp port_top ;display menu<br/>skip_v: display port_data ;prompt for new data<br/>lea si,ddra_sto ;point to data buffer<br/>call input_data ;get the data<br/>mov chk_sum,0<br/>send port_stg ;call emulator<br/>p_wait6: call get_flg<br/>compare msg_buf,rdy_stg<br/>call send_b<br/>p_wait7: call get_flg<br/>compare msg_buf,rdy_stg ;wait for ready signal</pre> |           | j <b>ne</b><br>jmp | p_hold2<br>port_top                   |                            |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|--------------------|---------------------------------------|----------------------------|
| <pre>cmp al,'e'<br/>je skip_ad<br/>jmp opt_port_f<br/>skip_ad: mov xmt,0<br/>mov ax,0<br/>mov al,ddra_sto<br/>mov work,ax<br/>convert 2,port_view,work ;convert ddr data<br/>display port_cont ;display the port data<br/>display chg_ddr ;do you want to change<br/>call read_key ;the ddr<br/>cmp al,'y'<br/>je skip_v<br/>jmp port_top ;display menu<br/>skip_v: display port_data ;prompt for new data<br/>lea si,ddra_sto ;point to data buffer<br/>call input_data ;get the data<br/>mov chk_sum,0<br/>send port_stg ;call emulator<br/>p_wait6: call get_flg<br/>compare msg_buf,rdy_stg<br/>cmp a1,dwn ;send down flag<br/>call send b<br/>p_wait7: call get_flg</pre>                                |           |                    |                                       |                            |
| <pre>je skip_ad<br/>jmp opt_port_f<br/>skip_ad: mov xmt,0<br/>mov ax,0<br/>mov al,ddra_sto<br/>mov work,ax<br/>convert 2,port_view,work ;convert ddr data<br/>display port_cont ;display the port data<br/>display chg_ddr ;do you want to change<br/>call read_key ;the ddr<br/>cmp al,'y'<br/>je skip_v<br/>jmp port_top ;display menu<br/>skip_v: display port_data ;prompt for new data<br/>lea si,ddra_sto ;point to data buffer<br/>call input_data ;get the data<br/>mov chk_sum,0<br/>send port_stg ;call emulator<br/>p_wait6: call get_flg<br/>compare msg_buf,rdy_stg<br/>cmp ax,0<br/>jne p_wait6<br/>mov al,down ;send down flag<br/>call send b<br/>p_wait7: call get_flg</pre>                 | opt_port_ |                    | -1 1-1                                |                            |
| <pre>jmp opt_port_f skip_ad: mov xmt,0 mov ax,0 mov al,ddra_sto mov work,ax convert 2,port_view,work ;convert ddr data display port_cont ;display the port data display chg_ddr ;do you want to change call read_key ;the ddr cmp al,'y' je skip_v jmp port_top ;display menu skip_v: display port_data ;prompt for new data lea si,ddra_sto ;point to data buffer call input_data ;get the data mov chk_sum,0 send port_stg ;call emulator p_wait6: call get_flg compare msg_buf,rdy_stg cmp ax,0 jne p_wait6 mov al,down ;send down flag call send_b p_wait7: call get_flg</pre>                                                                                                                            |           | . <b>.</b>         |                                       |                            |
| <pre>skip_ad: mov xmt,0<br/>mov ax,0<br/>mov al,ddra_sto<br/>mov work,ax<br/>convert 2,port_view,work ;convert ddr data<br/>display port_cont ;display the port data<br/>display chg_ddr ;do you want to change<br/>call read_key ;the ddr<br/>cmp al,'y'<br/>je skip_v<br/>jmp port_top ;display menu<br/>skip_v: display port_data ;prompt for new data<br/>lea si,ddra_sto ;point to data buffer<br/>call input_data ;get the data<br/>mov chk_sum,0<br/>send port_stg ;call emulator<br/>p_wait6: call get_flg<br/>compare msg_buf,rdy_stg<br/>cmp ax,0<br/>jne p_wait6<br/>mov al,down ;send down flag<br/>call send b<br/>p_wait7: call get_flg</pre>                                                   |           |                    |                                       |                            |
| <pre>mov ax,0<br/>mov al,ddra_sto<br/>mov work,ax<br/>convert 2,port_view,work ;convert ddr data<br/>display port_cont ;display the port data<br/>display chg_ddr ;do you want to change<br/>call read_key ;the ddr<br/>cmp al,'y'<br/>je skip_v<br/>jmp port_top ;display menu<br/>skip_v: display port_data ;prompt for new data<br/>lea si,ddra_sto ;point to data buffer<br/>call input_data ;get the data<br/>mov chk_sum,0<br/>send port_stg ;call emulator<br/>p_wait6: call get_flg<br/>compare msg_buf,rdy_stg<br/>cmp ax,0<br/>jne p_wait6<br/>mov al,down ;send down flag<br/>call send_b<br/>p_wait7: call get_flg</pre>                                                                          | skip ad:  |                    |                                       |                            |
| <pre>mov al,ddra_sto<br/>mov work,ax<br/>convert 2,port_view,work ;convert ddr data<br/>display port_cont ;display the port data<br/>display chg_ddr ;do you want to change<br/>call read key ;the ddr<br/>cmp al,'ỹ'<br/>je skip_v<br/>jmp port_top ;display menu<br/>skip_v: display port_data ;prompt for new data<br/>lea si,ddra_sto ;point to data buffer<br/>call input_data ;get the data<br/>mov chk_sum,0<br/>send port_stg ;call emulator<br/>p_wait6: call get_flg<br/>compare msg_buf,rdy_stg<br/>cmp ax,0<br/>jne p_wait6<br/>mov al,down ;send down flag<br/>call send b<br/>p_wait7: call get_flg</pre>                                                                                       | Unip_uu.  |                    |                                       |                            |
| <pre>mov work,ax<br/>convert 2,port_view,work ;convert ddr data<br/>display port_cont ;display the port data<br/>display chg_ddr ;do you want to change<br/>call read_key ;the ddr<br/>cmp al,'y'<br/>je skip_v<br/>jmp port_top ;display menu<br/>skip_v: display port_data ;prompt for new data<br/>lea si,ddra_sto ;point to data buffer<br/>call input_data ;get the data<br/>mov chk_sum,0<br/>send port_stg ;call emulator<br/>p_wait6: call get_flg<br/>compare msg_buf,rdy_stg<br/>cmp ax,0<br/>jne p_wait6<br/>mov al,down ;send down flag<br/>call send b<br/>p_wait7: call get_flg</pre>                                                                                                           |           |                    | -                                     |                            |
| <pre>convert 2,port_view,work ;convert ddr data<br/>display port_cont ;display the port data<br/>display chg_ddr ;do you want to change<br/>call read_key ;the ddr<br/>cmp al,'y'<br/>je skip_v<br/>jmp port_top ;display menu<br/>skip_v: display port_data ;prompt for new data<br/>lea si,ddra_sto ;point to data buffer<br/>call input_data ;get the data<br/>mov chk_sum,0<br/>send port_stg ;call emulator<br/>p_wait6: call get_flg<br/>compare msg_buf,rdy_stg<br/>cmp ax,0<br/>jne p_wait6<br/>mov al,down ;send down flag<br/>call send_b<br/>p_wait7: call get_flg</pre>                                                                                                                           |           |                    |                                       |                            |
| <pre>display port_cont ;display the port data<br/>display chg_ddr ;do you want to change<br/>call read key ;the ddr<br/>cmp al,'y'<br/>je skip_v<br/>jmp port_top ;display menu<br/>skip_v: display port_data ;prompt for new data<br/>lea si,ddra_sto ;point to data buffer<br/>call input_data ;get the data<br/>mov chk_sum,0<br/>send port_stg ;call emulator<br/>p_wait6: call get_flg<br/>compare msg_buf,rdy_stg<br/>cmp ax,0<br/>jne p_wait6<br/>mov aI,down ;send down flag<br/>call send_b<br/>p_wait7: call get_flg</pre>                                                                                                                                                                          |           |                    | •                                     | ;convert ddr data          |
| <pre>display chg_ddr ;do you want to change<br/>call read key ;the ddr<br/>cmp al,'y'<br/>je skip_v<br/>jmp port_top ;display menu<br/>skip_v: display port_data ;prompt for new data<br/>lea si,ddra_sto ;point to data buffer<br/>call input_data ;get the data<br/>mov chk_sum,0<br/>send port_stg ;call emulator<br/>p_wait6: call get_flg<br/>compare msg_buf,rdy_stg<br/>cmp ax,0<br/>jne p_wait6<br/>mov aI,down ;send down flag<br/>call send_b<br/>p_wait7: call get_flg</pre>                                                                                                                                                                                                                       |           |                    |                                       |                            |
| <pre>cmp al,'y'<br/>je skip_v<br/>jmp port_top ;display menu<br/>skip_v: display port_data ;prompt for new data<br/>lea si,ddra_sto ;point to data buffer<br/>call input_data ;get the data<br/>mov chk_sum,0<br/>send port_stg ;call emulator<br/>p_wait6: call get_flg<br/>compare msg_buf,rdy_stg<br/>cmp ax,0<br/>jne p_wait6<br/>mov al,down ;send down flag<br/>call send_b<br/>p_wait7: call get_flg</pre>                                                                                                                                                                                                                                                                                             |           | display            |                                       |                            |
| <pre>je skip_v<br/>jmp port_top ;display menu<br/>skip_v: display port_data ;prompt for new data<br/>lea si,ddra_sto ;point to data buffer<br/>call input_data ;get the data<br/>mov chk_sum,0<br/>send port_stg ;call emulator<br/>p_wait6: call get_flg<br/>compare msg_buf,rdy_stg<br/>cmp ax,0<br/>jne p_wait6<br/>mov al,down ;send down flag<br/>call send_b<br/>p_wait7: call get_flg</pre>                                                                                                                                                                                                                                                                                                            |           | call               |                                       | ;the ddr                   |
| <pre>jmp port_top ;display menu<br/>skip_v: display port_data ;prompt for new data<br/>lea si,ddra_sto ;point to data buffer<br/>call input_data ;get the data<br/>mov chk_sum,0<br/>send port_stg ;call emulator<br/>p_wait6: call get_flg<br/>compare msg_buf,rdy_stg<br/>cmp ax,0<br/>jne p_wait6<br/>mov al,down ;send down flag<br/>call send_b<br/>p_wait7: call get_flg</pre>                                                                                                                                                                                                                                                                                                                          |           |                    |                                       |                            |
| <pre>skip_v: display port_data ;prompt for new data<br/>lea si,ddra_sto ;point to data buffer<br/>call input_data ;get the data<br/>mov chk_sum,0<br/>send port_stg ;call emulator<br/>p_wait6: call get_flg<br/>compare msg_buf,rdy_stg<br/>cmp ax,0<br/>jne p_wait6<br/>mov al,down ;send down flag<br/>call send_b<br/>p_wait7: call get_flg</pre>                                                                                                                                                                                                                                                                                                                                                         |           |                    |                                       |                            |
| <pre>lea si,ddra_sto ;point to data buffer<br/>call input_data ;get the data<br/>mov chk_sum,0<br/>send port_stg ;call emulator<br/>p_wait6: call get_flg<br/>compare msg_buf,rdy_stg<br/>cmp ax,0<br/>jne p_wait6<br/>mov al,down ;send down flag<br/>call send_b<br/>p_wait7: call get_flg</pre>                                                                                                                                                                                                                                                                                                                                                                                                            |           |                    |                                       |                            |
| <pre>call input_data ;get the data mov chk_sum,0 send port_stg ;call emulator p_wait6: call get_flg compare msg_buf,rdy_stg cmp ax,0 jne p_wait6 mov al,down ;send down flag call send b p_wait7: call get_flg</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | skip_v:   |                    |                                       |                            |
| <pre>mov chk_sum,0<br/>send port_stg ;call emulator<br/>p_wait6: call get_flg<br/>compare msg_buf,rdy_stg<br/>cmp ax,0<br/>jne p_wait6<br/>mov al,down ;send down flag<br/>call send b<br/>p_wait7: call get_flg</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |           |                    | · · · · · · · · · · · · · · · · · · · | -                          |
| <pre>send port_stg ;call emulator p_wait6: call get_flg compare msg_buf,rdy_stg cmp ax,0 jne p_wait6 mov aI,down ;send down flag call send b p_wait7: call get_flg</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |           |                    |                                       | get the data               |
| <pre>p_wait6: call get_flg<br/>compare msg_buf,rdy_stg<br/>cmp ax,0<br/>jne p_wait6<br/>mov al,down ;send down flag<br/>call send_b<br/>p_wait7: call get_flg</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |           | -                  |                                       | call emulator              |
| compare msg_buf,rdy_stg<br>cmp ax,0<br>jne p_wait6<br>mov al,down ;send down flag<br>call send_b<br>p_wait7: call get_flg                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | p wait6:  |                    |                                       | your character             |
| <pre>cmp ax,0<br/>jne p_wait6<br/>mov al,down ;send down flag<br/>call send_b<br/>p_wait7: call get_flg</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | •         |                    |                                       |                            |
| mov al,down ;send down flag<br>call send b<br>p_wait7: call get_flg                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |           |                    |                                       |                            |
| call send_b<br>p_wait7: call get_flg                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |           | jne                | p_wait6                               |                            |
| p_wait7: call get_flg                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |           |                    | -                                     | ;send down flag            |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |           |                    |                                       |                            |
| COMDARE MED but rdy sta wait for ready signal                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | p_wait7:  |                    |                                       |                            |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |           |                    |                                       | ;walt for ready signal     |
| cmp ax,0<br>jne pwait7                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |           |                    |                                       |                            |
| mov al, ddra ; send port identification                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |           | -                  |                                       | .send port identification  |
| call send b                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |           |                    |                                       | , sena port identification |
| mov chk sum,al                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |           |                    |                                       |                            |
| mov al, ddra sto ; send the data                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |           | mov                |                                       | ;send the data             |
| call send b                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |           | call               |                                       |                            |
| add chk_sum,al                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |           | add                | chk_sum,al                            |                            |
| mov al,eot                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |           |                    | · · · ·                               |                            |
| call send b ; send eot                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |           |                    | _                                     | ;send eot                  |
| mov al, chk_sum                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |           |                    |                                       |                            |
| call send b ;send checksum<br>call get flg                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |           |                    |                                       | ;send cnecksum             |
| call get flg<br>compare msg_buf,ack stg                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |           |                    |                                       |                            |
| cmp ax,0 ;check for acknowledge                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |           |                    |                                       | check for acknowledge      |
| je skip_w                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |           |                    |                                       | , oncon for acknowledge    |
| add xmt, I                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |           | -                  |                                       |                            |
| cmp xmt,3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |           |                    |                                       |                            |
| jne p_wait7                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |           |                    | p_wait7                               |                            |
| jmp exit_port_pro                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |           |                    |                                       |                            |
| skip_w: display ddr_out ;ddr downloaded message                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | skip_w:   |                    |                                       | ;ddr downloaded message    |
| display continue                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |           | aisplay            | continue                              |                            |

the line that the same with and show - in

- . .

۰.,

|           | 1 1          |                          |                                                       |
|-----------|--------------|--------------------------|-------------------------------------------------------|
| p_hold3:  | call         | read_key                 |                                                       |
|           | cmp<br>jne   | al,cr                    |                                                       |
|           | -            | p_hold3<br>port top      |                                                       |
|           | jmp          | por c_cop                |                                                       |
| opt port  | f:           |                          |                                                       |
| oro_roro_ | cmp          | al,'f'                   |                                                       |
|           |              | skip x                   |                                                       |
|           | jmp          | opt port g               |                                                       |
|           |              |                          |                                                       |
| skip_x:   | mov          | xmt,0                    |                                                       |
|           | mov          | ax,0                     |                                                       |
|           | mov          | al,ddrb_sto              |                                                       |
|           |              | work,ax                  |                                                       |
|           |              |                          | ;convert ddr data                                     |
|           |              |                          | display the port data                                 |
|           |              |                          | ;do you want to change                                |
|           | call         | read_key                 | ;the ddr                                              |
|           | cmp          |                          |                                                       |
|           | je<br>im     | skip_y                   | . diemless menu                                       |
|           | jmp          | port_top                 | ;display menu                                         |
| skip_y:   | lea          | port_data<br>si,ddrb sto | <pre>;prompt for new data ;point to data buffer</pre> |
|           | call         | input data               | ;get the data                                         |
|           | mov          | chk sum,0                | get the data                                          |
|           | send         | port stg                 | ;call emulator                                        |
| p wait8:  | call         | get_flg                  | , call emalator                                       |
| P_warco.  |              | msg buf,rdy stg          |                                                       |
|           | cmp          | ax,0                     |                                                       |
|           | jne          | p wait8                  |                                                       |
|           | mov          |                          | ;send down flag                                       |
|           | call         |                          | ,                                                     |
| p wait9:  | call         |                          |                                                       |
|           | compare      | msg buf, rdy stg         | ;wait for ready signal                                |
|           | cmp          | ax,0                     |                                                       |
|           | jne          | p_wait9                  |                                                       |
|           | mov          | al,ddrb                  | ;send port identification                             |
|           | call         | send_b                   |                                                       |
|           | mov          | chk_sum,al               |                                                       |
|           | mov          | al,ddrb_sto              | ;send the data                                        |
|           | call         | send_b                   |                                                       |
|           | add          | chk_sum,al               |                                                       |
|           | mov          | al,eot                   | and ask                                               |
|           | call         | send b                   | ;send eot                                             |
|           | mov          | al,chk_sum<br>send b     | ;send checksum                                        |
|           | call<br>call | get flg                  | jsenu checksull                                       |
|           |              | msg buf,ack stg          |                                                       |
|           | Compare      | ax,0                     | ;check for acknowledge                                |
|           | jne          | alright                  | , one of the worldwickye                              |
|           | add          | xmt,1                    |                                                       |
|           | cmp          | xmt,3                    |                                                       |
|           | jne          | p wait9                  |                                                       |
|           | -            | • <u> </u>               |                                                       |

•

÷.

E

Ľ

12-4 24-1-41-Y

.....

.

۰.

•

.

| alright:<br>p_hold4:                    | display<br>call<br>cmp<br>jne                   | exit_port_pro<br>ddr_out<br>continue<br>read_key<br>al,cr<br>p_hold4<br>port_top | ;ddr downloaded message                                                                                                                           |
|-----------------------------------------|-------------------------------------------------|----------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| <pre>exit_port p_hold5: opt_port_</pre> | display<br>display<br>call<br>cmp<br>jne<br>jmp | read_key                                                                         | ;display error message                                                                                                                            |
| port_pro                                | endp                                            |                                                                                  |                                                                                                                                                   |
| ;*******                                | ******                                          | *****                                                                            | * * * * * * * * * * * * * * * * * * * *                                                                                                           |
| start:                                  |                                                 | break flg,off<br>step_flg,off<br>clr                                             | ;stepin step mode                                                                                                                                 |
|                                         | call<br>compare<br>cmp<br>je                    | <pre>standby get_flg msg_buf,ack_stg ax,0 sram_ok sram_err</pre>                 | <pre>;display wait message<br/>;look for first ack signal<br/>;if 0 then SRAM ok<br/>;if ram is bad display<br/>;error message and goto DOS</pre> |
| <pre>sram_ok:</pre>                     | cmp<br>je                                       | dos<br>get_flg<br>msg_buf,ack_stg<br>al,0<br>well<br>sram_err                    | <pre>;look for second ack signal<br/>;if 0 then user RAM ok<br/>;if ram is bad display<br/>;error message and goto DOS</pre>                      |
| well:<br>send emul                      | jmp<br>mov<br>:                                 | dos<br>xmt,0                                                                     | , criot message and goto Dos                                                                                                                      |
| hump1:                                  | send<br>mov<br>lea<br>mov<br>int                | down_ld<br>chk_sum,0<br>dx,filnam<br>ax,3d00h<br>21h                             | ;send download flag<br>;point to emulator code<br>;open the file for reading<br>;pointer at beginning                                             |

- in a

-0.4

المدادة والشراهب

|           | jnc       | skip ab                                |                          |
|-----------|-----------|----------------------------------------|--------------------------|
|           | jmp       | loaderr                                |                          |
| skip ab:  | mov       | bx,ax                                  | ;store file handle in BX |
| next set: |           | dx,user                                | ;destination buffer      |
|           | mov       | cx,2048                                | ; load number of bytes   |
|           | mov       | ah,3fh                                 | field number of syces    |
|           | int       | 21h                                    |                          |
|           | mov       | cx,ax                                  | ;set counter to actual   |
|           | MOV       | CATUR                                  | ;number of bytes         |
|           | mov       | si,offset user                         | ;point to buffer         |
| emul down |           | si,oliset uset                         | point to builer          |
|           | cmp       | ax,0                                   |                          |
|           |           |                                        |                          |
| emul d1:  | je<br>mov | emul_gone                              |                          |
| emui_ui.  | mov       | al,[si]                                |                          |
|           | call      | send_b                                 |                          |
|           | inc       | si                                     |                          |
|           | add       | chk_sum,al                             | ;update checksum         |
|           | loop      | emul_d1                                |                          |
|           | jmp       | next_set                               |                          |
| emul_gone |           |                                        | • • • • • •              |
|           | mov       | al,ETB                                 | ;place eot at the end    |
|           | call      | send_b                                 | ; of the stored data     |
|           | mov       | al,ETB                                 |                          |
|           | call      | send_b                                 |                          |
|           | mov       | al, chk_sum                            | ;send checksum value     |
|           | call      | send_b                                 |                          |
|           |           |                                        |                          |
|           | call      | get_flg                                |                          |
|           |           | msg_buf,ack_stg                        |                          |
|           | cmp       | ax,0                                   |                          |
|           | jne       | skip_z                                 |                          |
|           | jmp       | window_1                               | ;display setup menu      |
|           |           |                                        | ;else retransmit         |
| skip_z:   | add       | xmt,1                                  |                          |
| _         | cmp       | xmt,3                                  |                          |
|           | jne       | skip_ae                                |                          |
|           | jmp       | dos –                                  |                          |
| skip_ae:  | jmp       | send_emul                              |                          |
|           |           | _                                      |                          |
|           | mov       | ah,3eh                                 | ;close the file          |
|           | int       | 21h                                    |                          |
|           |           |                                        |                          |
| window_1: | call      | clr                                    |                          |
| _         | call      | disp stat                              | display system status;   |
|           | display   | setup menu                             | ;display setup menu      |
|           | display   |                                        |                          |
|           | call      | read key                               | ;get the option number   |
|           | cmp       | al,'ā'                                 |                          |
|           | jne       | opt set b                              |                          |
|           | call [    | user pro                               | ;goto user memory        |
|           |           | <b>—</b> -                             | ;subroutine              |
|           | jmp       | window 1                               |                          |
|           | 2 ···· 6  | ······································ |                          |

2

1.

مسدرات أعاشه

| opt set b | :               |                        |                                              |
|-----------|-----------------|------------------------|----------------------------------------------|
|           | cmp             | al,'b'                 |                                              |
|           | jne<br>call     | opt_set_c<br>break pro | ;goto break control                          |
|           | Cull            | Dreux_pro              | ;subroutine                                  |
|           | jmp             | window_1               |                                              |
| opt set c | :               |                        |                                              |
| -1        | cmp             | al,'c'                 |                                              |
|           | jne             | opt_set_d              |                                              |
|           | call<br>jmp     | port_pro<br>window 1   | ;goto port subroutine                        |
|           | J.m.P.          | window_1               |                                              |
| opt_set_d |                 |                        |                                              |
|           | cmp<br>jne      | al,'d'<br>opt set e    |                                              |
|           | jmp             | window 2               | ;goto main menu                              |
| opt_set_e |                 | -                      |                                              |
| opt set e |                 | bad_sel                | display invalid input;                       |
| opc_set_c | call            | read key               |                                              |
|           | cmp             | al,cr                  |                                              |
|           | jne<br>jmp      | opt_set_e1<br>window 1 |                                              |
|           | Jub             | window_1               |                                              |
| window_2: |                 | clr                    |                                              |
|           | call<br>display | disp_stat<br>main menu | ;display system status<br>;display main menu |
|           | display         |                        | , display main menu                          |
|           | call            | read_key               | ;get the option number                       |
|           | cmp<br>jne      | al, 'a'                |                                              |
|           | call            | opt_main_b<br>step pro | ;goto target subroutine                      |
|           | jmp             | window_2               |                                              |
| opt main  | b:              |                        |                                              |
| ope_main_ | cmp             | al,'b'                 |                                              |
|           | jne             | opt_main_c             |                                              |
|           | call<br>jmp     | break_pro<br>window 2  | ;toggle the break status                     |
|           | Jub             | window_2               |                                              |
| opt_main_ |                 |                        |                                              |
|           | cmp<br>jne      | al,'c'<br>opt main d   |                                              |
|           | call            | break pro              | ;goto break address                          |
|           |                 | -                      | ;subroutine                                  |
|           | jmp             | window_2               |                                              |
| opt main  | d:              |                        |                                              |
|           | cmp             | al,'d'                 |                                              |
|           | jne<br>call     | opt_main_e             | soto singla-star sectors                     |
|           | Call            | step_pro               | ;goto single-step control<br>;subroutine     |
|           |                 |                        |                                              |

|            | jmp                       | window_2                                     |                          |
|------------|---------------------------|----------------------------------------------|--------------------------|
| opt main ( | <b>•</b> •                |                                              |                          |
| op c_main_ | cmp<br>jne<br>call<br>jmp | al,'e'<br>opt_main_f<br>user_pro<br>window_2 |                          |
| opt main d | £:                        |                                              |                          |
| •          | cmp<br>jne<br>call<br>jmp | al,'f'<br>opt_main_g<br>port_pro<br>window_2 | goto to port subroutine; |
| opt_main o | g:                        |                                              |                          |
| dos:       | cmp<br>jne<br>mov<br>int  | al,'g'<br>opt_main_h<br>ax,4c00h<br>21h      | ;return to DOS           |
| opt_main_h |                           |                                              | •• • • • • • •           |
| ont set h. | display                   | bad_sel                                      | display invalid input;   |
| opt_set_h: | call<br>cmp<br>jne        | read_key<br>al,cr<br>opt_set_h               |                          |
| load_err:  | display                   | window_2<br>clr<br>disk_err<br>continue      |                          |
| load_err1: | :                         |                                              |                          |
|            | call<br>cmp<br>jne<br>jmp | read_key<br>al,cr<br>load_err1<br>hump1      |                          |
| cseg       | ends<br>end               | start                                        |                          |

and the second second

E

2

È

E

- .

## Appendix E: User Guide

المعدة ومنتج وسيعت وسيعا والمعادية والمعادية والمعالية

K

E

This user guide contains information concerning emulator system testing which is still pending. For completeness the interrelationship of untested circuits and the rest of the system will be discussed.

The only portion of the emulator which has not been tested is the break detector circuitry. The individual components of this section have been tested, but the overall functionality of the circuit is still pending. This circuit consists of the 74F524 register comparators (U19-U28), the 8259A interrupt controller (U58), and the 74F157 multiplexers (U42-U44). These devices are completely wired and respond to their control and data signal in the proper manner.

Testing of the register/comparators consisted of preforming read and write operations to ensure proper wiring. The interrupt controller appears to function properly when excited manually, but hasn't been verified with software control. The break disable function is functional and provides a means of using the emulator in a limited capacity. The other functions of the emulator do not directly depend on the break feature and function properly when isolated from the break section.

Software to support the break circuits consists of an interface to the user via the host computer and a corresponding break module in the emulator code. The host

computer portion of the control software has been tested by performing data aquisition. The emulator portion has some additional testing to under go. The break handler routine has not been tested in response to an actual break condition. This program is currently preventing complete testing of the break detector hardware as a complete circuit. No additional hardware errors are expected from the break circuit, but this is not verifiable at this time.

E

## Bibliography

- Bisbee, Lt Col Charles, Associate Professor. Personal Interview. Air Force Institute of Technology, Wright-Patterson AFB, OH 21 April 1988.
- Intel Corporation. <u>Microsystem Handbook Set.</u> Intel Literature Department, Intel Corporation, Santa Clara, CA 1986.
- Booch, Grady Software Engineering with Ada Tokyo: The Benjamin/Cummings Company, 1987.

the below the sector was also been as a sector of the sect

- Dinwiddie, George "An 8031 In-Circuit Emulator", Byte, Small System Journal, 11: 181-199 (July 1986).
- 5. Pedicini, Chris "Engineering on a Micro", Byte, Small System Journal, 11: 145-170 (July 1987).
- Pressman, Roger S. Software Engineering: A Practitioner's Approach. New York: McGraw-Hill, 1987.
- 7. Russo, John P. "A Vic-201 Commodore 64 Terminal Emulator", <u>Byte, Small System</u> Journal, <u>9:</u> 379-388 (April 1986).
- Stern, Marc "All About Interfacing", <u>Radio Electronics, 57:</u> 87-96 (December 1986).
- 9. Wilcox, Alan D. Engineering Design: Project Guidelines. Englewood Cliffs NJ: Prentice-Hall, 1987.
- 10. Woodhull, Albert S. "An EPROM Simulator", Byte, Small System Journal, 9: 400-410 (March 1985).

Captain John L Woods was born on

He graduated from high in Deadwood, South Dakota, in 1970. He entered the USAF in 1972 and served until July 1981. Upon leaving the Air Force he attended the University of Oklahoma, form which he received the degree of the Bachelor of Science in Electrical Engineering in May 1984. Upon graduation, he received a commission in the USAF through the Officer Training School. He received the degree of Master of Science in Consumer Studies at Oklahoma State University, Stillwater Oklahoma. He served as an Elecromagnetic Hazards Engineer at the Engineering Installation Division, Tinker AFB, Oklahoma, until entering the School of Engineering, Air Force Institute of Technology, in June 1987.

VITA

.

| <b>REPORT DOCUMENTATION PAGE</b>                                                                                                                               |                                                                                                          |                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                             |                                                                                         | Form Approved<br>OMB No. 0704-0188                                 |                           |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------|--------------------------------------------------------------------|---------------------------|
| 1a. REPORT SECURITY CLASSIFICATION<br>UNCLASSIFIED                                                                                                             |                                                                                                          |                                                                                           | 16. RESTRICTIVE MARKINGS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                             |                                                                                         |                                                                    |                           |
| 28. SECURITY CLASSIFICATION AUTHORITY                                                                                                                          |                                                                                                          | 3. DISTRIBUTION / AVAILABILITY OF REPORT                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                             |                                                                                         |                                                                    |                           |
| 2b. DECLASSIFICATION / DOWNGRADING SCHEDULE                                                                                                                    |                                                                                                          | Approved for Public Release;<br>Unlimited Distribution                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                             |                                                                                         |                                                                    |                           |
| PERFORM                                                                                                                                                        | ING ORGANIZAT                                                                                            | ION REPORT N                                                                              | UMBER(S)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 5. MONITORING                                                                               | ORGANIZATION                                                                            | REPORT NUM                                                         | MBER(S)                   |
|                                                                                                                                                                | r/Gr/ENG/88                                                                                              |                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                             |                                                                                         |                                                                    |                           |
|                                                                                                                                                                | of Engineer                                                                                              |                                                                                           | (If applicable)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 7a. NAME OF M                                                                               | ONITORING OR                                                                            | GANIZATION                                                         |                           |
| _                                                                                                                                                              | 5 (City, State, an                                                                                       |                                                                                           | AFIT/ENA                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 7b. ADDRESS (C                                                                              | ty State and Z                                                                          | IP Code)                                                           |                           |
| Air Ford                                                                                                                                                       | ce Institut<br>Patterson A                                                                               | e of Tech                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                             | .,,                                                                                     |                                                                    |                           |
| a. NAME O<br>ORGANIZ                                                                                                                                           | F FUNDING/SPO<br>ZATION                                                                                  | ONSORING                                                                                  | 8b. OFFICE SYMBOL<br>(If applicable)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | DL 9. PROCUREMENT INSTRUMENT IDENTIFICAT                                                    |                                                                                         |                                                                    |                           |
| C ADDRESS                                                                                                                                                      | i (City, State, and                                                                                      | I ZIP Code)                                                                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 10. SOURCE OF                                                                               | FUNDING NUM                                                                             | IERS                                                               |                           |
| •                                                                                                                                                              |                                                                                                          |                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | PROGRAM<br>ELEMENT NO.                                                                      | PROJECT<br>NO.                                                                          | TASK<br>NO                                                         | WORK UNIT<br>ACCESSION NO |
|                                                                                                                                                                | MULATOR DE                                                                                               | SIGN                                                                                      | (UNCLASSIFIED)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                             |                                                                                         |                                                                    |                           |
| John L V<br>3a. Type o<br>MS Thesi                                                                                                                             |                                                                                                          | 135. TI<br>FRON                                                                           | ME COVERED<br>A TO                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 14. DATE OF REPO<br>1988 Dece                                                               |                                                                                         | th, Day) 15.                                                       | PAGE COUNT                |
| John L V<br>3a. Type O<br>M <u>S Thesi</u><br>6. Supplen                                                                                                       | F REPORT<br>LS<br>MENTARY NOTAT                                                                          | 13b. TI<br>FRON                                                                           | а то                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 1988 Dece                                                                                   | mber                                                                                    |                                                                    | 205                       |
| Iohn L V<br>3a. Type O<br>15 Thesi<br>6. Supplem                                                                                                               | F REPORT                                                                                                 | 13b. TI<br>FRON                                                                           | A TO<br>18. SUBJECT TERMS (                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 1988 Dece                                                                                   | mber                                                                                    |                                                                    | 205                       |
| John L V<br>3a. TYPE O<br>MS Thesi<br>6. SUPPLEN<br>7.<br>FIELD<br>12                                                                                          | F REPORT<br>LS<br>MENTARY NOTAT<br>COSATI<br>GROUP<br>6                                                  | 13b. TI<br>FROM<br>TION<br>CODES<br>SUB-GROU                                              | A TO<br>18. SUBJECT TERMS (<br>P<br>Computers,                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 1988 Dece<br>Continue on reven<br>Computer Lo                                               | mber<br>se if necessary a                                                               |                                                                    | 205                       |
| John L V<br>3a. TYPE O<br>MS Thesi<br>6. SUPPLEN<br>7.<br>FIELD<br>12<br>9. ABSTRAC<br>Charl                                                                   | F REPORT<br>IS<br>MENTARY NOTAT<br>COSATI<br>GROUP<br>6<br>T (Continue on<br>Les R. Bisb                 | TION<br>CODES<br>SUB-GROU<br>reverse if nece                                              | TO                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 1988 Dece<br>Continue on revers<br>Computer Lo<br>umber)                                    | mber<br>se if necessary a<br>gic                                                        | and identify b                                                     | 205                       |
| John L V<br>3a. TYPE O<br>MS Thesi<br>6. SUPPLEN<br>7.<br>FIELD<br>12<br>9. ABSTRAC<br>Charl                                                                   | F REPORT<br>IS<br>MENTARY NOTAT<br>COSATI<br>GROUP<br>6<br>T (Continue on<br>Les R. Bisb                 | TION<br>CODES<br>SUB-GROU<br>reverse if nece                                              | TO      TO      18. SUBJECT TERMS (     Computers,     computers,     dentify by block m  1, USAF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 1988 Dece<br>Continue on revers<br>Computer Lo<br>umber)                                    | mber<br>se if necessary a<br>gic                                                        | and identify b                                                     | 205                       |
| John L V<br>3a. TYPE O<br><u>4S Thesi</u><br>6. SUPPLEN<br>7.<br>FIELD<br>12<br>9. ABSTRAC<br>Charl                                                            | F REPORT<br>IS<br>MENTARY NOTAT<br>COSATI<br>GROUP<br>6<br>T (Continue on<br>Les R. Bisb                 | TION<br>CODES<br>SUB-GROU<br>reverse if nece                                              | TO      TO      18. SUBJECT TERMS (     Computers,     computers,     dentify by block m  1, USAF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 1988 Dece<br>Continue on revers<br>Computer Lo<br>umber)                                    | mber<br>se if necessary a<br>gic                                                        | and identify b                                                     | 205                       |
| Ohn L V<br>Ba. TYPE O<br>IS Thesi<br>S. SUPPLEM<br>FIELD<br>12<br>ABSTRAC<br>Char]                                                                             | F REPORT<br>IS<br>MENTARY NOTAT<br>COSATI<br>GROUP<br>6<br>T (Continue on<br>Les R. Bisb                 | TION<br>CODES<br>SUB-GROU<br>reverse if nece                                              | TO      TO      18. SUBJECT TERMS (     Computers,     computers,     dentify by block m  1, USAF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 1988 Dece<br>Continue on revers<br>Computer Lo<br>umber)                                    | mber<br>se if necessary a<br>gic                                                        | and identify b                                                     | 205                       |
| John L V<br>3a. TYPE O<br>MS Thesi<br>6. SUPPLEM<br>7.<br>FIELD<br>12<br>9. ABSTRAC<br>Charl<br>Assoc                                                          | F REPORT<br>IS<br>MENTARY NOTAT<br>COSATI<br>GROUP<br>6<br>CT (Continue on<br>Les R. Bisb<br>ciate Profe | 13b. TI<br>FROM<br>TION<br>CODES<br>SUB-GROU<br>reverse if nece<br>ee, Lt Co<br>ssor of E | <pre>ATO<br/>P18. SUBJECT TERMS (<br/>Computers,<br/>Issary and identify by block n<br/>1, USAF<br/>lectrical Engineerin<br/></pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 1988 Dece<br>Continue on rever<br>Computer Lo<br>umber)                                     | mber<br>se if necessary a<br>gic                                                        | for prices<br>for prices<br>for prices<br>for prices<br>for prices | 205                       |
| John L V<br>3a. TYPE O<br>MS Thesi<br>6. SUPPLEN<br>7.<br>FIELD<br>12<br>9. ABSTRAC<br>Charl<br>Assoc                                                          | COSATI<br>COSATI<br>GROUP<br>6<br>CT (Continue on<br>Les R. Bisb<br>ciate Profe                          | I 13b. TI<br>FROM                                                                         | <pre>ATO<br/>P18. SUBJECT TERMS (<br/>Computers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComput</pre> | 1988 Dece<br>Continue on revers<br>Computer Lo<br>umber)<br>Dg<br>21. ABSTRACT SE<br>UNCLAS | mber<br>gic                                                                             | and identify by                                                    | 205<br>y block number)    |
| IOHN L V<br>3a. TYPE O<br>4S Thesi<br>6. SUPPLEN<br>7.<br>FIELD<br>12<br>9. ABSTRAC<br>Charl<br>Assoc<br>Charl<br>Assoc<br>0. DISTRIBU<br>3. UNCLA<br>2a. NAME | COSATI<br>COSATI<br>GROUP<br>6<br>COSATI<br>GROUP<br>6<br>CT (Continue on<br>Les R. Bisb<br>ciate Profe  | I 13b. TI<br>FROM                                                                         | <pre>ATO<br/>P18. SUBJECT TERMS (<br/>Computers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComputers,<br/>PComput</pre> | 1988 Dece<br>Continue on rever<br>Computer Lo<br>umber)<br>Dg                               | mber<br>gic<br>for the stary of<br>gic<br>locurity classif<br>SIFJED<br>Include Area Co | for prices<br>for prices<br>Tan 198                                | 205<br>y block number)    |

.

Item 19.

## Abstract

This paper discusses the requirements to develop and build an electronic device to emulate the 8755 microchip. The design had five basic objectives: (1) Allow the user to download 8755 emulation memory. (2) Allow control of the target program from the Z-100. (3) Provide a single step capability. (4) Provide breaking at a specified address. (5) Allow the user to set or change the emulated 8755 input/output ports.

It describes the standard memory and input/output capabilities of the 8755. It describes in detail the emulator enhancement features to the standard 8755. The hardware circuits used to implement the emulator are discussed at the block diagram, component, and signal levels. It concludes with a detail description of the emulator sotware used to control the hardware.