



(



# POINT 4 DATA CORPORATION

2569 McCabe Way / Irvine, California 92714

# POINT 4™ **MARK 3** PERIPHERALS

INTERFACE MANUAL



#### NOTICE

Every attempt has been made to make this reference 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 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 written permission of:

> POINT 4 Data Corporation 2569 McCabe Way Irvine, CA 92714 (714) 754-4114

HM-081-0027-A POINT 4 Data Corporation

MARK 3 Peripherals Manual

ii

# **REVISION RECORD**

PUBLICATION NUMBER: HM-081-0027

Date **Description** <u>Revision</u> 08/06/82 Initial Release A

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

# 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.

| Page           | Rev | Page | Rev | Page | Rev |
|----------------|-----|------|-----|------|-----|
|                |     |      |     |      |     |
| 0              |     |      |     |      |     |
| Cover          |     |      |     |      |     |
| Title          | -   |      |     |      |     |
| ii thru xii    | А   |      |     |      |     |
| 1-1 thru 1-20  | Α   |      |     |      |     |
| 2-1 thru 2-32  | Α   |      |     |      |     |
| 3-1 thru 3-49  | Α   |      |     |      |     |
| 4-1 thru 4-37  | A   |      |     |      |     |
| Appendix Title | -   |      |     |      |     |
| A-1            | A   |      |     |      |     |
| B-l thru B-8   | A   |      |     |      |     |
| Comment Sheet  | A   |      |     |      |     |
| Mailer         |     |      |     |      |     |
| Back Cover     | -   |      |     |      |     |

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

iv

MARK 3 Peripherals Manual

# PREFACE

This manual describes the interface functions of the POINT 4 MARK 3 Peripherals Interface Board (PIB). The PIB is a peripheral controller that interfaces the MARK 3 CPU to three groups of peripherals: asynchronous communications lines, disc drive units, and tape drive units.

The introduction provides information regarding the characteristics and internal architecture of the POINT 4 MARK 3 PIB as well as input/output interface handling.

Separate sections are devoted to the multiplexer, disc drive interface, and tape drive interface. The appendices provide a table of ASCII codes and tape handling flowcharts.

A separate manual describes the MARK 3 Computer System and provides 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 Manual

MARK 3 Peripherals Manual

# CONTENTS

| <u>Section</u>                                                                                                                                                | Title                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | Page                                                                                                                                                              |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1                                                                                                                                                             | INTRODUCTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 1-1                                                                                                                                                               |
| 1.1 $1.1.1$ $1.1.2$ $1.1.2.1$ $1.2.2$ $1.2.1$ $1.2.1$ $1.2.1.1$ $1.2.1.2$ $1.2.2.1$ $1.2.2.1$ $1.2.2.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>Performance Characteristics<br>Equipment Specifications<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 or Tape<br>Turning off Automatic Block Transfer Mode<br>for Multiplexer | $ \begin{array}{c} 1-1\\ 1-1\\ 1-3\\ 1-3\\ 1-5\\ 1-5\\ 1-7\\ 1-7\\ 1-7\\ 1-8\\ 1-9\\ 1-15\\ 1-15\\ 1-15\\ 1-17\\ 1-18\\ 1-19\\ 1-20\\ 1-20\\ 1-20\\ \end{array} $ |
| 2                                                                                                                                                             | MULTIPLEXER                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 2-1                                                                                                                                                               |
| 2.1 2.2                                                                                                                                                       | INTRODUCTION<br>MUX HARDWARE CONFIGURATION<br>Baud-Rate Selection                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 2-1<br>2-2                                                                                                                                                        |
| 2.2.1<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<br>2.4<br>2.4.1<br>2.4.2<br>2.4.3<br>2.4.3.1<br>2.4.3.2<br>2.4.3.3<br>2.4.3.4 | 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<br>COMMUNICATIONS AUTO MODE<br>MUX I/O Control Block<br>Control Word Definitions<br>Input Operations<br>Input Control Word<br>Input Termination Status<br>Input Byte Pointer<br>Last Input Byte                                                                                                                                                                            | 2-2 $2-4$ $2-5$ $2-5$ $2-7$ $2-7$ $2-8$ $2-11$ $2-12$ $2-12$ $2-13$ $2-14$ $2-14$ $2-19$ $2-19$ $2-19$                                                            |

•

| <b>A A</b>    |                                               | <u> </u>     |
|---------------|-----------------------------------------------|--------------|
| 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-29         |
| 2.5.3.2       |                                               |              |
| 2.5.3.3       | Enabling/Disabling Transmitters and Receivers | 2-30         |
|               | POLLING MUX INTERRUPT                         | 2-32         |
|               |                                               |              |
| 2.7           | DEACTIVATING MUX                              | 2-32         |
| 3             | DISC DRIVE INTERFACE                          | 3-1          |
| 3             | DISC DRIVE INIERFACE                          | <b>J</b> -T  |
| 3.1           | INTRODUCTION                                  | 3-1          |
|               |                                               | 3-2          |
| 3.1.1         | Performance Characteristics                   |              |
| 3.1.2         | Multi-Drive Connection                        | 3-3          |
| 3.1.3         |                                               | 3-4          |
| 3.1.3         | Disc Drive Cabling                            |              |
| 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         |
| 2.2.2         |                                               |              |
| 3.2.2.1       | DOA with Device Code 50 (Drive Unit Number)   | 3-13         |
| 3.2.2.2       | DOA with Device Code 52 (Tag Pulses)          | 3-14         |
| 3.2.2.3       |                                               |              |
| J • Z • Z • J | •                                             | <b>2 1 F</b> |
|               | Loading)                                      | 3-15         |
| 3.2.2.3.]     | Tag l                                         | 3-16         |
| 3.2.2.3.2     |                                               | 3-17         |
|               |                                               |              |
| 3.2.2.3.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.4         |                                               |              |
| 3.3.5         | Sector Address (Word 4)                       | 3-24         |
| 3.3.6         | Sector Count (Word 5)                         | 3-25         |
|               |                                               | 3-26         |
| 3.3.7         | Memory Address (Word 6)                       |              |
| 3.3.8         | Termination Status (Word 7)                   | 3-27         |
| 3.3.9         | Disc Controller Input Control                 | 3-30         |
|               |                                               | 3-31         |
| 3.3.10        | Disc Controller Output Control                |              |
| 3.4           | SEEK OPERATION                                | 3-32         |
| 3.4.1         | Drive Selection                               | 3-32         |
|               |                                               |              |
| 3.4.2         | Seek Initiation                               | 3-36         |
| 3.4.3         | Seek Error Recovery                           | 3-37         |
| 3.5           | SECTOR BLOCK FORMAT COMMANDS                  | 3-39         |
|               |                                               |              |
| 3.5.1         | Formatting Operation                          | 3-39         |
| 3.5.2         | Sector Block Description                      | 3-40         |
|               |                                               | 3-40         |
| 3.5.2.1       | Sector Block Format - Word 0 Functions        |              |
| 3.5.2.2       | Sector Block Format - Word 1 Functions        | 3-41         |
| 3.5.2.3       | Sector Block Format - Word 2 Functions        | 3-42         |
|               |                                               |              |
| 3.5.2.4       | Sector Block Format - Word 3 Functions        | 3-43         |
|               |                                               |              |
| HM-081-00     | 127-A                                         |              |
|               |                                               | Man 7        |
| FUINT 4 L     | Data Corporation viii MARK 3 Peripherals      | manual       |
|               |                                               |              |

