# PM Technical Reference Manual



Please attach this label to the spine of the binder. See the illustration below for the correct location.



# PM Technical Reference Manual

TeleVideo Part Number 127611-00 Rev. A

February 1985

)

)



#### Personal Mini Technical Reference

#### Copyright

Copyright ©1985 by TeleVideo Systems, Inc. All rights reserved. No part of this publication may be reproduced, transmitted, transcribed, stored in a retrieval system, or translated into any language or computer language, in any form or by any means, electronic, mechanical, magnetic, optical, chemical, manual, or otherwise, without the prior written permission of TeleVideo Systems, Inc., 550 East Brokaw Road, San Jose, CA 95112.

#### Disclaimer

TeleVideo Systems, Inc. reserves the right to make improvements to products without incurring any obligations to incorporate such improvements in products previously sold. Specifications and information contained in this manual are subject to change without notice.

Material describing applications of components supplied by independent vendors such as Intel, Synertek, and Western Digital have been based in large part upon handbooks, technical manuals, and similar information distributed by such vendors. For a complete description of those parts and the ways in which they may be used, reference should be made to vendors' texts, which will be more complete.

#### Personal Mini Technical Reference

TeleVideo is a registered trademark of TeleVideo Systems, Inc.

PM, PM/16, PM/16T, and PM/4T are trademarks of TeleVideo Systems, Inc.

Z80A is a registered trademark of ZILOG Corporation.

Printed February 1985.

TeleVideo Part Number: 127611-00 Rev. A

TeleVideo Systems, Inc., 550 East Brokaw Road, San Jose, CA 95112.

#### PREFACE

The Personal Mini Technical Reference Manual is intended for use by the programmer, engineer, dealer, and end user. The manual provides an overview of the hardware and a more in-depth view of the hardware programming. The systems covered include the PM/16, PM/16T, and PM/4T. The latter two systems feature an integral backup tape drive for backing up the hard disk, hence the 'T' suffix in their names.

The manual has five chapters and three appendices which are described here. Chapter 1, Unit Overview, describes the features of the Personal Mini and provides the physical, environmental, power, memory, and storage specifications. The workstation cable requirements and a general description of each major assembly are also described. At the end of the chapter is a list of references that provide additional information about the components discussed in this manual.

Chapter 2, Hardware Functions, details the operations of the following components: the CPU (16-bit), Z80A (8-bit processor), main memory, hard disk controller, and the tape backup drive.

**Chapter 3, Hardware Programming,** contains the information a programmer needs to interface with the system hardware, such as I/O addresses and command codes.

#### **Chapter 4, Interface,** details the pin-outs and signals for the internal and external connectors.

Appendix A, Jumper Configurations, describes the jumper configurations on the main CPU board and tape drive interface board.

**Appendix B, Self Diagnostics,** describes the diagnostics that are performed by the Personal Mini upon initialization.

**Appendix C, Logic Diagrams,** contains the logic diagrams of the main CPU board, Winchester disk controller board, and tape drive interface board.

## TABLE OF CONTENTS

#### **1 UNIT OVERVIEW**

)

)

)

| Physical Specifications      | 1.3  |
|------------------------------|------|
| Environmental Specifications | 1.5  |
| Power Requirements           | 1.5  |
| Memory and Storage           | 1.6  |
| Workstation Cables           | 1.8  |
| Major Assemblies             | 1.8  |
| Technical References         | 1.10 |

#### **2 HARDWARE FUNCTIONS**

| 80186 CPU Functions<br>DUART | 2.1<br>2.6 |
|------------------------------|------------|
| Parallel Printer Port        | 2.6        |
| Floppy Disk Controller       | 2.9        |
| Hard Disk Interface          | 2.11       |
| System Interrupts            | 2.11       |
| Main Memory                  | 2.13       |
| Memory Mux                   | 2.13       |
| Memory Controller            | 2.13       |
| Memory Banks                 | 2.15       |
| Winchester Disk Controller   | 2.16       |
| 8-Bit Networking Functions   | 2.18       |
| Local Memory                 | 2.20       |
| Memory Mapping               | 2.20       |
| Serial I/O and User          |            |
| Stations                     | 2.20       |
| Counter-Timer Circuit        | 2.22       |
| Expansion Slots              | 2.23       |
| Tape Back-Up                 | 2.23       |
| Tape Operation               | 2.23       |

## 3 HARDWARE PROGRAMMING

| 80186 Microprocessor            | 3.1  |
|---------------------------------|------|
| 80186 Interrupts                | 3.1  |
| 80186 Read-Only Memory          | 3.3  |
| 80186 I/O Port Selection        | 3.4  |
| Z80A Microprocessor             | 3.8  |
| Z80A Interrupts                 | 3.8  |
| Z80A Read-Only Memory           | 3.9  |
| Z80A I/O Ports                  | 3.10 |
| <b>Z80A</b> Processor Section   |      |
| Reset                           | 3.12 |
| Main Memory                     | 3.13 |
| Dual Port Ram Controller        | 3.13 |
| Memory Organization             | 3.16 |
| Memory Locking                  | 3.17 |
| Z80A CPU Main Memory            |      |
| Mapping                         | 3.17 |
| Expansion Card Slots            | 3.19 |
| System Facilities for Expansion |      |
| Cards                           | 3.21 |
| Parallel Port                   | 3.21 |
| Serial and Console Ports        | 3.23 |
| Mode Register 1 - MR1A          |      |
| & MRÍB                          | 3.24 |
| Clock Select Registers          |      |
| CSRA & CSRB                     | 3.27 |
| Interrupt Status Register -     |      |
| ISR                             | 3.29 |
| Command Registers - CRA         |      |
| & CRB                           | 3.30 |
| Floppy Disk Controller          | 3.32 |
| Status Register                 | 3.34 |
| Command Register                | 3.35 |
| Track Register                  | 3.38 |
| Sector Register                 | 3.38 |
| Data Register                   | 3.38 |
| Winchester Disk Controller      |      |
| Board                           | 3.39 |
| Task File Register              |      |
| Functions                       | 3.39 |
| Error Register                  | 3.40 |

١

)

## 3 HARDWARE PROGRAMMING Continued

| Write Precomp Register     | 3.41    |
|----------------------------|---------|
| Sector Count Register      | 3.41    |
| Sector Number Register     | 3.41    |
|                            | 3.4I    |
| Cylinder Number Low        | • • • • |
| Register                   | 3.41    |
| Cylinder Number High       |         |
| Register                   | 3.41    |
| Sector/Drive/Head Register | 3.42    |
| Status Register            | 3.43    |
| Command Register           | 3.44    |
| Tape Interface Card        | 3.51    |
|                            |         |
| Tape Card Interrupts       | 3.51    |
| Local Memory Space         | 3.53    |
| Main Memory Addressing     | 3.54    |
| Configuration Facility     | 3.55    |
| CTC Counter/Timer          | 3.55    |
| DMA Transfers              | 3.57    |
|                            | -       |
| Tape Drive Interface       | 3.57    |
| Data Format                | 3.60    |
| The IOCB                   | 3.63    |
| Tape Commands              | 3.65    |
| - The second second        |         |

## **4** INTERFACE

)

· )

)

| Internal Interfaces        | 4.1  |
|----------------------------|------|
| Power Supply (Pl)          | 4.1  |
| Tape Drive Controller      |      |
| Board (P2)                 | 4.2  |
| Expansion Card Slot (P7)   | 4.3  |
| Expansion Card Slot (P8)   | 4.6  |
| Floppy Disk Drive (P9)     | 4.9  |
| Memory Expansion           |      |
| Board (P10)                | 4.10 |
| Hard Disk Controller (P21) | 4.12 |
| External Interfaces        | 4.13 |
| Hard Disk Expansion and    |      |
| Hard Disk Data (P22)       | 4.13 |
| Parallel Printer Port (P3) | 4.13 |
| Console (P4) and Serial    |      |
| Printer (P5)               | 4.14 |

## 4 INTERFACE Continued

| RS422 Network (P6)      | 4.15 |
|-------------------------|------|
| User Channels (Pl1-Pl8) | 4.15 |
| User Expansion (P19)    | 4.16 |
| Reset Button (P20)      | 4.16 |

## APPENDICES

| Jumper Configurations | A.1 |
|-----------------------|-----|
| Self Diagnostics      | B.1 |
| Logic Diagrams        | C.1 |

#### FIGURES

)

)

)

| Tape Expansion Board<br>System Functions<br>80186 CPU Section<br>DUART | 1.4<br>2.3<br>2.5<br>2.7 |
|------------------------------------------------------------------------|--------------------------|
| Parallel Printer Port                                                  | 2.8                      |
| Floppy Disk Controller                                                 | 2.10                     |
| Hard Disk Interface                                                    | 2.12                     |
| Main Memory Section                                                    | 2.14                     |
| Winchester Disk Controller                                             | 2.17                     |
| <b>Z80A 8-Bit Section</b>                                              | 2.19                     |
| Local Memory                                                           | 2.21                     |
| Tape Back-Up                                                           | 2.24                     |
| Parallel Printer and                                                   |                          |
| Status Buffer                                                          | 3.3                      |
| Configure Z80A Buffer Select                                           | 3.12                     |
| Control Signal Input Port                                              | 3.22                     |
| Output Control Port                                                    | 3.23                     |
| Floppy Disk Control Latch                                              | 3.33                     |
| Status Register                                                        | 3.34                     |
| Tape Card Local Memory                                                 |                          |
| Space Map                                                              | 3.53                     |
| High Address Register                                                  | 3.54                     |
| Write Control Latch                                                    | 3.58                     |
| Drive Status Bit Assignments                                           | 3.59                     |
| Control Byte                                                           | 3.61                     |
| IOCB Pointer                                                           | 3.63                     |
| Status Code                                                            | 3.64                     |
|                                                                        |                          |

#### TABLES

| PM Features                | 1.2  |
|----------------------------|------|
| 80186 Interrupt Priorities | 3.2  |
| PACS Register              | 3.4  |
| PCS Address Ranges         | 3.5  |
| MPCS Register              | 3.6  |
| 80186 I/O Port Addresses   | 3.7  |
| Z80A Interrupts            | 3.9  |
| Z80A I/O Port Addresses    | 3.10 |
| Set User and Misc Latch    | 3.11 |

## TABLES Continued

| Default Initialization<br>of the Memory Controller | 3.15 |
|----------------------------------------------------|------|
| Data Output Port                                   | 3.22 |
| DUART Register Addresses                           | 3.24 |
| Mode Register 1 - MRIA & MRIB                      | 3.25 |
| CSRA                                               | 3.27 |
| Interrupt Status Register                          | 3.29 |
| Command Register                                   | 3.31 |
| FDC Register Addresses                             | 3.34 |
| FDC Commands                                       | 3.35 |
| Flag Summary                                       | 3.35 |
| WD1010-05 Registers                                | 3.39 |
| Error Register                                     | 3.40 |
| Status Register                                    | 3.43 |
| Command Register Format                            | 3.45 |
| Tape Card Interrupt Addresses                      | 3.51 |
| Main Board Interrupts to the                       |      |
| Tape Card                                          | 3.52 |
| CTC Channel Assignments                            | 3.56 |
| GCR Conversion Table                               | 3.60 |
| Status Byte O                                      | 3.72 |
| Status Byte 1                                      | 3.74 |
| Power Supply (P1)                                  | 4.1  |
| Tape Drive Controller                              |      |
| Board (P2)                                         | 4.2  |
| Expansion Card Slot (P7)                           | 4.3  |
| Expansion Card Slot (P8)                           | 4.6  |
| Floppy Disk Drive (P9)                             | 4.9  |
| Memory Expansion                                   |      |
| Board (P10)                                        | 4.10 |
| Hard Disk Controller (P21)                         | 4.12 |
| Hard Disk Expansion and                            |      |
| Hard Disk Data (P22)                               | 4.13 |
| Parallel Printer Port (P3)                         | 4.13 |
| Console (P4) and Serial                            |      |
| Printer (P5)                                       | 4.14 |
| RS422 Network (P6)                                 | 4.15 |
| User Channels (P11-P18)                            | 4.15 |
| User Expansion (P19)                               | 4.16 |
|                                                    |      |

)

)

)

## TABLES Continued

4.16 Reset Button (P20) Jumper Default Configuration A.1 Tape Board Default Configuration A.6 Sequence Number and Error Message B.15 Tape Status Bits B.15 Tape Extended Status Bits B.17 Hex Complementary Status Bits B.18 Drive Hex Status Code B.19

#### 1. UNIT OVERVIEW

The Personal Mini (PM) is a high performance, network system, capable of interfacing with the IBM PC, most IBM compatible computers, and the TeleVideo TS 1605 and TPC II systems. The Personal Mini is available in three configurations:

- \* PM/16 Manages eight workstations and contains a 40 megabyte hard disk drive. The system can be expanded to sixteen workstations with the PM Expansion Unit and its eight additional ports. The Expansion Unit also provides 40 megabytes of additional hard disk storage.
- \* PM/16T Manages eight workstations. The system contains an intelligent interface tape backup drive and a 40 megabyte hard disk. It too can be expanded to sixteen workstations with the PM Expansion Unit.
- \* PM/4T Manages four workstations and contains an intelligent interface tape backup drive to backup its 20 megabyte hard disk.

The hard disk in the PM/16 and the PM Expansion Unit can be backed up onto tape with the TS 806C Tape Drive Unit. The unit is available from TeleVideo and includes the necessary software. The Personal Mini is configured as a star network, with RS-422 ports and a simple, low overhead protocol. Table 1-1 lists many of the outstanding features of the systems.

Table 1-1 PM Features

| Maximum<br>‡ of    | P <b>m/4</b> T  | PM/16           | P <b>M/16</b> T |
|--------------------|-----------------|-----------------|-----------------|
| Users              | 12              | 16              | 16              |
| СРО                | 80186 &<br>Z80A | 80186 &<br>Z80A | 80186 &<br>Z80A |
| RAM                | 256-512K        | 256-512K        | 512K            |
| Floppy<br>Drive    | 360K            | 720K            | 360K            |
| Hard Disk<br>Drive | 20M             | 44.5M           | 44.5M           |
| Tape<br>Drive      | 20M             | -               | 2 O M           |

All PM systems use the InfoShare operating system, which offers four levels of security, as well as many other advanced features for handling business, engineering, and programming needs. Also, all of the systems can be expanded to one megabyte of main memory.

This chapter lists the unit specifications, briefly describes the main assemblies, and provides a list of technical references. The specifications are divided into five sections:

```
* Physical Specifications
```

```
* Environmental Specifications
```

```
* Power Requirements
```

```
* Memory and Storage
```

```
* Workstation Cables
```

#### PHYSICAL SPECIFICATIONS

| Height:<br>Width:<br>Depth: | 7.25 in<br>17.50 in<br>16.88 in |           |
|-----------------------------|---------------------------------|-----------|
| Weight:                     |                                 |           |
| PM/16:                      |                                 |           |
| Net:                        | 36.5 lbs                        | (18.1 kg) |
| Shipping:                   | 50.0 lbs                        |           |
| PM/4T, PM/16T:              |                                 |           |
| Net:                        | 41.5 lbs                        | (18.8 kg) |
| Shipping:                   |                                 | (24.9 kg) |

#### Expansion Board Dimensions

Expansion boards can be installed in the expansion board slots X1 and X2. The board dimensions are illustrated in Figure 1-1.

)

## Figure 1-1 Expansion Board Dimensions



Unit Overview

#### ENVIRONMENTAL SPECIFICATIONS

#### Temperature:

}

| Operating: | 15 to 35 degrees Celsius<br>59 to 95 degrees Fahrenheit |
|------------|---------------------------------------------------------|
| Non-       | -25 to 60 degrees Celsius                               |
| operating: | 13 to 140 degrees Fahrenheit                            |

#### Relative Humidity (non-condensing):

| Operating: | 20-80% |
|------------|--------|
| Transit:   | 5-95%  |

#### Heat Output:

| es  |
|-----|
|     |
| es  |
|     |
|     |
| ies |
|     |

#### Altitude:

| Operating: | 10,000 | ft. | (max) |
|------------|--------|-----|-------|
| Transit:   | 50,000 | ft. | (max) |

#### POWER REQUIREMENTS

#### AC Power:

Voltage: 115/230 Vac +/-10% Frequency: 50/60 Hz Regulation: 1% max

## ) Current (RMS):

| 115Vac | 1.50 ampere |
|--------|-------------|
|        | .75 ampere  |

Unit Overview 1.5

## **Power Consumption:**

| 115Vac | 2 | ampere |
|--------|---|--------|
| 230Vac | 1 | ampere |

## Start Current:

| 115Vac | 1.87 | ampere |
|--------|------|--------|
| 230Vac | 0.94 | ampere |

## DC Power:

PM/16:

| Voltage    | Current       | Regulation<br>(20%-100%) | Power<br>Consumption |
|------------|---------------|--------------------------|----------------------|
| +5         | 7 <b>.</b> 0a | 3% max                   | 35 watts             |
| +12        | 2.0a          | 5% max                   | 24 watts             |
| -12        | 0.5a          | 5% max                   | 6 watts              |
| +12V peak  | (300 ms)      | )                        | 6 ampere             |
| +5V cross  | s regulat:    | ion                      | l% max               |
| PM/4T and  | 3 PM/16T:     |                          |                      |
| Voltage    | Current       | Regulation<br>(20%-100%) | Power<br>Consumption |
| +5         | 12.0a         | 3% max                   | 60 watts             |
| +12        |               |                          |                      |
| <b>T12</b> | 8.0a          | 5% max                   | 96 watts             |

+5V Cross regulation (20%-100%) 1% max

#### MEMORY AND STORAGE

Main Memory:

| PM/4T, PM/16 | 64Kxl  | RAM | 256 | Kbytes |
|--------------|--------|-----|-----|--------|
| Expansion    | 64Kx1  | RAM | 512 | Kbytes |
| PM/16T       | 64Kx1  | RAM | 512 | Kbytes |
| Option       | 256Kx1 | RAM | 512 | Kbytes |
| Option       | 256Kxl | RAM | 1   | Mbyte  |

Unit Overview 1.6

## Z80A Static RAM:

)

' )

)

| All systems<br>Option<br>Option                                 |       | RAM<br>RAM<br>RAM | 64             | Kbytes<br>Kbytes<br>Kbytes |
|-----------------------------------------------------------------|-------|-------------------|----------------|----------------------------|
| Hard Disk:                                                      |       |                   |                |                            |
| PM/4T:<br>Formatted                                             |       |                   | 20 M           | lbytes                     |
| PM/16 and PM/16T<br>Formatted<br>Unformatted                    | :     |                   |                | 6 Mbytes<br>9 Mbytes       |
| Floppy Disk:                                                    |       |                   |                |                            |
| PM/16:<br>Formatted<br>Unformatted<br>TPI (tracks per :         | inch) |                   | 720<br>1<br>96 | Kbytes<br>Mbyte            |
| PM/4T and PM/16T<br>Formatted<br>Unformatted<br>TPI (tracks per |       |                   |                | Kbytes<br>Kbytes           |
| Mana Backun.                                                    |       |                   |                |                            |

#### Tape Backup:

| Formatted              | 20   | Mbytes |
|------------------------|------|--------|
| Unformatted            | 21   | Mbytes |
| Tape speed (nominal)   | 90   | ips    |
| Data density (nominal) | 7772 | bpi    |

#### WORKSTATION CABLES

## Maximum Distance Between Workstation and PM:

450 feet using shielded, twisted-pair cable.

6000 feet using Optic Data Systems ODS214/215 fiber optics modem and duplex fiber cables.

#### MAJOR ASSEMBLIES

#### Main CPU Board

The main CPU board contains the 16-bit CPU functions, 8-bit processor functions, main memory, and all interface signals going to the connectors and the floppy disk.

#### Winchester Disk Controller Board

The controller board controls the internal hard disk drive.

ſ

#### Hard Disk Assembly

PM/16 and PM/16T:

The hard disk is a random-access Winchester assembly with eight recording surfaces and a 44.5 megabyte storage capacity.

#### PM/4T:

The hard disk is a random-access Winchester assembly with four recording surfaces and a 20 megabyte storage capacity.

#### Unit Overview 1.8

#### **Floppy Disk Assembly**

#### PM/16:

The floppy disk drive is a 5 1/4-inch quaddensity, double-sided assembly with a 720 Kbyte capacity. This 96 TPI drive has read/write capabilities but the write function is not software supported. This drive is used to up-load the system. The drive can load programs recorded at 48 TPI in PC-DOS format.

PM/4T and PM/16T: The floppy disk drive is a 5 1/4-inch double-density, double-sided assembly with a 320 Kbyte capacity. This 48 TPI drive is a logical (read and write) drive for PC-DOS formatted diskettes.

#### Interface

The interface is made up of twenty-one interface connectors located on the main CPU board, back panel, front panel, and tape controller board.

#### Tape Backup:

The tape backup drive has an intelligent interface allowing it to directly access main memory. The intelligent tape adaptor is installed in one of the expansion slots and controls the Streaming Tape Drive through a standard QIC-02 intelligent interface board.

#### TECHNICAL REFERENCES

The following publications contain technical data related to the Personal Mini:

 \* Intel Microprocessor and Peripheral Handbook (Intel) )

- \* Zilog Data Book (Zilog)
- MOS Microprocessor Data Manual (Signetics)
- \* Synertek Data Catalog (Synertek)
- \* Storage Management Products Handbook (Western Digital)

#### 2. HARDWARE FUNCTIONS

The Personal Mini contains two processors: an Intel 80186 to handle the 16-bit operations, and a Zilog Z80A to handle the 8-bit operations. Both have access to main memory.

The system architecture is designed so that the two processors remain isolated in normal operation with main memory and the interrupts as their only link.

This chapter describes the functions of the unit. The functions described are the 80186 CPU, main memory, Winchester disk controller, Z80A, and tape backup. Figure 2-1 shows the functional block diagram of the unit.

#### 80186 CPU FUNCTIONS

)

The 80186 CPU (see Figure 2-2) is a 16-bit microprocessor that controls the 16-bit interfaces, system interrupts, and EPROM. The 80186 has sixteen data lines, twenty address lines, and an 8 MHz system clock that is developed from a 16 MHz crystal. The following main board 16-bit interfaces are controlled by the 80186.

- \* DUART - console and serial printer ports
- Parallel printer port \*
- Floppy disk controller Hard disk interface \*
- \*

THIS PAGE WAS INTENTIONALLY LEFT BLANK.

Hardware Functions 2.2

# Figure 2-1 System Functions



Hardware Functions 2.3



5

#### DUART (Console and Serial Printer)

The 2681 DUART (see Figure 2-3) controls both the system console port and the serial printer port. This device has programmable, internal baud rate generators derived from a 3.6864 MHz crystal, and provides handshaking signals on the general purpose IPO-IP6 input lines and the general purpose OPO-OP7 output lines.

)

The DUART has two DCE serial RS-232C I/O channels with channel A as the system console port and channel B as the serial printer port. The channels can be reconfigured to a DTE port by the installation of a special cable. They can also be converted for reverse channel protocol by changing the Ell and El5 jumpers (see Appendix A).

The system console port is the system service port that provides keyboard input.

The serial printer port can be configured by the jumpers for two functions. The default configuration sets it as a serial printer port but it can be changed to allow use by a diagnostics console (see Appendix A). This allows access to the Z80A independent of the 80186 CPU operations. This function is not software supported.

#### PARALLEL PRINTER PORT

The parallel printer port (see Figure 2-4) allows for the use of a parallel data input printer. This section is made up of a parallel printer and interrupt latch (U50), printer data latch (U61), and printer control and diagnostics latch (U56).

