| <b>MARK 2/3</b> | Peripherals<br>Interface<br>Manual |  |
|-----------------|------------------------------------|--|
|                 |                                    |  |
|                 |                                    |  |
|                 |                                    |  |
|                 |                                    |  |
|                 |                                    |  |
|                 |                                    |  |
|                 |                                    |  |
|                 |                                    |  |

-



# DATA CORPORATION

# POINT 4<sup>™</sup> MARK 2/3 PERIPHERALS INTERFACE MANUAL

# **Revision D**

### NOTICE

Every attempt has been made to make this manual complete, accurate and up-to-date. However, all information herein is subject to change due to updates. All inquiries concerning this manual should be directed to POINT 4 Data Corporation.

Copyright <sup>©</sup> 1982, 1984 by POINT 4 Data Corporation (formerly Educational Data Systems, Inc). Printed in the United States of America. All rights reserved. No part of this work covered by the copyrights hereon may be reproduced or copied in any form or by any means--graphic, electronic, or mechanical, including photocopying, recording, taping, or information and retrieval systems -- without the prior written permission of:

> POINT 4 Data Corporation 15442 Del Amo Avenue Tustin, CA 92680 (714) 259-0777

# **REVISION RECORD**

### PUBLICATION NUMBER: HM-081-0027

| <u>Revision</u> | Description                                                                                  | Date     |
|-----------------|----------------------------------------------------------------------------------------------|----------|
| Α               | Initial Release                                                                              | 08/06/82 |
| В               | Update package incorporating information on the MARK 3B PIB                                  | 10/30/82 |
| С               | Update package incorporating information on the MARK 2 PIB                                   | 02/20/84 |
| D               | Update package incorporating information<br>relevant to the MARK 2 with floppy disk<br>drive | 12/01/84 |

## LIST OF EFFECTIVE PAGES

Changes, additions, and deletions to information in this manual are indicated by vertical bars in the margins or by a dot near the page number if the entire page is affected. A vertical bar by the page number indicates pagination rather than content has changed. The effective revision for each page is shown below.

| Page                      | Rev    | Page                    | Rev   | Page | Rev |
|---------------------------|--------|-------------------------|-------|------|-----|
|                           |        |                         |       |      |     |
| Cover                     | -      | 4-7 thru 4-37           | А     |      |     |
| Title                     | D      | 5-1, 5-2                | С     |      |     |
| ii                        | С      | 5-3                     | В     |      |     |
| iii, iv                   | D      | 5-4                     | С     |      |     |
| v/vi                      | С      | 5-5 thru 5-14           | В     |      |     |
| vii thru xi               | D      | 5-15, 5-16              | С     |      |     |
| xii                       | С      | 5-17 thru 5- <b>4</b> 0 | В     |      |     |
| xiii                      | D      | 5-41                    | С     |      |     |
| xiv                       | С      | 6-1 thru 6-28           | D     |      |     |
| XV                        | D      | Appendix Title          | -     |      |     |
| 1-1                       | D      | A-1                     | A     |      |     |
| 1-2 thru 1-4              | С      | B-1 thru B-8            | A     |      |     |
| 1-5                       | D      | C-1 thru C-12           | B     |      |     |
| 1-6 thru 1-9              | С      | Comment Sheet           | D<br> |      |     |
| 1-10, 1-11                | D      | Mailer<br>Dack Couer    | -     |      |     |
| 1-12 thru 1-30<br>2-1     | C<br>B | Back Cover              | ·     |      |     |
| 2-2, 2-3                  | C      |                         |       |      |     |
| 2-2, 2-3<br>2-4 thru 2-28 | Ă      |                         |       |      |     |
| 2-29                      | В      |                         |       |      |     |
| 2-30, 2-31                | Ā      |                         |       |      |     |
| 2-32                      | В      |                         |       |      |     |
| 3-1, 3-2                  | С      |                         |       |      |     |
| 3-3, 3-4                  | В      |                         |       |      |     |
| 3-5 thru 3-18             | А      |                         |       |      |     |
| 3-19                      | D      |                         |       |      |     |
| 3-20 thru 3-32            | A      |                         |       |      |     |
| 3-33 thru 3-35            | С      |                         |       |      |     |
| 3-36, 3-37                | A      |                         |       |      |     |
| 3-38, 3-39                | С      |                         |       |      |     |
| 3-40                      | D      |                         |       |      |     |
| 3-41, 3-42                | С      |                         |       |      |     |
| 3-43 thru 3-49            | A      |                         |       |      |     |
| 4-1 thru 4-6              | С      |                         |       |      |     |
|                           |        |                         |       |      |     |

HM-081-0027-D POINT 4 Data Corporation iv

MARK 2/3 Peripherals Manual

# PREFACE

This manual describes the peripheral interface functions supported by the POINT 4 MARK 2 or 3 Computer System. The peripheral functions are controlled by a Peripherals Interface Board (PIB). The PIB is available in three versions. All versions contain a built-in multiplexer and a disc drive interface. However, the disc drive interfaces are different on the MARK 2 and MARK 3 systems. In addition, the MARK 2 and the MARK 3 PIBs provide a tape drive interface. The MARK 3B PIB provides a floppy disc drive interface.

The introduction provides information regarding the characteristics, internal architecture, and input/output interface handling of each of the PIBs.

Separate sections are devoted to the multiplexer, the different disc drives, tape drive, and floppy disc drive interfaces. The appendices provide a table of ASCII codes, and both tape and floppy disc handling flowcharts.

Separate manuals describe the MARK 2/3 Computer System and provide step-by-step instructions for installation, upgrade and operating procedures.

Related manuals include:

|       |        | Title                    | Pub. Number |
|-------|--------|--------------------------|-------------|
| POINT | 4 MARK | 3 Computer System Manual | HM-081-0019 |
| POINT | 4 MARK | 3 Diagnostics Document   |             |
| POINT | 4 MARK | 2 Diagnostics Document   |             |
| POINT | 4 MARK | 3T Computer User Guide   | HM-081-0029 |
| POINT | 4 MARK | 2 Computer User Guide    | HM-081-0031 |

HM-081-0027-C POINT 4 Data Corporation abios.

# **CONTENTS**

| <u>Section</u>                                                                                                                                                                                      | Title                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Page                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1                                                                                                                                                                                                   | INTRODUCTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 1-1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 1.1 $1.1.1$ $1.1.2$ $1.1.2.1$ $1.1.2.3$ $1.1.2.4$ $1.1.2.5$ $1.1.2.6$ $1.1.2.7$ $1.2.7$ $1.2.1$ $1.2.1.1$ $1.2.1.2$ $1.2.1.1$ $1.2.1.2$ $1.2.2.1$ $1.2.3.1$ $1.2.3.1$ $1.2.3.2$ $1.2.3.3$ $1.2.3.4$ | GENERAL DESCRIPTION<br>System Description<br>Equipment Characteristics<br>Communications Control<br>Disc Drive Interface on MARK 3<br>and MARK 3B PIBs<br>Disc Drive Interface on a MARK 2 PIB<br>Tape Drive Interface on MARK 3<br>and MARK 2 PIBs<br>Floppy Disc Drive Interface<br>on a MARK 3B PIB<br>Floppy Disc Drive Interface<br>on a MARK 2 PIB<br>Input/Output Instructions<br>PIB Internal Architecture<br>INPUT/OUTPUT INTERFACE HANDLING<br>Program Interrupt and Priority Scheme<br>Interrupt Sequence<br>Programming Polling and Interrupts<br>Programmed I/O Transfers<br>Master Terminal Interface<br>Direct Memory Access Transfers<br>Enabling/Disabling DMA Transfers<br>Initiating DMA Transfer<br>Turning off Automatic Block Transfer Mode<br>for Disc, Tape or Floppy<br>Turning off Automatic Block Transfer Mode<br>for Multiplexer | $ \begin{array}{c} 1-1\\ 1-6\\ 1-8\\ 1-9\\ 1-9\\ 1-9\\ 1-9\\ 1-10\\ 1-10\\ 1-10\\ 1-11\\ 1-12\\ 1-16\\ 1-16\\ 1-17\\ 1-18\\ 1-25\\ 1-25\\ 1-25\\ 1-25\\ 1-29\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\ 1-30\\$ |
| 2                                                                                                                                                                                                   | MULTIPLEXER                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 2-1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 2.1<br>2.2<br>2.3<br>2.3.1<br>2.3.2<br>2.3.3<br>2.3.3.1<br>2.3.3.2<br>2.3.4<br>2.3.5                                                                                                                | INTRODUCTION<br>BAUD-RATE SELECTION<br>COMMUNICATIONS BYTE MODE<br>• Programmed I/O Instructions<br>UART Asynchronous Communications<br>Command Register<br>Standard Mode of Operation<br>Operational Mode Modifications<br>Status Register<br>Software Polling                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 2-1<br>2-2<br>2-4<br>2-5<br>2-5<br>2-7<br>2-7<br>2-7<br>2-8<br>2-11                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |

| 2.4                 | COMMUNICATIONS AUTO MODE                      | 2-12 |
|---------------------|-----------------------------------------------|------|
| 2.4.1               | MUX I/O Control Block                         | 2-12 |
| 2.4.2               | Control Word Definitions                      | 2-13 |
| 2.4.3               | Input Operations                              | 2-14 |
| 2.4.3.1             | Input Control Word                            | 2-14 |
| 2.4.3.2             | Input Termination Status                      | 2-19 |
| 2.4.3.3             | Input Byte Pointer                            | 2-19 |
| 2.4.3.4             | Last Input Byte                               | 2-19 |
| 2.4.4               | Output Operations                             | 2-20 |
| 2.4.4.1             | Output Control Word                           | 2-20 |
| 2.4.4.2             | Output Termination Status                     | 2-24 |
| 2.4.4.3             | Output Byte Pointer                           | 2-25 |
| 2.4.4.4             | Last Output Byte                              | 2-25 |
| 2.5                 | INITIALIZATION PROCEDURES                     | 2-26 |
| 2.5.1               | Setting IOCB Starting Address                 | 2-26 |
| 2.5.2               | Initialization Guidelines                     | 2-27 |
| 2.5.3               | Enabling/Disabling Ports and Port Parameters  | 2-28 |
| 2.5.3.1             | Master Reset                                  | 2-28 |
| 2.5.3.2             | Port Initialization                           | 2-29 |
| 2.5.3.3             | Enabling/Disabling Transmitters and Receivers |      |
|                     | POLLING MUX INTERRUPT                         | 2-32 |
| 2.7                 | PAUSING MUX                                   | 2-32 |
| <b>-</b> • <i>i</i> |                                               |      |
|                     |                                               |      |
| 3                   | DISC DRIVE INTERFACE                          | 3-1  |
|                     |                                               |      |
| 3.1                 | INTRODUCTION                                  | 3-1  |
| 3.1.1               | Performance Characteristics                   | 3-2  |
| 3.1.2               | Multi-Drive Connection                        | 3-3  |
| 3.1.3               | Disc Drive Cabling                            | 3-4  |
| 3.1.3.1             | Drive Control Bus (A Cable)                   | 3-4  |
| 3.1.3.2             | Drive Cables (B Cables)                       | 3-9  |
| 3.2                 | PROGRAMMED INPUT/OUTPUT                       | 3-11 |
| 3.2.1               | Programmed I/O Input                          | 3-11 |
| 3.2.2               | Programmed I/O Output                         | 3-13 |
| 3.2.2.1             | DOA with Device Code 50 (Drive Unit Number)   | 3-13 |
| 3.2.2.2             |                                               | 3-14 |
| 3.2.2.3             |                                               | •    |
|                     | Loading)                                      | 3-15 |
| 3.2.2.3.            | l Tag l                                       | 3-16 |
| 3.2.2.3.            |                                               | 3-17 |
| 3.2.2.3.            | 3 Tag 3                                       | 3-18 |
| 3.3                 | INPUT/OUTPUT CONTROL BLOCK (IOCB)             | 3-19 |
| 3.3.1               | Opcode (Word 0)                               | 3-19 |
| 3.3.2               | Unit Number (Word 1)                          | 3-21 |
| 3.3.3               | Cylinder Address and Protect Flags (Word 2)   | 3-22 |
| 3.3.4               | Head/Volume (Word 3)                          | 3-23 |
| 3.3.5               | Sector Address (Word 4)                       | 3-24 |
| 3.3.6               | Sector Count (Word 5)                         | 3-25 |
| 3.3.7               | Memory Address (Word 6)                       | 3-26 |
| 3.3.8               | Termination Status (Word 7)                   | 3-27 |
| 3.3.9               | Disc Controller Input Control                 | 3-30 |
| 3.3.10              | Disc Controller Output Control                | 3-31 |
| 2.2.10              | bibe concrotter output concrot                |      |

deresting. Nerright

| 3.4<br>3.4.1<br>3.4.2<br>3.4.3<br>3.5<br>3.5.1<br>3.5.2<br>3.5.2.1<br>3.5.2.2<br>3.5.2.1<br>3.5.2.2<br>3.5.2.4<br>3.5.3<br>3.5.4<br>3.5.4.1<br>3.5.4.2<br>3.5.4.3<br>3.5.4.4<br>3.5.4.4<br>3.5.4.4 | Seek Initiation<br>Seek Error Recovery<br>SECTOR BLOCK FORMAT COMMANDS<br>Formatting Operation<br>Sector Block Description<br>Sector Block Format - Word 0 Functions<br>Sector Block Format - Word 1 Functions<br>Sector Block Format - Word 2 Functions<br>Sector Block Format - Word 3 Functions<br>Formatting Procedure<br>Sector Block I/O Operations<br>Write Data Operation<br>Read Data Operation<br>Read-Verify Operation<br>Read-Regardless Operation                                                                                                                                                                           | 3-32<br>3-32<br>3-36<br>3-37<br>3-39<br>3-40<br>3-40<br>3-40<br>3-41<br>3-42<br>3-43<br>3-44<br>3-46<br>3-46<br>3-46<br>3-46<br>3-47<br>3-47<br>3-49                                                                                                                                                    |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4                                                                                                                                                                                                  | QIC-02 STREAMING TAPE DRIVE INTERFACE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 4-1                                                                                                                                                                                                                                                                                                     |
| 4.4.1<br>4.4.1.1<br>4.4.1.2                                                                                                                                                                        | Features<br>Performance Characteristics<br>TAPE CONTROLLER INTERFACE<br>Tape Controller Interface Signals<br>INPUT/OUTPUT CONTROL OPERATIONS<br>Programmed I/O Input<br>Status Byte Transfer<br>Programmed I/O Output<br>TAPE CONTROLLER IOCB<br>Tape Transfer Control<br>DOBP Instruction<br>DIBP Instruction<br>TAPE CONTROLLER COMMANDS<br>Select Command (Type 0)<br>Position Command (Type 1)<br>Write Command (Type 2)<br>End of Tape Handling<br>Write File Mark Command (Type 3)<br>Read Command (Type 4)<br>Read File Mark Command (Type 5)<br>Read Status Command<br>Exception Byte 0<br>2 Exception Byte 1<br>3 Bytes 2 and 3 | $\begin{array}{c} 4-1\\ 4-1\\ 4-2\\ 4-3\\ 4-3\\ 4-7\\ 4-7\\ 4-9\\ 4-10\\ 4-13\\ 4-14\\ 4-14\\ 4-14\\ 4-14\\ 4-15\\ 4-16\\ 4-17\\ 4-18\\ 4-19\\ 4-20\\ 4-20\\ 4-20\\ 4-20\\ 4-20\\ 4-21\\ 4-22\\ 4-23\\ 4-24\\ 4-27\\ 4-29\\ 4-29\\ 4-29\\ 4-29\\ 4-30\\ 4-30\\ 4-31\\ 4-32\\ 4-33\\ 4-34\\ \end{array}$ |

| 4.6.6<br>4.6.7<br>4.6.7.1<br>4.6.7.2<br>4.6.7.3<br>4.6.7.4<br>4.6.7.5                                                                                                                                                                                                                                                                                                                                                            | Read File Mark Operations<br>Error Processing and Recovery<br>Write Buffer Overrun<br>Read After Write Errors<br>Read Buffer Underruns<br>Read Data Errors<br>Read Sequence Errors                                                                                                                          | 4-34<br>4-35<br>4-35<br>4-36<br>4-36<br>4-37<br>4-37                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5                                                                                                                                                                                                                                                                                                                                                                                                                                | FLOPPY DISC DRIVE INTERFACE                                                                                                                                                                                                                                                                                 | 5-1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 5.1<br>5.1.2<br>5.1.3<br>5.2<br>5.3<br>5.3.1<br>5.3.2<br>5.3.2.1<br>5.3.2.2<br>5.3.3<br>5.3.4<br>5.3.5<br>5.3.6<br>5.4<br>5.4.1.1<br>5.4.1.2<br>5.4.1.1<br>5.4.1.2<br>5.4.1.3<br>5.4.1.4<br>5.4.1.5<br>5.4.1.5<br>5.4.1.5<br>5.4.1.5<br>5.4.1.5<br>5.4.1.5<br>5.4.1.5<br>5.4.1.5<br>5.4.1.5<br>5.4.1.5<br>5.4.1.5<br>5.4.1.5<br>5.4.1.5<br>5.4.1.5<br>5.5.1.1<br>5.5.1.1<br>5.5.1.1<br>5.5.1.2<br>5.5.2<br>5.6<br>5.6.1<br>5.6.2 | Restore Command Bit Configuration<br>Seek Command Bit Configuration<br>Status Register<br>Track Register<br>Data Register<br>INPUT/OUTPUT CONTROL BLOCK (IOCB)<br>Command Word (Word 0)<br>Read Sector Command<br>Write Sector Command<br>Read Address Command<br>Read Track Command<br>Write track Command | 5-1<br>5-2<br>5-3<br>5-4<br>5-5<br>5-12<br>5-13<br>5-14<br>5-15<br>5-16<br>5-17<br>5-21<br>5-21<br>5-22<br>5-23<br>5-23<br>5-24<br>5-31<br>5-32<br>5-32<br>5-31<br>5-32<br>5-34<br>5-35<br>5-36<br>5-38<br>5-38<br>5-39<br>5-38<br>5-39<br>5-39<br>5-38<br>5-39<br>5-38<br>5-39<br>5-39<br>5-38<br>5-39<br>5-39<br>5-38<br>5-39<br>5-38<br>5-39<br>5-39<br>5-39<br>5-38<br>5-39<br>5-39<br>5-39<br>5-39<br>5-38<br>5-39<br>5-39<br>5-39<br>5-39<br>5-38<br>5-39<br>5-39<br>5-39<br>5-39<br>5-38<br>5-39<br>5-39<br>5-39<br>5-39<br>5-38<br>5-39<br>5-39<br>5-39<br>5-39<br>5-38<br>5-39<br>5-39<br>5-39<br>5-39<br>5-39<br>5-39<br>5-39<br>5-39<br>5-39<br>5-39<br>5-39<br>5-39<br>5-39<br>5-39<br>5-39<br>5-39<br>5-39<br>5-39<br>5-39<br>5-39<br>5-39<br>5-39<br>5-39<br>5-39<br>5-39<br>5-39<br>5-39<br>5-39<br>5-39<br>5-39<br>5-39<br>5-39<br>5-39<br>5-39<br>5-39<br>5-39<br>5-39<br>5-39<br>5-39<br>5-39<br>5-39<br>5-39<br>5-39<br>5-39<br>5-39<br>5-39<br>5-39<br>5-39<br>5-39<br>5-39<br>5-39<br>5-39<br>5-39<br>5-39<br>5-39<br>5-39<br>5-39<br>5-39<br>5-39<br>5-39<br>5-39<br>5-39<br>5-39<br>5-39<br>5-39<br>5-39<br>5-39<br>5-39<br>5-39<br>5-39<br>5-39<br>5-39<br>5-39<br>5-39<br>5-39<br>5-39<br>5-39<br>5-39<br>5-39<br>5-39<br>5-39<br>5-39<br>5-39<br>5-39<br>5-39<br>5-39<br>5-39<br>5-39<br>5-39<br>5-39<br>5-39<br>5-39<br>5-39<br>5-40<br>5-41 |

•

 $_{\rm c}\approx 0.05_{\rm M_{\odot}}$ 

| 6       | MARK 2 DISC/FLOPPY DRIVE INTERFACE    | 6-1  |
|---------|---------------------------------------|------|
| 6.1     | INTRODUCTION                          | 6-1  |
| 6.2     | MARK 2 INTERFACE                      | 6-3  |
| 6.3     | PROGRAMMED INPUT/OUTPUT               | 6-10 |
| 6.3.1   | Data Register                         | 6-11 |
| 6.3.2   | Write Precomp Register                | 6-11 |
| 6.3.3   | Error Register                        | 6-12 |
| 6.3.4   | Sector Count Register                 | 6-15 |
| 6.3.5   | Sector Number Register                | 6-15 |
| 6.3.6   | Cylinder High and Low Registers       | 6-16 |
| 6.3.7   | Select/Drive/Head Register            | 6-17 |
| 6.3.8   | Command Register                      | 6-18 |
| 6.3.8.1 | Test Command Bit Configuration        | 6-18 |
| 6.3.8.2 | Restore Command Bit Configuration     | 6-19 |
| 6.3.8.3 | Seek Command Bit Configuration        | 6-20 |
| 6.3.9   | Status Register                       | 6-21 |
| 6.4     | INPUT/OUTPUT CONTROL BLOCK (IOCB)     | 6-23 |
| 6.4.1   | Opcode/Write Precomp Word (Word 0)    | 6-23 |
| 6.4.1.1 | Read Sector Command                   | 6-24 |
| 6.4.1.2 | Readlong Command                      | 6-25 |
| 6.4.1.3 | Write Sector Command                  | 6-25 |
| 6.4.1.4 | Writelong Command                     | 6-26 |
| 6.4.1.5 | Format Track Command                  | 6-26 |
| 6.4.2   | Sector Number and Count Word (Word 1) | 6-27 |
| 6.4.3   | Cylinder Number Word (Word 2)         | 6-27 |
| 6.4.4   | Memory Address Word (Word 3)          | 6-28 |
| 6.4.5   | Termination Status Word (Word 4)      | 6-28 |

### APPENDICES

| Α | ASCII Codes                     | A-1 |
|---|---------------------------------|-----|
| В | Tape Handling Flowcharts        | B-1 |
| С | Floppy Disc Handling Flowcharts | C-1 |

### **FIGURES**

### Title

| 1-1<br>1-2<br>1-3<br>1-4<br>1-5<br>1-6<br>1-7<br>1-8<br>1-9<br>1-10<br>1-11 | POINT 4 MARK 3 Peripheral Interface Board<br>POINT 4 MARK 3B Peripheral Interface Board<br>POINT 4 MARK 2 Peripheral Interface Board<br>Peripheral Interface Board System Block Diagram<br>MARK 3 PIB Internal Architecture<br>MARK 3B PIB Internal Architecture<br>MARK 2 PIB Internal Architecture<br>IOCB Pointer Format<br>Software Polling/Interrupt Handling Flowchart<br>I/O Service Routine Multiplexer Handling<br>Procedures<br>I/O Service Routine Disc/Tape/Floppy Handling<br>Procedures | $ \begin{array}{r} 1-3\\ 1-4\\ 1-5\\ 1-7\\ 1-13\\ 1-14\\ 1-15\\ 1-18\\ 1-20\\ 1-23\\ 1-24\\ \end{array} $ |
|-----------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------|
| <b>0</b> 1                                                                  | Paud Data Haadar Lagatiang                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 2-3                                                                                                       |
| 2-1<br>2-2                                                                  | Baud Rate Header Locations<br>Command Register                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 2-3                                                                                                       |
| 2-2                                                                         | Status Register                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 2-8                                                                                                       |
| 2-4                                                                         | Software Polling Flowchart for                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 20                                                                                                        |
|                                                                             | Output Operations                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 2-11                                                                                                      |
| 2-5                                                                         | MUX Input/Output Control Block                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 2-13                                                                                                      |
| 2-6                                                                         | Input Control Word - Word 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 2-14                                                                                                      |
| 2-7                                                                         | Output Control Word - Word 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 2-20                                                                                                      |
| 2-8                                                                         | Master Reset Instruction Format                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 2-28                                                                                                      |
| 2-9                                                                         | Port Initialization Instruction Format                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 2-29                                                                                                      |
| 2-10                                                                        | Transmitter/Receiver Instruction Format                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 2-30                                                                                                      |
| 3-1<br>3-2                                                                  | Daisy Chain Drive Connection<br>PIB/Disc Drive Differential Bus Signals                                                                                                                                                                                                                                                                                                                                                                                                                               | 3-3<br>3-5                                                                                                |
| 3-3                                                                         | PIB/Disc Drive Differential Synchronization                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                           |
|                                                                             | Cable Signals                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 3-9                                                                                                       |
| 3-4                                                                         | Drive Status                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 3-11                                                                                                      |
| 3-5                                                                         | Contents of DOA Instruction Accumulator                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 3-14                                                                                                      |
| 3-6                                                                         | Tag 1 Instruction Format                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 3-16                                                                                                      |
| 3-7                                                                         | Tag 2 Instruction Format                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 3-17<br>3-18                                                                                              |
| 3-8<br>3-9                                                                  | Tag 3 Instruction Format<br>Disc IOCB Format                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 3-18                                                                                                      |
| 3-10                                                                        | Opcode Word Format                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 3-20                                                                                                      |
| 3-11                                                                        | Unit Number Word Format                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 3-21                                                                                                      |
| 3-12                                                                        | Cylinder Address Word Format                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 3-22                                                                                                      |
| 3-13                                                                        | Head/Volume Word Format                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 3-23                                                                                                      |
| 3-14                                                                        | Sector Address Word Format                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 3-24                                                                                                      |
| - 3-15                                                                      | Sector Count Word Format                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 3-25                                                                                                      |
| 3-16                                                                        | Memory Address Word Format                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 3-26                                                                                                      |
| 3-17                                                                        | Termination Status Word Format                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 3-27                                                                                                      |
| 3-18                                                                        | Seek Operation Timing                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 3-32                                                                                                      |
| 3-19                                                                        | Drive Select and Seek Initiation                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 3-33                                                                                                      |
| 3-20                                                                        | Seek Error Recovery Flowchart                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 3-38<br>3-39                                                                                              |
| 3-21                                                                        | Sector Table in Memory                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 3-33                                                                                                      |

REPER

| 3-22<br>3-23<br>3-24<br>3-25<br>3-26<br>3-27<br>3-28                                      | Sector Block Format - Word O Contents<br>Sector Block Format - Word 1 Contents<br>Sector Block Format - Word 2 Contents<br>Sector Block Format - Word 3 Contents<br>Input/Output Control Block<br>First Sector Block<br>Read-Regardless Operation                                                                                                                                                                                                                     | 3-40<br>3-41<br>3-42<br>3-43<br>3-44<br>3-44<br>3-48                                                         |
|-------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------|
| 4-1<br>4-2<br>4-3<br>4-4<br>4-5<br>4-6<br>4-7                                             | Tape Controller Interface Signals<br>Format of DIA Instruction Accumulator<br>Contents of DOA Instruction Accumulator<br>Tape Controller IOCB Format<br>Tape Controller Command Format<br>Exception Byte 0<br>Exception Byte 1                                                                                                                                                                                                                                        | 4-3<br>4-7<br>4-10<br>4-13<br>4-16<br>4-24<br>4-27                                                           |
| 5-1<br>5-2<br>5-3<br>5-4<br>5-5<br>5-6                                                    | Daisy-Chain Drive Connection<br>PIB/Floppy Disc Drive Interface Signals<br>Select Register Word<br>Restore Command Bit Configuration<br>Seek Command Bit Configuration<br>Drive Status Register Word For Data Transfer                                                                                                                                                                                                                                                | 5-5<br>5-6<br>5-13<br>5-15<br>5-16                                                                           |
| 5-7<br>5-8<br>5-9<br>5-10<br>5-11<br>5-12<br>5-13<br>5-14<br>5-15<br>5-16<br>5-17<br>5-18 | Commands<br>Status Register For Head Movement Commands<br>Floppy Disc IOCB Format<br>Read Sector Command Word Bit Configuration<br>Write Sector Command Word Bit Configuration<br>ID Field<br>Read Address Command Word Bit Configuration<br>Read Track Command Word Bit Configuration<br>Write Track Command Word Bit Configuration<br>Memory Address Word Bit Configuration<br>Termination Status Word Format<br>Seek Operation Flowchart<br>512-Byte Sector Format | 5-17<br>5-19<br>5-23<br>5-25<br>5-27<br>5-29<br>5-29<br>5-30<br>5-31<br>5-32<br>5-32<br>5-32<br>5-37<br>5-40 |
| 6-1<br>6-2<br>6-3<br>6-4<br>6-5<br>6-6<br>6-7<br>6-8<br>6-9<br>6-10                       | WD1002-5 Disc Controller Interface Signals<br>Error Register Bit Configuration<br>Low-High Cylinder Registers and Cylinder Number<br>SDH Register Bit Configuration<br>Test Command Bit Configuration<br>Restore Command Bit Configuration<br>Seek Command Bit Configuration<br>Status Register Bit Configuration<br>ST506 Disc IOCB Format<br>Read Sector/Readlong Command Bit Configuration                                                                         | 6-4<br>6-13<br>6-16<br>6-17<br>6-18<br>6-19<br>6-20<br>6-21<br>6-23<br>6-24                                  |
| 6-11<br>6-12<br>6-13                                                                      | Write Sector/Writelong Command Bit<br>Configuration<br>Format Track Command Bit Configuration<br>Sector Number and Count Bit Configuration                                                                                                                                                                                                                                                                                                                            | 6-25<br>6-26                                                                                                 |
| 6-14                                                                                      | (Word l of IOCB)<br>Cylinder Number Bit Configuration<br>(Word 2 of IOCB)                                                                                                                                                                                                                                                                                                                                                                                             | 6-27<br>6-27                                                                                                 |
| 6-15                                                                                      | Memory Address Bit Configuration<br>(Word 3 of IOCB)                                                                                                                                                                                                                                                                                                                                                                                                                  | 6-28                                                                                                         |
| 6-16                                                                                      | Termination Status Bit Configuration<br>(Word 4 of IOCB)                                                                                                                                                                                                                                                                                                                                                                                                              | 6-28                                                                                                         |
| HM-081-0<br>POINT 4                                                                       | 027-D<br>Data Corporation xiii MARK 2/3 Peripherals                                                                                                                                                                                                                                                                                                                                                                                                                   | Manual                                                                                                       |

| B-1<br>B-2<br>B-3<br>B-4<br>B-5<br>B-6<br>B-7 | (Tape Flowcharts)<br>Command Transfer Sequence Flowchart<br>Read Status Sequence Flowchart<br>Write Sequence Flowchart<br>Read Sequence Flowchart<br>Write Transfer Sequence Flowchart<br>Read Transfer Sequence Flowchart<br>Off-line Sequence Flowchart | B-2<br>B-3<br>B-4<br>B-5<br>B-6<br>B-7<br>B-8 |
|-----------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------|
| C-1<br>C-2<br>C-3<br>C-4                      | (Floppy Disc Flowcharts)<br>Head Movement (Type I) Flowchart<br>Read/Write Sector (Type II) Flowchart<br>Write Track (Type III) Flowchart<br>Read Track/Read Address (Type III) Flowchart                                                                 | C-3<br>C-6<br>C-9<br>C-11                     |

### TABLES

### Number

### Title

### Page

2 - 22-1 Baud Rate Jumpering 2-2 Port Assignments for Baud Rate Headers 2-2 2-4 2-3 DOA, DIA Device Codes 2-6 2 - 4Command Register Bit Functions 2-9 2-5 Status Register Bit Operations 2 - 6Input Control Word Definitions (Word 0 of Each Control Block) 2-15 2-7 Output Control Word Definitions 2-21 (Word 1 of Each Control Block) 2-31 2 - 8Enabling/Disabling Operation 3-1 Disc Drive Differential Bus Signals (A Cable Pin Assignment) 3-6 3-10 Drive Synchronization Cable Signals 3-2 3-12 3-3 Drive Status Definitions 3-15 3 - 4DOA Instruction Accumulator Bits 3-5 Data Bus Bit Functions with Tag 1 3-16 Data Bus Bit Functions with Tag 2 3 - 173-6 3-18 3-7 Data Bus Bit Functions with Tag 3 3-20 3-8 Disc IOCB Word 0 Disc IOCB Word 1 3-21 3-9 Disc IOCB Word 2 3-22 3-10 3-23 Disc IOCB Word 3 3-11 3 - 243 - 12Disc IOCB Word 4 Disc IOCB Word 5 3-25 3-13 Disc IOCB Word 6 3-26 3-14 Disc Termination Status Word 7 3-28 3-15 Sector Block Format - Word 0 Functions 3-40 • 3-16

xiv

| HM-081 | -0 | 027-0 | 2           |
|--------|----|-------|-------------|
| POINT  | 4  | Data  | Corporation |

| 3-17<br>3-18<br>3-19 | Sector Block Format - Word 1 Functions<br>Sector Block Format - Word 2 Functions<br>Sector Block Format - Word 3 Functions | 3-41<br>3-42<br>3-43 |
|----------------------|----------------------------------------------------------------------------------------------------------------------------|----------------------|
| 4-1                  | Tape Controller Interface Cable<br>Jl Signal Functions                                                                     | 4-4                  |
| 4-2                  | DIA Instruction Accumulator Bits                                                                                           | 4-8                  |
| 4-3                  | DOA Instruction Accumulator Bits                                                                                           | 4-11                 |
| 4-4                  | Status Byte Definitions                                                                                                    | 4-23                 |
| 4-5                  | Exception Byte 0 Bit Definition                                                                                            | 4-25                 |
| 4-6                  | Exception Byte 1 Bit Definition                                                                                            | 4-28                 |
| 5-1                  | 8-Inch Floppy Disc Controller Interface<br>(Jl Signal Functions)                                                           | 5-7                  |
| 5-2                  | 5-1/4-Inch Floppy Disc Controller Interface<br>(J17 Signal Functions)                                                      | 5-10                 |
| 5-3                  | Drive Status Definitions For Data Transfer<br>Commands                                                                     | 5-18                 |
| 5-4                  | Drive Status Definitions For Head Movement<br>Commands                                                                     | 5-20                 |
| 5-5                  | Sector Length Flag Setting                                                                                                 | 5-24                 |
|                      | Read Sector Command Bit Configuration                                                                                      | 5-26                 |
| 5-7                  | Write Sector Command Bit Configuration                                                                                     | 5-28                 |
| 5-8                  | Gap Sizes                                                                                                                  | 5-41                 |
| 6-1                  | ST506 Drive Control (J7) Signals                                                                                           | 6-5                  |
| 6-2                  | ST506 Drive Data (J1 thru J3) Signals                                                                                      | 6-7                  |
| 6-3                  | Floppy Disc Drive Control (J8) Signals                                                                                     | 6-8                  |
| 6-4                  | Diagnostic Error Codes                                                                                                     | 6-12                 |
| 6-5                  | Error Register Bit Definitions                                                                                             | 6-14                 |
| 6-6                  | Status Register Bit Functions                                                                                              | 6-22                 |
| A-1                  | ASCII Codes in Octal                                                                                                       | A-1                  |

MARK 2/3 Peripherals Manual



# Section 1 INTRODUCTION

### **1.1 GENERAL DESCRIPTION**

The Peripheral Interface Board (PIB) is a controller that interfaces the POINT 4 MARK 3 CPU to various groups of peripherals via the backplane. The PIB provides the following features:

- Separate Software Programmed I/O Control
- DMA Data Transfer
- Simultaneous Operation of Peripherals
- Ease of Software Interface

The PIB is available in three versions: the MARK 3 PIB, the MARK 3B PIB, and the MARK 2 PIB. The peripherals interfaced by each PIB are as follows:

- 1. MARK 3 PIB interfaces:
  - Asynchronous communications lines
  - Up to two disc drive units
  - QIC-02 streaming tape drive unit
- 2. MARK 3B PIB interfaces:
  - Asynchronous communications lines
  - Up to two disc drive units
  - Up to four floppy disc drive units
- MARK 2 PIB interfaces: 3.
  - Asynchronous communications lines
  - One ST506 5-1/4-inch disc drive unit
  - QIC-02 streaming tape drive unit
  - 5-1/4-inch floppy disc drive unit

The boards are easily distinguished because the layout of connectors and crystals is different for each board.

The MARK 3 PIB has the following distinguishing features:

- MARK 3 PIB label at the lower right corner of the board
- One crystal at the upper right
- A 50-pin connector at location Jl

The MARK 3 PIB layout is shown in Figure 1-1.