| 3.5.3   | Formatting Procedure                    | 3-44 |
|---------|-----------------------------------------|------|
| 3.5.4   | Sector Block I/O Operations             | 3-46 |
| 3.5.4.1 | Write Data Operation                    | 3-46 |
| 3.5.4.2 |                                         | 3-46 |
| 3.5.4.3 |                                         | 3-47 |
| 3.5.4.4 |                                         | 3-47 |
| 3.6     | INTERRUPT OPERATION                     | 3-49 |
|         |                                         | • •• |
| 4       | TAPE DRIVE INTERFACE                    | 4-1  |
| 4.1     | INTRODUCTION                            | 4-1  |
| 4.1.1   | Features                                | 4-1  |
| 4.1.2   | Performance Characteristics             | 4-2  |
| 4.2     | TAPE CONTROLLER INTERFACE               | 4-3  |
| 4.2.1   | Tape Controller Interface Signals       | 4-3  |
| 4.3     | INPUT/OUTPUT CONTROL OPERATIONS         | 4-7  |
| 4.3.1   | Programmed I/O Input                    | 4-7  |
| 4.3.1.1 |                                         | 4-9  |
| 4.3.2   | Programmed I/O Output                   | 4-10 |
| 4.4     | TAPE CONTROLLER IOCB                    | 4-13 |
| 4.4.1   | Tape Transfer Control                   | 4-14 |
| 4.4.1.1 |                                         | 4-14 |
| 4.4.1.2 | DIBP Instruction                        | 4-15 |
| 4.5     | TAPE CONTROLLER COMMANDS                | 4-16 |
| 4.5.1   | Select Command (Type 0)                 | 4-17 |
| 4.5.2   |                                         | 4-17 |
| 4.5.3   | Write Command (Type <sup>2</sup> )      | 4-18 |
| 4.5.4   | End of Tape Handling                    | 4-19 |
| 4.5.5   | Write File Mark Command (Type 3)        | 4-20 |
| 4.5.6   | Read Command (Type 4)                   | 4-20 |
| 4.5.7   | Read File Mark Command (Type 5)         | 4-21 |
| 4.5.8   | Read Status Command                     | 4-22 |
| 4.5.8.1 | Exception Status Bytes                  | 4-23 |
| 4.5.8.1 |                                         | 4-24 |
| 4.5.8.1 |                                         | 4-27 |
| 4.5.8.1 | ▲ · · · · · · · · · · · · · · · · · · · | 4-29 |
| 4.5.8.1 | <b>▲</b>                                | 4-29 |
| 4.6     | TAPE COMMAND INTERFACE                  | 4-30 |
| 4.6.1   | Command Transfer Sequence               | 4-30 |
| 4.6.2   | Read Status Command Sequence            | 4-31 |
| 4.6.3   | Write Command Operations                | 4-32 |
| 4.6.4   | Read Command Operations                 | 4-33 |
| 4.6.5   | Write File Mark Operations              | 4-34 |
| 4.6.6   | Read File Mark Operations               | 4-34 |
| 4.6.7   | Error Processing and Recovery           | 4-35 |
| 4.6.7.1 |                                         | 4-35 |
| 4.6.7.2 |                                         | 4-36 |
| 4.6.7.3 |                                         | 4-36 |
| 4.6.7.4 |                                         | 4-37 |
| 4.6.7.5 | Read Sequence Errors                    | 4-37 |

HM-081-0027-A POINT 4 Data Corporation

÷

.

MARK 3 Peripherals Manual

APPENDICES

| Α | ASCII Codes              | A-1 |
|---|--------------------------|-----|
| В | Tape Handling Flowcharts | B-1 |

### FIGURES

#### Number

Title

Page

| 1-1         | Peripheral Interface Board System                                                 | 1-2              |
|-------------|-----------------------------------------------------------------------------------|------------------|
| 1-2         | Block Diagram<br>PIB Internal Architecture                                        | 1-2<br>1-6       |
| 1-3         | Software Polling/Interrupt Handling                                               | 1 0              |
|             | Flowchart                                                                         | 1-11             |
| 1-4         | I/O Service Routine Multiplexer                                                   |                  |
| 1-5         | Handling Procedures<br>I/O Service Routine Disc/Tape                              | 1-13             |
| 1-2         | Handling Procedures                                                               | 1-14             |
|             | -                                                                                 |                  |
| 2-1         | PIB Multiplexer Baud Rate Selection<br>and Port Selection Locations               | 2-3              |
| 2-2         | Command Register                                                                  | 2-5              |
| 2-3         | Status Register                                                                   | 2-8              |
| 2-4         | Software Polling Flowchart for                                                    |                  |
|             | Output Operations                                                                 | 2-11             |
| 2-5         | MUX Input/Output Control Block                                                    | 2-13             |
| 2-6         | Input Control Word - Word O                                                       | 2-14             |
| 2-7         | Output Control Word - Word 1                                                      | 2-20             |
| 2-8         | Master Reset Instruction Format                                                   | 2-28             |
| 2-9<br>2-10 | Port Initialization Instruction Format<br>Transmitter/Receiver Instruction Format | 2-29<br>2-30     |
| 2-10        | Transmitter/Receiver instruction format                                           | 2-30             |
| 3-1         | Daisy Chain Drive Connection                                                      | 3-3              |
| 3-2         | PIB/Disc Drive Differential Bus Signals                                           | 3-5              |
| 3-3         | PIB/Disc Drive Differential Synchronization                                       |                  |
|             | Cable Signals                                                                     | 3-9              |
| 3-4         | Drive Status                                                                      | 3-11             |
| -           | Contents of DOA Instruction Accumulator                                           | 3-14<br>3-16     |
| 3-6<br>3-7  | Tag 1 Instruction Format                                                          | 3 - 10<br>3 - 17 |
| 3-8         | Tag 2 Instruction Format<br>Tag 3 Instruction Format                              | 3-17             |
| 3-8         | Disc IOCB Format                                                                  | 3-19             |
| 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<br>3-15<br>3-16<br>3-17<br>3-18<br>3-20<br>3-21<br>3-22<br>3-23<br>3-24<br>3-25<br>3-26<br>3-27<br>3-28 |                                         | 3-24 3-25 3-26 3-27 3-32 3-33 3-38 3-39 3-40 3-41 3-42 3-41 3-42 3-44 3-44 3-48 |
|--------------------------------------------------------------------------------------------------------------|-----------------------------------------|---------------------------------------------------------------------------------|
| 4-1                                                                                                          | Tape Controller Interface Signals       | 4-3                                                                             |
| 4-2                                                                                                          | Format of DIA Instruction Accumulator   | 4-7                                                                             |
| 4-3                                                                                                          | Contents of DOA Instruction Accumulator | 4-10                                                                            |
| 4-4                                                                                                          | Tape Controller IOCB Format             | 4-13                                                                            |
| 4-5                                                                                                          | Tape Controller Command Format          | 4-16                                                                            |
| 4-6                                                                                                          | Exception Byte 0                        | 4-24                                                                            |
| 4-7                                                                                                          | Exception Byte 1                        | 4-27                                                                            |
| B-1                                                                                                          | Command Transfer Sequence Flowchart     | B-2                                                                             |
| B-2                                                                                                          | Read Status Sequence Flowchart          | B-3                                                                             |
| B-3                                                                                                          | Write Sequence Flowchart                | B-4                                                                             |
| B-4                                                                                                          | Read Sequence Flowchart                 | B-5                                                                             |
| B-5                                                                                                          | Write Transfer Sequence Flowchart       | B-6                                                                             |
| B-6                                                                                                          | Read Transfer Sequence Flowchart        | B-7                                                                             |
| B-7                                                                                                          | Off-line Sequence Flowchart             | B-8                                                                             |