#### Hardware Functions 2.6

Figure 2-3 DUART



## Pigure 2-**4** Parallel Printer Port



Hardware Functions 2.8

The parallel printer and interrupt latch receives control signals from the parallel printer and four interrupt signals. These interrupt signals are the INT Z TO 186, -INT X1 TO 186, -INT X2 TO 186, and a software programmable PPRNT INT signal that is not used in the default configuration. Data bits DO-D7 are passed by the latch to the 80186 data bus.

The printer control and diagnostics latch strobes parallel data to the printer and controls the 80186 diagnostic LED's. This latch provides the parallel printer control signals. The most important is the -STROBE signal which strobes the parallel data bits to the printer.

#### FLOPPY DISK CONTROLLER

The floppy disk controller is a Western Digital WD1770 (see Figure 2-5). It contains internal registers to accept highlevel commands from the 80186. The controller interface to the 80186 consists of an 8-bit, bidirectional, data access bus for the transfer of status, data, and commands. All 80186 communication with the drive occurs through these lines. The controller contains an internal digital data separator, digital phase lock loop circuit, and write precompensation.

The drive select buffer (Ull2) controls floppy disk drive selection, motor on, and side selection.





#### HARD DISK INTERFACE

The hard disk interface (see Figure 2-6) includes the Winchester disk controller Board, which is discussed later in this chapter. The interface provides data and control lines from the 80186 to the WDC board.

The hard disk data buffer (U53) holds data for transfer to the WDC board or the 80186.

The control buffer (U54) transfers the control signals to the WDC board.

#### SYSTEM INTERRUPTS

The 80186 has four interrupt inputs: INT 0, INT 1, INT 2, and INT 3. All interrupts are maskable and are prioritized. The interrupts are described according to their priority with the highest priority listed first.

**INT 0** is the DUART interrupt. It is activated when either the system console or serial printer has completed a command function and is ready for another command.

**INT 1** receives one of four interrupts on this input. They are PPRNT INT, INT Z TO 186, -INT X1 TO 186, and -INT X2 TO 186. When this interrupt input is active, the 80186 polls the Parallel Printer and Interrupt Latch (U50) to find out which interrupt is active. This latch also holds error signals from the parallel printer.

**INT 2** is the hard disk controller interrupt. It is activated to let the 80186 know that the previous command has been completed. Figure 2-6 Hard Disk Interface



**INT 3** is the floppy disk interrupt. The drive activates the signal to inform the 80186 CPU that the previous command has been completed and that a new drive command can be issued.

#### MAIN MEMORY

Main memory (see Figure 2-7) is a two-port memory that is equally addressable by the 80186 and the Z80A. The intelligent interface tape backup can also directly access main memory on the 8-bit bus but does not have access to the memory mappers. The 80186 and Z80A can both access up to one megabyte of memory. The main memory contains a memory MUX, memory controller, and memory banks.

#### Memory MUX

The memory MUX (U9) is an R-S flip-flop that enables either the 80186 or Z80A to address main memory. The MUX is set or reset by the memory controller (U96) MUX/PCLK signal.

#### Memory Controller

The 8207 memory controller is configured as a dual-port controller. Port A holds the 80186 CPU address lines and port B holds the Z80A address lines. The controller arbitrates the processor requests and directs data to or from the appropriate port. A priority system reassigns priorities based on past history. Requests are internally queued. Figure 2-7 Main Memory Section



The memory controller limits the number of functions performed by main memory at any time to one event. The controller may be addressing for the Z80A or the 80186, or performing a refresh cycle.

At power-up, parallel data bits from the parallel data register (U144 & U145) are sent to the PDI input. This input programs the controller's jumper selectable options.

Refresh requests are generated internally for the dynamic RAM's. This frees the processors from this function. The controller provides RAS (row) and CAS (column) signals for each of four possible memory banks allowing it to access one megabyte of memory.

The memory-locking feature gives each processor uninterrupted access to a portion of the memory. This allows one processor to complete its data processing before the other processor can access that area.

## Memory Banks

)

If the system contains a memory expansion board, the memory controller divides the memory into four banks. The main memory contains 64Kxl dynamic RAM chips to provide 256 Kbytes of main memory. The memory expansion board provides another 256 Kbytes of memory expanding it to 512 Kbytes. The 256 kbyte configuration is basic for the PM/4T and PM/16 units, and the 512 Kbyte configuration is basic for the PM/16T unit. Another option is the use of 256Kxl dynamic RAM chips to provide either 512 Kbytes or 1 Mbyte of main memory. Each bank has its own RAS (row) and CAS (column) lines to strobe the address. The RAS and CAS are selected by the decoding of the program bits RB1 and RB2, and bank input bits BS0 and BS1. Twenty address lines are required to address one megabyte of memory.

The signals from the high and low byte write enable are decoded by the Write Enable Decoder (U49).

#### WINCHESTER DISK CONTROLLER

The Winchester disk controller board (see Figure 2-8) provides the main controller function for the Winchester disk drive(s).

The WD controller (U23) can handle up to four disk drives and provides all control and data handling functions needed to interface the system with a disk drive.

The controller interfaces the host through a bi-directional transceiver (U27), which is controlled at its DIR input by the 80186. The data bus goes to the controller (U23), buffer RAM Controller (U24), and static RAM (U25).

The static RAM is controlled by the RAM buffer controller and stores one sector of read or write data.

The RAM buffer controller controls the RAM sector data and the head and drive select lines. It also controls the interface between the static RAM and the controller.





Hardware Functions 2.17

)

The write precompensator/data separator (U16) provides the write precompensation logic and data separator control logic that sends a synthesized read clock and read data to the controller.

The controller board receives commands from the 80186 CPU, initiates the commands, and sends status signals to the CPU.

During a read operation, composite read data (serial) is received by the differential line receiver (U3) from the hard disk. This data is passed to the buffer RAM Controller.

During a write operation, data is sent from the write precompensator/data separator to the precompensator, and then to the differential line transmitter (U4) for transmittal to the hard disk.

#### 8-BIT NETWORKING FUNCTIONS

The 280A 8-bit processor (see Figure 2-9) controls the 8-bit functions that include networking, expansion cards, and 8-bit diagnostics. The processor runs on a 4 MHz clock generated by the clock generator (U7) from the CPU CLKOUT BF signal. The processor has eight data lines and sixteen address lines. The functional areas of the processor are local memory, memory mapping, SIO and work stations, CTC, and expansion slots. Figure 2-9 280A 8-Bit Section



#### Local Memory

The local memory (see Figure 2-10) has a 4kbyte EPROM and 4 Kbytes of static RAM, expandable to 16 Kbytes. The EPROM performs the 8-bit initialization and diagnostics. The static memory polls the workstations for a service request since interrupts are not used for the workstations.

)

# Memory Mapping

The Z80A has sixteen address lines which allow it to access up to 64 Kbytes of memory. The PM can have up to 1 Mbyte of memory. This means that, in order to access 1 Mbyte of memory, twenty address lines are needed. Address bus bits 0-11 go to the memory controller while bus bits 12-15 go to the memory mapping RAM's (U94 and U97), which are decoded into eight address lines (bus bits 12-19). These eight address lines go to the memory controller to produce a 20-bit address bus.

## Serial I/O And Workstations

The Serial I/O (SIO) contains two RS-422 ports with port A as the workstation port and port B as the daisy-chain network port. Port B also allows for direct access to the 280A by a diagnostic console. A jumper configuration change (see Appendix A) is required for this. The SIO 800 KHz baud rate is generated by the clock generator (U7) which also generates the 800 KHz receive clock to the workstations. Figure 2-10 Local Memory



Port A sends out the TXDA signal to select the one workstation out of the possible sixteen that is latched in the user ID and diagnostics latch (U105). This latch output is also used for diagnostics at power-up. When the diagnostics have been completed, it latches the binary-coded user select address. The ZLK MEM line locks the memory area that the Z80A is using. This allows the processor to complete its operation before the memory area is accessed. The INHIBIT BUS RO signal is used to establish the priority of the expansion cards or the workstations. The -Z PROM OFF signal allows the EPROM memory area to be masked off.

)

#### Counter-Timer Circuit

The CTC (Counter-Timer Circuit) is a four channel device of which only three are currently being used. The CTC is used as an interrupt controller to control and prioritize the following interrupts, which are listed from the highest to lowest in priority:

-INT 186 TO Z -INT X1 TO Z -INT X2 TO Z

In response to an interrupt signal, the CTC issues an interrupt to the Z80A CPU, which in turn interrupts the 80186. The 80186 determines the source of the interrupt by reading the internal registers of the CTC.

# **Expansion Slots**

There are two expansion card slots mounted on the main board. Slots X1 (P8) and X2 (P7) are used for system expansion including the intelligent interface tape backup. An expansion card may contain its own DMA controller for direct access to main memory. The expansion card must be 8-bit to access the 8-bit Z80A bus. On power-up, the processor checks bits 1 and 2 of the buffer (U62) to determine if the slots are occupied. For more information on the expansion slots, refer to Chapter 3.

#### TAPE BACKUP

)

The tape backup (see Figure 2-11) has an intelligent interface that can access the main memory on the 8-bit processor bus. The tape expansion board can be installed in either the X1 or X2 expansion slot but there are jumper requirements (see Appendix A). The tape backup has a storage capacity of 20 Mbytes. The tape expansion board has a DMA and a processor control section.

The local memory is made up of 8 Kbytes of EPROM with a 4 kbyte option, and 4 Kbytes of static RAM with an 8-kbyte or 16-kbyte option.

#### Tape Operation

The 80186 moves data from the hard disk to main memory on the main board. This occurs during the CPU operating cycle. Figure 2-11 Tape Backup



)

}

The DMA requests the 8-bit data bus from the two processors on the main board, and when acknowledged, accesses the bus. All 8-bit functions occur during the Z80A operating cycle. The DMA fetches the data memory address and moves the data to the local static RAM. The DMA continues this process to keep the RAM full as long as there is data in main memory for the tape backup.

)

The Z80A on the tape expansion board provides the local intelligence to access the main memory and communicate with the 80186 microprocessor. It controls the tape drive interface and runs on a 4-MHz clock. The processor moves data from the static RAM to the tape drive in the streaming mode.

The DMA and processor run concurrent operations to keep the RAM buffer full to maintain the streaming of the tape.

#### 3. HARDWARE PROGRAMMING

This chapter provides the programmer with the information necessary to interface with the system hardware. Included in the chapter are discussions on I/O port addresses, coding tables, command codes, and registers for the 80186, Z80A, and the tape expansion card.

#### 80186 MICROPROCESSOR

The 80186 is a 16-bit internal and external HMOS microprocessor device with a 20-bit address bus. The 80186 performs all DMA transfers to the floppy and hard disk drives, and handles interrupts from the 280A 8-bit processor and from peripheral devices. This microprocessor is also responsible for performing diagnostics on the 16-bit side of the system at system initialization. For complete information on the 80186, refer to the Intel iAPX 86/88, 186/188 User's Manual.

#### 80186 Interrupts

The interrupt lines INTO through INT3 on the 80186 provide four prioritized levels of interrupts to service hardware requirements, with INTO having the highest priority. The interrupt levels are shown in Table 3-1. To properly service interrupts, the system software must program the interrupt control registers of the 80186 into the fully-nested mode (non-cascade, non-iRMX operation). All interrupts are maskable.

Interrupts from the 80186 are applied on a SETI line to the reset pin of a set-reset flip-flop. The acknowledgement from the Z80A 8-bit side or from an expansion card returns the flip-flop to the set state. A system reset also places the flip-flop into the set state.

Table 3-1

80186 Interrupt Priorities

| Level | Input | Device                                                                                             |
|-------|-------|----------------------------------------------------------------------------------------------------|
| 0     | INTO  | Serial printer or console port.                                                                    |
| 1     | INTl  | Parallel printer, Z80<br>microprocessor,<br>expansion card slot 1,<br>or expansion card slot<br>2. |
| 2     | INT2  | Winchester hard disk<br>controller board.                                                          |
| 3     | INT3  | Floppy disk controller board.                                                                      |

To determine which device is sending an interrupt on INT1, the 80186 polls bits 4 through 7 of the parallel printer and interrupt status buffer at address %0120. Refer to Figure 3-1 for the bit assignments to the buffer. )

Figure 3-1 Parallel Printer and Status Buffer (\$0120)Bit 6 5 4 7 L L 1 I L 1 0 = Parallel printer interrupt ł 1 1 = Normal input I 1 L 1 I 0 = Normal input I 1 1 = 280 interrupt L 0 = Normal input 1 = Expansion card slot 1 I I interrupt L 0 = Normal input 1 = Expansion card slot 2 interrupt

# 80186 Read-Only Memory

Standard read-only memory for the 80186 processor is organized as 4K x 16 bits in two chips, optionally expandable to 8K x 16 bits. Standard ROM is located in address space %FE000 through %FFFFF. The size of the ROM is contained in the firmware itself, thus eliminating the need to change jumpers or switch settings with a change in ROM.

The UCS pin of the 80186 decodes the memory address of the ROM devices. After system reset, the UMCS register must be initialized to the ROM block size and programmed with one wait for the ROM devices.

## 80186 I/O Port Selection

System I/O port selection is performed through the six peripheral chip select lines PCS0 through PCS5 of the 80186. The lines are controlled through the PACS register and the MPCS register. These registers set the programmable base address (PBA) of the peripherals and specify whether the peripherals are mapped into memory or I/O space. Both registers must be accessed to activate the peripheral chip select lines.

The PACS register defines the starting address of the peripheral chip select block. Refer to Table 3-2 for the bit assignments to the register.

## Table 3-2 PACS Register

| Bits   | Function                                                                                                                     |
|--------|------------------------------------------------------------------------------------------------------------------------------|
| 15 - 6 | Correspond to bits 19 through 10<br>of the 20-bit programmable base<br>address (PBA) of the peripheral<br>chip-select block. |
| 5 - 3  | Set to 1.                                                                                                                    |
| 2 - 0  | Specify the READY mode and the wait states, and are encoded as follows:                                                      |
|        | Bits<br>2 1 0<br>0 0 0 = Zero wait states,<br>external RDY also used.                                                        |
|        |                                                                                                                              |

3.4

)

#### Table 3-2 continued Function Bits 2 - 0Bits 2 1 0 n 1 0 = Two wait states inserted, external RDY also used. 1 = Three wait states 1 0 inserted, external RDY also used. 0 = Zero wait states, 1 0 external RDY ignored. 0 1 = One wait state 1 inserted, external RDY ignored. 1 0 = Two wait states1 inserted, external RDY ignored. 1 1 1 = Three wait states inserted, external RDY ignored.

Table 3-3 shows the address range of each peripheral chip select with respect to the PBA contained in the PACS register.

# Table 3-3 PCS Address Ranges

)

| PCS Line | Active Between Locations |
|----------|--------------------------|
| PCS0     | PBA - PBA+127            |
| PCS1     | PBA+128 - PBA+255        |
| PCS2     | PBA+256 - PBA+383        |
| PCS3     | PBA+384 - PBA+511        |
| PCS4     | PBA+512 - PBA+639        |
| PCS5     | PBA+640 - PBA+767        |

The MPCS register controls the mode of operation for the peripheral chip select lines. Refer to Table 3-4 for the bit assignments. Bit 6 of this register determines whether the selects are mapped into memory or I/O space. A one for this bit maps the peripherals into memory space. A zero maps the peripherals into I/O space.

## Table 3-4 MPCS Register

Bits Function

15 Set to 1.

14 - 8 Define the size of the memory block. Only one bit can be set at a time.

| Bits    | Total<br>Block | Individual<br>Select |
|---------|----------------|----------------------|
| 14 - 8  | Size           | Size                 |
| 0000001 | 8K             | 2K                   |
| 0000010 | 16K            | 4K                   |
| 0000100 | 32K            | 8K                   |
| 0001000 | 64K            | 16K                  |
| 0010000 | 128K           | 3 2 K                |
| 0100000 | 256K           | 64K                  |
| 1000000 | 512K           | 128K                 |

7 Set to 1.

6 If 0, the peripherals are mapped into memory space. If 1, the periherals are mapped into I/O space. 

#### Table 3-4 continued

#### Bits Function

- 5 3 Set to 1.
- 2 0 Specify the READY mode. Refer to Table 3-3 for the coding.

The I/O port addresses for the 16-bit processor are listed in Table 3-5. The port addresses assume that the programmable base address of the PACS register is zero, that the relocation register is in the default %20FF, and that the ports are I/O mapped. This arrangement assures that the I/O space for the internal control register block is located outside of the low order address space.

Table 3-5 80186 I/O Port Addresses

Address

1

Function

| \$0000               | Printer Control/Diagnostic |
|----------------------|----------------------------|
|                      | Indicators Latch Select    |
| 80004                | Reset FDC                  |
| <b>%0008</b>         | Release FDC Reset          |
| \$000C               | Reset HDC                  |
| \$0010               | Release HDC Reset          |
| 80014                | Reset Z80                  |
| \$0018               | Release Z80 Reset          |
| <b>%0020</b>         | Printer Data Latch Select  |
| <b>%0040</b>         | Floppy Disk Drive Control  |
|                      | Latch                      |
| <b>%0060</b>         | Printer Interrupt          |
|                      | Acknowledge                |
| <b>%0080 - %009E</b> | DUART Device Registers     |

# Table 3-5 continued

| Address              | Function                                                  |
|----------------------|-----------------------------------------------------------|
| <b>%0120</b>         | Parallel Printer and<br>Interrupt Status Buffer<br>Select |
| <b>%0180 - %018E</b> | Floppy Disk Controller<br>Device Registers                |
| <b>%0200 - %020E</b> |                                                           |
| <b>%0280</b>         | Spare 6                                                   |
| 80290                | Spare 7                                                   |
| %02A0                | Set Interrupt 80186 to Z80                                |
| \$02B0               | Set Interrupt 80186 to<br>Expansion Card 1                |
| <b>%</b> 02C0        | Set Interrupt 80186 to                                    |
| %02D0                | Expansion Card 2<br>Interrupt Acknowledge 80186<br>to 280 |
| <b>%02E0</b>         | Interrupt Acknowledge 80186<br>to Expansion Card 1        |
| <b>%02F0</b>         | Interrupt Acknowledge 80186<br>to Expansion Card 2        |
| %FF00 - %FFFE        | 80186 Internal Registers                                  |

#### **Z80 MICROPROCESSOR**

The task of interfacing with the workstations is performed by the 8-bit side of the motherboard with a Z80A CPU running at 4 MHz.

## **280 Interrupts**

Interrupts from the Z80A SIO and Z80A CTC are daisy-chained to the Z80A CPU, with the SIO device having the highest priority. Other interrupts are generated at timer inputs 1 through 3 of the CTC. These interrupts are listed in Table 3-6.

3.8

## Table 3-6 280A Interrupts

Timer

Channel Function

| 1 | Interrupt from 80186 to Z80A CPU               |
|---|------------------------------------------------|
| 2 | Interrupt from expansion slot 1<br>to Z80A     |
| 3 | Interrupt from expansion slot 2<br>to Z80A CPU |

The timer channel is loaded with a count of l; an incoming interrupt decrements this count to 0 to generate a CTC interrupt. The expansion cards can also directly interrupt the 80186, as previously described in Table 3-3. Interrupt acknowledge signals to these devices are sent through the Z80A CPU I/O ports at the addresses listed in Table 3-7.

Interrupts are sent from the Z80A CPU to the 80186 through the Z80A CPU port address %06.

# **Z80 Read-Only Memory**

The 8-bit processor ROM occupies the lower 4 Kbytes of Z80A CPU address space from %0000 through %0FFF. The section also has a local RAM area in the upper Z80A CPU space from %F000 through %FFFF.

Standard local memory is expandable with one or two 8K x 8 static RAM devices to begin local RAM at %E000 or %C000.

# Z80A I/O Ports

Table 3-7 lists the I/O port addresses for the 8-bit processor section.

## Table 3-7 280A I/O Port Addresses

| Address          | Function                                              |
|------------------|-------------------------------------------------------|
| 800              | Interrupt Acknowledge Z80A<br>CPU to 80186            |
| <b>%02</b>       | Interrupt Acknowledge Z80A<br>CPU to Expansion Slot 1 |
| 804              | Interrupt Acknowledge Z80A<br>CPU to Expansion Slot 2 |
| 806              | Interrupt Z80A CPU to 80186                           |
| 808              | Configure Z80A Buffer Select                          |
| 80A              | Spare 5                                               |
| 80C              | Set User ID and Misc. Latch<br>Enable                 |
| <b>%0E</b>       | Set Memory Map Enable                                 |
| 810 - 813        | Z80A CTC Internal Registers                           |
| <b>%20 - %23</b> | Z80A SIO Internal Registers                           |
| <b>%60 - %FF</b> | Expansion Card I/O                                    |

The first four bits of the set user ID and misc latch at address %0C select one of the sixteen workstation channels for input. The latch is sequenced as follows:

| Bit 3 | Bit 2 | Bit l | Bit O | User No. |
|-------|-------|-------|-------|----------|
| 0     | 0     | 0     | 0     | 1        |
| 0     | 0     | 0     | 1     | 2        |
| 0     | 0     | 1     | 0     | 3        |
| 0     | 0     | 1     | 1     | 4        |

)

This continues in binary sequence up to workstation sixteen:

Bit 3 Bit 2 Bit 1 Bit 0 User No. 1 1 1 1 1 16

Bits 0 through 3 of this latch are also used to light the diagnostic LED indicators 1 through 4. These indicators are lit when the bits are low.

The functions of bits 4 through 7 of the latch are listed in Table 3-8.

# Table 3-8 Set User ID and Misc Latch (%OC)

#### Bit Function

4

)

)

- Network Transmit Enable Enables transmission on the RS-422 network channel to allow communications between multiple PM systems.
- 5 8-Bit Processor Main Memory Locking - activates the main memory locking feature of the 16bit processor section.
- 6 Inhibit Bus Request Inhibits a bus request from an expansion card when the cards and the Z80A CPU simultaneously request the section data and address busses.

7 Disable 8-Bit Processor ROM -Frees the address space normally used by the ROM for memory mapping. When writing to a portion of this latch, care must be taken to preserve the remaining bit values. The configure Z80A buffer select is read at address %08. The bit assignments for the buffer are listed in Figure 3-2. Figure 3-2 Configure Z80A Buffer Select (\$08)Bits 7 6 5 4 3 2 1 0 
 I
 I
 I
 I

 I
 I
 I
 I
 = Normal operation

 I
 I
 I
 = No expansion card in

 I
 I
 I
 slot 1
 1 L 1 1 1 L I. 1 II0= Expansion cardII0= Expansion cardII1= No expansion card in 1 1 F 1 1 slot 2 1 0 = Expansion card presentin slot 2 I I 1 1 1 Spare for expansion cards 1 1 Spare for expansion cards Spare for expansion cards Spare for expansion cards Not used

## **Z80A** Processor Section Reset

The 8-bit processor section is reset at 80186 I/O port address %0014. This reset includes the expansion card slots. After reset, the 8-bit processor section must be software released at 80186 I/O port address %0018 to begin operation. After release, the Z80A CPU executes a self-diagnostic test as described in Appendix C.

## Hardware Programming

)

## MAIN MEMORY

)