The MARK 3B PIB can be recognized by the following features:

- MARK 3B PIB label at the lower left corner of the board
- Two crystals along the right side of the board
- A 40-pin chip above location J17
- 50-pin connector at location Jl for 8-inch floppy disc drives
- 34-pin connector at location J17 for 5-1/4-inch floppy disc drives

The MARK 3B PIB is set up for 8-inch and 5-1/4-inch floppy disc drives. Because of a difference in cabling and timing requirements, only one size of floppy disc drive can be used at one time.

The layout of a MARK 3B PIB is shown in Figure 1-2.

The MARK 2 PIB has the following distinguishing features:

- MARK 2 PIB label at the lower right corner of the board
- WD1002-5 controller mounted on the left side of the board

The layout of a MARK 2 PIB is shown in Figure 1-3.



081-8

Figure 1-1. POINT 4 MARK 3 Peripheral Interface Board

### INTRODUCTION 1-3 MARK 2/3 Peripherals Manual





| 8-INCH FLOPPY            | J1             |
|--------------------------|----------------|
| PRINTER OR<br>CRT CABLES | J2<br>J3<br>J4 |
| MASTER CRT CABLE         | J5             |
| DISC CABLE A             | J6             |
| DISC CABLE B - NO. 2     | J7             |
| DISC CABLE B - NO. 1     | J8             |
| 5% INCH FLOPPY CABLE     | J17            |

081-9

Figure 1-2. POINT 4 MARK 3B Peripheral Interface Board



BACKPLANE

Figure 1-3. POINT 4 MARK 2 Peripheral Interface Board

HM-081-0027-D POINT 4 Data Corporation

### INTRODUCTION 1-5 • MARK 2/3 Peripherals Manual

### 1.1.1 SYSTEM DESCRIPTION

A PIB interfaces to the MARK 3 CPU via the backplane, providing high-speed DMA transfer between peripherals and the CPU. Control for all PIB functions is provided by the CPU as needed via I/O instructions.

Each PIB contains three main control modules:

- Asynchronous Communications Control Module (see Section 2)
- CMD/SMD/LMD Disc Drive Control Module (see Section 3)

or

ST506 Disc Drive Control Module (see Section 6)

• Tape Drive Control Module (see Section 4)

or

Floppy Disc Drive Control Module (see Section 5)

Figure 1-4 shows the basic system block diagram for the PIB. Communication is via the backplane DMA facility, utilizing I/O control blocks (IOCBs) for access control. The PIB includes device control and instruction decode logic. This allows the CPU to access each control module individually.



.

081-24

•

### Figure 1-4. Peripheral Interface Board System Block Diagram

### **1.1.2 EQUIPMENT CHARACTERISTICS**

The following subsections give performance and equipment characteristics for the MARK 3 Peripheral Interface Board.

Cables are normally supplied by the drive vendor. POINT 4 does not supply the Mux cables. For Mux cabling specification and installation, refer to the POINT 4 MARK 3 Computer System Manual.

### 1.1.2.1 Communications Control

Transmission Type: Asynchronous Line Types: Half or Full Duplex Line Interface: RS-232C Number of Ports: Four (Seven with Port Expansion Board option) Modes of Operation: Programmed I/O Port 0 - Device Code 10/11 Port 1 - Device Code 12/13 Port 2 - Device Code 14/15 Port 3 - Device Code 16/17 Port 4 - Device Code 20/21 Port 5 - Device Code 22/23 Port 6 - Device Code 24/25 (Ports 4 thru 6 are Optional Expansion Ports) DMA Operation - Device Code 77 Serial Line Printer: May be connected to any port

Baud Rates (hardware strappable): 110, 150, 300, 600, 1200, 2400, 4800, 9600

### 1.1.2.2 Disc Drive Interface on MARK 3 and MARK 3B PIBs

```
Drives per Controller:
   Two
Drive Type:
   SMD/CMD/LMD
DMA Transfer Rate:
    1.25 megabytes per second
Sector Size:
   Header - 8 bytes
   Data - 512 bytes
```

### 1.1.2.3 Disc Drive Interface on a MARK 2 PIB

```
Drives per Controller:
    One (limited by packaging only)
Drive Type:
    ST506 drive
DMA Transfer Rate:
    3 microseconds per word (approximate)
Sector Size:
    Data - 512 bytes
```

### 1.1.2.4 Tape Drive Interface on MARK 3 and MARK 2 PIBs

Drives per Controller: MARK 3 PIB - One MARK 2 PIB - One

- Drive Type: QIC-02 Streaming Tape
- Tape Data Rate: 90 kilobytes/second

Tape Speed: 90 inches/second

Tape Capacity: 20 or 45 megabytes

### 1.1.2.5 Floppy Disc Drive Interface on a MARK 3B PIB

Drives per Controller: Four Drive Type: Shugart-compatible (soft-sectored) drives supporting single and double-sided, single and double-density diskettes with head-load-on-select jumper. The drives can be either • 8-inch Floppy Disc Drive • 5-1/4-inch Floppy Disc Drive DMA Transfer Rate: Single Density = 250 kilobits/second Double Density = 500 kilobits/second Rotational Speed: 360 RPM Diskette Capacity: Depends on size of diskette, format, and sector size. For example, an 8-inch diskette, double sided, double density, with 512-byte sectors (required for IRIS) = 1.24megabytes Formats Supported: IBM 1 Frequency Modulation (FM) IBM 2 Modulated Frequency Modulation (MFM) IBM 2D MFM 1.1.2.6 Floppy Disc Drive Interface on a MARK 2 PIB Drives per Controller: Four (currently one per MARK 2 system) Drive Type: 5-1/4-inch 460-type supporting 96 tracks per inch, double-sided, double-density diskettes DMA Transfer Rate: 250 kilobits/second Diskette Capacity: 640 kilobytes formatted Format: MFM NOTE Diskettes should be 5-1/4-inch, 96TPIcertified, double-sided, double-density.

HM-081-0027-D

INTRODUCTION POINT 4 Data Corporation 1-10 MARK 2/3 Peripherals Manual

### 1.1.2.7 Input/Output Instructions

```
Input - DIA
Output - DOA
Device Codes:
    10-17 - MUX Ports 0-3
    20-25 - Expansion Ports 4-6
    30-37 - Floppy Disc 0-3
    50-55 - SMD Disc 0&1
    50-57 - WD1002-5
    60-62 - Tape 0-3
DMA (Device Code 77):
    DOBS/DIBS - MUX
    DOBC/DIBC - Disc
    DOBP/DIBP - Tape or Floppy
CPU Functions (Device Code 77):
    SKPBN - Skip if Interrupts Enabled
    SKPDN - Skip if Power-Fail Detected
    SKPBZ - Skip if Interrupts Disabled
```

SKPDZ - Skip if no Power-Fail Detected

HM-081-0027-D POINT 4 Data Corporation

### **1.1.3 PIB INTERNAL ARCHITECTURE**

Four types of control functions are performed by a PIB:

- General Control Functions
- Multiplexer Control Functions
- Disc Control Functions
- Tape or Floppy Disc Control Functions

General Control Functions include data reception/transmission, command decoding, device decoding, and status recording.

Multiplexer Control Functions include jumper-selectable baud rate, data transfer synchronization, port selection, data format manipulation, and the real-time clock.

Disc Control Functions include disc selection, bus control for DMA transfer, word count, CRC generation, tag line control (MARK 3 configurations only), and ECC (MARK 2 only).

Tape Control Functions include function decode, strobe generation, command and status, and data transfer control.

Floppy Disc Control Functions include side and unit selection, bus control for DMA transfer, CRC generation and checking, and data transfer control.

Figure 1-5 shows the internal architecture of a MARK 3 PIB, Figure 1-6 a MARK 3B PIB, and Figure 1-7 a MARK 2 PIB.

HM-081-0027-C POINT 4 Data Corporation





HM-081-0027-C POINT 4 Data Corporation

INTRODUCTION 3 MARK 2/3 Peripherals Manual

1-13



# Figure 1-6. MARK 3B PIB Internal Architecture

HM-081-0027-C POINT 4 Data Corporation INTRODUCTION 1-14 MARK 2/3 Peripherals Manual



HM-081-0027-C POINT 4 Data Corporation

### INTRODUCTION 1-15• MARK 2/3 Peripherals Manual

### **1.2 INPUT/OUTPUT INTERFACE HANDLING**

This section provides information about basic operating principles and programming methods for input/output devices. Two types of I/O devices are compatible with the POINT 4 MARK 3 Computer:

- those transferring data via I/O programmed instructions only
- those using Direct Memory Access (DMA) for input/output transfers

The following subsections outline interrupt handling and priority scheme, programmed transfer handling and DMA channel transfer handling.

### **1.2.1 PROGRAM INTERRUPT AND PRIORITY SCHEME**

Many I/O devices require service within a short time of request; however, service is needed infrequently (relative to the processor speed) and only a small amount of time is required to service them. Failure to service within the specified time (which varies among devices) causes operation below the device's maximum speed and can result in loss of information.

The use of interrupts in the current program sequence facilitates concurrent operation of the main program and servicing of a number of peripheral devices. The program interrupt scheme allows an I/O device to gain control of the processor. When a device raises an interrupt-request flag, the processor suspends normal program execution and starts a device service routine. When the routine is completed, the processor returns to the interrupted program.

### 1.2.1.1 Interrupt Sequence

When a device needs service, it sets its interrupt-request flag. The processor begins servicing interrupts if all four of the following conditions exist:

- The processor has just completed an instruction fetch or a data channel transfer
- At least one device has an interrupt-request flag set
- Interrupts are enabled (i.e., ION is set)
- No device is waiting for a DMA transfer

The processor responds to the interrupt request by storing the value of the program counter in memory location 0 and jumping to the instruction addressed by memory location 1. Location 1 must contain the address of the interrupt handling routine. Interrupts are disabled at the start of the interrupt service cycle and must be re-enabled by the software at the end of the interrupt service.

The POINT 4 MARK 3 has only one priority level for interrupts. The mask-out (MSKO) instruction may be used to mask out interrupts and still allow use of programming routines using INTDS/INTEN instructions. MSKO is also used to turn DMA operation on and off. The single priority level is reflected in the least significant bit (LSB) of the accumulator specified in the MSKO instruction. The value of the accumulator can be interpreted as follows:

| Accumulator<br><u>Value</u> | Function                                   |
|-----------------------------|--------------------------------------------|
| Odd (≠ 1)                   | Masks out (disables) all interrupts        |
| Even (≠ 0)                  | Masks in (enables if ION=1) all interrupts |
| = 1                         | Disables DMA to controllers                |
| = 0                         | Enables DMA to controllers                 |

### **1.2.1.2** Programming Polling and Interrupts

Pending interrupts are flagged in the most significant bit (MSB) of the pointer to the device controller input/output control block (IOCB) as shown in Figure 1-8. Because the MSB of the address is used as the interrupt-pending bit, IOCBs must be in the lower 32K of memory on MARK 3 configurations. For a MARK 2, the MSB of the IOCB address is not used for interrupt-pending. Therefore, the full 16 bits can be used for addressing.

The DIB instruction with a device code of 77 (CPU) is used to read the IOCB pointers (registers 13-15). There are three forms of DIB instructions, one for each of the device controllers. The control field of the I/O instruction is used to designate multiplexer (S), disc controller (C), or tape or floppy controller (P). The resulting I/O instructions are:

- DIBS ac,77 read MUX pointer
- DIBC ac,77 read Disc pointer
  DIBP ac,77 read Tape or Floppy pointer



081-28

### Figure 1-8. IOCB Pointer Format

For MARK 3 configurations, two software procedures are used to service I/O devices using the DIB instruction:

- Polling Disable interrupts using an INTDS or a MSKO 1. instruction. The DIB with S, C or P must be used to constantly poll the IOCB pointers to check for MSB = 1. Upon detecting a pending interrupt, the program jumps to a device service routine. After servicing of the first pending interrupt encountered, the other IOCB pointers should be checked, since more than one interrupt may be pending at one time.
- Interrupting Enable interrupts using an INTEN instruction. 2. The system will be in automatic-transfer mode. When an interrupt is generated by a device requesting service, the processor resets the interrupt-request flag and jumps to a software interrupt handling routine. There the DIB instruction is used to read the IOCB pointers to check for MSB = 1. The controller causing the interrupt is serviced immediately as described in Section 1.2.1.1. Note that if more than one controller is requesting service, each should be serviced at this time. If not, a pending interrupt will be ignored.

HM-081-0027-C POINT 4 Data Corporation

INTRODUCTION 1-18 MARK 2/3 Peripherals Manual

In the automatic-transfer mode, interrupts may also be generated by a controller either when the block transfer is finished or when a status change or error has occurred. In either case the controller sets the interrupt-request flag and the processor responds by resetting the interrupt-request flag and jumping to a software read-status handling routine, as described above.

When using either method, the software must first reset the interrupt-pending bit in the IOCB pointer before jumping to the interrupt servicing routine.

Resetting the interrupt-pending bit at that time ensures the detection of a second interrupt-pending condition while the first one is being serviced.

The IOCB for each multiplexer port contains an operation-complete bit (bit 0 of word 0 or 1). The operation-complete bit is set by the multiplexer when an interrupt is requested. This bit is used by the software to confirm that the pending interrupt was caused by the IOCB for this device.

The operation-complete bit is essential to multiplexer operation, since there is only one multiplexer IOCB pointer and thus one interrupt-pending flag for all multiplexer ports. Each port is identified by an IOCB. Bit 0 of word 0 (input operations) and word 1 (output operations) designates operation-complete status for that port. When software detects an interrupt pending for the multiplexer, the software must scan the multiplexer IOCBs (see Section 2.4) to determine which port needs service (bit 0 set to 1). More than one port may be completing a transfer at any one time. Care must be taken to scan all operation-complete bits, even if one set operation-complete bit has been detected. The operation-complete bit must be reset to 0 by the software in order to prevent redundancy in servicing of I/O ports.

For an SMD configuration, in addition to an operation-complete bit (bit 0, word 7), the disc controller IOCB also contains a summary-error bit in the termination status (bit 1, word 7) which is used to flag the existence of an error condition in disc transfer. Like the operation-complete bit, the summary-error bit is set by the disc controller when an error has been detected and is read by the software to determine the cause of the interrupt. This bit must be reset to 0 by software in order to prevent redundancy in interrupt servicing.

Figure 1-9 is a flowchart showing the sequence of steps that must be taken into account when programming polling and interrupt processing procedures for a MARK 3 configuration. Refer to Section 6 for the MARK 2 procedure. Note that interrupts other than those caused by the Peripheral Interface Board (i.e., power-fail interrupt) are not covered in this flowchart. Figure 1-9 begins with the polling of the interrupt-pending bit. Arrival at this point in the software procedure may have been from a constant polling sequence or from an interrupt that caused a jump to a poll routine.

HM-081-0027-C POINT 4 Data Corporation



## Figure 1-9. Software Polling/Interrupt Handling Flowchart (1 of 2)

HM-081-0027-C POINT 4 Data Corporation



# Figure 1-9. Software Polling/Interrupt Handling Flowchart (2 of 2)

Figures 1-10 and 1-11 are flowcharts of parts of the I/O service routines for the multiplexer and for disc, tape or floppy. The part of the service routines shown only takes into account testing of operation-complete and various error bits. The remainder of the service routine is determined by the programmer.

HM-081-0027-C

INTRODUCTION POINT 4 Data Corporation 1-22 MARK 2/3 Peripherals Manual





081-30

## Figure 1-10. I/O Service Routine Multiplexer Handling Procedures

HM-081-0027-C POINT 4 Data Corporation





Figure 1-11. I/O Service Routine Disc/Tape/Floppy Handling Procedures

HM-081-0027-C POINT 4 Data Corporation 1-24 Sec. al

## 1.2.2 PROGRAMMED I/O TRANSFERS

For programmed input/output the program directly controls the data transfer between the CPU and the I/O device. Programmed I/O is used by the multiplexer in communications-byte mode. Each data word is transferred between an accumulator specified in the instruction and an I/O device register (see MARK 3 Computer System Manual, Section 5.6).

Programmed I/O uses DIA and DOA instructions to program transfer of data and status information between the CPU and peripheral device controllers. The two programmed I/O instructions are used as follows:

- DIA Transfers (reads) contents of either the status or data register in the specified port's UART into the specified CPU accumulator. If the device code is even, contents of the status register are transferred. If device code is odd, the contents of the data register are transferred.
- DOA Transfers (writes) contents of the specified CPU accumulator to either the command or data register in the specified port's UART. If the device code is even, contents of the accumulator are transferred to the command register. If the device code is odd, contents of the accumulator are transferred to the accumulator are transferred to the data register.

See Section 2.3 for detailed description of byte-mode operations.

### **1.2.2.1** Master Terminal Interface

All alphanumeric and control characters are represented by standard ASCII code (see Appendix A) consisting of eight bits, the most significant of which is usually an even parity bit.

The following are programming conventions for handling CRT terminals:

- Instruction Formats The data-transfer-output instruction transmits bits 8-15 from the specified accumulator to the output-interface register. The input-interface instruction loads the contents of the input-interface register into bits 8-15 and resets bits 0-7 of the specified accumulator.
- Terminal Data Word Output To transfer a data character from an accumulator to the Port 0 UART, the following instruction is used:

DOA ac,11

where ac represents one of the four processor accumulators.

• Terminal Command Output - To transfer a command from an accumulator to the Port O UART, the following instruction is used:

DOA ac,10

This instruction causes bits 8-15 of the accumulator to be transferred to the command register of Port 0. Bit 0 of the accumulator is also used for enabling/disabling the real-time clock.

• Terminal Data Word Input - When a key is pressed on the keyboard, the data word is placed in the data register. If interrupts are enabled an interrupt is requested. The program then reads the data word from the data register into bits 8-15 of the specified accumulator with the following instruction:

DIA ac,11

 Terminal Status Input - A change in terminal status causes an interrupt request, if interrupts are enabled. The program must read the status of Port 0 from the status register into bits 8-15 of the specified accumulator using the following instruction:

DIA ac,10

## **1.2.3 DIRECT MEMORY ACCESS TRANSFERS**

Mass storage devices (such as tape, floppy disc or disc drives) can transfer blocks of data at high speeds directly into memory, without requiring programmed I/O instructions for each word transferred, by using the DMA (direct memory access). DMA device interface logic contains both conventional device registers and special data channel logic.

At the start of each instruction cycle, the processor checks to see if a device is requesting DMA service. If a device is requesting service, the DMA transfer is performed before going on with the instruction. The program initiates a DMA transfer by supplying certain parameters to the device registers and starting the device. The device automatically transfers one or more data words to or from memory. When the DMA transfer is completed, the device generates an interrupt (if so enabled). The processor acknowledges the interrupt, checks the operation-complete status and resets the interrupt-request flag.

See Section 1.2.1.2 for interrupt handling procedures.

## 1.2.3.1 Enabling/Disabling DMA Transfers

The mask-out (MSKO) instruction is used to enable and disable DMA transfers. To enable/disable DMA, special values must be loaded into the CPU accumulator specified in the MSKO instruction. These values are:

| Accumulator<br><u>Value</u> | Function                    |
|-----------------------------|-----------------------------|
| 1                           | Disables DMA to controllers |
| 0                           | Enables DMA to controllers  |

An alternate way of expressing the MSKO instruction is to use a DOB instruction with a device code of 77 octal as follows:

| Instruction | Accumulator<br><u>Value</u> | Function                    |
|-------------|-----------------------------|-----------------------------|
| DOB ac,77   | 1                           | Disables DMA to controllers |
| DOB ac,77   | 0                           | Enables DMA to controllers  |

Alternate methods of disabling DMA transfer include:

- Issue an IORST instruction (clears processor's ION flag)
- Press the RESET switch (gives control to the Virtual Control Panel-MANIP)
- Power-up the system (gives control to the Virtual Control Panel-MANIP)
- Issue a halt instruction (gives control to the Virtual Control Panel-MANIP)

#### NOTE

The longer the period of time DMA is disabled, the greater the risk of having an overrun of data in the multiplexer or of having the streaming tape come to a stop due to data underrun. Thus, DMA should be disabled the minimum time possible.

### 1.2.3.2 Initiating DMA Transfer

Three configurations of the DOB instructions are used to initiate DMA transfers:

| DOBS | ac <b>,</b> 77 | set | Mult: | iple | exer IO | СВ   |
|------|----------------|-----|-------|------|---------|------|
| DOBC | ac <b>,</b> 77 | set | Disc  | 100  | СВ      |      |
| DOBP | ac <b>,</b> 77 | set | Tape  | or   | Floppy  | IOCB |

Accumulator ac contains the memory address of the input/output control block (IOCB) for the device specified. Accumulators 13 through 15 are used for IOCB pointers as follows:

| <u>Accumulator</u> | <u>Device Controller IOCB</u> |
|--------------------|-------------------------------|
| 13                 | Multiplexer                   |
| 14                 | Tape or Floppy                |
| 15                 | Disc                          |

If an IOCB pointer contains a value of 0, the device controller is not being used in the system. On MARK 3 configurations, the most significant bit (MSB) of this accumulator is set to 1 when an interrupt is pending. For DMA transfers on MARK 3 configurations, the MSB must be reset to 0 after interrupt processing to avoid erroneous interrupt processing. Refer to Section 6 for information on the MARK 2.

When issued to the disc, floppy, or tape controllers, the DOB instruction signals the corresponding controller. The controller responds by performing an automatic block transfer of data as specified in the IOCB for that device. The following is an example of a MARK 3 SMD disc DMA operation:

IOCB Address: 075000

Instruction: DOBC 1,77

Accumulator 1 Value: A1 = 011110100000000

> Memory address 75007 (termination word): Must be set to 0 (Reserved for termination code)

When issued to the multiplexer, the DOBS instruction sets the software pointer to the multiplexer IOCB pointer but does not initiate any action on the part of the multiplexer. When the DOBS is complete, the software routine must issue DOA instructions to each port on which input or output is to be The DOA instruction will initiate DMA transfer between enabled. the CPU and the peripheral device.

HM-081-0027-C

## 1.2.3.3 Turning Off Automatic Block Transfer Mode For Disc, Tape or Floppy

DOB instructions with device code 77 may be used to turn off automatic block transfer mode to disc, tape or floppy and/or reset the interrupt-pending bit in the IOCB pointer. Both of these functions must be performed by the software. To turn off automatic-block-transfer mode and reset the interrupt-pending bit for disc, tape or floppy, issue a DOBC or DOBP with the accumulator set to zero:

Instruction: DOBC 1,77 for disc DOBP 1,77 for tape or floppy

Accumulator 1 Value: A1 = 0

1

This sequence turns off automatic transfer mode and resets the interrupt-pending bit.

#### NOTE

Except on a MARK 2, it is important that the most significant bit (MSB) be set to 0. If a DOBC or DOBP is issued with a value of 1 in the MSB, it will initiate processing of an interrupt which may or may not be pending for the controller whose IOCB address is in the accumulator.

#### 1.2.3.4 Turning Off Automatic Block Transfer Mode For Multiplexer

Caution must be taken when using a DOBS to turn off automaticblock-transfer mode to the multiplexer and/or reset the interrupt-pending bit for the multiplexer. If the accumulator contains a value of 0 when the DOBS is issued, the automatic mode is turned off for <u>all</u> ports, regardless of whether a port is in the process of performing a block transfer.

For a majority of operations, the DOBS is used only to reset the interrupt-pending bit. In this case, the contents of the accumulator specified in the DOBS instruction should be set to the address of the multiplexer IOCB pointer with the most significant bit set to 0.

## Section 2 MULTIPLEXER

## 2.1 INTRODUCTION

The multiplexer (MUX) portion of the Peripheral Interface Board supports four asynchronous ports which use the EIA-RS232C interface. Each port is independently software programmable. This allows selection of the number of bits per character, number of stop bits, and odd, even, or no parity. Baud rates are hardware jumper selectable in a range of 110 to 9600 bits per second.

Multiplexer operation is in either byte mode, using programmed I/O instructions, or in automatic-block-transfer mode using direct memory access (DMA) procedures based on information contained in an input/output control block (IOCB) for each port. Receiver and transmitter sections of the port are operated independently of one another. Associated with Port 0 is a real-time clock that, when enabled, causes an interrupt every 10 milliseconds.

## 2.2 BAUD-RATE SELECTION

The following baud rates may be hardware jumpered for MARK 3 communications ports:

| 110 | 1200 |
|-----|------|
| 150 | 2400 |
| 300 | 4800 |
| 600 | 9600 |

Header jumpering for each baud rate is given in Table 2-1.

Header-port correspondence is given in Table 2-2.

Locations of the baud rate headers for jumpering (which are the same for both PIBs) are shown in Figure 2-1.

| Baud Rate  | Jumper             | Baud Rate    | Jumper            |
|------------|--------------------|--------------|-------------------|
| 110        | 16 to 1            | 1200         | 12 to 5           |
| 150        | 15 to 2            | 2400         | 11 to 6           |
| 300<br>600 | 14 to 3<br>13 to 4 | 4800<br>9600 | 10 to 7<br>9 to 8 |
|            | · ·                |              |                   |

#### TABLE 2-1. BAUD RATE JUMPERING

TABLE 2-2. PORT ASSIGNMENTS FOR BAUD RATE HEADERS

| Standard   | Ports    | Expansion  | n Ports  |
|------------|----------|------------|----------|
| Header No. | Port No. | Header No. | Port No. |
| J16        | 0        | J12        | 4        |
| J15        | 1        | J11        | 5        |
| J14        | 2        | J10        | 6        |
| J13        | 3        |            |          |

No. SEL

.

diff the



•PIN 1

081-32

Figure 2-1. Baud Rate Header Locations

HM-081-0027-C POINT 4 Data Corporation

## MULTIPLEXER 2-3• MARK 2/3 Peripherals Manual

## 2.3 COMMUNICATIONS BYTE MODE

This section outlines the communications-byte mode programming protocols for the multiplexer controller on the Peripheral Interface Board (PIB). Communications-byte mode can operate in both DMA channel and programmed I/O modes. Section topics include: programmed I/O instructions, UART asynchronous communications, command and status registers, and software polling.

## 2.3.1 PROGRAMMED I/O INSTRUCTIONS

When the communications controller is used in the byte mode, command, status and data transfer are accomplished through programmed I/O (see Section 1.2.2), utilizing DOA and DIA instructions (see Section 5.6.1). Valid DOA and DIA device codes for each port and their functions are shown in Table 2-3.

| Device Code<br>(Octal) | Read (DIA)                                            | Write (DOA)                       |
|------------------------|-------------------------------------------------------|-----------------------------------|
| 10<br>11               | PORT 0<br>Status Register<br>Data Register            | Command Register<br>Data Register |
| 12<br>13               | PORT 1<br>Status Register<br>Data Register            | Command Register<br>Data Register |
| 14<br>15               | PORT 2<br>Status Register<br>Data Register            | Command Register<br>Data Register |
| 16<br>17               | PORT 3<br>Status Register<br>Data Register            | Command Register<br>Data Register |
| 20<br>21               | PORT 4 (optional)<br>Status Register<br>Data Register | Command Register<br>Data Register |
| 22<br>23               | PORT 5 (optional)<br>Status Register<br>Data Register | Command Register<br>Data Register |
| 24<br>25               | PORT 6 (optional)<br>Status Register<br>Data Register | Command Register<br>Data Register |

2-4

| TABLE 2-3 |  | DOA, | DIA | DEVICE | CODES |
|-----------|--|------|-----|--------|-------|
|-----------|--|------|-----|--------|-------|

MULTIPLEXER MARK 3 Peripherals Manual

## 2.3.2 UART ASYNCHRONOUS COMMUNICATIONS

The UART is an asynchronous communications chip with four internal registers. Two registers are read-only; two are The UART is programmable, and can select port write-only. characteristics: number of bits per character; number of stop bits; and odd, even, or no parity. In byte-mode operation, programming is directed by programmed I/O software procedures. An example of the UART programming process is provided below, using Port 0 and its associated device codes (10 and 11 octal).

### 2.3.3 COMMAND REGISTER

The following instruction is used to write to the command register (Port 0):

DOA ac,10

Only the least significant byte of the accumulator (ac) is used. The accumulator bits 8-15 will contain the command information to be loaded into the multiplexer's command register (in this example, Port 0). The command information is used to establish operational parameters for this port. The most significant byte (bits 0-7) must be set to zero (0).

Figure 2-2 shows the format of the command register. Bits, settings, and their functions are shown in Table 2-4.



## Figure 2-2. Command Register

| Setting                         |                                      |                                      | Function                                                                                                                                                                                                                                                                                   |  |  |  |  |  |
|---------------------------------|--------------------------------------|--------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| В                               | its 0-7*                             |                                      | Reserved - Must be set to zero                                                                                                                                                                                                                                                             |  |  |  |  |  |
|                                 | Bit 8<br>(MSB)                       |                                      | Receiver Interrupts                                                                                                                                                                                                                                                                        |  |  |  |  |  |
|                                 | 0<br>1                               |                                      | Receiver interrupts disabled<br>Receiver interrupts enabled                                                                                                                                                                                                                                |  |  |  |  |  |
| Bit <b>9</b>                    | Bi                                   | t 10                                 | Transmit Control                                                                                                                                                                                                                                                                           |  |  |  |  |  |
| 0                               |                                      | 0                                    | Transmit interrupts disabled<br>(RTS low)                                                                                                                                                                                                                                                  |  |  |  |  |  |
| 0                               |                                      | 1                                    | Transmit interrupts enabled<br>(RTS low)                                                                                                                                                                                                                                                   |  |  |  |  |  |
| 1                               |                                      | 0                                    | Transmit interrupts disabled<br>(RTS high)                                                                                                                                                                                                                                                 |  |  |  |  |  |
| 1                               |                                      | 1                                    | Transmit interrupts disabled<br>(RTS low, transmits a break and<br>transmits data output).                                                                                                                                                                                                 |  |  |  |  |  |
| Bit 11                          | Bit 12                               | Bit 13                               | Word Select                                                                                                                                                                                                                                                                                |  |  |  |  |  |
| 0<br>0<br>0<br>1<br>1<br>1<br>1 | 0<br>0<br>1<br>1<br>0<br>0<br>1<br>1 | 0<br>1<br>0<br>1<br>0<br>1<br>0<br>1 | <pre>7 bits + even parity + 2 stop bits<br/>7 bits + odd parity + 2 stop bits<br/>7 bits + even parity + 1 stop bit<br/>7 bits + odd parity + 1 stop bit<br/>8 bits + 2 stop bits<br/>8 bits + 1 stop bit<br/>8 bits + even parity + 1 stop bit<br/>8 bits + odd parity + 1 stop bit</pre> |  |  |  |  |  |
| Bit 14                          | Bi                                   | t 15                                 | Counter Divide                                                                                                                                                                                                                                                                             |  |  |  |  |  |
| 0<br>0<br>1<br>1                | 0 1<br>1 0                           |                                      | Reserved<br>Divide-by-16<br>Reserved<br>Master reset                                                                                                                                                                                                                                       |  |  |  |  |  |
| *Bit 0 f                        | or Port                              | *Bit 0 for Port 0 controls RTC.      |                                                                                                                                                                                                                                                                                            |  |  |  |  |  |

## TABLE 2-4. COMMAND REGISTER BIT FUNCTIONS

1996 Newson

## 2.3.3.1 Standard Mode Of Operation

During power-up initialization the UART is reset, then programmed to a standard mode of operation. The POINT 4 MARK 3 is delivered with a standard mode of operation established for all ports. This standard mode is as follows:

- Divide-by-16 clock
- 7 bits + even parity + 1 stop bit
- RTS = Low, transmitting interrupt disabled
- Receiving interrupt disabled

## 2.3.3.2 Operational Mode Modifications

For certain devices, it may be necessary to change the mode of operation set in the UART. This may be done by issuing the following two instructions:

1. Master Reset

DOA ac,10 Contents of ac = 000000000000011

2. Redefine Command Register

DOA ac,10 Contents of ac = 00000000XXXXXX01 (X = user-defined command register bits)

If there is a need to change the mode of operation, two important points should be considered:

- The UART uses a divide-by-16 clock. If bits 14 and 15 are 1. not set to master reset (1,1) or to divide-by-16 (0,1), erroneous data will result.
- 2. During the byte mode of systems operation, interrupts may be utilized. If interrupts are used, bits 8 and 10 must be programmed accordingly. If interrupts are not used, the status register may be polled to determine if the transmitter is empty, or if the receiver is full.

## 2.3.4 STATUS REGISTER

Software utilizes the status register during a polling sequence to determine the following:

- 1. Receive data register full
- 2. Transmit data register empty
- 3. Error condition

The following instruction is used to read the status register for Port 0:

DIA ac,10

The status will be read from the status register into the least significant byte of the accumulator (ac). The PIB sets the most significant byte to zero.

Figure 2-3 shows the status register. Status register bits, instructions, and operational descriptions are shown in Table 2-5.

| 0                | 1                                    | 2                        | 3     | 4     | 5     | 6 | 7 | 8 | 9 | 10 | 11 | 12 | _13 | 14 | 15 |
|------------------|--------------------------------------|--------------------------|-------|-------|-------|---|---|---|---|----|----|----|-----|----|----|
|                  |                                      |                          |       |       |       |   |   |   |   |    |    |    |     |    |    |
| WIL<br>INT<br>PA | SERVEC<br>L BE SI<br>ERRUP<br>RITY E | ET TO<br>PT REQ<br>RROR. | UEST  |       |       |   |   |   |   |    |    |    |     |    |    |
|                  | CEIVE (                              |                          |       |       |       |   |   |   |   | ]  |    |    |     |    |    |
|                  | AMING<br>EAR TO                      |                          |       |       |       |   |   |   |   |    |    |    |     |    |    |
|                  | TA CAF                               |                          | -     |       |       |   |   |   |   |    |    |    |     |    |    |
| TR               | ANSMIT                               | DATA                     | REG   | ISTER | ЕМРТҮ | · |   |   |   |    |    |    |     |    |    |
| RE               |                                      | DATA                     | REGIS | TER F | ULL — |   |   |   |   |    |    |    |     |    |    |



ANRIA. Nagosti

| INDER 7-2. DIVIOD VEGIDIEN DII OLEMATIONE | TABLE | 2-5. | STATUS | REGISTER | BIT | <b>OPERATIONS</b> |
|-------------------------------------------|-------|------|--------|----------|-----|-------------------|
|-------------------------------------------|-------|------|--------|----------|-----|-------------------|

| Bit | Instruction                   | Operation                                                                                                                                                                                                                                                                                                                                   |
|-----|-------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0-7 | Reserved                      | Will be set to 0.                                                                                                                                                                                                                                                                                                                           |
| 8   | Interrupt<br>Request<br>(IRQ) | In byte mode, transmit and receive<br>interrupts should be disabled to prevent<br>use of this bit.                                                                                                                                                                                                                                          |
| 9   | Parity<br>Error<br>(PE)       | Valid as long as a data character with<br>parity error is in the receive-data<br>register and parity is enabled. If no<br>parity is selected, both transmitter<br>parity generator output and receiver<br>parity check results are inhibited.                                                                                               |
| 10  | Receiver<br>Overrun<br>(OVRN) | Error flag, which indicates that one or<br>more characters in the data stream have<br>been lost due to failure to read data in<br>the receive-data register. Flag does not<br>occur until a valid character prior to the<br>overrun has been read. Reset after<br>reading the data from the receive-data<br>register, or by a master reset. |
| 11  | Framing<br>Error<br>(FE)      | When set high, indicates that received<br>character is improperly framed by a start<br>and stop bit. Indicates the existence of<br>an error as long as character is<br>available.                                                                                                                                                           |
| 12  | Clear to<br>Send<br>(CTS-)    | The CTS- input is normally low. If it<br>goes high, it inhibits the transmit-<br>data-register-empty status bit.                                                                                                                                                                                                                            |

(Table continues on next page)

2-9

## TABLE 2-5. STATUS REGISTER BIT OPERATIONS (Cont)

| Bit | Instruction                                     | Operation                                                                                                                                                                                                                                                                                                                      |
|-----|-------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 13  | Data<br>Carrier<br>Detect<br>(DCD-)             | Set high when a loss of carrier occurs.<br>Generation depends upon port connection to<br>data terminal equipment (DTE). In a<br>point-to-point connection, this signal is<br>generated from the data terminal ready<br>(DTR-) of the DTE. In a modem connection,<br>it is generated from the modem's carrier<br>detect.        |
|     |                                                 | Inhibits the receive-data-register-full<br>status bit. Once set, this bit will<br>remain on until reset by reading the<br>status register and the data register, or<br>by a master reset. If it remains high<br>after attempts to clear, it indicates that<br>the DCD- input remains in the high state.                        |
| 14  | Transmit<br>Data<br>Register<br>Empty<br>(TDRE) | Set high when transmit-data register<br>contents have been transferred, and new<br>data may be entered. Low state indicates<br>either that transmit-data register is<br>full, or a high on clear-to-send is<br>inhibiting data transfer.                                                                                       |
| 15  | Receive<br>Data<br>Register<br>Full<br>(RDRF)   | Set high when received data has been<br>transferred to the receive-data register.<br>Cleared by reading the receive-data<br>register (DIA ac,11) or by a master reset<br>(DOA ac,10 with ac=3). Cleared state<br>indicates that the receive-data register<br>has not yet received new data, or data<br>carrier detect is high. |

Scutter

## 2.3.5 SOFTWARE POLLING

Section 1.2.1.2 describes the polling procedures used to determine if a port needs service. When the multiplexer is in byte mode, it polls the MUX ports to ensure that each port's data register is empty and may receive another byte of data. Figure 2-4 illustrates this procedure.





2-11

## 2.4 COMMUNICATIONS AUTO MODE

This section outlines the communications auto mode programming protocol for the multiplexer controller on the Peripheral Interface Board (PIB). Communications auto mode operates only in DMA channel mode.

Auto mode topics covered include: MUX I/O control block (IOCB), control word definitions, termination status descriptions, and initialization procedures.

## 2.4.1 MUX I/O CONTROL BLOCK

The MUX Controller supplies software control for the communications ports and their parameters (excluding baud rate) through programmed I/O. Software control includes enabling and disabling the receiver and transmitter, setting character length, determining parity, and selecting the number of stop bits. A real-time clock is also enabled or disabled under software control.

Each port has an I/O control block (IOCB) in system memory; the MUX Controller utilizes four IOCBs (seven IOCBs if expansion board is used). The MUX IOCBs contain information which the MUX uses for automatic data transfers. They do not contain data for selecting port parameters or enabling and disabling ports. All IOCBs must be contiguous in main memory, offset from one another by a multiple of 40 octal. . Each IOCB contains input and output control words and buffer pointers for each port.

## 2.4.2 CONTROL WORD DEFINITIONS

Each IOCB consists of eight words. Six words are used for MUX control: 0, 1, 4, 5, 6, and 7. The three even-numbered words (0, 4, 6) control input; the three odd-numbered words (1, 5, 7) control output. Two words (2, 3) are not used.

The MUX IOCB is shown in Figure 2-5.



## Figure 2-5. MUX Input/Output Control Block

HM-081-0027-A POINT 4 Data Corporation

MULTIPLEXER 2-13 MARK 3 Peripherals Manual

## 2.4.3 INPUT OPERATIONS

The three even-numbered words of each IOCB (0, 4, 6) control input. Word 0 is the input control word (ICW); word 4 is the input byte pointer (IBP); word 6 is the last input byte pointer (LIB).

## 2.4.3.1 Input Control Word

The structure of word 0 is shown in Figure 2-6. Table 2-6defines the input control word, indicating each bit, the appropriate function, and the resultant operation.



Figure 2-6. Input Control Word - Word 0

HM-081-0027-A

## TABLE 2-6.INPUT CONTROL WORD DEFINITIONS(WORD 0 OF EACH CONTROL BLOCK)

| Bit | Instruction                                         | Operation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-----|-----------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit | Instruction<br>IOC (Input<br>Operation<br>Complete) | <ul> <li>Set to one (1) if any of the following conditions occurs:</li> <li>1. Input buffer is full</li> <li>2. The receiver detects: <ul> <li>a. Parity error (if parity is not inhibited)</li> <li>b. Framing error (break detect)</li> <li>c. Receiver overrun (DMA is disabled for an extended period, or another controller uses DMA cycles for an unreasonably extended period, i.e., greater than one character time, approximately 1 millisecond at 9600 baud).</li> </ul> </li> <li>3. IOCB is in single-character-input mode, and an incoming character is received and stored in bits 8-15 of ICW.</li> <li>4. Special-character-interrupt request is enabled and a special character is received (&lt;40 octal or 174 through 177 octal).</li> <li>5. A loss of carrier occurs (carrier detect, which is normally active low, goes high) during a receive operation.</li> <li>At the same time that IOC is set to one (1), the controller sets the interrupt-request flag. The IOC must be cleared by the MUX interrupt service program. There is</li> </ul> |
|     |                                                     | <ul> <li>mode, and an incoming character is received and stored in bits 8-15 of ICW.</li> <li>4. Special-character-interrupt request is enabled and a special character is received (&lt;40 octal or 174 through 177 octal).</li> <li>5. A loss of carrier occurs (carrier detect, which is normally active low, goes high) during a receive operation.</li> <li>At the same time that IOC is set to one (1), the controller sets the interrupt-pending bit and the interrupt-request flag. The IOC must be cleared by the MUX</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|     |                                                     | accomplish this.<br>If another input character is received<br>before the IOC is cleared, the original<br>character will be overwritten in bits<br>8-15.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

## TABLE 2-6. INPUT CONTROL WORD DEFINITIONS (Cont) (WORD 0 OF EACH CONTROL BLOCK)

| Bit   | Instruction | Operation                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1 & 2 | Input Mode  | The input mode is determined as follows:                                                                                                                                                                                                                                                                                                                                                                                                                            |
| Value |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 0 0   |             | Single Character Input Mode - each<br>incoming character is placed in bits 8-15<br>of ICW. IOC is set, interrupt-pending bit<br>is set, and an interrupt generated.                                                                                                                                                                                                                                                                                                 |
| 0 1   |             | Not used (illegal)                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 10    |             | Automatic Input - incoming characters are<br>placed in input buffer defined by input<br>byte pointer (IBP) and last input byte<br>(LIB), until the buffer is filled, if no<br>special interrupt conditions are<br>encountered.                                                                                                                                                                                                                                      |
| 11    |             | Automatic Input With Echo - same as<br>automatic input, except that each<br>character placed in input buffer is also<br>automatically echoed (output). Note that<br>any character producing an interrupt<br>(other than buffer full) is not<br>automatically echoed.                                                                                                                                                                                                |
|       |             | NOTE                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|       |             | When using automatic-input-with-<br>echo mode, software must ensure<br>that the transmitter interrupt<br>section is disabled for a<br>specified port. If interrupts<br>are not disabled, the controller<br>will both echo characters and<br>transmit characters from the<br>output buffer. With transmitter<br>interrupts disabled, the<br>controller will ignore the<br>output section of IOCB for a<br>specified port and characters<br>will be echoed correctly. |

## TABLE 2-6. INPUT CONTROL WORD DEFINITIONS (Cont)(WORD 0 OF EACH CONTROL BLOCK)

| Bit | Instruction                                  | Operation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-----|----------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3   | Special<br>Character<br>Interrupt<br>Enabled | If this bit is set to one (1) by the<br>programmer, the controller examines each<br>incoming character to determine if it is<br>a special ASCII character (<40 octal or<br>174 through 177 octal). If the incoming<br>character is a special character, the<br>controller stores the character in bits<br>8-15 of the input control word, sets the<br>interrupt-pending bit, and generates an<br>interrupt request. The character will<br>not be stored in the input buffer. In<br>addition, the controller sets the most<br>significant bit of all incoming<br>characters to one (1). |
| 4   | Parity<br>Error                              | Set to one (1) by hardware when the<br>incoming character has a parity error.<br>When this condition occurs, the IOC bit<br>is set to one (1), and the character is<br>stored in ICW.                                                                                                                                                                                                                                                                                                                                                                                                  |
| 5   | Receiver<br>Overrun                          | Set to one (1) when the controller cannot<br>service the receiving section of the<br>specified port before a character is<br>overwritten. This can occur if DMA is<br>disabled for an extended period, or if<br>another controller uses an excessive<br>number of DMA cycles. In this condition,<br>the IOC bit is set to one (1), and data<br>in receive-data register is stored in<br>ICW.                                                                                                                                                                                           |
| 6   | Framing<br>Error                             | Set to one (1) by hardware when an<br>incoming character has a framing error (a<br>zero bit at the point where a stop bit<br>was expected). Sets IOC bit to one (1)<br>and stores the incoming character in ICW.                                                                                                                                                                                                                                                                                                                                                                       |

(Table continues on next page.)

## TABLE 2-6. INPUT CONTROL WORD DEFINITIONS (Cont)(WORD 0 OF EACH CONTROL BLOCK)

| Bit  | Instruction        | Operation                                                                                                                                                                                                                                                             |
|------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7    | Carrier<br>Detect  | Set to one (1) when a loss of carrier<br>occurs (data carrier detect, which is<br>normally active low, goes high). When<br>this condition occurs, receiver section<br>is disabled. Sets IOC bit to one (1) and<br>stores data in the receive-data register<br>in ICW. |
| 8-15 | Input<br>Character | Each incoming character is stored in bits<br>8-15. Characters that cause the IOC bit<br>to be set are:                                                                                                                                                                |
|      |                    | <ol> <li>The last character stored in input<br/>buffer, causing an input buffer-full<br/>condition.</li> </ol>                                                                                                                                                        |
|      |                    | EXCEPTION                                                                                                                                                                                                                                                             |
|      |                    | If an input buffer ends in<br>mid-word, the byte placed in<br>ICW is the right half of the<br>last buffer word, and not the<br>last incoming character.<br>Software must check for<br>buffer full before it checks<br>for a special character.                        |
|      |                    | <ol> <li>An incoming character which is<br/>overrun, or which has caused a parity<br/>or framing error.</li> </ol>                                                                                                                                                    |
|      |                    | <ol> <li>An incoming character which is a<br/>special character.</li> </ol>                                                                                                                                                                                           |
|      |                    | <ol> <li>The character in the receive-data<br/>register of the UART when carrier<br/>detect went high.</li> </ol>                                                                                                                                                     |
|      |                    | -                                                                                                                                                                                                                                                                     |

### 2.4.3.2 Input Termination Status

When an input operation is completed, the appropriate status is written into the ICW by the controller.

When the status is written, the input-operation-complete (IOC) bit is set to one (1). The incoming character which completed the operation is written in the right half of the right byte of word 0 (bits 8-15). The controller also sets the interrupt-pending bit and the interrupt-request flag.

When the interrupt occurs, the software has approximately one character time to determine which port's input operation is complete, and reinitialize the IOCB after interpreting the status word by creating a new input memory buffer address and resetting the IOC bit. Otherwise, a MUX overrun may occur.

## 2.4.3.3 Input Byte Pointer

Word 4 of the IOCB is the input byte pointer (IBP). IBP and LIB (last input byte) are only used in automatic-input mode. IBP must be set by the program to one (1) less than the first byte address of the automatic input buffer. Each time the MUX stores an incoming byte, it will increment IBP. The MUX uses the least significant bit (bit 15) as the byte indicator (BIN). If BIN = 0, the byte will be stored in the left half of the word addressed. If BIN = 1, it will be stored in the right half of the word addressed. IBP always points to the last input byte stored. If IBP  $\geq$  LIB, an interrupt will be generated by the first incoming character, which will be stored at IBP.

### 2.4.3.4 Last Input Byte

Word 6 of the IOCB is the last input byte (LIB). It is set up by the program to the last byte address of the auto input buffer. The MUX will generate an input-done interrupt when a byte is stored at this address. IBP will then be equal to LIB.

HM-081-0027-A POINT 4 Data Corporation 2-19

MULTIPLEXER MARK 3 Peripherals Manual

## 2.4.4 OUTPUT OPERATIONS

The three odd-numbered words of each IOCB (1,5,7) control output. Word 1 is the output control word (OCW); word 5 is the output byte pointer (OBP); word 7 is the last output byte pointer (LOB).

## 2.4.4.1 Output Control Word

The structure of word 1 is shown in Figure 2-7.

Table 2-7 defines the output control word, indicating each bit, the appropriate function, and the resultant operation.



Figure 2-7. Output Control Word - Word 1

## TABLE 2-7. OUTPUT CONTROL WORD DEFINITIONS (WORD 1 OF EACH CONTROL BLOCK)

| Bit | Instruction                           | Operation                                                                                                                                                                                                                                                                                                                                                                                                         |
|-----|---------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0   | OOC (Output<br>Operation<br>Complete) | Set to one (1) if the operation has been<br>terminated due to one of the following<br>conditions:                                                                                                                                                                                                                                                                                                                 |
|     |                                       | <ol> <li>If MUX is in single-character mode<br/>when the output byte is read for<br/>transmission to the port. The<br/>program must reload the output<br/>control word at an average of once<br/>per character time and a maximum of<br/>two character times for uninterrupted<br/>output to result.</li> </ol>                                                                                                   |
|     |                                       | <ol> <li>If MUX is in automatic-buffer-output<br/>mode when the last byte of the<br/>automatic buffer is read for<br/>transmission.</li> </ol>                                                                                                                                                                                                                                                                    |
|     |                                       | 3. If MUX is in automatic-buffer-output<br>mode with special-character interrupt<br>enabled, and if the transmitted<br>character is a special control<br>character, automatic output is<br>terminated after transmission of the<br>special character. The character<br>which completed the operation is<br>stored in the OCW. The controller<br>sets the interrupt-pending bit and<br>the interrupt-request flag. |
|     |                                       | The OOC bit must be cleared by the MUX<br>interrupt service program. If the IOCB<br>is re-initialized at an average of once<br>per character time, and within a maximum<br>of two character times, uninterrupted<br>transmission will result. When the last<br>byte of the output buffer is transferred,<br>OOC is the only bit set.                                                                              |

## TABLE 2-7. OUTPUT CONTROL WORD DEFINITIONS (Cont) (WORD 1 OF EACH CONTROL BLOCK)

| Bit                                 | Instruction          | Operation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|-------------------------------------|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1 & 2<br><u>Value</u><br>0 0<br>0 1 | Output Mode          | Written by the program and ead by MUX to<br>determine the type of output.<br>Idle (no output)<br>Single Character Output Mode - the data<br>byte in bits 8-15 of the OCW is                                                                                                                                                                                                                                                                                                                                                     |
| 1011                                |                      | <pre>transmitted, and the OOC bit is set.<br/>Not Used (Illegal)<br/>Automatic Buffer Output - characters are<br/>automatically transmitted from the output<br/>buffer, as defined by the output byte<br/>pointer (OBP) and the last output byte<br/>pointer (LOB).</pre>                                                                                                                                                                                                                                                       |
| Bit                                 |                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 3                                   | Special<br>Character | Used only in the automatic-output mode.<br>If this bit is set to one (1), MUX tests<br>each outgoing character to determine if<br>it is an ASCII special character (<40<br>octal or 174 through 177 octal). If it<br>is, MUX transmits the character, sets the<br>output-operation-complete bit in the<br>output termination word to one (1), and<br>stores the special character in bits 8-15<br>of the OCW. It then sets the interrupt-<br>pending bit and generates an interrupt<br>request. Automatic output is terminated. |
| 4-6                                 |                      | Must be set to zero.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |

(Table continues on next page /

## TABLE 2-7. OUTPUT CONTROL WORD DEFINITIONS (Cont) (WORD 1 OF EACH CONTROL BLOCK)

| Bit  | Instruction         | Operation                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------|---------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7    | Real-Time<br>Clock  | Used only on Port 0. Set to one (1) if<br>the software has enabled the real-time<br>clock and the controller has been<br>interrupted by the clock. (The real-time<br>clock interrupts once each 10<br>milliseconds.)<br>The interrupt-pending bit is set, and an<br>interrupt request is generated. Does not<br>set the OOC bit, or terminate automatic<br>operation.                                                                                     |
| 8-15 | Output<br>Character | <ul> <li>In single-character mode, this byte is sent to the port for transmission.</li> <li>In automatic-output mode, each outgoing character which causes the OOC bit to be set is stored in this byte. These characters meet the following conditions:</li> <li>1. An outgoing character is a special character, and the special-character-enable bit is set.</li> <li>2. The outgoing character is the last character in the output buffer.</li> </ul> |

### 2.4.4.2 Output Termination Status

When an output operation is completed, the appropriate status is written into the OCW by the controller. When the status is written, the output-operation-complete (OOC) bit is set to one (1). The outgoing character which completed the operation is written in the right half of word 1 (bits 8-15). The controller also sets the interrupt-pending bit and the interrupt-request flaq.

When the interrupt occurs, the software has approximately one character time to determine which port's output operation is complete, and to perform one of the following services:

If there is no more output to be done, disable the 1. transmitter section of the corresponding port through programmed I/O.

#### CAUTION

Exercise caution when using this method because the transmitter double-buffers characters. Software may disable the transmitter interrupt, but must not issue a master reset until the buffered characters have been transmitted or a character may be lost.

Reinitialize the IOCB after interpreting the status word by 2. creating a new input memory buffer address and resetting the This must be effected within two character times IOC bit. for uninterrupted output to result.

If neither function is completed, MUX will examine the OCW word after each executed instruction, which will create a significant system slow-down.

# 2.4.4.3 Output Byte Pointer

Word 5 of the IOCB is the output byte pointer (OBP). OBP and LOB (last output byte) are used only in the automatic-output mode. OBP must be set up by the program to one (1) less than the first byte address of the automatic output buffer. Each time the MUX is ready for an output byte, it will increment OBP. The MUX fetches the byte for transmission from the appropriate half of the word address given by the most significant 15 bits of the OBP (word address) in conjunction with the byte indicator (BIN). If BIN = 0 the left byte will be output; if BIN = 1 the right byte will be output. OBP always points to the last byte transmitted.

#### 2.4.4.4 Last Output Byte

Word 7 of the IOCB is the last output byte (LOB). It is set by the program to the last byte address of the automatic output buffer. When the byte at that address is picked up for transmission, the MUX will generate an output-done interrupt (OBP will then be equal to LOB). An automatic buffer may contain as little as one byte. In this case, initially LOB = OBP + 1. If initially LOB < OBP + 1, the MUX will transmit one byte from OBP + 1, set OOC and produce an interrupt.

# 2.5 INITIALIZATION PROCEDURES

This section covers setup procedures for the MUX controller, and includes the following steps: setting the IOCB starting address pointer; initialization guidelines; enabling and disabling ports and defining port parameters; and enabling and disabling transmitters and receivers.

#### 2.5.1 SETTING IOCB STARTING ADDRESS

All port IOCBs must be contiguous in main memory. Software only sets up IOCBs for ports that are to be enabled, but must reserve space for all possible port IOCBs in the contiguous memory block. For example:

| <u>Memory Location</u> | Port   |  |
|------------------------|--------|--|
| 1000                   | Port O |  |
| 1040                   | Port l |  |
| 1100                   | Port 2 |  |
| 1140                   | Port 3 |  |

When MUX is in automatic-transfer mode, the controller must be informed of the IOCB starting address by issuing a DOBS instruction with the contents of the accumulator containing the IOCB address. For example:

DOBS ac,77

Contents of ac = 1000

When the controller receives a DOBS, the memory address is stored in a register. No other activity occurs as a result of the DOBS (unlike the tape and disc controllers). Software has control over enabling and disabling each individual port through programmed I/O. See Section 1.2.2 for detailed description of multiplexer port initialization under programmed I/O control.

HM-081-0027-A POINT 4 Data Corporation 2-26

#### 2.5.2 INITIALIZATION GUIDELINES

Four basic enabling and disabling considerations are listed below:

- 1. If an input or output section of an IOCB has not been previously set up by software, the corresponding receiver or transmitter of the port should not be enabled.
- 2. If a port is to operate in automatic-echo mode for incoming characters, the transmitter section of that port must be disabled.
- 3. Software may disable the receiver section of a port after the input operation is complete. There is a risk of having an overrun condition on any further incoming characters if the receiver section is disabled for an extended period.
- 4. When an output operation is complete, there is approximately one character time for software to either update the IOCB for a new transmission, or disable the transmitter with a DOA instruction.

#### 2.5.3 ENABLING/DISABLING PORTS AND PORT PARAMETERS

After software has set the IOCBs and issued a DOBS ac,77 instruction, individual ports must be enabled. A list of instructions used for enabling and disabling the individual ports follows:

| DOA ac,10 | Port O |
|-----------|--------|
| DOA ac,12 | Port l |
| DOA ac,14 | Port 2 |
| DOA ac,16 | Port 3 |

The accumulator contains the necessary information for port programming in the form of command register input as described in Section 2.3.3.

When the system powers up, the following parameters are standard:

- Receiver interrupts disabled
- Transmitter interrupts disabled
- Word length = 7 bits
- Even parity
- One stop bit

Software can change any of these parameters using a DOA instruction with the new port parameters in the specified accumulator.

#### 2.5.3.1 Master Reset

Software may reinitialize the port at any time by issuing a master reset DOA. It should be used only to initialize the MUX when receive, transmit and status data are lost. The master reset should never be used once the port has been initialized and continuous operations are to be performed. An example of the master reset DOA instruction is:

DOA ac,10

in which the accumulator contains the value 3 as shown in Figure 2-8.



Figure 2-8. Master Reset Instruction Format

# 2.5.3.2 Port Initialization

Once a master reset DOA has been issued, software re-programs the word length, parity, and stop-bit parameters, using another DOA instruction. An example of the port-characteristic instruction for Port 0 is:

DOA ac,10

where the contents of the accumulator have the format as shown in Figure 2-9.

Bits 11, 12, and 13 are defined during initialization (see Table 2-4).

This procedure should be followed for each port when first initializing the MUX. The procedure should only be used for an initialization routine.



# Figure 2-9. Port Initialization Instruction Format

#### 2.5.3.3 Enabling/Disabling Transmitters And Receivers

The receiver and transmitter sections for each port operate independently, and may be enabled or disabled independently. An example of the enable/disable instruction for Port 0 is:

DOA ac,10

where the contents of the accumulator have the format as shown in Figure 2-10.

Each DOA instruction updates the port-command register. If previous values have been defined (such as port parameters) for the specified port, they should be repeated on all DOA instructions used to define operation modes. Table 2-8 defines the bit settings used to enable/disable operation.

The MUX controller uses a hardware "attention flag" for servicing ports in the automatic mode. Bits 8 and 10 of the accumulator, when set to enable, allow a port's receiver or transmitter to generate the attention flag.

| 0 | 1    | 2                           | 3           | 4     | 5 | 6 | 7   | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 |
|---|------|-----------------------------|-------------|-------|---|---|-----|---|---|----|----|----|----|----|----|
|   | 0    | <b></b>                     |             |       |   |   | • 0 |   | 0 |    |    |    |    | o  | 1  |
|   | (POR | TIME (<br>T 0 ONL<br>IVER — | CLOCK<br>Y) |       |   |   |     |   |   |    |    |    |    |    |    |
|   | TRAN | ISMITTE                     | R           |       |   |   |     |   |   |    |    |    |    |    |    |
|   |      | -DEFINI<br>CHARA            |             | STICS |   |   |     |   |   |    |    |    |    |    |    |

Figure 2-10. Transmitter/Receiver Instruction Format

HM-081-0027-B

MULTIPLEXER POINT 4 Data Corporation 2-30 MARK 3 Peripherals Manual

# Section 3 **DISC DRIVE INTERFACE**

# 3.1 INTRODUCTION

This section describes the interface for the SMD/CMD/LMD disc controller which is available on the MARK 3 and MARK 3B versions of the Peripheral Interface Board (PIB).

The POINT 4 MARK 3 Disc Controller is designed to handle up to two SMD/CMD/LMD-type drives. The controller provides high-speed, direct-memory access between the disc drives and the POINT 4 MARK 3 CPU. The following are features of the controller:

- Handles SMD/CMD/LMD drives
- Interfaces up to two drives
- Drives of different type and manufacture may be connected to each port
- DMA transfer rates up to 1.25 megabytes per second
- Control block-oriented instructions
- Read-verify data operations
- Complete software control of sector addressing
- Status and error reporting on completion of operation

Disc operation control is handled through use of an input/output control block (IOCB). Actual data transfer is performed in DMA mode.

#### 3.1.1 PERFORMANCE CHARACTERISTICS

```
Drives per Controller:
   Two
Drive Type:
   SMD/CMD/LMD
DMA Transfer Rate:
    1.25 megabytes per second
Sector Size:
   Header - 4 words Header CRC - 1 word
   Data - 256 words Data CRC - 1 word
Controller Device Code:
    50-55
Drive Port Assignments:
   Port A-J8
    Port B-J7
I/O Instructions:
    Input - DIA
   Output - DOA
```

DMA (Device Code 77): DOBC/DIBC = DISC

HM-081-0027-C

### 3.1.2 MULTI-DRIVE CONNECTION

The disc controller supports two SMD, CMD or LMD drives, which must have a daisy-chain connection, as illustrated in Figure 3-1. The two drives need not be of the same type, nor produced by the same manufacturer.



# Figure 3-1. Daisy-Chain Drive Connection

#### 3.1.3 DISC DRIVE CABLING

Two types of cables connect the Peripheral Interface Board to the disc drives:

1. Drive control bus (A Cable)

2. Drive cables (B Cables)

These cables are described in the following subsections.

# 3.1.3.1 Drive Control Bus (A Cable)

Cable A is the drive control bus. This bus leaves the PIB at connector J6 and is daisy chained between drives (see Figure 3-1). Figure 3-2 illustrates the signals carried on the control bus and Table 3-1 defines these signals.



#### Figure 3-2. **PIB/Disc Drive Differential** Bus Signals

# TABLE 3-1. DISC DRIVE DIFFERENTIAL BUS SIGNALS (A CABLE PIN ASSIGNMENT)

| Pin  | Signal | Direction | Description                                                                                                                                                                                                                                |
|------|--------|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1,31 | Tag l  | Out       | Used to strobe the cylinder<br>address to disc drive. For CMD<br>drives, a tag 2 must precede a<br>tag l for a volume change.                                                                                                              |
| 2,32 | Tag 2  | Out       | Used to strobe the head address<br>to disc drive. For CMD drives,<br>the volume is also sent to the<br>drive.                                                                                                                              |
| 3,33 | Tag 3  | Out       | Used to strobe control bits.                                                                                                                                                                                                               |
|      |        |           | NOTE                                                                                                                                                                                                                                       |
|      |        |           | Bits 0 through 9 are defined<br>according to tag. If tag 1,<br>all bits are used to define<br>the cylinder address. If<br>tag 2, all bits are used to<br>define the head address.<br>For tag 3, each bit is<br>defined as described below. |
| 4,34 | Bit O  | Out       | Enables the write drivers. Must<br>never be on simultaneously with<br>read drivers.                                                                                                                                                        |
| 5,35 | Bit l  | Out       | Enables the read drivers. Must<br>never be on simultaneously with<br>write drivers.                                                                                                                                                        |
| 6,36 | Bit 2  | Out       | Offsets the servo from the<br>nominal on-cylinder toward the<br>spindle.                                                                                                                                                                   |
| 7,37 | Bit 3  | Out       | Offsets the servo from the<br>nominal on-cylinder away from<br>the spindle.                                                                                                                                                                |
| 8,38 | Bit 4  | Out       | Clears a fault only if the condition no longer exists.                                                                                                                                                                                     |
| 9,39 | Bit 5  | Out       | When issued with bit 0 or 1,<br>enables address-mark writing or<br>reading.                                                                                                                                                                |

Negster

Negel

# TABLE 3-1. DISC DRIVE DIFFERENTIAL BUS SIGNALS (Cont) (A CABLE PIN ASSIGNMENT)

| Pin   | Signal          | Direction | Description                                                                                            |
|-------|-----------------|-----------|--------------------------------------------------------------------------------------------------------|
| 10,40 | Bit 6           | Out       | Causes seek to track 0,<br>resetting of head register. For<br>CMD drives, selects head 0,<br>volume 0. |
| 11,41 | Bit 7           | Out       | Causes strobing of data earlier than normal.                                                           |
| 12,42 | Bit 8           | Out       | Causes strobing of data later than normal.                                                             |
| 13,43 | Bit <b>9</b>    | Out       | Selects the unit, if enabled,<br>and if priority does not exist<br>for opposite channel.               |
| 14,44 | Open<br>Cable   | Out       | Disables interface if the<br>control bus cable is<br>disconnected.                                     |
| 15,45 | Fault           | In        | Indicates that a fault exists on the drive.                                                            |
| 16,46 | Seek<br>Error   | In        | Indicates that a seek error has occurred.                                                              |
| 17,47 | On<br>Cylinder  | In        | Indicates that the heads are positioned over a track.                                                  |
| 18,48 | Index           | In        | A signal occurring once per<br>revolution in coordination with<br>the leading edge of sector 0.        |
| 19,49 | Unit<br>Ready   | In        | Indicates the drive is up to speed.                                                                    |
| 20,50 | -               | -         | Reserved                                                                                               |
| 21,51 | -               | _         | Reserved                                                                                               |
| 22,52 | Unit Sel<br>Tag | Out       | Strobes the binary address<br>formed by unit select 0, 1, 2,<br>and 3.                                 |
| 23,53 | Unit<br>Sel O   | Out       | Unit select 0.                                                                                         |
| 24,54 | Unit<br>Sel l   | Out       | Unit select l.                                                                                         |

HM-081-0027-A

DISC DRIVE INTERFACE POINT 4 Data Corporation 3-7 MARK 3 Peripherals Manual

| Pin   | Signal        | Direction | Description                                     |
|-------|---------------|-----------|-------------------------------------------------|
| 25,55 | Sector        | In        | Indicates that a sector mark has been detected. |
| 26,56 | Unit<br>Sel 2 | Out       | Unit select 2.                                  |
| 27,57 | Unit<br>Sel 3 | Out       | Unit select 3.                                  |
| 28,58 | Write<br>Prot | In        | Disables write gate.                            |
| 29,59 | _             | -         | Reserved                                        |
| 30,60 | -             | -         | Reserved                                        |

# TABLE 3-1. DISC DRIVE DIFFERENTIAL BUS SIGNALS (Cont) (A CABLE PIN ASSIGNMENT)

# 3.1.3.2 Drive Cables (B Cables)

The PIB requires one B cable per drive for use in synchronization and data transfers. These cables are connected to the PIB at connectors J7 and J8. Figure 3-3 illustrates the signals carried on the drive cables and Table 3-2 defines these signals.



# Figure 3-3. PIB/Disc Drive Differential Synchronization Cable Signals

HM-081-0027-A POINT 4 Data Corporation 3-9

# TABLE 3-2. DRIVE SYNCHRONIZATION CABLE SIGNALS

| Pin   | Signal        | Direction | Description                                                                                    |
|-------|---------------|-----------|------------------------------------------------------------------------------------------------|
| 1     | GND           | -         | Ground                                                                                         |
| 2,14  | SERVO<br>CLK  | In        | Used to synchronize write<br>data.                                                             |
| 3,16  | READ<br>DATA  | In        | Data from drive to controller<br>used on a read operation.                                     |
| 4     | GND           | -         | Ground                                                                                         |
| 5,17  | READ<br>CLK   | In        | Signals the beginning of a data cell.                                                          |
| 6,19  | WRITE<br>CLK  | Out       | Transmits the write clock<br>signal which is used to<br>synchronize the write data.            |
| 7     | GND           | -         | Ground                                                                                         |
| 8,20  | WRITE<br>DATA | Out       | Transmits data from the controller to the drive.                                               |
| 9,22  | UNIT<br>SELD  | In        | Disc drive unit has been selected.                                                             |
| 10,23 | SEEK<br>END   | In        | The logical OR of on cylinder<br>and seek error indicating that<br>a seek operation has ended. |
| 11    | GND           | -         | Ground                                                                                         |
| 12,24 | -             | -         | Reserved                                                                                       |
| 13,26 | -             | _         | Reserved                                                                                       |
| 15    | GND           | -         | Ground                                                                                         |
| 18    | GND           | -         | Ground                                                                                         |
| 21    | GND           | -         | Ground                                                                                         |
| 25    | GND           | -         | Ground                                                                                         |

Jointh Re-

# 3.2 PROGRAMMED INPUT/OUTPUT

The following subsections provide information on disc programmed I/O, detailing instruction formats and accumulator bit functions.

#### 3.2.1 PROGRAMMED I/O INPUT

The DIA instruction is used to read the status of the disc drive. Software can use the status to detect the following:

- Unit Ready
- Drive Fault
- Write Protect
- On Cylinder
- Drive Select
- Seek Error

The instruction format is:

DIA ac,50

where ac is the processor accumulator into which the status will be read and 50 is the device code. The format of the status word is shown in Figure 3-4.

Table 3-3 defines the function of each bit in the accumulator.



#### Figure 3-4. Drive Status

# TABLE 3-3. DRIVE STATUS DEFINITIONS

| Bits | Name    | Function                                                                                                                                                                                           |
|------|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0-7  |         | Reserved, set to O                                                                                                                                                                                 |
| 8    | SEKERR+ | Seek Error - When set to l, indicates a<br>seek error has occurred. A seek error can<br>result from the following:                                                                                 |
|      |         | <ul> <li>A seek could not be completed within<br/>500 milliseconds</li> </ul>                                                                                                                      |
|      |         | <ul> <li>An illegal track address was received<br/>by the drive</li> </ul>                                                                                                                         |
|      |         | <ul> <li>The carriage has moved outside the recording field</li> </ul>                                                                                                                             |
|      |         | A seek error can only be cleared by<br>issuing a return-to-zero command. See<br>Section 3.4.3.                                                                                                     |
| 9    | SLCTED- | Selected - When set to 0, indicates the<br>drive has been selected. When set to 1,<br>indicates the drive has not been selected.                                                                   |
| 10   |         | Reserved, set to 0                                                                                                                                                                                 |
| 11   | ONCYL-  | On Cylinder - When set to 0, indicates the<br>heads are on cylinder. When set to 1,<br>indicates the heads are not on cylinder.                                                                    |
| 12   | WRTPRT+ | Write Protect - When set to 1, indicates<br>the selected drive may only be read (i.e.,<br>the drive is write protected). When set<br>to 0, indicates the drive may be written<br>to and read from. |
| 13   | FAULT+  | Fault - When set to 1, indicates a fault<br>in the selected drive has occurred. A<br>fault may be caused by one or more of the<br>following:                                                       |
|      |         | <ul> <li>Power fail</li> <li>Illegal head select</li> <li>Write fault</li> <li>Writing or reading while off cylinder</li> <li>Write and read gate on simultaneously</li> </ul>                     |

HM-081-0027-ADISC DRIVE INTERFACEPOINT 4 Data Corporation3-12MARK 3 Peripherals Manual

#### TABLE 3-3. DRIVE STATUS DEFINITIONS (Cont)

| Bits | Name    | Function                                                                                                                                                                                             |
|------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 14   |         | Reserved, set to O                                                                                                                                                                                   |
| 15   | UNTRDY- | Unit Ready - When set to 0, the unit<br>selected is ready. When set to 1, the<br>unit selected is not installed, is not up<br>to speed, has heads which are not engaged,<br>or a drive fault exists. |

# 3.2.2 PROGRAMMED I/O OUTPUT

DOA instructions utilizing device codes 50 and 52 are used to specify the disc drive unit output pulses.

#### 3.2.2.1 DOA With Device Code 50 (Drive Unit Number)

The DOA instruction with a device code of 50 is used to output the unit number of the drive to be selected. The contents of the accumulator should contain the unit number found in word 1 of the IOCB (see Section 3.3.2). The format of the instruction is:

DOA ac,50

where ac is the processor accumulator containing the unit number and 50 is the device code.

HM-081-0027-A POINT 4 Data Corporation 3-13

DISC DRIVE INTERFACE MARK 3 Peripherals Manual

### 3.2.2.2 DOA With Device Code 52 (Tag Pulses)

The DOA instruction with a device code of 52 is used to output the different tag pulses. Tag pulses are sent to the drive to indicate that there is valid data in either the bus register, unit register, or both. The format of the instruction is:

DOA ac,52

The contents of the accumulator should be arranged as indicated in Figure 3-5.

#### NOTE

Tag 1, 2 or 3 may be used one at a time. It is illegal to have more than one tag signal active at the same time.

Table 3-4 gives a definition of the function of each bit in the accumulator which represent the different tag pulses.



#### Figure 3-5. Contents of DOA Instruction Accumulator

HM-081-0027-A

DISC DRIVE INTERFACE POINT 4 Data Corporation 3-14 MARK 3 Peripherals Manual

#### TABLE 3-4. DOA INSTRUCTION ACCUMULATOR BITS

| Bit  | Function                                                                                                                                                                                                                                                         |
|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0-11 | Reserved, set to O                                                                                                                                                                                                                                               |
| 12   | Tag 3 - When set to 1, indicates to the drive<br>that the bus register contains valid drive<br>control information.                                                                                                                                              |
| 13   | Tag 2 - When set to 1, indicates to the drive<br>that the bus register contains a valid<br>volume/head address.                                                                                                                                                  |
| 14   | Tag l - When set to l, indicates to the drive<br>that the bus register contains a valid<br>cylinder address.                                                                                                                                                     |
| 15   | Unit Select Tag - When set to 1, indicates to<br>the drive that there is valid data in the<br>unit-select register. The unit-select tag<br>must be on at The same time as a tag 1, 2, or<br>3. The tag signal must be held high through<br>the entire operation. |

#### 3.2.2.3 DOA With Device Code 51 (Bus Register Loading)

The DOA instruction with a device code of 51 is used to load the bus register with the cylinder number. The format of the instruction is:

DOA ac,51

The meaning of the data bus register is determined by the selection of a tag 1, tag 2 or tag 3. If tag 1 is selected, the bus register contains cylinder information. If tag 2 is selected, the register contains head and volume information. If tag 3 is selected, the register contains control information to the disc controller, as defined in Table 3-1.

The instruction formats are defined and illustrated in the following subsections.

# 3.2.2.3.1 TAG 1

The instruction format for the cylinder address is shown in Figure 3-6.

Table 3-5 defines data bus bit functions with tag 1.



# Pigure 3-6. Tag 1 Instruction Format

# TABLE 3-5. DATA BUS BIT FUNCTIONS WITH TAG 1

| Bit  | Function                      |
|------|-------------------------------|
| 0-5  | Reserved, must be set to zero |
| 6-15 | Cylinder address (10 bits)    |

marial

# 3.2.2.3.2 TAG 2

The instruction format for the cylinder address is shown in Figure 3-7. Note that the volume bit (bit 11) is for CMD drives only. For SMD drives, bit 11 is the most significant head bit.

Table 3-6 defines data bus bit functions with tag 2.



HEAD NUMBER

**CMD DRIVE ONLY** 

# Figure 3-7. Tag 2 Instruction Format

# TABLE 3-6. DATA BUS BIT FUNCTIONS WITH TAG 2

| Bit   | Function                                                             |
|-------|----------------------------------------------------------------------|
| 0-10  | Not defined; must be set to zero                                     |
| 11    | Volume (CMD drives only); most<br>significant head bit (SMD drives). |
| 12-15 | Head number                                                          |

# 3.2.2.3.3 TAG 3

The instruction format which allows the drive to perform functions other than directly transferring data is shown in Figure 3-8.

Table 3-7 defines data bus bit functions with tag 3.



Figure 3-8. Tag 3 Instruction Format

# TABLE 3-7. DATA BUS BIT FUNCTIONS WITH TAG 3

| Bit   | Function                                                                                                                                                                                                                                                 |
|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0-8   | Reserved; must be set to zero                                                                                                                                                                                                                            |
| 9     | Return to Zero - When this bit is set to<br>1, the disc will seek to track 0, reset<br>the head register, select the cartridge<br>volume (CMD only) and reset the seek-<br>error bit in the termination-status word<br>of the IOCB. (See Section 3.3.8). |
| 10    | Reserved; must be set to zero                                                                                                                                                                                                                            |
| 11    | Fault Clear - If the cause of a drive<br>fault no longer exists, the fault is<br>cleared and the drive is ready for<br>operation. If the fault still exists,<br>no action is taken.                                                                      |
| 12-15 | Reserved; must be set to zero                                                                                                                                                                                                                            |

HM-081-0027-A POINT 4 Data Corporation 3-18 MARK 3 Peripherals Manual

DISC DRIVE INTERFACE

# 3.3 INPUT/OUTPUT CONTROL BLOCK (IOCB)

The input/output control block (IOCB) for the disc controller consists of eight words located in main memory and reserved for holding information about a disc transfer. The eight words of the IOCB are loaded with information by the software before the operation begins.

Upon completion of an operation (successful or not), the controller writes status information about the operation into the termination status word. Figure 3-9 shows the format of the disc IOCB.



Figure 3-9. Disc IOCB Format

#### 3.3.1 OPCODE (WORD 0)

The opcode word (word 0 of the disc IOCB) is used to define five operations which the disc may perform. The format of word 0 of the disc IOCB is shown in Figure 3-10.

Table 3-8 defines the bit usage in word 0.



Figure 3-10. Opcode Word Format

# TABLE 3-8. DISC IOCB WORD 0

| Bits  | Definition                                                                                                                                                                |
|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | Reserved - must be set to O                                                                                                                                               |
| 1-3   | Opcode - defines the following operations<br>depending on their octal setting:<br>6 = Format<br>5 = Read Regardless<br>2 = Write Data<br>1 = Read Data<br>0 = Read Verify |
| 4-6   | Reserved - must be set to O                                                                                                                                               |
| 7     | Set to 1 for strobe late                                                                                                                                                  |
| 8     | Set to 1 for strobe early                                                                                                                                                 |
| 9-11  | Reserved - must be set to O                                                                                                                                               |
| 12    | Set to 1 for OFSET out                                                                                                                                                    |
| 13    | Set to 1 for OFSET in                                                                                                                                                     |
| 14-15 | Reserved - must be set to O                                                                                                                                               |
|       | NOTE                                                                                                                                                                      |
|       | Unused opcodes are reserved<br>and should not be used.                                                                                                                    |

HM-081-0027-A POINT 4 Data Corporation 3-20 MARK 3 Peripherals Manual

AN SOL Negosti

DISC DRIVE INTERFACE

# 3.3.2 UNIT NUMBER (WORD 1)

The unit-number word (word 1 of the disc IOCB) is used to specify the drive number on which to perform the operation. The format of word 1 of the disc IOCB is shown in Figure 3-11.

Table 3-9 defines the bit usage in word 1.



Figure 3-11. Unit Number Word Format

#### TABLE 3-9. DISC IOCB WORD 1

| Bits  | Definition                                           |
|-------|------------------------------------------------------|
| 0-11  | Reserved - must be set to zero                       |
| 12-15 | Represents the binary equivalent of the drive number |

#### 3.3.3 CYLINDER ADDRESS AND PROTECT FLAGS (WORD 2)

The cylinder-address word (word 2 of the disc IOCB) is used to specify the cylinder address for each operation. The controller uses this word to compare with the current cylinder address in the sector address header for address verification. The format of word 2 of the disc IOCB is shown in Figure 3-12.

Table 3-10 defines the bit usage in word 2.

If the file protect flags were set for this cylinder by the software at format time, they must also be set in the IOCB cylinder select word (see Sector Block Format Commands, Section 3.5).

All sixteen bits of the cylinder-select word are compared with the current cylinder address found in the sector header. If there is no match, a no-ID-compare error will occur and the operation will not be performed.

| 0 | 1    | 2 | 3 | 4 | 5 | 6 | 7 | 8   | 9     | 10    | 11   | 12 | 13 | 14 | 15 |
|---|------|---|---|---|---|---|---|-----|-------|-------|------|----|----|----|----|
|   | FLAG | S |   | I |   |   |   | CYL | INDEF | RADDF | RESS |    |    |    |    |

# Figure 3-12. Cylinder Address Word Format

#### TABLE 3-10. DISC IOCB WORD 2

| Bits | Definition                 |
|------|----------------------------|
| 0-3  | File protect flags         |
| 4-15 | Cylinder address (12 bits) |

HM-081-0027-A POINT 4 Data Corporation 3-22

#### 3.3.4 HEAD/VOLUME (WORD 3)

The head/volume word (word 3 of the disc IOCB) is used by the controller during sector verification. The format of word 3 of the disc IOCB is shown in Figure 3-13.

Table 3-11 defines the bit usage in word 3. It further defines head/volume number bit usage for CMD and SMD drives.



**HEAD NUMBER** 

\*CMD DRIVE ONLY

#### Figure 3-13. Head/Volume Word Format

# TABLE 3-11. DISC IOCB WORD 3

| Bits          | Definition                                                                                                                                                |  |  |  |  |  |
|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| 0-10          | Reserved - must be set to O                                                                                                                               |  |  |  |  |  |
| 11-15         | Used for head/volume number as follows:                                                                                                                   |  |  |  |  |  |
|               | Bits Drive                                                                                                                                                |  |  |  |  |  |
|               | 11*12 13 14 15 CMD Drives                                                                                                                                 |  |  |  |  |  |
|               | 0 0 0 0 0 Head number 0; Removable<br>1 0 0 0 0 Head number 0; Fixed<br>1 0 0 0 1 Head number 1; Fixed                                                    |  |  |  |  |  |
|               | <u>11 12 13 14 15</u> <u>SMD Drives</u>                                                                                                                   |  |  |  |  |  |
|               | 0       0       0       0       Head number 0         0       0       0       1       Head number 1         0       0       1       0       Head number 2 |  |  |  |  |  |
| *Bit 11 = v   | volume bit - used by CMD drives only.                                                                                                                     |  |  |  |  |  |
| HM-081-0027-A | DISC DRIVE INTERFACE                                                                                                                                      |  |  |  |  |  |

POINT 4 Data Corporation 3-23 MARK 3 Peripherals Manual

### 3.3.5 SECTOR ADDRESS (WORD 4)

The sector-address word (word 4 of the disc IOCB) is used to specify the sector address to be used by this operation. The controller compares the sector address word with the current sector address in the sector header. If the sector address does not match, the sector will not be accessed by the controller. The format of word 4 of the disc IOCB is shown in Figure 3-14.

Table 3-12 defines the bit usage in word 4.



Figure 3-14. Sector Address Word Format

# TABLE 3-12. DISC IOCB WORD 4

| Bits | Definition                         |
|------|------------------------------------|
| 0-7  | Reserved - must be set to O        |
| 8-15 | Specifies the 8-bit sector address |

#### 3.3.6 SECTOR COUNT (WORD 5)

The sector-count word (word 5 of the disc IOCB) is used only for read-regardless and format (see Section 3.5.3) operations. It allows a specific number of sectors to be included in an operation. The format for word 5 of the disc IOCB is shown in Figure 3-15.

Table 3-13 defines the bit usage in word 5.

••



Figure 3-15. Sector Count Word Format

# TABLE 3-13. DISC IOCB WORD 5

| Bits | Definition                                                                                                                                                                                                               |
|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0-7  | Reserved - must be set to O                                                                                                                                                                                              |
| 8-15 | Specifies the binary equivalent of the<br>number of sectors to be transferred in<br>the operation.<br>The sector count must never be greater<br>than the sector capacity of one track.<br>If it is, an error will occur. |

# 3.3.7 MEMORY ADDRESS (WORD 6)

The 16-bit memory address word (word 6 of the disc IOCB) is used to specify the starting address for the data buffer. The format for word 6 of the disc IOCB is shown in Figure 3-16.

Table 3-14 defines the bit usage in word 6.

# 0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 MEMORY ADDRESS

Figure 3-16. Memory Address Word Format

#### TABLE 3-14. DISC IOCB WORD 6

| Bits | Definition                              |  |  |  |
|------|-----------------------------------------|--|--|--|
| 0-15 | Starting address for the memory buffer. |  |  |  |

3-26

#### 3.3.8 TERMINATION STATUS (WORD 7)

Upon completion of an operation, the controller writes a termination status into the last word of the IOCB. The termination status provides information on the result of the operation, controller status, and drive status to the processor. Disc-related status information refers only to the drive selected by the unit select word in the IOCB involved. The format of word 7 of the disc IOCB is shown in Figure 3-17.

Table 3-15 defines the bit usage in word 7.



#### Figure 3-17. Termination Status Word Format

HM-081-0027-A POINT 4 Data Corporation 3-27 MARK 3 Peripherals Manual

DISC DRIVE INTERFACE

# TABLE 3-15. DISC TERMINATION STATUS WORD 7

| Bit | Definition                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0   | Operation Complete - Set to 1 upon completion<br>of an operation, successful or not. It<br>provides a means for software to determine<br>when a valid termination status word has been<br>written. The operation-complete bit must be<br>cleared by software. For an error-free<br>operation, this will be the only bit set in<br>the termination status word.                                                                                                                                                                                                                                                                                                                                                                              |
| 1   | Summary Error - Indicates that one or more of the controller error bits is set.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 2-4 | Reserved - set to 0 by PIB.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 5   | Alternate Track - Set to 1 when the controller<br>detects a nonzero value in the next cylinder<br>address of the sector address header, during a<br>sector verification.<br>The controller overwrites the cylinder and<br>head number words in the IOCB with the value<br>found in the sector header next-cylinder and<br>next-head fields. The controller also sets<br>the alternate-track bit to 1, the operation-<br>complete bit to 1, and the summary-error bit<br>to 1. The pending-interrupt bit in the disc<br>IOCB pointer is set to 1 and an interrupt<br>generated, if interrupts are enabled.<br>When software detects the alternate-track bit<br>set, a new seek should be issued based on the<br>new information in the IOCB. |
| 6   | Synchronization Error - Indicates that the<br>controller failed to synchronize with data<br>(could not find any sectors on the track).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 7   | Format Error - Indicates that during a format,<br>a track overrun occurred.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 8   | Seek Error - Indicates that a seek error occurred on the selected drive.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

er Seiter Mar most of

# TABLE 3-15. DISC TERMINATION STATUS WORD 7 (Cont)

| Bit | Definition                                                                                                                                                                                                                                                                                                                     |
|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 9   | Data CRC Error - Indicates that the CRC code<br>did not match with that obtained while reading<br>the data field.                                                                                                                                                                                                              |
| 10  | Address CRC Error - Indicates that the CRC<br>code did not match with that obtained while<br>reading the sector address header which the<br>controller was trying to access.                                                                                                                                                   |
| 11  | No ID Compare - Indicates that the controller<br>could not verify the sector address it was<br>attempting to access. In effect, this means<br>that there was no sector address match with<br>any of the sectors on that track.                                                                                                 |
| 12  | Write Protect Error - Indicates that a write<br>or format operation was attempted on a drive<br>that was write protected.                                                                                                                                                                                                      |
| 13  | <ul> <li>Fault - Indicates that a fault has occurred in the selected drive. A drive fault means that one or more of the following has occurred:</li> <li>Power-fail</li> <li>Illegal head select</li> <li>Write fault</li> <li>Writing or reading while off cylinder</li> <li>Write and read gate on simultaneously</li> </ul> |
| 14  | Reserved - must be set to O                                                                                                                                                                                                                                                                                                    |
| 15  | Unit Not Ready - Indicates that the unit<br>selected in the IOCB word 1 is not installed,<br>is not up to speed, the heads are not engaged,<br>or a drive fault exists.                                                                                                                                                        |

### 3.3.9 DISC CONTROLLER INPUT CONTROL

The processor has a dedicated register that is reserved as a pointer to the IOCB for the disc. This register may be written into or read from by using the DOBC or DIBC instructions, respectively. The C control code is used to specify command instructions directed to the disc controller (rather than the multiplexer (S) or tape controller (P)). The format of the disc controller input control instruction is

DIBC ac,77

where ac is the accumulator into which the value in the disc IOCB pointer is loaded.

The DIBC instruction may be used for two purposes:

- 1. Sensing the idle state - The idle state is indicated by a zero value in the accumulator following execution of a DIBC instruction to read the disc IOCB pointer.
- 2. Polling the interrupt-pending bit When the disc controller has completed an operation, successful or not, it sets the interrupt-pending bit in the disc IOCB pointer. The interrupt-pending bit is the most significant bit in the disc IOCB pointer.

#### **3.3.10** DISC CONTROLLER OUTPUT CONTROL

The DOBC instruction is used for activating and deactivating the disc controller. The format of the disc controller output control instruction is

DOBC ac,77

where ac is a general purpose accumulator. This instruction is used for two purposes:

1. Activating the disc controller - The disc controller is activated by a DOBC instruction in which the accumulator contains the 15-bit memory address of the first IOCB word. The most significant bit must be set to 0.

#### NOTE

Location 0 is an illegal location for an IOCB starting address; 0 is defined as the idle state.

When activated, the controller goes busy and starts the operation specified in the IOCB words.

Deactivating the disc controller - After the disc controller 2. completes an operation and generates an interrupt, it must be deactivated by the software. A DOBC instruction with the accumulator set to zero deactivates the controller. This resets the interrupt-pending bit and places the disc controller in an idle state.

# 3.4 SEEK OPERATION

Software is responsible for initiating a seek, and ensuring its proper completion. Drive selection, seek initiation, and seek error recovery are described in the following subsections which include operational flowcharts. In these operations, tag pulse widths are of critical importance; a timing diagram is provided in Figure 3-18.

#### 3.4.1 DRIVE SELECTION

To select a drive, issue a unit number (the DOA with the drive unit number) to device code 50. Then send a DOA to device code 52 with the accumulator containing 1 which outputs a unit select tag. Issue a DIA to verify the unit is selected and ready. If it is not selected, reissue the DIA until it is selected. This completes drive selection.

The drive select and seek initiation flowchart (Figure 3-19) illustrates this procedure.



Figure 3-18. Seek Operation Timing





ł



HM-081-0027-C



Figure 3-19. Drive Select and Seek Initiation (2 of 3)

HM-081-0027-C POINT 4 Data Corporation



1



#### 3.4.2 SEEK INITIATION

The proper tag sequence to initiate a seek operation is tag 2, tag 1, tag 2. Note that when issuing a tag 1, 2 or 3, the unit select tag must be on.

The first tag 2 contains the head bits and/or volume bit. The volume bit must be issued in this tag 2 if utilizing a CMD drive.

The tag 1 issues the cylinder number. If using a CMD drive, the volume change takes effect, and initiates head movement.

The second tag 2 loads the head and is required for CMD drives. Setting the volume bit is not mandatory.

The seek is initiated.

On the first status read of the disc drive with the DIA instruction (Section 3.2), bit 11 (ONCYL- bit) is normally 1. The heads are in movement and not on cylinder. If the seek procedure has been successful, the ONCYL- goes to 0 and the seek error (bit 8) is also at 0.

A drive select and seek initiation flowchart is shown in Figure 3-19.

#### 3.4.3 SEEK ERROR RECOVERY

A seek error occurs if one of the following conditions exist:

- The drive was unable to complete the seek within 500 milliseconds
- The carriage on the drive has moved outside the recording field
- The carriage has received an illegal track address

If on-cylinder (bit 11 = 0) and a seek error (bit 8 = 1) are indicated, the error must be cleared. To clear the seek error, issue a DOA to device code 51 with bit 9 (return-to-zero) set. Then issue a tag 3 to device code 52. Tag 3 must be kept low during the entire operation. Issue DIAs until the heads are on-cylinder. When they are on-cylinder, tag 3 can be released, and brought inactive. The seek is then reissued. If there is a drive fault (bit 13), issue a fault clear, tag 3. Note that tag 3 is kept low during the whole operation.

A seek error recovery flowchart is shown in Figure 3-20.



Figure 3-20. Seek Error Recovery Flowchart

HM-081-0027-C POINT 4 Data Corporation **N**ana (

**a**n 1984. No 1997

# 3.5 SECTOR BLOCK FORMAT COMMANDS

This section describes disc sector block formatting, command functions, and I/O operations.

#### 3.5.1 FORMATTING OPERATION

The disc is formatted under software control when a DOBC is issued with a format opcode (opcode 60000) specified in word 0 of the IOCB. The controller searches for the first index mark and begins reading address headers from processor memory. Each sector is written to the disc, allowing partitioning in the manner best suited for the particular application.

Before initiating a format operation, the software must build a sector table in memory. This table is used as a source of sector header information when formatting begins. The starting address for this table is located in word 6 of the disc IOCB. The sector table consists of a series of sector blocks, one for each sector to be formatted. All sector blocks must be stored in a contiguous area in processor memory, in the same sequential order that they are to be written to disc. The sector addresses, however, do not have to be in sequential order. Figure 3-21 shows the sector table as built in memory.



Figure 3-21. Sector Table in Memory

#### 3.5.2 SECTOR BLOCK DESCRIPTION

A sector block is comprised of four words which contain the information to be written into the header for each sector.

#### 3.5.2.1 Sector Block Format - Word O Functions

Word 0 is used to define the current cylinder address of the sector. Figure 3-22 shows the contents of word 0.

Table 3-16 defines the fields in word 0.



Figure 3-22. Sector Block Format - Word 0 Contents

#### TABLE 3-16. SECTOR BLOCK FORMAT - WORD 0 FUNCTIONS

| Bits | Function                                            |
|------|-----------------------------------------------------|
| 0-5  | Reserved.                                           |
| 6-15 | Defines the current cylinder address of the sector. |

HM-081-0027-D POINT 4 Data Corporation

3-40

# 3.5.2.2 Sector Block Format - Word 1 Functions

Word 1 is used to define the current sector and head number of the sector. Figure 3-23 shows the contents of word 1.

Table 3-17 defines the fields in word 1.

| 0              | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9        | 10 | 11 | 12  | 13   | 14   | 15 |
|----------------|---|---|---|---|---|---|---|---|----------|----|----|-----|------|------|----|
| CURRENT SECTOR |   |   |   |   |   |   |   |   | 0        | 0  |    | CUR | RENT | HEAD |    |
|                |   |   |   |   |   |   |   | L | <b>L</b> |    |    |     |      |      |    |

081-63

# Figure 3-23. Sector Block Format - Word 1 Contents

## TABLE 3-17. SECTOR BLOCK FORMAT - WORD 1 FUNCTIONS

| Bits  | Function                                          |
|-------|---------------------------------------------------|
| 0-7   | Defines the current sector address of the sector. |
| 8-10  | Reserved - must be set to 0.                      |
| 11-15 | Defines the head number of the sector.            |

1

### 3.5.2.3 Sector Block Format - Word 2 Functions

Word 2 is used to define the alternate-head/alternate-cylinder address of the sector. Figure 3-24 shows the contents of word 2.

小牛种毒素

1.1.40

Table 3-18 defines the fields in word 2.

| <br>1          | 2 | 3 | 4 | 5 | 6 | 7 | 8                  | 9 | 10 | 11 | 12 | 13 | 14 | 15 |  |  |  |
|----------------|---|---|---|---|---|---|--------------------|---|----|----|----|----|----|----|--|--|--|
| ALTERNATE HEAD |   |   |   |   |   |   | ALTERNATE CYLINDER |   |    |    |    |    |    |    |  |  |  |
|                |   |   |   |   |   |   |                    |   |    |    |    |    | •  |    |  |  |  |

081-64

Figure 3-24. Sector Block Format - Word 2 Contents

## TABLE 3-18. SECTOR BLOCK FORMAT - WORD 2 FUNCTIONS

.

| Bits | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0-5  | Defines the alternate-head (two's complement)<br>address of the sector.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 6-15 | Defines the alternate-cylinder address of the sector.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|      | NOTE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|      | When initially formatting a track,<br>this word must be set to zero. If<br>the track being formatted was bad,<br>the software may update this word<br>with an alternate-head/<br>alternate-cylinder address by<br>issuing another format command. A<br>nonzero value in this word notifies<br>the controller that this track is<br>bad, sets the alternate-track bit to<br>l in the termination status word,<br>and terminates the operation. The<br>alternate-head/alternate-cylinder<br>word of each sector block in the<br>sector table (every sector on the<br>track) should contain the same<br>value, since the entire track will<br>be flagged as bad. |

HM-081-0027-C POINT 4 Data Corporation • 3-42 MARK 2/3 Peripherals Manual

DISC DRIVE INTERFACE

## 3.5.2.4 Sector Block Format - Word 3 Functions

Word 3 is reserved, and must be set to zero (0). Figure 3-25 shows the contents of word 3.

Table 3-19 defines the fields in word 3.

#### **1 2 3 4 5 6 7 8 9 10 11 12 13 14 15** 0 • 0

Figure 3-25. Sector Block Format - Word 3 Contents

## TABLE 3-19. SECTOR BLOCK FORMAT - WORD 3 FUNCTIONS

| Bits | Function                            |
|------|-------------------------------------|
| 0-15 | Reserved - must be set to zero (0). |

#### 3.5.3 FORMATTING PROCEDURE

The format command formats one track per operation. The software must ensure that the sector table contains all sectors to be written on a track. If fewer sectors are specified than are available on the track, the remaining sectors will be zeroed out. If more sectors are specified than are available, a format error will occur.

The software must also build the IOCB for the format operation. Figure 3-26 is an example of a format IOCB; Figure 3-27 shows the first sector block of the sector table. The IOCB cylinder and head select words must match the current cylinder and head number of each sector block. The IOCB memory address (word 6) must contain the address of the first word in the sector table. The IOCB sector count (word 5) must be set to the total number of sectors which will be formatted on the track.

|   | 0                 | 1                          | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 |                  |
|---|-------------------|----------------------------|---|---|---|---|---|---|---|---|----|----|----|----|----|----|------------------|
| 0 | 0                 | 0                          | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0  | 0  | 0  | 0  | 0  | 1  | FORMAT OPCODE    |
| 1 | 0                 | 0                          | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0  | 0  | 0  | 0  | 1  | 1  | UNIT 3           |
| 2 | 0                 | 0                          | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0  | 0  | 0  | 1  | 0  | 1  | CYLINDER 5       |
| 3 | 0                 | 0                          | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0  | o  | 0  | 0  | 0  | 0  | HEAD 0           |
| 4 | 0                 | 0                          | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0  | 0  | 0  | 0  | 0  | 0  | SECTOR 0         |
| 5 | 0                 | 0                          | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0  | 0  | 1  | 0  | 0  | 0  | SECTOR COUNT = 8 |
| 6 |                   | FIRST SECTOR BLOCK ADDRESS |   |   |   |   |   |   |   |   |    |    |    |    |    |    |                  |
| 7 | CONTROLLER STATUS |                            |   |   |   |   |   |   |   |   |    |    |    |    |    |    |                  |

Figure 3-26. Input/Output Control Block

|                    | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 1 | CURRENT CYLINDER = 5   |
|--------------------|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|------------------------|
| CURRENT SECTOR = 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | CURRENT HEAD = 0       |
|                    |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   | ALTERNATE CYLINDER = 0 |
| NEXT SECTOR = 0    | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | NEXT HEAD = 0          |

Figure 3-27. First Sector Block

When activated by a DOBC instruction and an index mark is recognized, the controller writes the sector information with the header contained in the first four words (first sector block) of the sector table. The controller writes the first sector address and the address header cyclic redundancy check (CRC), an algorithm used to detect errors in data transfer. Then the controller writes the data, followed by the data CRC. Α worst-case pattern is written into the data field (66666). After the initial sector block, each sector mark reads the next entry and writes that onto the disc. The same procedure is followed for each sector.

The controller continues to write sectors until one of two conditions occurs:

- 1. The specified number of sectors has been formatted, i.e., the sector count is 0. In this case, the controller fills the remainder of the track with zeroes, sets the operation-complete bit in the termination-status word, sets the interrupt-pending bit and generates an interrupt, if interrupts are enabled.
- 2. All available sectors on the current track have been written, and the sector count indicates that there are still sectors In this case, the format operation aborts and to be written. a format error is reported in the termination-status word.

When the format operation is complete, the software should issue a read-verify for each sector. This will ensure that there are no CRC errors in the address fields or data fields.

When a header-CRC error is reported, an alternate cylinder must be selected. The alternate cylinder is written into the alternate-cylinder word in every location of the sector table, and the format command reissued. The alternate cylinder number is then written into all the current cylinder numbers and the alternate cylinder numbers in the sector table are zeroed out. A seek to the alternate cylinder is then issued. When the heads are on-cylinder, a format is issued.

When this procedure is completed, software returns the heads to the bad cylinder plus one (1) to continue the formatting operation.

It is also advisable for software to perform a read-regardless operation (see Section 3.5.4.4). This reads the header field, header CRC, the data field and data CRC into main memory. The sector count in the read-regardless operation should equal the number of sectors written to the track. After the readregardless operation is performed, software may compare the address header information with the information in the sector table. This ensures that the address information was written to disc properly.

#### 3.5.4 SECTOR BLOCK I/O OPERATIONS

I/O operations involve the various read and write operations as described in the following subsections.

#### 3.5.4.1 Write Data Operation

A write-data operation causes the controller to transfer data from the processor memory buffer to the drive. When a DOBC instruction is issued with the write operation (opcode 20000) specified in word 0 of the IOCB, the controller responds by reading the sector address headers on the disc in search of a match to the address in words 2, 3 and 4 of the IOCB. When the controller finds a sector address header that compares with the IOCB address fields, it starts reading the data from the memory data buffer and writing it to the disc until 256 data words are written to the sector.

If there is no compare of the sector address and the address specified in the IOCB, the controller issues a no-ID-compare, a summary error and an operation-complete, and then generates an interrupt.

#### 3.5.4.2 Read Data Operation

The read-data operation is used to read data from the disc and transfer it into the specified processor memory buffer. When a DOBC instruction is issued with the read operation (opcode 10000) specified in word 0 of the IOCB, the controller responds by searching for the sector address specified in words 2, 3 and 4 of the IOCB. When the controller finds a sector address header that compares with the IOCB address fields, it starts reading data from the disc and writing it to the memory buffer. After the sector is completely read (256 words), the CRC is checked. If the CRC is not correct, the data-CRC error bit will be set to 1 in the termination status word.

If there is no compare of the sector address and the address specified in the IOCB, the controller issues a no-ID-compare, a summary error and an operation-complete, and then generates an interrupt.

3-46

#### 3.5.4.3 Read-Verify Operation

The read-verify operation is used to verify that data written on the disc during a write data or format operation was written without error. When a DOBC instruction is issued with the readverify operation (opcode 00000) specified in word 0 of the IOCB, the controller responds by searching for the sector address specified in the IOCB. When the controller finds a sector address header that compares with the IOCB address fields, it reads the data in the sector without transferring it to memory. The data CRC is computed and compared with the CRC on disc and any error is reported in the termination status word.

If there is no compare of the sector address and the address specified in the IOCB, the controller issues a no-ID-compare, a summary error and an operation-complete, and then generates an interrupt.

#### **3.5.4.4** Read-Regardless Operation

The read-regardless operation is used by the software for error recovery and the identification of bad tracks. When the disc controller is activated by a DOBC instruction with the readregardless operation (opcode 50000) specified in word 0 of the IOCB, it starts transfer of data from the disc to the memory buffer upon detection of an index mark.

The number of sectors transferred is specified in the IOCB sector count. The maximum sector count should not be greater than the sector capacity of one track. If the count is less than the number specified, the sectors are transferred, beginning from the index mark. If the count is greater than the capacity of the track, the whole track will be transferred until index is seen again, and the operation terminates.

The largest read cycle that a read-regardless operation can perform is one track. No sector verification is involved and the controller transfers all 262 words of the sector including the address header (four words), the address CRC (one word), the data field (256 words) and the data CRC (one word).

Sector transfer is illustrated in Figure 3-28.

DISC DRIVE INTERFACE MARK 3 Peripherals Manual



HM-081-0027-A POINT 4 Data Corporation 3-48

DISC DRIVE INTERFACE MARK 3 Peripherals Manual

# 3.6 INTERRUPT OPERATION

The disc controller generates an interrupt after completion of an operation whether successful or not. For a description of interrupt servicing, see Section 1.2.1.2 on Programming Polling and Interrupts.

.#800 m

€eg

# Section 4 **QIC-02 STREAMING TAPE DRIVE INTERFACE**

# 4.1 INTRODUCTION

This section describes the interface for the MARK 2/3 Streaming Tape Controller which is available on the MARK 2 and MARK 3 versions of the Peripheral Interface Board (PIB).

The POINT 4 MARK 2/3 Streaming Tape Controller is designed to handle one QIC-02-compatible Intelligent Interface. The Tape Controller provides high speed, direct memory access between the tape drive(s) and the POINT 4 MARK 3 CPU. A streaming tape system provides maximum tape utilization and high throughput for those applications which do not require individual records. One major application is backup for disc systems. To achieve maximum tape utilization and data throughput, a streaming-tape system incorporates very short inter-record gaps and constant high-speed tape motion.

#### 4.1.1 FEATURES

The POINT 4 MARK 2/3 Tape Controller has the following features:

- Handles one Intelligent Interface
- Tape transfers at 90 kilobytes per second
- Accommodates tape speeds of 90 inches per second

#### 4.1.2 PERFORMANCE CHARACTERISTICS

**Tape Controller** Drive type: QIC-02-compatible 1/4-inch streaming tape Tape Transfer Rate: 90 kilobytes per second Controller Device Codes: 60-63 Tape Port Assignments: Port - Jl I/O Instructions: Input - DIA Output - DOA DMA (Device Code 77): DIBP DOBP Tape Drive Track positioning: 500 milliseconds/track Tape start: 300 milliseconds maximum for 90 inches per second Tape stop: 300 milliseconds maximum for 90 inches per second Formatted capacity: 20 or 45 megabytes Recording tracks: 4 or 9

1

# 4.2 TAPE CONTROLLER INTERFACE

Interface between the Tape Controller and the Intelligent Interface consists of:

- Two programmed I/O control lines
- Two programmed I/O status lines
- Two DMA control lines
- 8-bit bidirectional bus
- Bus-direction line
- Interface reset line

#### 4.2.1 TAPE CONTROLLER INTERFACE SIGNALS

Tape controller interface signals are carried on 50-pin cable connector Jl. Figure 4-1 illustrates these signals; their functions are defined in Table 4-1.



#### **Figure 4-1.** Tape Controller Interface Signals

# TABLE 4-1.TAPE CONTROLLER INTERFACE CABLEJ1SIGNAL FUNCTIONS

| Pin | Signal       | Direc-<br>tion | Description                                                   |
|-----|--------------|----------------|---------------------------------------------------------------|
| 1   | GND          | -              | Ground                                                        |
| 2   | -            | _              | Reserved                                                      |
| 3   | GND          | -              | Ground                                                        |
| 4   | -            | -              | Reserved                                                      |
| 5   | GND          | -              | Ground                                                        |
| 6   | -            | -              | Reserved                                                      |
| 7   | GND          | -              | Ground                                                        |
| 8   | -            | -              | Reserved                                                      |
| 9   | GND          | -              | Ground                                                        |
| 10  | HBP-         | Bidirec        | Data Bus Odd Parity - reserved<br>for optioned odd bus parity |
| 11  | GND          | -              | Ground                                                        |
| 12  | нв7-         | Bidirec        | Data Bus Bit 7 (MSB of 8-bit<br>bidirectional data bus)       |
| 13  | GND          | -              | Ground                                                        |
| 14  | НВ <b>6-</b> | Bidirec        | Data Bus Bit 6                                                |
| 15  | GND          | -              | Ground                                                        |
| 16  | нв5-         | Bidirec        | Data Bus Bit 5                                                |
| 17  | GND          | -              | Ground                                                        |
| 18  | HB <b>4-</b> | Bidirec        | Data Bus Bit 4                                                |
| 19  | GND          | -              | Ground                                                        |
| 20  | нв3-         | Bidirec        | Data Bus Bit 3                                                |
| 21  | GND          | -              | GROUND                                                        |
| 22  | HB2-         | Bidirec        | Data Bus Bit 2                                                |
| 23  | GND          | -              | Ground                                                        |

• 4-4

HM-081-0027-C POINT 4 Data Corporation

# TABLE 4-1.TAPE CONTROLLER INTERFACE CABLEJ1SIGNAL FUNCTIONS (Cont)

|     |        | r              |                                                                                                                     |
|-----|--------|----------------|---------------------------------------------------------------------------------------------------------------------|
| Pin | Signal | Direc-<br>tion | Description                                                                                                         |
| 24  | HBl-   | Bidirec        | Data Bus Bit l                                                                                                      |
| 25  | GND    | -              | Ground                                                                                                              |
| 26  | HB0-   | Bidirec        | Data Bus Bit 0 (LSB of 8-bit<br>bidirectional data bus)                                                             |
| 27  | GND    | _              | Ground                                                                                                              |
| 28  | ONL-   | OUT            | Tape Controller is on-line to<br>Intelligent Interface                                                              |
| 29  | GND    | -              | Ground                                                                                                              |
| 30  | REQ-   | OUT            | Request - used by Tape Controller<br>to initiate command sequence,<br>provided RDY- or EXC- is asserted<br>by drive |
| 31  | GND    | -              | Ground                                                                                                              |
| 32  | RST-   | OUT            | Reset - resets Intelligent<br>Interface, causes default<br>selection to device 0, asserts<br>Exception              |
| 33  | GND    | -              | Ground                                                                                                              |
| 34  | XFR-   | OUT            | Transfer - indicates that data is on bus, ready for transfer                                                        |
| 35  | GND    | -              | Ground                                                                                                              |
| 36  | ACK-   | IN             | Acknowledge - indicates that data<br>has been received by device                                                    |
| 37  | GND    | -              | Ground                                                                                                              |
| 38  | RDY -  | IN             | Ready - Intelligent Interface is<br>ready for new operation                                                         |
| 39  | GND    | -              | Ground                                                                                                              |
| 40  | EXC-   | IN             | Exception - indicates exception<br>condition in Intelligent<br>Interface/drive operation                            |

# TABLE 4-1. TAPE CONTROLLER INTERFACE CABLE J1 SIGNAL FUNCTIONS (Cont)

| Pin        | Signal | Direc-<br>tion | Description                                     |
|------------|--------|----------------|-------------------------------------------------|
| 41         | GND    | -              | Ground                                          |
| 42         | DIR-   | IN             | Direction - indicates direction<br>of data flow |
| 43         | GND    | -              | Ground                                          |
| 44         | -      | -              | Reserved .                                      |
| <b>4</b> 5 | GND    | -              | Ground                                          |
| 46         | -      | -              | Reserved                                        |
| 47         | GND    | -              | Ground                                          |
| 48         | _      | -              | Reserved                                        |
| 49         | GND    | -              | Ground                                          |
| 50         | -      | -              | Reserved                                        |

**《明**相》。

HM-081-0027-C

TAPE DRIVE INTERFACE POINT 4 Data Corporation • 4-6 MARK 2/3 Peripherals Manual

## 4.3 INPUT/OUTPUT CONTROL OPERATIONS

The following subsections provide information on tape programmed I/O, detailing instruction formats and accumulator bit functions.

#### 4.3.1 PROGRAMMED I/O INPUT

The DIA instruction is used by software to read status information from the Tape Controller. Software can detect the following status information using the DIA instruction:

- An exception to normal operation
- Direction of data transfer
- Ready for command transfer

The instruction format is:

DIA ac,60

where ac is the processor accumulator to receive status information and 60 is the device code. The format of the accumulator is shown in Figure 4-2; bit functions are defined in Table 4-2.

| 0 | 1 1                  | 1 2                    | 3                           | 4                     | 5          | 6 | 7 | 8    | 9 | 10      | 11 | 12  | 13 | 14  | 15  |
|---|----------------------|------------------------|-----------------------------|-----------------------|------------|---|---|------|---|---------|----|-----|----|-----|-----|
|   |                      |                        |                             |                       |            |   |   | DIRC |   |         |    | АСК |    | EXC | RDY |
|   | Di<br>RE<br>AC<br>RE | RECTI<br>SERVI<br>KNOW | ON<br>ED :<br>/LEDG<br>ED : | SET TO<br>E<br>SET TO | D 0<br>D 0 |   |   |      |   | <u></u> |    |     |    |     |     |
|   | RE                   | ADY .                  |                             |                       |            |   |   |      |   |         |    |     |    |     |     |

#### Figure 4-2. Format of DIA Instruction Accumulator

## TABLE 4-2. DIA INSTRUCTION ACCUMULATOR BITS

| Bits | Signal | Function                                                                                                                                                                                                                                                                                                         |
|------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0-7  | -      | Reserved - set to O                                                                                                                                                                                                                                                                                              |
| 8    | DIRC   | Indicates the direction of data bus. Set<br>to 1 for input; set to 0 for output.                                                                                                                                                                                                                                 |
| 9-11 | -      | Reserved - set to O                                                                                                                                                                                                                                                                                              |
| 12   | ACK    | The status signal supplied by the<br>Intelligent Interface to indicate that it<br>has read (for write operations) the byte<br>from the data bus. For read operations,<br>the Intelligent Interface indicates that a<br>byte has been placed on the data bus to be<br>read by the Tape Controller.<br><b>NOTE</b> |
|      |        | This bit is used by the Tape<br>Controller and need not concern<br>the programmer.                                                                                                                                                                                                                               |
| 13   | _      | Reserved - set to O                                                                                                                                                                                                                                                                                              |
| 14   | EXC    | The Intelligent Interface reports that an<br>error condition exists, and that the<br>previous command has been aborted. The<br>Tape Controller issues a read-status<br>command to determine the exact cause of the<br>exception condition.                                                                       |

(Table continues on next page)

HM-081-0027-A POINT 4 Data Corporation 4-8 MARK 3 Peripherals Manual

TAPE DRIVE INTERFACE

**Millio** 466-68-19

Newsper

#### TABLE 4-2. DIA INSTRUCTION ACCUMULATOR BITS (Cont)

| Bits | Signal | Function                      |                                                                                                                          |  |  |  |  |  |
|------|--------|-------------------------------|--------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| 15   | RDY    | depending on<br>following out | tus bit has different meanings<br>the operational mode. The<br>lines the conditions indicated<br>is set to one.          |  |  |  |  |  |
|      |        | Mode                          | RDY Bit Function                                                                                                         |  |  |  |  |  |
|      |        | Command<br>Transfer           |                                                                                                                          |  |  |  |  |  |
|      |        | Status<br>Input               | Status byte has been placed<br>on the data bus by the<br>Intelligent Interface                                           |  |  |  |  |  |
|      |        | Positioning                   | Position command has been completed                                                                                      |  |  |  |  |  |
|      |        | Writing                       | An Intelligent Interface<br>buffer is ready to be filled<br>by the Tape Controller or a<br>write-file-mark can be issued |  |  |  |  |  |
|      |        | Write<br>File<br>Mark         | Write-file-mark command is<br>completed                                                                                  |  |  |  |  |  |
|      |        | Reading                       | A buffer is ready to be<br>emptied by the Tape<br>Controller                                                             |  |  |  |  |  |
|      |        | Idle                          | Tape Controller is ready to receive a new command                                                                        |  |  |  |  |  |

#### 4.3.1.1 Status Byte Transfer

The DIA instruction with a device code of 61 is used to transfer status bytes from the Tape Controller to the Intelligent Interface. The format of the instruction is

DIA ac,61

where ac is the processor accumulator to receive the data byte and 61 is the device code.

#### 4.3.2 PROGRAMMED I/O OUTPUT

The DOA instruction with a device code of 61 is used to transfer control information from the Tape Controller to the Intelligent Interface. The instruction format is:

DOA ac,61

where ac is the processor accumulator from which the control information will be transferred and 61 is the device code.

The format of the processor accumulator is shown in Figure 4-3; bit functions are described in Table 4-3.

| 0 | 1 1                      |     | 2 | 1 | 3        | I. | 4   | 1   | 5 | ; 1 | • | 6 | 1 7 | 7 | L | 8 | 1 | 9 | 1 | 10 | ) | 11 |   | 12 | 11     | 3        | 1        | 4        | 15 |   |
|---|--------------------------|-----|---|---|----------|----|-----|-----|---|-----|---|---|-----|---|---|---|---|---|---|----|---|----|---|----|--------|----------|----------|----------|----|---|
|   | +                        | - 1 |   | + | <u> </u> | +  |     | 1   |   |     | • |   | 1   |   | T |   | T |   | Т |    |   |    | Т |    | R<br>S | E-<br>ET | ON<br>LI | I-<br>NE | RE | a |
|   | RESERVED - MUST SET TO 0 |     |   |   |          |    |     |     |   |     |   |   |     |   |   |   |   |   |   |    |   |    |   |    |        |          |          |          |    |   |
|   |                          |     |   |   |          | c  | N-L | .IN | E |     |   |   |     |   |   |   |   |   |   |    |   |    |   |    |        |          |          |          |    |   |

# Figure 4-3. Contents of DOA Instruction Accumulator

## TABLE 4-3. DOA INSTRUCTION ACCUMULATOR BITS

| Bits | Signal |                                                                                                                                                                                                             | Function     |  |  |  |  |  |
|------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|--|--|--|--|--|
| 0-12 | -      | Reserved                                                                                                                                                                                                    | d - set to O |  |  |  |  |  |
| 13   | RESET  | Provides the capability to reset the<br>Intelligent Interface. This bit causes a<br>reset equivalent to a power-on reset. All<br>operations abort and the Intelligent<br>Interface waits for a new command. |              |  |  |  |  |  |
| 14   | ONLINE | command<br>• Writ<br>• Read<br>• Writ<br>• Read<br>The on-                                                                                                                                                  | zing         |  |  |  |  |  |

.

## TABLE 4-3. DOA INSTRUCTION ACCUMULATOR BITS (Cont)

| Bits | Signal | Function                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |
|------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
|      |        | ModeOn-line Bit FunctionWriteThe Intelligent Interface must be<br>on-line to the Tape Controller to<br>MarkMarkexecute the write-file-mark<br>command.ReadThe Intelligent Interface must be<br>on-line to the Tape Controller to<br>MarkReadThe Intelligent Interface must be<br>on-line to the Tape Controller to<br>execute the read-file-mark command. |  |  |  |  |  |
| 15   | REQ    | Used to initiate command sequences to the<br>Intelligent Interface. Request (REQ) can<br>only be set in response to the interface<br>setting either ready (RDY) or exception<br>(EXC). Request is used in conjunction with<br>ready to transfer command and status bytes<br>between the Tape Controller and the<br>Intelligent Interface.                 |  |  |  |  |  |

.

HM-081-0027-A

HM-081-0027-ATAPE DRIVE INTERFACEPOINT 4 Data Corporation4-12MARK 3 Peripherals Manual

# 4.4 TAPE CONTROLLER IOCB

For DMA operations the input/output control block (IOCB) contains the command to be performed. The IOCB for the Tape Controller consists of three words located in main memory and used to indicate operational mode. The three words of the IOCB are set up by the software before the operation begins.

An additional word immediately following the IOCB must be reserved for a termination status word. Upon completion of an operation (successful or not), the controller writes operation complete into the termination status word. Figure 4-4 shows the format of the Tape Controller IOCB.



#### Figure 4-4. Tape Controller IOCB Format

- Word 0 Ignored.
- Word 1 Byte Pointer points to one less than the first byte to be transferred. Bit 15 of word 1 is a byte indicator. If BIN=0 the left byte will be output. If BIN=1 the right byte will be output.
- Word 2 Last Byte Pointer equal to word 1 + 1000 octal.

DMA transfer is accomplished one block at a time (400 words = 1000 bytes octal). Initiation of DMA transfer is effected with a DOBP command (see Section 4.4.1).

Word 3 - Termination Status Word - contains an operation-complete bit (bit 0). The operation-complete bit will be set upon completion of an operation, successful or not. As each byte is transferred, the byte pointer is incremented until it equals the last byte, which signals that the transfer is completed.

| HM-081-0027-A            |      | TAPE DRIVE INTERFACE      |
|--------------------------|------|---------------------------|
| POINT 4 Data Corporation | 4-13 | MARK 3 Peripherals Manual |

#### 4.4.1 TAPE TRANSFER CONTROL

The processor has a dedicated register that is reserved as a pointer to the IOCB for the Tape Controller. This register may be written into or read from by using DOBP or DIBP instructions, respectively. The P control code is used to specify instructions directed to the Tape Controller (rather than the multiplexer (S) or disc controller (C)).

Tape transfer control is effected using DOBP and DIBP instructions with device code 77. The DOBP instruction activates and deactivates the Tape Controller; the DIBP instruction senses the idle state and polls the interrupt-pending bit in the tape IOCB pointer.

#### 4.4.1.1 DOBP Instruction

The DOBP instruction is used for activating and deactivating the Tape Controller. The format of the control output instruction is

DOBP ac,77

where ac is a processor accumulator into which the address of the IOCB pointer will be loaded. This instruction is used for two purposes:

- Activating the Tape Controller The Tape Controller is 1. activated when a DOBP instruction is issued with the contents of the accumulator containing the memory address of the first tape IOCB word and the most significant bit set to 0. When activated, the controller will go to a busy state and start the operation specified, e.g.
  - Transfer direction (read or write), determined by the a. last DOA ac,61
  - Memory address, determined by the Tape IOCB b.
- 2. Deactivating the Tape Controller - When the Tape Controller completes an operation and generates an interrupt, it must be deactivated by the software. The DOBP instruction with the accumulator set to the value zero is used to deactivate the controller. This resets the interrupt-pending bit and places the Tape Controller in an idle state.

#### 4.4.1.2 DIBP Instruction

The format of the tape-input-control instruction is

DIBP ac,77

where ac is the accumulator into which the value of the tape IOCB pointer is loaded.

The DIBP instruction may be used for two purposes:

- 1. Sensing the idle state The idle state is defined as a zero value in the accumulator after executing a DIBP instruction to read the tape IOCB pointer.
- 2. Polling the interrupt-pending bit When the Tape Controller has completed an operation, successful or not, it sets the interrupt-pending bit in the tape IOCB pointer. The interrupt-pending bit is the most significant bit in the tape IOCB pointer.

The DIBP instruction can be used to read the IOCB pointer to check for the interrupt-pending bit set to 1. This allows for polling to check for devices requiring service.

# 4.5 TAPE CONTROLLER COMMANDS

Tape Controller commands for interface to the drives are single-byte commands. Bits 0 through 7 must be zero. The most significant bit is 0; the least significant bit is 15. The instruction format is:

DOA ac, 62

The command format is shown in Figure 4-5.

|   | 5 6 7    | 8 9 10       | <b>11</b>   <b>12</b>   <b>13</b>   <b>14</b>   15 |
|---|----------|--------------|----------------------------------------------------|
| 0 | <b>0</b> | COMMAND TYPE | COMMAND DATA                                       |

#### Figure 4-5. Tape Controller Command Format

The command-type field selects one of seven possible commands. The command types and bit positions for bits 8, 9 and 10 are shown below. Commands are described in detail in the subsections that follow.

| Type | Bit Position <u>8910</u> | Command                |
|------|--------------------------|------------------------|
| 0    | 0 0 0                    | Select                 |
| 1    | 0 0 1                    | Position               |
| 2    | 0 1 0                    | Write                  |
| 3    | 0 1 1                    | Write File Mark        |
| 4    | 1 0 0                    | Read                   |
| 5    | 1 0 1                    | Read File Mark         |
| 6    | 1 1 0                    | Read Status            |
| 7    | 1 1 1                    | Reserved for later use |

The Intelligent Interface will accept any command when the ready bit has been set to one, and the interface is not currently executing a command. Only a read-status command will be accepted when the exception bit is set.

The on-line bit must be set for command types 2, 3, 4 and 5 to be executed; otherwise the interface will cause an exception status to be reported to the processor. The on-line control bit is ignored for command types 0, 1 and 6.

Direction is established in the write mode by issuing to the interface either command type 2 (write) or type 3 (write file mark). After write mode has been established, command types 2 or 3 will be accepted between data block transfers only. Direction is established in the read mode by issuing command type 4 (read) or type 6 (read status). After read mode has been established, no commands will be accepted between data blocks.

HM-081-0027-A POINT 4 Data Corporation 4-16

#### 4.5.1 SELECT COMMAND (TYPE 0)

The select command is used to select one of four drives attached to the interface. For systems equipped with a single tape drive, use of this command is optional. The interface will default to tape drive 0 if no select command is issued. For multi-drive systems, this command should be issued before any of the other six commands. Once a drive has been selected by this command, it will remain selected until another select command is issued, or until power is removed from the tape unit.

Bit descriptions for the select command are shown below.

#### Bit Description

A.C.

| 15 | Select drive 0 |
|----|----------------|
| 14 | Select drive l |
| 13 | Select drive 2 |
| 12 | Select drive 3 |
| 11 | Not used       |

#### NOTE

Execution of the select command is virtually instantaneous. If two or more drives are selected simultaneously, the interface will set the exception bit.

#### 4.5.2 POSITION COMMAND (TYPE 1)

The position command permits mechanical manipulation of the tape for rewinding, erasing or retensioning.

Bit descriptions for the position command are shown below.

| Bi | t | De | es | cr | i | ot | i | on |
|----|---|----|----|----|---|----|---|----|
|    |   |    |    |    |   |    |   |    |

| 15 | BOT-rewind to beginning of tape |
|----|---------------------------------|
| 14 | Erase tape                      |
| 13 | Retension tape                  |
| 12 | Set to 0                        |
| 11 | Set to O                        |

Upon receiving the position command, the Intelligent Interface will check the drive status for cartridge-in. If a cartridge is not installed in the drive, the controller will abort the position command and report an exception (illegal command) condition to the processor. At the completion of the position command, and if no abnormal conditions exist, the controller will report a ready status to the processor and wait for a new command.

Setting of bit 15 in the position command data field will reposition the tape at the BOT position. A BOT-position command may be issued prior to a read or write command. If a position command is not issued, the interface will default to BOT before executing a read or write command.

Setting of bit 14 in the command-data field erases the entire tape. Tape erasure occurs while writing is in progress, up to and including the end of that write routine. However, previously written data may still exist on this and other tracks when the file just written is shorter than the previously existing files. Erasure of a tape before writing new files on the tape prevents confusion in such an activity as reading file marks to determine the number of files on the tape. The erase-position command causes the tape to be moved from BOT to EOT with the erase channel activated and then returned to BOT.

Setting of bit 13 in the position command-data field causes a retensioning pass to be performed on the cartridge tape, as recommended by the tape manufacturer. When excessive read errors are encountered, a retensioning pass should be executed prior to writing. A retensioning pass should be executed any time an unreasonable number of tape errors is experienced.

#### 4.5.3 WRITE COMMAND (TYPE 2)

The write command is used to initiate recording of data blocks onto the tape. Bit descriptions for the write command are shown below.

| <u>Bit</u> D | escription |
|--------------|------------|
|--------------|------------|

| 15<br>14 | Set<br>Set |    | - |
|----------|------------|----|---|
| 13       | Set        | to | 0 |
| 12<br>11 | Set<br>Set |    | - |

The on-line control bit must be set to 1 before issuing a write command or an illegal command status will occur.

Upon receiving the write command, the interface will check the tape drive status for cartridge-in and write-protect status. If either condition exists, the write command is inhibited and an exception status will be reported to the processor.

If the on-line bit is reset to 0, the remaining buffered data will be written to tape, a file mark written, and the tape positioned at BOT. Otherwise, writing will continue until a write-file-mark command is issued between data blocks. A write-file-mark will cause the controller to finish writing the remaining buffer memory and then write the file mark. Another write command resumes recording of data. Another write-file-mark command or a position command can be issued to terminate writing.

#### 4.5.4 END OF TAPE HANDLING

The interface may terminate writing by setting the exception bit to 1 due to an irrecoverable-data error or end-of-tape being sensed. When the early warning hole (EWH) of the last track is detected, the controller will discontinue accepting new data blocks, will write the remaining buffer memories, and will set the exception bit to warn the processor of a change in status.

When a read-status command is issued subsequent to EWH detection, the tape drive will stop, pending further instructions. Three possible courses of action may follow:

- 1. Issue a new write command
- 2. Issue a write-file-mark command
- 3. Set the on-line bit to 0

If a new write command is issued, two blocks of data will be accepted and the end-of-tape procedure repeated. These blocks are used to indicate a completed file or a file continued on another cartridge. A write-file-mark command followed by resetting the on-line bit causes a file mark and a return to BOT. A failure to issue either a write or write-file-mark command before resetting the on-line bit will reposition the tape to BOT without writing a file mark, and there will be no indication that the final record is complete. The blocks written from this write command or a write command with no data, followed by resetting of on-line to 0, will cause a file mark to be written and the tape returned to BOT.

4-19

#### 4.5.5 WRITE FILE MARK COMMAND (TYPE 3)

The write-file-mark command provides for the separation of the data stored on the tape cartridge into more logical segments. This enables the use of better-defined data areas. Bit descriptions for the write-file-mark command are shown below.

| <u>Bit</u> | Description |
|------------|-------------|
| 15         | Set to O    |
| 14         | Set to O    |
| 13         | Set to O    |
| 12         | Set to O    |
| 11         | Set to O    |

The on-line bit must be set to 1 when the write-file-mark command is issued or an illegal command status will occur. During execution of a write command, the write-file-mark command can only be issued between data blocks since the data bus is occupied by data during the block transfers. A write-file-mark command terminates the write command after the data block in progress has been recorded and then writes a file mark.

#### 4.5.6 READ COMMAND (TYPE 4)

The read command is used to retrieve data blocks from a pre-recorded cartridge. Bit descriptions for the read command are shown below.

Bit Description

| 15 | Set | to | 0 |
|----|-----|----|---|
| 14 | Set | to | 0 |
| 13 | Set | to | 0 |
| 12 | Set | to | 0 |
| 11 | Set | to | 0 |

The on-line bit must be set to 1 when the read command is issued or an illegal command status will occur. Before beginning a read operation, the interface will check the drive status for cartridge in place. If no cartridge is installed, the controller will report an error status by setting the exception bit.

The interface will set the exception bit to terminate the read operation after reading a tape file mark. The exception bit will also be set after transferring the block in error (BIE) when an irrecoverable read error occurs.

In order to continue data transfers, the on-line bit must be set to 1 and another read command issued. If the read command was terminated because a file mark was encountered, the new read command will cause the next file to be read from tape. If the read command was terminated because of an irrecoverable read error in the data field, issuing another read command causes the

HM-081-0027-A POINT 4 Data Corporation 4-20

TAPE DRIVE INTERFACE MARK 3 Peripherals Manual

controller to continue reading the current file beginning at the next block. If the block in error was a file mark, the data transferred by the new read command will be from the next file.

No commands are accepted by the interface during execution of read data transfers. However, a read operation may be terminated between data blocks by issuing a DOA instruction with the on-line bit set to 0. When this instruction is received, the controller will position the tape to BOT. The tape may be returned to BOT after the completion of an entire read command by issuing a position-to-BOT command while the on-line bit is still set to 1.

#### 4.5.7 READ FILE MARK COMMAND (TYPE 5)

The read-file-mark command is used to detect file marks. Bit descriptions for the read-file-mark command are shown below.

| <u>Bit</u> | Description |
|------------|-------------|
| 15         | Set to O    |
| 14         | Set to O    |
| 13         | Set to O    |
| 12         | Set to O    |
| 11         | Set to O    |

The on-line bit must be set to 1 when the read-file-mark command is issued or an illegal command status will occur. Before beginning a read-file-mark operation, the interface will check the drive status for cartridge in place. If no cartridge is in place, the interface will report an error status to the processor by setting the exception bit to 1.

After reading the tape file mark, the interface will set the exception bit to 1. To continue reading file marks, the on-line bit must be kept set to 1 and another read-file-mark command issued. If the block in error is a file mark, the new read-filemark command will begin reading at the next file mark following the block in error.

For a read-file-mark command, no actual data is transferred to the processor. To terminate a read-file-mark operation, reset the on-line bit to 0. When this instruction is received, the controller will position the tape to BOT. The tape may be returned to BOT after the completion of an entire read-file-mark command by issuing a position-to-BOT command while the on-line bit is still set to 1.

## 4.5.8 READ STATUS COMMAND

The read-status command is used to retrieve six bytes of information from the interface. The interface status can be read under two conditions:

Security

- When the interface sets the exception bit to 1 due to a change in status
- At the normal completion of a data transfer command

The command data field of the read-status command is defined as follows:

| <u>Bit</u> | Description |
|------------|-------------|
| 15         | Set to 0    |

| 15 | Set | to | 0 |
|----|-----|----|---|
| 14 | Set | to | 0 |
| 13 | Set | to | 0 |
| 12 | Set | to | 0 |
| 11 | Set | to | 0 |

## 4.5.8.1 Exception Status Bytes

Six exception-status bytes define the conditions which can cause the interface to report an exception status. The six status bytes transferred are defined in Table 4-4.

| Byte | Bit | Operation     | Exception Status                                  |
|------|-----|---------------|---------------------------------------------------|
| 0    | 15  | -             | File Mark Detected                                |
|      | 14  | -             | Block in Error Not Detected                       |
|      | 13  | -             | Irrecoverable Data Error                          |
|      | 12  | -             | End of Tape                                       |
|      | 11  | -             | Write Protected                                   |
|      | 10  | -             | Drive Not On-line                                 |
|      | 9   | -             | Cartridge Not in Place                            |
|      | 8   | -             | Exception Byte 0                                  |
| 1    | 15  | -             | Reset Occurred                                    |
|      | 14  | -             | Reserved - Set to O                               |
|      | 13  | -             | Reserved - Set to O                               |
|      | 12  | -             | Reserved - Set to O                               |
|      | 11  | -             | Reserved - Set to O                               |
|      | 10  | -             | No data detected                                  |
|      | 9   | -             | Illegal command                                   |
|      | 8   | -             | Exception Byte 1                                  |
| 2&3  | -   | Write         | Data Error counter: Number of<br>blocks rewritten |
|      |     | Read          | Data Error counter: Number of soft read errors    |
| 4&5  |     | Write<br>Read | Number of buffer underruns                        |

| TABLE 4-4. | STATUS | BYTE | DEFINITIONS |
|------------|--------|------|-------------|
|------------|--------|------|-------------|

HM-081-0027-A POINT 4 Data Corporation 4-23

#### 4.5.8.1.1 EXCEPTION BYTE 0

The eight bits of exception byte 0 are shown in Figure 4-6 and defined in Table 4-5.



Figure 4-6. Exception Byte 0

HM-081-0027-A POINT 4 Data Corporation 4-24 MARK 3 Peripherals Manual

TAPE DRIVE INTERFACE

Netterstal

## TABLE 4-5. EXCEPTION BYTE 0 BIT DEFINITION

| Bit | Name                                | Definition                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-----|-------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15  | File Mark<br>Detected               | Set to one each time the controller-read<br>channel encounters a file mark during a<br>read or position command. This bit and<br>the exception bit will be reset to 0<br>after a read-status command is executed.<br>This bit does not indicate an error<br>condition and data transfers or tape<br>positioning can continue if the processor<br>issues another read or position command.                                                                                                                                                                                                                                                                                            |
| 14  | Block In<br>Error Not<br>Detected   | Set to one along with the irrecoverable-<br>error status bit (bit 13) if the last<br>block transferred during a read command<br>was not the block containing the<br>irrecoverable error.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 13  | Irrecov-<br>erable<br>Data<br>Error | Set to one when the soft error retry<br>sequence fails to recover a data block<br>from the tape during a read or<br>read-file-mark command. This bit will be<br>set to one on a write or write-file-mark<br>command if the same data block is<br>rewritten more than 16 times. This bit<br>and the exception bit will be reset to 0<br>after a read-status command has been<br>executed. The tape will be repositioned<br>to BOT after the read-status command if<br>the irrecoverable error occurred during a<br>write or write-file-mark command.                                                                                                                                  |
| 12  | End of<br>Tape                      | When set to one, indicates that an<br>attempt was made to read past the EOT<br>holes for the last track or may write<br>past the end of the recording area on the<br>last track. For write operations, two<br>additional data blocks and a file mark<br>can be written after encountering an<br>end-of-tape status report. For read<br>operations, if this status bit is set, it<br>indicates that the controller missed the<br>last file mark on the tape, or that the<br>tape was positioned past the final file<br>mark when another read or read-file-mark<br>command was issued. This bit and the<br>exception bit will be reset after<br>execution of the read-status command. |

HM-081-0027-A

.

TAPE DRIVE INTERFACE POINT 4 Data Corporation 4-25 MARK 3 Peripherals Manual

## TABLE 4-5. EXCEPTION BYTE 0 BIT DEFINITION (Cont)

| Bit | Name                         | Definition                                                                                                                                                                                                                 |
|-----|------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 11  | Write<br>Protected           | When set to one, operator intervention is<br>required. Set if the write-protect plug<br>is set in the file-position (bracket<br>safe). Operator must determine<br>error-status cause before this bit can be<br>reset to 0. |
| 10  | Drive Not<br>On-line         | Set if the selected drive is not<br>physically connected to the interface, or<br>is not receiving power.                                                                                                                   |
| 9   | Cartridge<br>Not<br>in Place | When set to one, operator must check<br>cartridge placement before this bit can<br>be reset to 0.                                                                                                                          |
| 8   | Exception<br>Byte 0          | Set to one when any other bit in<br>exception byte 0 is set to one. Reset to<br>0 after a read-status command.                                                                                                             |

HM-081-0027-ATAPE DRIVE INTERFACEPOINT 4 Data Corporation4-26MARK 3 Peripherals Manual

#### 4.5.8.1.2 EXCEPTION BYTE 1

The eight bits of exception byte 1 are shown in Figure 4-7, and defined in Table 4-6.



Figure 4-7. Exception Byte 1

HM-081-0027-A POINT 4 Data Corporation 4-27

TAPE DRIVE INTERFACE MARK 3 Peripherals Manual

### TABLE 4-6. EXCEPTION BYTE 1 BIT DEFINITION

| Bit | Name                | Definition                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |
|-----|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 15  | Reset<br>Occurred   | When set to one, indicates a reset has<br>occurred. Causes all operations to<br>abort. The interface sets the exception<br>bit.                                                                                                                                                                                                                                                                                                                                                                                          |  |
| 14  |                     | Reserved - set to 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |
| 13  |                     | Reserved - set to O                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |
| 12  |                     | Reserved - set to O                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |
| 11  |                     | Reserved - set to O                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |
| 10  | No Data<br>Detected | Set when an irrecoverable-data error<br>occurs due to insufficient recorded data,<br>caused by failure to detect a data block<br>within an interface timeout period. It<br>is reset after a read-status command.                                                                                                                                                                                                                                                                                                         |  |
| 9   | Illegal<br>Command  | <ul> <li>Detected by the controller and set to one when the following conditions exist:</li> <li>1. A select command was issued with more than one drive specified or no drive specified.</li> <li>2. A position command was issued with more than one or no qualifier specified.</li> <li>3. The on-line bit is reset to 0 and a write, write-file-mark, read or read-file-mark command is issued.</li> <li>4. A command other than write or write-file-mark was issued during execution of a write command.</li> </ul> |  |
| 8   | Exception<br>Byte 1 | Set to one when any other bit in status<br>byte 1 is set. It is reset to 0 after<br>issuing a read-status command.                                                                                                                                                                                                                                                                                                                                                                                                       |  |

HM-081-0027-A

TAPE DRIVE INTERFACE POINT 4 Data Corporation 4-28 MARK 3 Peripherals Manual

Net in all of

a. judi

#### 4.5.8.1.3 BYTES 2 AND 3

Status bytes 2 and 3 provide a 16-bit binary count of the tape data errors. Byte 2 contains the most significant byte and byte 3 contains the least significant byte. The counter is reset to 0 after issuing a DOA instruction with the on-line bit set to one.

During write operations, the counter will increment for each data block that is rewritten due to a read-after-write error. Since the rewrite operation rewrites two data blocks for each error, the counter will be incremented twice for each error. Α four-track, 450-foot tape cartridge will store approximately 40,000 512-byte blocks.

During read operations, the data error counter will be incremented for each data block containing an unexpected cyclicredundancy-code (CRC) error. Expected CRC errors are blocks that were rewritten during the write operation. The counter is incremented for each read retry until the block is successfully read or logged as an irrecoverable-data error.

#### 4.5.8.1.4 BYTES 4 AND 5

These two bytes will contain a 16-bit binary count of buffer underruns. Byte 4 contains the MSB and byte 5 contains the LSB. For write operations, this count will be incremented each time the processor is unable to keep data flowing to the interface. If the interface is ready to write the next block, but the buffer is not full and ready to write, the interface will stop tape motion and wait for the processor.

During a read operation, this count will increment when the processor is unable to empty the interface buffers fast enough. If an empty buffer is not available for the next block of data to be read from the tape, tape motion will stop.

## 4.6 TAPE COMMAND INTERFACE

This section describes the sequence of events that occur when I/O commands interface with the tape drive. Flowcharts for the various operational modes are provided in Appendix B. The operational sequences described in Sections 4.6.1 through 4.6.6 are for error-free handling. Refer to Section 4.6.7 for error processing and recovery.

#### 4.6.1 COMMAND TRANSFER SEQUENCE

The sequence for transferring a command between the processor and the interface is:

- The program places the command byte on the command data bus. 1.
- 2. The program sets the REQ (request) bit.
- The interface takes the command byte from the command data 3. bus and sets the RDY (ready) bit.
- The processor receives RDY (ready) and resets REQ (request). 4.
- 5. The interface resets RDY (ready).

See Appendix B-1 for command transfer sequence flowchart.

#### 4.6.2 READ STATUS COMMAND SEQUENCE

The sequence for reading status information is:

- 1. The program issues a read-status command as described in Section 4.6.1.
- 2. The interface takes the command from the command data bus and sets the DIRC (direction) bit.
- 3. The interface places the status byte on the command data bus.
- 4. The interface sets the RDY (ready) bit.
- 5. The status byte is transferred from the interface to the processor.
- 6. The program sets the REQ (request) bit.
- 7. The interface resets RDY (ready).
- 8. The program drops REQ (request).
- 9. Steps 3 through 8 are repeated until all six status bytes have been transferred.
- 10. The interface resets the DIRC (direction) bit.

See Appendix B-2 for read-status sequence flowchart.

#### 4.6.3 WRITE COMMAND OPERATIONS

The sequence of events for write command operations is:

- The processor, in preparation for a write operation, checks to see if the interface is ready. If it is, the processor will place a write command on the bus and notify the interface.
- 2. The interface will read the command, verify that a cartridge is in place and not write-protected, and signal the processor that the command was accepted.
- 3. If the processor had not preceded the write command with select and position commands, the interface will automatically select unit 0 and track 0, BOT.
- 4. The interface will begin accepting data. When the first buffer is full, the interface will begin writing.
- 5. The interface will write blocks of data on the tape, automatically adding gap, sync, block address and CRC.
- 6. After the data is written, it passes over the read head, which read-checks the data for CRC errors.
- 7. After the data has been verified by the read-after-write check, the buffer which held that data will be released for the next transfer of data from the processor.
- 8. The interface will continue writing blocks of data to the tape until it detects the early warning hole. When the interface detects this hole, it will stop accepting new data from the processor on the next block boundary. The interface will write all existing buffers to tape and then write a constant gap signal to the end-of-tape (EOT) hole.
- 9. The interface will then deselect the write mode, disable the erase head and stop tape motion.
- 10. The interface will switch to track 1, reverse the capstan motor direction, and start tape motion. When the tape is up to speed and in the recording zone, the interface will resume writing.
- 11. The interface will continue writing for the full length of track 1. When the load-point hole is reached, the interface will again halt tape motion. This time the controller will physically reposition the read/write head and select track 2.
- 12. If the processor continues writing data until the early warning hole of track 3, the interface will stop accepting data and inform the processor that the tape is full. The processor may now write a block describing that the file is not complete and write a file mark.

See Appendix B-3 for write sequence flowchart.

HM-081-0027-A TAPE DRIVE INTERFACE POINT 4 Data Corporation 4-32 MARK 3 Peripherals Manual

#### 4.6.4 READ COMMAND OPERATIONS

Read command operations follow the sequence of events detailed below.

- 1. The program issues the read command.
- 2. The interface positions the tape to BOT of track 0.
- 3. The interface brings the tape up to speed and begins searching for the first data block.
- 4. The interface reads the entire data block to the read buffer and checks the CRC and the block address number.
- 5. If the CRC and block address are good, the block is transferred to the processor.
- 6. Steps 4 and 5 are repeated for all of the blocks on track 0.
- 7. When the EOT (end-of-tape) holes are detected for track 0, the interface stops the drive, selects track 1, reverses the direction of the drive's capstan motor and brings the tape up to speed.
- 8. All of the records on track 1 are read, error checked and transferred to the processor.
- 9. Tracks 2 and 3 are handled in a similar manner to tracks 0 and 1.
- 10. The read command can be terminated by the program any time a block boundary is reached, or automatically by the interface if a file mark or EOT holes for the last track are detected.

See Appendix B-4 for read sequence flowchart.

#### 4.6.5 WRITE FILE MARK OPERATIONS

The write-file-mark command will generate a standard length data block with unique codes in the data field, a block address and a CRC. The processor does not transfer any data for the file mark The sequence of events is: block.

- The program issues the write-file-mark command at any data 1. block boundary.
- 2. The interface writes the remaining blocks of data from the interface buffers to the tape.
- The interface generates a file-mark block and writes this 3. block to the tape.
- The file-mark block is checked with a read-after-write 4. operation and if an error occurs it is treated like any other block in error (BIE).

There is no restriction concerning the number of file marks which can be written on a tape. There are also no restrictions as to the number of user blocks which can be written between file marks.

A read command will terminate upon encountering a file mark and will set the file-mark bit in the status words.

If the program terminates a write command without issuing a write-file-mark command (i.e., by resetting the on-line bit), the controller automatically generates a file mark.

After issuing a write file mark, the program can immediately issue another write command (or write-file-mark command) and continue transferring files to tape.

#### 4.6.6 READ FILE MARK OPERATIONS

Read-file-mark operations follow the sequence of events detailed below.

- 1. A read-file-mark command is performed the same as a read command, but no data is transferred to the processor.
- A read-file-mark command is terminated by reading a file 2. mark. Counting the total number of files (or file marks) on a tape would require reissuing the read-file-mark command for each file mark found.

#### 4.6.7 ERROR PROCESSING AND RECOVERY

The Intelligent Interface provides error processing and recovery sequences which are transparent to the program/processor and reduces the load on the processor. Information passed to the processor consists only of statistical data on the number of errors automatically processed by the interface. These statistics can be used for evaluating media integrity and system performance.

The following subsections discuss simple error handling. The controller is capable of handling compound (multiple) errors. However, this discussion is intended only to illustrate the principle of error recovery procedures.

## 4.6.7.1 Write Buffer Overrun

Streaming-tape systems use constant tape motion with small gaps between the data blocks. This means the processor must maintain uninterrupted transfer of data blocks to the controller. Once writing has been initiated and a full buffer is not available for transfer to the drive, the interface will automatically extend the length of the inter-record gap up to 0.3 inches (a little over half a record). The automatic gap extension will be logged in the statistical counters. If a buffer becomes available before the end of the extended gap, the gap extension will be terminated and the buffer written immediately. Regardless of the length of the gap extension, the statistical counter will be updated for each gap extension. A complete buffer overrun will occur when at the end of the extended gap period, a buffer is still not available for the write channel. Gap extension is provided to allow for processor system contention without decreasing the system throughput by terminating tape motion. The number of gap extensions will directly subtract from the total number of data blocks available on the tape (approximately 10,000 per track). For this reason, write buffer overruns are highly undesirable.

#### 4.6.7.2 Read After Write Errors

1

With high-density streaming tapes, information is recorded in 0.0001-inch increments. The recording area must be free of all contamination and imperfections approaching 0.0001 inches. For this reason, the interface is designed to accommodate occasional data errors. A read-check is performed on each block of data immediately following the write operation. If a CRC error is found during the read-check, that block will be rewritten.

The tape drive head has two gaps, one for writing and one for reading. These gaps are separated by a distance of 0.3 inches. For tape streaming the inter-record gap length is only 0.013 inches. Therefore the interface must begin writing the next record before the previous record has been verified.

If the block being verified has a CRC error, the interface will continue rewriting the blocks until no read-after-write errors are detected, or until 16 rewrites have been performed. If 16 rewrites are performed, the interface terminates the write command and reports an irrecoverable data error to the processor. A read-after-write counter is provided to inform the program of the number of blocks automatically rewritten by the interface. These rewritten blocks will subtract from the total capacity of the tape.

#### 4.6.7.3 Read Buffer Underruns

The interface has an extra buffer reserved in case the processor system gets behind the transfer rate of the read channel. This provides a one-block buffer to allow for short-term processor system contentions before the read channel overruns the controller buffer.

If the processor fails to stay ahead of the read channel, a read-buffer underrun will occur. This condition arises when the read channel has located the next block of data and no interface buffer is available. To prevent the loss of this block, the interface must stop the tape, back up the tape and wait for a buffer to become available. The controller restarts the tape and begins reading until it locates the block that underran the buffer. From this point on, the normal read sequence is resumed.

Since the read buffer underrun recovery is invisible to the processor, a statistical counter is provided to keep track of the number of underruns.

HM-081-0027-A POINT 4 Data Corporation

4-36

#### 4.6.7.4 Read Data Errors

The read-after-write check operation occasionally detects errors. To ensure data integrity, the error recovery routine rereads the block in error (BIE) up to 16 times. The process of rereading the BIE is a soft error retry.

If the data block has not been successfully recovered after 16 retries, the interface will transfer the BIE if it can be located, terminate the read operation, and report an irrecoverable read error to the processor. A block is always transferred. If it is not the block in error, the processor will be notified.

Since soft error retries are invisible to the processor, a statistical counter is available. This counter is updated for each soft error retry. Data blocks with CRC errors that were rewritten during the write process do not increment the soft error retry counter.

#### 4.6.7.5 Read Sequence Errors

The interface appends a block-address byte to each data block written to the tape. During a write operation, a data block with a read-after-write check will be rewritten. Rewritten blocks will alter the normal sequence of blocks. The interface uses the block-address byte to maintain the proper sequence of data blocks sent to the processor.

During read operations, when a data block without a CRC error is read and the next block contains an unexpected address, a block-sequence error results. Block-sequence errors will automatically invoke a soft error retry. This retry sequence is the same as performed for read-data errors. The soft error retry counter will be incremented for each retry until the proper sequence is re-established, or until a limit of 16 retries is exceeded. The interface will transfer the BIE if it can be located, terminate the read command and report an irrecoverable data error to the processor. A block is always transferred. The processor will be informed if it is not the BIE.

## Section 5 FLOPPY DISC DRIVE INTERFACE

## 5.1 INTRODUCTION

This section describes the interface for the MARK 3 Floppy Disc controller which is available on the MARK 3B version of the Peripheral Interface Board (PIB).

The POINT 4 MARK 3B PIB utilizes a state-of-the-art Western Digital 1797 controller chip. The Floppy Disc Controller is designed to handle up to four Shugart-compatible drives with single or double-sided, single or double-density capabilities. It provides high-speed, direct-memory access to the MARK 3 CPU. Multiple drives are accommodated by daisy chaining using connector Jl for 8-inch or Jl7 for 5-1/4-inch floppy disc drives. Drives used with the MARK 3B system must have soft sectoring and head-load-on-select capabilities.

Diskettes are an inexpensive means of mass storage. They are small and easily transportable. If security is a consideration, they are easily stored in a locked cabinet or may even be carried in a brief case. Diskettes are most frequently used for word processing and inputting data records.

The MARK 3B Peripheral Interface Board (PIB) supports either 8-inch or 5-1/4-inch drives. Both sizes cannot be run on the same PIB because each size drive has different cabling and timing requirements.

The Interface supports the following IBM formats:

| IBM 1 FM   | (single-sided, | single-density | Frequency | Modulation) |
|------------|----------------|----------------|-----------|-------------|
| IBM 2 MFM  | (single-sided, | double-density | Modified  | Frequency   |
|            | Modulation)    |                |           |             |
| IBM 2D MFM | (double-sided, | double-density | Modified  | Frequency   |
|            | Modulation)    |                |           |             |

This section describes the MARK 3 floppy disc drive interface in general terms. Some discussions, such as those dealing with diskette formatting, are annotated for the IRIS user. Users of other operating systems may wish to consult Western Digital's FD 1797 Data Sheet for appropriate formatting information.

#### 5.1.1 PLOPPY DISC CONTROLLER FEATURES

THE POINT 4 MARK 3B Floppy Disc Controller has the following features:

- Supports up to four Shugart-compatible (soft sectored) drives
- 8-inch or 5-1/4-inch diskettes
- FM and MFM encode and decode logic
- Side select
- Address mark detection
- Control-block-oriented instructions
- Software control of sector addressing
- Read/Write head position verification
- Floppy disc operation handled via an I/O control block (IOCB)
- I/O Instructions using device codes 30 to 37
- Data transfer is performed in DMA mode (device code 77)
- Status and error reporting on completion of operation
- Write protect
- CRC (cyclic redundancy check) generation and detection
- Controller device codes range from 30 to 37
- Drive port assignments for floppy disc: Jl for 8-inch Jl7 for 5-1/4-inch

HM-081-0027-C POINT 4 Data Corporation

#### 5.1.2 TYPICAL DRIVE PERFORMANCE CHARACTERISTICS

Performance depends on the type of drive used. The performance characteristics given here are typical for most drives.

- DMA transfer at 250 kilobits per second for single density and 500 kilobits per second for double density diskettes.
- Average latency is 83 milliseconds.
- The capacity of the diskettes depends on the format used:

| <u>Unformatted</u> | <u>Single Density</u> | Double Density |
|--------------------|-----------------------|----------------|
| Per Disc           | 800 kilobits          | 1600 kilobits  |
| Per Surface        | 400 kilobits          | 800 kilobits   |
| Per Track          | 5.2 kilobits          | 10.4 kilobits  |

| IBM Format<br>(128-Byte Sectors) | Single Density | Double Density |
|----------------------------------|----------------|----------------|
| Per Disc                         | 500 kilobits   | 1000 kilobits  |
| Per Surface                      | 250 kilobits   | 500 kilobits   |
| Per Track                        | 3.3 kilobits   | 6.66 kilobits  |

• Typical access times are as follows:

| Track-to-track               | 3 milliseconds  |
|------------------------------|-----------------|
| Settling time                | 15 milliseconds |
| Head load time               | 50 milliseconds |
| Average (including settling) | 90 milliseconds |

FLOPPY DISC DRIVE INTERFACE MARK 3 Peripherals Manual

#### 5.1.3 DISKETTE SPECIFICATIONS

Diskettes may be either 8-inch or 5-1/4-inch depending on the size of the drive. Specifications are as follows:

. 6<sup>12</sup>181

100.00

8-inch Diskettes:

I

I

- Single or double sided
- Single or double density
- Sectors may be formatted as follows:

128 bytes

256 bytes

512 bytes\*

1024 bytes

\*IRIS requires that diskettes be double density and be formatted into 15 sectors of 512 bytes.

5-1/4-inch Diskettes:

- Single or double sided
- Single or double density
- Sectors may be formatted as follows:

128 bytes

257 bytes

512 bytes\*\*

1024 bytes

\*\*IRIS requires that diskettes be double density, be formatted into sectors of 512 bytes, and have a capacity of at least 750K bytes after formatting.

5-4

## 5.2 FLOPPY DISC DRIVE INTERFACE

The Floppy Disc Controller supports up to four diskette drives. The drive(s) must be Shugart-compatible (soft sectored), and have head-load-on-select capability. If two or more drives are used, they must be daisy-chained. Figure 5-1 illustrates the daisy-chain connection.

Figure 5-2 shows the Floppy Disc Drive interface signals. Table 5-1 lists the Jl signal functions (for 8-inch floppy drives) and Table 5-2 the Jl7 signal functions (for 5-1/4-inch floppy. drives).



Figure 5-1. Daisy-Chain Drive Connection

5-5



## Figure 5-2. PIB/Floppy Disc Drive Interface Signals

HM-081-0027-B POINT 4 Data Corporation 5-6 FLOPPY DISC DRIVE INTERFACE MARK 3 Peripherals Manual

## TABLE 5-1. 8-INCH FLOPPY DISC CONTROLLER INTERFACE (J1 SIGNAL FUNCTIONS)

| Pin | Signal          | Direc-<br>tion | Description                                                                                                                   |
|-----|-----------------|----------------|-------------------------------------------------------------------------------------------------------------------------------|
| 1   |                 |                |                                                                                                                               |
| 2   |                 |                |                                                                                                                               |
| 3   | GND             |                | Ground                                                                                                                        |
| 4   |                 |                |                                                                                                                               |
| 5   | GND             |                | Ground                                                                                                                        |
| 6   |                 |                |                                                                                                                               |
| 7   |                 |                |                                                                                                                               |
| 8   |                 |                |                                                                                                                               |
| 9   | GND             |                | Ground                                                                                                                        |
| 10  |                 |                |                                                                                                                               |
| 11  | GND             |                | Ground                                                                                                                        |
| 12  |                 |                |                                                                                                                               |
| 13  | GND             |                | Ground                                                                                                                        |
| 14  | SIDE 1<br>SELD- | OUT            | Side 1 Select - Indicates which<br>side of a two-sided diskette to<br>use for reading or writing.<br>0 = Side 0<br>1 = Side 1 |
| 15  | GND             |                | Ground                                                                                                                        |
| 16  |                 |                |                                                                                                                               |
| 17  | GND             |                | Ground                                                                                                                        |
| 18  |                 |                |                                                                                                                               |
| 19  | GND             |                | Ground                                                                                                                        |

#### TABLE 5-1. 8-INCH FLOPPY DISC CONTROLLER INTERFACE (Cont) (J1 SIGNAL FUNCTIONS)

|     |           | Direc- |                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-----|-----------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Pin | Signal    | tion   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 20  | IP-       | IN     | Index Pulse - Provided by a<br>drive once each revolution of<br>the diskette (166.67<br>milliseconds) to indicate the<br>beginning of the track.                                                                                                                                                                                                                                                                                               |
| 21  | GND       |        | Ground                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 22  | READY -   | IN     | Unit Ready - Indicates that two<br>index holes were sensed after<br>proper insertion of diskette<br>and closing the door; or two<br>index holes were sensed<br>following the application of<br>+5V power to the drive. Three<br>holes must be sensed for<br>two-sided diskettes. READY is<br>activated for a two-sided<br>diskette when either side is<br>selected. For a one-sided<br>diskette READY is activated<br>when side 0 is selected. |
| 23  | GND       |        | Ground                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 24  |           |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 25  | GND       |        | Ground                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 26  | DRVSEL 1- | OUT    | Select drive l                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 27  | GND       |        | Ground                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 28  | DRVSEL 2- | OUT    | Select drive 2                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 29  | GND       |        | Ground                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 30  | DRVSEL 3- | OUT    | Select drive 3                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 31  | GND       |        | Ground                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 32  | DRVSEL 4- | OUT    | Select drive 4                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 33  | GND       |        | Ground                                                                                                                                                                                                                                                                                                                                                                                                                                         |

## TABLE 5-1. 8-INCH FLOPPY DISC CONTROLLER INTERFACE (Cont) (J1 SIGNAL FUNCTIONS)

| []  |        |                |                                                                                    |
|-----|--------|----------------|------------------------------------------------------------------------------------|
| Pin | Signal | Direc-<br>tion | Description                                                                        |
| 34  | DIR-   | ОИТ            | Direction Select - Defines<br>which direction the Read/Write<br>heads will move.   |
| 35  |        |                |                                                                                    |
| 36  | STEP-  | OUT            | Step - Causes the Read/Write<br>heads to move as defined by<br>DIR                 |
| 37  | GND    |                | Ground                                                                             |
| 38  | WDATA- | OUT            | Write Data - Provides the<br>data to be written to the<br>diskette.                |
| 39  | GND    |                | Ground                                                                             |
| 40  | WGATE- | OUT            | Write Gate - When activated,<br>enables WDATA to write to<br>diskette.             |
| 41  | GND    |                | Ground                                                                             |
| 42  | TR00-  | IN             | Track 00 - Indicates when<br>Read/Write heads are positioned<br>on track zero.     |
| 43  | GND    |                | Ground                                                                             |
| 44  | WPRT-  | IN             | Write Protect - Inhibits<br>writing if a write-protected<br>diskette is installed. |
| 45  | GND    |                | Ground                                                                             |
| 46  | RDATA- | IN             | Read Data - Provides the raw<br>data (clock and data together).                    |
| 47  | GND    |                | Ground                                                                             |
| 48  |        |                |                                                                                    |
| 49  | GND    |                | Ground                                                                             |
| 50  |        |                |                                                                                    |

# TABLE 5-2.5-1/4-INCH FLOPPY DISC CONTROLLER INTERFACE(J17 SIGNAL FUNCTIONS)

| PinSignalDirectionDescription1GNDGround2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | r   |           |     |                                                                                        |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-----------|-----|----------------------------------------------------------------------------------------|
| 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | Pin | Signal    |     | Description                                                                            |
| 3       GND       Ground         4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 1   | GND       |     | Ground                                                                                 |
| 4Ground5GNDGround6DRVSEL 4-OUTSelect drive 4.7READY-INForced low by interface. Not<br>normally supported by<br>5-1/4-inch drives.8IP-INIndex Pulse - Provided by a<br>drive once each revolution of<br>the diskette (166.67<br>milliseconds) to indicate the<br>beginning of the track.9GNDGround10DRVSEL1-OUTSelect drive 111GNDGround12DRVSEL2-OUTSelect drive 213GNDGround14DRVSEL3-OUTSelect drive 315GNDGround16Index Ground17GNDGround18DIR-OUTDirection Select - Defines<br>which direction the Read/Write<br>heads will move when the step<br>line is pulsed. | 2   |           |     |                                                                                        |
| 5GNDGround6DRVSEL 4-OUTSelect drive 4.7READY-INForced low by interface. Not<br>normally supported by<br>5-1/4-inch drives.8IP-INIndex Pulse - Provided by a<br>drive once each revolution of<br>the diskette (166.67<br>millisconds) to indicate the<br>beginning of the track.9GNDGround10DRVSEL1-OUT11GNDGround12DRVSEL2-OUT13GNDGround14DRVSEL3-OUT15GNDGround16I17GNDGround18DIR-OUT00TDirection Select - Defines<br>which direction the Read/Write<br>heads will move when the step<br>line is pulsed.                                                           | 3   | GND       |     | Ground                                                                                 |
| 6DRVSEL 4-OUTSelect drive 4.7READY-INForced low by interface. Not<br>normally supported by<br>5-1/4-inch drives.8IP-INIndex Pulse - Provided by a<br>drive once each revolution of<br>the diskette (166.67<br>milliseconds) to indicate the<br>beginning of the track.9GNDGround10DRVSEL1-OUT11GNDGround12DRVSEL2-OUT13GNDGround14DRVSEL3-OUT15GNDGround16                                                                                                                                                                                                            | 4   |           |     |                                                                                        |
| 7READY-INForced low by interface. Not<br>normally supported by<br>5-1/4-inch drives.8IP-INIndex Pulse - Provided by a<br>drive once each revolution of<br>the diskette (166.67<br>milliseconds) to indicate the<br>beginning of the track.9GNDGround10DRVSEL1-OUT11GNDGround12DRVSEL2-OUT13GNDGround14DRVSEL3-OUT15GNDGround16                                                                                                                                                                                                                                        | 5   | GND       |     | Ground                                                                                 |
| Normally supported by<br>5-1/4-inch drives.8IP-INIndex Pulse - Provided by a<br>drive once each revolution of<br>the diskette (166.67<br>milliseconds) to indicate the<br>beginning of the track.9GNDGround10DRVSEL1-OUT11GNDGround12DRVSEL2-OUT13GNDGround14DRVSEL3-OUT15GNDGround16                                                                                                                                                                                                                                                                                 | 6   | DRVSEL 4- | OUT | Select drive 4.                                                                        |
| drive once each revolution of<br>the diskette (166.67<br>milliseconds) to indicate the<br>beginning of the track.9GNDGround10DRVSEL1-OUT9GNDGround11GNDGround12DRVSEL2-OUT13GNDGround14DRVSEL3-OUT15GNDGround16If17GNDGround18DIR-OUT0UTDirection Select - Defines<br>which direction the Read/Write<br>heads will move when the step<br>line is pulsed.                                                                                                                                                                                                              | 7   | READY-    | IN  | normally supported by                                                                  |
| 10DRVSEL1-OUTSelect drive 111GNDGround12DRVSEL2-OUTSelect drive 213GNDGround14DRVSEL3-OUTSelect drive 315GNDGround16                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 8   | IP-       | IN  | drive once each revolution of<br>the diskette (166.67<br>milliseconds) to indicate the |
| 11GNDGround12DRVSEL2-OUTSelect drive 213GNDGround14DRVSEL3-OUTSelect drive 315GNDGround161617GNDGround18DIR-OUTDIR-OUTDirection Select - Defines which direction the Read/Write heads will move when the step line is pulsed.                                                                                                                                                                                                                                                                                                                                         | 9   | GND       |     | Ground                                                                                 |
| 12DRVSEL2-OUTSelect drive 213GNDGround14DRVSEL3-OUTSelect drive 315GNDGround1617GND18DIR-OUTDirection Select - Defines which direction the Read/Write heads will move when the step line is pulsed.                                                                                                                                                                                                                                                                                                                                                                   | 10  | DRVSEL1-  | OUT | Select drive l                                                                         |
| 13       GND       Ground         14       DRVSEL3-       OUT       Select drive 3         15       GND       Ground         16           17       GND       Ground         18       DIR-       OUT         DIR-       OUT       Direction Select - Defines which direction the Read/Write heads will move when the step line is pulsed.                                                                                                                                                                                                                              | 11  | GND       |     | Ground                                                                                 |
| 14       DRVSEL3-       OUT       Select drive 3         15       GND       Ground         16           17       GND       Ground         18       DIR-       OUT       Direction Select - Defines which direction the Read/Write heads will move when the step line is pulsed.                                                                                                                                                                                                                                                                                       | 12  | DRVSEL2-  | OUT | Select drive 2                                                                         |
| 15       GND       Ground         16                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 13  | GND       |     | Ground                                                                                 |
| 16       Ground         17       GND       Ground         18       DIR-       OUT       Direction Select - Defines which direction the Read/Write heads will move when the step line is pulsed.                                                                                                                                                                                                                                                                                                                                                                       | 14  | DRVSEL3-  | OUT | Select drive 3                                                                         |
| 17     GND     Ground       18     DIR-     OUT     Direction Select - Defines which direction the Read/Write heads will move when the step line is pulsed.                                                                                                                                                                                                                                                                                                                                                                                                           | 15  | GND       |     | Ground                                                                                 |
| 18 DIR- OUT Direction Select - Defines<br>which direction the Read/Write<br>heads will move when the step<br>line is pulsed.                                                                                                                                                                                                                                                                                                                                                                                                                                          | 16  |           |     |                                                                                        |
| which direction the Read/Write<br>heads will move when the step<br>line is pulsed.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 17  | GND       |     | Ground                                                                                 |
| 19 GND Ground                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 18  | DIR-      | OUT | which direction the Read/Write<br>heads will move when the step                        |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 19  | GND       |     | Ground                                                                                 |

HM-081-0027-B POINT 4 Data Corporation 5-10

## TABLE 5-2. 5-1/4-INCH FLOPPY DISC CONTROLLER INTERFACE (Cont) (J17 SIGNAL FUNCTIONS)

| Pin | Signal          | Direc-<br>tion | Description                                                                                                                   |
|-----|-----------------|----------------|-------------------------------------------------------------------------------------------------------------------------------|
| 20  | STEP-           | OUT            | Step - Causes the Read/Write<br>heads to move as defined by<br>DIR                                                            |
| 21  | GND             |                | Ground                                                                                                                        |
| 22  | WDATA-          | OUT            | Write Data - Provides the data<br>to be written to the diskette.                                                              |
| 23  | GND             |                | Ground                                                                                                                        |
| 24  | WGATE-          | OUT            | Write Gate - When activated,<br>enables WDATA to write to<br>diskette.                                                        |
| 25  | GND             |                | GROUND                                                                                                                        |
| 26  | TR00-           | IN             | Track 00 - Indicates when<br>Read/Write heads are positioned<br>on track zero.                                                |
| 27  | GND             |                | GROUND                                                                                                                        |
| 28  | WPRT-           | IN             | Write Protect - Inhibits<br>writing if a diskette is write-<br>protected.                                                     |
| 29  | GND             |                | GROUND                                                                                                                        |
| 30  | RDATA-          | IN             | Read Data - Provides the raw<br>data (data and clock together).                                                               |
| 31  | GND             |                | GROUND                                                                                                                        |
| 32  | SIDE 1<br>SELD- | OUT            | Side 1 Select - Indicates which<br>side of a two-sided diskette to<br>use for reading or writing.<br>0 = Side 0<br>1 = Side 1 |
| 33  | GND             |                | Ground                                                                                                                        |
| 34  |                 |                |                                                                                                                               |

HM-081-0027-B POINT 4 Data Corporation 5-11

FLOPPY DISC DRIVE INTERFACE MARK 3 Peripherals Manual

## 5.3 PROGRAMMED INPUT/OUTPUT

Two modes of operation are standard with the Floppy Disc Controller: programmed I/O and DMA (Direct Memory Access).

Three types of command are used to communicate with the controller:

DOBP ac,77 (initiates a floppy data transfer) DIA ac,3x (Read from Floppy Controller register) DOA ac,3x (Write to Floppy Controller register)

where

ac = accumulator 3x = device code

The device codes used by the Floppy Disc Controller range from 30 to 37:

| Device      | DOA                 | DIA                   |
|-------------|---------------------|-----------------------|
| <u>Code</u> | Instruction         | Instruction           |
| 30/32       | Select Register     | *                     |
| 31/33       | Intermediate Buffer | Intermediate Buffer** |
| 34          | Command Register    | Status Register       |
| 35          | Track Register      | Track Register        |
| 36          | Sector Register     | Sector Register       |
| 37          | Data Register       | Data Register         |

\*The Select Register can be written to but not read from. \*\*Reserved for firmware or test purposes.

A DOA instruction is used to write to and a DIA instruction is used to read from a Floppy Disc Controller register. The general command formats are:

DOA ac,3x DIA ac,3x where ac = accumulator 3x = device code

The following subsections provide information on floppy disc programmed I/O and the use of registers.

5-12

#### 5.3.1 SELECT REGISTER

The Select Register can be written to but may not be read from. It is loaded using the least significant six bits of the specified accumulator as shown in Figure 5-3.

The command format is

DOA ac,30

where ac = the accumulator



#### Figure 5-3. Select Register Word

HM-081-0027-B POINT 4 Data Corporation 5-13

FLOPPY DISC DRIVE INTERFACE -13 MARK 3 Peripherals Manual

#### 5.3.2 COMMAND REGISTER

The Command and Status Registers (see Section 5.3.3) are physically the same register. As a Command Register, it holds the command currently being executed. A command is input with a DOA instruction. When execution of the command is completed, or if a halt occurs because of an error condition, status information may be retrieved with a DIA instruction.

Five instructions are available to software:

- 1. Restore
- 2. Seek
- 3. Step
- 4. Step In
- 5. Step Out

Of these instructions only Restore and Seek are required. The bit configuration is discussed in Sections 5.3.2.1 and 5.3.2.2 respectively. For information on the Step commands, refer to Western Digital's FD 1797 Data Sheet.

The Command Register should not be loaded when the device is busy.

The command format is

DOA ac,34

where ac = the accumulator.

5-14

## 5.3.2.1 Restore Command Bit Configuration

The Command Register uses the eight least significant bits of the accumulator word. Bits 8 through 12 are set to zero. Bit 13 is the Verify flag and bits 14 and 15 control the stepping motor rate. Figure 5-4 shows how these bits may be set.

#### NOTE

The setting of bits 14 and 15 depends on the type of drive used. Not all drives support the 3-millisecond stepping motor rate. See the specification supplied by the drive vendor.



| BIT 14 (R1) | BIT 15 (R0) | TEST- = 1<br>(MILLISECONDS) | TEST-=0<br>(Microseconds) |
|-------------|-------------|-----------------------------|---------------------------|
| 0           | 0           | 3 ms                        | <b>184 ی</b>              |
| 0           | 1           | 6 ms                        | su, 190                   |
| 1           | 0           | 10 ms                       | <b>198</b> يىر            |
| 1           | 1           | 15 ms                       | sبر 208                   |
| 081-79      |             |                             |                           |

#### Figure 5-4. Restore Command Bit Configuration

HM-081-0027-C POINT 4 Data Corporation 5-15

FLOPPY DISC DRIVE INTERFACE MARK 2/3 Peripherals Manual

## 5.3.2.2 Seek Command Bit Configuration

The Command Register uses the eight least significant bits of the accumulator word. Bits 8 through 10 are set to zero. Bit 11 is set to one, bit 12 to zero and bit 13 is the Verify flag. Bits 14 and 15 control the stepping motor rate. Figure 5-5 shows how these bits may be set.

#### NOTE

The setting of bits 14 and 15 depends on the type of drive used. Not all drives support the 3-millisecond stepping motor rate. See the specification supplied by the drive vendor.

| 0 1                           | 2     | 3     | 4     | 5 | 6     |     | 8 | 9                   | 10 | 11         | 12 | 13 | 14 | 15 |
|-------------------------------|-------|-------|-------|---|-------|-----|---|---------------------|----|------------|----|----|----|----|
| 0 🔫 —                         |       |       |       |   | >     | - 0 | 0 | 0                   | 0  | 1          | o  | v  | R1 | R0 |
|                               |       |       |       |   |       |     |   | $\overline{\gamma}$ |    |            |    |    |    |    |
| RESERVED FO                   |       |       | SE    |   |       |     |   |                     |    |            |    |    |    |    |
| MUST BE SET                   | TO ZE | RO    |       |   |       |     |   |                     |    |            |    |    |    |    |
| SEEK COMMA                    | ND FL | AG    |       |   |       |     |   |                     |    |            |    |    |    |    |
| MUST BE SET                   | TO ZE | RO    |       |   |       |     |   |                     |    |            |    |    |    |    |
| V=VERIFY FL<br>0- NO<br>1- VE | VERI  |       | STINA |   | FRACK | <   |   |                     |    | <u>ura</u> |    |    |    |    |
| STEPPING MO                   | TOR R | ATE - |       |   |       |     |   |                     |    |            |    |    |    |    |

| BIT 14 (R1) | BIT 15 (R0) | TEST-= 1<br>(MILLISECONDS) | TEST-=0<br>(MICROSECONDS) |
|-------------|-------------|----------------------------|---------------------------|
| 0           | Ó           | 3 ms                       | su, 184                   |
| 0           | 1           | 6 ms                       | <del>د</del> ىر 190       |
| 1           | 0           | 10 ms                      | <del>ع</del> بر 198       |
| 1           | 1           | 15 ms                      | <b>208</b> يىر            |
| 081-80      |             |                            |                           |

#### **Figure 5-5.** Seek Command Bit Configuration

I

#### 5.3.3 STATUS REGISTER

The Status Register contains information on the status of the drives after a command has been executed. It uses the same address as the Command Register (see Section 5.3.2). The eight least significant bits contain status information depending on the type of command. This status information is retrieved with a DIA instruction.

The instruction format is

DIA ac,34

where ac = the accumulator.

The format of the status word for data transfer commands is given in Figure 5-6; Table 5-3 defines the function of each bit.

The bit configuration for head movement commands is shown in Figure 5-7; Table 5-4 explains the bit functions.



## Figure 5-6. Drive Status Register Word For Data Transfer Commands

## TABLE 5-3. DRIVE STATUS DEFINITIONS FOR DATA TRANSFER COMMANDS

| Bits | Name      | Function                                                                                                                                                                                                                                                                                          |
|------|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0-7  |           | Reserved, set to 0 by the controller                                                                                                                                                                                                                                                              |
| 8    | NOT READY | Unit Not Ready - When set to 0, the<br>selected unit is ready. When set to 1,<br>the unit is not ready. This bit is an<br>inverted copy of the Ready input. Data<br>transfer commands will not execute<br>unless the requested drive is ready.                                                    |
| 9    | WRTPRT    | Write Protect - Indicates that data may<br>not be written into a file. Not used<br>for Read Record or Read Track commands.<br>Reset when the next command is received.                                                                                                                            |
| 10   | RECTYPE   | Record Type - For Read Sector command<br>only. A user-definable flag that<br>indicates the record-type code from the<br>Data Address Mark.<br>0 = Data Address Mark<br>1 = Deleted Data Address Mark<br>Reset when the next command is received.                                                  |
| 11   | RNF       | Record Not Found - Not used for Read<br>Track or Write Track commands. When set<br>to 1, indicates that the specified<br>track, sector, or side was not found.<br>Reset to 0 when the next command is<br>received.                                                                                |
| 12   | CRCERR    | CRC Error - Not used for Read Track or<br>Write Track commands. When set to 1 and<br>bit 11 is also set to 1, indicates an<br>error is found in one or more ID fields.<br>When set to 1 and bit 11 = 0, indicates<br>an error in the data field. Reset to 0<br>when the next command is received. |
| 13   | LOST DATA | Lost Data - When set to 1, indicates<br>that the computer did not respond to the<br>data request in one byte time. Reset to<br>0 when the next command is received.                                                                                                                               |

HM-081-0027-BFLOPPY DISC DRIVE INTERFACEPOINT 4 Data Corporation5-18MARK 3 Peripherals Manual

4 august i

-#812<sub>60</sub>

# TABLE 5-3. DRIVE STATUS DEFINITIONS FOR DATA TRANSFER COMMANDS (Cont)

| Bits | Name | Function                                                                                                                                                                                                                  |
|------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 14   | DRQ  | Data Request - When set to 1, indicates<br>that the Data Register is full on a read<br>operation or it is empty on a write<br>operation. This bit is reset to 0 when<br>updated. This bit is a copy of the DRQ<br>output. |
| 15   | BUSY | Busy - When set to 0, no command is<br>being executed. When set to 1, a<br>command is being executed.                                                                                                                     |



## Figure 5-7. Status Register For Head Movement Commands

## TABLE 5-4. DRIVE STATUS DEFINITIONS FOR HEAD MOVEMENT COMMANDS

| Bits | Name      | Function                                                                                                                                                    |
|------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0-7  |           | Reserved, set to 0 by the controller                                                                                                                        |
| 8    | NOT READY | Unit Not Ready - When set to 0, the<br>selected unit is ready. When set to 1,<br>the unit is not ready. This bit is an<br>inverted copy of the Ready input. |
| 9    | WRTPRT    | Write Protect - When set to 1, indicates<br>that Write Protect is activated. This<br>bit is an inverted copy of WRTPRT-<br>input.                           |
| 10   | HDL       | Head Load - Not used. Select loads the<br>heads at the drive end.                                                                                           |
| 11   | SKERR     | Seek Error - When set to 1, indicates<br>that the specified track was not<br>verified. It is reset when updated.                                            |
| 12   | CRCERR    | CRC Error - When set to l, an error was<br>encountered in the ID field.                                                                                     |
| 13   | TR00      | Track Number 00 - When set to 1,<br>indicates that Read/Write heads are<br>positioned on track zero. This bit is<br>an inverted copy of TR00- input.        |
| 14   | INDEX     | Index - When set to 1, indicates that an<br>Index Mark from the drive is detected.<br>This bit is an inverted copy of the IP-<br>input.                     |
| 15   | BUSY      | Busy - When set to 0, no command is<br>being executed. When set to 1, a<br>command is being executed.                                                       |

HM-081-0027-B POINT 4 Data Corporation 5-20 FLOPPY DISC DRIVE INTERFACE MARK 3 Peripherals Manual

#### 5.3.4 TRACK REGISTER

The Track Register holds the track number of the current Read/Write head position. It is incremented by one every time the head is stepped in (toward track 76) and decremented by one when the head is stepped out (toward track 00). The contents of the register are checked against the recorded track number in the ID field during disc Read, Write, and Verify procedures.

This register may be written to or read from. To write to the Track Register, use the format

DOA ac,35

To read from the register, use the format

DIA ac,35

where ac = the accumulator.

#### 5.3.5 SECTOR REGISTER

The Sector Register contains a specified sector address. It may be written to or read from. The contents of this register are compared with the recorded sector number in the ID field during disc Read or Write operations. To write to the Sector Register, use the format

5-21

DOA ac,36

To read from the register, use the format

DIA ac,36

where ac = the accumulator.

#### 5.3.6 DATA REGISTER

The Data Register is an 8-bit holding register used while disc Read or Write operations are in progress. When a Seek Command (see Section 5.3.2.2) is executed, the Data Register is used to hold the destination track of the Seek. During a Read operation, data is transferred into the register. During a Write operation, data is transferred from the register. All data transfers are handled by firmware in DMA mode. The Data Register may be written to and read from. To write to the register, use the format

DOA ac,37

To read from the register, use the format

DIA ac,37

where ac = the accumulator.

AREAS

# 5.4 INPUT/OUTPUT CONTROL BLOCK (IOCB)

The input/output control block (IOCB) contains commands to be performed via direct memory access (DMA). The IOCB for the Floppy Disc Controller consists of three words located in the lower 32K of main memory. It is used to indicate the operational mode. The three words are set up by the software before an operation begins. The format of the Floppy Disc IOCB is shown in Figure 5-8.



#### Figure 5-8. Floppy Disc IOCB Format

### 5.4.1 COMMAND WORD (WORD 0)

The command word (word 0 of the IOCB) is used to define five commands. These commands may be divided into three classes as follows:

- Data Transfer Commands Read Sector Write Sector
- 2. Utility Commands Read Address Read Track
- 3. Format Command Write Track

The following subsections discuss each command function and bit configuration.

5-23

#### 5.4.1.1 Read Sector Command

The Read Sector command transfers data blocks from diskette to memory. The block size depends on the setting of the B-flag in the command word and the sector length code in the header (see Table 5-5). For IRIS-compatibility, the B-flag should be set to 1 and the sector length should be 02 (see Section 5.4.1.3). Upon receipt of the command, the Busy status bit is set. When an ID field is encountered with the correct track number, sector number, side number, and cyclic redundancy check (CRC), the data is transferred to memory.

| P. Plag Catting    | Sector Length Code |          |      |      |  |  |  |  |
|--------------------|--------------------|----------|------|------|--|--|--|--|
| B Flag Setting     | 00                 | 01       | 02   | 03   |  |  |  |  |
| 0 - Single Density | 256                | 512      | 1024 | 128  |  |  |  |  |
| l - Double Density | 128                | 256      | 512* | 1024 |  |  |  |  |
| *Required for IRIS | <b>.</b>           | <u> </u> |      |      |  |  |  |  |

TABLE 5-5. SECTOR LENGTH FLAG SETTING

The Data Address Mark must be found within 30 bytes (single density) or 43 bytes (double density) of the last ID field CRC byte. If it is not found, the Record Not Found (RNF) bit is set and the operation terminates.

Once the first byte reaches the Data Register, the Data Request bit (DRQ) is set. If the computer has not read the contents of the Data Register before a new byte is transferred, that byte is lost and the Lost Data status bit is set. If a CRC error occurred at the end of the data field, the CRC Error status bit is set and the operation terminates.

At the end of the Read operation, the type of Data Address Mark encountered in the data field is recorded in the Status Register (Deleted Data Mark = 1; Data Mark = 0).

The bit configuration and possible flag settings for the Read Sector command are shown in Figure 5-9. Bits 0-12 must be set as shown; bits 13 and 14 may be set as required; bit 15 is a user-defined flag. Table 5-6 defines the bit settings.

HM-081-0027-B POINT 4 Data Corporation

5-24



Figure 5-9. Read Sector Command Word Bit Configuration

.

## TABLE 5-6. READ SECTOR COMMAND BIT CONFIGURATION

| Bit  | Definition                                                                                                                                                                        |
|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0    | Set to O                                                                                                                                                                          |
| 1    | Set to 1 for Read operation                                                                                                                                                       |
| 2-7  | Set to O                                                                                                                                                                          |
| 8    | Set to l                                                                                                                                                                          |
| 9-11 | Set to O                                                                                                                                                                          |
| 12   | Side Select Output Flag (SSO). This flag is<br>used in address verification.<br>0 - Side 0<br>1 - Side 1                                                                          |
| 13   | Delay Flag (E).<br>0 - No delay<br>1 - 15-millisecond delay (normal)                                                                                                              |
| 14   | Sector Length Flag (B). This flag, in<br>conjunction with the sector length code in the<br>header, signals the block size to be<br>transferred. For IRIS compatibility, set to l. |
| 15   | Data Address Mark Flag. This is a user-defined flag. Set to 0.                                                                                                                    |

diam'r.

•

#### 5.4.1.2 Write Sector Command

The Write Sector command transfers data blocks from memory to diskette. The block size depends on the setting of the B-flag in the command word and the sector length code in the header (see Table 5-5). For IRIS-compatibility, the B-flag should be set to 1 and the sector length should be 02 (see Section 5.4.1.3). Upon receipt of the command, the Busy status bit is set. When an ID field is encountered that has the correct track number, sector number, side, and cyclic redundancy check (CRC), a Data Request (DRQ) is generated. 11 bytes for single density or 22 bytes for double density are counted off and output is activated if the Data Register has been loaded. If the DRQ is not serviced, the operation terminates and the Lost Data bit is set. The Data Address Mark is written on diskette. It is set by bit 15 and is a user-defined flag (1 = Deleted Data Mark, 0 = Data Mark).

The data field is written and the DRQ is generated to the computer. If the DRQ is not serviced in time for continuous writing, the Lost Data bit is set and a byte of zeros is written to the diskette. The command is <u>not</u> terminated.

Writing is inhibited when the Write Protect logic is low. The command is terminated, an interrupt generated, and the Write Protect status bit is set.

The bit configuration and possible flag settings for the Write Sector command are shown in Figure 5-10 and defined in Table 5-7.



Figure 5-10. Write Sector Command Word Bit Configuration

| НМ-081-0027-В            |      | FLOPPY DISC DRIVE INTERFACE |
|--------------------------|------|-----------------------------|
| POINT 4 Data Corporation | 5-27 | MARK 3 Peripherals Manual   |

## TABLE 5-7. WRITE SECTOR COMMAND BIT CONFIGURATION

| Bit | Definition                                                                                                                                                                       |
|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0-7 | Set to 0                                                                                                                                                                         |
| 8   | Set to l                                                                                                                                                                         |
| 9   | Set to 0                                                                                                                                                                         |
| 10  | Set to l                                                                                                                                                                         |
| 11  | Set to O                                                                                                                                                                         |
| 12  | Side Select Output Flag (SSO). This flag is<br>used in address verification.<br>0 - Side 0<br>1 - Side 1                                                                         |
| 13  | Delay Flag (E).<br>0 - No delay<br>1 - 15-millisecond delay (normal)                                                                                                             |
| 14  | Sector Length Flag (B). The B-flag, in<br>conjunction with the sector size code in the<br>header, signals the block size to be<br>transferred. For IRIS compatibility, set to l. |
| 15  | Data Address Mark Flag (D). A user-defined<br>flag, it is set by this bit and recognized by<br>Read Sector command.<br>0 - Data Mark<br>1 - Deleted Data Mark                    |

### 5.4.1.3 Read Address Command

The Read Address command is used to check the sector header of the diskette. Upon receipt of the command, the Busy status bit is set. The next encountered ID field is read in from the diskette. Six data bytes of the ID field (see Figure 5-11) are assembled, transferred to the Data Register, and a Data Request (DRQ) is generated for each byte. Cyclic redundancy check (CRC) characters are transferred to the CPU but they are also checked for validity. The CRC Error bit is set if an error is detected. The track address is written to the Sector Register. When the operation is completed, an interrupt is generated and the Busy bit reset.

For the Read Address command, the bit configuration and possible flag setting for bit 13 are shown in Figure 5-12.

| BYTES | 1     | 2      | 2 3    |        | 5   | 6   |  |  |
|-------|-------|--------|--------|--------|-----|-----|--|--|
|       | TRACK | SIDE   | SECTOR | SECTOR | CRC | CRC |  |  |
|       | ADDR  | NUMBER | ADDR   | LENGTH | 1   | 2   |  |  |

Figure 5-11. ID Field





### 5.4.1.4 Read Track Command

The Read Track command is used to check the format of a diskette. Upon receipt of a Read Track command, the Busy status bit is set. The track is read starting with the first index pulse encountered and continues until the next index pulse is found. As each byte is assembled, it is transferred to the Data Register and the Data Request (DRQ) is generated for each byte. Cyclic redundancy check (CRC) is not performed. Gaps are included in the input data stream. The accumulation of bytes is synchronized to each Address Mark encountered. Upon completion the interrupt is activated.

For the Read Track command, the bit configuration and possible settings for bit 13 are shown in Figure 5-13.



## Figure 5-13. Read Track Command Word Bit Configuration

#### 5.4.1.5 Write Track Command

The Write Track command is used to format a diskette by transferring an image of the memory buffer to the diskette. Upon receipt of the command, the Busy status bit is set. Writing starts with the first index pulse encountered and continues until the next one is found. Data Request (DRQ) is activated upon receipt of the command but writing does not start until the first byte is loaded into the Data Register. If the register is not loaded when the first index pulse is encountered, the operation terminates and the Busy bit is reset, the Lost Data bit is set, and interrupt is enabled.

If a byte is not in the Data Register when it is needed, a byte of zeros is substituted. Address Marks and CRC characters are written to the diskette when certain data byte patterns (see Section 5.6.1) are detected in the outgoing data stream.

The bit configuration and possible settings for bit 13 are shown in Figure 5-14.

|               | 1            | 2      | 3   | 4 | 5      | 6     | 7  | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 |
|---------------|--------------|--------|-----|---|--------|-------|----|---|---|----|----|----|----|----|----|
| 0             | 0            | 0      | 0   | 0 | • 0    | 0     | 0  | 1 | 1 | 1  | 1  | 0  | E  | 0  | 0  |
| MUST<br>E=DEL | AY FL<br>0-N | D DELA | λ¥. |   | .AY (N | ORMAI | L) |   |   |    |    |    | ,  |    |    |
| SET TO        | 00           |        |     |   |        |       |    |   |   |    |    |    |    |    |    |

## Figure 5-14. Write Track Command Word Bit Configuration

#### 5.4.2 MEMORY ADDRESS (WORD 1)

The 16-bit memory address word is used to specify the word address of the memory buffer. The format of the memory address word is shown in Figure 5-15.

100.000

| 0 | 1 | 2 | 3 | 4 | 5 | 6  | 7    | 8    | 9   | 10 | 11 | 12 | 13 | 14 | 15 |
|---|---|---|---|---|---|----|------|------|-----|----|----|----|----|----|----|
|   |   |   |   |   |   | ME | MORY | ADDR | FSS |    |    |    |    |    |    |
|   |   |   |   |   |   |    |      |      | 200 |    |    |    |    |    |    |

Figure 5-15. Memory Address Word Bit Configuration

#### 5.4.3 TERMINATION STATUS WORD (WORD 2)

Upon completion of an operation, the controller writes the termination status into word 2 of the IOCB. The termination status provides information on the result of the operation. The information is presented in the eight least significant bits of The bit configuration depends on the type of command word 2. issued (see Figure 5-16).



## Figure 5-16. Termination Status Word Format

#### 5.4.4 FLOPPY DISC CONTROLLER INPUT CONTROL

A dedicated register in the processor serves as a pointer to the floppy disc IOCB. This register may be written into or read from by using the DOBP or DIBP instructions, respectively. The P control code is used to specify command instructions directed to the floppy disc controller (rather than the multiplexer (S) or disc controller (C)). The format of the floppy disc controller input control instruction is

DIBP ac,77

where ac is the accumulator into which the value in the floppy disc IOCB pointer is loaded.

The DIBP instruction may be used for two purposes:

- Sensing the idle state The idle state is indicated by a zero value in the accumulator following execution of a DIBP instruction to read the floppy disc IOCB pointer.
- 2. Polling the interrupt-pending bit When the floppy disc controller has completed an operation, successful or not, it sets the interrupt-pending bit in the floppy disc IOCB pointer. The interrupt-pending bit is the most significant bit in the floppy disc IOCB pointer.

#### 5.4.5 FLOPPY DISC CONTROLLER OUTPUT CONTROL

The DOBP instruction is used for activating and deactivating the Floppy Disc Controller. The format of the Floppy Disc Controller output control instruction is

DOBP ac,77

where ac is a general purpose accumulator. This instruction is used for two purposes:

 Activating the Floppy Disc Controller - The Floppy Disc Controller is activated by a DOBP instruction in which the accumulator contains the 15-bit memory address of the first IOCB word. The most significant bit must be set to 0.

#### NOTE

Location 0 is an illegal location for an IOCB starting address; 0 is defined as the idle state.

When activated, the controller goes busy and starts the operation specified in the IOCB words.

2. Deactivating the Floppy Disc Controller - After the Floppy Disc Controller completes an operation and generates an interrupt, it must be deactivated by the software. A DOBP instruction with the accumulator set to zero deactivates the controller. This resets the interrupt-pending bit and places the Floppy Disc Controller in an idle state.

FLOPPY DISC DRIVE INTERFACE MARK 3 Peripherals Manual

5-34

# 5.5 READ/WRITE HEAD POSITIONING

The Read/Write heads may be positioned by five instructions:

- 1. Seek
- 2. Restore
- 3. Step
- 4. Step In
- 5. Step Out

For the MARK 3B, only the Seek and Restore commands are required and are discussed here. Users who wish to use the Step commands, refer to Western Digital's FD 1797 Data Sheet.

When a Seek or Restore is executed, an optional verification can be performed. This option depends on the setting of the Verify flag in bit 13 of the command word (see Figure 5-4 for Restore, Figure 5-5 for Seek). If bit 13 is set to 1, the verification option is executed.

Verification begins at the end of the 15-millisecond settling time after the head is loaded against the media. The track number of the first encountered ID field is compared against the contents of the Track Register. If the track numbers correspond and the ID field Cyclic Redundancy Check (CRC) is correct, the verify operation completes. If the track numbers are not the same, the ID field, or the correct CRC are not found within five revolutions of the diskette, a SEEK error and an interrupt are generated.

The Read/Write heads are loaded when the Drive Select Signal is received.

#### 5.5.1 SEEK OPERATION

A Seek command is performed in two steps. First load the appropriate track number into the Data Register (device code = 37). Then load the Seek command into the Command Register (device code = 34). At the completion of the Seek, the Track Register (device code = 35) contains the current value of the head position and an interrupt is generated. The Seek command assumes that the initial value of the Track Register is a true reading of the Read/Write heads. If interrupts are not to be used, the completion of the Seek can be polled by testing the interrupt-pending bit as follows:

DIBP ac,77

where ac = accumulator.

Seek is completed when the interrupt-pending bit (bit 0) = 1.

| НМ-081-0027-В            |      | FLOPPY DISC DRIVE INTERFACE |
|--------------------------|------|-----------------------------|
| POINT 4 Data Corporation | 5-35 | MARK 3 Peripherals Manual   |

# 5.5.1.1 Seek Command Initiation

An example of a Seek command sequence follows:

| LDA 0,track number<br>DOA 0,37<br>LDA 1,SEEK command<br>DOA 1,34<br>DIBP 2,/7<br>SSN 2,2<br>JMP2 | <pre>;Load track no. into register 0 ;Issue track no. to Data Register ;Load SEEK command into register 1 ;Issue SEEK command to Command Register ;Read interrupt pending bit in register 2 ;Test if set ;Repeat until set</pre> |
|--------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| DIA 3,34                                                                                         | ;Read status                                                                                                                                                                                                                     |
| • • • • •                                                                                        | ;Check for error                                                                                                                                                                                                                 |

Figure 5-17 is a flowchart of Select and Seek operations.



Figure 5-17. Select and Seek Operation Flowchart

HM-081-0027-B POINT 4 Data Corporation 5-37

.

FLOPPY DISC DRIVE INTERFACE MARK 3 Peripherals Manual

.

 $\cdot, \star^{\flat}$ 

#### 5.5.1.2 Seek Error Recovery

A Seek error occurs if one of the following conditions exists:

- Wrong track number was issued
- Cyclic redundancy check is incorrect
- ID field was not found within 5 revolutions of the diskette

If a Seek error occurs (SKERR/RNF, bit 11 and/or CRCERR, bit 12 in the Status Register), restore and reissue the command. The bits are reset when the next command is received.

#### 5.5.2 RESTORE OPERATION

A Restore command causes the Read/Write heads to be positioned over track 00 (TR00- flag is set in the Status Register).

A Restore (recalibrate, return to 0) is done automatically when the RESET button on the mini-panel is pressed.

To effect a Restore without use of the RESET button, issue the following command:

DOA ac,34

where

- ac accumulator where a valid restore command has been
  loaded
  - 34 Command Register device code

à 1 - 13

5-38

# 5.6 FORMATTING DISKETTES

The Write Track command initiates the formatting process. For IRIS-compatibility, 8-inch diskettes are formatted with 15 sectors for double density and 5-1/4-inch diskettes are formatted with 8 sectors. The required block size is 512 bytes, double density, in IBM-type format. Users of other operating systems have a choice of formats and block sizes. Blocks may contain 128, 256, 512, or 1024 bytes.

Sector lengths are entered at format time via the following decimal codes:

00 = 128 bytes 01 = 256 bytes 02 = 512 bytes (normal for IRIS) 03 = 1024 bytes

Formatting is done one track at a time. When the appropriate track has been accessed by a Seek command, the Write Track command writes an image of the memory buffer. The memory address word in the IOCB points to the starting location in the memory buffer.

The command format is as follows:

| IOCB: | Write Track             |                   |
|-------|-------------------------|-------------------|
|       | Starting memory address | (word address)    |
|       | Termination word        | (set by firmware) |

#### 5.6.1 IBM-TYPE FORMATS

IBM-type formats are recommended. For IRIS users, the diskettes should be formatted into IBM-type, double-density format using 512-byte tracks.

The format for a track containing 512-byte sectors is shown in Figure 5-18.

The pattern shown in the Sector Table of Figure 5-18 should be repeated 15 times for double density, 8 times for single density, or until the controller interrupts out (approximately 598 bytes).

#### PREAMBLE TABLE (1 OF 1)

| Q                    | <u>ctal Constant (Word)</u> | <u>Octal (</u> | <u>Count (Words</u> | 2               |
|----------------------|-----------------------------|----------------|---------------------|-----------------|
| GAP IV (PRE-INDEX GA | P) 47116                    | 50             | (116-116)           |                 |
|                      | 0                           | 6              | (0-0)               |                 |
|                      | 173366                      | 1              | (366-366)           |                 |
|                      | 173374                      | 1              | (366-374)           | 374= INDEX MARK |
| GAP I (POST-INDEX GA | P) 47116                    | 31             | (116-116)           |                 |

#### SECTOR TABLE (1 OF 17 OCTAL)

|                   | <u>Octal Constant (Word)</u> | <u>Octal (</u> | Count (Words) | 2                      |
|-------------------|------------------------------|----------------|---------------|------------------------|
|                   | 0                            | 6              | (0-0)         |                        |
|                   | 172765                       | 1              | (365-365)     |                        |
|                   | 172776                       | 1              | (365-376)     | 376= ADDRESS MARK      |
|                   | 0*                           | 1              | TRACK-SIDE    |                        |
|                   | 2*                           | 1              | SECTOR-2**    |                        |
|                   | 173516                       | 1              | (367-116)     | 367= CRC***            |
| GAP II (ID GAP)   | 47116                        | 12             | (116-116)     |                        |
|                   | 47000                        | 1              | (116-0)       |                        |
|                   | 0                            | 5              | (0-0)         |                        |
|                   | 365                          | 1              | (0-365)       |                        |
|                   | 172765                       | 1              | (365-365)     |                        |
|                   | 175400                       | 1              | (373-0)       | 373= DATA ADDRESS MARK |
|                   | 0                            | 377            | (0-0)         |                        |
|                   | 367                          | 1              | (0-367)       | 367= CRC***            |
| GAP III (DATA GAP | ) 47116                      | 33             | (116-116)     |                        |

#### POSTAMBLE TABLE (1 OF 1)

| <u>Octal</u>           | Constant (Word) | <u>Octal</u> C | Count (Words) |
|------------------------|-----------------|----------------|---------------|
| GAP IV (PRE-INDEX GAP) | 47116           | 453            | (116-116)     |

\*These numbers are sector, track and side dependent. \*\*512-byte flag. \*\*\*Two CRCs inserted automatically by the 1797 chip.

#### Figure 5-18. 512-Byte Sector Format

HM-081-0027-B POINT 4 Data Corporation 5-40

FLOPPY DISC DRIVE INTERFACE MARK 3 Peripherals Manual

#### 5.6.2 NON-IBM FORMATS

IBM formats may be modified to a limited extent if the following requirements are met:

- Sector size must be 128, 256, 512, or 1024 bytes.
- Gap sizes must meet the minimum requirements shown in Table 5-8.

Note that the Index Mark is not required. For Phase Lock Loop (PLL) lock-up time, motor speed variations, etc., additional bytes must be added to the minimum gap sizes given in Table 5-8.

|                                                                       | Single           | Density          | Double Density    |                  |  |
|-----------------------------------------------------------------------|------------------|------------------|-------------------|------------------|--|
| Gap<br>Number                                                         | Size<br>(For FM) | Hexa-<br>decimal | Size<br>(For MFM) | Hexa-<br>decimal |  |
| I                                                                     | 16 bytes         | FF               | 32 bytes          | 4E               |  |
| ĪI                                                                    | ll bytes         | FF               | 22 bytes          | 4E               |  |
| *                                                                     | 6 bytes          | 00               | 12 bytes          | 00               |  |
|                                                                       |                  |                  | 3 bytes           | Al               |  |
| III                                                                   | 10 bytes         | FF               | 24 bytes          | 4E               |  |
| * *                                                                   | 4 bytes          | 00               | 8 bytes           | 00               |  |
|                                                                       | 1                |                  | 3 bytes           | Al               |  |
| * *                                                                   | 4 bytes          | 00               | 8 bytes           | 00               |  |
| IV                                                                    | 16 byte          | FF               | 16 bytes          | <b>4</b> E       |  |
|                                                                       |                  |                  |                   |                  |  |
| *Byte count must be exact.                                            |                  |                  |                   |                  |  |
| **Byte counts are minimum, but exactly 3 bytes of Al must be written. |                  |                  |                   |                  |  |

#### TABLE 5-8. GAP SIZES

HM-081-0027-C POINT 4 Data Corporation

ations.

# Section 6 ST506 (WD1002-5) INTERFACE

# 6.1 INTRODUCTION

This section describes the interface for Western Digital's WD1002-5 Disc Controller which has been integrated into the POINT 4 MARK 2 Peripheral Interface Board (PIB).

The WD1002-5 Disc Controller can interface up to three ST506-type drives and up to four floppy disc drives. POINT 4's MARK 2 uses one port to interface the ST506 (5-1/4-inch Winchester-type) disc drive and one port for the floppy disc drive.

For a detailed discussion of the WD1002-5 Controller, refer to Western Digital's Winchester/Floppy Disk Controller OEM Manual.

The WD1002-5 Disc Controller has the following features:

- ST506 disc operations
- MFM encode and decode logic
- Side select
- Address mark detection
- 8-bit bidirectional bus
- Control-block-oriented instructions
- Software control of sector addressing
- Programmable sector sizes (128, 256, 512, or 1024 bytes)
- Read/write head position verification
- ST506 disc operation handled via an I/O control block (IOCB)
- I/O instructions using device codes 50 to 57
- Data transfer performed in DMA mode (device code 77)
- Status and error reporting on completion of operation
- CRC (cyclic redundancy check) generation and detection

HM-081-0027-D

#### MARK 2 DISC/FLOPPY POINT 4 Data Corporation 6-1 MARK 2/3 Peripherals Manual

- Error detection and correction (ST506 only)
- Internal diagnostics

- 16 different stepping rates
- Drive port assignments: J7 for ST506 disc drive J8 for floppy disc drive

ALC: NO.

# 6.2 MARK 2 INTERFACE

The MARK 2 PIB interfaces the MARK 3 CPU and the WD1002-5 | peripherals via seven connectors as follows:

- J5 MARK 3 CPU 40-pin connector
- J6 4-pin power connector
- J7 ST506 disc drive 34-pin connector for control signals
- J8 Floppy disc drive 34-pin connector for control signals
- J1, J2, J3 ST506 20-pin high-speed data connectors which communicate with each disc drive. They may not be multiplexed. Refer to Western Digital's Winchester Disk/Floppy Controller Manual for more information.

Figure 6-1 illustrates WD1002-5 disc controller interface signals. Table 6-1 describes ST506 drive control signals. Table 6-2 describes ST506 drive data signals. Table 6-3 describes floppy disc drive control signals.



## Figure 6-1. WD1002-5 Disc Controller Interface Signals

\*\*\*\*\*\*\*

All A

# TABLE 6-1. ST506 DRIVE CONTROL (J7) SIGNALS

| Signal<br>Ground | Signal<br>Pin | Direc-<br>tion | Description                                                                                                                                                                                                                                                                                                                                                               |
|------------------|---------------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1                | 2             | ОИТ            | Reduce Write Current - When<br>activated with the Write Gate, a<br>lower write current is used to<br>compensate for greater bit-packing<br>density on the inner cylinders.<br>Activated when the cylinder number<br>is greater than or equal to four<br>times the contents of the write<br>precomp register. Output is valid<br>only during write and format<br>commands. |
| 3                | 4             | OUT            | Head Select 2 - Selects heads on<br>drive number 3.                                                                                                                                                                                                                                                                                                                       |
| 5                | 6             | OUT            | Write Gate - Enables write to<br>disc.                                                                                                                                                                                                                                                                                                                                    |
| 7                | 8             | IN             | Seek Complete - Signals that the<br>head of a selected drive has<br>reached the specified cylinder and<br>has stabilized. The signal is not<br>checked after a seek command and<br>overlapped seeks are allowed.                                                                                                                                                          |
| 9                | 10            | IN             | Track 000 - Indicates that the<br>read/write heads are positioned on<br>track 0. The signal is sampled<br>before each step pulse is issued.                                                                                                                                                                                                                               |
| 11               | 12            | IN             | Write Fault - Indicates that a<br>fault condition exists on the<br>selected drive. Commands are not<br>executed while this signal is<br>true.                                                                                                                                                                                                                             |
| 13               | 14            | Ουτ            | Head Select 0 - Selects read/write<br>heads on drive number l.                                                                                                                                                                                                                                                                                                            |
| 15               | 16            |                | Not connected                                                                                                                                                                                                                                                                                                                                                             |
| 17               | 18            | ΟυΤ            | Head Select 1 - Selects read/write<br>heads on drive number 2.                                                                                                                                                                                                                                                                                                            |

## TABLE 6-1. ST506 DRIVE CONTROL (J7) SIGNALS (Cont)

| Signal | Signal | Direc- | Decorintion                                                                                                                                                                                                                                                                                                                                                                                      |
|--------|--------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Ground | Pin    | tion   | Description                                                                                                                                                                                                                                                                                                                                                                                      |
| 19     | 20     | IN     | Index - Indicates the index point<br>for synchronization during<br>formatting. Also used as a<br>timeout mechanism for retries.<br>Should pulse once every rotatation<br>of the disc.                                                                                                                                                                                                            |
| 21     | 22     | IN     | Ready - Signals that a selected<br>drive is up to speed. No commands<br>are executed unless this signal is<br>true.                                                                                                                                                                                                                                                                              |
| 23     | 24     | ΟυΤ    | Step - Pulsed once for every<br>cylinder to be stepped. The<br>direction of the step is<br>determined by Direction In. The<br>step pulse period is determined by<br>the internal stepping rate<br>register during implied seek<br>operations, or explicitly during<br>seek commands. During<br>auto-restore, the step pulse<br>period is determined by the seek<br>complete time from the drive. |
| 25     | 26     | OUT    | Drive Select 1 - Selects drive<br>number 1.                                                                                                                                                                                                                                                                                                                                                      |
| 27     | 28     | OUT    | Drive Select 2 - Selects drive<br>number 2.                                                                                                                                                                                                                                                                                                                                                      |
| 29     | 30     | OUT    | Drive Select 3 - Selects drive<br>number 3.                                                                                                                                                                                                                                                                                                                                                      |
| 31     | 32     |        | Not connected                                                                                                                                                                                                                                                                                                                                                                                    |
| 33     | 34     | ОИТ    | Direction In - Specifies the<br>direction of the read/write heads<br>when Step is pulsed. When high,<br>the direction is out; when low,<br>the direction is in.                                                                                                                                                                                                                                  |

HM-081-0027-D

MARK 2 DISC/FLOPPY POINT 4 Data Corporation • 6-6 MARK 2/3 Peripherals Manual

S. 550

difference.

# TABLE 6-2. ST506 DRIVE DATA (J1 THRU J3) SIGNALS

| Signal<br>Ground | Signal<br>Pin | Direc-<br>tion | Description                                       |
|------------------|---------------|----------------|---------------------------------------------------|
|                  |               |                |                                                   |
| 2                | 1             |                | Not connected                                     |
| 4                | 3             |                | Not connected                                     |
| 8                | 7             |                | Not connected                                     |
|                  | 9             |                | Not connected                                     |
|                  | 10            |                | Not connected                                     |
| 11               |               |                | Ground                                            |
| 12               |               |                | Ground                                            |
|                  | 13            | OUT            | MFM Write Data                                    |
|                  | 14            | OUT            | MFM Write Data - Differential<br>Write Data lines |
| 15               |               |                | Ground                                            |
| 16               |               |                | Ground                                            |
|                  | 17            | IN             | MFM Read Data                                     |
|                  | 18            | IN             | MFM Read Data - Differential Read<br>Data lines   |
| 19               |               |                | Ground                                            |
| 20               |               |                | Ground                                            |

# TABLE 6-3. FLOPPY DISC DRIVE CONTROL (J8) SIGNALS

| Signal<br>Ground | Signal<br>Pin | Direc-<br>tion | Description                                                                                                                                                                                                                                                                                                                                                                                                     |
|------------------|---------------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1                | 2             |                | Not connected                                                                                                                                                                                                                                                                                                                                                                                                   |
| 3                | 4             |                | Not connected                                                                                                                                                                                                                                                                                                                                                                                                   |
| 5                | 6             | OUT            | Drive Select 0 - Selects heads on<br>drive 0.                                                                                                                                                                                                                                                                                                                                                                   |
| 7                | 8             | IN             | Index - Pulses once every disc<br>rotation to indicate the beginning<br>of a track.                                                                                                                                                                                                                                                                                                                             |
| 9                | 10            | OUT            | Drive Select l - Selects heads on<br>drive l.                                                                                                                                                                                                                                                                                                                                                                   |
| 11               | 12            | OUT            | Drive Select 2 - Selects heads on<br>drive 2.                                                                                                                                                                                                                                                                                                                                                                   |
| 13               | 14            | OUT            | Drive Select 3 - Selects heads on<br>drive 3.                                                                                                                                                                                                                                                                                                                                                                   |
| 15               | 16            | ΟυΤ            | Motor On - Controls the dc spindle<br>motor of the floppy drive. If<br>Motor On Mode (MOM) - 0<br>(selectable jumper option on<br>drive) then a 40-nanosecond delay<br>occurs. Otherwise, a one-second<br>delay occurs after Motor On and<br>before any reading or writing is<br>attempted. If the floppy drive is<br>not accessed in approximately 3<br>seconds, the motor is turned off<br>by the controller. |
| 17               | 18            | ΟυΤ            | Direction In - Selects direction<br>of read/write heads. When high,<br>direction is out; when low,<br>direction is in.                                                                                                                                                                                                                                                                                          |

diana.

### TABLE 6-3. FLOPPY DISC DRIVE CONTROL (J8) SIGNALS (Cont)

| Signal<br>Ground | Signal<br>Pin | Direc-<br>tion | Description                                                                                                                                                                                                                                                                                                                                                                                               |
|------------------|---------------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 19               | 20            | OUT            | <pre>Step - Pulsed once for each<br/>cylinder to be stepped.<br/>Determines the direction of the<br/>step. The internal floppy disc<br/>stepping rate register determines<br/>the step pulse period during the<br/>following operations:<br/>Implied seek<br/>Auto restore<br/>Seek and restore commands<br/>The stepping-rate period is<br/>limited to 8 microseconds minimum<br/>during arguments</pre> |
| 21               | 22            | ОUТ            | during any restore operation.<br>Write Data - Transmits write data.<br>Enabled when Write Gate is<br>enabled.                                                                                                                                                                                                                                                                                             |
| 23               | 24            | ΟυͲ            | Write Gate - Enables disc write<br>circuitry.                                                                                                                                                                                                                                                                                                                                                             |
| 25               | 26            | IN             | Track 000 - Indicates that the<br>read/write heads are positioned on<br>the outermost cylinder. This line<br>is sampled before each step is<br>issued.                                                                                                                                                                                                                                                    |
| 27               | 28            | IN             | Write Protect - Indicates a write-<br>protected disc is in the drive.                                                                                                                                                                                                                                                                                                                                     |
| 29               | 30            | IN             | Read Data - Transmits clock and<br>data to controller.                                                                                                                                                                                                                                                                                                                                                    |
| 31               | 32            | ОUТ            | Side Select - Selects side of<br>floppy disc to be written or read.                                                                                                                                                                                                                                                                                                                                       |

HM-081-0027-D

i.

## 6.3 PROGRAMMED INPUT/OUTPUT

Two modes of operation are standard with the ST506/Floppy Disc Controller: programmed I/O and DMA (Direct Memory Access).

Three command formats are used to communicate with the controller via eight registers in the following format:

DIA ac,xx (Read from ST506/Floppy Controller register) DOA ac,xx (Write to ST506/Floppy Controller register) DOBC ac,77 (Initiate data transfer in DMA mode) where ac - accumulator xx - device code

The device codes used by the ST506/Floppy Disc Controller range from 50 to 57:

| Device<br><u>Code</u> | DOA<br>Instruction       | DIA<br><u>Instruction</u> |
|-----------------------|--------------------------|---------------------------|
| 50                    | Data Register            | Data Register             |
| 51                    | Write Precomp Register   | Error Register            |
| 52                    | Sector Count Register    | Sector Count Register     |
| 53                    | Sector Number Register   | Sector Number Register    |
| 54                    | Cylinder Low Register    | Cylinder Low Register     |
| 55                    | Cylinder High Register   | Cylinder High Register    |
| 56                    | Size/Drive/Head Register | Size/Drive/Head Register  |
| 57                    | Command Register         | Status Register           |

The first digit (5) in the device code selects the WD1002-5 controller board.

#### NOTE

For normal read/write operations, the following commands are used:

DIA ac,51 (Get error register if there is an error)

DOA ac,56 (Select drive)

DOBC ac,77 (Start transfer)

All other commands are provided for diagnostic purposes only.

The following subsections provide information on ST506/Floppy Disc programmed I/O and the use of the registers.

HM-081-0027-D POINT 4 Data Corporation 6-10

#### 6.3.1 DATA REGISTER

The Data Register is an 8-bit holding register that contains the next byte of data to be written to or read from the internal sector buffer. The sector buffer contains data to be read during a Read Sector command. When a Write Sector or Format Track command has been issued, the sector buffer awaits the data to be written. All data transfers are handled by firmware in DMA mode.

The Data Register may not be written to or read from except in the context of a valid command. The syntax for a read or format command is

DOA ac,50

The syntax for a read command is

DIA ac,50

where ac - the accumulator

#### **6.3.2 WRITE PRECOMP REGISTER**

The Write Precompensation and the Error Registers (see Section 6.3.3) are physically the same 8-bit register. During a write or format command, the Write Precomp Register contains the cylinder address where the lower write current is to be turned on (see Table 6-1) and write precompensation is to start.

The lower write current is activated when the cylinder being addressed is four times greater or equal to the value contained in this register. For example, if write precompensation is required for cylinder number 128 (80 hex) or higher, the register must be loaded with the value of 32 (20 hex).

Write precompensation is not used for floppy discs.

The register can only be written to; it cannot be read from. The command format is

DOA ac,51

where ac - the accumulator

HM-081-0027-D

MARK 2 DISC/FLOPPY POINT 4 Data Corporation 6-11 MARK 2/3 Peripherals Manual

<u>\_\_\_\_\_</u>

#### 6.3.3 ERROR REGISTER

The 8-bit Error Register contains fault information generated by the last command executed. The information in the register is valid only if the error bit in the Status Register is set, except when a Test command was issued (see Section 6.3.8.1). If the last command executed was a Test command, the error bit in the Status Register is not set but a binary diagnostic error code is loaded into the Error Register. This code indicates which device on the WD1002-5 board was in error as shown in Table 6-4.

| Code | Description                 |
|------|-----------------------------|
| 5    | WD1015 Error                |
| 4    | WD1014 Error                |
| 3    | Sector Buffer Error         |
| 2    | WD1010 Error                |
| 1    | WD2797 Error                |
| 0    | OK - WD1002-5 is functional |

#### TABLE 6-4. DIAGNOSTIC ERROR CODES

HM-081-0027-D

The Error Register can be read from; it cannot be written to. The command format is

DIA ac,51

where ac - the accumulator

The bit configuration of the Error Register is shown in Figure 6-2; Table 6-5 defines each bit in the accumulator.



# **Figure 6-2.** Error Register Bit Configuration

HM-081-0027-D

•

#### TABLE 6-5. ERROR REGISTER BIT DEFINITIONS

| Bits | Name             | Function                                                                                                                                                                                                                                                                                                                                                                                |
|------|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8    | BAD BLOCK        | Bad Block Detect - When set to 1,<br>indicates that a bad block mark was<br>detected in the specified ID field. If<br>a write sector command was issued, the<br>Write gate may be pulsed but the sector<br>will not be written. If a read sector<br>command was issued, the data field will<br>not be read. The bad block may not be<br>detected if there is a flaw in the ID<br>field. |
| 9    | UERR             | Uncorrectable Error - When set to 1,<br>indicates that an ECC or CRC error was<br>encountered in a data field during a<br>write sector command and that the error<br>cannot be corrected.                                                                                                                                                                                               |
| 10   | CRC ERR          | CRC Error - When set to l indicates that<br>a CRC error has been detected in the ID<br>field.                                                                                                                                                                                                                                                                                           |
| 11   | ID ERROR         | ID Not Found - When set to 1, indicates<br>that a specified ID field (cylinder,<br>head, sector number, or sector size) was<br>not found after all retries were<br>executed.                                                                                                                                                                                                            |
| 12   |                  | Reserved - Must be set to zero.                                                                                                                                                                                                                                                                                                                                                         |
| 13   | ABORT            | Aborted Command - When set to 1,<br>indicates that a valid command cannot be<br>executed because of drive status<br>information. For example, the drive is<br>not ready, seek operation was not<br>issued, or a read fault exists.                                                                                                                                                      |
| 14   | TROOO ERR        | Track 0 Error - When set to 1 during a<br>restore command, indicates that the<br>track 000 line was not asserted by the<br>drive after all the stepping pulses have<br>been issued.                                                                                                                                                                                                     |
| 15   | DAM NOT<br>FOUND | Data Address Mark - When set to l,<br>indicates that the address mark was not<br>found within 16 bytes of the ID field.                                                                                                                                                                                                                                                                 |

HM-081-0027-D

ABHRA. WRITE

#### 6.3.4 SECTOR COUNT REGISTER

The 8-bit Sector Count Register is used by the Read Sector, Write Sector, and Format commands to implement multiple sector handling with one command. A value of zero implies a transfer of 256 sectors regardless of size. During read and write multiple sector commands, the sector count is decremented. The sector count is then incremented after each sector transfer to or from the buffer.

During a format command, the register is loaded with the total number of sectors to be formatted. It is then decremented as each sector is formatted until it reaches zero. During format operations, sector numbers are specified using interleaved tables loaded in the sector buffer.

The command format for reading the register is

DIA ac, 52

The command format for writing to the register is

DOA ac, 52

where ac - the accumulator

#### 6.3.5 SECTOR NUMBER REGISTER

The 8-bit Sector Number Register is loaded with the specified sector number before a read or write command.

The command format for reading the register is

DIA ac,53

For writing to the register the command format is

DOA ac,53

where ac - the accumulator

#### 6.3.6 CYLINDER HIGH AND LOW REGISTERS

The Cylinder High and Cylinder Low Registers are 8-bit accumulators. Together they provide a 16-bit register to hold the cylinder number specified for a seek, read, or write command. The two least significant bits (LSB) form the two most significant bits (MSB) of the cylinder number (see Figure 6-3).

The command format for reading the contents of the Cylinder High Register is

DIA ac,55

For writing to the Cylinder High Register, the command format is DOA ac,55

The command format for reading the Cylinder Low Register is

DIA ac,54

For writing to the Cylinder Low Register, the command format is DOA ac,54

where ac - the accumulator

#### CYLINDER HIGH REGISTER

#### CYLINDER LOW REGISTER



081-96

#### Figure 6-3. High-Low Cylinder Registers and Cylinder Number

HM-081-0027-D MARK 2 DISC/FLOPPY POINT 4 Data Corporation 6-16 MARK 2/3 Peripherals Manual

#### 6.3.7 SELECT/DRIVE/HEAD REGISTER

The 8-bit Select/Drive/Head (SDH) Register contains the ECC/CRC sector size, drive, select, and head select bits. Figure 6-4 shows the bit configuration.



Figure 6-4. SDH Register Bit Configuration

#### 6.3.8 COMMAND REGISTER

The Command and Status Registers are physically the same 8-bit register. As a Command Register, it holds the command currently being executed. A command is input with a DOA instruction. When execution of the command is completed, or if a halt occurs because of an error condition, status information may be retrieved with a DIA instruction (see Section 6.3.9).

Negatifi S

Three instructions are available to software:

- 1. Test
- 2. Restore
- 3. Seek

I

The bit configuration for each command is discussed in Sections 6.3.8.1 through 6.3.8.3. The Command Register should not be loaded when the device is busy.

The command format is

DOA ac,57

where ac - the accumulator

#### 6.3.8.1 Test Command Bit Configuration

The Test command is used to isolate faults in the WD 1002-5 board logic by running internal diagnostics. Faults are reported in the Error Register (see Section 6.3.3). The Command Register bit configuration for a Test command is shown in Figure 6-5.





HM-081-0027-D POINT 4 Data Corporation

#### 6.3.8.2 Restore Command Bit Configuration

The Restore command is used to calibrate the position of the read/write head by stepping the head outward until the TR000 line is true.

When a Restore command is received, the Busy bit in the Status Register is set. The Cylinder High and Cylinder Low Registers are cleared. For ST506 operation, the actual stepping rate is determined by the Seek Complete period.

The Restore command bit configuration is shown in Figure 6-6.



| BITS (12-15)<br>R3-R0 | ST506               |      |
|-----------------------|---------------------|------|
| 0000                  | APPROX. 35 MICROSEC | ONDS |
| 0001                  | 0.5 MILLISECONDS    |      |
| 0010                  | 1.0                 |      |
| 0011                  | 1.5                 |      |
| 0100                  | 2.0                 |      |
| 0101                  | 2.5                 |      |
| 0110                  | 3.0                 |      |
| 0111                  | 3.5                 |      |
| 1000                  | 4.0                 |      |
| 1001                  | 4.5                 |      |
| 1010                  | 5.0                 |      |
| 1011                  | 5.5                 |      |
| 1100                  | 6.0                 |      |
| 1101                  | 6.5                 |      |
| 1110                  | 7.0                 |      |
| 1111                  | 7.5 MILLISECONDS    |      |

081-99/081-100

Figure 6-6. Restore Command Bit Configuration

#### 6.3.8.3 Seek Command Bit Configuration

The Seek command positions the read/write head at a specified cylinder. It is primarily used to start two or more concurrent seeks on drives that support buffered stepping. The Seek Complete Line is not sampled after a Seek command to make multiple seek operations possible.

The bit configuration for a Seek command is shown in Figure 6-7.



| BITS (12-15)<br>R3-R0 | 51506          |            |
|-----------------------|----------------|------------|
| 0000                  | APPROX. 35 MI  | CROSECONDS |
| 0001                  | 0.5 MILLISECO  | NDS        |
| <b>001</b> 0          | 1.0            |            |
| 0011                  | 1.5            |            |
| 0100                  | 2.0            |            |
| 0101                  | 2.5            |            |
| 0110                  | 3.0            |            |
| 0111                  | 3.5            |            |
| 1000                  | 4.0            |            |
| 1001                  | 4.5            |            |
| 1010                  | 5.0            |            |
| 1011                  | 5.5            |            |
| 1100                  | 6.0            |            |
| 1101                  | 6.5 L          |            |
| 1110                  | 7.0            |            |
| 1111                  | 7.5 MILLISECON | NDS        |
|                       |                |            |

CTEUC

081-99/081-100

DITC (12 15)

Figure 6-7. Seek Command Bit Configuration

HM-081-0027-D POINT 4 Data Corporation

#### **6.3.9 STATUS REGISTER**

The 8-bit Status Register contains information on the status of the drives after a command has been executed. It uses the same address as the Command Register (see Section 6.3.8). If the Busy bit is set, no other bits in the register are valid. The INTRO line is reset when the Status Register is accessed. Status information is retrieved with a DIA instruction in the following format:

DIA ac,57

where ac - the accumulator

The bit configuration for the Status Register is shown in Figure 6-8. Table 6-6 defines the function of each bit.



#### Figure 6-8. Status Register Bit Configuration

HM-081-0027-D POINT 4 Data Corporation 6-21 MARK 2/3 Peripherals Manual

### TABLE 6-6. STATUS REGISTER BIT FUNCTIONS

| Bits | Name          | Function                                                                                                                                                                                                                                                                                                                                            |
|------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8    | BUSY          | Busy - When set to 1, a command is<br>being executed. No other bits in<br>this or any other register are valid<br>when this bit is set.                                                                                                                                                                                                             |
| 9    | READY         | Drive Ready - When set to 1,<br>indicates that the specified drive<br>is ready. No command is executed<br>unless this bit is set.                                                                                                                                                                                                                   |
| 12   | WRITE FAULT   | Write Fault or Write Protect - When<br>set to 1, no command is executed.<br>If a write-protected disc is sensed,<br>the write command is aborted.                                                                                                                                                                                                   |
| 11   | SEEK COMPLETE | Seek Complete - When set to 1,<br>indicates that a seek operation is<br>completed. For floppy operations,<br>the bit is set when the SDH Register<br>is loaded.                                                                                                                                                                                     |
| 12   | DRQ           | Data Request - When set to 1,<br>indicates that the Sector Buffer is<br>ready to accept data or contains<br>data to be read. This bit is reset<br>when the Sector Buffer has been<br>fully read from or written to.                                                                                                                                 |
| 13   | CORR DATA     | Corrected Data - When set to 1,<br>indicates that an error correction<br>has been successfully completed on<br>one or more data fields when in<br>multiple mode or on the data field<br>just read from the ST506 disc.<br>If an uncorrectable error occurred,<br>the command is aborted and the<br>appropriate bit is set in the Error<br>Register. |
| 14   |               | Not used.                                                                                                                                                                                                                                                                                                                                           |
| 15   | ERR           | Error Condition - When set to 1,<br>indicates that one or more bits are<br>set in the Error Register. Reset<br>when a new command is issued.                                                                                                                                                                                                        |

HM-081-0027-DMARK 2 DISC/FLOPPYPOINT 4 Data Corporation6-22MARK 2/3 Peripherals Manual

No. state

# 6.4 INPUT/OUTPUT CONTROL BLOCK (IOCB)

The input/output control block (IOCB) contains commands to be performed via direct memory access (DMA). The IOCB for the ST506/Floppy Disc Controller consists of five words located anywhere in main memory. It is used to indicate the operational mode. The five words are set up by the software before an operation begins (see also Section 6.3). The format of the ST506 Disc IOCB is shown in Figure 6-9.



Figure 6-9. ST506 Disc IOCB Format

#### 6.4.1 OPCODE/WRITE PRECOMP WORD (WORD 0)

Word zero of the IOCB is divided into two bytes. The first byte (bits 0-7) contains the opcode for five possible data transfer commands:

- Read Sector
- Readlong
- Write Sector
- Writelong
- Format Track

These commands use an implicit stepping rate for the read/write head positioning which is determined by the stepping rate specified for the last Restore or Seek command executed.

The second byte (bits 8-15) contains the contents of the Write Precomp Register which defines the cylinder address where the lower write current is to be turned on (see Section 6.3.2).

HM-081-0027-DMARK 2 DISC/FLOPPYPOINT 4 Data Corporation6-23MARK 2/3 Peripherals Manual

#### 6.4.1.1 Read Sector Command

The Read Sector command is used to read a sector of data from disc. The Status and Error Registers are updated for every block of data transferred.

40.005

Provided the ECC is enabled, ECC bytes are recomputed. After the buffer is full, the recorded ECC bytes are compared to the check bytes and syndrome bytes are generated. If the syndrome is nonzero, errors have occurred.

Error correction is invoked if two consecutive syndromes match; otherwise up to eight retries are attempted. If the data is correctable, the correction is made and the data is read into memory. If eight retries are unsuccessful, an error status is sent to the CPU, Multiple Sector Read commands are modified to single sector commands and are issued a corresponding number of times.

The Read Sector command bit configuration is shown in Figure 6-10.



#### Figure 6-10. Read Sector/Readlong Command Bit Configuration

HM-081-0027-D POINT 4 Data Corporation

#### 6.4.1.2 Readlong Command

The Readlong command is similar to the Read Sector command except that the generation of the syndrome bytes is inhibited. The four recorded check bytes are copied from the disc and read into memory. The Readlong command can only be used in DMA mode (bit 4=1) which transfers an entire buffer of data at a time. Refer to Figure 6-10 for the appropriate bit settings.

#### 6.4.1.3 Write Sector Command

The Write Sector command is used to write a sector of data from memory to disc. Upon receipt of the command, the DRQ bit is set in the Status Register until the entire sector length has been written into the buffer.

The bit configuration for a Write Sector command is shown in Figure 6-11.



#### Figure 6-11. Write Sector/Writelong Command Bit Configuration

| HM-081-0027-D            |      | MARK 2 DISC/FLOPPY          |
|--------------------------|------|-----------------------------|
| POINT 4 Data Corporation | 6-25 | MARK 2/3 Peripherals Manual |

#### 6.4.1.4 Writelong Command

The Writelong command functions like the Write Sector command except that ECC operations are inhibited. The four check bytes are passed unaltered to the buffer and are subsequently written to disc at the end of the data.

Refer to Figure 6-11 for the appropriate Writelong command bit configuration.

#### 6.4.1.5 Format Track Command

The Format Track command is used for initializing the ID and data fields on a particular disc. The DRQ bit in the Status Register is set until the interleave table is written to the buffer. The number of bytes transferred to the buffer must correspond to the current sector size.

When the buffer has been completely filled, the specified number of sectors are written to disc and the DRQ bit is reset. The data field is written with 00 for hard disc or E5 (Hex) for floppies. ECC or CRC bytes are automatically computed and written to disc.

Once the index is found, a number of ID and data fields are written to disc. As each sector is written, the Sector Count Register is decremented. Consequently, it must be updated before each format operation.

The Format Track command bit configuration is shown in Figure 6-12.



Figure 6-12. Format Track Command Bit Configuration

HM-081-0027-D POINT 4 Data Corporation 16.89%5.

#### 6.4.4 MEMORY ADDRESS WORD (WORD 3)

Word 3 is used to specify the word address of the memory buffer. The format of the memory address word is shown in Figure 6-15.





#### 6.4.5 TERMINATION STATUS WORD (WORD 4)

Upon completion of an operation, the controller writes the termination status into word 4 of the IOCB. The result of the operation is represented in the lower byte of word 4 and the most significant bit is set when an operation has been completed (see Figure 6-16).



#### Figure 6-16. Termination Status Bit Configuration (Word 4 of IOCB)

#### 6.4.2 SECTOR NUMBER AND COUNT WORD (WORD 1)

Word 1 of the IOCB contains the sector number and sector count. The first byte (bits 0-7) is loaded with the number of the sector being transferred. The second byte (bits 8-15) contains the sector count for a format operation or zeros for single block transfers.

Figure 6-13 shows the bit configuration for word 1 of the IOCB.





#### 6.4.3 CYLINDER NUMBER WORD (WORD 2)

Word 2 of the IOCB contains the cylinder number as represented by the Cylinder High and Cylinder Low Registers.

Figure 6-14 shows the bit configuration for word 2 of the IOCB.





# APPENDICES

# Appendix A **ASCII CODES**

TABLE A-1. ASCII CODES IN OCTAL

| $\begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | r   |               |                   | J   |       | T     | <u>  </u> |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|---------------|-------------------|-----|-------|-------|-----------|
| $\begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 000 | NUL           | <ctrl-@></ctrl-@> | 040 | BLANK | 100 @ | 140 `     |
| 002DIACITRL-C>043#103C144d003ETXCTRL-C>043#103C143c004EOTCTRL-D>044\$104D144d005ENQCTRL-E>045\$105E145e006ACKCTRL-F>046 $\&$ 106F146f007BELCTRL-G>047'107G147g010BKSPCTRL-H>050(110H150h011HTABCTRL-I>051)111I151i012LF <ctrl-j>052*112J152j013VTAB<ctrl-k>053+113K153k014FF<ctrl-n>054,114L1541015CR<ctrl-n>054,114L1541015CR<ctrl-n>056.116N156n016SO<ctrl-n>056.1170157o020DLE<ctrl-r>0622122R162r023XOFF<ctrl-n>0644124T164t024AUXOFF<ctrl-v>066126V166v027ETB<ctrl-n>0677127<td>001</td><td>SOH</td><td><ctrl-a></ctrl-a></td><td>041</td><td>1</td><td>101 A</td><td>141 a</td></ctrl-n></ctrl-v></ctrl-n></ctrl-r></ctrl-n></ctrl-n></ctrl-n></ctrl-n></ctrl-k></ctrl-j>                                                                                                                                                                                                                                                                                                                                                                                                                                    | 001 | SOH           | <ctrl-a></ctrl-a> | 041 | 1     | 101 A | 141 a     |
| $\begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 002 | STX           | <ctrl-b></ctrl-b> | 042 | "     | 102 B | 142 b     |
| $\begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 003 | ETX           | <ctrl-c></ctrl-c> | 043 | #     | 103 C | 143 c     |
| $\begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 004 | EOT           | <ctrl-d></ctrl-d> | 044 | \$    | 104 D | 144 d     |
| $\begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 005 | ENQ           | <ctrl-e></ctrl-e> | 045 | ક     | 105 E | 145 e     |
| $\begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 006 | ACK           | <ctrl-f></ctrl-f> | 046 | &     | 106 F | 146 f     |
| $\begin{array}{c c c c c c c c c c c c c c c c c c c $                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 007 | BEL           | <ctrl-g></ctrl-g> | 047 | 1     | 107 G | 147 g     |
| $\begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 010 | BKSP          | <ctrl-h></ctrl-h> | 050 | (     | 110 н |           |
| 013VTAB $\langle CTRL-K \rangle$ 053+113K153k014FF $\langle CTRL-L \rangle$ 054,114L1541015CR $\langle CTRL-M \rangle$ 055-115M155m016SO $\langle CTRL-N \rangle$ 056.116N156n017SI $\langle CTRL-Q \rangle$ 057/117O157o020DLE $\langle CTRL-Q \rangle$ 0611121Q161q022AUXON $\langle CTRL-R \rangle$ 0622122R162r023XOFF $\langle CTRL-T \rangle$ 0644124T164t025NAK $\langle CTRL-V \rangle$ 0655125U165u026SYN $\langle CTRL-X \rangle$ 0677127W167w030CAN $\langle CTRL-X \rangle$ 0708130X170x031ENDMD $\langle CTRL-Z \rangle$ 072:132Z172Z033ESC $\langle CTRL-I \rangle$ 0741341741035GSEP $\langle CTRL-I \rangle$ 075=13511753036RSEP $\langle CTRL-I \rangle$ 0761361767176176                                                                                                                                                                                                                                                                                                                                                                                                                         | 011 | HTAB          | <ctrl-i></ctrl-i> | 051 | )     | 111 I | 151 i     |
| $\begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 012 | $\mathbf{LF}$ | <ctrl-j></ctrl-j> | 052 | *     | 112 J | 152 j     |
| $\begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 013 | VTAB          | <ctrl-k></ctrl-k> | 053 | +     | 113 K | 153 k     |
| $\begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 014 | FF            | <ctrl-l></ctrl-l> | 054 | ,     | 114 L | 154 1     |
| $017$ SI $\langle CTRL-O \rangle$ $057$ $/$ $117$ $0$ $157$ $o$ $020$ DLE $\langle CTRL-P \rangle$ $060$ $0$ $120$ P $160$ p $021$ XON $\langle CTRL-Q \rangle$ $061$ $1$ $121$ Q $161$ q $022$ AUXON $\langle CTRL-R \rangle$ $062$ $2$ $122$ R $162$ r $023$ XOFF $\langle CTRL-R \rangle$ $062$ $2$ $123$ S $163$ s $024$ AUXOFF $\langle CTRL-T \rangle$ $064$ $4$ $124$ T $164$ t $025$ NAK $\langle CTRL-U \rangle$ $065$ $5$ $125$ U $165$ u $026$ SYN $\langle CTRL-V \rangle$ $066$ $6$ $126$ V $166$ v $027$ ETB $\langle CTRL-W \rangle$ $067$ $7$ $127$ W $167$ W $030$ CAN $\langle CTRL-X \rangle$ $070$ 8 $130$ X $170$ x $031$ ENDMD $\langle CTRL-Z \rangle$ $072$ : $132$ $2$ $172$ $2$ $033$ ESC $\langle CTRL-I \rangle$ $073$ ; $133$ $173$ $\{$ $034$ F <sep< td=""><math>CTRL-1 \rangle</math><math>075</math><math>135</math><math>175</math><math>3</math><math>036</math>R<sep< td=""><math>\langle CTRL-^2 \rangle</math><math>076</math><math>136</math><math>176</math><math>76</math></sep<></sep<>                                                                                  | 015 | CR            | <ctrl-m></ctrl-m> | 055 | -     | 115 M | 155 m     |
| 020       DLE <ctrl-p>       060       0       120       P       160       p         021       XON       <ctrl-q>       061       1       121       Q       161       q         022       AUXON       <ctrl-r>       062       2       122       R       162       r         023       XOFF       <ctrl-s>       063       3       123       S       163       s         024       AUXOFF       <ctrl-t>       064       4       124       T       164       t         025       NAK       <ctrl-u>       065       5       125       U       165       u         026       SYN       <ctrl-v>       066       6       126       V       166       v         027       ETB       <ctrl-w>       067       7       127       W       167       w         030       CAN       <ctrl-x>       070       8       130       X       170       x         031       ENDMD       <ctrl-y>       071       9       131       Y       171       y         032       SUB       <ctrl-z>       072       :       132</ctrl-z></ctrl-y></ctrl-x></ctrl-w></ctrl-v></ctrl-u></ctrl-t></ctrl-s></ctrl-r></ctrl-q></ctrl-p>        | 016 | SO            | <ctrl-n></ctrl-n> | 056 | •     | 116 N | 156 n     |
| 021XON $\langle CTRL-Q \rangle$ 0611121Q161q022AUXON $\langle CTRL-R \rangle$ 0622122R162r023XOFF $\langle CTRL-S \rangle$ 0633123S163s024AUXOFF $\langle CTRL-T \rangle$ 0644124T164t025NAK $\langle CTRL-U \rangle$ 0655125U165u026SYN $\langle CTRL-V \rangle$ 0666126V166v027ETB $\langle CTRL-W \rangle$ 0677127W167w030CAN $\langle CTRL-X \rangle$ 0708130X170x031ENDMD $\langle CTRL-Z \rangle$ 072:132Z172z033ESC $\langle CTRL-I \rangle$ 073;133I173{034FSEP $\langle CTRL-I \rangle$ 075=135175}036RSEP $\langle CTRL-^{2} \rangle$ 076136176~                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 017 | SI            | <ctrl-o></ctrl-o> | 057 | 1     | 117 0 | 157 o     |
| 021XON $\langle CTRL-Q \rangle$ 0611121Q161q022AUXON $\langle CTRL-R \rangle$ 0622122R162r023XOFF $\langle CTRL-S \rangle$ 0633123S163s024AUXOFF $\langle CTRL-T \rangle$ 0644124T164t025NAK $\langle CTRL-U \rangle$ 0655125U165u026SYN $\langle CTRL-V \rangle$ 0666126V166v027ETB $\langle CTRL-W \rangle$ 0677127W167w030CAN $\langle CTRL-X \rangle$ 0708130X170x031ENDMD $\langle CTRL-Z \rangle$ 072:132Z172z033ESC $\langle CTRL-I \rangle$ 073;133I173{034FSEP $\langle CTRL-I \rangle$ 075=135175}036RSEP $\langle CTRL-^{2} \rangle$ 076136176~                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |     |               |                   |     |       |       |           |
| 021XON $<$ CTRL-Q>0611121Q161q022AUXON $<$ CTRL-R>0622122R162r023XOFF $<$ CTRL-S>0633123S163s024AUXOFF $<$ CTRL-T>0644124T164t025NAK $<$ CTRL-U>0655125U165u026SYN $<$ CTRL-V>0666126V166v027ETB $<$ CTRL-W>0677127W167w030CAN $<$ CTRL-X>0708130X170x031ENDMD $<$ CTRL-Z>072:132Z172z033ESC $<$ CTRL-I>073;133I173{034F <sep< td=""><math>&lt;</math>CTRL-I&gt;075=1351175}036R<sep< td=""><math>&lt;</math>CTRL-<math>^&gt;</math>076136176<math>&lt;</math></sep<></sep<>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 020 | DLE           | <ctrl-p></ctrl-p> | 060 | 0     | 120 P | 160 p     |
| 023       XOFF <ctrl-s>       063       3       123       S       163       s         024       AUXOFF       <ctrl-t>       064       4       124       T       164       t         025       NAK       <ctrl-u>       065       5       125       U       165       u         026       SYN       <ctrl-v>       066       6       126       V       166       v         027       ETB       <ctrl-w>       067       7       127       W       167       w         030       CAN       <ctrl-x>       070       8       130       X       170       x         031       ENDMD       <ctrl-z>       071       9       131       Y       171       y         032       SUB       <ctrl-z>       072       :       132       Z       172       z         033       ESC       <ctrl-i>       073       ;       133       I       173       {{         034       F       SEP       <ctrl-i>       075       =       135       1       175       {{         036       R       SEP       <ctrl-^>       076       13</ctrl-^></ctrl-i></ctrl-i></ctrl-z></ctrl-z></ctrl-x></ctrl-w></ctrl-v></ctrl-u></ctrl-t></ctrl-s> | 021 | XON           | <ctrl-q></ctrl-q> | 061 | 1     | 121 Q | 161 q     |
| 024       AUXOFF <ctrl-t>       064       4       124       T       164       t         025       NAK       <ctrl-u>       065       5       125       U       165       u         026       SYN       <ctrl-v>       066       6       126       V       166       v         027       ETB       <ctrl-w>       067       7       127       W       167       w         030       CAN       <ctrl-x>       070       8       130       X       170       x         031       ENDMD       <ctrl-z>       071       9       131       Y       171       y         032       SUB       <ctrl-z>       072       :       132       Z       172       z         033       ESC       <ctrl-i>       073       ;       133       I       173       {         034       F       SEP       <ctrl-i>       075       =       135       175       }         036       R       SEP       <ctrl-^>       076       136       176       ~</ctrl-^></ctrl-i></ctrl-i></ctrl-z></ctrl-z></ctrl-x></ctrl-w></ctrl-v></ctrl-u></ctrl-t>                                                                                             | 022 | AUXON         | <ctrl-r></ctrl-r> | 062 | 2     | 122 R | 162 r     |
| 025       NAK <ctrl-u>       065       5       125       U       165       u         026       SYN       <ctrl-v>       066       6       126       V       166       v         027       ETB       <ctrl-w>       067       7       127       W       167       w         030       CAN       <ctrl-x>       070       8       130       X       170       x         031       ENDMD       <ctrl-y>       071       9       131       Y       171       y         032       SUB       <ctrl-z>       072       :       132       Z       172       z         033       ESC       <ctrl-[>       073       ;       133       [       173       {         034       F       SEP       <ctrl-1>       075       =       135       1       175       }         035       G       SEP       <ctrl-1>       075       =       135       1       176       ~         036       R       SEP       <ctrl-^>       076       136       176       ~</ctrl-^></ctrl-1></ctrl-1></ctrl-[></ctrl-z></ctrl-y></ctrl-x></ctrl-w></ctrl-v></ctrl-u>                                                                                | 023 | XOFF          | <ctrl-s></ctrl-s> | 063 | 3     | 123 S | 163 s     |
| 026       SYN <ctrl-v>       066       6       126       V       166       v         027       ETB       <ctrl-w>       067       7       127       W       167       w         030       CAN       <ctrl-x>       070       8       130       X       170       x         031       ENDMD       <ctrl-y>       071       9       131       Y       171       y         032       SUB       <ctrl-z>       072       :       132       Z       172       z         033       ESC       <ctrl-[>       073       ;       133       [       173       {         034       F       SEP       <ctrl-\>       074       134       174       1         035       G       SEP       <ctrl-]>       075       =       135       175       }         036       R       SEP       <ctrl-^>       076       136       176       ~</ctrl-^></ctrl-]></ctrl-\></ctrl-[></ctrl-z></ctrl-y></ctrl-x></ctrl-w></ctrl-v>                                                                                                                                                                                                            | 024 | AUXOFF        | <ctrl-t></ctrl-t> | 064 |       | 124 T | 164 t     |
| 027       ETB <ctrl-w>       067       7       127       W       167       w         030       CAN       <ctrl-x>       070       8       130       X       170       x         031       ENDMD       <ctrl-y>       071       9       131       Y       171       y         032       SUB       <ctrl-z>       072       :       132       Z       172       z         033       ESC       <ctrl-[>       073       ;       133       [       173       {         034       F       SEP       <ctrl-\>       074        134       174       1         035       G       SEP       <ctrl-]>       075       =       135       175       }         036       R       SEP       <ctrl-^>       076       136       176       ~</ctrl-^></ctrl-]></ctrl-\></ctrl-[></ctrl-z></ctrl-y></ctrl-x></ctrl-w>                                                                                                                                                                                                                                                                                                               | 025 | NAK           | <ctrl-u></ctrl-u> | 065 |       | 125 U | 165 u     |
| 030       CAN <ctrl-x>       070       8       130       X       170       x         031       ENDMD       <ctrl-y>       071       9       131       Y       171       y         032       SUB       <ctrl-z>       072       :       132       Z       172       z         033       ESC       <ctrl-[>       073       ;       133       [       173       {         034       F       SEP       <ctrl-\>       074        134       \       174                 035       G       SEP       <ctrl-]>       075       =       135       ]       175       }         036       R       SEP       <ctrl-^>       076       136       176       ~</ctrl-^></ctrl-]></ctrl-\></ctrl-[></ctrl-z></ctrl-y></ctrl-x>                                                                                                                                                                                                                                                                                                                                                                                                   | 026 | SYN           | <ctrl-v></ctrl-v> | 066 |       |       | 166 v     |
| 031       ENDMD <ctrl-y>       071       9       131       Y       171       y         032       SUB       <ctrl-z>       072       :       132       Z       172       z         033       ESC       <ctrl-[>       073       ;       133       [       173       {         034       F       SEP       <ctrl-\>       074       134       \       174                 035       G       SEP       <ctrl-]>       075       =       135       ]       175       }         036       R       SEP       <ctrl-^>       076       &gt;       136       176       ~</ctrl-^></ctrl-]></ctrl-\></ctrl-[></ctrl-z></ctrl-y>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 027 | ETB           | <ctrl-w></ctrl-w> | 067 |       | 127 W | 167 w     |
| 032       SUB <ctrl-z>       072       :       132       Z       172       Z         033       ESC       <ctrl-[>       073       ;       133       [       173       {         034       F       SEP       <ctrl-\>       074        134       \       174                 035       G       SEP       <ctrl-]>       075       =       135       ]       175       }         036       R       SEP       <ctrl-^>       076       &gt;       136       176       ~</ctrl-^></ctrl-]></ctrl-\></ctrl-[></ctrl-z>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 1   |               |                   |     |       |       | 11        |
| 033       ESC <ctrl-[>       073       ;       133       [       173       {         034       F       SEP       <ctrl-\>       074        134       \       174                 035       G       SEP       <ctrl-1>       075       =       135       ]       175       }         036       R       SEP       <ctrl-^>       076       &gt;       136       ^       176       ~</ctrl-^></ctrl-1></ctrl-\></ctrl-[>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 1   |               |                   |     | 9     |       |           |
| 034       F SEP <ctrl-\>       074 &lt;</ctrl-\>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 1   |               |                   |     | :     |       | 11 1      |
| 035       G SEP <ctrl-1>       075       =       135       ]       175       }         036       R SEP <ctrl-^>       076       &gt;       136       176       ~</ctrl-^></ctrl-1>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 1   |               |                   |     |       |       | n i       |
| 036 R SEP <ctrl-^> 076 &gt; 136 ^ 176 ~</ctrl-^>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 1   |               |                   | 11  | <     |       |           |
| 030 R SEP (CTRL- >    0/0 >    130    1/0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |     |               |                   |     |       |       |           |
| 037 U SEP <ctrl> 077 ? 137 _ 177 DEL</ctrl>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 1   |               |                   | 11  |       | 130   | 11        |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 037 | U SEP         | <ctrl></ctrl>     | 077 | ?     | 137 _ | 177 DEL   |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | l   |               |                   |     |       |       |           |

HM-081-0027-A

An and a second address of a second of the second of the

rd i i Pijači

,

# Appendix B TAPE HANDLING FLOWCHARTS

This appendix contains programming flowcharts for typical tape handling operations. They are intended as a guide to and a pictorial representation of the tape handling command sequences discussed in Section 4.

Operations covered by these flowcharts are:

#### Figure Operation

| B-l         | Command Transfer Sequence |
|-------------|---------------------------|
| B-2         | Read Status Sequence      |
| в-3         | Write Sequence            |
| B <b>-4</b> | Read Sequence             |
| B-5         | Write Transfer Sequence   |
| в <b>-6</b> | Read Transfer Sequence    |
| B-7         | Off-line Sequence         |



### Figure B-1. Command Transfer Sequence Flowchart

HM-081-0027-A POINT 4 Data Corporation B-2

APPENDIX B MARK 3 Peripherals Manual \*\*\*\*\*\*

ANERSKA Normal



Figure B-2. Read Status Sequence Flowchart

HM-081-0027-A POINT 4 Data Corporation B-3

APPENDIX B MARK 3 Peripherals Manual



Pigure B-3. Write Sequence Flowchart

 ${\cal A}^{(2)}({\cal A}_{2})$ 



Figure B-4. Read Sequence Flowchart





, affilis Nursiai

Venio V



Figure B-6. Read Transfer Sequence Flowchart



Figure B-7. Off-line Sequence Flowchart

相信认

# Appendix C FLOPPY DISC HANDLING FLOWCHARTS

This appendix contains programming flowcharts for typical floppy disc handling operations. The flowcharts cover the floppy disc command sequences discussed in Section 5. They also include internal sequences not covered in the text. The text divides the commands into two types: head movement and data transfer commands. The flowcharts, which provide additional detail, divide the commands into three types. The three types cover the following commands:

Type I = Head Movement commands Restore Seek Step Step-in Step-out

Type II = Data Transfer commands Read Sector Write Sector

Type III = Data Transfer/Format commands Read Track/Address Write Track (Format)

Operations covered in the flowcharts are:

#### <u>Operation</u>

#### Figure

| Head Movement (Type I)             | C-1 |
|------------------------------------|-----|
| Read/Write Sector (Type II)        | C-2 |
| Write Track (Type III)             | C-3 |
| Read Track/Read Address (Type III) | C-4 |

Abbreviations used in the flowcharts are defined below.

| CR    | Command Register        |
|-------|-------------------------|
| CRC   | Cyclic Redundancy Check |
| DAL   | Data Access Line        |
| DAM   | Data Address Mark       |
| DDEN  | Double Density          |
| DR    | Data Register           |
| DRQ   | Data Request            |
| DSR   | Data Shift Register     |
| HLD   | Head Load               |
| HLT   | Head-Load Timing        |
| IDAM  | ID Address Mark         |
| INTRQ | Interrupt Request       |
| SR    | Sector Register         |
| SSO   | Side Select Output      |
| STR   | Status Register         |
| TG    | Track Greater Than      |
| TR    | Track Register          |
| WG    | Write Gate              |

.



Figure C-1. Head Movement (Type I) Flowchart (1 of 3)

C-3



Figure C-1. Head Movement (Type I) Flowchart (2 of 3)

C-4

HM-081-0027-B POINT 4 Data Corporation



Figure C-1. Head Movement (Type I) Flowchart (3 of 3)

## APPENDIX C

HM-081-0027-B POINT 4 Data Corporation

C-5

MARK 3 Peripherals Manual





C-6

HM-081-0027-B POINT 4 Data Corporation

APPENDIX C MARK 3 Peripherals Manual  $\mathcal{A} = \mathbb{P}(q)$ 



Figure C-2. Read/Write Sector (Type II) Flowchart (2 of 3)



Figure C-2. Read/Write Sector (Type II) Flowchart (3 of 3)

HM-081-0027-B POINT 4 Data Corporation APPENDIX C MARK 3 Peripherals Manual

C-8



Figure C-3. Write Track (Type III) Flowchart (1 of 2)

C-9

HM-081-0027-B POINT 4 Data Corporation



Figure C-3. Write Track (Type III) Flowchart (2 of 2)

HM-081-0027-B POINT 4 Data Corporation

C-10

APPEND1X C MARK 3 Peripherals Manual edition.



Figure C-4. Read Track/Read Address (Type III) Flowchart (1 of 2)

HM-081-0027-B POINT 4 Data Corporation C-11



Figure C-4. Read Track/Read Address (Type III) Flowchart (2 of 2)

HM-081-0027-B POINT 4 Data Corporation C-12

APPENDIX C MARK 3 Peripherals Manual Quero.

## **COMMENT SHEET**

MANUAL TITLE POINT 4 MARK 2/3 Peripherals Interface Manual

PUBLICATION NO. <u>HM-081-0027</u> REVISION D

FROM: NAME/COMPANY:\_\_\_\_\_

BUSINESS ADDRESS:\_\_\_\_\_

CITY/STATE/ZIP:\_\_\_\_\_

COMMENTS: Your evaluation of this manual will be appreciated by POINT 4 Data Corporation. Notation of any errors, suggested additions or deletions, or general comments may be made below. Please include page number references where appropriate.

> NO POSTAGE NECESSARY IF MAILED IN U.S.A. Fold on Dotted Lines and Tape

## Image: Second system <td

Nereil



15442 Del Amo Avenue Tustin, CA 92680 (714) 259-0777