## HM-081-0027-A POINT **4** Data Corporation

MARK 3 Peripherals Manual

хi

#### TABLES

### Number

<u>Title</u>

.

| 2-1<br>2-2 | Baud Rate Jumpering<br>Port Assignments for Baud Rate Headers | 2-2<br>2-2 |
|------------|---------------------------------------------------------------|------------|
| 2-3        | DOA, DIA Device Codes                                         | 2-4        |
| 2-4        | Command Register Bit Functions                                | 2-6        |
| 2-5        | Status Register Bit Operations                                | 2-9        |
| 2-6        | Input Control Word Definitions                                |            |
|            | (Word 0 of Each Control Block)                                | 2-15       |
| 2-7        | Output Control Word Definitions                               |            |
|            | (Word 1 of Each Control Block)                                | 2-21       |
| 2-8        | Enabling/Disabling Operation                                  | 2-31       |
|            |                                                               |            |
| 3-1        | Disc Drive Differential Bus Signals                           |            |
| • -        | (A Cable Pin Assignment)                                      | 3-6        |
| 3-2        | Drive Synchronization Cable Signals                           | 3-10       |
| 3-3        | Drive Status Definitions                                      | 3-12       |
| 3-4        | DOA Instruction Accumulator Bits                              | 3-15       |
| 3-5        | Data Bus Bit Functions with Tag 1                             | 3-16       |
| 3-6        | Data Bus Bit Functions with Tag 2                             | 3-17       |
| 3-7        | Data Bus Bit Functions with Tag 3                             | 3-18       |
| 3-8        | Disc IOCB Word 0                                              | 3-20       |
| 3-9        | Disc IOCB Word 1                                              | 3-21       |
| 3-10       | Disc IOCB Word 2                                              | 3-22       |
| 3-11       | Disc IOCB Word 3                                              | 3-23       |
| 3-12       | Disc IOCB Word 4                                              | 3-24       |
| 3-13       | Disc IOCB Word 5                                              | 3-25       |
| 3-14       | Disc IOCB Word 6                                              | 3-26       |
| 3-15       | Disc Termination Status Word 7                                | 3-28       |
| 3-16       | Sector Block Format - Word 0 Functions                        | 3-40       |
| 3-17       | Sector Block Format - Word 1 Functions                        | 3-41       |
| 3-18       | Sector Block Format - Word 2 Functions                        | 3-42       |
| 3-19       | Sector Block Format - Word 3 Functions                        | 3-43       |
| 3-19       | Sector Brock Format - Word S runcerons                        | 5 45       |
| 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-4        | Exception Byte 0 Bit Definition                               | 4-25       |
|            | Exception Byte 1 Bit Definition                               | 4-28       |
| 4-6        | Exception dyte i bit betinition                               | 7 20       |
| A-1        | ASCII Codes in Octal                                          | A-1        |

## MARK 3 Peripherals Manual

# Section 1 INTRODUCTION

## 1.1 GENERAL DESCRIPTION

The Peripheral Interface Board (PIB) is a peripheral controller that interfaces the MARK 3 CPU to three groups of peripherals: asynchronous communications lines, disc drive units, and tape drive units. The 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. The PIB board itself has no on-board intelligence.

PIB features include:

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

#### 1.1.1 SYSTEM DESCRIPTION

The PIB contains three main control modules:

- Asynchronous Communications Control Module
- CMD/SMD/LMD Disc Drive Control Module
- Tape Drive Control Module

Utilizing these modules, the MARK 3 system can control up to three types of peripherals simultaneously.

Figure 1-1 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.



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

HM-081-0027-A

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

#### **1.1.2 EQUIPMENT CHARACTERISTICS**

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

#### 1.1.2.1 Performance Characteristics

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 Line Printer: May be connected to any port Baud Rates (Hardware Strappable): 110, 150, 300, 600, 1200, 2400, 4800, 9600 DISC DRIVE INTERFACE Drives per Controller: Two Drive Type: SMD/CMD/LMD drives supporting the sector mark interface signal DMA Transfer Rate: 1.25 megabytes per second Sector Size: Header - 4 words Data - 256 words HM-081-0027-A INTRODUCTION POINT 4 Data Corporation 1-3 MARK 3 Peripherals Manual

#### TAPE DRIVE INTERFACE

Drives per Controller: Four Drive Type:

Archive Streamer Tape Units

DMA Transfer Rate: 90 kilobytes/second

Tape Speed: 90 inches/second

Tape Capacity: 20 megabytes

#### INPUT/OUTPUT INSTRUCTIONS

Input - DIA Output - DOA

Device Codes: 10-17 - MUX Ports 0-3 20-25 - Expansion Ports 4-6 50-55 - Disc 0&1 60-62 - Tape 0-4

DMA (Device Code 77): DOBS/DIBS - MUX DOBC/DIBC - Disc DOBP/DIBP - Tape

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-A POINT 4 Data Corporation

#### INTRODUCTION MARK 3 Peripherals Manual

#### 1.1.2.2 Equipment Specifications

Power Supply:

| Nominal        | Rated          |
|----------------|----------------|
| <u>Voltage</u> | <u>Current</u> |
| +5V dc         | 18 amps        |
| -5V dc         | 500 milliamps  |
| -12V dc        | 100 milliamps  |
| +12V dc        | 1.5 amps       |

Environmental Requirements:

Temperature: 0 to  $+50^{\circ}$ C (32 to  $122^{\circ}$  F) operating -20 to +100°C nonoperating

Relative Humidity: 5 to 90% noncondensing

Dimensions: 14.5 in. x 12 in. (36.8 cm x 30.5 cm)

#### 1.1.3 PIB INTERNAL ARCHITECTURE