Main memory is contained in 64K x 1 dynamic RAM devices. Standard memory is 256 Kbytes, expandable to 512 Kbytes with an add-on board, and to 1 Mbyte with 256K x 1 dynamic RAM devices. This area can be accessed by either the 16-bit processor or the 8-bit processor sections under control of the dual port RAM controller. When the 8-bit section, including an 8-bit expansion card, accesses main memory, the 20-bit address for the controller is produced through a mapper in the 8-bit section. Generation of this mapped address is described later in this section.

## Dual Port RAM Controller

Main memory is controlled through an Intel 8207 Advanced Dynamic RAM Controller device. This device provides independent access to main memory by each processor section on a last-access-served-first priority scheme. The 8207 generates all control signals for memory, including programmable refresh and data transfer acknowledge. A detailed description of the 8207 is contained in the Intel Microsystem Components Handbook, Volume I.

Port A of the 8207 is connected to the 16bit processor. This port runs in the slowcycle, synchronous, status interface mode of the controller. There are no wait states for a normal memory access with 150 nanosecond RAM devices. Port B of the 8207 services the 8-bit processor and expansion card bus. Port B runs in the slow-cycle, asynchronous, command interface mode of the controller. One wait state is required for a normal memory read and two wait states for an normal memory write.

If one port attempts to access the memory while the other port is active, the port attempting the access must wait from 1 to 5 wait states for 80186 memory cycles (125 nanoseconds/wait), or 3 to 5 wait states for Z80A memory cycles (250 nanoseconds/wait). Longer wait states are necessary if the controller is refreshing memory during a simultaneous request.

Address lines from each processor are multiplexed to a single set of lines for the 8207. Address bit 0 selects the high or low byte during the access along with high byte enable lines -BHE for the 80186, or -ZRBH for the Z80A. Jumper options finalize the memory selection, as described under Memory Organization below.

The 8207 is programmed through a hardware initialization shift register during system reset. Table 3-9 lists these default states. )

)

; )

. )

Table 3-9 Default Initialization of the Memory Controller

| Bit    | Set/Function                      |
|--------|-----------------------------------|
| 0      | Low. Non-ECC mode.                |
| 1      | Low. Port A set asynchronous.     |
|        | Low. Port B set synchronous.      |
| 2<br>3 | High. Slow cycle iAPX 86 mode.    |
| 4      | High. Slow (150 nanoseconds)      |
|        | RAM.                              |
| 5/6    | Low. RAS and CAS to banks as      |
|        | selected by bank select inputs to |
|        | memory controller:                |
|        | (BS1) (BS0) Utilization           |
|        | 0 0 RASO/CASO to Bank 0           |
|        | 0 1 RAS1/CAS1 to Bank 1           |
|        | 1 0 RAS2/CAS2 to Bank 2           |
|        | 1 1 RAS3/CAS3 to Bank 3           |
| 7/8/9  | Low. One refresh each 15.6        |
|        | microseconds, no frequency        |
|        | deviation. Optionally, bit 9 is   |
|        | tied high to give one refresh     |
|        | every 7.8 microseconds with no    |
|        | frequency deviation for some 256K |
|        | RAM devices. Jumpers are          |
|        | required as listed in Appendix B. |
| 10     | Low. Memory cycle is not          |
|        | extended.                         |
| 11     | Low. Fast (8 MHz) 80186 clock.    |
| 12     | Low. In priority contention, the  |
|        | most-recently used port is        |
| 10     | selected.                         |
| 13     | Low. Test mode is not selected.   |
| 14/15  | Low. Reserved.                    |

## **Memory Organization**

Main memory occupies the address space from %00000 through %3FFFF in the standard 256 Kbyte memory version, from %00000 through %7FFFF in the 512 Kbyte option version, and from %00000 through the lower boundary of system ROM in the 1 megabyte system. With standard 8 Kbyte ROM, this boundary is at %FE000. When changed, the new size of ROM and the number of wait states must be programmed into the UMCS register of the 80186.

Referring to Table 3-9, bits 5 and 6 of the initialization register set up the bank interleaving feature of the 8207. Interleaving overlaps the start of the next RAM access cycle with the RAM precharge period of the previous cycle. This feature optimizes memory bandwidth for the PM system.

For systems with 256 Kbytes of memory, banks 0 and 1 are selected using address line Rl to input BS0 of the 8207. For 512 Kbyte memories made up of 64 Kbyte devices, address lines Rl and Rl8 are tied to controller inputs BS0 and BS1, with all four banks of memory selected. When 256 Kbyte devices are used, only bank 0 is selected with no bank interleaving. The 1 megabyte memory uses interleaving in banks 0 and 1 with the address lines utilized as for the 256 Kbyte configuration. Physical selection of these memory configurations is accomplished with jumper options as listed in Appendix B.

Some 256 Kbyte dynamic RAM devices require a refresh every 7.8 microseconds, accomplished by setting the PD9 bit of the 8207 high as listed in Table 3-9.

## Memory Locking

)

A memory-locking feature of the 8207 prevents access to a portion of memory by either processor section. This feature may be used to allow one side to complete processing a block of data before allowing the other section to access the area. The lock feature is multiplexed between the two processor sections; when port A (80186) is selected, the lock feature originates at port A, and when port B (Z80A CPU) is selected, the lock originates at port B.

To use the lock feature, the 80186 must execute a lock prefix instruction and assert the -LOCK line to the 8207. When the Z80A asserts a lock, it writes a 1 to bit 5 of the set user ID latch on the 8-bit side, which is transferred through an address buffer to the lock input of the 8207. Refer to the schematic diagrams and to the 8-bit I/O port listing in Table 3-7. Expansion cards may use lock in a similar manner to the Z80A.

### **Z80A CPU Main Memory Mapping**

Memory mapping, using two high-speed bipolar RAM devices, is used to translate the 16-bit Z80A CPU address into a 20-bit address for main memory. The upper four address bits, on lines ZA15 through ZA12, address the mapper RAM to produce main memory upper address lines SA19 through SA12. The lower Z80A CPU address lines, ZA11 through ZA0 address main memory as SA11 through SA0. Using memory mapping, any 4 Kbyte segment of main memory can be addressed by loading the upper eight bits of its address into the mapper RAM. Using the four address bits to mapper RAM, up to sixteen such segments can be stored for mapping. For example, if the Z80A CPU wishes to address the 4 Kbyte area from %2E000 through %2EFFF of main memory, it loads the value %2E into mapper RAM. If the mapper RAM location chosen for this segment is the one addressed, the upper four address bits would be:

| ZA15 | ZA14 | ZA13 | ZA12 |
|------|------|------|------|
| 0    | 0    | 1    | 1    |

Then the Z80A CPU would produce \$3000 through \$3FFF to access \$2E000 through \$2EFFF. Any other mapper RAM location could have been chosen to map this address, with a corresponding change in the Z80A CPU address to mapper RAM.

Due to possible conflicts between 8-bit processor ROM, local memory, and mapper RAM, several cautions must be observed with mapped addresses:

- The area between %0000 and %0FFF must not be used unless the 8-bit processor ROM is mapped off.
- \* The area between %C000 and %FFFF must not be used if the local RAM consists of two 8K x 8 devices.
- \* The area between %E000 and %FFFF must not be used if the local RAM consists of one 8K x 8 device.

\* The area between %F000 and %FFFF must never be used because it is always occupied by local RAM and cannot be mapped off.

The system determines the areas of 8-bit processor ROM and local memory during power-up and reset, and automatically inhibits mapper RAM access.

Mapper RAM is located at 280A CPU I/O port %2E. Load the mapper address into bits 4 through 7 of register B of the 280A CPU, using bits 12 through 15 for the address. Next, put the map data out using register A, address %2E. Because the RAM devices invert the data, the data to be written must be in complemented form.

#### **EXPANSION CARD SLOTS**

The PM system can accommodate two 8-bit or 16-bit expansion cards in the x1 and x2 slots on the main board. The expansion cards can be intelligent or slave to the 280A microprocessor.

A slave expansion card decodes its address and responds with -XIORQ and -XRD for a read request, and -XIORQ and -XWR for a write request. Hardware timing must conform to the Z80A family timing, with an extra delay due to card buffers. If the card requires wait states, the expansion card must assert the signal -XZ WAIT. There are no provisions for slave expansion card DMA; however, an expansion card can contain its own DMA controller for independent operations. Refer to Table 3-7 for the expansion card I/O port assignments. Only intelligent cards can access main memory. The data bus for the expansion cards is either 8-bit on lines XD7 through XD0, or 16-bit on lines XD15 through XD0. To use a 16-bit data bus, the expansion card sets the XBYTE line low; the default assumes an 8-bit data bus.

If a 16-bit address is provided to main memory from an expansion card, it uses the address bus from the 8-bit processor section through its own lines XZA15 through XZA0 and the memory mapper by setting the XUSEMAP line high. If the expansion card provides a 20-bit address, it accesses main memory on lines XSA19 through XSA12, and lines XZA11 through XZA0. Use of the memory map is assumed; if the expansion card provides a 20-bit address to main memory, it must disable the map by setting its XUSEMAP signal low.

Because some data and address bus lines, and control lines -ZMREQ, -ZIORQ, -ZRD, and -ZWR, are shared by the Z80A CPU and the expansion card, the card must request the buses from the Z80A CPU before each operation. The Z80A CPU can override this request by setting bit 6 of the set user ID and miscellaneous latch low.

To use the buses, the expansion card sets its line -INT X TO Z low and waits for the -BUS AK return signal from the Z80A CPU. Expansion slot 1 has the higher priority, by virtue of its daisy-chained position. Expansion card devices do not have to be in the Z80A family, but the Z80A rules for bus request and acknowledge must be observed. An expansion card can use the lock feature of the 16-bit processor section in the same manner as the 8-bit processor section. The expansion card lock signal is -XLOCK.

Hardware Programming

# System Facilities for Expansion Cards

After power-on or reset, and its selfdiagnostics, the Z80A CPU checks bits 1 and 2 of the configure Z80A buffer to determine if expansion cards are installed (refer to Figure 3-2). These bits are generated on the expansion card, and are active low to indicate card presence. Next, the CPU reads a configuration port on the expansion card to determine the card's identification. This port is intended to be configured in a DIP switch or with jumpers, and is read as an I/O port. Bits 3 through 6 of the configure Z80A buffer are available for general purpose signals. These signals must be of the open-collector type.

Timer channels 0 and 1 of the 80186 are directly useable by the expansion cards. These channels are clocked at 1.6 MHz.

#### PARALLEL PORT

)

The parallel port has three ports for data transfer and control. Table 3-10 and Figures 3-3 and 3-4 give their addresses and bit assignments. **Table 3-10** Data Output Port (\$0020)Bit Signal Pin Num. 2 0 Data 0 3 4 1 Data 1 234567 Data 2 5 6 Data 3 Data 4 7 Data 5 8 Data 6 9 Data 7 Figure 3-3 Control Signal Input Port (\$0120)10 15 12 13 11 Pin 2 1 3 0 Bit 4 L E I - E T 0 = Printer not busy, sendI 1 1 t data L 1 = Printer busy, do not 1 I send data L 1 I 0 = Printer not on line1 1 = Printer on line 1 1 1 0 = Printer has paper L 1 1 = Printer out of paper 1 1 0 = Printer error1 1 = Printer normal L 0 = Acknowledge pulse 1 = Normal input

Figure 3-4 Output Control Port (\$0000) Pin 10 17 16 14 1 Bit 3 2 1 0 4 1 L 1 1 ł 1 0 = Normal setting  $1 = Pulse bit to \tilde{1} to$ ١ 1 send data to the I Ł printer I I 1 1 1 0 = Normal settingI 1 = Auto line feed after I I 1 carriage return ł 0 = Pulse bit must be set low for I 1 at least 50 microseconds to L L initialize the printer 1 1 1 = Normal setting 1 0 = Normal setting L 1 = Allows printer to read output 0 = Printer interrupt disabled 1 = INT1 interrupt enabled on printer acknowledge signal pulse

#### SERIAL AND SYSTEM CONSOLE PORTS

The serial port and the system console port are controlled through the DUART chip and its two independent, asynchronous channels. Channel A controls the console port, and channel B the serial port. Both ports are configured DCE and can be programmed from 50 to 9600 baud. Parity checking, character lengths of from 5 to 8 bits, and eight interrupt masking conditions are also supported.

The independent channels are programmed by initializing the appropriate channel registers. Table 3-11 lists the DUART registers and their addresses.

## Table 3-11 DUART Register Addresses

| Address         | Register                     |
|-----------------|------------------------------|
| <b>%0080</b>    | MR1A: Mode Register 1        |
| <b>%0090</b>    | MRlB: Mode Register l        |
| <b>%0080</b>    | MR2A: Mode Register 2        |
| 80090           | MR2B: Mode Register 2        |
| <b>%0082</b>    | CSRA: Clock Select Register  |
| 80092           | CSRB: Clock Select Register  |
| 80084           | CRA: Command Register        |
| 80094           | CRB: Command Register        |
| <b>%0082</b>    | SRA: Status Register         |
| <b>%0092</b>    | SRB: Status Register         |
| 8009A           | OPRC: Output Port            |
|                 | Configuration Register       |
| <b>%0088</b>    | ACR: Auxiliary Control       |
|                 | Register                     |
| <b>%0088</b>    | IPČR: Input Port Change      |
|                 | Register                     |
| 8008A           | ISR: Interrupt Status        |
|                 | Register                     |
| 8008A           | IMR: Interrupt Mask Register |
| \$008C & \$008E | CTUR/CTLR: Counter/Time      |
|                 | Register                     |

# Mode Register 1 - MRIA & MRIB

The format of the asynchronous data communications is specified through the Channel A Mode Register 1 (MRIA) for the console port and the Channel B Mode Register 1 (MRIB) for the serial port. The bit definitions for both registers are identical and are listed in Table 3-12.

| Table 3-<br>Mode Reg<br>MRlA & M     | ister l                                                              |                                                                                           |                             |
|--------------------------------------|----------------------------------------------------------------------|-------------------------------------------------------------------------------------------|-----------------------------|
| Bit                                  | <b>Assignme</b>                                                      | nt                                                                                        |                             |
| 0<br>1<br>2<br>3<br>4<br>5<br>6<br>7 | Bits per<br>Parity t<br>Parity m<br>Parity m<br>Error mo<br>Receiver | character<br>character<br>ype select<br>ode select<br>de select<br>interrupt<br>request-t |                             |
| Bits O<br>& 1                        | in each<br>serial c                                                  |                                                                                           |                             |
|                                      | Bit O                                                                | Bit l                                                                                     | Character<br>Length         |
|                                      | 0<br>1<br>0<br>1                                                     | 0<br>0<br>1<br>1                                                                          | 5<br>6<br>7<br>8            |
| Bit 2                                | This bit<br>parity n<br>odd.                                         | designate<br>umber will                                                                   | s whether the<br>be even or |
|                                      | Bit 2                                                                | Parity N                                                                                  | lumber                      |
|                                      | 0<br>1                                                               | Even<br>Odd                                                                               |                             |

)

)

)

These bits enable the parity Bits 3 check. & 4 Bit 3 Parity Check Bit 4 0 0 Parity enabled 1 0 Force parity Parity disabled 0 1 Multiple drop 1 1 mode This bit sets the operating mode Bit 5 of the status bits to either character-by-character status or an accumulation of the status for all characters since the last reset error command (block). Bit 5 Error Mode 0 Character-by-character 1 Block Bit 6 This bit selects either the receiver ready status or the FIFO full status to be used for 80186 interrupts. Interrupt Select Bit 6 Receiver ready status 0 FIFO full status 1 This bit controls the Bit 7 deactivation of the request to send signal (RTSAN) on the OPO output to prevent an overrun in the receiver. Assignment Bit 7 0 Active RTSAN output 1 Deactivate

Hardware Programming

# Clock Select Registers - CSRA & CSRB

The DUART provides each channel with a programmable baud rate generator capable of taking the clock input and dividing it by any divisor from 1 to 65,535. The output frequency of the baud rate generator is sixteen times the baud rate. Channel A Clock Select Register (CSRA) sets the baud rate for the console port, and Channel B Clock Select Register (CSRB) sets the baud rate for the serial port.

Table 3-13 lists the bit assignments for bits 4 through 7 of the CSRA. These bits set the baud rate for the channel receiver.

Table 3-13 CSRA

)

)

|   |   |   |   | Baud             | Rates            |
|---|---|---|---|------------------|------------------|
| 7 | 6 | 5 | 4 | ACR(7) = 0       | ACR(7) = 1       |
| 0 | 0 | 0 | 0 | 50               | 75               |
| 0 | 0 | 0 | 1 | 110              | 110              |
| 0 | 0 | 1 | 0 | 134.5            | 134.5            |
| 0 | 0 | 1 | 1 | 200              | 150              |
| 0 | 1 | 0 | 0 | 300              | 300              |
| 0 | 1 | 0 | 1 | 600              | 600              |
| 0 | 1 | 1 | 0 | 1200             | 1200             |
| 0 | 1 | 1 | 1 | 1050             | 200 <b>0</b>     |
| 1 | 0 | 0 | 0 | 2400             | 2400             |
| 1 | 0 | 0 | 1 | 4800             | 4800             |
| 1 | 0 | 1 | 0 | 7200             | 1800             |
| 1 | 0 | 1 | 1 | 9600             | 9600             |
| 1 | 1 | 0 | 1 | Timer            | Timer            |
| 1 | 1 | 1 | 0 | IP <b>4-16</b> X | IP <b>4-16</b> X |
| ī | 1 | 1 | 1 | IP4-1X           | IP4-1X           |

**NOTE:** IP4 refers to a general purpose input line on the DUART.

Bit 7 of the Auxiliary Control Register selects which of the two sets of baud rates the baud rate generator is to generate.

The definitions for bits 0 through 3 of the CSRA for the channel A transmitter are identical to bits 4 through 7, with the following exceptions:

| Bi | ts |   |   | Baud       | Rates      |
|----|----|---|---|------------|------------|
| 0  | 1  | 2 | 3 | ACR(7) = 0 | ACR(7) = 1 |
| 1  | 1  | 1 | 0 | IP3-16X    | IP3-16X    |
| 1  | 1  | 1 | 1 | IP3-1X     | IP3-1X     |

The definitions of bits 4 through 7 for CSRB, which set the baud rate for the channel B receiver, are identical to the corresponding bits in the CSRA register, with the following exceptions:

| Bi | ts |   |   | Baud          | Rates      |
|----|----|---|---|---------------|------------|
| 4  | 5  | 6 | 7 | ACR(7) = 0    | ACR(7) = 1 |
| 1  | 1  | 1 | 0 | IP6-16X       | IP6-16X    |
| 1  | 1  | 1 | 1 | <b>IP6-1X</b> | IP6-1X     |

The definitions of bits 0 through 3, which set the baud rate for the channel B transmitter, are identical to bits 4 through 7, with the following exceptions:

| Bi<br>O |   | 2      | 3 |                   | Rates<br>ACR(7) = 1       |
|---------|---|--------|---|-------------------|---------------------------|
| 1<br>1  | _ | 1<br>1 | - | IP6-16X<br>IP6-1X | IP <b>6-16X</b><br>IP6-1X |

# Interrupt Status Register - ISR

This register provides the status of all potential interrupt sources. If a bit in the ISR is set at "1" and the corresponding bit in the IMR register is also a "1", the interrupt line INTRN goes low, generating an interrupt. Refer to Table 3-14 for the register bit assignments.

### Table 3-14 Interrupt Status Register

- Bit Description
- 0 The function of this bit is identical to bit 2 of the SRA register.
- 1 Channel A Receiver Receiver Ready or FIFO Full - The function of this bit is programmed by bit 6 in MRIA. If programmed as receiver ready, it indicates that a character has been received in channel B. If programmed as FIFO full, it is set when a character is transferred from the receive holding register to the receive FIFO, causing the FIFO to become full.
- 2 Channel A Change in Break This bit goes to 1 when the Channel A receiver detects the beginning or the end of a received break.
- 3

Counter Ready - In the counter mode, this bit is set when the counter reaches terminal count. In the timer mode, this bit is set once each cycle of the square wave.

# Table 3-14 continued

| Bit | Description                                                                                                                                           |
|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4   | Channel B Transmitter Ready - The<br>function of this bit is identical<br>to bit 2 of the SRB register.                                               |
| 5   | Channel B Receiver Ready or FIFO<br>Full - The function of this bit<br>is identical to bit 1, with the<br>exception that it operates on<br>channel B. |
| 6   | Channel B Change in Break - The<br>function of this bit is identical<br>to bit 2, with the exception that<br>it operates on Channel B.                |
| 7   | This bit goes to 1 when a change<br>of state occurs on input line<br>IP3.                                                                             |

### Command Registers - CRA & CRB

The CRA register provides commands to the console port on channel A. The CRB register provides commands to the serial port on channel B. The bit assignments to both registers are identical and are listed in Table 3-15.

# Table 3-15 Command Register

)

Bit Description 0 Enable Channel Receiver Enables operation of the channel receiver. 1 Disable Channel Receiver - A 1 for this bit immediately terminates the operation of the receiver. 2 Enable Channel Transmitter -Enables operation of the channel transmitter. Disable Channel Transmitter -3 Set this bit to 1 to terminate transmitter operation and reset the TxRDY and TxEMT status bits. 6 5 4 0 0 0 No command. 0 0 1 Reset MR pointer - Causes the channel A MR pointer to point to MR1. 1 0 Reset receiver - Resets the 0 channel receiver as if a hardware reset had been applied. 0 1 1 Reset transmitter - Resets the channel transmitter as if a hardware reset had been applied. 1 0 0 Reset error status - Resets error bits 4 through 7 of the status register.

### Table 3-15 continued

Bit

Description

- 6 5 4
- 1 0 1 Reset channel break change interrupt - Changes bit 2 in the interrupt status register to 0.
- 1 1 0 Start break Forces the TXDA output low.
- 1 1 1 Stop break Causes the TXDA line to go high within two bit times. TXDA will remain high for one bit time before the next character, if any, is transmitted.

### FLOPPY DISK CONTROLLER

A Western Digital WD1770 controller generates the floppy disk control signals for the PM system. For complete information on the controller, refer to the **Storage Management Products Handbook** from Western Digital. Additional control signals are generated by the 80186 through the latch at address %0040. The 80186 must program this latch as part of a floppy disk access. Refer to Figure 3-5 for the latch bit assignments. Figure 3-5 Floppy Disk Control Latch 6 14 12 10 - 32 16 Pin 1 Bit 5 4 3 2 7 6 Ω 1 1 1 1 ł 1 1 1 Ł I I Ł L 1 Not used L L I 1 L 1 L I I L L 0 = Motor onL 1 1 1 1 1 1 = Motor off1 1 1 L 1 1 1 I 1 1 1 0 =Side 1 head is 1 1 1 selected L 1 1 = Side 2 head isI 1 1 1 1 I L selected 1 1 I I 1 L | | Not used 1 L 1 L 1 1 i i 0 = Drive A is selected L 1 1 I 1 = Normal output ſ 1 L ł 1 0 = Drive B is selected 1 = Normal output L 1 I L 1 0 = Drive C is selected 1 = Normal output 1 0 = Drive D is selected 1 = Normal output

1

The FDC has four registers accessible to the 80186. The registers and their addresses are listed in Table 3-16.

# **Table 3-16** FDC Register Addresses

Address Register

| <b>%0180</b> | Status | and | Command | Registers |
|--------------|--------|-----|---------|-----------|
|--------------|--------|-----|---------|-----------|

- %0181 %0182
- Track Register Sector Register
- 80183 Data Register

### Status Register

The status register provides the 80186 with status information on the previously executed command and is accessible only when the R/W input is high. Refer to Figure 3-6 for the bit assignments to this register.

### Figure 3-6 Status Register

Bit

| 7 | 6   | 5   | 4   | 3   | 2   | 1   | 0                      |
|---|-----|-----|-----|-----|-----|-----|------------------------|
| 1 | 1   | 1   | 1   | 1   | 1   | I   | 0 = FDC is busy:       |
| 1 | 1   |     |     | 1   | 1   |     | command in             |
| 1 | 1   | 1   | - 1 | I   | 1   | 1   | progress               |
| 1 | 1   | 1   | 1   | 1   | 1   | 0   | = Data register is     |
| 1 | 1   | 1   | 1   | 1   | 1   |     | ready to send or       |
| 1 | 1   | - 1 | -   | I   | 1   |     | receive data           |
| 1 | 1   | 1   | 1   | I   | 1   | = N | lo response to DRQ     |
| 1 | 1   | 1   |     | 1   | = E | rro | or in ID or data field |
| 1 | 1   | 1   | 1   | = E | rro | r i | n locating track,      |
| 1 | 1   |     |     |     |     |     | or side                |
| 1 | 1   | 1   | = I | ndi | cat | es  | 6 drive revolutions    |
| 1 | 1   | = D | isk | is  | wr  | ite | -protected             |
| 0 | = M | oto | r o | n   |     |     |                        |
| 1 | = M | oto | r o | ff  |     |     |                        |

)

### **Command Register**

The command register holds the command currently being executed and is accessible only when the R/W input is low.

The WD1770 is capable of executing 11 commands. All commands are initiated by the 80186 with a byte transfer on lines D0 through D7. The commands are listed in Table 3-17. Table 3-18 contains a flag summary.

#### Table 3-17 FDC Commands

|              | Bit |   |   |   |    |    |           |     |  |  |
|--------------|-----|---|---|---|----|----|-----------|-----|--|--|
| Command      | 7   | 6 | 5 | 4 | 3  | 2  | 1         | 0   |  |  |
| Restore      | 0   | 0 | 0 | 0 | h  | v  | rl        | r0  |  |  |
| Seek         | 0   | 0 | 0 | 1 | h  | V  | <b>r1</b> | r0  |  |  |
| Step         | 0   | 0 | 1 | u | h  | V  | <b>r1</b> | r 0 |  |  |
| Step-in      | 0   | 1 | 0 | u | h  | V  | rl        | r0  |  |  |
| Step-out     | 0   | 1 | 1 | u | h  | V  | rl        | r0  |  |  |
| Read Sector  | 1   | 0 | 0 | m | h  | Е  | 0         | 0   |  |  |
| Write Sector | 1   | 0 | 1 | m | h  | E  | Ρ         | a0  |  |  |
| Read Address | 1   | 1 | 0 | 0 | h  | Е  | 0         | 0   |  |  |
| Read Track   | 1   | 1 | 1 | 0 | h  | E  | 0         | 0   |  |  |
| Write Track  | 1   | 1 | 1 | 1 | h  | E  | Ρ         | 0   |  |  |
| Force        |     |   |   |   |    |    |           |     |  |  |
| Interrupt    | 1   | 1 | 0 | 1 | 13 | 12 | 11        | 10  |  |  |

# Table 3-18 Flag Summary

h = Motor On Flag (Bit 3) h = 0, Enable spin-up sequence h = 1, Disable spin-up sequence

Table 3-18 continued Flag Summary V = Verify Plag (Bit 2) V = 0, No verify V = 1, Verify on destination track rl, r0 = Stepping Rate (Bits 1,0) rl r2 0 0 = 6 ms1 = 12 ms0 1 0 = 20 ms 1 = 30 ms1 u = Update Flag (Bit 4)u = 0, No update u = 1, Update track sector  $\mathbf{m} = \mathbf{M}\mathbf{u}\mathbf{l}\mathbf{t}\mathbf{i}\mathbf{p}\mathbf{l}\mathbf{e}$  Sector Flag (Bit 4) m = 0, Single sector m = 1, Multiple sector a0 = Data address mark (Bit 0) a0 = 0, Write normal data mark a0 = 1, Write deleted data mark E = 30ms Settling Delay (Bit 2) E = 0, No delay E = 1, Add 30ms delay **P** = Write Precompensation (Bit 1) P = 0, Enable write precomp P = 1, Disable write precomp I3 - I0 = Interrupt Condition (Bit 3-0) I0 = 1, Don't care Il = 1, Don't care  $\overline{12} = \overline{1}$ , Interrupt on index pulse I3 = 1, Immediate interrupt I3 - I0 = 0, Terminate without interrupt

Hardware Programming

The FDC commands are described in the following pages.

SEEK: In response to this command, the FDC updates the track register as it issues stepping pulses. This continues until the contents of the track register and the data register are equal. This assumes that the data register is holding the location of the desired track number.

**STEP:** In response to this command, the FDC steps the disk drive with one stepping pulse. The direction of the step is the same as the previous step command.

**STEP-IN:** In response to this command, the FDC steps the drive towards track 76, and increments the track register by 1.

**STEP-OUT:** In response to this command, the FDC steps the drive towards track O, and decrements the track register by 1.

**READ SECTOR:** In response to this command, the busy bit is set, and when the correct ID field is encountered, a sector is read from disk.

**READ ADDRESS:** In response to this command, the busy bit is set and the next ID field is read from disk.

**READ TRACK:** In response to this command, the head is loaded and the busy bit is set. reading starts with the leading edge of the first encountered index pulse and continues until the next index pulse.

WRITE SECTOR: In response to this command, the busy bit is set, and when the correct ID field is encountered, a sector is transferred to disk.

#### Hardware Programming

**FORCE INTERRUPT:** This command can be loaded into the command register at any time. It is generally used to stop a multiple sector read or write command.

# Track Register

This 8-bit register holds the number of the current head position. The register is incremented with each step-in command and decremented with every step-out command. During read and write operations, this register is compared with the track number in the ID field on the disk itself.

#### Sector Register

This 8-bit register holds the address of the desired sector. During read and write operations, the contents of this register are compared with the sector number in the ID field on the disk.

### Data Register

This 8-byte register is used as a holding register for the byte of data being either written to or read from disk. )

#### WINCHESTER DISK CONTROLLER BOARD

The Winchester disk controller board contains a WD1010-05 Winchester disk controller device to perform executive control over disk operations. To command the board, the system addresses a set of task file registers in the WD1010-05 with the I/O port address of each of the individual registers. Table 3-19 is a list of the individual registers, along with their I/O port addresses for the PM system.

### Table 3-19 WD1010-05 Registers

| Address      | Read              | Write                     |
|--------------|-------------------|---------------------------|
| <b>%0200</b> | System Access     | System Access             |
| <b>%0202</b> | Error Flags       | Write Precomp<br>Cylinder |
| <b>%0204</b> | Sector Count      | Sector Count              |
| <b>%020C</b> | Sector Number     | Sector Number             |
| <b>%0208</b> | Cylinder Low      | Cylinder Low              |
| <b>%020A</b> | Cylinder High     | Cylinder High             |
| <b>%020C</b> | Sector/Drive/Head | Sector/Drive/Head         |
| <b>%020E</b> | Status Register   | Command Register          |

A detailed description of the WD1010-05 device is given in the **1984 Storage Management Products Handbook** from Western Digital.

#### Task File Register Functions

For a typical operation, the task file registers are written to, or read for status, and a command is given to the command register. The WD1010-05 then tri-states the address bus and executes the command. At the end of the operation, the task file is again opened to the system.

# **Brror Register**

Contains error flags for bad block detect, CRC data field, ID not found, aborted command, TK0000 error, and data address mark error. During read operations, the error register is read after the data is read out of buffer RAM, that is, after the byte count goes to zero. The error register bit assignments are listed in Table 3-20.

# Table 3-20 Brror Register

#### Bit Description

- 0 Set during a read sector command if the address mark is not found after the proper sector ID is read.
- Set only by the restore command. It indicates that the head is not positioned over track 000 after 1024 stepping pulses.
- 2 Set if a command was issued while the status register shows a drive fault (bit 5), or command disable (bit 6) condition. This bit is also set if an undefined command is issued.
- 4 Set when the desired cylinder, head, sector, or size parameter cannot be found after 8 revolutions of the disk. This bit is also set if a cyclic redundancy check error has occurred.
- 5 Not used. Forced to 0.

Ì

### Table 3-20 continued

### Bit Description

Ì

- 6 Set if a data field CRC error has occurred or the data mark address has not been found.
- 7 Set if an ID field has been encountered that contains a bad block mark (used for bad sector mapping).

#### Write Precomp Register

Defines the starting cylinder number at which reduced write current (RWC) begins. This value is in the range 0 to 255, and is internally multiplied by four to obtain the actual cylinder.

# Sector Count Register

Contains the number of sectors that are to be transferred to buffer RAM. Because this is a decrementing function, all zeros are written for a 256-sector transfer and a 1 is written for a 1 sector transfer.

#### Sector Number Register

Contains the starting sector of a transfer in the range 0 to 255. This register is incremented with every transfer.

#### Cylinder Number Low Register

Least significant 8 bits of the starting cylinder number in the range 0 to 1023. **Cylinder Number High Register** 

Carries the most significant bits of the starting cylinder number as bits 0(8) and 1(9). The other bits of this register are unused.

# Sector/Drive/Head Register

Contains the sector size, drive number, and head number parameters for the operation:

| Bi  | ts |     |     |     |     |      |     |     |      |     |      |   |
|-----|----|-----|-----|-----|-----|------|-----|-----|------|-----|------|---|
| 7   | 6  | 5   | 4   | 3   | 2   | 1    | 0   |     |      |     |      |   |
| I   | I  | 1   | I   | 1   | - 1 | l    | 1   |     |      |     |      |   |
| 1   |    | 1   | 1   | 1   | 0   | 0    | 0   | =   | Sele | ect | head | 0 |
| I   | I  | 1   | 1   | 1   | 0   | 0    | 1   | =   | Sele | ect | head | 1 |
| 1   | 1  | 1   | 1   | 1   | 0   | 1    | 0   | =   | Sele | ect | head | 2 |
| 1   | 1  | 1   | 1   | 1   | 0   | 1    | 1   | =   | Sele | ect | head | 3 |
| Ì   | Ì  | 1   | 1   | 1   | 1   | 0    | 0   | =   | Sele | ect | head | 4 |
| 1   | 1  |     | 1   | 1   | 1   | 0    | 1   | Ħ   | Sele | ect | head | 5 |
| Ì   | 1  | ŀ   | 1   | 1   | 1   | 1    | 0   | =   | Sele | ect | head | 6 |
| I   | 1  |     | I   | 1   | 1   |      |     | =   | Sele | ect | head | 7 |
| Ì   | Ì  | 1   | 1   | 1   |     |      |     |     |      |     |      |   |
| 1   | 1  | 1   | 0   | 0   | =   | Sele | ct  | dı  | ive  | 1   |      |   |
| 1   | 1  | 1   | 0   | 1   | =   | Sele | ct  | dr  | ive  | 2   |      |   |
| Ì   | Ì  | 1   | 1   | 0   | =   | Sele | ct  | dr  | ive  | 3   |      |   |
| Ì   | Í  | 1   | 1   | 1   | =   | Sele | ct  | dı  | ive  | 4   |      |   |
| Ì   | Ì  | Ì   |     |     |     |      |     |     |      |     |      |   |
| I   | 0  | 0   | = S | ect | or  | siz  | e 2 | 256 | 5    |     |      |   |
| - E | 0  | 1   | = S | ect | or  | siz  | e S | 512 | 2    |     |      |   |
| Ì   | 1  | 0   | = S | ect | or  | siz  | e ] | 102 | 24   |     |      |   |
| I   | 1  | 1   |     |     |     | siz  |     | 128 |      |     |      |   |
| I   | =  | Ext | ens | ior | n b | it   |     |     |      |     |      |   |

Bit 7 is an extension bit that extends the data field by 7 bytes when ECC codes are used. When set to 1, CRC is not appended to the end of the data field; the data field becomes sector size + 7 bytes long. The SDH byte written into the ID field is different than the SDH register contents. The recorded SDH byte does not have the drive number and contains a bad block in bit 7.

### Status Register

Contains status bits for device busy, device ready, write fault (same as WF line), seek complete (same as SC line), data request (same as BDRQ line), command in progress, and error register flags set. The status register bit assignments are listed in Table 3-21.

Table 3-21 Status Register

Bit Description

- 0 Set whenever any bits in the error register are set. This bit is reset when a new command is written into the command register.
- 1 Set when a command is being executed.
- 3 Set when the sector buffer should be loaded or read (depending on the command). It is reset upon completion of the operation.
- 4 Set during a seek, and reset when the head settling time has expired.
- 5 Indicates a fault condition at the drive when set. An interrupt is generated when this bit is set.
- 6 Must be set for commands to execute.

### Table 3-21 continued

#### Bit Description

7 Set whenever the disk is being accessed. Do not load commands into the command register when this bit is set. It is reset at the end of all commands except the read sector command. This bit is reset after the sector buffer is filled on the read sector command.

### **Command Register**

This write-only register loads the desired command. A command begins to execute immediately upon loading. Do not load this register while bits 1 or 7 are set in the status register.

The command set consists of six commands: restore, seek, read, write sector, scan ID, and write format. Prior to loading a command, the task file registers must be set with the proper parameters. Except for the command register, the task file registers can be loaded in any order.

**RESTORE** - Restore heads. The restore command is usually used on a power-up condition. The head is stepped back to track 000. If, after 1024 stepping pulses, the head is not over track 000, bit 1 of the error flag is set. The head settling time determines the stepping rate. The rate entered into the rate field of the restore command is stored in an internal register and used in future commands with implied seeks (the default stepping rate is 7.5 ms.) **SEEK** - For seek operations between multiple drives. Since all commands feature an implied seek, the seek command is primarily used for overlap seek operations on multiple drives. The rate field step rate is used and then stored in an internal register for future use.

# Table 3-22 Command Register Format

| Command      | 7 | 6 | 5 | 4 | 3  | 2  | 1         | 0  |
|--------------|---|---|---|---|----|----|-----------|----|
| Restore      | 0 | 0 | 0 | 1 | R3 | R2 | Rl        | R0 |
| Seek         | 0 | 1 | 1 | 1 | R3 | R2 | <b>R1</b> | RÛ |
| Read sector  | 0 | 0 | 1 | 0 | I  | М  | 0         | 0  |
| Write sector | 0 | 0 | 1 | 1 | 0  | Μ  | 0         | 0  |
| Scan ID      | 0 | 1 | 0 | 0 | 0  | 0  | 0         | 0  |
| Write format | 0 | 1 | 0 | 1 | 0  | 0  | 0         | 0  |

#### Note:

a. R0 through R3 is the rate field:

| R3 | R <b>2</b> | <b>R1</b> | RO                          |
|----|------------|-----------|-----------------------------|
| 0  | 0          | 0         | 0 = approx. 35 microseconds |
| 0  | 0          | 0         | 1 = 0.5 milliseconds        |
| 0  | 0          | 1         | 0 = 1.0 milliseconds        |
| 0  | 0          | 1         | 1 = 1.5 milliseconds        |
| 0  | 1          | 0         | 0 = 2.0 milliseconds        |
| 0  | 1          | 0         | 1 = 2.5 milliseconds        |
| 0  | 1          | 1         | 0 = 3.0 milliseconds        |
| 0  | 1          | 1         | 1 = 3.5 milliseconds        |
| 1  | 0          | 0         | 0 = 4.0 milliseconds        |
| 1  | 0          | 0         | 1 = 4.5 milliseconds        |
| 1  | 0          | 1         | 0 = 5.0 milliseconds        |
| 1  | 0          | 1         | 1 = 5.5 milliseconds        |
| 1  | 1          | 0         | 0 = 6.0 milliseconds        |
| 1  | 1          | 0         | 1 = 6.5 milliseconds        |
| 1  | 1          | 1         | 0 = 7.0 milliseconds        |
| 1  | 1          | 1         | 1 = 7.5 milliseconds        |

- b. M is the multiple sector flag: 0 = Transfer 1 sector 1 = Transfer multiple sectors
- c. When limited RAM buffer size does not allow multiple sector operations, M must be set to 0.
- d. I is the interrupt enable:
  - 0 = Set interrupt when bit 3 of the status register is set (sector buffer is ready to be loaded or read)
  - 1 = Set interrupt upon completion of the command

The value is calculated by comparing the contents of the cylinder high/low registers to the cylinder position number stored internally. After all steps have been issued, the command is terminated.

**READ SECTOR -** Transfers one or more sectors to disk. The following programming sequence should be used with the read sector command:

 Check the status of the Busy bit (bit 7) of the status register until a reset condition is found.  Write to the task file registers with the transfer parameters:

> Precomp reg = Desired precomp start track/4 Sector count = 1 Sector number = Sector number to read Cylinder high/low = Desired cylinder number SDH = Desired sector size, drive number, and head number

- 3. Send the read sector command to the command register.
- 4. Delay 1 or 2 NOP instructions.

)

)

- Check the status of the Busy bit (bit 7) of the status register until a reset condition is found.
- ) 6. Read the data buffer (total number of bytes is equal to the sector size).
  - Read the status register and check the error bit (bit 0).
  - 8. If the error bit is set, read the error register for error information.

**WRITE SECTOR** - Writes one or more sectors to disk. The following programming sequence should be used with the write command:

 Check the status of the Busy bit (bit 7) of the status register until a reset condition is found. 2. Write to the task file registers with the transfer parameters:

| Precomp reg       | = | Desired precomp<br>start track/4                            |
|-------------------|---|-------------------------------------------------------------|
| Sector count      | = |                                                             |
| Sector number     | = | Sector number to write                                      |
| Cylinder high/low | = | Desired cylinder<br>number                                  |
| SDH               | = | Desired sector<br>size, drive<br>number, and head<br>number |

- 3. Send the write command to the command register.
- 4. Write a sector of data to the data buffer.
- 5. Delay 1 or 2 NOP instructions.
- Check the status of the Busy bit Register (bit 7) of the status register until a reset condition is found.
- 7. Re-read the status register and check the error bit (bit 0).
- 8. If the error bit is set, read the error register for error information.

SCAN ID - Updates the head, sector size, sector number, and cylinder registers. The internal cylinder position is also updated. This operation is used for multiple drives for an implied seek.

**WRITE FORMAT** - Used to format a single track using the task file and sector buffer. The sector buffer is used for additional parameter information instead of sector data. The following programming sequence should be used with the write format command:

- Check the status of the Busy bit (bit 7) of the status register until a reset condition is found.
- Write to the task file registers with the transfer parameters:

Precomp reg = Desired precomp start track/4 Sector count = Number of sectors to

be formatted Sector number = Number of bytes minus three to be used for Gap 1 and Gap 3. Gap 3 is determined as follows:

Gap 3 = 2 \* M \* S + K + E

where: M = motor speed variation (.03 for +-3%) S = sector length in bytes K = 25 for an interleave factor of 1 K = 0 for any other interleave factor E = 7 if the sector is to be extended

Cylinder high/low = Desired cylinder number SDH = Desired sector size, drive number, and head number (set extension = 0)

- 3. Send the write format command to the command register.
- Fill the interleave table in the sector 4. buffer. Each sector to be formatted requires a 2-byte sequence. The first byte indicates whether a bad block mark is to be recorded in the sector's ID field. An 80H indicates a bad block mark for that sector; a 00H is normal. The second byte indicates the logical sector number to be recorded. Using this scheme, sectors can be recorded in any interleave factor desired. The remaining memory in the sector buffer can be filled with any value (but must be filled with one sector size worth of data).
- 5. Delay 1 or 2 NOP instructions.
- Check the status of the Busy bit (bit
   7) of the status register until a reset condition is found.
- 7. Re-read the status register and check the error bit (bit 0).
- 8. If the error bit is set, read the error register for error information.

#### TAPE INTERFACE CARD

The Tape Interface Card is designed to interface the PM system with the Tape Storage Unit.

The card contains a Z80A microprocessor running at 4 MHz, an 8 Kbyte PROM, and 4 Kbytes of static RAM, optionally expandable to 16 Kbytes. The size of RAM was chosen to provide enough buffer area for streaming operations to the tape drive. Underrun or overrun of the buffer area will severely slow down the streaming operation of the drive.

The tape interface card can be installed in either the xl or x2 expansion slot of the PM system. Several jumpers on the card, however, must be set according to the slot in which the board is installed. For the correct jumper settings, refer to Appendix A.

### **Tape Card Interrupts**

Handshaking protocol between the Z80A on the tape card and the two processors on the PM main system board is performed by several interrupt lines. The addresses to the interrupts are listed in Table 3-23.

### Table 3-23 Tape Card Interrupt Addresses

| Address    | Function                   |      |    |      |    |
|------------|----------------------------|------|----|------|----|
| %C0        | Set interrupt<br>PM's Z80A | 280A | on | card | to |
| <b>%C8</b> | Set interrupt<br>80186     | 280A | on | card | to |

Hardware Programming

### Table 3-23 continued

#### Address Function

%D0 Interrupt acknowledge from card's Z80A to 80186

%D8 Interrupt acknowledge from card's Z80A to PM's Z80A

Interrupts from the PM main board to the tape interface card are sent through the addresses listed in Table 3-24. Note that the port addresses differ depending on the slot in which the card is installed.

### **Table 3-24**

# Main Board Interrupts to the Tape Card

| Address           | Function                                                                               |
|-------------------|----------------------------------------------------------------------------------------|
| <b>%02</b>        | Interrupt acknowledge from the PM<br>280A to the tape interface card<br>if in slot x1. |
| <b><b>%04</b></b> | Interrupt acknowledge from the PM<br>Z80A to the tape interface card<br>if in slot x2. |
| %002E0            | Interrupt acknowledge from the<br>80186 to the tape interface card<br>if in slot x1.   |
| <b>%002F0</b>     | Interrupt acknowledge from the<br>80186 to the tape interface card<br>if in slot x2.   |
| ¥088              | Interrupt signal from the PM Z80A to the tape interface card if in slot x1.            |
| <b>%0D8</b>       | Interrupt signal from the PM Z80A to the tape interface card if in slot x2.            |

)

# Table 3-24 continued

### Address Function

- %02B0 Interrupt signal from the 80186 to the tape interface card if in slot xl.
- %02C0 Interrupt signal from the 80186 to the tape interface card if in slot x2.

### Local Memory Space

The local memory space on the interface board consists of an 8 Kbyte EPROM and 4 Kbytes static RAM, expandable to 16 Kbytes. Refer to Figure 3-7 for a map of the local memory space.

| Figure 3-7<br>Tape Card Local Memory Space Map |     |     |     |     |                 |                                 |  |  |
|------------------------------------------------|-----|-----|-----|-----|-----------------|---------------------------------|--|--|
| A15                                            | A14 | A13 | A12 | A11 | Range           | Memory                          |  |  |
| 0                                              | 0   | 0   | 0   | x   | 0000н           | Start of<br>EPROM               |  |  |
|                                                |     |     |     |     | lfffh           | End of EPROM                    |  |  |
| 0                                              | 1   | x   | x   | x   | <b>4</b> 000H   | Start of<br>static RAM          |  |  |
|                                                |     |     |     |     | 4FFFH           | End of <b>4</b> K<br>static RAM |  |  |
|                                                |     |     |     |     | 5FFFH           | End of 8K<br>static RAM         |  |  |
|                                                |     |     |     |     | 7FFFH           | End of 16K<br>static RAM        |  |  |
| <b>1</b><br>)                                  | x   | x   | x   | x   | 8000H-<br>FFFFH | PM main<br>memory               |  |  |