Figure 1-2 shows the internal architecture of the Peripheral Interface Board (PIB). There are four areas of control performed on the PIB:

- General Control Functions
- Multiplexer Control Functions
- Disc Control Functions
- Tape Control Functions

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

Multiplexer Control Functions include baud rate selection, 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, and tag line control.

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

HM-081-0027-A





HM-081-0027-A POINT 4 Data Corporation

#### INTRODUCTION MARK 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 least significant bit of the accumulator can be interpreted as follows:

Accumulator Value

#### 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                 |

HM-081-0027-A POINT 4 Data Corporation 1-8

INTRODUCTION MARK 3 Peripherals Manual

#### **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). The DIB instruction with a device code of 77 (CPU) is used to read the IOCB pointers (accumulators 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 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 pointer

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.
- 2. Interrupting - Enable interrupts using an INTEN instruction. 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.

In the automatic-transfer mode, interrupts may also be generated by a controller when either 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 pending-interrupt flag for the four 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 four IOCBs for multiplexer ports to determine which port needs service (bit 0 set to 1). There may be more than one port 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.

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-3 is a flowchart showing the sequence of steps that must be taken into account when programming polling and interrupt processing procedures. 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-3 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.

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

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



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

HM-081-0027-A POINT 4 Data Corporation 1-11

INTRODUCTION MARK 3 Peripherals Manual



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

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





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

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

INTRODUCTION MARK 3 Peripherals Manual



### Figure 1-5. I/O Service Routine Disc/Tape Handling Procedures

HM-081-0027-A POINT 4 Data Corporation

INTRODUCTION MARK 3 Peripherals Manual

#### 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 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 0 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

HM-081-0027-A POINT 4 Data Corporation

1-16 M

INTRODUCTION MARK 3 Peripherals Manual

#### 1.2.3 DIRECT MEMORY ACCESS TRANSFERS

Mass storage devices, such as tape drives and discs, 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.

INTRODUCTION MARK 3 Peripherals Manual

#### **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)

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 tape streamer come to a stop. Thus, DMA should be disabled the minimum time possible.

HM-081-0027-A POINT 4 Data Corporation

INTRODUCTION MARK 3 Peripherals Manual

#### 1.2.3.2 Initiating DMA Transfer

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

| DOBS | ac,77 | set | Multi | plexer | IOCB |
|------|-------|-----|-------|--------|------|
| DOBC | ac,77 | set | Disc  | IOCB   |      |
| DOBP | ac,77 | set | Tape  | 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:

| <b>Accumulator</b> | <u>Device Controller IOCB</u> |  |  |
|--------------------|-------------------------------|--|--|
| 13                 | Multiplexer                   |  |  |
| 14                 | Таре                          |  |  |
| 15                 | Disc                          |  |  |

If an IOCB pointer contains a value of 0, the device controller is not being used in the system. The most significant bit (MSB) of this accumulator is set to 1 when an interrupt is pending. For DMA transfers the MSB must be reset to 0 after interrupt processing to avoid erroneous interrupt generation.

When issued to the disc 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. This data transfer may be one byte or an entire 256-byte block of data, depending on the starting and ending parameters supplied in the IOCB. An example for disc DMA operation would be:

IOCB Address: 075000

Instruction: DOBC 1,50

Accumulator 1 Value:

A1 = 011110100000000

Memory address: Must be set to 0 (Reserved for pending interrupt)

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 the port whose IOCB address was in the accumulator of the DOBS instruction. The DOA instruction will The DOA instruction will initiate DMA transfer between the CPU and the peripheral device.

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

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

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

Instruction: DOBC 1,50

Device Code: 50 = DISC

Accumulator 1 Value: Al = 0000000000000000

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

#### NOTE

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.

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

# 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.

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

# 2.2 MUX HARDWARE CONFIGURATION

This section describes MARK 3 baud-rate selection.

#### 2.2.1 BAUD-RATE SELECTION

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

| 110 | 1200         |
|-----|--------------|
| 150 | 2400         |
| 300 | 4800         |
| 600 | <b>96</b> 00 |

Table 2-1 shows jumpering for each baud rate. Table 2-2 indicates port assignments for baud-rate headers. Figure 2-1 shows PIB board locations for jumpering and header selection.

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

TABLE 2-1. BAUD RATE JUMPERING

#### TABLE 2-2. PORT ASSIGNMENTS FOR BAUD RATE HEADERS

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

HM-081-0027-A

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



Figure 2-1. PIB Multiplexer Baud Rate Selection and Port Selection Locations

HM-081-0027-A POINT 4 Data Corporation

# 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 |

TABLE 2-3. DOA, DIA DEVICE CODES

HM-081-0027-A POINT 4 Data Corporation 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 write-only. The UART is programmable, and can select port 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

HM-081-0027-A POINT 4 Data Corporation

MULTIPLEXER 2-5 MARK 3 Peripherals Manual

## TABLE 2-4. COMMAND REGISTER BIT FUNCTIONS

| Setting                                        |                                                |                                                | , Function                                                                                                                                                                                                                                                                              |
|------------------------------------------------|------------------------------------------------|------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                | Bits 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 9                                          | Bi                                             | t 10                                           | Transmit Control                                                                                                                                                                                                                                                                        |
| 0<br>0<br>1<br>1                               |                                                | 0<br>1<br>0<br>1                               | Transmit interrupts disabled<br>(RTS low)<br>Transmit interrupts enabled<br>(RTS low)<br>Transmit interrupts disabled<br>(RTS high)<br>Transmit interrupts disabled<br>(RTS low, transmits a break and<br>transmits data output).                                                       |
| Bit 11<br>0<br>0<br>0<br>1<br>1<br>1<br>1<br>1 | Bit 12<br>0<br>1<br>1<br>0<br>0<br>1<br>1<br>1 | Bit 13<br>0<br>1<br>0<br>1<br>0<br>1<br>0<br>1 | Word Select<br>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 |
| Bit 14 Bit 15<br>0 0<br>0 1<br>1 0<br>1 1      |                                                | 0<br>1<br>0                                    | Counter Divide<br>Reserved<br>Divide-by-16<br>Reserved<br>Master reset                                                                                                                                                                                                                  |
| *Bit 0 for Port 0 control:                     |                                                |                                                | ls RTC.                                                                                                                                                                                                                                                                                 |

HM-081-0027-A MULTIPLEXER POINT 4 Data Corporation 2-6 MARK 3 Peripherals Manual

¥830

## 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 = 00000000000011

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 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.

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

## 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.



#### Figure 2-3. Status Register

HM-081-0027-A

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

## TABLE 2-5. STATUS REGISTER BIT OPERATIONS

| 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)

HM-081-0027-A MULTIPLEXER POINT 4 Data Corporation 2-9 MARK 3 Peripherals Manual MULTIPLEXER

## 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. |

HM-081-0027-AMULTIPLEXERPOINT 4 Data Corporation2-10MARK 3 Peripherals Manual

## 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.





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

# 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 <u>pointers</u> for each port.

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