### Main Memory Addressing

The Z80A and the DMA chip on the tape interface card can access the PM main memory by executing a bus request to the Z80A on the PM board. A bus request is automatically asserted whenever the address space accessed falls between 8000H and FFFFH. To avoid blocking out the PM Z80A for too long, the transfer should be performed in the DMA byte mode.

The 20-bit address bus on the tape interface card is designed to bypass the memory mapper on the PM main board and directly access the main memory. Bits 0 through 14 of the bus are identical to address bits 0 through 14 on the PM board. Bits 15 through 19 are generated from a latch at address %E0 called the High Address Register. Refer to Figure 3-8 for the bit assignments to the register.

# Figure 3-8 High Address Register (%E0)

Bit 6 5 3 2 1 0 7 4 1 1 1 I 1 1 I L L 1 1 1 1 Address bit 15 1 L (XSA15)L L I 1 L 1 1 Address bit 16 (XSA16) 1 1 1 Address bit 17 1 I L 1 (XSA17) Address bit 18 (XSA19) I Address bit 19 (XSA19) I I Not used I 1 1 Not used = LOCK signal 1

When bit 0 of the register (XSA15) is set to 1, the card accesses main memory. When set to 0, the card accesses local RAM.

Bit 7 of the register generates the LOCK signal. When set to 1, the 80186 is locked out of the main memory.

# Configuration Facility

At power-on or reset of the PM system, the Z80A on the main system board inspects the expansion slots to determine if an expansion board is installed. It does this by reading the 'ANY 1' and 'ANY 2' signals. A low on the line indicates the presence of a card. If a board is installed, the Z80A needs to determine its ID by inspecting the XD4 through XD0 bits on the PM interface data bus.

The ID of the Tape Interface Card is given ) below:

| XD | Bits | 4 | 3 | 2 | 1 | 0 |
|----|------|---|---|---|---|---|
|    |      |   |   |   |   |   |
| ID |      | 0 | 0 | 0 | 1 | 0 |

#### CTC Counter/Timer

)

Table 3-25 lists the CTC channel assignments and their addresses.

# Table 3-25 CTC Channel Assignments

| Channel | Address    | Function                                               |
|---------|------------|--------------------------------------------------------|
| 0       | <b>%00</b> | Bus-request-time-out<br>timer (timer mode)             |
| 1       | <b>%01</b> | General purpose<br>counter/timer                       |
| 2       | <b>%02</b> | Time-out interrupt<br>(counter mode)                   |
| 3       | <b>%03</b> | Interrupt from PM main<br>board to tape card's<br>Z80A |

NOTE: These ports are accessible only by the card's Z80A.

Channel 0 of the CTC on the Tape Interface Card is used as a bus-request-time-out timer. Channel 2 of the CTC is used to generate an interrupt to notify the CPU once time-out has occurred. This scheme resolves any possibility of a hang-up in the bus-request cycle. Channel 0 must be programmed in the timer mode, and channel 2 in the counter mode.

Channel 1 is a general purpose counter/timer. Channel 3 is used to generate an interrupt to the card's Z80A when either the PM's Z80A or 80186 wants to interrupt the card.

# DMA Transfers

The DMA chip on the tape interface board transfers data between local memory and the main memory on the PM main system board. The upper limit of the size of a DMA transfer is 32 Kbytes, which corresponds to the 32-Kbyte boundary of the address space.

To maintain the high pace of data transfer required by streaming tape, the card's Z80A transfers data between local memory and the tape drive in the block I/O instruction. Transfer of data between the local memory and the PM main memory should be performed by the card's DMA chip in 'BYTE MODE'. This prevents the possibility of shutting-off other operations external to the card. If desired, the block transfer mode can be used if the PM Z80A and the 80186 do not need to access main memory, or when both of them can wait for the card's DMA chip to complete a block transfer.

#### Tape Drive Interface

The tape interface card contains three I/O ports that interface with the tape drive itself. These ports provide control, data, and status information, and are accessible only to the card's Z80A.

The Write Control latch at address %42 generates three of the four control signals for the tape drive unit. Figure 3-9 lists the bit assignments.

| Figure 3-9<br>Write Control Latch<br>(%42) |   |    |      |      |                       |  |  |  |
|--------------------------------------------|---|----|------|------|-----------------------|--|--|--|
| Pin                                        | - | 32 | 30   | 28   |                       |  |  |  |
| Bit                                        | 3 | 2  | 1    | 0    |                       |  |  |  |
|                                            | 1 | I  | 1    | 1    |                       |  |  |  |
|                                            | 1 | 1  | 1    | 0    | = Places the drive in |  |  |  |
|                                            |   | 1  | 1    |      | on-line status        |  |  |  |
|                                            | I | 1  | 0    | = Ha | Indshake control      |  |  |  |
|                                            | 1 | 0  | = Re | set  | the tape drive        |  |  |  |
|                                            | 1 |    |      |      | st to PM system       |  |  |  |

The fourth control signal, -XFR, is generated by two D-type latches that are ORed together and clocked whenever a read from or write to tape command is issued. The signal controls the transfer timing.

Drive status information is obtained by reading the two latches at address %43. The first latch provides bits 0-3 of the drive status by reading back the control signals to the Write Command Latch. The second latch provides bits 4-7 from the control signal port from the drive. Together they make the 8-bit wide command status byte. Refer to Figure 3-10 for the bit assignments.

Hardware Programming

```
Figure 3-10
 Drive Status Bit Assignments
 ($43)
 Pin 42 40 38 36
                     3 2 1 0
        7 6 5 4
 Bit
                    | | | |
| | | 1 = Drive is
              1
        L
           1
                  1
)
           L
              I
                  L
                                  on-line
              I
                  1
                    L
                          ||1=Handshaking|||signal is|||active
           I
               I
              1
        I
           L
              L
        I
              1
        I
           I
                 1
                    1 = Reset tape drive
                    0 = Bus request to PM
           L
              1
                1
        I
        ł
                          system
           1
              1
                 1 0 = Interrupt acknowledge
        I
           1
        ł
           | 0 = Drive ready for next
                  command
        Ł
           0 = Interrupt signal
        1
        0 = Data direction: Read from tape
        1 = Data direction: Write to tape
```

### Data Format

Data storage by the tape drive on the tape's four tracks involves the conversion of the data into a GCR format. Data is stored in blocks of 512 bytes, which after conversion, is 5120 bytes on tape. Refer to Table 3-26 for the conversion table.

# Table 3-26 GRC Conversion Table

| D7/D3 | PM Da<br>D6/D2 | ta<br>D5/D1 | D4/D0 | G4 | Data<br>G3 | on<br>G2 | Tape<br>Gl | G0 |
|-------|----------------|-------------|-------|----|------------|----------|------------|----|
| 0     | 0              | 0           | 0     | 1  | 1          | 0        | 0          | 1  |
| 0     | 0              | 0           | 1     | 1  | 1          | 0        | 1          | 1  |
| 0     | 0              | 1           | 0     | 1  | 0          | 0        | 1          | 0  |
| 0     | 0              | 1           | 1     | 1  | 0          | 0        | 1          | 1  |
| 0     | 1              | 0           | 0     | 1  | 1          | 1        | 0          | 1  |
| 0     | 1              | 0           | 1     | 1  | 0          | 1        | 0          | 1  |
| 0     | 1              | 1           | 0     | 1  | 0          | 1        | 1          | ٢. |
| 0     | 1              | 1           | 1     | 1  | 0          | 1        | 1          |    |
| 1     | 0              | 0           | 0     | 1  | 1.         | 0        | 1          | 0  |
| 1     | 0              | 0           | 1     | 0  | 1          | 0        | 0          | 1  |
| 1     | 0              | 1           | 0     | 0  | 1          | 0        | 1          | 0  |
| 1     | 0              | 1           | 1     | 0  | 1          | 0        | 1          | 1  |
| 1     | 1              | 0           | 0     | 1  | 1          | 1        | 1          | 0  |
| 1     | 1              | 0           | 1     | 0  | 1          | 1        | 0          | 1  |
| 1     | 1              | 1           | 0     | 0  | 1          | 1        | 1          | 0  |
| 1     | 1              | 1           | 1     | 1  | 1          | 1        | 1          | 1  |
|       |                |             |       |    |            |          |            |    |

Data is recorded on tape with G4 first and G0 last.

Timing and address information is added by the drive to every block of data in the following sequence:

Sync
 Mark
 Control Byte
 Data Block
 CRC
 Sync

**SYNC** - Designates both the beginning and the end of a data block and its related control signals. The signal is a magnetic flux at 60 times per minute at a density of 10,000frpi.

**MARK** - Indicates the header of a data block and takes on the following pattern. The MSB is on the left.

 G4
 G3
 G2
 G1
 G0
 G4
 G3
 G2
 G1
 G0

 1
 1
 1
 1
 0
 0
 1
 1
 1

**CONTROL BYTE - 8** bits before conversion and 10 bits on tape. The format of the byte before conversion is shown in Figure 3-11.

```
Figure 3-ll
Control Byte
```

```
Bits
```

```
7
      5
         4
            3
               2
   6
                  1
                     0
   L
      1
         1
           1
                  1
                     1
        1
           1
                     Track Number (LSB)
     1
               1
                  1
                  Track Number
     1 1
           1
               1
      1
         L
            I
               Track Number
        Track Number
      1
         Track Number
     1
L
      Track Number (MSB)
1
   1
     = End of track
I
   ٦.
l = File Mark
```

## Table 3-11 Continued

Bits Description

- 7 Set to 1 to indicate a file mark, which divides data segments on tape.
- 6 Set to 1 in the last block of each track except for the last track.
- 5-0 Designates the current track number in binary.

**BLOCK ADDRESS** - Two bytes before conversion and 20 bits after conversion. The control block designates the block address, which starts at 0 for the first block on the tape. This is incremented block-by-block to generate a serial number for each block. On reaching FFFF, the address starts again at 0.

**DATA BLOCK** - 512 bytes before conversion and 5120 bytes after conversion.

**CRC** - Ensures that the conversion process functioned properly by checking that every 16 bits of data before conversion resulted in 20 bits after conversion.

## The IOCB

The Z80A on the tape card communicates with the 80186 through the IOCB (I/O Control Block). The IOCB is an area in main memory that is accessible to both processors and through which commands and status information based on the semaphore set/reset mechanism, are passed.

The pointer to the IOCB consists of four bytes. The first two bytes contain the segment value and the last two the offset. Refer to Figure 3-12.

Figure 3-12 IOCB Pointer

Memory Location

600 - 601H

602 - 603H

OFFSET \_\_\_\_\_\_\_\_\_SEGMENT

To maintain the speed of the streaming tape, two IOCB's should be used. While one IOCB is being processed by the tape card, the 80186 can be setting up the second IOCB for execution by the tape drive. One byte of the IOCB provides status information on and interrupt control for the tape drive. The byte is referred to as the **Status Code**. Refer to Figure 3-13 for the bit assignments to this byte.

## Figure 3-13 Status Code

#### Bits

| 6 | 5                                    | 4                                    | 3     | 2   | 1                                        | 0                                  |                       |                                                  |                                                                        |
|---|--------------------------------------|--------------------------------------|-------|-----|------------------------------------------|------------------------------------|-----------------------|--------------------------------------------------|------------------------------------------------------------------------|
| 1 | 1                                    | 1                                    | ł     | 1   | 1                                        | 1                                  |                       |                                                  | -                                                                      |
| 1 | 1                                    | 1                                    | 1     | I   | х                                        | X                                  | =                     | IOCB                                             | status                                                                 |
| 1 |                                      | 1                                    | 1     | 1   |                                          |                                    |                       |                                                  |                                                                        |
| 1 | ł                                    | 1                                    | I     | In  | ter                                      | ruj                                | pt                    | signa                                            | al                                                                     |
| 1 | 1                                    | 1                                    | 1     |     |                                          | -                                  | •                     | -                                                |                                                                        |
| х | х                                    | x                                    | x     | = D | on '                                     | t d                                | cai                   | re                                               |                                                                        |
|   | 6<br> <br> <br> <br> <br> <br> <br>x | 65<br>   <br>   <br>   <br>   <br>xx | 1 1 1 |     | <br>         <br>         <br>        In | <br>          x<br>          x<br> | <br>          x x<br> | <br>          x x =<br>            Interrupt<br> | <br>            x x = IOCB<br>           <br>          Interrupt signa |

Bits

#### Description

0-1 The 80186 sets bits 0 and 1 to 0 when the IOCB is ready to be processed by the tape card. As the command is being executed, the tape card changes bit 1 to 1. At the completion of the command, the tape card changes both bits to 1 to signal the 80186 that it is ready for a new command.

2 If this bit is set to 0 by the 80186, the tape card will issue an interrupt at the completion of the command. If set to 1, no interrupt will be generated.

3-7 Don't care.

Hardware Programming

3.64

## Tape Commands

)

The tape drive can perform the following ten commands:

Reset the drive
 Drive select (0 - 1)
 Tape drive status
 Rewind the tape
 Erase the tape
 Retension the tape
 Retension the tape
 Read data from tape
 Read file mark
 Read file mark

The IOCB structure for each command along with the command and error codes are discussed in the following pages. **RESET THE DRIVE -** This command resets the tape expansion board.

**IOCB Structure:** 

1 Byte - Command Code 11 Bytes - Not used 1 Byte - Status Code 1 Byte - Error Code 6 Bytes - Drive Status

**Command Code** - contains the code of the command:

| Bits | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|------|---|---|---|---|---|---|---|---|
|      | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

**Status Code** - contains information on the status of the tape drive. Refer to page **3.64** for details on this IOCB byte.

**Brror Code** - If the drive experiences difficulty during the execution of the command, it signals the 80186 by setting one or more of the bits in this byte to 1. Specific information on the nature of the difficulty is obtained in the six bytes of the Drive Status section of the IOCB. **Drive Status** - provides specific information on any problem that the tape drive may have experienced during the execution of a command. For the bit definitions to these six bytes, refer to the Drive Status command.

## **Error Conditions:**

The following error conditions will cause the drive to reject the command.

- Illegal Command The command is issued while the tape drive is performing another operation.
- Illegal Command The command selects more than one drive.
- Unselected Drive The command selects a non-existing drive (i.e. drive 1 when the system has only one drive).
- ) 4. Fault A system error exists.

**DRIVE SELECT** - This command selects the drive to perform a command. This command must be issued whenever the PM system is turned on or reset, even if the system has only one tape drive. The maximum number of tape drives that can be connected to a PM system is two.

**NOTE:** This command must not be issued while a read or write operation is in progress. The command should only be issued once the operation is completed and the tape is rewound.

When a drive is selected with this command and the cassette tape is properly loaded, the LED indicator on the front of the drive should light up.

#### **IOCB Structure:**

1 Byte - Command Code 1 Byte - Drive Number

10 Bytes - Not used

1 Byte - Status Code

1 Byte - Error Code

6 Bytes - Drive Status

ļ

**Command Code** - contains the code of the command:

Bits 7 6 5 4 3 2 1 0 0 0 0 0 0 0 0 1

) **Drive Number** - designates the number of the desired drive. A 0 for this byte selects drive 0, and a 1 drive 1.

**Status Code** - contains information on the status of the tape drive. Refer to page 3.64 for details on this IOCB byte.

**Brror Code** - If the drive experiences difficulty during the execution of the command, it signals the 80186 by setting one or more of the bits in this byte to 1. Specific information on the nature of the difficulty is obtained in the six bytes of the Drive Status section of the IOCB.

**Drive Status** - provides specific information on any problem that the tape drive may have experienced during the execution of a command. For the bit definitions to its six bytes, refer to the Drive Status command.

**Brror Conditions:** 

The following error conditions will cause the drive to reject the command.

- Illegal Command The command is issued while the tape drive is performing another operation.
- Illegal Command The command selects more than one drive.

Hardware Programming

3. Unselected Drive - The command selects a non-existing drive (i.e. drive 1 when the system has only one drive).

4. Fault - A system error exists.

**TAPE DRIVE STATUS -** This command provides status and error information on the tape drive. The information is read from the six bytes of the Drive Status section of the IOCB.

) IOCB Structure:

1 Byte - Command Code 11 Bytes - Not used 1 Byte - Status Code 1 Byte - Error Code 6 Bytes Drive Status

**Command Code** - contains the code of the command:

Bits 7 6 5 4 3 2 1 0 1 1 0 0 0 0 1

**Status Code** - contains information on the status of the tape drive. Refer to page **3.64** for details on this IOCB byte.

**Error Code** - If the drive experiences difficulty during the execution of the command, it signals the 80186 by setting one or more of the bits in this byte to 1. Specific information on the nature of the difficulty is obtained in the six bytes of the Drive Status section of the IOCB.

**Drive Status** - provides specific information on problems that the tape drive may have experienced during the execution of a command. The bit definitions for the bytes are provided below.

Status Byte 0:

Table 3-27 Status Byte 0

```
Bits
```

5 4 3 2 1 0 76 I 1 4 12 - N 1 1 | | | | | = File Mark Detected | | | | 1 = Block Not Located | | 1 1 = Unrecoverable Data Error | | 1 = End of Media 1 1 1 = Write Protected Cassette 1 1 = Unselected Driveł 1 = Cassette Not In Place 1 = Error Flag

## Bit Description

7

Set whenever one of the bits in this status byte is set. The bit is reset with a read status command.

## Table 3-27 Continued

Bit Description

)

- 6 Set when no drive is selected, or if the cassette is not loaded properly.
- 5 Set when a command is issued without a selected drive, or when a non-existing drive is selected.
- 4 Set when a command is issued without a selected drive. This bit is also set if the cassette is not properly loaded or is write protected.
- 3 Set when the BOT (Beginning of Tape) is detected during a write or read operation. The bit is reset with any one of the following commands: rewind the tape, retension the tape, and drive select.
  - 2 Set when a write or read operation fails more than sixteen times on the same data block. The bit is reset with the read status command.
  - 1 Indicates that a block address cannot be read after sixteen attempts. Reset the bit with a read status command.

O Set when a file mark is detected during a read operation, and reset with a read status command. Status Byte 1: Table 3-28 Status Byte 1 Bits 3 2 1 0 7 6 5 4 1 1 1 1 1 1 1 1 = Power/On, Reset 1 1 1 1 1 1 1 1 1 1 = Fault1 ۱ ł 1 Not used 1 = Beginning Of Media 1 1 1 1 = Marginal Block Detected . 1 I 1 1 1 = No Data Detected 1 = Illegal Command L l = Error FlagDescription Bit 7 Indicates that one or more of the bits in this status byte have been set. The bit is reset with a read status command. Indicates that an illegal command 6 has been issued, such as specifying more than one drive or issuing a drive select command during a write operation. Set when a gap of 380 mm has been 5 detected during a read operation. Set when a write operation fails 4 after more than eight attempts in the same block. The bit is also set after the drive has stored all of the received data. Indicates that the tape is 3 located on the BOT clear reader tape of Track 0.

#### Hardware Programming

3.74

## Table 3-28 Continued

### Bits Description

2 Not used.

- Set when a error occurs that is not related to a read or write operation. Sources of such errors include ROM, RAM, and the buffer.
  - O Set whenever the Persoal Mini is turned on or reset. The bit is reset with the read status command.

Status Bytes 2 and 3: Data Error Counter:

Status bytes 2 and 3 provide a 16-bit binary counter. Transferred to the system with the MSB first, the counter is incremented whenever an error is encountered during a read or write operation.

Status Bytes 4 and 5: Underrun/Overrun Counter:

Status bytes 4 and 5 also provide a 16-bit binary counter. Transferred to the system with the MSB first, the counter is incremented whenever there is an overrun of the buffer during a read operation, or an underrun during a write operation.

**REWIND THE TAPE** - This command rewinds the tape back to the BOT.

**IOCB Structure:** 

| <br>  1 Byte - Command Code  <br> |
|-----------------------------------|
| <br>  ll Bytes - Not used         |
| <br>  1 Byte - Status Code  <br>  |
| <br>  1 Byte - Error Code         |
| <br>  6 Bytes - Drive Status<br>  |

**Command Code** - contains the code of the command:

| Bits | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|------|---|---|---|---|---|---|---|---|
|      | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 1 |

**Status Code** - contains information on the status of the tape drive. Refer to page 3.64 for details on this IOCB byte.

**Brror Code** - If the drive experiences difficulty during the execution of the command, it signals the 80186 by setting one or more of the bits in this byte to 1. Specific information on the nature of the difficulty is obtained in the six bytes of the Drive Status section of the IOCB.

3.76

**Drive Status** - provides specific information on any problem that the tape drive may have experienced during the execution of a command. For the bit definitions to its six bytes, refer to the Drive Status command.

#### **Brror Conditions:**

The tape drive will reject this command if any of the following conditions exist when the command is issued.

- Unselected Drive The drive select command was not issued.
- Cassette Not In Place The cassette is not properly loaded in the drive.
- 3. Fault A system error exists.

The tape drive will reject the command if any of the following conditions occur during its execution.

- Cassette Not In Place The cassette is ejected.
- 2. Fault The drive is unable to start the tape.

**BRASE THE TAPE** - This command, which can be executed at any tape position, erases all of the data on the tape. At the completion of the command, the drive rewinds the tape back to the BOT.

**IOCB Structure:** 

| <br>  1 byte - Command Code<br> |
|---------------------------------|
| <br>  ll bytes - Not used<br>   |
| <br>  1 byte - Status Code<br>  |
| <br>  1 byte - Error Code       |
| <br>  6 bytes - Device Stat<br> |
| <br>  6 bytes - Not used<br>    |

**Command Code** - contains the code of the command:

| Bits | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|------|---|---|---|---|---|---|---|---|
|      | 0 | 0 | 1 | 0 | 0 | 0 | 1 | 0 |

**Status Code** - contains information on the status of the tape drive. Refer to page 3.64 for details on this IOCB byte.

**Brror Code** - If the drive experiences difficulty during the execution of the command, it signals the 80186 by setting one or more of the bits in this byte to 1. Specific information on the nature of the difficulty is obtained in the six bytes of the Drive Status section of the IOCB.

**Drive Status** - provides specific information on any problem that the tape drive may have experienced during the execution of a command. For the bit definitions to its six bytes, refer to the Drive Status command.

#### **Brror Conditions:**

The drive will reject this command if any of the following conditions exist at the time the command is issued.

- ) 1. Unselected Drive The drive select command was not issued.
  - Cassette Not In Place The cassette tape is not properly loaded in the drive.
  - 3. Write Protected Cassette The tape is write protected.
  - Illegal Command A read operation is being performed.
  - 5. Fault A system error exists.

## Hardware Programming

The drive will abort the command if any of the following conditions occur during the execution of the command.

- Cassette Not In Place The cassette tape is ejected.
- 2. Fault, Timeout The tape drive is unable to start the tape.
- 3. Fault, Drive Fault The drive's erase head fails to operate properly.

**RETENSION THE TAPE** - This command, which can be run at any tape location, ensures that the tape is wound at the proper tension by running it to the EOT and then by rewinding back to the BOT.

**IOCB Structure:** 

1 byte - Command Code 11 bytes - Not used 1 byte - Status Code 1 byte - Error Code 6 bytes - Drive Status 6 bytes - Not used

**Command Code** - contains the code of the command:

Bits 7 6 5 4 3 2 1 0 0 0 1 0 0 1 0 0

**Status Code** - contains information on the status of the tape drive. Refer to page 3.64 for details on this IOCB byte.

**Brror Code** - If the drive experiences difficulty during the execution of the command, it signals the 80186 by setting one or more of the bits in this byte to 1. Specific information on the nature of the difficulty is obtained in the six bytes of the Drive Status section of the IOCB.

**Drive Status** - provides specific information on any problem that the tape card may have experienced during the execution of a command. For the bit definitions to its six bytes, refer to the Drive Status command.

#### **Brror Conditions:**

The following error conditions will cause the tape drive to reject the command.

- Unselected Drive The drive select command was not issued.
- 2. Cassette Not In Place The cassette tape is not loaded properly.
- 3. Fault A system error exists.

The following error conditions will cause the command to abort.

- Unselected Drive The cassette is ejected.
- Fault, Timeout The drive is unable to start the tape.

### Hardware Programming

Ĵ

WRITE DATA TO TAPE - This command writes data from the hard disk onto the cassette tape, which consists of four tracks, numbered from 0 to 3.

# **IOCB Structure:**

| l Byte - Command Code                      |
|--------------------------------------------|
| l Byte - Reference Point                   |
| 2 Bytes - Number of<br>Segments to Skip    |
| 2 Bytes - Real Starting<br>Segment Number  |
| 2 Bytes - Number of Blocks<br>to Transfer  |
| <b>4</b> Bytes - Pointer to Data<br>Buffer |
| l Byte - Status Code                       |
| l Byte - Error Code                        |
| 6 Bytes - Drive Status                     |

When the drive is writing data on track 0, it erases the old data prior to storing the new. It also checks to issue accurate data storage by performing a Read after Write Check error detection operation. If an error is detected, the write operation is retried up to sixteen times. The Data Error Counter in the Drive Status section of the IOCB is incremented every time an error is encountered.

**Command Code** - contains the code of the command:

| Bits | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|------|---|---|---|---|---|---|---|---|
|      | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 |

**Reference Point** - designates the starting point for the operation. If the drive is reset or if a new cassette is loaded, a 0 is written into this byte to indicate that the starting point is the BOT. Otherwise, the byte is written with a 1 to indicate the current tape position.

Number of Segments to Skip - specifies the number of segments the drive is to skip prior to performing the read operation.

**Real Starting Segment Number** - contains the actual number of segments the drive skipped prior to starting the write operation. The value here can be compared with the value in Number of Segments to Skip to insure that the drive is at the proper location.

**Status Code** - contains information on the status of the tape drive. Refer to page 3.64 for details on this IOCB byte.

**Brror Code** - If the drive experiences difficulty during the execution of the command, it signals the 80186 by setting one or more of the bits in this byte to 1. Specific information on the nature of the difficulty is obtained in the six bytes of the Drive Status section of the IOCB.

**Drive Status** - provides specific information on any problem that the tape card may have experienced during the execution of a command. For the bit definitions to its six bytes, refer to the Drive Status command.

Number of Segments Skipped - contains the number of segments the drive skipped prior to starting the operation. The value of these two bytes can be checked against the two bytes in Number of Segments to Skip to ensure that the drive is located at the proper segment.

## **Brror Conditions:**

The tape drive will reject the command if any of the following error conditions exist.

- Unselected Drive The drive select command was not issued.
- Cassette Not In Place The tape cassette is not properly loaded.
- 3. Write Protected Cassette The cassette is write protected.
- 4. Fault A system error has occurred.

The following error conditions abort the execution of the command.

- Cassette Not In Place The cassette is ejected.
- 2. Fault, Timeout The drive is unable to start the tape.
- 3. Marginal Block Detected A rewrite operation is repeated more than eight times for the same block. To continue the write operation, issue the write command again.

#### Hardware Programming

- 4. Unrecoverable Data Error A rewrite operation is repeated more than sixteen times to the same block. The occurrence of this error causes the drive to rewind the tape automatically.
- 5. End Of Media The end of the tape is detected.

)

)

 Fault, Drive Fault - The drive's erase head fails to operate during the write operation on Track 0.

All other commands can be executed during a write operation. The only exception is the erase the tape command which will only function on Track 0.

**READ DATA FROM TAPE** - This command reads data from the cassette and transfers it to the Personal Mini.

## **IOCB Structure:**

The IOCB for this command consists of two parts: the main portion with its vector address at 600H, and a sub-IOCB with its vector address located in the main IOCB.

| 1 Byte - Command Code                      |
|--------------------------------------------|
| l Byte - Reference Point                   |
| 2 Bytes - Number of<br>Segments to Skip    |
| 4 Bytes - Pointer to<br>Sub-IOCB           |
| <b>4</b> Bytes - Pointer to Data<br>Buffer |
| l Byte - Status Code                       |
| 1 Byte - Error Code                        |
| 6 Bytes - Drive Status                     |
| 2 Bytes - Number of Blocks<br>Transferred  |
|                                            |

2 Bytes - Number of the Starting Block

2 Bytes - Number of Blocks to Read

If an error is detected during the read operation, the operation can be retried up to sixteen times. The retry includes the block containing the error and two or more succeeding blocks, or until a gap of 35 inches is detected. The Data Error Counter is incremented every time a data error is detected.

**Command Code** - contains the code of the command:

| Bits | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|------|---|---|---|---|---|---|---|---|
|      | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

**Reference Point** - designates the starting point for the operation. If the drive is reset or if a new cassette is loaded, a 0 is written into this byte to indicate that the starting point is the BOT. Otherwise, the byte is written with 1 to indicate that the operation is to start at the current tape position.

Number of Segments to Skip - specifies the number of segments the drive is to skip prior to performing the read operation.

**Pointer to IOCB** - contains the address in main memory where the second portion of the IOCB is located.

## Hardware Programming

**Pointer to Data Buffer** - contains the address in main memory where the data is to be transferred from the tape drive.

**Status Code** - contains information on the status of the tape drive. Refer to page 3.64 for details on this IOCB byte.

**Brror Code** - If the drive experiences difficulty during the execution of the command, it signals the 80186 by setting one or more of the bits in this byte to 1. Specific information on the nature of the difficulty is obtained in the six bytes of the Drive Status section of the IOCB.

**Drive Status** - provides specific information on any problem that the tape card may have experienced during the execution of a command. For the bit definitions to its six bytes, refer to the Drive Status command.

Number of Blocks Transferred - contains the number of blocks of data transferred by the drive to the data buffer.

Number of the Starting Block - contains the address of the first block of data that the drive is to read from the tape.

Number of Blocks to Read - contains the number of blocks the drive is to read during the operation.

### Error Conditions:

)

)

The drive will reject this command if any of the following error conditions exist at the time the command is issued.

- Unselected Drive The drive select command was not issued.
- Cassette Not In Place The cassette is not loaded properly in the drive.
- 3. Illegal Command The drive is performing a write operation.

The drive will abort the command if any of the following error conditions occur during the execution of the command.

- Cassette Not In Place The cassette is ejected.
- 2. Fault, Timeout The drive is unable to start the tape.
- 3. Unrecoverable Data Error The drive fails to read a block of data without error after sixteen attempts.
- No Data Detected The drive detects a gap of 380 mm with no data.
- 5. No Data Detected, End Of Media The drive encountered the BOT clear reader tape on the last track.
- File Mark Detected The drive detects a file mark.
- 7. Fault, BOT, EOT The clear leader tape is detected before the last block from each track is read.

#### Hardware Programming

3.91

WRITE FILE MARK - This command writes a file mark to divide major segments of data on tape. If the file mark is being written on track 0, the erase head is activated causing the tracks to be erased before the file marks are written.

### **IOCB Structure:**

| 1 Byte - Command Code                   |
|-----------------------------------------|
| l Byte - Reference Point                |
| 4 Bytes - Not used                      |
| 2 Bytes - Number of<br>Segments to Skip |
| 4 Bytes - Not used                      |
| l Byte - Status Code                    |
| l Byte - Error Code                     |
| 6 Bytes - Drive Status                  |
| 2 Bytes - Number of<br>Segments Skipped |

**Command Code** - contains the code of the command:

Bits 7 6 5 4 3 2 1 0 0 1 1 0 0 0 0 0

)

)

**Reference Point** - designates the starting point for the operation. If the drive is reset or a new cassette is loaded, this byte is written with 0 to indicate the BOT. Otherwise, the byte is written with 1 to indicate the current tape location.

Number of Segments to Skip - specifies the number of segments the drive is to skip prior to performing the read operation.

**Status Code** - contains information on the status of the tape drive. Refer to page 3.64 for details on this IOCB byte.

**Brror Code** - If the drive experiences difficulty during the execution of the command, it signals the 80186 by setting one or more of the bits in this byte to 1. Specific information on the nature of the difficulty is obtained in the six bytes of the Drive Status section of the IOCB.

**Drive Status** - provides specific information on any problem that the tape card may have experienced during the execution of a command. For the bit definitions to the six bytes, refer to the Drive Status command. Number of Segments Skipped - contains the number of segments the drive skipped prior to starting the operation. The value of these two bytes can be checked against the two bytes in Number of Segments to Skip to ensure that the drive is located at the proper segment.

#### Brror Conditions:

The drive will reject the command if any of the following error conditions exist at the time the command is issued.

- Unselected Drive The drive select command was not issued.
- 2. Cassette Not In Place The cassette is not properly loaded in the drive.
- 3. Write Protected Cassette The cassette is write protected.

If any of the following error conditions occur during the execution of the command, the drive will abort the operation.

- Cassette Not In Place The cassette is ejected.
- Fault, Timeout The drive is unable to start the tape.
- Marginal Block Detected The drive is unable to write the file mark after eight attempts.
- 4. Unrecoverable Data Error The drive is unable to write the file mark after sixteen attempts. If this error occurs, the drive will automatically rewind the tape.

## Hardware Programming

3.94

)

)

- 5. End of Media The drive encountered the BOT on the last track.
- 6. Drive Fault The erase head on the drive failed to operate.

) :

)

)

## Hardware Programming

**READ FILE MARK** - This command runs the tape until it encounters a file mark.

**IOCB Structure:** 

| l Byte - Command Code                     |
|-------------------------------------------|
| l Byte - Reference Point                  |
| 4 Bytes - Not used                        |
| 2 Bytes - Number of<br>Segments to Skip   |
| 4 Bytes - Not used                        |
| l Byte - Status Code                      |
| l Byte - Error Code                       |
| 6 Bytes - Drive Status                    |
| 2 Bytes - Number of  <br>Segments Skipped |

**Command Code** - contains the code of the command:

Bits 7 6 5 4 3 2 1 0 1 0 1 0 0 0 0 0

## Hardware Programming

**Reference Point** - designates the starting point for the operation. If the drive is reset or if a new cassette is loaded, this byte is written with 0 to indicate the BOT. Otherwise, the byte is written with 1 to indicate the current tape location.

Number of Segments to Skip - specifies the number of segments the drive is to skip prior to performing the read operation.

**Status Code** - contains information on the status of the tape drive. Refer to page 3.64 for details on this IOCB byte.

**Brror Code** - If the drive experiences difficulty during the execution of the command, it signals the 80186 by setting one or more of the bits in this byte to 1. Specific information on the nature of the difficulty is obtained in the six bytes of the Drive Status section of the IOCB.

**Drive Status** - provides specific information on any problem that the tape card may have experienced during the execution of a command. For the bit definitions to its six bytes, refer to the Drive Status command.

Number of Segments Skipped - contains the number of segments the drive skipped prior to starting the operation. The value of these two bytes can be checked against the two bytes in Number of Segments to Skip to insure that the drive is located at the proper segment.

# **Error Conditions:**

The drive will reject the command if any of the following conditions exist at the time the command is issued.

- Unselected Drive The drive select command was not issued.
- 2. Cassette Not In Place The cassette is not properly loaded in the drive.
- 3. Illegal Command The drive is performing a write operation.
- 4. Fault A system error exists.

The drive will terminate the command if any of the following error conditions occur during its execution.

- Cassette Not In Place The cassette is ejected.
- Fault, Timeout The drive is unable to start the tape.
- Unrecoverable Data Error The drive fails to read the file mark after sixteen attempts. The drive responds to this error by rewinding the tape.

)

# 4. INTERFACE

)

This chapter describes the internal connector interfaces and external connector ports. These ports provide the means to expand or perform major internal functions while allowing external system expansion. This section is divided into internal and external interfaces.

There are two connectors located on the tape expansion board. Pl can be connected to either the Xl or X2 expansion slot. P2 is connected to the tape drive controller board. A second P2 connector, located on the main board, is the hard disk expansion connector.

### INTERNAL INTERFACES

| Table<br>Power                                  | 4-1<br>Supply (Pl)                                            |                                                                                                                                  |
|-------------------------------------------------|---------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------|
| Pin                                             | Signal                                                        | Description                                                                                                                      |
| 1<br>2<br>3<br>4<br>5<br>6<br>7<br>8<br>9<br>10 | -12V<br>GND<br>+5V<br>+12V<br>GND<br>GND<br>+5V<br>GND<br>+5V | -l2v supply<br>Polarization key<br>Ground<br>+5v supply<br>+l2v supply<br>Ground<br>Ground<br>+5v supply<br>Ground<br>+5v supply |

4.1

# Table 4-2 Tape Drive Expansion Board (P2)

**NOTE:** This P2 connector is located on the Tape Drive Expansion Board and connects to the tape controller board found on the tape drive.

| Pin | Signal      | Description           |
|-----|-------------|-----------------------|
| 2   |             | No connection         |
| 4   |             | No connection         |
| 6   |             | No connection         |
| 8   |             | No connection         |
| 10  | HBP         | Host bus odd parity   |
| 12  | нв7         | Host bus bit 7 (MSB)  |
| 14  | HB <b>6</b> | Host bus bit 6        |
| 16  | HB5         | Host bus bit 5        |
| 18  | HB <b>4</b> | Host bus bit <b>4</b> |
| 20  | HB3         | Host bus bit 3        |
| 22  | HB2         | Host bus bit 2        |
| 24  | HBl         | Host bus bit l        |
| 26  | нво         | Host bus bit 0 (LSB)  |
| 28  | ONL         | Online                |
| 30  | REQ         | Request               |
| 32  | RST         | Reset                 |
| 34  | XFR         | Transfer              |
| 36  | ACK         | Acknowledge           |
| 38  | RDY         | Ready                 |
| 40  | EXC         | Exception             |
| 42  | DIR         | Direction             |
| 44  |             | No connection         |
| 46  |             | No connection         |
| 48  |             | No connection         |
| 50  |             | No connection         |

All odd numbered pins are connected to ground.

Table 4-3 Expansion Card Slot (P7)

| Pin          | Signal        | Description                      |
|--------------|---------------|----------------------------------|
| Al           | +5V           | +5v supply                       |
| A2           | +5V           | +5v supply                       |
| A3           | +12V          | +12v supply                      |
| A4           | -XWR          | Write enable                     |
| A5           | -XIORQ        | I/O request                      |
| AG           | -XRD          | Read enable                      |
| A7           | -XZ RESET     | Expansion card reset             |
| <b>A8</b>    | X USE MAP     | High, uses mapper                |
|              |               | Low, bypasses mapper             |
| A9           | -XRFSH        | Expansion memory                 |
|              |               | refresh                          |
| A10          | X BYTE        | High, 1 byte data bus            |
|              |               | Low, 2 byte data bus             |
| A11          | -XM1          | Inverted Z80 M1 output           |
| A12          | XZ SYS CLK    | 4 MHz clock signal               |
| A13          | X CLK OUT     | 8 MHz clock signal               |
| ) <b>Al4</b> |               | I/O write to address             |
| )            |               | <b>%0290</b>                     |
| A15          | SPARE 6       | I/O write to address             |
|              |               | <b>%0280</b>                     |
| A16          | SPARE 5       | I/O write to address             |
|              |               | <b>%0A</b>                       |
| A17          | XD 15         | Data bit 15                      |
| A18          | XD 14         | Data bit 14                      |
| A19          | XD 13         | Data bit 13                      |
| A20          | XD 12         | Data bit 12                      |
| A21          | XD 11         | Data bit ll                      |
| A22          | XD 10         | Data bit 10                      |
| A23          | XD 9          | Data bit <b>9</b>                |
| A24          | XD 8          | Data bit 8                       |
| A25          | SA 12         | Address bit 12                   |
| A26          | SA 13         | Address bit 13                   |
| A27          | SA 1 <b>4</b> | Address bit 14                   |
| A28          | SA 15         | Address bit 15                   |
| A29          | SA 16         | Address bit 16<br>Address bit 17 |
| A30          | SA 17         | Address bit 17                   |
| A31          | SA 18         | Address bit 18                   |
| A32          | SA 19         | Address bit 19                   |

• )

# Table 4-3 continued

| Pin        | Signal         | Description                  |
|------------|----------------|------------------------------|
| Bl         | +5V            | +5v supply                   |
| B2         | +5V            | +5v supply                   |
| B3         | -12V           | -12v supply                  |
| B4         | -12V           | -12v supply                  |
| B5         | -ANY X2        | X2 board installed           |
| B6         | -XMREQ         | Memory request               |
| B7         | -X1 BUSAK      | Expansion bus                |
|            |                | acknowledge                  |
| B8         | -BUSAK OUT     | Bus request from X2          |
| B <b>9</b> | -INTA Z TO X1  | Interrupt acknowledge        |
| B10        | GND            | Ground                       |
| B11        | XZ WAIT        | Wait request                 |
| B12        | GND            | Ground                       |
| B13        | -INT X2 TO 186 | Interrupt request            |
| B14        | GND            | Ground                       |
| B15        | -INT X1 TO Z   | Interrupt request to<br>CTC  |
| B16        | GND            | Ground                       |
| B17        | -X1 BUSAK      | Interrupt                    |
|            |                | acknowledge from<br>80186    |
| B18        | GND            | Ground                       |
| B19        | -X BUS REQ     | Interrupt request to<br>CTC  |
| B20        | GND            | Ground                       |
| B21        | -X LOCK        | Memory lock request          |
| B22        | GND            | Ground                       |
| B23        |                | Not used                     |
| B24        | GND            | Ground                       |
| B25        | -INT X2 TO Z   | Interrupt request to<br>280A |
| B26        | GND            | Ground                       |
| в27        | TIMER 1        | 80186 timer output           |
| B28        | GND            | Ground                       |
| B29        | TIMER O        | 80186 timer output           |

)

)

| Table      | 4-3 continued   |                                                                               |
|------------|-----------------|-------------------------------------------------------------------------------|
| Pin        | Signal          | Description                                                                   |
| B30        | -INTA 186 TO X2 | Interrupt<br>acknowledge from<br>80186                                        |
| B31        | -INT 186 TO X2  |                                                                               |
| B32        | -INTA X2 TO 186 | Interrupt                                                                     |
|            | _               | acknowledge to 80186                                                          |
| C1         | +5V             | +5v supply                                                                    |
| C2         | +5V             | +5v supply                                                                    |
| C3         | +12V            | +12v supply                                                                   |
| C4         | XD 0            | Data bus bit 0                                                                |
| C5<br>C6   | XD 1            | Bus bit 1                                                                     |
| C0<br>C7   | XD 2<br>XD 3    | Data bus bit 2<br>Data bus bit 3                                              |
| C8         | XD 3<br>XD 4    | Data bus bit 4                                                                |
| C9         | XD 5            | Data bus bit 5                                                                |
| C10        |                 | Data bus bit 6                                                                |
| C11        | XD 7            | Data bus bit 7                                                                |
| C12        | SPARE 3         | I/O read in bit 6 at                                                          |
|            |                 | address %08                                                                   |
| C13        | SPARE 2         | Data bus bit 7<br>I/O read in bit 6 at<br>address %08<br>I/O read in bit 5 at |
|            |                 | address %08                                                                   |
| C14        | SPARE 1         | I/O read in bit 4 at                                                          |
|            |                 | address %08                                                                   |
| C15        | SPARE 0         | 1/0 read in bit 3 at                                                          |
|            |                 | address %08                                                                   |
| C16        | -INTA Z TO X2   | Interrupt                                                                     |
| <b>7</b>   | V7 15           | acknowledge from Z80                                                          |
| C17<br>C18 | XZ 15           | Address bit 15                                                                |
| C18<br>C19 | XZ 14<br>XZ 13  | Address bit 14<br>Address bit 13                                              |
| C19<br>C20 | XZ 13<br>XZ 12  | Address bit 13<br>Address bit 12                                              |
| C20<br>C21 | XZ 12<br>XZ 11  | Address bit 12<br>Address bit 11                                              |
|            |                 | Address bit 10                                                                |
| C22<br>C23 | XZ 9            | Address bit 9                                                                 |
| C23        | XZ 8            | Address bit 8                                                                 |
| C24<br>C25 | XZA 7           | Address bit 7                                                                 |
| 645        | 42 44 CZ /      | HUALODD DIC /                                                                 |

)

)

)

4.5

# Table 4-3 continued

| Pin | Signal | Description   |
|-----|--------|---------------|
| C26 | XZA 6  | Address bit 6 |
| C27 | XZA 5  | Address bit 5 |
| C28 | XZA 4  | Address bit 4 |
| C29 | XZA 3  | Address bit 3 |
| C30 | XZA 2  | Address bit 2 |
| C31 | XZA l  | Address bit 1 |
| C32 | XZA O  | Address bit 0 |

# Table 4-4 Expansion Card Slot (P8)

| Pin       | Signal     | Description                               |
|-----------|------------|-------------------------------------------|
| Al        | +5V        | +5v supply                                |
| A2        | +5V        | +5v supply                                |
| A3        | +12V       | +12v supply                               |
| A4        | -XWR       | Write enable                              |
| A5        | -XIORQ     | I/O request                               |
| A6        | –XRD       | Read enable                               |
| A7        | -XZ RESET  | Expansion card reset                      |
| <b>A8</b> | X USE MAP  | High, uses mapper<br>Low, bypasses mapper |
| A9        | -XRFSH     | Expansion memory<br>refresh               |
| A10       | X BYTE     | High, 1 byte data<br>bus                  |
|           |            | Low, 2 byte data bus                      |
| A11       | -XM1       | Inverted Z80 M1<br>output                 |
| A12       | XZ SYS CLK | 4 MHz clock signal                        |
| A13       | X CLK OUT  | 8 MHz clock signal                        |
| A14       |            | I/O write to address<br>%0290             |
| A15       | SPARE 6    | I/O write to address<br>%0280             |

|   | Table      | 4-4 continued  |                                  |
|---|------------|----------------|----------------------------------|
|   | Pin        | Signal         | Description                      |
| 1 | A16        | SPARE 5        | I/O write to address<br>%0A      |
| ) | A17        | XD 15          | Data bit 15                      |
|   | A18        | XD 14          | Data bit 1 <b>4</b>              |
|   | A19        | XD 13<br>XD 12 | Data bit 13                      |
|   | A20        | XD 12          | Data bit 12                      |
|   |            | XD 11          | Data bit ll                      |
|   |            | XD 10          | Data bit 10                      |
|   | A23        | XD 9           | Data bit 9                       |
|   |            | XD 8           | Data bit 8                       |
|   | A25        | SA 12          | Address bit 12                   |
|   | A26        | SA 13          | Address bit 13                   |
|   | A27        | SA 14          | Address bit 14                   |
|   | A28        | SA 15          | Address bit 15                   |
|   | A29<br>A30 | SA 16<br>Sa 17 | Address bit 16<br>Address bit 17 |
|   | A30<br>A31 | SA 17<br>SA 18 | Address bit 17<br>Address bit 18 |
|   | A32        | SA 19          | Address bit 19                   |
|   | Bl         | +5V            | +5v supply                       |
| ) | B2         | +5V            | +5v supply                       |
|   | B3         | -12V           | -12v supply                      |
|   | B4         | -12V           | -12v supply                      |
|   | B5         | -ANY X1        | X1 board installed               |
|   | B6         | -XMREQ         | Memory request                   |
|   | B7         | -BUSAK IN      | Daisy chain bus                  |
|   |            |                | acknowledge                      |
|   | B8         |                | Not used                         |
|   | B <b>9</b> | INTA Z TO X1   | Interrupt                        |
|   |            |                | acknowledge                      |
|   | B10        | GND            | Ground                           |
|   | B11        | XZ WAIT        | Wait request                     |
|   | B12        | GND            | Ground                           |
|   | B13        | -INT TO 186    | Interrupt request                |
|   | B14        | GND            | Ground                           |
| ) | B15        | -INT X1 TO Z   | Interrupt request to<br>CTC      |
|   | B16        | GND            | Ground                           |