2-12

MULTIPLEXER MARK 3 Peripherals Manual

### 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 2-13 MARK 3 Peripherals Manual

MULTIPLEXER

## 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-6 defines 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

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

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

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

HM-081-0027-A

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

# 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.                                                                                                                                                                                                                                                                                                 |
| 01    |             | 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. |

HM-081-0027-A

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

## 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.                        |
|      |                    | 2. An incoming character which is overrun, or which has caused a parity or framing error.                                                                                                                                                                             |
|      |                    | <ol> <li>An incoming character which is a special character.</li> <li>The character in the receive-data register of the UART when carrier detect went high.</li> </ol>                                                                                                |
|      |                    |                                                                                                                                                                                                                                                                       |

HM-081-0027-A POINT 4 Data Corporation

MULTIPLEXER 2-18 MARK 3 Peripherals Manual

### 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 If IBP  $\geq$  LIB, an interrupt will be generated by the stored. 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 MARK 3 Peripherals Manual

MULTIPLEXER

## 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

HM-081-0027-A

## 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                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|-----------------------|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| l & 2<br><u>Value</u> | Output Mode          | Written by the program and read by MUX to determine the type of output.                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 0 0                   |                      | Idle (no output)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 01                    |                      | Single Character Output Mode - the data<br>byte in bits 8-15 of the OCW is<br>transmitted, and the OOC bit is set.                                                                                                                                                                                                                                                                                                                                                                                                              |
| 10                    |                      | Not Used (Illegal)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 11                    |                      | 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).                                                                                                                                                                                                                                                                                                                                      |
| 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 flag.

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 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.

2. Reinitialize the IOCB after interpreting the status word by creating a new input memory buffer address and resetting the IOC bit. This must be effected within two character times 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:

| Memory Location | Port   |  |
|-----------------|--------|--|
| 1000            | Port 0 |  |
| 1040            | Port 1 |  |
| 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.

#### 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.
- If a port is to operate in automatic-echo mode for incoming 2. 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 0 |
|-----------|--------|
| 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.

| 0   | 1 2 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 |
|-----|-----|---|---|---|---|---|---|---|---|----|----|----|----|----|----|
| 0 🖛 |     |   |   |   |   |   |   |   |   |    |    |    | 0  | 1  | 1  |

## 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-6).

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

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

MULTIPLEXER MARK 3 Peripherals Manual

## 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.



Figure 2-10. Transmitter/Receiver Instruction Format

# TABLE 2-8. ENABLING/DISABLING OPERATION

| Bit   | Name                                       | Operation                                                         |  |  |  |  |
|-------|--------------------------------------------|-------------------------------------------------------------------|--|--|--|--|
| 0     | Real-Time<br>Clock Enable<br>(Port 0 Only) | 0 = Disable Real-Time Clock<br>l = Enable Real-Time Clock         |  |  |  |  |
| 8     | Receiver                                   | 0 = Disable Receiver Section<br>l = Enable Receiver Section       |  |  |  |  |
| 10    | Transmitter                                | 0 = Disable Transmitter Section<br>l = Enable Transmitter Section |  |  |  |  |
| 11-13 | Port<br>Parameters                         | Set to Values Defined<br>During Initialization                    |  |  |  |  |

•

.

## 2.6 POLLING MUX INTERRUPT

The following instruction is used to poll the MUX interruptpending bit:

DIBS ac,77

This instruction causes the controller to transfer the contents of the MUX pointer (interrupt-pending bit + IOCB memory address) into the specified accumulator. Software may then test the most significant bit (interrupt-pending bit); MSB = 1 indicates a request for service.

The interrupt-pending bit is reset by resetting the MSB in the specified accumulator and issuing the following instruction:

DOBS ac,77

The accumulator value will be loaded into the MUX IOCB pointer, thus resetting the interrupt-pending bit.

## 2.7 DEACTIVATING MUX

The instruction format for temporarily deactivating and then reactivating the MUX is as follows:

DOB ac,77

When the instruction is first issued, with the accumulator equal to 0, it causes the MUX to ignore all port requests for service.

When the instruction is reissued, with the accumulator containing the IOCB pointer (see Section 2.5), the MUX is reactivated.

# Section 3 DISC DRIVE INTERFACE

# 3.1 INTRODUCTION

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/FMD/MMD 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.

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

## **3.1.1 PERFORMANCE CHARACTERISTICS**

```
Drives per Controller:
    Two
Drive Type:
    SMD/CMD/LMD/FMD/MMD drives supporting the sector mark
    interface signal
DMA Transfer Rate:
    1.25 megabytes per second
Sector Size:
    Header - 4 words
Data - 256 words
Header CRC - 1 word
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):
```

3-2

DOBC/DIBC = DISC

## 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

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

DISC DRIVE INTERFACE MARK 3 Peripherals Manual

## 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 Jl 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.



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

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

| 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 1 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 0  | 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 nominal on-cylinder toward the 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.                                                                                                                                                                |

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

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

| 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 9           | 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.                                                                                         |  |

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

HM-081-0027-A POINT 4 Data Corporation

| 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                                                                                         |  |

# 3.2 PROGRAMMED INPUT/OUTPUT

The following subsections provide information on disc programmed  $I/O_r$  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

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

# 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-A POINT 4 Data Corporation 3-12

DISC DRIVE INTERFACE MARK 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.

# 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

# 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.





#### 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)    |

DISC DRIVE INTERFACE MARK 3 Peripherals Manual

## 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                                                          |

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

#### 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.





# 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 0                                                                                                                                               |
|       | NOTE                                                                                                                                                                      |
|       | Unused opcodes are reserved<br>and should not be used.                                                                                                                    |

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

# 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 |

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

#### 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 |   |   |   |   |   | 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) |  |  |  |  |  |

3-22

HM-081-0027-A POINT 4 Data Corporation

# 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

| <b>TABLE 3-11.</b> | DISC | IOCB | WORD | 3 |
|--------------------|------|------|------|---|
|--------------------|------|------|------|---|

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

| 0 | 1       | 2 | 3 | 4 | 5 | 6 | 7   | 8 | 9 | 10 | 11   | 12   | 13  | 14 | 15 |
|---|---------|---|---|---|---|---|-----|---|---|----|------|------|-----|----|----|
| 0 | <b></b> |   |   |   |   | > | . 0 |   |   | SE | CTOR | ADDR | ESS |    |    |

# 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 |  |  |  |  |  |  |

DISC DRIVE INTERFACE MARK 3 Peripherals Manual

# 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 0                                                                                                                                                                                              |
| 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.



Figure 3-16. Memory Address Word Format

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

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

HM-081-0027-A POINT 4 Data Corporation 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

# 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.                                                                                                                                                                                                                                                                                                                                                                              |
| l   | 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.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

# 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:

- 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:

 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.

2. Deactivating the disc controller - After the disc controller 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

3-32

HM-081-0027-A POINT 4 Data Corporation





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

HM-081-0027-A POINT 4 Data Corporation

3-33



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

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





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