Table 4-4 continued Signal Pin Description **B17** X1 BUSAK Expansion bus acknowledge B18 GND Ground B19 -X BUS REO Bus request to Z80 GND B20 Ground **B21** -X LOCK Memory lock request B22 GND Ground **B23** Not used \_\_\_\_ B24 GND Ground B25 -INT X2 TO Z Interrupt request to CTC **B26** GND Ground B27 TIMER 1 80186 timer output B28 GND Ground B29 TIMER O 80186 timer output -INTA 186 TO X1 Interrupt request to **B30** 80186 **B31** -INT 186 TO X1 Interrupt request to 80186 **B32** -INTA X1 TO 186 Interrupt acknowledge to 80186 **C1** +5v supply +5V C2 +5V +5v supply C3 +12V +12v supply C4 XD 0 Data bit 0 **C5** XD 1 Data bit 1 **C6** XD<sub>2</sub> Data bit 2 **C7** XD 3 Data bit 3 XD 4 Data bit 4 **C8** XD 5 **C9** Data bit 5 C10 XD 6 Data bit 6 **C11** XD 7 Data bit 7 C12 SPARE 3 I/O read on bit 6 at address %08 C13 SPARE 2 I/O read on bit 5 at address %08

| Table 4-4 continued                                  |                                                                      |                                                                                                                                                                                                    |  |
|------------------------------------------------------|----------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Pin                                                  | Signal                                                               | Description                                                                                                                                                                                        |  |
| C14                                                  | SPARE 1                                                              | I/O read on bit 4 at<br>address %08                                                                                                                                                                |  |
| C15                                                  | SPARE 0                                                              | I/O read on bit 3 at<br>address %08                                                                                                                                                                |  |
| C16                                                  | -INTA Z TO X2                                                        | Interrupt                                                                                                                                                                                          |  |
| C17<br>C18<br>C19<br>C20<br>C21<br>C22<br>C23<br>C24 | XZ 15<br>XZ 14<br>XZ 13<br>XZ 12<br>XZ 11<br>XZ 10<br>XZ 9<br>XZ 8   | acknowledge from 280<br>Address bus bit 15<br>Address bus bit 14<br>Address bus bit 13<br>Address bus bit 12<br>Address bus bit 11<br>Address bus bit 10<br>Address bus bit 9<br>Address bus bit 8 |  |
| C25<br>C26<br>C27<br>C28<br>C29<br>C30<br>C31<br>C32 | XZA 7<br>XZA 6<br>XZA 5<br>XZA 4<br>XZA 3<br>XZA 2<br>XZA 1<br>XZA 0 | Address bus bit 7<br>Address bus bit 6<br>Address bus bit 5<br>Address bus bit 4<br>Address bus bit 3<br>Address bus bit 2<br>Address bus bit 1<br>Address bus bit 0                               |  |

Table 4-5

)

i

Floppy Disk Drive (P9)

Pin Signal Description 1 - 4Not used 6 -DR SEL 3 Select drive 3 8 -INDEX Index mark -DR SEL 0 Select drive 0 10 12 -DR SEL 1 Select drive 1 14 -DR SEL 2 Select drive 2 ) 16 -MOTOR ON Start drive motor 18 -DIR Low, stepping in High, stepping out

# Table 4-5 continued

| Pin      | Signal                 | Description                        |
|----------|------------------------|------------------------------------|
| 20<br>22 | -STEP<br>-COMP WR DATA | Step pulse<br>Composite write data |
| 24<br>26 | -WR EN<br>-TR 00       | Write Enable<br>Head on track 00   |
| 28       | -WR PROT               | Write protect                      |
| 30       | -COMP RD DATA          | Composite read data                |
| 32       | -SIDE SELECT           | Low, side l<br>High, side 2        |

Table 4-6

Memory Expansion Board (P10)

| Pin | Signal   | Description       |
|-----|----------|-------------------|
| Al  | RAMDO 7  | Data output bit 7 |
| A2  | RAMDO 5  | Data output bit 5 |
| A3  | RAMDO 3  | Data output bit 3 |
| A4  | GND      | Ground            |
| A5  | RAMDO 1  | Data output bit 1 |
| A6  | -RAS 2   | Bank 2 RAS        |
| A7  | -RAS 3   | Bank 3 RAS        |
| A8  |          | Not used          |
| A9  | RAMDI 1  | Data input bit l  |
| A10 | RAMDI 3  | Data input bit 3  |
| A11 | +5V      | +5v supply        |
| A12 | RAMDI 5  | Data input bit 5  |
| A13 | RAMDI 7  | Data input bit 7  |
| A14 | GND      | Ground            |
| A15 | GND      | Ground            |
| A16 | -CAS 1   | Bank 1 CAS        |
| A17 | -RAS 1   | Bank 1 RAS        |
| A18 | RAMA 8   | Address bit 8     |
| A19 | RAMDI 9  | Data input bit 9  |
| A20 | RAMDI 11 | Data input bit 11 |
| A21 | +5V      | +5v supply        |
| A22 | RAMDI 13 | Data input bit 13 |

|        | Table                           | 4-6 continued                         |                                                                                                      |
|--------|---------------------------------|---------------------------------------|------------------------------------------------------------------------------------------------------|
|        | Pin                             | Signal                                | Description                                                                                          |
| 、<br>、 | A23<br>A24                      | RAMDI 15<br>GND                       | Data input bit 15<br>Ground                                                                          |
| )      | A25<br>A26<br>A27<br>A28<br>A29 | RAMDO 13<br>RANDO 11<br>AMDO <b>9</b> | Data output bit 15<br>Data output bit 13<br>Data output bit 11<br>Data output bit 9<br>Address bit 6 |
|        | A30<br>A31<br>A32               | RAMA O<br>Rama 2<br>Rama 1            | Address bit 0<br>Address bit 2<br>Address bit 1                                                      |
|        | C1<br>C2<br>C3<br>C4            | RAMDO 6<br>RAMDO 4<br>RAMDO 2<br>GND  | Data output bit 6<br>Data output bit 4<br>Data output bit 2<br>Ground                                |
|        | C5<br>C6<br>C7<br>C8            | RAMDO 0<br>-CAS 3<br>-CAS 2           | Data output bit 0<br>Bank 3 CAS<br>Bank 2 CAS<br>Not used                                            |
| )      | C9<br>C10<br>C11                | RAMDI 2<br>+5V                        | Data input bit 0<br>Data input bit 2<br>+5v supply                                                   |
|        | C12<br>C13<br>C14<br>C15        | RAMDI 4<br>RAMDI 6<br>GND<br>GND      | Data input bit 4<br>Data input bit 6<br>Ground<br>Ground                                             |
|        | C16<br>C17                      | HIGH WR 2                             | Not used<br>High byte write<br>enable 2                                                              |
|        | C18                             | LOW WR 2                              | Low byte write enable<br>2                                                                           |

)

# Table 4-7

# Hard Disk Controller (P21)

| Pin                                          | Signal                                                | Description                                                                                                                       |
|----------------------------------------------|-------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 1<br>3<br>5<br>7<br>9<br>11<br>13            | WD 0<br>WD 1<br>WD 2<br>WD 3<br>WD 4<br>WD 5<br>WD 6  | Data bus bit 0<br>Data bus bit 1<br>Data bus bit 2<br>Data bus bit 3<br>Data bus bit 4<br>Data bus bit 5<br>Data bus bit 6        |
| 15<br>17<br>19<br>21<br>23                   | WD 7<br>WA 0<br>WA 1<br>WA 2<br>-WCS                  | Data bus bit 7<br>Address bus bit 0<br>Address bus bit 1<br>Address bus bit 2<br>Controller chip<br>select                        |
| 25<br>27<br>29<br>31<br>33<br>35<br>37<br>39 | -WWE<br>-WRE<br><br>8 MHZCK<br>WINTRQ<br>WDRQ<br>-WMR | Write enable<br>Read enable<br>Not used<br>Not used<br>8 megahertz clock<br>Interrupt request<br>Data request<br>Controller reset |

All even-numbered pins are connected to ground.

Ĺ

# EXTERNAL INTERFACES

)

. )

)

| Table 4-8<br>Hard Disk<br>(P22)                                                                 |                                                                                                 | <b>Expansion</b>                                                                                                                                                          | (P2) And Hard Disk Data                                                                                                                                                                                                                                                                                                      |  |
|-------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| P22<br>Pin                                                                                      | P2<br>Pin                                                                                       | Signal                                                                                                                                                                    | Description                                                                                                                                                                                                                                                                                                                  |  |
| 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 | 1<br>14<br>2<br>15<br>3<br>16<br>4<br>17<br>5<br>18<br>6<br>19<br>7<br>20<br>8<br>21<br>9<br>22 | MFMWR<br>-MFMWR<br>GND<br>GND<br>MFMRD<br>-MFMRD<br>MFMWR<br>GND<br>GND<br>MFMRD<br>-MFMRD<br>GND<br>GND<br>MFMWR<br>GND<br>GND<br>MFMWR<br>GND<br>GND<br>MFMRD<br>-MFMRD | Drive 4 write data<br>Drive 4 write data<br>Ground<br>Drive 4 read data<br>Drive 4 read data<br>Drive 3 write data<br>Drive 3 write data<br>Drive 3 write data<br>Ground<br>Drive 3 read data<br>Drive 3 read data<br>Drive 2 write data<br>Drive 2 write data<br>Ground<br>Ground<br>Drive 2 read data<br>Drive 2 read data |  |
| 19<br>20                                                                                        | 10<br>23                                                                                        | GND<br>GND                                                                                                                                                                | Ground<br>Ground                                                                                                                                                                                                                                                                                                             |  |

# Table 4-8 Parallel Printer Port (P3)

| Pin | Signal  | Description               |
|-----|---------|---------------------------|
| 1   | -STROBE | Data strobe to<br>printer |
| 2   | DATA O  | Data bus bit 0            |
| 3   | DATA 1  | Data bus bit l            |
| 4   | DATA 2  | Data bus bit 2            |
| 5   | DATA 3  | Data bus bit 3            |
| 6   | DATA 4  | Data bus bit 4            |

Interface

4.13

# Table 4-9 continued

| Pin   | Signal      | Description                 |
|-------|-------------|-----------------------------|
| 7     | DATA 5      | Data bus bit 5              |
| 8     | Data 6      | Data bus bit 6              |
| 9     | DATA 7      | Data bus bit 7              |
| 10    | -ACK        | Printer ready to            |
| 11    | BUSY        | receive data                |
| 12    | PE          | Printer busy<br>Paper empty |
| 13    | SELECT      | Printer selected            |
| 14    | -AUTO FD XT | Automatic feed              |
| 15    | -ERROR      | Error state                 |
| 16    | -INIT       | Reset printer               |
| 17    | -SLCTIN     | Select to printer           |
| 18-25 | GND         | Ground                      |

**NOTE:** The ground lines can be used as return lines.

# Table 4-10 Console (P4) And Serial Printer (P5) RS-232C Serial I/0

| Pin       | Signal | Description                          |
|-----------|--------|--------------------------------------|
| 1         | GND    | Ground                               |
| 2         | -TXD   | Incoming serial data                 |
| 3         | -RXD   | Outgoing serial data                 |
| 4         | RTS    | Request to send                      |
| 5         | CTS    | Clear to send                        |
| 6         | DSR    | Data set ready                       |
| 7         | GND    | Ground                               |
| 8         | DCD    | Data carrier detect                  |
| 9-18      |        | Not used                             |
| 19        | SRTS   | Secondary RTS                        |
| 20        | DTR    | Data terminal ready<br>(Busy, Buffer |
|           |        | Control Signal)                      |
| 21-<br>25 |        | Not used                             |

(

# Table 4-11 RS-422 Network Port (P6)

| Pin | Signal | Description       |
|-----|--------|-------------------|
| 1   | GND    | Ground            |
| 2   | TXD    | Data to system    |
| 3   | RXD    | Data to user      |
| 4   | RTS    | Ready to send     |
| 5   | CTS    | Clear to send     |
| 6   | -TXC   | Clock to system   |
| 7   | -RXC   | Clock from system |
| 8   | GND    | Ground            |
| 9   | -TXD   | Data to system    |
| 10  | -RXD   | Data to user      |
| 11  | -RTS   | Ready to send     |
| 12  | -CTS   | Clear to send     |
| 13  | TXC    | Clock to system   |
| 14  | RXC    | Clock from system |

# Table 4-12

)

)

)

User Channels (P11-P18)

| Pin                                                                                  | Signal                                                                                                                 | Description                                                                                                                                                                                                                                                                       |
|--------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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 | GND<br>-TXD<br>TXD<br>-RXD<br>RXD<br>-RTS<br>RTS<br>-CTS<br>CTS<br>TXC<br>-TXC<br>RXC<br>-RXC<br>-RXC<br>-SDIAG<br>GND | Ground<br>Data to system<br>Data to system<br>Data to user<br>Data to user<br>Ready to send<br>Ready to send<br>Clear to send<br>Clear to send<br>Clock to system<br>Clock to system<br>Clock from system<br>Clock from system<br>Manufacturing use<br>only<br>Ground<br>Not used |
| * Coni                                                                               | nector Pll only                                                                                                        |                                                                                                                                                                                                                                                                                   |

# Table 4-13

User Expansion (P19)

| Pin | Signal     | Description         |  |
|-----|------------|---------------------|--|
| 1   |            | Not used            |  |
| 2   | GND        | Ground              |  |
| 3   | -RXC OUT   | Clock from system   |  |
| 4   | GND        | Ground              |  |
| 5   | RXD OUT    | SDLC data from      |  |
|     |            | system              |  |
| 6   | GND        | Ground              |  |
| 7   | TXD IN     | SDLC data to system |  |
| 8   | -CTS OUT   | Clear to send from  |  |
|     |            | system              |  |
| 9   | -RTS IN    | Ready to send to    |  |
|     |            | system              |  |
| 10  | GND        | Ground              |  |
| 11  | -TXC IN    | Clock to system     |  |
| 12  | USER SEL 0 | User select line O  |  |
| 13  | USER SEL 1 | User select line l  |  |
| 14  | USER SEL 2 | User select line 2  |  |
| 15  | USER SEL 3 | User select line 3  |  |
| 16  |            | Not used            |  |

)

(

Table 4-14 Reset Button (P20)

| Pin    | Signal       | Description               |  |
|--------|--------------|---------------------------|--|
| 1<br>2 | GND<br>RESET | Ground<br>Reset (normally |  |
| 3      |              | open)<br>Normally closed  |  |

### APPENDIX A JUMPER CONFIGURATIONS

Appendix A lists the jumper default configurations and describes the function of each jumper. The jumper configurations provide flexability in operation and are set up in a basic (default) configuration (see Tables A-1 and A-2).

A jumper plug connects the jumper pins but, in some instances, a trace on the motherboard is used. This appendix is divided into motherboard and tape expansion board sections. In the following description of the jumpers, three designations are used:

|         | Jumper connection |
|---------|-------------------|
| <x></x> | Trace must be cut |
| < >     | No connection     |

Table A-1 Jumper Default Configurations

# **Basic configuration:**

1

| Jumper | Connection | Jumper | Connection |
|--------|------------|--------|------------|
| E2     | АВ         | E14    | BC         |
| E3     | ВС         | E15    | АВ         |
| E4     | ВС         | E16    | АВ         |
| E5     | АВ         | E17    | ВС         |
| E6     | A< >B      | E18    | АВ         |
| E7     | АВ         | E19    | АВ         |
| E8     | A< >B      | E20    | АВ         |
| E9     | АВ         | E21    | АВ         |
| E10    | АВ         | E22    | A< >B      |

Jumper Configurations A.1

# Table A-1 Continued

| Jumper | Connection | Jumper | Connection |
|--------|------------|--------|------------|
| E11    | АВ         | E23    | АВ         |
| E12    | ВС         | E24    | АВ         |
| E13    | АВ         |        |            |

Tape configuration (modified basic configuration):

Jumper Connection

| E4  | ВС |
|-----|----|
| E14 | АВ |
| E19 | ВС |

### MOTHERBOARD

**Memory Configurations** 

Thirty-two 64Kxl dynamic RAM devices, 256 Kbytes total (default).

| E3  | A< >B | ВС    |
|-----|-------|-------|
| E4  | A< >B | ВС    |
| E12 | A< >B | ВС    |
| E13 | АВ    | B< >C |
| E14 | A< >B | ВС    |
| E19 | АВ    | B< >C |

Sixty-four 64Kxl dynamic RAM devices, 512 Kbytes total. This configuration is used in the PM/16M memory expansion model.

| E3  | A< >B | ВС    |
|-----|-------|-------|
| E4  | АВ    | B< >C |
| E12 | A< >B | ВС    |
| E13 | A< >B | ВС    |
| E14 | A< >B | ВС    |
| E19 | АВ    | B< >C |

Jumper Configurations A.2

Sixteen 256Kxl dynamic RAM devices, 512 Kbytes total.

| E3  | A< >B | ВС    |
|-----|-------|-------|
| E4  | АВ    | B< >C |
| E12 | A< >B | ВС    |
| E13 | АВ    | B< >C |
| E14 | АВ    | B< >C |
| E19 | A< >B | ВС    |

)

Thirty-two 256Kxl dynamic RAM devices, 1 megabyte total.

| E3  | АВ    | B< >C |
|-----|-------|-------|
| E4  | АВ    | B< >C |
| E12 | АВ    | B< >C |
| E13 | АВ    | B< >C |
| E14 | A< >B | ВС    |
| E19 | A< >B | ВС    |

Two 2Kx8 static RAM devices (default).

| E6  | A< >B |       |
|-----|-------|-------|
| E7  | АВ    | B< >C |
| E9  | АВ    | B< >C |
| E10 | АВ    | B< >C |

One 8Kx8 static RAM device.

| E <b>6</b> | АВ    |       |
|------------|-------|-------|
| E7         | A< >B | ВС    |
| E9         | A< >B | ВС    |
| E10        | A< >B | B< >C |

Two 8Kx8 static RAM devices.

| E6  | A< >B |    |
|-----|-------|----|
| E7  | A< >B | ВС |
| E9  | A< >B | ВС |
| E10 | A< >B | ВС |

### Parallel Data Bits

Sets the parallel data bits for the PDI input of the memory mapping RAM (U96). Interval between refreshes is decreased by 0% (default). A---B B< >C E16 A - - - B B < > CE20 Interval between refreshes is decreased by 10%. E16 B< >C A---B E20 A<X>B B---C Interval between refreshes is decreased by 20% E16 A<X>B B---C E20 А---В B< >C Interval between refreshes is decreased by 30% -A<X>B E16 B---C B---C E20 A<X>B Fast RAM (default) E17 A< >B B---C Slow RAM E17 А---В B<X>C RAM cycle not extended (default). E18 A---B B< >C RAM cycle is extended.

Jumper Configurations A.4

# E18 A<X>B B---C

# Network Channel Termination

Set this jumper to "terminated" if the Personal Mini is located at either end of the network cable. If the Personal Mini is located between two other Personal Mini systems, set the jumper to "not terminated."

Terminated (default)

| АВ<br>АВ<br>АВ                         |
|----------------------------------------|
| Terminated                             |
| A <x>B<br/>A<x>B<br/>A<x>B</x></x></x> |
|                                        |

)

### Normal DCE or Reverse Channel Protocol

Ell modifies the console interface and El5 modifies the serial printer interface. Ell and El5 allow connection to either the DTR (normal DCE) signal or SRTS (reverse channel protocol) signal.

Normal DCE (default)

| E11 | АВ | B< | >C |
|-----|----|----|----|
| E15 | АВ | B< | >C |

**Reverse Channel Protocol** 

| E11 | A <x>B</x> | ВС |
|-----|------------|----|
| E15 | A< >B      | ВС |

# **Z80A** Reset

The reset signal may come from either the Z Reset Latch (U21) or the reset button on the front panel.

)

( )

Z Reset Latch (default)

E2 A---B B< >C

Reset Button

E2 A< >B B---C

### **DR4 MFMWR**

The E5 jumper must always remain connected.

### CLKOUT BF

This jumper breaks the CLKOUT BF signal line to U54, which goes to a pin (P21-33) that is reserved for later use.

E8 A< >B

### Serial Printer Port

The diagnostic console may be connected to the serial printer port.

Serial Printer (default)

E22 A< >B

Diagnostic Console

E22 A---B

# Jumper Configurations A.6

### TAPE EXPANSION BOARD

Seven jumpers on the tape expansion board are default-configured according to the expansion slot used for the tape drive (see Table A-2).

Table A-2 Tape Board Default Configuration

| 2      | <b>K1</b>  | X      | 2          |
|--------|------------|--------|------------|
| Jumper | Connection | Jumper | Connection |
| J1     | 12         | Jl     | 23         |
| J2     | 12         | J2     | 23         |
| J3     | 12         | J3     | 23         |
| J4     | 12         | J4     | 12         |
| J5     | 12         | J5     | 12         |
| J6     | 23         | J6     | 23         |
| J7     | 23         | J7     | 12         |

# X1 or X2 Configuration

JI, J2, J3, and J7 configure expansion slots X1 and X2.

Xl Slot (default)

: )

| J1 | 12    | 2< >3 | -INTA Z TO X1                                                       |
|----|-------|-------|---------------------------------------------------------------------|
| J2 | 12    | 2< >3 | -INT X1 TO Z                                                        |
| J3 | 12    | 2< >3 | Address decoder<br>output which<br>initializes U14<br>output for X1 |
| J7 | 1< >2 | 23    | -BUS ACK                                                            |
| J7 | 12    | 2< >3 | If tape is in<br>Xl and another<br>card is in X2.                   |

#### X2 Slot -INTA Z TO X2 **J1** 1< >2 2---3 2---3 -INT X2 TO Z 1< >2 **J2** 2---3 Address decoder J3 1< >2 output which initializes Ul4 output for X2 2< >3 1---2 -BUS ACK IN J7 **EPROM** Size 1---2 2< >3 J4 8 Kbytes (default)

)

J4 1< >2 2---3 4 Kbytes

# Local Static RAM Size

| 4 Kbytes | (default) |       |
|----------|-----------|-------|
| J5       | 12        | 2< >3 |
| J6       | 1< >2     | 23    |
| 8 Kbytes | or 16 Kby | rtes  |
| J5       | 1< >2     | 23    |
| J6       | 12        | 2< >3 |

### APPENDIX B SELF DIAGNOSTICS

The Personal Mini contains self-test diagnostics that are automatically run during system initialization. The PM/16 diagnostics are similar to the enhanced version in the PM/4T and PM/16T units. The main differences are the optional memory test and the tape diagnostics. The diagnostic LED indicators flash during the self-test to indicate an error.

When the diagnostics are successfully completed, the operating system is loaded.