#### 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 l 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-A POINT 4 Data Corporation

DISC DRIVE INTERFACE MARK 3 Peripherals Manual

# 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 0 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.

| <br> | 2  | 3 | 4 | 5 | 6 | 7 | 8     | 9     | 10     | 11 | 12 | 13 | 14 | 15 |
|------|----|---|---|---|---|---|-------|-------|--------|----|----|----|----|----|
| FLA  | GS |   |   |   |   |   | CURRI | ENT C | YLINDI | ER |    |    |    |    |
|      |    |   |   |   |   |   |       |       |        |    |    |    |    |    |

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

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

| Bits Function |                                                     |  |  |  |  |  |  |
|---------------|-----------------------------------------------------|--|--|--|--|--|--|
| 0-3           | Defines file-protect flags (see Section 3.3.3).     |  |  |  |  |  |  |
| 4-15          | Defines the current cylinder address of the sector. |  |  |  |  |  |  |

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 |
|---|---|----|-------|--------|----|---|---|---|---|----|----|------|------|------|----|
|   |   | CU | RRENT | r sect | OR |   |   | 0 | 0 | 0  |    | CURI | RENT | HEAD |    |

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.            |

HM-081-0027-A

#### 3.5.2.3 Sector Block Format - Word 2 Functions

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

Table 3-18 defines the fields in word 2.

|       | 1    | 2   | 3 | 4                  | 5 | 6 | 7 | 8 | 9 | 10 | 11    | 12 | 13 | 14 | 15 |
|-------|------|-----|---|--------------------|---|---|---|---|---|----|-------|----|----|----|----|
| FLAGS |      |     |   | ALTERNATE CYLINDER |   |   |   |   |   |    |       |    |    |    |    |
|       | 1 67 | 100 |   |                    |   |   |   |   |   |    | - 1 1 |    |    |    |    |

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

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

| Bits | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0-3  | Defines file-protect flags (if alternate<br>track is needed). Should be 0, unless there<br>is a bad track.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 4-15 | Defines the alternate-cylinder address of the<br>sector. When initially formatting a track,<br>this word must be set to zero. If the track<br>being formatted was bad, the software may<br>update this word with an alternate-cylinder<br>address by issuing another format command. A<br>nonzero value in this word notifies the<br>controller that this track is bad, sets the<br>alternate-track bit to 1 in the termination<br>status word, and terminates the operation.<br>The alternate-cylinder word of each sector<br>block in the sector table (every sector on<br>the track) should contain the same value,<br><u>since the entire track will be flagged as</u><br>bad. |

## 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.

#### 0 <u>1 2 3 4 5 6 7 8 9 10 11 12 13 14 15</u> ➡ 0 0 4

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 | o | 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     | 0  | 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  | 1  | 0  | 0  | 0  | SECTOR COUNT = 8 |
| 6 |   |   |   |   |   | FIRS | T SEC | CTOR | BLOC | K AD  | DRESS |    |    |    |    |    |                  |
| 7 |   |   |   |   |   |      | CO    | NTRO | LLER | STATI | JS    |    |    |    |    |    |                  |

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. A 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:

- 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 to be written. In this case, the format operation aborts and 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.

DISC DRIVE INTERFACE MARK 3 Peripherals Manual

## 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 <u>without</u> 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.



Figure 3-28. Read-Regardless Operation

HM-081-0027-A

DISC DRIVE INTERFACE POINT 4 Data Corporation 3-48 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.

Ng-col

•

## Section 4 TAPE DRIVE INTERFACE

## 4.1 INTRODUCTION

The POINT 4 MARK 3 Streaming Tape Controller is designed to handle one Archive-compatible Intelligent Interface. One Intelligent Interface can handle four physical drives. The Tape Controller provides high speed, direct memory access between the tape drives 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 **PEATURES**

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

- Handles one Intelligent Interface which accommodates four Archive-compatible streaming tape drives
- DMA transfers at 90 kilobytes per second
- Accommodates tape speeds of 90 inches per second

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

## **4.1.2 PERFORMANCE CHARACTERISTICS**

Tape Controller Drives: Four Drive type: Archive-compatible 1/4-inch streamers DMA Transfer Rate: 90 kilobytes per second Controller Device Codes: 60-62 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 100 milliseconds maximum for 30 inches per second Tape stop: 300 milliseconds maximum for 90 inches per second 100 milliseconds maximum for 30 inches per second Unformatted capacity: 21.6 megabytes Formatted capacity: 20 megabytes Recording tracks: 4

## 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

HM-081-0027-A

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

# TABLE 4-1.TAPE CONTROLLER INTERFACE CABLEJ1 SIGNAL FUNCTIONS

| Pin | Signal | Direc-<br>tion | Description                                                               |
|-----|--------|----------------|---------------------------------------------------------------------------|
|     |        |                |                                                                           |
| 1   | -      | -              | Reserved                                                                  |
| 2   | GND    | -              | Ground                                                                    |
| 3   | ONL-   | OUT            | Tape Controller is on-line to<br>Intelligent Interface                    |
| 4   | GND    | -              | Ground                                                                    |
| 5   | REQ-   | OUT            | Request - Used by the Tape<br>Controller to initiate command<br>sequences |
| 6   | GND    | -              | Ground                                                                    |
| 7   | -      | -              | Reserved                                                                  |
| 8   | GND    | -              | Ground                                                                    |
| 9   | REST-  | OUT            | Resets Intelligent Interface,<br>aborting all operations                  |
| 10  | GND    | -              | Ground                                                                    |
| 11  | EXC-   | IN             | Exception condition exists in<br>Intelligent Interface/drive<br>operation |
| 12  | GND    | -              | Ground                                                                    |
| 13  | -      | -              | Reserved                                                                  |
| 14  | -      | -              | Reserved                                                                  |
| 15  | -      | -              | Reserved                                                                  |
| 16  | GND    | -              | Ground                                                                    |
| 17  | DIRC-  | IN             | Indicates the direction of data flow                                      |
| 18  | GND    | -              | Ground                                                                    |
| 19  | -      | -              | Reserved                                                                  |
| 20  | GND    | -              | Ground                                                                    |
| 21  | -      | -              | Reserved                                                                  |

4-4

TAPE DRIVE INTERFACE MARK 3 Peripherals Manual

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

| Pin | Signal        | Direc-<br>tion | Description                                   |
|-----|---------------|----------------|-----------------------------------------------|
| 22  | GND           | _              | Ground                                        |
| 23  | RDY-          | IN             | Intelligent Interface ready for new operation |
| 24  | GND           | -              | Ground                                        |
| 25  | -             | -              | Reserved                                      |
| 26  | GND           | -              | Ground                                        |
| 27  | DA0-          | Bidirec        | Data Bit O                                    |
| 28  | GND           | -              | Ground                                        |
| 29  | DA1-          | Bidirec        | Data Bit l                                    |
| 30  | GND           | -              | Ground                                        |
| 31  | DA2-          | Bidirec        | Data Bit 2                                    |
| 32  | GND           | -              | Ground                                        |
| 33  | DA3-          | Bidirec        | Data Bit 3                                    |
| 34  | GND           | -              | Ground                                        |
| 35  | DA <b>4</b> - | Bidirec        | Data Bit <b>4</b>                             |
| 36  | GND           | -              | Ground                                        |
| 37  | DA5-          | Bidirec        | Data Bit 5                                    |
| 38  | GND           | -              | Ground                                        |
| 39  | DA6-          | Bidirec        | Data Bit 6                                    |
| 40  | GND           | -              | Ground                                        |
| 41  | DA7-          | Bidirec        | Data Bit 7                                    |
| 42  | GND           | -              | Ground                                        |
| 43  | -             | -              | Reserved                                      |
| 44  | -             | -              | Reserved                                      |

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

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

| Pin | Signal | Direc-<br>tion | Description                                         |  |  |  |  |  |  |  |  |
|-----|--------|----------------|-----------------------------------------------------|--|--|--|--|--|--|--|--|
| 45  | XFER-  | OUT            | Used in control of data transfer                    |  |  |  |  |  |  |  |  |
| 46  | GND    | -              | Ground                                              |  |  |  |  |  |  |  |  |
| 47  | ACK-   | IN             | Intelligent Interface<br>acknowledges data transfer |  |  |  |  |  |  |  |  |
| 48  | GND    | -              | Ground                                              |  |  |  |  |  |  |  |  |
| 49  | -      | -              | Reserved                                            |  |  |  |  |  |  |  |  |
| 50  | -      | -              | Reserved                                            |  |  |  |  |  |  |  |  |

## 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  $6\overline{0}$  is the device code. The format of the accumulator is shown in Figure 4-2; bit functions are defined in Table 4-2.

| <br>1                | 12     | 3                           | 4      | 5   | 6 | 7 | 8    | 9 | 10 | 11 | 12  | 13 | 14  | 15  |
|----------------------|--------|-----------------------------|--------|-----|---|---|------|---|----|----|-----|----|-----|-----|
|                      |        |                             |        |     |   |   | DIRC |   |    |    | АСК |    | EXC | RDY |
| Di<br>RE<br>AC<br>RE | ESERVI | ON<br>ED :<br>/LEDG<br>ED : | SET TO | ) 0 |   |   |      |   |    |    |     |    |     |     |
| 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 0                                                                                                                                                                                                                                                                                                                                                                                    |
| 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><br>This bit is used by the Tape<br>Controller and need not concern<br>the programmer. |
| 13   | _      | Reserved - set to 0                                                                                                                                                                                                                                                                                                                                                                                    |
| 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)

4-8

A<sup>(88</sup>)

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

| Bits | Signal |                               | Function                                                                                                                 |
|------|--------|-------------------------------|--------------------------------------------------------------------------------------------------------------------------|
| 15   | RDY    | depending on<br>following out | atus 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           | Command has been taken from<br>the data bus by the<br>Intelligent Interface                                              |
|      |        | 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.