The self diagnostics are divided into two sets. The first is for the EPROM which comes with the basic PM/16 unit, and the second is for the one that comes with the PM/4T and PM/16T units.

At power-on, the 16-bit CPU disables the interrupts and performs a system reset. All CPU diagnostic indicators are flashed once.

The 2681 DUART is now initialized allowing communication on the service terminal. The CPU (16-bit) diagnostics begin at this time.

# BASIC UNIT (PM/16)

# Memory Test

The memory test is performed by writing a pattern in main memory and then reading it back. The data patterns %FF, %00, and incrementing %00-%FF are repeated for the entire memory.

)

An error in the memory test causes the DS5 indicator to flash. The system halts testing and prints the error message:

### MEMORY ERROR.....

Successful completion of the memory test turns off all indicators and the system moves to the next test.

### Checksum

A checksum is then made on the system PROM to detect any alterations to the data stored in the PROM. An error in this test causes the DS6 indicator to flash. The system halts testing and prints the error message:

#### HASH TOTAL BRROR

Successful completion of the PROM test turns off the indicators and the system moves to the next test.

### Memory Size

The size of the main memory is now displayed.

### Interrupt Test

Ì

)

)

A software interrupt test is now performed on all interrupts. An error in the interrupt test displays one of the error messages:

#### **NO INTERRUPT**

### **INTERRUPT TEST ERROR**

The system moves to the next test.

#### Timer Interrupt Test

The timer interrupt test checks the timer 0 and 2 interrupts. If an interrupt is not detected, then the following error message is displayed:

### **O NO TIMER INTERRUPT**

### **2 NO TIMER INTERRUPT**

If any other interrupt is detected the following error message is displayed:

### TIMER INTERRUPT TEST ERROR

#### **Restore Test**

After completion of the interrupt tests, the system resets the floppy disk controller and then the hard disk controller.

The Z80A is now released so that it can perform the 8-bit diagnostics. See the Z80A Checksum Test for the description of the 8-bit diagnostics. A floppy disk restore and then a hard disk restore is performed. An error displays one of the following messages:

### TOO MUCH TIME

### FLOPPY DRIVE RESTORE ERROR

### HARD DISK RESTORE ERROR

### STATUS = XX

XX = Hex status code from hard disk controller.

### System Boot

The system now displays the following message:

### HIT ESC TO BOOT FROM THE FLOPPY DISK

If no answer is given within ten seconds, the system boots from the hard disk. If the user presses the <ESC> key, the system boots from the floppy disk.

For either a hard disk or a floppy disk boot, the system will load the boot record into memory. The operating system is then loaded and execution begins. An initial message is displayed to indicate the operating system.

# Hard Disk Boot

Prior to the hard disk boot, a reset to the hard disk controller is performed. A restore is again performed to read the system information from the disk. Some of the possible error messages are:

# BAD BOOT SECTOR .....RESET PLEASE

### ....READ ERROR....

### HARD DISK SEEK ERROR

An error in the hard disk boot causes the DS7 indicator to flash.

### Floppy Disk Boot

)

Prior to the floppy disk boot, a reset to the floppy controller is performed. A restore is again performed to read the system information from the disk. Some of the possible error messages are:

### CHECK FLOPPY DISKETTE PLEASE

### CONTROLLER ALWAYS BUSY, NO COMMAND ISSUED

### ....SEEK ERROR....

### ...NO DRQ...

#### ...READ ERROR...

### **Z80A** Checksum Test

A checksum test is made on the 280A EPROM to detect any alterations to the stored data. If an error occurs, DS1 and DS2, and DS3 and DS4 indicators will flash alternately.

)

# Static RAM

A static RAM test is performed using %00, %FF, %55, and %AA patterns. If an error occurs, DS2 will flash.

# Dynamic RAM

A dynamic RAM test is performed and an error causes DS1 and DS2 to flash.

# SIO Test

The SIO ports are initialized and an error causes DS1, DS2, DS3, and DS4 to flash &OF - &00.

# System Loader

The Z80A CPM3 system loader is initialized by initializing the interrupt vectors and memory mapper. The Z80A now halts, waiting for an interrupt.

# TAPE UNIT (PM/4T, PM/16T)

The tape unit contains its own Z80A processor and EPROM for diagnostics. When the 80186 CPU completes its tests, it releases the main board Z80A and the tape Z80A to perform their diagnostics. There are four diagnostic LED's located on the tape expansion board. The LED's light up to indicate the test being run and flash if there is an error. The LED indicators light up giving the binary-coded test sequence.

# **Optional Memory Test**

An optional memory test can be performed. This test has a menu and takes several minutes, depending on the menu selections. If the Control "@" keys are not pressed then the timed period ends, bypassing this test. The DS5 indicator lights to indicate that this test is being run.

# **CPU Memory Test**

The memory test is performed by writing a pattern in main memory and then reading it back. The data patterns %FF, %00, and incrementing %00-%FF are repeated for the entire memory.

An error in the memory test causes the DS5 indicator to flash. The system halts testing and displays the error message:

### MEMORY ERROR.....

# **CPU Checksum**

A checksum test is made on the system PROM to detect any alterations to the data stored. An error in this test causes the DS6 indicator to flash and the following error message is displayed.

### HASH TOTAL ERROR

)

# Memory Size

The size of the main memory is now displayed.

### **CPU Interrupt Test**

A software interrupt test is now performed on all interrupts. An error displays one of the following messages:

### NO INTERRUPT

### **INTERRUPT TEST ERROR**

### **CPU Timer Interrupt Test**

This test checks the timer 0 and timer 2 interrupts. If an interrupt is not detected, then one of the following error messages is displayed.

### **0 NO TIMER INTERRUPT**

### **2 NO TIMBR INTERRUPT**

If any other interrupt is detected the following message is displayed.

### TIMER INTERRUPT TEST ERROR

### 8-Bit Diagnostics

After completion of the interrupt tests, the system resets the floppy disk controller and then the hard disk controller.

The 80186 now releases the 280A and any expansion cards to perform the 8-bit diagnostics.

## **Expansion** Slot Configuration

The Z80A checks the expansion slots, and, if occupied, places their ID in memory at a preset location.

### **Z80A** Checksum

A checksum test is made on the 280 EPROM to detect any alterations to the stored data. The DS1 indicator is used and the following error message is displayed.

### **BRROR Z80 BPROM**

### **Z80 Static RAM**

)

A static RAM test is performed using %00. %FF, %55, and %AA patterns. If an error occurs, DS2 flashes and the following error message is displayed.

### BRROR Z80 EPROM

# **Z80A** Initial Status

The 80186 polls the Z80A for its initial status and waits for a reply. If the status contains an error, an error message is displayed. If there is no reply, the following message is displayed.

# NO REPLY FROM PROCESSOR Z

)

# **Tape** Configuration

The tape Z80A checks memory for its slot location, and, if not located, assumes it is located in slot 1. If not located, the following error message appears:

### **BRROR TAPE ID**

### Tape Checksum

A checksum is made on the tape EPROM to detect any alterations to the stored data. If an error occurs, the DS2 indicator flashes and the following error message appears.

### **ERROR TAPE CHECKSUM**

### Tape Static RAM

The local memory is tested using incrementing patterns %55, %AA, %FF, and %00. The DS1 and DS2 indicators are used and the following message is displayed:

### ERROR TAPE LOCAL PROM

#### Tape Initial Status

The 80186 polls the initial status of the tape Z80A and waits for a reply. If the status contains an error, an error message is displayed. If there is no reply, the following message is displayed:

#### NO REPLY FROM PROCESSOR X

X = slot location

#### **Z80** Dynamic RAM

A dynamic RAM test if performed and an error causes DS1 and DS2 to flash and the following error message is displayed:

#### ERROR 280 LOCAL PROM

#### **Z80 Memory Status**

)

The 80186 polls the Z80A for its memory status and waits for a reply.

## Tape Dynamic RAM

A dynamic RAM test is performed by the tape 280A. The DS3 indicator is used and the following error message is displayed:

#### **BRROR TAPE DYNAMIC RAM**

## DMA Local To Dynamic

The DMA transfers data from local memory to main memory and the DMA interrupt is set to indicate completion of data transfer. The DS1 and DS3 indicators are used and one of the following error messages is displayed:

)

#### ERROR TAPE DMA NO INTERRUPT

#### ERROR TAPE DMA LOCAL TO MAIN MEMORY

#### DMA Dynamic To Local

The DMA transfers data from main memory to the static memory and the DMA interrupt is set to indicate completion of data transfer. The DS2 and DS3 indicators are used and one of the following error messages is displayed:

#### ERROR TAPE DMA NO INTERRUPT

#### ERROR TAPE DMA MAIN TO LOCAL MEMORY

#### Tape Memory Status

The CPU polls the tape Z80 for its memory status and waits for a reply.

#### **Z80** SIO

The SIO ports are initialized and an error causes DS3 to flash. The following error message is displayed:

#### ERROR Z80 SIO

# Self Diagnostics B.12

## **Z80 Final Test Status**

The CPU polls the Z80A for its final test status and waits for a reply.

### Tape CTC

)

The CTC is set up to generate the timer mode of channel 0 and the counter mode of channel 2. It then signals the main 280 to block its access to main memory for a short period. The DS1, DS2, and DS3 indicators are used and one of the following error messages is displayed:

#### BRROR CTC 0, NO INTERRUPT

ERROR CTC 2, NO INTERRUPT

### Tape Reset

A tape reset is performed and the status is checked. If an error occurs, one of the following error messages is displayed:

#### **BRROR TAPE RESET**

#### TAPE CARTRIDGE NOT INSTALLED

#### Tape Motion

If the tape is installed in the unit, a rewind operation is performed. If an error occurs, the following error message is displayed:

#### **BRROR TAPE BOOT**

## Tape Final Test Status

The CPU polls the tape 280 for its final test status and waits for a reply.

)

# **Optional Tape Diagnostics**

To request the optional tape diagnostics, type in a question mark when the escape message is displayed on the screen. A rewind operation is performed prior to each read or write operation. When an error occurs, an error message and the status of the tape controller are displayed. Table B-1 lists the LED's the PM will light up for a given problem. The tape status bits are defined in Table B-2 and the tape extended status bits are defined in Table B-3. Table B-4 lists the hex complementary status bits.

Bit 7 is the most significent bit and bit 0 is the least significent bit. The controller status is displayed as follows:

## STATUS = NN XX XX XX XX XX XX

NN = Sequence number of the test as defined by the binary coded indicators.

XX = Tape controller status from byte 0 - 5
in complementary hex.

# Self Diagnostics B.14

# Table B-1 Sequence Number And Error Message

#### Sequence Number\*

)

)

# Brror Message

| 8 | Tape Cartridge Not Installed |
|---|------------------------------|
| 8 | Tape Is Write Protected      |
| В | Error Tape Write             |
| Α | Error Tape Read              |
| 0 | Aborting, No Tape Unit       |
| 0 | Main Z80 Failed Test         |
| 0 | No Reply From Processor Z    |
| 0 | No Reply From Processor 1    |
| 0 | No Reply From Processor 2    |

\* Sequence number in hex.

# Table B-2 Tape Status Bits

Byte 0

# Bit Description

| 0 | File mark detected           |
|---|------------------------------|
| 1 | Block not found              |
| 2 | Unrecoverable data error     |
| 3 | End of Tape (media)          |
| 4 | Tape is write protected      |
| 5 | Tape not online              |
| б | Tape cartridge not installed |
| 7 | Status bit set in byte 0     |

# Table B-2 continued

Tape Status Bits

# Byte 1

| Bit                   | Description                                                                                                    |  |  |  |
|-----------------------|----------------------------------------------------------------------------------------------------------------|--|--|--|
| 0<br>1<br>2           | Power on or reset occurred<br>Fault (ROM, RAM, or buffer)<br>Bus parity error (command or<br>data output)      |  |  |  |
| 3<br>4                | Beginning of tape (media)<br>Marginal block detected during<br>write retry                                     |  |  |  |
| 5<br>6                | No data detected<br>Illegal command sent to tape<br>controller                                                 |  |  |  |
| 7                     | Status bit set in byte l                                                                                       |  |  |  |
| Byte 2                |                                                                                                                |  |  |  |
| MSB                   | Data error counter                                                                                             |  |  |  |
| Byte 3                |                                                                                                                |  |  |  |
| LSB                   | Data error counter                                                                                             |  |  |  |
|                       | The data error counter is<br>incremented when a block has<br>to be rewritten or a read<br>retry has been made. |  |  |  |
| Byte 4                |                                                                                                                |  |  |  |
| MSB                   | Underrun/Overrun counter                                                                                       |  |  |  |
| Byte 5                |                                                                                                                |  |  |  |
| LSB                   | Underrun/Overrun counter                                                                                       |  |  |  |
| Self Diagnostics B.16 |                                                                                                                |  |  |  |

)

)

This counter is incremented when data to the tape controller is not sent fast enough to enable the tape to stream. It is also incremented if data is not accepted fast enough to enable the tape to stream.

## Table B-3 Tape Extended Status Bits

- Byte 0
- Bit Description
- Not used
  Erase current not detected during an erase or write command
  Clear reader tape is detected before BOT/EOT during a write.
  Timeout (command execution)
  Repositioning Error
  Tape controller buffer error
  Tape controller RAM error
  Tape controller ROM error

#### Byte 1

)

)

| 0<br>1<br>2 - 7 | Tape drive 0 selected<br>Tape drive 1 selected<br>No tape drive selected |
|-----------------|--------------------------------------------------------------------------|
| Byte 2          |                                                                          |
| 0 - 1           | 00 Track 0<br>01 Track 1<br>10 Track 2<br>11 Track 3                     |
| 2 - 7           | No track selected                                                        |

Table B-3 continuedByte 3BitDescriptionMSBCurrent block number (binary)

# Byte 4

LSB Current block number

## Table B-4 Hex Complementary Status Bits

#### Bits

| Count                      | 7                | 6                   | 5                     | 4                     | 3                | 2                | 1                | 0                |
|----------------------------|------------------|---------------------|-----------------------|-----------------------|------------------|------------------|------------------|------------------|
| 7F<br>BF<br>DF<br>EF<br>F7 | 0<br>1<br>1<br>1 | 1<br>0<br>1<br>1    | 1<br>1<br>0<br>1<br>1 | 1<br>1<br>1<br>0<br>1 | 1<br>1<br>1<br>0 | 1<br>1<br>1<br>1 | 1<br>1<br>1<br>1 | 1<br>1<br>1<br>1 |
| FB<br>FD<br>FE<br>NOTE:    | l<br>l<br>True   | 1<br>1<br>1<br>= 0, | l<br>l<br>l<br>Fal    | 1<br>1<br>1<br>se =   | 1<br>1<br>1      | 0<br>1<br>1      | 1<br>0<br>1      | 1<br>1<br>0      |

## System Loader

The Z80A CPM3 system loader is initialized by initializing the interrupt vectors and memory mapper. The main Z80 now halts and waits for an interrupt.

# Self Diagnostics B.18

#### **Restore Test**

)

)

)

A floppy disk restore and then a hard disk restore are performed. An error will display one of the following messages:

## TOO MUCH TIME

## FLOPPY DRIVE RESTORE ERROR

#### HARD DISK RESTORE ERROR

#### STATUS = XX

XX = Hex status code as listed in Table B-5.

Table B-5 Drive Hex Status Code

Floppy Disk

| Hex | Bit | Description             |
|-----|-----|-------------------------|
| 80  | 7   | Motor on                |
| 40  | 6   | Write protected         |
| 20  | 5   | Type I commands:        |
|     |     | Spin up sequence        |
|     |     | completed, 6 rev.       |
|     |     | Type II - II commands:  |
|     |     | 0 = Data mark           |
|     |     | l = Deleted data mark   |
| 10  | 4   | Record not found        |
| 08  | 3   | CRC error:              |
|     |     | ID field error if bits  |
|     |     | 3 and 4 are set         |
|     |     | Data field error if not |
|     |     | set                     |

# Table B-5 continued

| Hex | Bit | Description                                                                   |
|-----|-----|-------------------------------------------------------------------------------|
| 04  | 2   | Type I command:<br>Track 00 indicator<br>Type II - III commands:<br>Lost data |
| 02  | 1   | Type I command:<br>Index<br>Type II - III commands:<br>Data request           |
| 01  | 0   | Busy                                                                          |

# Type I Commands

Restore Seek Step Step-in Step-out

# Type II Commands

Read Sector Write Sector

# Type III Commands

Read Address Read Track Write Track

# Table B-5 continued

Hard Disk

Ì

)

)\_

| Hex | Bit | Description                    |
|-----|-----|--------------------------------|
| 80  | 7   | Bad block detected             |
| 40  | 6   | CRC data field error           |
| 20  | 5   | Reserved (not used)            |
| 10  | 4   | ID not found                   |
| 08  | 3   | Reserved (not used)            |
| 04  | 2   | Command aborted                |
| 02  | 1   | Track 000 error                |
| 01  | 0   | Data address mark not<br>found |

# Hard Disk Commands

Restore Seek Read Sector Write Sector Scan ID Write Format

### Boot

The System now displays the following message:

# HIT ESC TO BOOT FROM FLOPPY

If no answer is given within a short period of time, the system boots from the hard disk. If the user presses the <ESC> key, the system boots from the floppy disk. For either a hard disk boot or a floppy disk boot, the system loads the boot record into memory. The operating system is then loaded and execution begins. An initial message is displayed to indicate the operating system. Hard Disk Boot

Prior to the hard disk boot, a reset to the hard disk controller is performed. A restore is again performed to read the system information from the disk. Some of the possible error messages:

#### BAD BOOT.....RESET PLEASE

#### ...READ BRROR...

#### HARD DISK SEEK ERROR

An error in the hard disk boot causes DS7 to flash.

#### Floppy Disk Boot

Prior to the floppy disk boot, a reset is performed. A restore is again performed to read the system information from the disk. Some of the error messages are:

#### CHECK FLOPPY DISKETTE PLEASE

#### CONTROLLER ALWAYS BUSY, NO COMMAND ISSUED

....SEEK BRROR....

...NO DRQ...

....READ ERROR....

Self Diagnostics B.22

# APPENDIX C LOGIC DIAGRAMS

This section contains the logic diagrams of the Personal Mini. They are:

- \* Personal Mini (motherboard)
- \* Winchester disk controller board
- \* Tape expansion board

NAMES OF CONNECTORS: PI: DC POWER (IOP MOLEX WAFER) PO: ISSS MEN EXTENSION (64P DIN-TYPE, 2 ROWS) P9: FLOPPY DISK (34P STR HDR) P2I: HARD DISK HOST INTERFACE (4 ØP STR HDR) P22: HARD DISK DATA DR 2/3/4 (2 \$ P STR HDR) P2: HARD DISK DATA DR 2/3/4 EXTERNAL (25P DB-TYPE) P6: RS422 NETWORK (ISP DB-TYPE) P3: PARALLEL PRINTER (25P DB-TYPE) P20: RESET BUTTON(3P MOLEX WAFER) PS: SERIAL PRINTER (25P DB-TYPE) P4 : CONSOLE (25P DB-TYPE) PII - PIB : 8 USER CHANNELS (IGP STR HDR) PI9: EXTRA USER CHANNELS(I6P STR HDR) P8: OPTIONAL CARD XI SLOT (96P DIN TYPE, 3ROWS) PT: OPTIONAL CARD X2 SLOT (96P DIN TYPE, 3ROWS)

NOTES: UNLESS OTHERWISE SPECIFIED 1. ALL RESISTORS ARE VALUED IN OHMS AND ARE 1/4 WATT±5%. 2. ALL CAPACITORS ARE VALUED IN UF. 16 VDC AND ARE±20%.

NOTES ON JUMPERS: A) STANDARD MOUNTING OF JUMPERS: E148-C EG (PARK ON PIN B) E13A - 8 E7A-B E12 B - C E9A-B F4 R - C EIOA-B E36-C E19A - 8 E2 A - B EISA-B B) OPTIONAL MOUNTING OF JUMPERS: D 512K OF 64K DRAMS:EI4(8-C), EI3(8-C), E12(8-C), E4(A-8), E3(8-C), E19(A-8) 2 512K OF 256K DRAMS:EH4-8,E13(A-8) .E12(B-C),E4(A-8),E3(B-C),E19(8-C) () IN OF 256K DRAMS:EI4(8-C),EI3(A-BLEI2(A-B),E4(A-B),E3(A-B),E19(8-C) REVERSE CHANNEL ON SERIAL PRINTERIES (B-C) SZSP DIAGNOSTICS CONSOLEEZ2(AB) BOIREGT RESET ZBØ THROUGH RESET BUTTON: E2B-C TWO 2KX8 SRAM'S EG (PARK ON PIN B), E7 (A-B), E9 (A-B), E10 (A-B) ( ONE BEAR SRAMS EG (A-B), ET (B-C), ET (B-C), ENO (PARK ON PIN C) TWO BKX8 SRAM'S EG (PARK ON PIN B),E7 (B-C), E9 (B-C), E10 (B-C)



ł

CPU













#### DUART













# LINE RECEIVERS



Logic Diagrams

C.16



C.17

## WINCHESTER DISK CONTROLLER BOARD WDC 1000-05 122988-00 REV G



5







DIFFERENTIAL LINE RECEIVER



NOTES : UNLESS OTHER, WISE SPECIFIED

I. STANDARD MOUNTING OF JUMPERS (CARD INSTALLED ON XI EXP SLOT, SRAM SIZE 4K EPROM SIZE 8K)

JI (1,2) J7 (2,3) J2 (1,2) J3 (1,2) J4 (2,3) J5 (1,2)

J 3 (1,2) J 6 (2,3) 2. OPTIONAL MOUNTING OF JUMPERS HISTALLED ON X2 EXP SLOT : J1(2,3) J2(2,3) J3(2,3) EPRON SIZE 4K:J5 (2,3) SRAM SIZE IGK:J5 (2,3), J6 (1,2) WHEN TAPE CARD IS INSTALLED ON XI SLOT AND SOME CARD IS INSTALLED ON X2 SLOT OR WHEN THE TAPE CARD IS INSTALLED ON X2 SLOT : J7(1,2)

- 3. NAME OF CONNECTORS
  - PI 1608 MAIN BOARD INTERFACE
  - P2 GIC-02 INTERFACE
- 4. ALL RESISTOR ARE VALUED IN OHMS AND ARE 1/4 WATT15%



PULL UP SHT 2

## TAPE EXPANSION BOARD 125882-00 REV A





1



•



# TeleVideo Systems, Inc. PM Technical Reference Manual

P/N 127611-00 Rev. A. 2/85

#### **Reader Comments**

We welcome comments on the usefulness and readability of this publication. Your comments will help us to provide you with better publications in the future.

| Do you find the publi | cation: easy | to understand,   | well-organized |
|-----------------------|--------------|------------------|----------------|
| complete,             | accurate,    | well-illustrated | ?              |
| Comments:             |              |                  |                |
|                       |              |                  | ,              |

What didn't you like about this publication? How would you improve it? \_\_\_\_\_

Additional Comments: \_

Thank you for your comments!

# BUSINESS REPLY CARD

Fold

NO POSTAGE NECESSARY IF MAILED IN THE UNITED STATES

First Class Permit No. 7634 San Jose, CA

POSTAGE WILL BE PAID BY THE ADDRESSEE

# TeleVideo Systems, Inc.

550 East Brokaw Road P.O. Box 6602 San Jose, CA 95150-9990

Attn: Marketing Publications



550 East Brokaw Road, San Jose, CA 95112

127611-00 Rev. A

© TeleVideo 2/85. Printed in U.S.A.

Į.