| RESERVED – MUST SET TO 0<br>RESET |   | 0 | 1 | 1 | 1 | 2 | 1 | 3 | 1      | 4           | 1  | . 5 | 5 1 | 1   | 6   | L     | 7   | 1          | 8   | I | 9 | 1 | 1 | 10 | 11 | 12 | 1 | 3 | 1 | 4 | 15  |  |
|-----------------------------------|---|---|---|---|---|---|---|---|--------|-------------|----|-----|-----|-----|-----|-------|-----|------------|-----|---|---|---|---|----|----|----|---|---|---|---|-----|--|
| RESET                             | Γ |   | T |   | - |   | 1 |   | 1      |             | -1 |     |     | 1   |     | Т     |     | -1         |     | Т |   | Т |   |    |    |    |   |   |   |   | REQ |  |
|                                   | ¢ |   |   |   |   |   |   |   | 1<br>( | RES<br>DN-I | ET |     |     | - M | MUS | т<br> | SET | г <b>т</b> | 0 0 |   |   |   |   |    |    |    |   |   |   |   |     |  |

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

## TABLE 4-3. DOA INSTRUCTION ACCUMULATOR BITS

| Bits | Signal | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0-12 | -      | Reserved - 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 | This bit <u>must</u> be set for the following<br>command modes:<br>• Writing<br>• Reading<br>• Write File Mark<br>• Read File Mark<br>The on-line bit performs the following<br>functions depending upon the operational<br>mode.<br>Mode <u>On-line Bit Function</u><br>Write The Intelligent Interface must be<br>on-line to the Tape Controller to<br>execute the write command. The<br>Intelligent Interface continues to<br>request data blocks as long as<br>on-line is true. To terminate data<br>transfer, the on-line bit must be<br>set to 0. The interface writes the<br>remaining buffers, writes a file<br>mark and goes to BOT (beginning of<br>tape).<br>Read The Intelligent Interface must be<br>on-line to the Tape Controller to<br>execute the read command. The Tape<br>Controller receives read data as<br>long as on-line is set to 1. If<br>on-line is set to 0, the<br>Intelligent Interface will not<br>attempt to transfer the next block<br>even though read data may remain in<br>the buffer memories. The tape is<br>positioned to BOT. |

.

## 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-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 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.
  - a. Transfer direction (read or write), determined by the last DOA ac,61
  - b. Memory address, determined by the Tape IOCB
- 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:

- 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.

| 0 1 2 3 4 5 6 7 | 1 8 9 1 10   | <b>  11   12   13   14   15</b> |
|-----------------|--------------|---------------------------------|
| 0◀0             | 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<br><u>8 9 10</u>           | Command                     |
|-------------|-----------------------------------------|-----------------------------|
| 0<br>1<br>2 | 000000000000000000000000000000000000000 | Select<br>Position<br>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

| 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.

Bit Description

| 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> | <u>Description</u> |
|------------|--------------------|
|------------|--------------------|

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

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.

TAPE DRIVE INTERFACE MARK 3 Peripherals Manual

## 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.

| Description |
|-------------|
| 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. Durina 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.

| <u>Bit</u> | <u>Description</u> |  |  |
|------------|--------------------|--|--|
| 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 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

4-20

HM-081-0027-A POINT 4 Data Corporation

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> | <b>Description</b> |
|------------|--------------------|
| 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-file-mark 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:

- 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:

4-22

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

Description

Bit

.effica.

ĵ.

## 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 0                               |
|      | 13  | -             | Reserved - Set to 0                               |
|      | 12  | -             | Reserved - Set to 0                               |
|      | 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

## 4.5.8.1.1 EXCEPTION BYTE 0

The eight bits of exception byte 0 are shown in Figure  $4-\frac{1}{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

## 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 POINT 4 Data Corporation

4-25

TAPE DRIVE INTERFACE 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-A POINT 4 Data Corporation

## 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 O                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 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.                                                                                                                                                                                                                                                                                                                                                                                                       |

#### 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.

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

### 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:

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

4-30

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-31

#### 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.
- The interface brings the tape up to speed and begins 3. 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.
- If the CRC and block address are good, the block is 5. transferred to the processor.
- 6. Steps 4 and 5 are repeated for all of the blocks on track 0.
- When the EOT (end-of-tape) holes are detected for track 0, 7. 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.
- The read command can be terminated by the program any time a 10. 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 block. The sequence of events is:

- 1. The program issues the write-file-mark command at any data 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.

TAPE DRIVE INTERFACE MARK 3 Peripherals Manual

#### 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-35

#### 4.6.7.2 Read After Write Errors

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.



# **APPENDICES**

and the set of the set

•

٠

•

-

# Appendix A **ASCII CODES**

#### TABLE A-1. ASCII CODES IN OCTAL

|     |               |                   | 1   |       | T   |              | 1   |     |
|-----|---------------|-------------------|-----|-------|-----|--------------|-----|-----|
| 000 | NUL           | <ctrl-@></ctrl-@> | 040 | BLANK | 100 | 6            | 140 | 、   |
| 001 | SOH           | <ctrl-a></ctrl-a> | 041 | 1     | 101 | A            | 141 | a   |
| 002 | STX           | <ctrl-b></ctrl-b> | 042 | n     | 102 | В            | 142 | b   |
| 003 | ETX           | <ctrl-c></ctrl-c> | 043 | #     | 103 | С            | 143 | с   |
| 004 | EOT           | <ctrl-d></ctrl-d> | 044 | \$    | 104 | D            | 144 | d   |
| 005 | ENQ           | <ctrl-e></ctrl-e> | 045 | ક     | 105 | Е            | 145 | e   |
| 006 | ACK           | <ctrl-f></ctrl-f> | 046 | &     | 106 | F            | 146 | f   |
| 007 | BEL           | <ctrl-g></ctrl-g> | 047 | T     | 107 | G            | 147 | g   |
| 010 | BKSP          | <ctrl-h></ctrl-h> | 050 | (     | 110 | H            | 150 | h   |
| 011 | HTAB          | <ctrl-i></ctrl-i> | 051 | )     | 111 | I            | 151 | i   |
| 012 | $\mathbf{LF}$ | <ctrl-j></ctrl-j> | 052 | *     | 112 | J            | 152 | j   |
| 013 | VTAB          | <ctrl-k></ctrl-k> | 053 | +     | 113 | K            | 153 | k   |
| 014 | FF            | <ctrl-l></ctrl-l> | 054 | ,     | 114 | $\mathbf{L}$ | 154 | 1   |
| 015 | CR            | <ctrl-m></ctrl-m> | 055 | -     | 115 | М            | 155 | m   |
| 016 | SO            | <ctrl-n></ctrl-n> | 056 | •     | 116 | N            | 156 | n   |
| 017 | SI            | <ctrl-o></ctrl-o> | 057 | 1     | 117 | 0            | 157 | 0   |
|     |               |                   |     |       |     |              |     |     |
| 020 | DLE           | <ctrl-p></ctrl-p> | 060 | 0     | 120 | Р            | 160 | р   |
| 021 | XON           | <ctrl-q></ctrl-q> | 061 | 1     | 121 | Q            | 161 | q   |
| 022 | AUXON         | <ctrl-r></ctrl-r> | 062 | 2     | 122 | R            | 162 | r   |
| 023 | XOFF          | <ctrl-s></ctrl-s> | 063 | 3     | 123 | S            | 163 | s   |
| 024 | AUXOFF        | <ctrl-t></ctrl-t> | 064 | 4     | 124 | Т            | 164 | t   |
| 025 | NAK           | <ctrl-u></ctrl-u> | 065 | 5     | 125 | U            | 165 | u   |
| 026 | SYN           | <ctrl-v></ctrl-v> | 066 | 6     | 126 | V            | 166 | v   |
| 027 | ETB           | <ctrl-w></ctrl-w> | 067 | 7     | 127 | W            | 167 | W   |
| 030 | CAN           | <ctrl-x></ctrl-x> | 070 | 8     | 130 | Х            | 170 | х   |
| 031 | ENDMD         | <ctrl-y></ctrl-y> | 071 | 9     | 131 | Y            | 171 | У   |
| 032 | SUB           | <ctrl-z></ctrl-z> | 072 | :     | 132 | Z            | 172 | Z   |
| 033 | ESC           | <ctrl-[></ctrl-[> | 073 | ;     | 133 | ]            | 173 | {   |
| 034 | F SEP         | <ctrl-\></ctrl-\> | 074 | <     | 134 | \            | 174 |     |
| 035 | G SEP         | <ctrl-]></ctrl-]> | 075 | =     | 135 | ]            | 175 | }   |
| 036 | R SEP         | <ctrl-^></ctrl-^> | 076 | >     | 136 | ~            | 176 | ~   |
| 037 | U SEP         | <ctrl></ctrl>     | 077 | ?     | 137 |              | 177 | DEL |
|     |               |                   |     |       |     |              |     |     |

HM-081-0027-A

APPENDIX A POINT 4 Data Corporation A-1 MARK 3 Peripherals Manual

e#05... \* . . -2

# 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-1         | Command Transfer Sequence |
|-------------|---------------------------|
| B-2         | Read Status Sequence      |
| B-3         | Write Sequence            |
| B-4         | Read Sequence             |
| B-5         | Write Transfer Sequence   |
| B <b>-6</b> | Read Transfer Sequence    |
| B-7         | Off-line Sequence         |





ł

APPENDIX B MARK 3 Peripherals Manual



### Figure B-2. Read Status Sequence Flowchart

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

APPENDIX B MARK 3 Peripherals Manual



Figure B-3. Write Sequence Flowchart

#### APPENDIX B MARK 3 Peripherals Manual

.



Figure B-4. Read Sequence Flowchart

APPENDIX B MARK 3 Peripherals Manual





APPENDIX B MARK 3 Peripherals Manual



Figure B-6. Read Transfer Sequence Flowchart

APPENDIX B MARK 3 Peripherals Manual



Figure B-7. Off-line Sequence Flowchart

APPENDIX B MARK 3 Peripherals Manual

#### COMMENT SHEET

| MANUAL | TITLE POINT 4 MARK 3 Peripherals Interface Manual |
|--------|---------------------------------------------------|
| PUBLIC | ATION NO. <u>HM-081-0027</u> REVISION <u>A</u>    |
| FROM:  | NAME/COMPANY:                                     |

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.

### **BUSINESS REPLY MAIL**

FIRST CLASS P

PERMITINO: 5755

SANTA ANA, CA

NO POSTAGE NECESSARY IF MAILED IN UNITED STATES

CUT ON THIS LINE

POSTAGE WILL BE PAID BY ADDRESSEE

## **POINT 4 Data Corporation** PUBLICATIONS DEPARTMENT

2569 McCabe Way Irvine, CA 92714



# POINT 4 DATA CORPORATION

2569 McCabe Way / Irvine, California 92714 / (714) 754-4114