## RX02 FLOPPY DISK SYSTEM TECHNICAL MANUAL # RX02 Floppy Disk System Technical Manual #### Copyright • 1978 by Digital Equipment Corporation The material in this manual is for informational purposes and is subject to change without notice. Digital Equipment Corporation assumes no responsibility for any errors which may appear in this manual. Printed in U.S.A. This document was set on DIGITAL's DECset-8000 computerized typesetting system. The following are trademarks of Digital Equipment Corporation, Maynard, Massachusetts: | DIGITAL | DECsystem-10 | MASSBUS | |---------|--------------|---------| | DEC | DECSYSTEM-20 | OMNIBUS | | PDP | DIBOL | OS/8 | | DECUS | EDUSYSTEM | RSTS | | UNIBUS | VAX | RSX | | | VMS | IAS | ## **CONTENTS** | PREFACE | | Page | |-----------|-----------------------------------------------------------------|--------------| | TREFACE | | | | CHAPTER 1 | GENERAL INFORMATION | | | 1.1 | INTRODUCTION | | | 1.2 | GENERAL DESCRIPTION | 1-2 | | 1.2.1 | Interface Modules | 1-2 | | 1.2,2 | Microprogrammed Controller | 1 -2 | | 1.2.3 | Read/Write Electronics | 1-2 | | 1.2.4 | Electromechanical Drive | 1-2 | | 1.2.5 | Power Supply | 1-4 | | 1.3 | OPTION DESCRIPTION | | | 1.3.1 | Operation For Single Density Recording Only (RX8E, RX11, RXV11) | 1-€ | | 1.3.1.1 | PDP-8 Operation | 1-6 | | 1 3 1,2 | PDP-11 Operation | 1 6 | | 1.3.1.3 | LSI-11 Operation | 1-7 | | 1.3.2 | Operation For Single or Double Density Recording RX28, RX211, | | | | RXV211) | | | 1.3.2.1 | PDP-8 Operation | 1-7 | | 1.3,2,2 | PDP-11 Operation | 1-7 | | 1.3.2.3 | LSI-11 Operation | 1-7 | | 1.4 | SPECIFICATIONS | 1-8 | | 1.5 | SYSTEMS COMPATIBILITY | 1-9 | | 1.5.1 | Media | 1-9 | | 1.5.2 | Recording Scheme | 1-10 | | 1.5,2.1 | Double Frequency (FM) | 1-10 | | 1.5.2.2 | Miller Code (MFM) | 1-10 | | 1.5.3 | Logical Format | 1-12 | | 1.5.3.1 | Header Field Description | <b>1-</b> 13 | | 1.5,3,2 | Data Field Description | | | 1.5.3,3 | Track Usage | 1-14 | | 1.5.3.4 | CRC Capability | | | CHAPTER 2 | INSTALLATION | | | 2.1 | SITE PREPARATION | 2- | | 2.1.1 | Space | | | 2.1.2 | Cabling | 2-2 | | 2.1.3 | AC Power | | | 2.1.3.1 | Power Requirements | | | 2.1.3.2 | Input Power Modification Requirements | | | | | Page | |-----------|---------------------------------------------------------|------| | 2.1.4 | Fire and Safety Precautions | 2-4 | | 2.2 | CONFIGURATION GUIDELINES | | | 2.3 | ENVIRONMENTAL CONSIDERATIONS | 2-4 | | 2.3.1 | General | 2-4 | | 2.3.2 | Temperature, Relative Humidity | | | 2.3.3 | Heat Dissipation | | | 2.3.4 | Radiated Emissions | | | 2.3.5 | Cleanliness | 2-6 | | 2.4 | UNPACKING AND INSPECTION | 2-6 | | 2.4.1 | General | 2-6 | | 2.4.2 | Tools | | | 2.4.3 | Unpacking | | | 2.4.3.1 | Cabinet-Mounted | | | 2.4.3.2 | Separate Container | 2-7 | | 2.4.3.3 | Inspection | | | 2.5 | INSTALLATION | | | 2.6 | TESTING | | | | | | | CHAPTER 3 | USER INFORMATION | | | 3.1 | CUSTOMER RESPONSIBILITY | 3-1 | | 3.2 | CARE OF MEDIA | | | 3.2.1 | Handling Practices and Precautions | 3-1 | | 3.2,2 | Diskette Storage | 3-2 | | 3.2.2.1 | Short Term (Available for Immediate Use) | 3-2 | | 3.2.2.2 | Long Term | 3-2 | | 3.2.3 | Shipping Diskettes | 3-2 | | 3.3 | OPERATING INSTRUCTIONS | 3-3 | | 3.4 | OPERATOR TROUBLESHOOTING | 3-3 | | CHAPTER 4 | PROGRAMMING | | | 4.1 | RX8E and RX28 PROGRAMMING INFORMATION | 4-1 | | 4.1.1 | Device Codes. | | | 4.1.2 | Instruction Set | | | 4.1.2.1 | RX8E Load Command (LCD) - 67x1 | | | 4.1.2.2 | RX28 Load Command - (First byte 67x1, Second byte 67x2) | | | 4.1,2.3 | Transfer Data Register (XDR) - 67x2 | | | 4.1.2.4 | STR - 67x3 | | | 4.1.2.5 | SER – 67x4 | 4-4 | | 4.1.2.6 | SDN - 67x5 | | | 4.1.2.7 | INTR - 67x6 | | | 4.1.2.8 | INIT – 67x7 | | | 4.1.3 | Register Description | | | | | Page | |----------|---------------------------------------------|------| | 4.1,3.1 | Command Register | 4-4 | | 4.1.3.2 | Error Code Register | 4-5 | | 4.1.3.3 | RX2TA - RX Track Address | | | 4.1.3.4 | RX2SA - RX Sector Address | | | 4.1.3.5 | RX2DB - RX Data Buffer | | | 4.1.3.6 | RX8E - RX Error and Status | | | 4.1.3.7 | RX28 - RX Error and Status | | | 4.1.4 | Function Code Description | | | 4.1.4.1 | Fill Buffer (000) | | | 4.1.4.2 | Empty Buffer (001) | | | 4.1.4.3 | Write Sector (010) | | | 4.1.4.4 | Read Sector (011) | | | 4.1.4.5 | Set Media Density (100) for RX28 Only | 4-11 | | 4.1.4.6 | Maintenance Read Status (101) for RX28 Only | | | 4.1.4.7 | Read Status (101) for RX8E Only | 4-12 | | 4.1.4.8 | Write Deleted Data Sector (110) | 4-12 | | 4.1.4.9 | Read Error Code Function (111) | | | 4.1.4.10 | Power Fail | | | 4.1.5 | Error Recovery | | | 4.1.5.1 | RX8E | | | 4.1.5.2 | RX28 | | | 4.1.6 | RX8E Programming Examples | 4-14 | | 4.1.6.1 | Write/Write Deleted Data/Read Functions | 4-14 | | 4.1.6.2 | Empty Buffer Function | | | 4.1.6.3 | Fill Buffer Function. | | | 4.1.7 | RX28 Programming Examples | | | 4.1.8 | Restrictions and Programming Pitfalls | | | 4.2 | RXII and RXVII PROGRAMMING INFORMATION | 4-24 | | 4.2.1 | Register and Vector Addresses | | | 4.2.2 | Register Description | | | 4.2.2.1 | RXCS - Command and Status (177170) | | | 4.2.2.2 | RXDB - Data Buffer Register (177172) | | | 4.2.2.3 | RXTA - RX Track Address | 4-26 | | 4.2,2,4 | RXSA - RX Sector Address | 4-26 | | 4.2.2.5 | RXDB - RX Data Buffer | | | 4.2.2.6 | RXES - RX Error and Status | | | 4.2.3 | Function Codes | | | 4.2.3.1 | Fill Buffer (000) | 4-29 | | 4.2.3.2 | Empty Buffer (001) | | | 4.2.3.3 | Write Sector (010) | | | 4.2.3.4 | Read Sector (011) | | | 4.2.3.5 | Read Status (101) | | | 4.2.3.6 | Write Sector with Deleted Data (110) | | | 4.2.3.7 | Read Error Code Function (111) | | | | | Page | |-----------|-------------------------------------------------------|------| | 4.2.3.8 | Power Fail | 4-31 | | 4.2.4 | Programming Examples | 4-31 | | 4.2.4.1 | Read Data/Write Data | | | 4.2.4.2 | Empty Buffer Function | | | 4.2.4.3 | Fill Buffer Function | 4-33 | | 4.2.5 | Restrictions and Programming Pitfalls | 4-33 | | 4.2.6 | Error Recovery | | | 4.3 | RX211 and RXV21 PROGRAMMING INFORMATION | | | 4.3.1 | Register and Vector Addresses | 4-37 | | 4.3.2 | Register Description | | | 4.3.2.1 | RX2CS - Command and Status (177170) | | | 4.3.2.2 | RX2DB - Data Buffer Register (177172) | | | 4.3.2.3 | RX2TA - RX Track Address | | | 4.3,2.4 | RX2SA - RX Sector Address | | | 4.3.2.5 | RX2WC - RX Word Count Register | | | 4.3.2.6 | RX2BA – RX Bus Address Register | | | 4.3.2.7 | RX2DB - RX Data Buffer | | | 4.3.2.8 | RX2ES – RX Error and Status | | | 4.3.3 | Function Codes | | | 4.3.3.1 | Fill Buffer (000) | | | 4.3.3.2 | Empty Buffer (001) | | | 4.3.3.3 | Write Sector (010) | | | 4.3.3.4 | Read Sector (011) | | | 4.3.3.5 | Set Media Density (100) | | | 4.3.3.6 | Maintenance Read Status (101) | | | 4.3.3.7 | Write Sector with Deleted Data (110) | | | 4,3.3.8 | Read Error Code (111) | | | 4.3.3.9 | RX02 Power Fail | | | 4.3.4 | Error Recovery | | | 4.3.5 | RX211/RXV21 Programming Examples | | | 4.3.5.1 | , | | | 4.3.5.2 | Write/Fill Buffer | | | 4.3.3.2 | Read/Empty Buller | 440 | | CHAPTER 5 | THEORY OF OPERATION | | | 5.1 | OVERALL SYSTEM BLOCK DIAGRAM | 5-1 | | 5.1.1 | Omnibus to RX8E/RX28 Interface Signals | 5-1 | | 5.1.2 | Unibus to RX11/RX211 Interface Signals | 5-3 | | 5.1.3 | LSI-11 Bus to RXV11/RXV21 Interface Signals | 5-4 | | 5.1.4 | Interface Module to µCPU Controller Signals | | | 5.1.5 | μCPU Controller to Read/Write Electronics Signals | | | 5.1.6 | Read/Write Electronics to Drive Signals | | | 5.2 | INTERFACE MODULES BLOCK DIAGRAM DESCRIPTION | 5-10 | | 5.2.1 | RX8E/RX28 Interface (M8357) Block Diagram Description | | | | | Page | |---------|------------------------------------------------------------|------| | 5.2.1.1 | Device Select and IOT Decoder | 5-10 | | 5.2.1.2 | Interrupt Control and Skip Logic | 5-12 | | 5.2.1.3 | C Line Select Logic | | | 5.2.1.4 | Interface Register | | | 5.2.1.5 | Sequence and Function Control Logic | | | 5.2.2 | RX11 Interface (M7846) Block Diagram Description | | | 5.2.2.1 | Address Decoder | | | 5.2.2.2 | Data Path Selection | | | 5.2.2,3 | Interface Data Buffer Register | | | 5.2.2.4 | Sequence and Function Control Logic | | | 5.2.2.5 | Interrupt Control Logic | | | 5.2,2.6 | Vector Address Generator | | | 5.2.3 | RXV11 Interface (M7946) Block Diagram Description | | | 5.2.3.1 | Address Decoding Logic | | | 5,2,3,2 | 1/O Control Logic | | | 5.2.3.3 | RX Data Buffer (RXDB) Register | | | 5.2.3.4 | RX Command/Status (RXCS) Register | | | 5.2.3.5 | Status and Control Signal Interface Logic | | | 5.2.3.6 | Interrupt Control Logic | | | 5.2.3.7 | Initialize Logic | | | 5.2.4 | RX211 Interface (M8256) Block Diagram Description | | | 5.2.4.1 | Address Decoder, Buffer Selector, SSYN Register | | | 5.2.4.2 | Command and Status Buffer | | | 5.2.4.3 | Data Buffer | | | 5.2.4.4 | Data Input/Output and TRANSMIT DATA CIRCUIT | | | 5.2.4.5 | Address Circuits | | | 5.2.4.6 | Interface Control Circuits | | | 5.2.4.7 | Bus Control Circuits | | | 5.2.4.8 | Interrupt Circuits | | | 5.2.5 | RXV21 Interface (M8029) Block Diagram Description | | | 5.2.5.1 | Input/Output Transceiver, Buffer Selector | | | 5.2.5.2 | Command and Status Buffer | | | 5.2.5.3 | Data Buffer | | | 5.2.5.4 | Input/Output Transceiver and Transmit/Receive Data Circuit | | | 5.2.5.5 | Address Circuits | | | 5.2.5.6 | Interface Control Circuits | | | 5.2.5.7 | Bus Control Circuits | | | 5,2.5.8 | Interrupt Circuits | | | 5.3 | UNIT LEVEL DESCRIPTION | | | 5.3.1 | Microprogrammed Controller (M7744) Hardware Description | | | 5.3.1.1 | PROM, ROM Register, Processor and Sequencer Circuits | | | 5.3.1.2 | Branch Control Circuits | | | 5.3.1.3 | I/O Control Circuits | | | 5.3.1.4 | Sector Buffer and Control Circuits | | | | | Page | |----------------|----------------------------------------------------------------------|------| | 5.3.1.5 | Data Selection and CRC Circuits | 5-31 | | 5.3.1.6 | Timing and Synchronizing Circuits | 5-32 | | 5.3.1.7 | Power Fail Circuit | | | 5.3.2 | Microprogrammed Controller Software Description | | | 5,3,2,1 | Initialize Routine | | | 5.3.2,2 | Find Header (FIND HD) Subroutine | | | 5,3,2,3 | Read Address Mark (RDAM) Subroutine | | | 5.3.2.4 | Read (RD) Sector Subroutine | | | 5.3.2.5 | Write/Write Sector Subroutine | | | 5.3.2.6 | Read Error Register (RDERRG) and Set Density (SET DEN) | | | 5 3 <b>3 7</b> | Subroutines | | | 5.3.2.7 | Fill/Empty Buffer Routine | | | 5.3.2.8 | Find Track Subroutine | | | 5.3.2.9 | Decode Command (DECCMD) Routine | 5-45 | | 5.3.2.10 | Maintenance Read Status (MRDST) and Check Ready (CHKRDY) Subroutines | 5-45 | | 5.3.2.11 | Get Parameter (GET PAR), Step Head (STEPHD), Wait, | | | J.B.2.11 | Wait Run, and Write Zeros (WRTS) Subroutines | 5-45 | | 5.3.2.12 | Find Sector (FINDSE), Send Word 12 (SNDW12), | | | 5.5.2.12 | Send Word 8 (SNDW8), Get Command (GET CMD), and | | | | Get Word (GET WRD) Subroutines | 5-45 | | 5.3.2.13 | Maintenance Check Ready (MAINT CHK) Subroutine | | | 5.3.3 | Read/Write Block Diagram Description | | | 5.3.3.1 | Drive and Head Control | | | 5.3.3.2 | Position Data Selection | | | 5,3.3,3 | Read/Write Circuit | | | 5.3.4 | Mechanial Drive Description | | | 5.3.4.1 | Drive Mechanism | | | 5.3.4.2 | Spindle Mechanism | | | 5.3.4.3 | Positioning Mechanism | | | 5.3.4.4 | Head Load Mechanism | | | | | ەر-ر | | CHAPTER 6 | MAINTENANCE | | | 6.1 | EQUIPMENT CARE | | | 6.2 | TROUBLESHOOTING THE RX02 | | | 6.2.1 | M7744, M7745 Failures | | | 6.2.2 | Drive Failures | | | 6.3 | TROUBLESHOOTING WITH DIAGNOSTICS | | | 6.4 | TROUBLESHOOTING WITHOUT A DIAGNOSTIC | | | 6.4.1 | RX211 and RXV21 Systems | 6-2 | | 6.4.2 | PDP-8 and CM05-8 Based Systems | | | 6.5 | REMOVAL AND REPLACEMENT | 6-5 | | 6.5.1 | Module Replacement Procedures | 6-5 | 6.5.2 6.5.3 6.5.4 6.5.5 Drive Replacement Procedure ......6-8 Front Handle Replacement Procedure......6-8 Drive Motor Replacement Procedures......6-9 Drive Belt Replacement Procedures ......6-10 Page | 6.5.6 | Quick Check For Belt on Pulleys | 6-10 | |------------|--------------------------------------------|--------------| | APPENDIX A | RX02 SUMMARY | | | | FIGURES | | | Figure No. | Title | Page | | 1-1 | Floppy Disk Configuration | 1-3 | | 1-2 | Front View of the Floppy Disk System | | | 1-3 | Interface Modules | | | 1-4 | Top View of R X02 | 1-6 | | 1-5 | Underside View of Drive | | | 1-6 | Diskette Media | 1-10 | | 1-7 | Flux Reversal Patterns for FM | 1-11 | | 1-8 | FM Versus MFM Encoding | 1-12 | | 1-9 | Track Format (Each Track) | 1-12 | | 1-10 | Sector Format (Each Sector) | 1-13 | | 2-1 | RX02 Outline Dimensions | 2-1 | | 2-2 | Cabinet Layout Dimensions | | | 2-3 | RX02 Rear View | | | 2-4 | RX02 Unpacking | 2-8 | | 2-5 | RX02 Cabinet Mounting Information | | | 4-1 | LCD Word Format (RX8E) | <b>.4-</b> 2 | | 4-2 | Command Word Format (RX28) | | | 4-3 | Command Register Format (RX8E) | 4-4 | | 4-4 | Command Register Format (RX28F) | | | 4-5 | Error Code Register Format (RX8E/RX28A) | | | 4-6 | RX2TA Format (RX8E/RX28) | 4-7 | | 4-7 | RX2SA Format (RX8E/RX28) | 4-7 | | 4-8 | RX2DB Format (RX8E/RX28) | 4-7 | | 4-9 | RXES Format (RX8E) | | | 4-10 | RX2ES Format (RX28) | | | 4-11 | RX8E Write/Write Deleted Data/Read Example | | | 4-12 | RX8E Empty Buffer Example | | | 4-13 | RX8E Fill Buffer Example | | ## FIGURES (Cont) | Figure No. | Title | Page | |------------|---------------------------------------------------|------| | 4-14 | RX28 Write/Write Deleted Data/Read Example | 4-19 | | 4-15 | RX28 Fill Buffer Example | 4-21 | | 4-16 | RX28 Empty Buffer Example | 4-22 | | 4-17 | RXCS Format (RXI1/RXVI1) | 4-25 | | 4-18 | RXTA Format (RX11/RXV11) | 4-26 | | 4-19 | RXSA Format (RX11/RXV11) | | | 4-20 | RXDB Format (RX11/RXV11) | | | 4-21 | RXES Format (RX11/RXV11) | | | 4-22 | RX11/RXV11 Write/Write Deleted Data/Read Example | 4-32 | | 4-23 | RX11/RXV11 Empty Buffer Example | | | 4-24 | RX11/RXV11 Fill Buffer Example | | | 4-25 | RX2CS Format (RX211/RXV21) | | | 4-26 | RX2TA Format (RX211/RXV21) | | | 4-27 | R X2SA Format (R X211/RXV21) | | | 4-28 | RX2WC Format (RX211/RXV21) | | | 4-29 | RX2BA and RX2DB Format (RX211/RXV21) | | | 4-30 | RX2ES Format (RX211/RXV21) | | | 4-31 | RX211/RXV21 Write/Fill Buffer Example | | | 4-32 | RX211/RXV21 Read/Empty Buffer Example | | | 5-1 | RX02 System Block Diagram | | | 5-2 | Omnibus to RX8E/RX28 Interface Signals | | | 5-3 | Unibus to RX11/RX211 Interface Signals | | | 5-4 | LSI-11 Bus to RXV11/RXV21 Interface Signals | | | 5-5 | Interface to µCPU Controller Signals | | | 5-6 | μCPU Controller to Read/Write Electronics Signals | | | 5-7 | Read/Write Electronics to Drive Signals | | | 5-8 | RX8E/RX28 Interface Block Diagram | | | 5-9 | RX11 Interface Block Diagram | | | 5-10 | RXVII Interface Block Diagram | | | 5-11 | RX211 Interface Module Block Diagram | | | 5-12 | RXV21 Interface Module Block Diagram | | | 5-13 | μCPU Controller Block Diagram | | | 5-14 | Arithmetic and Logical Instruction Format | | | 5-15 | Branch Instruction Format | | | 5-16 | I/O Instruction Format | | | 5-17 | JMP/JSR Instruction Format | | | 5-18 | Initialize Routine Flowchart | | | 5-19 | Find Header Subroutine Flowchart | | | 5-20 | Read Address Mask Subroutine Flowchart | | | 5-21 | Read Sector Subroutine Flowchart | | ## FIGURES (Cont) | Figure No. | Title | Page | |------------|------------------------------------------------------------------|-------| | 5-22 | Write/Write Sector Subroutine Flowchart | 5-40 | | 5-23 | Read Error Register and Set Density Subroutines Flowchart | | | 5-24 | Fill/Empty Buffer Routine Flowchart | | | 5-25 | Select Drive and Find Track Subroutines Flowchart | | | 5-26 | Decode Command Routine Flowchart | 5-46 | | 5-27 | Maintenance Read Status and Check Ready Subroutines Flowchart | | | 5-28 | Get Parameter, Step Head, Wait, Wait Run, and Write Zeros | - | | | Subroutines Flowchart | 5-49 | | 5-29 | Find Sector, Send Word 12, Send Word 8, Get Command and Get Word | ***** | | | Flowchart Subroutines | 5-50 | | 5-30 | Maintenance Check Ready Subroutine Flowchart | | | 5-31 | Read/Write Electronics Block Diagram | | | 5-32 | Data SYNC Timing Diagram | | | 5-33 | Disk Drive Mechanical System | | | 5-34 | Drive Mechanism | | | 5-35 | Centering Cone and Drive Hub | | | 5-36 | Positioning Mechanism | | | 6-1 | RX02 Component Location Diagram. | | | 6-2 | Drive Motor Positioning Diagram | | | A-1 | RX02 System Interconnection Diagram | | | A-I | K XU2 System Interconnection Diagram | A | ### **TABLES** | Table No. | Title | Page | |-----------|-------------------------------------------|------| | 1-1 | Data Address Mark Code | 1-14 | | 2-1 | RX02 Configurations | 2-5 | | 2-2 | Controller Configuration Switch Positions | | | 2-3 | Interface Code/Jumper Configuration | | | 3-1 | Operator Troubleshooting Guide | 3-3 | | 4-1 | Device Code Switch Selection | 4-2 | | 5-1 | C Line Transfer Control Signals | 5-13 | | 6-1 | Troubleshooting Chart | | | 6-2 | Error Code Probable Causes | | | 6-3 | M7745 Connectors | | #### **PREFACE** The manual is intended to provide the user with sufficient information to correctly set up and operate the RX02 Floppy Disk System in any of the various configurations that are available for use with the PDP-8, PDP-11, or LSI-11 computers. The manual presents general, installation, user, programming and maintenance information for the RX02 Floppy Disk System and the interface options associated with the PDP-8, PDP-11, and LSI-11 computer systems. ## CHAPTER 1 GENERAL INFORMATION #### 1.1 INTRODUCTION The RX02 is a low cost, random access mass memory device that stores data in fixed length blocks on flexible diskettes with preformatted industry standard headers. The RX02 interfaces with either a PDP-8, a PDP-11, or an LSI-11 system. Various interface modules are selected according to the computer being used and either single or double density recording. The various configurations are: | Designation | Computer | Interface<br>Module | Recording<br>Density | |-------------|----------|---------------------|----------------------| | RX8E | PDP-8 | M8357 | Single | | RX28 | PDP-8 | M8357 | Single or Double | | RXII | PDP-11 | M7846 | Single | | RX211 | PDP-11 | M8256 | Single or Double | | RXVI1 | LSI-11 | M7946 | Single | | RXV21 | LSI-11 | M8029 | Single or Double | #### NOTE The single density recording configurations RX8E, RX11, and RXV11 are compatible with the RX01 Floppy Disk System when the M7744 controller module has been switched to be compatible with these configurations. (See Table 2-2.) The RX02 consists of one or two flexible disk drives, a single read/write electronics module, a microprogrammed controller module, and a power supply, enclosed in a rack-mountable, 10-1/2 inch, self-cooled chassis. A cable is included for connection to either a PDP-8 interface module, a PDP-11 interface module, or an LSI-11 interface module. The amount of data that can be stored on the RX02 varies according to the configuration. For each drive system using double density recording, up to 512K 8-bit bytes of data (PDP-8, PDP-11, LSI-11) or 256K 12-bit words (PDP-8) can be stored and retrieved. For each drive system using single density recording, up to 256K 8-bit bytes of data or 128 12-bit words (PDP-8) can be stored and retrieved. The RX02 interfaces with IBM-compatible devices when single density data recording is used. If two drives are used, the recording density can be different for each drive. For single or double density recording, the RX02 is used with either an M8357 interface module (PDP-8), an M8256 interface module (PDP-11), or an M8029 interface module (LSI-11). The interface modules convert the RX02 I/O bus to the bus structure of the computer being used. Each module controls the interrupts to the CPU initiated by the RX02 and handles the data interchange between the RX02 and the host computer. Each interface module is powered by the host processor. In addition, the RX02 is used for single density recording when it is configured to be compatible with the RX01. The interface module used is either an M8357 (PDP-8), an M7846 (PDP-11), or an M7946 (LSI-11). To record or retrieve data the RX02 performs implied seeks. Given an absolute sector address, the RX02 locates the desired sector and performs the indicated function, including automatic head position verification and hardware calculation and verification of the cyclic redundancy check (CRC) character. The CRC character that is read and generated is compatible with IBM 3740 equipment. #### 1.2 GENERAL DESCRIPTION An RX02 Floppy Disk System consists of the following components: M7744 Controller Module M7745 Read/Write Electronics Module H771-A, -C, or -D Power Supply RX02-CA Floppy Disk Drive (60 Hz max of 2) RX02-CC Floppy Disk Drive (50 Hz max of 2) One interface module is used: M8357 (PDP-8, Programmed I/O) M7846 (PDP-11, Programmed I/O) M7946 (LSI-11, Programmed I/O) M8029 (LSI-11 with DMA) All components except the interface modules are housed in a 10-1/2 inch rack-mountable box. The power supply, M7744 module, and M7745 module are mounted above the drives. Interconnection from the RX02 to the interface is with a 40-conductor BC05L-15 cable of standard length (15 ft). Figure 1-1 is a configuration drawing of the system: part A shows the configuration for a bus interface with DMA; part B shows the configuration for all Omnibus interfaces (programmed I/O); part C shows the configuration for a bus interface (programmed I/O) that is RX01 compatible. Figure 1-2 is a front view of a dual drive system. #### 1.2.1 Interface Modules The interface modules plug into a slot on the bus for PDP-8, PDP-11, and LSI-11 computers. Figure 1-3 shows the outline of the various modules and areas of interest on each module. #### 1.2.2 Microprogrammed Controller The M7744 microprogrammed controller module is located in the RX02 cabinet as shown in Figure 1-4. The M7744 is hinged on the left side and lifts up for access to the M7745 read/write electronics module. #### 1.2.3 Read/Write Electronics The M7745 read/write electronics module is located in the RX02 cabinet as shown in Figure 1-4. #### 1.2.4 Electromechanical Drive A maximum of two drives can be attached to the read/write electronics. The electromechanical drives are mounted side by side under the read/write electronics board (M7745). Figure 1-5 is an underside view of the drive showing the drive motor connected to the spindle by a belt. (This belt and the drive pulley are different on the 50 Hz and 60 Hz units; see Paragraph 2.1.3.2 for complete input power modification requirements.) C. Bus Interface, Programmed I/O (RX01 Compatible) Figure 1-1 Floppy Disk Configuration MA-1824 Figure 1-2 Front View of the Floppy Disk System #### 1.2.5 Power Supply The H771 power supply is mounted at the rear of the RX02 cabinet as shown in Figure 1-4. The H771-A is rated at 60 Hz $\pm 1/2$ Hz over a voltage range of 90-128 Vac. The H771-C and -D are rated at 50 Hz + 1/2 Hz over four voltage ranges: ``` 90-120 Vac 100-128 Vac } 3.5 A circuit breaker; H771-C 184-240 Vac } 1.75 A circuit breaker; H771-D ``` Two configuration plugs are provided to adapt the H771-C or -D to each voltage range. This is not applicable to the H771-A. #### 1.3 OPTION DESCRIPTION The optional interface modules that are used to interface the RX02 with a PDP-8, PDP-11, and LSI-11 are listed in Paragraphs 1.1 and 1.2. (Each module is powered by the host processor.) The module selected is determined by the computer being used and whether the data interchange is between either IBM system 3740 compatible devices or DIGITAL system double density devices. Also, when an M7744 controller module's configuration switch is set to be compatible, the RX02 can operate as an RX01. The RX02 interfaces with IBM compatible devices when single density data recording is used. The RX02 interfaces with DIGITAL system double density recording devices when the controller module configuration switch is positioned to be compatible with RX28, RX211, and RXV21 configurations. Figure 1-3 Interface Modules Figure 1-4 Top View of RX02 #### 1.3.1 Operation For Single Density Recording Only (RX8E, RX11, RXV11) - 1.3.1.1 PDP-8 Operation The RX02 connects to the M8357 Omnibus interface module. This module converts the RX02 I/O bus to PDP-8 family Omnibus structure. It controls interrupts to the CPU initiated by the RX02, controls data interchange between the RX02 and the host CPU by programmed I/O, and handles input/output transfers used for maintenance status conditions. - 1.3.1.2 PDP-11 Operation The RX02 connects to the M7846 Unibus interface module. This module converts the RX02 I/O bus to PDP-11 Unibus structure. It controls interrupts to the CPU initiated by the RX02, decodes Unibus addresses for register selection, and handles data interchange between the RX02 and the host CPU main memory by programmed I/O. 1-6 Figure 1-5 Underside View of Drive 1.3.1.3 LSI-11 Operation – The RX02 connects to the M7946 LSI-11 bus interface module. This module converts the RX02 I/O bus to the LSI-11 bus structure. It controls interrupts to the CPU initiated by the RX02, decodes LSI-11 bus addresses for register selection, and transfers data between the RX02 and the host CPU main memory by programmed I/O. #### 1.3.2 Operation For Single or Double Density Recording (RX28, RX211, RXV21) - 1.3.2.1 PDP-8 Operation The RX02 connects to the M8357 Omnibus interface module. This module converts the RX02 I/O bus to PDP-8 family Omnibus structure. It controls interrupts to the CPU initiated by the RX02, controls transfer of data between the RX02 and host CPU by programmed I/O, and handles input/output transfer used to test status conditions. - 1.3.2.2 PDP-11 Operation The RX02 connects to the M8256 Unibus interface module. This module converts the RX02 I/O bus to PDP-11 Unibus structure. It controls interrupts to the CPU initiated by the RX02, decodes Unibus addresses for register selection, and initiates NPR requests to transfer data between the RX02 and the host CPU main memory. - 1.3.2.3 LSI-11 Operation The RX02 connects to the M8029 LSI-11 bus interface module. This module converts the RX02 I/O bus to the LSI-11 bus structure. It controls interrupts to the CPU initiated by the RX02, decodes LSI-11 bus addresses for register selection, and initiates NPR requests to transfer data between the RX02 and the host CPU main memory. #### 1.4 SPECIFICATIONS System Reliability Minimum number of revo- lutions per track Seek error rate Soft data error rate Hard data error rate 3 million/media (head loaded) 1 in 106 seeks 1 in 109 bits read or written 1 in 1012 bits read or written #### NOTE The above error rates only apply to DEC approved media that is properly cared for. Seek error and soft data errors are usually attributable to random effects in the head/media interface, such as electrical noise, dirt, or dust. Both are called "soft" errors if the error is recoverable in 10 additional tries or less. "Hard" errors cannot be recovered. Seek error retries should be preceded by a recalibrate. #### Drive Performance | Capacity | Recording | 8-bit bytes | 12-bit words | |--------------|-----------|-------------|--------------| | Per diskette | FM | 256,256 | 128,128 | | | MFM | 512,512 | 256,256 | | Per track | FM | 3,328 | 1,664 | | | MFM | 6,656 | 3,328 | | Per sector | FM | 128 | 64 | | | MFM | 256 | 128 | Data transfer rate Diskette to controller buffer 4 μs/data bit (FM) 2 μs/data bit (MFM) Buffer to CPU interface $1.2 \,\mu s/bit$ #### NOTE #### PDP-8 interface can operate in 8- or 12-bit modes under software control. Track-to-track move 6 ms/track maximum Head settle time 25 ms maximum Rotational speed 360 rpm $\pm$ 2.5%; 166 ms/rev nominal Recording surfaces per disk Tracks per disk Sectors per track Recording technique Bit density maximum on inner track Track density Average access 77 (0-76) or (0-114<sub>8</sub>) 26 (1-26) or (0-32<sub>8</sub>) Double frequency (FM) or modified MFM 3200 bpi (FM) or modified (MFM) 48 tracks/inch 262 ms, computed as follows: Seek Settle Rotate 77 tks/3 ×6 ms + + 166 ms/2 = 262 ms25 ms #### **Environmental Characteristics** #### Temperature RX02, operating 15° to 32° C (59° to 90° F) ambient: maximum temperature gradient = 11° C/hr (20° F/hr) RX02, nonoperating $-35^{\circ}$ to $+60^{\circ}$ C ( $-30^{\circ}$ to $+140^{\circ}$ F) $-35^{\circ}$ to $+52^{\circ}$ C ( $-30^{\circ}$ to $+125^{\circ}$ F) Media, nonoperating #### NOTE #### Media temperature must be within operating temperature range before use. Heat Dissipation (RX02 System) Less than 225 Btu/hr Relative humidity RX02, operating 25° C (77° F) maximum wet bulb 2° C (36° F) minimum dew point 20% to 80% relative humidity RX02, nonoperating 5% to 98% relative humidity (no condensation) Media, nonoperating 10% to 80% relative humidity Magnetic field Media exposed to a magnetic field strength of 50 oersteds or greater may lose data. Interface modules Operating temperature 5° to 50° C (41° to 122° F) Relative humidity Maximum wet bulb 10% to 90% 32° C (90° F) Minimum dew point 2° C (36° F) #### Electrical Power consumption RX02 5 A at +5 Vdc, 25 W; 0.14 A at -5 Vdc, 0.7 W; 1.3 A t +24 Vdc, 31 W PDP-11 interface (M7846, 1.8 A at 5 Vdc M8256) PDP-8 interface (M8357) 1.5 A at 5 Vdc LSI-11 interface (M7946, 1.8 A at 5 Vdc M8029) 4 A at 115 Vac AC power 2 A at 230 Vac #### 1.5 SYSTEMS COMPATIBILITY This section describes the physical, electrical, and logical aspects of compatibility for data interchange with IBM system 3740 devices and for data interchange with double density devices. #### 1.5.1 Media The media used on the RX02 Floppy Disk system is compatible with the IBM 3740 family of equipment and is shown in Figure 1-6. The "diskette" media was designed by applying tape technology to disk architecture, resulting in a flexible oxide-on-mylar surface. The diskette is encased in a plastic envelope with a hole for the read/write head, a hole for the drive spindle hub, and a hole for the hard index mark. The envelope is lined with a fiber material that cleans the diskette surface. The media is supplied to the customer preformatted and pretested. Figure 1-6 Diskette Media #### 1.5.2 Recording Scheme There are two recording schemes used in the RX02: double frequency (FM) and modified Miller code (MFM). The FM scheme is used for single density data recording which is compatible with IBM system 3740 devices. (When this recording scheme is used and the RX02 is configured as shown in Figure 1-1 part C, the RX02 is compatible with the RX01.) The MFM scheme is used for double density data recording which is compatible with DIGITAL double density devices but is not compatible with other manufacturers. 1.5.2.1 Double Frequency (FM) – For the double frequency recording scheme data is recorded between bits of a constant clock stream. The clock stream consists of a continuous pattern of one flux reversal every four $\mu$ s (Figure 1-7). A data "one" is indicated by an additional reversal between clocks (i.e., doubling the bit stream frequency; hence the name). A data "zero" is indicated by no flux reversal between clocks. A continuous stream of ones, shown in the bottom waveform in Figure 1-7, would appear as a "2F" bit stream, and a continuous stream of zeros, shown in the top waveform in Figure 1-7, would appear as a "IF" or fundamental frequency bit stream. 1.5.2.2 Miller Code (MFM) - MFM or Miller code encodes clocks between data bits of a continuous data stream. The data stream consists of flux reversals for a data "one" and no flux reversal for a data "zero." A clock is recorded only between data "zeros." Because it is possible to have double density data fields map into a preamble and ID mark, the MFM encoding is modified slightly to prevent a false header from being detected within a double density data field. #### NOTE The modified MFM encoding is not compatible with other manufacturers. Figure 1-7 Flux Reversal Patterns for FM The encoding algorithms for implementing modified MFM are: Encoding Algorithm #1 (MFM or Miller Code Algorithm) | | Data | Encoded | | | |----|--------|---------|----|--------| | Dn | Dn + 1 | Dn | Cn | Dn + 1 | | 0 | 0 | 0 | 1 | 0 | | ì | 0 | ] 1 | Ū | j o | | 0 | 1 | 0 | 0 | 1 | | 1 | 1 | 1 | 0 | 1 | Encoding Algorithm #2 (MFM Modified Algorithm) | Data | | | | | | | | |------|--------|--------|--------|--------|--------|--|--| | Dn | Dn + 1 | Dn + 2 | Dn + 3 | Dn + 4 | Dn + 5 | | | | 0 | 1 | 1 | 1 | 1 | 0 | | | | | Encoded Data | | | | | | | | | | |----|--------------|--------|--------|--------|--------|--------|--------|--------|--------|--------| | Dn | Cn | Dn + 1 | Cn + 1 | Dn + 2 | Cn + 2 | Dn + 3 | Cn + 3 | Dn + 4 | Cn + 4 | Dn + 5 | | 0 | 1 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 1 | 0 | The decoding algorithm used in data separation is: | | Encoded | Decoded | | | |----|---------|---------|-----|--------| | Dn | Cn | Dn + 1 | Dn | Dn + 1 | | 0 | 0 | 0 | 1 | 1 | | 0 | i | 0 | 0 | 0 | | ! | 0 | 0 | 1 | 0 | | 0 | 0 | ł | 0 | j | | 1 | 0 | 1 | ] 1 | ì | Figure 1-8 shows the waveforms that are generated for a data stream of zeros and ones when FM code, MFM code, and modified MFM code are used. #### 1.5.3 Logical Format Data is recorded on only one side of the diskette. This surface is divided into 77 concentric circles or "tracks" numbered 0-76. Each track is divided into 26 sectors numbered 1-26 (Figure 1-9). Each sector contains two major fields: the header field and the data field (Figure 1-10). Figure 1-8 FM Versus MFM Encoding Figure 1-9 Track Format (Each Track) Figure 1-10 Sector Format (Each Sector) - 1.5.3.1 Header Field Description The header field is broken into seven bytes (eight bits/byte) of information and is preceded by a field of at least six bytes of zeros for synchronization. The header and its preamble are always recorded in FM. - 1. Byte No. 1: ID Address Mark This is a unique stream of flux reversals (not a string of data bits) that is decoded by the controller to identify the beginning of the header field. (Data = FE hex, clock = C7 hex.) - 2. Byte No. 2: Track Address This is the absolute (0-1148) binary track address. Each sector contains track address information to identify its location on 1 of the 77 tracks. - 3. Byte No. 3: Zeros - 4. Byte No. 4: Sector Address This is the absolute binary sector address (1-32<sub>8</sub>). Each sector contains sector address information to identify its circumferential position on a track. There is no sector 0. - 5. Byte No. 5: Zeros - 6,7. Bytes No. 6 and 7: CRC This is the cyclic redundancy check character that is calculated for each sector from the first five header bytes using the IBM 3740 polynomial. - 1.5.3.2 Data Field Description The data field contains either 131<sub>10</sub> or 259<sub>10</sub> bytes of information depending on the recording scheme. This field is preceded by a field of zeros for synchronization and the header field (Figure 1-10). - 1. Byte No. 1: Data or Deleted Data Address mark This byte is always recorded in FM and is unique because it contains missing clocks. It is decoded by the controller to identify the beginning of a data field. The deleted data mark is not used during normal operation but the R X02 can identify and write deleted data marks under program control as required. There is a unique address mark for each density as shown in the following table. One of these marks is the first byte of each data field. Table 1-1 Data Address Mark Code | | | Hex Byte | | |---------|----------|----------|------------| | Mark | Density | Data | Clock | | | FM | FB | C7 | | Data | MFM mod. | FD | <b>C</b> 7 | | DELETED | FM | F8 | C7 | | DATA | MFM mod. | F9 | C7 | 2. Bytes No. 2: -129 (FM) or -257 (MFM modified) – This is the data field and it can be recorded in either FM or MFM (modified). It is used to store 128<sub>10</sub> or 256<sub>10</sub> (depending upon encoding) 8-bit bytes of information. ## NOTE Partial data fields are not recorded. - 3. Bytes No. 130 and 131 or 258 and 259 These bytes comprise the CRC character that is calculated for each sector from the first 129 or 257 data field bytes using the industry standard polynomial division algorithm designed to detect the types of failures most likely to occur in recording on the floppy media. These bytes will be recorded with the same encoding scheme as the data field. - 1.5.3.3 Track Usage In the IBM 3740 system, some tracks are commonly designated for special purposes such as error information, directories, spares, or unused tracks. The RX02 is capable of recreating any system structure through the use of special systems programs, but normal operation will make use of all the available tracks as data tracks. Any special file structures must be accomplished through user software. - 1.5.3.4 CRC Capability Each sector has a two-byte header CRC character and a two-byte data CRC character to ensure data integrity. The CRC characters are generated by the hardware during a write operation and checked to ensure all bits were read correctly during a read operation. The CRC character is the same as that used in IBM 3740 series equipment. #### CHAPTER 2 INSTALLATION #### 2.1 SITE PREPARATION This chapter contains information that is required for site preparation, unpacking, installation, and testing of the RX02 Floppy Disk System. Information is also provided to identify the various system configurations that are available. #### 2.1.1 Space The RX02 is a cabinet-mountable unit that may be installed in a standard Digital Equipment Corporation cabinet. This rack-mountable version is approximately 28 cm high, (10-1/2 inches), 48 cm wide, (19 inches) and 42 cm deep (16-1/2 inches) as shown in Figure 2-1. Figure 2-1 RX02 Outline Dimensions 2-1 When the RX02 is mounted in a cabinet (Figure 2-2), provision should be made for service clearances of approximately 56 cm (22 inches) at the front and rear of the cabinet so that the RX02 can be extended or the cabinet rear door opened. Figure 2-2 Cabinet Layout Dimensions #### 2.1.2 Cabling The standard interface cable provided with an RX02 (BC05L-15) is 4.6 m (15 ft) in length; the positioning of the RX02 in relation to the central processor should be planned to take this into consideration. The RX02 should be placed near the control console or keyboard so that the operator will have easy access to load or unload disks. The position immediately above the CPU is preferred. The ac power cord is about 2.7 m (9 ft) long. #### 2.1.3 AC Power 2.1.3.1 Power Requirements – The RX02 is designed to use either a 60 Hz or a 50 Hz power source. The 60 Hz version will operate from 90–128 Vac, without modifications, and will use less than 4 A operating. The 50 Hz version will operate within four voltage ratings and will require field verification/modification to ensure that the correct voltage option is selected. The voltage ranges of 90–120 Vac and 184–240 Vac will use less than 4 A operating. The voltage ranges of 100–128 Vac and 200–256 Vac will use less than 2 A. Both versions of the RX02 will be required to receive the input power from an ac source (e.g., 861 power control) that is controlled by the system's power switch. 2.1.3.2 Input Power Modification Requirements – The 60 Hz version of the RX02 uses the H771-A power supply and will operate on 90–128 Vac, without modification. To convert to operate on a 50 Hz power source in the field, the H771-A supply must be replaced with an H771-C or -D (Figure 1-4) and the drive motor belt and drive motor pulley must be replaced (Figure 1-5). The H771-C operates on a 90–120 Vac or 100–128 Vac power source. The H771-D operates on a 184–240 Vac or 200–256 Vac power source. To convert the H771-C to the higher voltage ranges or the H771-D to the lower voltage ranges, the power harness and circuit breaker must be changed. See Figure 2-3 for the appropriate jumper and circuit breaker. | VOLTAGE (VAC) | JUMPER | CIRCUIT BREAKER | |---------------|-------------|---------------------| | 90-120 | 70-10696-02 | 3.5 A, 12-12301-01 | | 100-128 | 70-10696-01 | 3.5 A, 12-12301-01 | | 184-240 | 70-10696-04 | 1.75 A, 12-12301-00 | | 200-256 | 70-10696-03 | 1.75 A, 12-12301-00 | MA-1855 Figure 2-3 RX02 Rear View #### 2.1.4 Fire and Safety Precautions The RX02 Floppy Disk System presents no additional fire or safety hazards to an existing computer system. Wiring should be carefully checked, however, to ensure that the capacity is adequate for the added load and for any contemplated expansion. #### 2.2 CONFIGURATION GUIDELINES The most common RX02 Floppy Disk System configurations available are listed in Table 2-1. Each interface module listed in the table plugs into a computer bus; it is compatible with the applicable computer so that there is adequate power to operate each module. The interconnections between each interface module and the RX02 controller for each of the configurations in Table 2-1 is by a BC05L-15 cable which is 4.6 m (15 ft) maximum. (See Table 2-2 for the controller module configuration switch positions.) #### NOTE For single drive configurations, the drive will be identified as drive 0 and will be mounted as the left drive. For dual drive configurations, the left drive will be identified as drive 0 and the right drive will be identified as drive 1. #### 2.3 ENVIRONMENTAL CONSIDERATIONS #### 2.3.1 General The RX02 is capable of efficient operation in computer environments; however, the parameters of the operating environment must be determined by the most restrictive facets of the system, which in this case are the diskettes. #### 2.3.2 Temperature, Relative Humidity The operating ambient temperature range of the diskette is 15° to 32° C (59° to 90° F) with a maximum temperature gradient of 11° C/hr (20° F/hr). The media nonoperating temperature range (storage) is increased to -34.4° to 51.6° C (-30° to 125° F), but care must be taken to ensure that the media has stabilized within the operating temperature range before use. This range will ensure that the media will not be operated above its absolute temperature limit of 51.6° C (125° F). Humidity control is important in any system because static electricity can cause errors in any CPU with memory. The RX02 is designed to operate efficiently within a relative humidity range of 20 to 80 percent, with a maximum wet bulb temperature of 25° C (77° F) and a minimum dew point of 2° C (36° F). #### 2.3.3 Heat Dissipation The heat dissipation factor for the RX02 Floppy Disk System is less than 225 Btu/hr. By adding this figure to the total heat dissipation for the other system components and then adjusting the result to compensate for such factors as the number of personnel, the heat radiation from adjoining areas, and sun exposure through windows, the approximate cooling requirements for the system can be determined. It is advisable to allow a safety margin of at least 25 percent above the maximum estimated requirements. #### 2.3.4 Radiated Emissions Sources of radiation, such as FM radio broadcasts, vehicle ignitions, and radar transmitters located close to the computer system, may affect the performance of the RX02 Floppy Disk System because of the possible adverse effects magnetic fields can have on diskettes. A magnetic field with an intensity of 50 oersteds or greater might destroy all or some of the information recorded on the diskette. Table 2-1 RX02 Configurations | Computer | System<br>Designation | μCPU<br>Controller | Interface<br>Module | RX02<br>Model No. | Drive | |----------|-----------------------|--------------------|---------------------|-------------------------------|-------------------------------------------------------------------| | | RX8E | M7744 | M8357 | RX02-AA<br>RX02-AC<br>RX02-AD | Single/115 V, 60 Hz<br>Single/115 V, 50 Hz<br>Single/230 V, 50 Hz | | | | | | RX02-BA<br>RX02-BC<br>RX02-BD | Dual/115 V, 60 Hz<br>Dual/115 V, 50 Hz<br>Dual/230 V, 50 Hz | | PDP-8 | RX28E | M7744 | M8357 | RX02-AA<br>RX02-AC<br>RX02-AD | Single/115 V, 60 Hz<br>Single/115 V, 50 Hz<br>Single/230 V, 50 Hz | | | | | | RX02-BA<br>RX02-BC<br>RX02-BD | Dual/115 V, 60 Hz<br>Dual/115 V, 50 Hz<br>Dual/230 V, 50 Hz | | | RX11 | M7744 | M7846 | RX02-AA<br>RX02-AC<br>RX02-AD | Single/115 V, 60 Hz<br>Single/115 V, 50 Hz<br>Single/230 V, 50 Hz | | | | | | RX02-BA<br>RX02-BD | Dual/115 V, 60 Hz<br>Dual/230 V, 50 Hz | | PDP-11 | RX211 | M7744 | M8256 | RX02-AA<br>RX02-AC<br>RX02-AD | Single/115 V, 60 Hz<br>Single/115 V, 50 Hz<br>Single/230 V, 50 Hz | | | | | | RX02-BA<br>RX02-BC<br>RX02-BD | Dual/115 V, 60 Hz<br>Dual/115 V, 50 Hz<br>Dual/230 V, 50 Hz | | | RXVII | M7744 | M7946 | RX02-AA<br>RX02-AC<br>RX02-AD | Single/115 V, 60 Hz<br>Single/115 V, 50 Hz<br>Single/230 V, 50 Hz | | | | | | RX02-BA<br>RX02-BC<br>RX02-BD | Dual/115 V, 60 Hz<br>Dual/115 V, 50 Hz<br>Dual/230 V, 50 Hz | | LSI-11 | RXV21 | M7744 | M8029 | RX02-AA<br>RX02-AC<br>RX02-AD | Single/115 V, 60 Hz<br>Single/115 V, 50 Hz<br>Single/230 V, 50 Hz | | | | | | RX02-BA<br>RX02-BC<br>RX02-BD | Dual/115 V, 60 Hz<br>Dual/115 V, 50 Hz<br>Dual/230 V, 50 Hz | Table 2-2 Controller Configuration Switch Positions | Interface | S1-1 | S1-2 | 2<br>1 | S1 | |---------------------------------------------|------------------|------------------|--------|----------| | RX211, RXV21,<br>RX8E, RX11, RXV11,<br>RX28 | OFF<br>ON<br>OFF | ON<br>OFF<br>OFF | ON | Top View | #### 2.3.5 Cleanliness Although cleanliness is important in all facets of a computer system, it is particularly important in the case of moving magnetic media, such as the RX02. Diskettes are not sealed units and are vulnerable to dirt. Such minute obstructions as dust specks or fingerprint smudges may cause data errors. Therefore, the RX02 should not be subjected to unusually contaminated atmospheres, especially one with abrasive airborne particles. #### NOTE Removable media involve use, handling, and maintenance which are beyond DIGITAL's direct control. DIGITAL disclaims responsibility for performance of the equipment when operated with media not meeting DIGITAL specifications or with media not maintained in accordance with procedures approved by DIGITAL. DIGITAL shall not be liable for damages to the equipment or to media resulting from such operation. #### 2.4 UNPACKING AND INSPECTION #### 2.4.1 General The RX02 Floppy Disk System can be shipped in a cabinet as an integral part of a system or in a separate container. If the RX02 is shipped in a cabinet, the cabinet should be positioned in the final installation location before proceeding with the installation. #### 2.4.2 Tools Installation of an RX02 Floppy Disk System requires no special tools or equipment. Normal hand tools are all that are necessary. However, a forklift truck or pallet handling equipment may be needed for receiving and installing a cabinet-mounted system. #### 2.4.3 Unpacking #### 2.4.3.1 Cabinet-Mounted - 1. Remove the protective covering over the cabinet. - 2. Remove the restraint on the rear door latch and open the door. - 3. Carefully roll the cabinet off the pallet; if a forklift is available, it should be used to lift and move the cabinet. - 4. Remove the shipping restraint from the RX02 and save it for possible reuse. - 5. Slide the RX02 out on the chassis slides and visually inspect for any damage as indicated in Paragraph 2.4.3.3. #### 2.4.3.2 Separate Container - 1. Open the carton (Figure 2-4) and remove the packing pieces. - Lift the RX02 out of the carton. - 3. Remove the shipping fixtures from both sides of the RX02 and inspect for shipping damage as indicated in Paragraph 2.4.3.3. - 4. Attach the inside tracks of the chassis slides provided in the carton to the RX02 (Figure 2-1). - 5. Locate the proper holes in the cabinet rails (Figure 2-5) and attach the outside tracks to the cabinet. - 6. Place the tracks attached to the RX02 inside the extended cabinet tracks and slide the unit in until the tracks lock in the extended position. - 7. Attach the front bezel with the screws supplied. - 8. Locate the RX02 cover in the cabinet above the unit and secure it to the cabinet rails (Figure 2-5). #### 2.4.3.3 Inspection - 1. Inspect the front cover(s) of the RX02 to be sure it operates freely. Compress the latch which allows the spring-loaded front cover to open. - 2. Inspect the rear of the RX02 chassis to be sure there are no broken or bent plugs. Also, be sure the fuse is not damaged. - 3. Visually inspect the interior of the unit for damaged wires or loose hardware. - 4. Loosen the screws securing the hinged upper module (M7744) and raise the module so that modules M7744 and M7745 can be inspected for damaged components or wires. - 5. Verify that the items listed on the shipping order are included in the shipment. Be sure the interface cable (BC05L-15) and the appropriate interface module are included. #### **NOTE** If any shipping damage is found, the customer should be notified at this time so he can contact the carrier and record the information on the acceptance form. #### 2.5 INSTALLATION - 1. Ensure that power for the system is off. - 2. Loosen the screws securing the upper module (M7744) and swing it up on the hinge. - Inspect the wiring and connectors for proper routing and ensure that they are seated correctly. - 4. This step is for 50 Hz versions only. Check the power configuration to ensure that the proper jumpers and the correct circuit breaker are installed (Figure 2-3). Figure 2-4 RX02 Unpacking Figure 2-5 RX02 Cabinet Mounting Information 5. Connect the BC05L-15 cable to the M7744 module and route it along the near side of the chassis through the back of the RX02 to the CPU; then connect it to the interface module for the PDP-8, PDP-11, or LSI-11. The cable is connected to the M7744 module with the red stripe on the left, looking from the component side of board; the cable is connected to the interface module with the red stripe toward the center of the module. - 6. Refer to Table 2-2 for the correct controller configuration switch positions. - 7. Refer to Table 2-3 for correct device code or addressing jumpers on the interface module. - 8. Insert the interface module into the Omnibus (PDP-8), available SPC slot (PDP-11), or LSI bus (LSI-11). The PDP-11 and LSI-11 interface modules must be inserted in the lowest numbered available option location. Modules that use DMA processing should have a higher priority than programmed I/O devices. For modules using DMA processing in the PDP-11 SPC slot, ensure that the NPG (NPG IN, NPG OUT) line (CA1-CB1) is cut on the backplane. - 9. Connect the RX02 ac power cord into a switched power source. - 10. Turn the power on, watching for head movement on the drive(s) during the power up, initialize phase. The head(s) should move one track toward the center and back to track zero. Table 2-3 Interface Code/Jumper Configuration | PDP-8 | (M8357) | |--------|---------| | Davice | e Codes | | | SW1 | SW2 | SW3 | SW4 | SW5 | SW6 | |-------------------------------------------|-------------------------------------|-------------------------------------------|-------------------------------------|-------------------------------------|--------------------------------------------|--------------------------------------------| | 670X* 671X 672X 673X 674X 675X 676X 6777X | ON<br>ON<br>ON<br>OFF<br>OFF<br>OFF | ON<br>ON<br>OFF<br>OFF<br>ON<br>ON<br>OFF | ON<br>OFF<br>ON<br>OFF<br>ON<br>OFF | OFF<br>OFF<br>OFF<br>ON<br>ON<br>ON | OFF<br>OFF<br>ON<br>ON<br>OFF<br>OFF<br>ON | OFF<br>ON<br>OFF<br>ON<br>OFF<br>ON<br>OFF | | | | PDP-11 (M7846) | (M8256) | | |-----------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------| | BR Priority | Unibus Address 17 | 717X* | Vector Address (2 | 64 <sub>s</sub> )* | | BR7 - 54-08782<br>BR6 - 54-08780<br>BR5 - 54-08778*<br>BR4 - 57-08776 | A12 - Removed<br>A11 - Removed<br>A10 - Removed<br>A9 - Removed<br>A8 - Installed<br>A7 - Installed<br>A6 - Removed<br>A5 - Removed<br>A4 - Removed<br>A3 - Removed | SW10 OFF<br>SW9 OFF<br>SW8 OFF<br>SW7 OFF<br>SW6 ON<br>SW5 ON<br>SW4 OFF<br>SW3 OFF<br>SW2 OFF<br>SW1 OFF | V2 – Installed<br>V3 – Removed<br>V4 – Installed<br>V5 – Installed<br>V6 – Removed<br>V7 – Installed<br>V8 – Removed | SW1 ON<br>SW2 OFF<br>SW3 ON<br>SW4 ON<br>SW5 OFF<br>SW6 ON<br>SW7 OFF | ### LSI-11 (M8029) | Register Address* (17717X) | Vector Address (264 <sub>8</sub> ) | |---------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------| | A12 - Installed A11 - Installed A10 - Installed A9 - Installed A8 - Removed A7 - Removed A6 - Installed A5 - Installed A4 - Installed A3 - Installed A3 - Installed | V2 - Installed V3 - Removed V4 - Installed V5 - Installed V6 - Removed V7 - Installed V8 - Removed | Table 2-3 Interface Code/Jumper Configuration (Cont) | | LS | I-11 (M7946) | | |--------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------| | Vector | Address | Registe | er Address | | 2648 | 2708 | 177170 | 177150 | | V6 - Removed<br>V5 - Installed<br>V4 - Removed<br>V3 - Removed<br>V2 - Installed<br>V1 - Removed | W6 - Removed<br>W5 - Installed<br>W4 - Removed<br>W3 - Removed<br>W2 - Removed<br>W1 - Installed | W17 - Removed W16 - Removed W14 - Removed W13 - Installed W11 - Removed W10 - Removed W9 - Removed W8 - Removed W7 - Installed | W17 - Removed W16 - Removed W14 - Removed W13 - Installed W11 - Removed W10 - Removed W9 - Installed W8 - Removed W7 - Installed | #### 2.6 TESTING To test the operation of RX02, run the DEC diagnostics supplied. Perform the diagnostics in the sequence listed for the number of passes (time) indicated. RX8 or RX11 Diagnostic - 2 passes Data Reliability/Exerciser - 3 passes DECX-8 or DECX-11 - 10 minutes If any errors occur contact Field Service. ### CHAPTER 3 USER INFORMATION #### 3.1 CUSTOMER RESPONSIBILITY It is the user's responsibility to ensure that the RX02 is located and operated in an area that is free from excessive dust and dirt, and meets or exceeds the environmental conditions listed in Paragraph 1.4. The exterior of the RX02 should be kept clean. Also, it is the user's responsibility to ensure that the diskettes are handled and stored properly in order to prevent errors or data loss which might occur when recording or reading data; diskette handling procedures are described in Paragraph 3.2. #### 3.2 CARE OF MEDIA #### 3.2.1 Handling Practices and Precautions To prolong the diskette life and prevent errors when recording or reading, reasonable care should be taken when handling the media. The following handling recommendations should be followed to prevent unnecessary loss of data or interruptions of system operation. - 1. Do not write on the envelope containing the diskette. Write any information on a label prior to affixing it to the diskette. - 2. Paper clips should not be used on the diskette. - 3. Do not use writing instruments that leave flakes (such as lead or grease pencils) on the jacket of the media. - 4. Do not touch the disk surface exposed in the diskette slot or index hole. - 5. Do not clean the disk in any manner. - 6. Keep the diskette away from magnets or tools that may have become magnetized. Any disk exposed to a magnetic field may lose information. - 7. Do not expose the diskette to a heat source or sunlight. - 8. Always return the diskette to the envelope supplied with it to protect the disk from dust and dirt. Diskettes not being used should be stored in a file box if possible. - 9. When the diskette is in use, protect the empty envelope from liquids, dust, and metallic materials. - 10. Do not place heavy items on the diskette. - 11. Do not store diskettes on top of computer cabinets or in places where dirt can be blown by fans into the diskette interior. 12. If a diskette has been exposed to temperatures outside the operating range, allow five minutes for thermal stabilization before use. The diskette should be removed from its packaging during this time. #### CAUTION - · Do not use paper clips on diskettes. - Do not expose the diskette to a heat source or sunlight. - · Keep the diskettes from magnetic fields. - Do not write on the diskette with an instrument that leaves an impression or flakes. #### 3.2.2 Diskette Storage #### 3.2.2.1 Short Term (Available for Immediate Use) - 1. Store diskettes in their envelopes. - 2. Store horizontally, in piles of ten or less. If vertical storage is necessary, the diskettes should be supported so that they do not lean or sag, but should not be subjected to compressive forces. Permanent deformation may result from improper storage. - 3. Store in an environment similar to that of the operating system; at a minimum, store within the operating environment range. - 3.2.2.2 Long Term When diskettes do not need to be available for immediate use, they should be stored in their original shipping containers within the nonoperating range of the media. #### 3.2.3 Shipping Diskettes Data recorded on disks may be degraded by exposure to any sort of small magnet brought into close contact with the disk surface. If diskettes are to be shipped in the cargo hold of an aircraft, take precautions against possible exposure to magnetic sources. Because physical separation from the magnetic source is the best protection against accidental erasure of a diskette, diskettes should be packed at least 3 inches within the outer box. This separation should be adequate to protect against any magnetic sources likely to be encountered during transportation, making it generally unnecessary to ship diskettes in specially shielded boxes. When shipping, be sure to label the package: #### DO NOT EXPOSE TO PROLONGED HEAT OR SUNLIGHT. When received, the carton should be examined for damage. Deformation of the carton should alert the receiver to possible damage of the diskette. The carton should be retained, if it is intact, for storage of the diskette or for future shipping. #### 3.3 OPERATING INSTRUCTIONS ### NOTE The left drive is always identified as drive 0. The RX02 has no operator controls and indicators. The diskette is inserted on a drive after compressing the latch to allow the spring-loaded front cover to open. Place the diskette with the label or top up (the jacket seams are on the bottom) on the drive spindle. Close the front cover which will automatically lock when it is pushed down. Initialize the system (from the computer) and listen for audible clicking sounds which indicate the head is moving over the diskette; the RX02 is ready for use. Data storage and retrieval is controlled by the user's program. #### CAUTION Do not open the drive door while the diskette is in use; this results in errors. #### 3.4 OPERATOR TROUBLESHOOTING Table 3-1 is a list of possible problems and some probable causes the operator may encounter. If the problem cannot be corrected, refer the problem to DIGITAL Field Service. Table 3-1 Operator Troubleshooting Guide | Problem | Probable Cause | Correction | |------------------------------|-------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | No power (drive inoperative) | a. Power cord disconnected b. Blown fuse c. Circuit breaker open | a. Connect power cord b. Replace fuse c. Close circuit breaker | | Drive not ready | a. Drive door open b. Diskette improperly in- stalled | a. Close door<br>b. Properly seat diskette | | Error in recording | a. Diskette wear b. Diskette mounting hole c. Mismatch in recording density on a diskette | a. If worn, replace b. If the hole is not concentric, replace diskette c. If diskette data density is not compatible with data to be recorded, replace diskette with a new preformatted diskette. | #### CHAPTER 4 PROGRAMMING This chapter contains programming information for the following interface options: RX8E, RX28, RX11, RXV11, RX211, and RXV21. The RX8E and RX28 programming information is presented first, followed by the RX11 and RXV11 information, and then the RX211 and RXV21 information is presented. The RX8E, RX11, and RXV11 options are used for single density recording and are compatible with the RX01 Floppy Disk System. The RX28E, RX211, and RXV21 can be used for either single or double density recording. #### 4.1 RX8E and RX28 PROGRAMMING INFORMATION The RX8E interface allows two modes of data transfer: 8-bit word length and 12-bit word length. In the 12-bit mode, 64 words are written in a diskette sector, thus requiring 2 sectors to store 1 page of information. The diskette capacity in this mode is 128,128 12-bit words (1001 pages). In the 8-bit transfer mode, 128 8-bit words are written in each sector. Disk capacity is 256,256 8-bit words, which is a 33 percent increase in disk capacity over the 12-bit mode. The 8-bit mode must be used for generating IBM-compatible diskettes, since 12-bit mode does not fully pack the sectors with data. The hardware puts in the extra 0s. Data transfer requests occur 23 ms after the previous request was serviced for 12-bit mode (18 ms for 8-bit mode). There is no maximum time between the transfer request from the RX02 and servicing of that request by the host processor. This allows the data transfer to and from the RX02 to be interrupted without loss of data. The RX28 interface allows two modes of data transfer: 8-bit word length and 12-bit word length. For each mode of data transfer there can be either single density or double density storage of data. In the 12-bit mode single density recording, 64 words are written in a diskette sector, and the diskette capacity is 128,128 12-bit words; for double density, there are 128 words written in a sector with a diskette capacity of 256,256 12-bit words. In the 8-bit word mode single density recording, 128 8-bit bytes are written in each sector and the diskette capacity is 256,256 8-bit bytes; for double density, there are 256 8-bit bytes written in a sector with a diskette capacity of 512,512 8-bit bytes. (For the 12-bit mode, all 12-bit data words are loaded into the buffer and then the hardware forces zeros to add extra bits to the end of the buffer so that the buffer is filled.) #### 4.1.1 Device Codes The eight possible device codes that can be assigned to the interface are 70-77. These device codes define address locations of a specific device and allow up to eight RX8E/RX28 interfaces to be used on a single PDP-8. These multiple device codes are also shared with other devices. Depending on what other devices are on the system, the RX8E/RX28 device code can be selected to avoid conflicts. (Refer to the PDP-8 Small Computer Handbook for specific device codes.) The device codes are selected by switches according to Table 4-1. These switches control ac bits 6-8, while ac bits 3-5 are fixed at 1s. The device code is initially selected to be 70. Switches 7 and 8 are not connected and will not affect the device selection code. The switches are all located on a single DIP switch package that is located on the M8357 RX8E/RX28 interface board. Table 4-1 Device Code Switch Selection | Device<br>Code | S1 | S2 | S3 | <b>S4</b> | S5 | <b>S6</b> | S7 | S8 | |----------------|----|----|----|-----------|----|-----------|----|----| | 77 | 0 | 0 | 0 | 1 | 1 | 1 | X | X | | 76 | 0 | 0 | 1 | 1 | 1 | 0 | X | X | | 75 | 0 | 1 | 0 | 1 | 0 | 1 | XX | X | | 74 | 0 | 1 | 1 | 1 | 0 | 0 | X | X | | 73 | 1 | 0 | 0 | 0 | 1 | i | X | X | | 72 | 1 | 0 | 1 | 0 | 1 | 0 | X | X | | 71 | 1 | 1 | 0 | 0 | 0 | 1 | X | X | | 70 | 1 | 1 | 1 | 0 | 0 | 0 | X | X | | 0 (OFF) | 1 (ON) | |---------|------------| | | SI | | | <b>S</b> 2 | | | <b>S</b> 3 | | | <b>S4</b> | | | <b>S</b> 5 | | | <b>S</b> 6 | | | \$7 | | | S8 | #### 4.1.2 Instruction Set The RX8E/RX28 instruction set is listed below and described in the following paragraphs. When operating as an RX28, for the 8-bit mode, all instruction set commands are transferred in two 8-bit bytes. | IOT | Mnemonic | Description | |------|----------|-------------------------------------------| | 67x0 | | No Operation | | 67x1 | LCD | Load Command, Clear AC | | 67x2 | XDR | Transfer Data Register | | 67x3 | STR | Skip on Transfer Request Flag, Clear Flag | | 67x4 | SER | Skip on Error Flag, Clear Flag | | 67x5 | SDN | Skip on Done Flag, Clear Flag | | 67x6 | INTR | Enable or Disable Disk Interrupts | | 67x7 | INIT | Initialize Controller and Interface | 4.1.2.1 RX8E Load Command (LCD) - 67x1 - This command transfers the contents of the AC to the interface register and clears the AC. The RX02 begins to execute the function specified in AC 8, 9, and 10 on the drive specified by AC 7. A new function cannot be initiated unless the RX02 has completed the previous function. The command word is defined as shown in Figure 4-1. The command word is described in greater detail in Paragraph 4.1.3.1. Figure 4-1 LCD Word Format (RX8E) 4.1.2.2 RX28 Load Command – (First byte 67x1, Second byte 67x2) – This command transfers the contents of the AC to the interface register and clears the AC. The RX02 begins to execute the function specified in AC 8, 9, and 10 on the drive specified by AC 7. A new function cannot be initiated unless the RX02 has completed the previous function. The command word is defined as shown in Figure 4-2 and is described in greater detail in Paragraph 4.1.3.1. Figure 4-2 Command Word Format (RX28) When operating in the 8-bit mode, the Load command is stored in two 8-bit transfers. The first 8 bits of the command word (shown as bits 4-11 in Figure 4-2) are stored; then TR is asserted and an XDR is performed to transfer the remaining bits of data (bit 3, DEN, and bit 2, as shown in Figure 4-2) right-justified. The extra bits in the second 8-bit transfer are filled with zeros. Upon completing the transfer of the second 8-bit byte, Done is asserted to end the function. - 4.1.2.3 Transfer Data Register (XDR) 67x2 With the maintenance flip-flop cleared, this instruction operates as follows. A word is transferred between the AC and the interface register. The direction of transfer is governed by the RX02 and the length of the word transferred is governed by the mode selected (8-bit or 12-bit). When Done is negated, executing this instruction indicates to the RX02 that: - 1. The last data word supplied by the RX02 has been accepted by the PDP-8, and the RX02 can proceed, or - 2. The data or address word requested by the RX02 has been provided by the PDP-8, and the RX02 can proceed. A data transfer (XDR) from the AC always leaves the AC unchanged. If operation is in 8-bit mode, AC 0-3 are transferred to the interface register but are ignored by the RX02. Transfers into the AC are 12-bit jam transfers when in 12-bit mode. When in 8-bit mode, the 8-bit word is ORed into AC 4-11 and AC 0-3 remain unchanged. When the RX02 is done, this instruction can be used to transfer the RXES status word from the interface register to the AC. The selected mode controls this transfer as indicated above. - 4.1.2.4 STR 67x3 This instruction causes the next instruction to be skipped if the transfer request (TR) flag has been set by RX02 and clears the flag. The TR flag should be tested prior to transferring data or address words with the XDR instruction to ensure the data or address has been received or transferred, or after an LCD instruction to ensure the command is in the interface register. In cases where an XDR follows an LCD, the TR flag needs to be tested only once between the two instructions. - 4.1.2.5 SER 67x4 This instruction causes the next instruction to be skipped if the error flag has been set by an error condition in the RX02 and clears the flag. An error also causes the done flag to be set (Paragraph 4.1.3.6). - 4.1.2.6 SDN 67x5 This instruction causes the next instruction to be skipped if the done flag has been set by the RX02, indicating the completion of a function or detection of an error condition. If the done flag is set, it is cleared by the SDN instruction. This flag will interrupt if interrupts are enabled. - **4.1.2.7** INTR 67x6 This instruction enables interrupts by the done flag if AC 11=1. It disables interrupts if AC 11=0. - 4.1.2.8 INIT 67x7 The instruction initializes the RX02 by moving the head position mechanism of drive 1 (if drive 1 is available) to track 0. It reads track 1, sector 1 of drive 0. It zeros the error and status register and sets Done upon successful completion of Initialize. Up to 1.8 seconds may elapse before the RX02 returns to the Done state. Initialize can be generated by the program or by the Omnibus Initialize. #### 4.1.3 Register Description Only one physical register (the interface register) exists in the RX8E/RX28, but it may represent one of the six RX02 registers described in the following paragraphs, according to the protocol of the function in progress. 4.1.3.1 Command Register (Figures 4-3 and 4-4) – The command is loaded into the interface register by the LCD instruction for RX8E and by a load command (LCD and XDR) for the RX28 (Paragraphs 4.1.2.1 and 4.1.2.2). Figure 4-3 Command Register Format (RX8E) Figure 4-4 Command Register Format (RX28F) The function codes (bits 8, 9, 10) are summarized below and described in Paragraph 4.1.4. | Code | Function | |------|--------------------------------------| | 000 | Fill Buffer | | 001 | Empty Buffer | | 010 | Write Sector | | 011 | Read Sector | | 100 | Not used (RX8E) - Set Density (RX28) | | 101 | Read Status | | 110 | Write Deleted Data Sector | | 111 | Read Errror Register | | | _ | The DRV (UNIT) SEL bit (bit 7) selects one of the two drives upon which the function will be performed: | AC7 = 0 | Select drive 0 | |---------|----------------| | AC7 = 1 | Select drive I | The 8/12 bit (bit 5) selects the length of the data word. | AC 5 = 0 | 12-bit mode selected | |----------|----------------------| | AC 5 = 1 | 8-bit mode selected | The DEN bit (bit 3) for RX28 indicates the density for the function to be performed (0 = single, 1 = double). The RX8E/RX28 will initialize into 12-bit mode. 4.1.3.2 Error Code Register (Figure 4-5) - Specific error codes can be accessed by use of the read error code function (111) (Paragraph 4.1.4.9). The specific octal error codes are given in Paragraph 4.1.5. The maintenance bit (M bit) can be used to diagnose the RX8E interface under off-line and on-line conditions. The off-line condition exists when the BC05L-15 cable is disconnected from the RX02; the on-line condition exists when the cable is connected to the RX02. Figure 4-5 Error Code Register Format (RX8E/RX28A) If an LCD IOT (I/O transfer) is issued with AC 4 = 1, the maintenance flip-flop is set. When the maintenance flip-flop is set, the assertion of RUN following XDR instructions is inhibited, and all data register transfers (XDR) are forced into the AC. The maintenance bit allows the interface register to be written and read for maintenance checks. The maintenance flip-flop is cleared by Initialize or by a Load Command IOT with AC 4 = 0. The following paragraphs describe more explicitly how to use the maintenance bit in an off-line mode. The contents of the interface buffer cannot be guaranteed immediately following the first Load Command IOT, which sets the maintenance flip-flop. However, successive Load Command IOTs will guarantee the contents of the interface register. The contents of the interface register can then be verified by using the XDR IOT to transfer those contents into the AC. In addition, the maintenance flip-flop directly sets the skip flags, which will remain set as long as the maintenance flip-flop is set. Skipping on these flags as long as the maintenance flip-flop is set will not clear the flags. Setting and then clearing the maintenance flip-flop will leave the skip flags in a set condition. The skip IOTs can then be issued to determine whether or not a large portion of the interface skip logic is working correctly. With the maintenance flip-flop set, it can be determined if the interface is capable of generating an interrupt on the Omnibus. When the maintenance flip-flop is set, the done flag is set, and the interrupt enable flip-flop can be set by issuing an INTR IOT with AC bit 11=1. The combination of done and interrupt enable should generate an interrupt. The maintenance flip-flop can also be used to test the INIT IOT. The maintenance flip-flop is set and cleared to generate the flags, and INIT IOT is then executed. If execution of INIT IOT is internally successful, all of the flags and the interrupt enable flip-flop should be cleared if they were previously set. In the on-line mode, use of the maintenance bit should be restricted to writing and reading the interface register. The same procedure described to write and read the interface register in the off-line mode should be implemented in the on-line mode. Exiting from the on-line maintenance bit mode should be finalized by an initialize to the RX02. - 4.1.3.3 RX2TA RX Track Address (Figure 4-6) This register is loaded to indicate on which of the 77 (0-76) tracks a given function is to operate. It can be addressed only under the protocol of the function in progress (Paragraph 4.1.4). Bits 0-3 are unused and are ignored by the control. - 4.1.3.4 RX2SA RX Sector Address (Figure 4-7) This register is loaded to indicate on which of the 26 (1-26) sectors a given function is to operate. It can be addressed only under the protocol of the function in progress (Paragraph 4.1.4). Bits 0-3 are unused and are ignored by the control. Figure 4-6 RX2TA Format (RX8E/RX28) Figure 4-7 RX2SA Format (RX8E/RX28) - 4.1.3.5 RX2DB RX Data Buffer (Figure 4-8) All information transferred to and from the floppy media passes through this register and is addressable only under the protocol of the function in progress. The length of data transfer is either 8 or 12 bits, depending on the state of bit 5 of the command register when the Load Command IOT is issued (Paragraph 4.1.3.1). - 4.1.3.6 RX8E RX Error and Status (Figure 4-9) The RXES contains the current error and status conditions of the selected drive. This read-only register can be accessed by the read status function (101). The RXES is also available in the interface register upon completion of any function. The RXES is accessed by the XDR instruction. The meaning of the error bits is given below. Figure 4-8 RX2DB Format (RX8E/RX28) Figure 4-9 RXES Format (RX8E) | Bit No. | Description | |---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 11 | CRC Error - The cyclic redundancy check at the end of the data field has indicated an error. The data must be considered invalid; it is suggested that the data transfer be retried up to 10 times, as most data errors are recoverable (soft). | | 9 | Initialize Done – This bit indicates completion of the Initialize routine. It can be asserted due to RX02 power failure, system power failure, or programmable or bus Initialize. This bit is not available within the RXES from a read status function. | | 5 | Deleted Data (DD) – In the course of reading data, a deleted data mark was detected in the identification field. The data following will be collected and transferred normally as the deleted data mark has no further significance within the RX02. Any alteration of files or actual deletion of data due to this mark must be accomplished by user software. This bit will be set if a successful or unsuccessful Write Deleted Data function is performed. | | 4 | Drive Ready – This bit is asserted if the unit currently selected exists, is properly supplied with power, has a diskette installed properly, has its door closed, and has a diskette up to speed. | #### NOTE 1 This bit is only valid for either drive when retrieved via a Read Status function or for drive 0 upon completion of an Initialize. #### NOTE 2 If the error bit was set in the RX2CS but error bits are not set in the RXES, specific error conditions can be accessed via a read error register function. 4.1.3.7 RX28 – RX Error and Status (Figure 4-10) – The RX2ES contains the current error and status conditions of the selected drive. This read-only register can be accessed by the read status function (101). The RX2ES is also available in the interface register upon completion of any function. The RX2ES is accessed by the XDR instruction. The meaning of the error bits is given below. Figure 4-10 RX2ES Format (RX28) #### Bit No. Description - 11 CRC Error The cyclic redundancy check at the end of the data field has indicated an error. The data must be considered invalid; it is suggested that the data transfer be retried up to 10 times; as most data errors are recoverable (soft). - 10 Reserved. - Initialize Done This bit indicates completion of the Initialize routine, It can be asserted due to RX02 power failure, system power failure, or programmable or bus Initialize. This bit is not available within the RX2ES from a read status function. - 8 RX02 This bit is asserted if an RX02 system is being used. - DEN ERR This bit indicates that the density of the function does not agree with the drive density. Upon detection of this error the control terminates the operation and asserts error and done. - 6 DRV DEN This bit indicates the density of the diskette in the drive selected (0 = single, 1 = double). - Deleted Data (DD) In the course of reading data, a deleted data mark was detected in the identification field. The data following will be collected and transferred normally, as the deleted data mark has no further significance within the RX02. Any alteration of files or actual deletion of data due to this mark must be accomplished by user software. This bit will be set if a successful or unsuccessful write deleted data function is performed. - Drive Ready This bit is asserted if the unit currently selected exists, is properly supplied with power, has a diskette installed properly, has its door closed, and has a diskette up to speed. #### NOTE 1 This bit is only valid for either drive when retrieved via a read status function or for drive 0 upon completion of an Initialize. #### NOTE 2 If the error bit was set in thee RX2CS but error bits are not set in the RX2ES, specific error conditions can be accessed via a read error code function. #### 4.1.4 Function Code Description The RX8E/RX28 functions are initiated by means of the Load command described in Paragraphs 4.1.2.1 and 4.1.2.2. The done flag should be tested and cleared with the SDN instruction in order to verify that the RX8E/RX28 is in the Done state prior to issuing the command instruction. Upon receiving a command instruction while in the Done state, the RX8E/RX28 enters the Not Done state while the command is decoded. Each of the eight functions summarized below requires that a strict protocol be followed for the successful transfer of data, status, and address information. The protocol for each function is described in the following sections. A summary table is presented below. | | | AC | | | |-------|---|----|----|-------------------------------------| | Octal | 8 | 9 | 10 | Function | | 0 | 0 | 0 | 0 | Fill Buffer | | 2 | 0 | 0 | 1 | Empty Buffer | | 4 | 0 | 1 | 0 | Write Sector | | 6 | 0 | 1 | 1 | Read Sector | | 10 | 1 | 0 | 0 | Not Used (RX8E), Set Density (RX28) | | 12 | 1 | 0 | 1 | Read Status | | 14 | 1 | 1 | 0 | Write Deleted Data Sector | | 16 | 1 | 1 | 1 | Read Error Register | NOTE AC bit 11 is assumed to be 0 in the above octal codes since AC bit 11 can be 0 or 1. 4.1.4.1 Fill Buffer (000) – For RX8E this function is used to load the RX02 sector buffer from the host processor with 64 12-bit words if in 12-bit mode or 128 8-bit words if in 8-bit mode. For RX28 this function loads the sector buffer in 12-bit mode with 64 12-bit words for single density or 128 12-bit words for double density; in the 8-bit mode, the buffer is loaded with 128 8-bit bytes for single density or 256 8-bit bytes for double density. This instruction only loads the sector buffer. In order to complete the transfer to the diskette, another function, write sector, must be performed. The buffer may also be read back by means of the empty buffer function in order to verify the data. Upon decoding the fill buffer function, the RX02 will set the transfer request (TR) flag, signaling a request for the first data word. The TR flag must be tested and cleared by the host processor with the STR instructions prior to each successive XDR IOT (Paragraph 4.1.2.4). The data word can then be transferred to the interface register by means of the XDR IOT. The RX02 next moves the data word from the interface register to the sector buffer and sets the TR flag as a request for the next data word. The sequence above is repeated, until the sector buffer has been loaded (64 data transfers for 12-bit mode or 128 data transfers for 8-bit mode). After the 64th (or 128th) word has been loaded into the sector buffer, the RX2ES is moved to the interface register, and the RX02 sets the done flag to indicate the completion of the function. Therefore, it is unnecessary for the host processor to keep a count of the data transfers. Any XDR commands after Done is set will result in the RX2ES status word being loaded in the AC. The sector buffer must be completely loaded before the RX8E/RX28 will set Done and recognize a new command. An interrupt would now occur if Interrupt Enable were set. 4.1.4.2 Empty Buffer (001) – This function moves the contents of the sector buffer to the host processor. Upon decoding this function RX2ES bits are cleared and the TR flag is set with the first data word in the interface register. This TR flag signifies the request for a data transfer from the RX8E/RX28 to the host processor. The flag must be tested and cleared; then the word can be moved to the AC by an XDR command. The direction of transfer for an XDR command is controlled by the RX02. The TR flag is set again with the next word in the interface register. The above sequence is repeated until all words or bytes have been transferred, thus emptying the sector buffer. The done flag is then set after the RX2ES is moved in the interface register to indicate the end of the function. An interrupt would now occur if Interrupt Enable were set. #### NOTE The empty buffer function does not destroy the contents of the sector buffer. 4.1.4.3 Write Sector (010) – This function transfers the contents of the sector buffer to a specific track and sector on the diskette. Upon decoding this function, the RX8E/RX28 clears the RX2ES and sets the TR flag, signifying a request for the sector address. The TR flag must be tested and cleared before the binary sector address can be loaded into the interface register by means of the XDR command. The sector address must be within the limits 1-328. The TR flag is set, signifying a request for the track address. The TR flag must be tested and cleared; then the binary track address may be loaded into the interface register by means of the XDR command. The track address must be within the limits 0-1148. The RX02 tests the supplied track address to determine if it is within the allowable limits. If it is not, the RX2ES is moved to the interface register, the error and done flags are set, and the function is terminated. If the track address is legal, the RX02 moves the head of the selected drive to the selected track, locates the requested sector, transfers the contents of the sector buffer and a CRC character to that sector, and sets Done. Any errors encountered in the seek operation will cause the function to cease, the RX2ES to be loaded into the interface register, and the error and done flags to be set. If no errors are encountered, the RX2ES is loaded into the interface register and only the done flag is set. ## NOTE The write sector function does not destroy the contents of the sector buffer. 4.1.4.4 Read Sector (011) – This function moves a sector of data from a specified track and sector to the sector buffer. Upon decoding this function, the RX8E/RX28 clears RX2ES and sets the TR flag, signifying the request for the sector address. The flag must be tested and cleared. The sector address is then loaded into the interface register by means of the XDR command. The TR flag is set, signifying a request for the track address. The flag is tested and cleared by the host processor and the track address is then loaded into the interface register by an XDR command. The legality of the track address is checked by the RX02. If illegal, the error and done flags are set with the RX2ES moved to the interface register and the function is terminated. Otherwise, the RX02 moves the head to the specified track, locates the specified sector, transfers the data to the sector buffer, computes and checks CRC for the data. If no errors occur, the done flag is set with the RX2ES in the interface register. If an error occurs anytime during the execution of the function, the function is terminated by setting the error and done flags with RX2ES in the interface register. A detection of CRC error results in RX2ES bit 11 being set. If a deleted data mark was encountered at the beginning of the desired data field, RX2ES bit 5 is set. 4.1.4.5 Set Media Density (100) for RX28 Only – This function causes the entire diskette to be reassigned to a new density. The density bit (bit 3 RX2CS) indicates the new density of the diskette. The control reformats the diskette by writing new data address marks (double or single density) and zeroing out all data fields on the diskette. Before executing the command the control will look for a protective key word of 01001001 (ASCII'I'). The control starts at sector 1, track 0 and reads the header information, then starts a write operation, writing the new data address mark and data field as well as CRC characters. If the header information is damaged, the control will abort the operation and assert DONE and ERROR. This operation takes about 15 seconds and should not be interrupted. If for any reason the operation is interrupted, an illegal diskette has been generated which may have data marks of both densities. This diskette should again be completely reformatted. - 4.1.4.6 Maintenance Read Status (101) for RX28 Only This function updates the drive ready and drive density status of the selected drive, clears the INIT DONE bit, updates the Unit Sel, possibly sets the density error bit and leaves the remainder of the RX2ES unchanged. The drive density is updated by loading the head on the selected drive (without changing head and reading position) with the first header and data mark that randomly appears under the head. The control will then generate the appropriate number of shift pulses which will transfer the RX2ES (error and status) register over the interface. Upon completion of the RX2ES transfer, the control asserts Done to complete the operation. - 4.1.4.7 Read Status (101) for RX8E Only Upon decoding this function, the RX02 moves the RXES to the RX8E interface register and sets the done flag. The RXES can then be read by the transfer data register (XDR) command. The bits are defined in Paragraph 4.1.3.6. #### NOTE The average time for this function is 250 ms. Excessive use of this function will result in substantially reduced throughput. - 4.1.4.8 Write Deleted Data Sector (110) This function is identical to the write data function except that a deleted data mark is written prior to the data field rather than the normal data mark (Paragraph 1.5.3.2). RX2ES bit 5 (Deleted Data) will be set in the interface register upon completion of the function. - 4.1.4.9 Read Error Code Function (111) The read error code function can be used to retrieve explicit error information upon detection of the error flag. Upon receiving this function, the RX02 moves an error code to the interface register and sets Done. The interface register can then be read via an XDR command and the code interrogated to determine which type of failure occurred (Paragraph 4.1.5). #### NOTE Care should be exercised in the use of this function. The program must perform this function before a read status because the error register is always modified by a read status function. 4.1.4.10 Power Fail - There is no actual function code associated with power fail. When the RX02 senses a loss of power, it will unload the head and abort all controller action. All status signals are invalid while power is low. When the RX02 senses the return of power, it will remove Done and begin a sequence to: - 1. Move drive 1 head position mechanism to track 0. - 2. Clear any active error bits. - 3. Read sector 1 of track 1 of drive 0 into the buffer. - 4. Set Initialize Done bit of the RX2ES, after which Done is again asserted. There is no guarantee that information being written at the time of a power failure will be retrievable. However, all other information on the diskette will remain unaltered. INIT IOT is a method of aborting an incomplete function (Paragraph 4.1.2.7). #### 4.1.5 Error Recovery 4.1.5.1 RX8E - There are two error indications given by the RX8E system. The read status function (Paragraph 4.1.4.7) will assemble the current contents of the RXES (Paragraph 4.1.3.6), which can be sampled to determine errors. The read error register function (Paragraph 4.1.4.9) can also be used to retrieve explicit error information. The results of the read status function or the read error register function are in the interface register when Done sets, indicating the completion of the function. The XDR IOT must be issued to transfer the contents of the interface register to the PDP-8's AC. #### NOTE A read status function is not necessary if the DRV READY bit is not going to be interrogated because the RXES is in the interface register at the completion of every function. The error codes for the read error register function are presented below. | Octal | | |-------|------------------------------------------------------------------------------------| | Code | Error Code Meaning | | 0010 | Drive 0 failed to see home on Initialize. | | 0020 | Drive I failed to see home on Initialize. | | 0030 | Found home when stepping out 10 tracks for INIT | | 0040 | Tried to access a track greater than 77 | | 0050 | Home was found before desired track was reached | | 0070 | Desired sector could not be found after looking at 52 headers (2 revolutions) | | 0110 | More than 40 µs and no SEP clock seen | | 0120 | A preamble could not be found. | | 0130 | Preamble found but no I/O mark found within allowable time span | | 0150 | The header track address of a good header does not compare with the desired track. | | 0160 | Too many tries for an IDAM (identifies header) | | 0170 | Data AM not found in allotted time | | 0200 | CRC error on reading the sector from the disk. No code appears in the ERREG. | | 0210 | All parity errors | | 0220 | Self diagnostic error on Initialize | | 0240 | Density Error | | 0240 | | 4.1.5.2 RX28 – There are two error indications given by the RX28 system. The read status function will assemble the current contents of the RX2ES which can be sampled to determine errors. The read error register function can also be used to retrieve explicit error information. The results of the read status function or the read error register function are in the interface register when Done sets, indicating the completion of the function. The XDR IOT must be issued to transfer the contents of the interface register to the PDP-8's AC. #### NOTE A read status function is not necessary if the DRV RDY bit is not going to be interrogated because the RX2ES is in the interface register at the completion of every function. The error codes for the read error register function are presented below. | Octal | | |-------|------------------------------------------------------------------------------------| | Code | Error Code Meaning | | 0010 | Drive 0 failed to see home on Initialize. | | 0020 | Drive 1 failed to see home on Initialize. | | 0040 | Tried to access a track greater than 76 | | 0050 | Home was found before desired track was reached. | | 0070 | Desired sector could not be found after looking at 52 headers (2 revolutions). | | 0110 | More than 40 $\mu$ s and no SEP clock seen | | 0120 | A preamble could not be found. | | 0130 | Preamble found but no ID mark found within allowable time span | | 0150 | The header track address of a good header does not compare with the desired track. | | 0160 | Too many tries for an IDAM (identifies header) | | 0170 | Data AM not found in allotted time | | 0200 | CRC error on reading the sector from the disk | | 0220 | R/W electronics failed maintenance mode test. | | 0240 | Density error | | 0250 | Wrong key word for Set Media Density command | #### 4.1.6 RX8E Programming Examples 4.1.6.1 Write/Write Deleted Data/Read Functions - Figure 4-11 presents a program for implementing a write, write deleted data, or a read function with interrupts turned off (IOF). The first 3 steps preset the PTRY, CTRY, and STRY retry counters, which are set at 10 retries but can be changed to any number. Starting at RETRY, the program tests for 8- or 12-bit mode, type of function, and drive. Once the command is loaded, the program waits in a loop for the controller to respond with transfer request (TR). When TR is set, the sector address is loaded and the AC is cleared. The program loops while waiting for the controller to respond with another TR. When TR is reset, the track address is loaded and the AC is cleared again. The program loops to wait for the Done condition. When the done flag is set, the program checks for an error condition, indicated by the error flag being set. If the AC=0000, the error is a seek error; if bit 11 of the AC is set, the error is a CRC error. Error status from the RXES is saved and tested to determine the error (Paragraph 4.1.3.6). The RXES will not include the select drive ready bit. If a parity error is detected, the program increments and tests the PTRY retry counter. If a parity error persists after 10 tries, it is considered a hard error. If 10 retries have not occurred, a branch is made to RETRY and the sequence is repeated. After a parity test, the program tests to see if the CRC error bit is set. If a CRC error is detected, the program increments and tests the CTRY retry counter. If a CRC error persists after 10 retries, it is considered a hard error. If 10 retries have not occurred, a branch is made to RETRY and the sequence repeated. A seek error is assumed if neither a CRC nor a parity error is detected. An Initialize (INIT) instruction is performed (Paragraph 4.1.2.8). During a write or write deleted data function, the sector buffer must be refilled because INIT will cause sector 1 of track 1 of drive 0 to be read, which will destroy the previous contents of the sector buffer. The instruction sequence for a fill buffer function is not included in Figure 4-11, but is presented in Figure 4-13. After the system has been initialized, the program increments and tests the STRY retry counter. If a seek error persists after 10 tries, it is considered a hard error. If 10 retries have not occurred, a branch is made to RETRY and the sequence repeated. ``` PROGRAMMING EXAMPLES FOR THE RXBPRXB1 FLEXIBLE DISKETTE ITHE FOLLOWING ARE REST TOT CODE DEFINITIONS THE STANDARD TOT DEVICE CODE IS 678- /IOT TO LOAD THE COMMAND, (AC) IS THE COMMAND /IOT TO LOAD OR READ THE TRANSFER RESISTER /IDT TO SKIP ON A TRANSFER REQUEST FLAG /IOT TO SKIP ON AN ERROR FLAG /IOT TO SKIP ON THE DONE FLAG /IOT TO SKIP ON THE DONE FLAG /IOT TO SKIP ON THE DONE FLAG /IOT TO INITIELIAE THE RYS/RYSI SUSSYSTEM . CO=6781 6781 6782 6783 6784 6785 6785 XDR=6782 XDR=6782 STR=6783 SER=6784 SDN=6789 INTR=6786 $123456789812345678981234567898123456789012 THE FOLLOWING IS A PROGRAMMING EXAMPLE OF THE PROTOCOL REQUIRED TO WRITE, WRITE DELETED DATA, OR READ AT SECTOR "3" (THE CONTENTS OF PROGRAM PLOCATION SECTORS OF TRACK MTM LINE CONTENTS OF PROGRAM LOCATION TRACKS /|N 8 OR 12 8|T HODE 1254 3255 1254 3256 1254 3257 TAG KM18 DCA PTRY TAD KM18 DCA CTRY TAD XM18 DCA STRY 0238 0231 0292 0293 0294 , Start. / -13 /PARITY RETRY COUNTER JOAC RETRY COUNTER SEEK RETRY COUNTER ...... WRITE DELETED DATA. OR READ RETRY, TAD MODE TAD COMMAND /# IF 12-BIT, 180 IF 8-BIT / 4 IF WRITE, 14 IF WRITE DELETED /DATA, OR 6 IF READ / 8 IF UNIT 7, 28 IF UNIT 1 /IOT 67X1 TO LOAD THE COMMAND 9286 1268 9207 1261 WALT FOR THE TRANSFER REQUEST FLAG THEN TRANSFER THE SECTOR ADDRESS 6723 5212 1263 6722 7208 STR JMP 1-1 TAD SECTOR XDR /IOT 67%3 TO /WALT FOR TRANSFER REQUEST FLAG 0212 0213 0214 0215 / 1 TO SECOCTAL? /IDT TO LOAD SECTOR /CLA BECAUSE LOT XON DOESH'T THAIT FOR THE TRANSFER REQUEST FLAG THEN THANSFER THE TRACK ADDRESS #217 6783 #22# 5217 #22# 1264 #22# 47#2 #233 72## /IOT 67%% TO .MAIT FOR TRANSFER REQUEST / 8 TO 134(OCTAL) VIST TO LOAD TRACK /CLA BEGAUSE LO3 XOA DOLSN'S STR PHL PAD XD9 ITHE SECTOR AND TRACK ADDRESSES HAVE BEEN TRANSFERRED TO THE MX81 VIA THE XDR LOT / ZWAIT FOR THE DONE FLAG AND CHECK FOR ANY ERRORS FIR THE FUNCTION HAS COMPLETED SUCCESSFULLY (ND ERROR FLAG) THEM HALT /101 67X3 TO /WAIT FOR DONE FLAG /IOT 67X4 SAMPLES ERROR FLAG / OK = COMPLETED 8224 6785 8225 5224 8226 6784 8227 7482 THE ERROR FLAG IS SET THE CONTENTS OF THE TRANSFER REGISTER IS THE ERROR STATUS / /IF TRANSFER REGISTER BITS 18, AND 11 = 8 THEN SOME TYPE OF SEEK ERROR HAS OCCURED, /IF TRANSFER REGISTER BIT 18 = 1 THEN A CRC ERROR HAS OCCURED, /IF TRANSFER REGISTER BIT 18 = 1 THEN A PARITY ERROR HAS OCCURED /GET CONTENTS OF TH (ERROR STATUS) /AND SAVE / 2 /TEST FOR PARITY ERROR /NOT A PARITY ERROR - MAYBE CRC 9239 6702 9231 3265 9232 7395 9233 0265 9234 7658 9235 5241 XDR DC4 ASTATUS CLL CL4 1AC RAL AND ASTATUS SNA CL4 JMP TCRC /A PARTTY ERROR HAS OCCURED PINCHEMENT AND YEST THE PARTTY ERROR RETRY COUNTER PROBRAN LOCATION " PTRY " VAND RETRY THE " COMMAND " UNTIL THE PARITY ERROR RECOVERS YOR UNTIL THE PTRY COUNTER OVERFLONS TO B 152 PTRY JMP RETRY HLT #236 2295 #237 92#6 #249 74#Z PRETRY THE COMMAND MAND PARITY ERROR / /THE ERROR FLAG IS SET BUT THE ERHOR IS NOT A FAMILY ERROR / /TEST FOR A CAC ERROR CLL CLA JAC AND ASTATUS / 1 /TEST FOR A CRC ERROR /SKIP IF A CRC ERROR /MOT A CRC - MUST BE A SEEK 7381 2265 7658 5258 TCRC. SNA CLA JHP SEEK ``` Figure 4-11 RX8E Write/Write Deleted Data/Read Example (Sheet 1 of 2) ``` /A CRC ERROR HAS OCCURED FINGREMENT AND TEST THE GRO ERROR RETHY COUNTER PROGRAM LOCATION " STRY " 103 104 105 106 106 108 110 111 111 111 111 115 JAND RETRY THE COMMAND UNTIL THE CRC ERROR RECOVERS JOR UNTIL THE CTRY COUNTER OVERFLOWS TO B ISE CTRY JMP RETRY WLT /RETRY THE COMMAND /HARD CRG ERROR THE ERROR FLAG 18 BET THE ERROR IS CHOTT A PARITY ERROR AND IS CHOTT A CHE ERROR THEREFORE IS MUST BE A SEEK ERNOR 116 117 118 119 128 121 122 8258 A767 SEEK. INIT JIST 67X7 TO INITIBILIAN FINGREHENT AND TEST THE SEEK ERROR RETRY COUNTER PROGRAM LOGATION " STRY " VAND RETRY THE COMMAND UNTIL THE BEEK ERROR RECOVERS 123 124 125 126 127 128 129 YOR UNTIL THE CTRY COUNTER DYERFLOWS TO B /RETRY THE COMMAND /HARD SEEK ERROR THE FOLLOWING PROGRAM LOCATIONS ARE REFERENCED WITHIN THIS EXAMPLE 8254 7778 KH18, -15 THE FOLLOWING 3 PROGRAM LOCATIONS ARE THE ERROR RETRY COUNTERS /PARITY ERROR RETRY COUNTER /CRC ERROR RETRY COUNTER /SEEK ERROR RETRY COUNTER 9255 3388 3894 5368 PROGRAM LOCATION " MODE " CONTAINS A B IF 12-BIT MODE, OR JOUNTAINS A SEE IF 8-BIT MODE япОЕ. 9268 ares PROGRAM LOCATION " COMMAND " CONTAINS THE COMMAND TO BE ISSUED VIA THE LCD TOT JURITE (4), WRITE DELETED DATA (14), OR READ (6). OR EMPTY BUFFER (2) PROGRAM LOCATION " UNIT " CONTAINS THE UNIT DESIGNATION VUNIT 8 (8), OR UNIT 1 (28) 8262 8348 UNITA / E. OR 28 PROGRAM LOCATION " SECTOR " CONTAINS THE SECTOR ADDRESS (1 TO 32 OCTAL) 9263 0284 PAROGRAM LOCATION " TRACK " CONTAINS THE TRACK ADDRESS (8 TO 114 OCTAL) B264 / 8 TO 114 OSTAL PROGRAM LOGATION " ASTATUS " CONTAINS THE CONTENTS OF THE TRANSFER REGISTER PAT THE DETECTION OF AN ERROR (ERROR FLAG = 1) WHICH CORRESPONDS TO THE ZERROR STATUS y = 0 IF SEEK ERROR, 1 IF ORG ERROR. 2 IF PARITY CRACK 8265 2288 ASTATUS. B /STATUS AT ERROR ``` Figure 4-11 RX8E Write/Write Deleted Data/Read Example (Sheet 2 of 2) 4.1.6.2 Empty Buffer Function – Figure 4-12 shows a program for implementing an empty buffer function with interrupts turned off (IOF). The first instruction sets the number of retries at 10. A 2 is set in the AC to indicate an Empty Buffer command and the command is loaded. When TR is set, the program jumps to EMPTY to transfer a word to the BUFFER location. A jump is made back to loop to wait for another TR. This process continues until either 64 words or 128 bytes have been emptied from the sector buffer. When Done is set, the program tests to see if the error bit is set. If the error bit is set, the program retries 10 times. If the error persists, a hard parity error is assumed, indicating a problem in the interface cable. 4-16 ``` THE FOLLOWING IS A PROGRAMMING EXAMPLE OF PROTOCOL REQUIRED TO 229 PENPTY THE SECTOR BUFFER OF 64 12-BIT HORDS (12 BIT HODE), OR 231 232 233 PEMPTY THE SECTOR BUFFER OF 128 8-817 BYTES (8 817 MODE) 234 235 236 237 0312 0313 0314 0319 0316 0317 1254 3255 1377 3010 EENTRY, TAD KHIB / 8 TAYS TO EMPTY THE SECTOR BUFFER /PARLTY ERROR RETRY COUNTER /PROGRAMS DATA BUFFER OCA PTRY ESETUP, TAD (BUFFER-1) /AUTO INDEX REGISTER 18 / B IF 18-BIT, 188 IF 8 / 2 MEANS EMPTY BUFFER DCA A16 TAD HODE 1268 TAD COMMAND LCD FIOT TO ISSUE THE COMMAND THAIT FOR A TRANSFER REQUEST FLAG BEFORE THANSFERRING DATA TO THE PROGRAMS ZOATA BUFFER FROM THE RXB1 SECTOR BUFFER WAST FOR A DONE FLAG TO INDICATE THE COMPLETION OF THE EMPTY BUFFER COMMAND PRIOR TO / /TESTING THE ERROR FLAG YTEST FOR TR FLAG YTA NOT BET, TEST FOR DONE FLAG YTR FLAG SET YTEST FOR DONE FLAG YNOT TR, OR DONE YET 6783 7418 9333 6789 9274 8321 8322 8323 8324 8324 STR ELOOP, JAP EMPTY JAP ELUUF FINE DONE PLAG IS BET FIRST FOR ANY ERRORS (ONLY ERROR POSSIBLE IS A PARTTY ERROR) /TEST FOR THE ERROR FLAG /NO ERRORS - OK /INGREHENT AND TEST THE PARITY ERROR METRY PROGRAM LOGATION " PTRY " YAND RETRY THE COMMAND UNTIL THE ERROR RECOVERS YOR UNTIL THE PTRY COUNTER OVERFLOWS TO B ISE PTRY JHP ESETUP HLT PRETRY TO EMPTY THE SECTOR BUFFER PHARD PARTTY ERROR THE TRANSPER REQUEST FLAG IS SET Z-RANSFER DATA TO THE PROGRAMS WATA BUFFER FROM THE RX81 SECTOR BUFFER 6782 3416 9321 8377 8488 XDR DCA 1 A18 8333 8334 EMPTY, /FROM THE RXS1 SECTOR BUFFER 278 279 /TO THE PROGRAMS DATA OUFFER /LOOP UNTIL THE BONE FLAG SETS JAP ELOGP 260 PAGE 261 262 263 264 265 ITHE FOLLOWING PROGRAM LOCATIONS ARE RESERVED FOR THE PROGRAMS DATA BUFFER BUFFER, 8 •BUFFER+288 $ 9488 2000 8608 ``` Figure 4-12 RX8E Empty Buffer Example **4.1.6.3** Fill Buffer Function – Figure 4-13 presents a program to implement a fill buffer function. It is very similar to the empty buffer example. #### 4.1.7 RX28 Programming Examples Figures 4-14, 4-15, and 4-16 are programming examples for write, write deleted data or read functions, for fill buffer functions, and for empty buffer functions, respectively. These examples are very similar to the RX8E programming examples described in Paragraph 4.1.6. Basically, there are two differences between the RX8E and RX28 examples. First, for the RX28 when a command is transferred in the 8-bit mode of operation, it is transferred in two 8-bit words using an XDR to transfer the second command word (see location 0225 in Figure 4-14); second, for the RX28, there is no parity error check as there is in the RX8E; instead there is a density error cpack. ``` THE FOLLOWING IS A PROGRAMMING EXAMPLE OF PROTOCOL REQUIRED TO FILL THE SECTOR BUFFER WITH 64 12-817 HORDS (12 BIT MODE). OR FILL THE SECTOR BUFFER WITH 128 8-BIT BYTES (8 BIT 400E) , 18-18 9010 1254 3255 1377 3018 1268 6781 FENTRY, TAD KM18 DCA PTRY SETUP, TAD (BUFFER-1) / 8 TRYS TO FILL THE SECTOR BUFFER /PARITY ERROR RETRY COUNTER /PROGRAMS DATA BUFFER /AUTO INDEX REGISTER 18 / 8 IF 12-817, 188 IF 8 BIT /10T TO ISSUE THE COMMAND #267 #267 #27# 8271 8272 DCA ALE TAD HODE /WAIT FOR A TRANSFER REQUEST FLAG BEFORE TRANSFERRING DATA FROM THE PROGRAMS JOATA BUFFER TO THE RXB1 SECTOR BUFFER MAIT FOR A DOME FLAG TO INDICATE THE COMPLETION OF THE FILL BUFFER COMMAND PRIOR TO / /TESTING THE ERROR FLAG /TEST FOR TR FLAG /TR NOT BET, TEST FOR DONE FLAG /TR FLAG SET /TEST FOR DONE FLAG /NOT TR, DR DONE YET 8274 8275 8276 8277 6793 7419 5396 6795 5274 LOOF, STR SKP JHP FILL SON JHP LOOP THE DONE FLAG IS SET / /TEST FOR ANY ERRORS CONLY ERROR POSSIBLE IS A PARTITY ERRORS 8381 6784 8382 7482 SER HLT /TEST FOR THE ERROR FLAG /NO ERRORS - OK FINGREHENT AND TEST THE PARITY ERROR HETRY PROGRAM LOCATION * PTRY * VAND METRY THE COMMAND UNTIL THE ERROR REGOVERS FOR UNTIL THE PTRY COUNTER OVERFLOWS TO B 8303 2255 #384 5270 #385 7482 18E PTRY UMP SETUP HLT 216 217 218 219 228 221 222 223 FRETRY TO FILL THE SECTOR BUFFER PHARD PARITY ERROR ITHE TRANSFER REQUEST FLAG IS SET ATRANSFER DATA FROM THE PROGRAMS DATA BUFFER TO THE REGI SECTOR BUFFER /YIA AUTO INDEX REGISTER 18 /TO THE RXB1 SECTOR BUFFER /GLA BECAUSE IOT XOR DOESN'T /LODP UNTIL THE DONE FLAG SETS 0306 9397 9318 1418 6782 7288 5274 TAD I ALB 224 Fills SLA JHP LOOP ``` Figure 4-13 RX8E Fill Buffer Example ``` PROGRAMING EXAMPLES FOR THE RESSEE FLEXIBLE DISKETTE ALIGITATE SCOT TOT TEXE BET BUILDING SHIN THE STANDARD TOT DEVICE CODE IS 675- /13T T3 LOAD THE COMMAND, (AC) IS THE COMMAND /13T T3 LOAD OR MEAD THE TRANSFER REGISTER /13T T3 SHIP NOT TRANSFER REQUEST FLAG /13T T3 SHIP NOT TRANSFER REQUEST FLAG /13T T3 SHIP ON DONE FLAG (13T T3 SHIP ON DONE FLAG (14C) AT STRENGTH THE NEW TOT T3 INTERSTREET OF /(AC) AT MEANS DN /13T T3 INTIGALIZE THE RS SUBSYSTEM 6781 6782 6783 6784 ĹCDu 67F2 67F3 67F4 67F5 ETTA SERO 6795 6726 6727 804= 1478= 1417• 6787 ATHE ADDITIONING IS A PROGRAMING EXAMPLE OF THE PROTOCOL REQUIRED ITO HALTE, WALTE SELETED DATA, OR READ AT SECTOR "5" (THE CONTENTS OF PROGRAM PLOCATION RECTOR-) OF TRACK "I" (THE CONTENTS OF PROGRAM LUCATION PRIMARCA) IN B OF 12 BIT MODE. 8288 1266 3274 1266 3271 *23F 51491, 4418 4419 4418 4418 /SET RETHY CONSTANT /SET UP CRC RETHY COUNT DCA TAB DCA JEET UP BEEK KETRY COUNT SHRITE, HRITE DELETED DATA, OR READ /MAKE SURE DRIVE READY FOR US /IF NOT MAIT /# IF 12-917 MODE, 128 IF 4-917 MODE /GET FUNCTION CODE /GET ORIVE PARAMETERS; UNIT, #, 9234 9235 9236 9237 6785 5284 1275 1274 804 .+1 403E Funcun 3014EP TAD TAD JOET ORIVE PARAMETERS; UNIT, #, JOENSITY JAVE ENTITE COMMAND JOET COMMAND JOET COMMAND JOES COMMAND JOES COMMAND JOES COMMAND JOE COMMAND JOE SKIP AND DO BUSIT PROTOCOL JOET LEMBAR DOWE LCD PROTOCOL JOET UPPER # MITS DO JOENSITY OF AC JOET OF A THANSPER REQUEST JOED UNTIL TR. JOING SECOND COMMAND LOTE CHMMAND GUANNECO DCA TAR 5276 1276 1276 1287 1287 5286 1136 7736 100 740 440 0344443 4188 112345 07 PC BNA JMP CLL RTL RTL 443770 94L 818 34P 708 PHATE FOR THANSPER REQUEST FLAS THEN TRANSFER SECTOR ADONESS 9226 7227 9236 1775 1277 matife, bin FIRST TH SELP ON THENSEER NEWDEST /LIDP UNTIL TH, /1 TO BE (DUTAL) /LIAD THE SECTOR /CLEAP AC IHP TAR $EC124 ¥D₽ / FIRST THE THENSTER REGUEST FLES THEY TRANSFER THACK ASSISTS / VACED ON TRANSPER REGUEST ALTOP UNTIL TH VC IN 114 (OCTAL) ALGAD THE TRACK VCLEAR AC #234 #234 #239 #236 #236 578 JFB 140 3733 ...l #OR CLA ZTHE COMMAND PROTHEDL HAS BEEN COMPLETED. FOR PARTY FOR DONE AND CHECK FOR ERRORS 4543 4543 4544 4544 6735 5283 6734 7432 VIDT TO SKIP ON DONE FLAG VLDOP UNTEL OUNE VIDT TO SKIP ON ERROR FLAG VMO FRHOMS SO HALT BE * THE ERROR FLAG IS SET ATHE ERROW STATUS IS LOCATED IN THE TRANSFER HERISTER VIE STATUS » 1 THEN CHC EMAIN OCCURED VIE STATUS » 28 THEN CHC EMAITY ERROM OCCURED VIE STATUS » 1 THEN SEEK ERROM OCCURED ZGEF CUNTENTS OF TRANSFER BEGISTER ZSTATUS AT DONE ZAND SAVE IT ZHASK FOR CRC ERROR BIF ZIFA C NOT EQUAL TO ZEED CRC ZEROR DOCURED SO SKIP ZIFAC A R THEN CHECK FOR DENSITY ERROR ZEEP COUNT OF RETAILS IF & IR THEN SKIP ZIF RETRIES SIN THEN TO IT AGAIN. MALED 6732 b732 X09 2245 7246 2247 225m 2251 7252 8254 3301 7331 7654 7655 2270 5705 5705 DCA ASTATUS IAC AND SNA CLA JMB asfatus 3E 4511 132 JHP ML 7 93 ``` Figure 4-14 RX28 Write/Write Deleted Data/Read Example (Sheet 1 of 2) ``` ATHE ERROR HAS WOT A CRC SO CHECK FOR HRUNG DENSITY, IF DENSITY ERROR FORES EXIST THEM HALT. IF THIS ERROR OCCURS IT COULD JUST HAVE PREEM SECAUSE HE PORGOT TO SET THE RIGHT NEWSTRY IN THE COMPAND HORD JUR IT COULD BE THE HRONG DISKETTE HAS REEN INSERTED IN THE DRIVE OR FIT COULD BE SOME DINER REASON OUT HE SHOULD KNOW WHAT CAUSED IT /BEF346 ME PROCEED. /AC + 4 /AC + 28, MASK FOR DENSITY ERROR /IN STATUS MOND IF SET SKIP /IF NOT DENSITY ERROR MOST BE SEEK ERROR /IF NOT DENSITY ERROR SIT SET IN AC #255 #256 #257 7347 7312 3371 DEWSTY, CLA CLL TAG RTL AND ASTATUS 111 9269 8261 7447 824 112 PHALT WITH DENSITY ERROR BIT SET IN AC 113 / /THE EARDM MUST HAVE BEEN A SEEK ERROR IF HE GOT THIS FAR. 115 FIRST AN INITIALIZE TO DRIVE BO WE START FROM THACK & JAND TRY ASATN /IOT TO INITIALIZE RX /KEEP COUNT OF SEEK ERROPS /RETRY COMMAND 18 TIMES /THEN HALT #262 0263 0264 0264 6737 BEER. INTT 2271 5286 7432 SET 46134 HLT ACONSTANTS USED BY THIS COOP 7772 8266 Klap, JERRIA RETAY COUNTERS ÉTRY. 3734 3738 3722 /CRC ERROR HETHY COUNTER /BERN ENROR RETRY COUNTER FTRY, FILL AND EMPTY BUFFER RETYR COUNTER PROSPAN LOCATION "MODE" CONTAINS & IF 12-617 MODE, OR LINK IF 8-917 MODE 4666 2750 MODE, PLOCATION PERMICUNE CONTAINS & IF WRITE, 14 IF WRITE RELETED DATA, DR 16 IF READ FUNCTION FUNCJU, # 8274 3333 PLOCATION TORINET HAS BIT ASSIGNMENTS JUST M SINGLE DENSITY JUST 1 SINGLE DENSITY JUST M DOUGLE DENSITY JUST 1 DOUGLE DENSITY . 290 4000 4200 151 OPIVEP. # 153 154 155 156 157 159 159 PLOCATION "COMMAND IS WHERE THE ASSEMBLED COMMAND IS STORED CO44447, P VEDCATION "SECTOR" WIST BE 1 TO SE DOTAL 8220 BEC734, # 161 163 164 165 166 167 PLOCATION PERACK" MUST BE A TO SIM OCTAL TRACE. F 8579 2377 PLOCATION "ASSATUR" IS USEN TO STORE THE CONTENTS OF THE STATUS AREGISTER IF AN ENTIRE DECURS, THE STATUS IS IN THE TRANSFER AREGISTER WHEN "DANE" IS SET. 8321 222a ASTATUS, P MA-1872 ``` Figure 4-14 RX28 Write/Write Deleted Data/Read Example (Sheet 2 of 2) ``` 17: 172 173 174 175 176 176 176 ATHE FOLLOWING IS A PROGRAMMING EXAMPLE FO PROTOCOL REQUIRED TO / /FILL THE SECTOR BUFFER AIRCOR 3317 / B THYS TO FILL THE SECTOR SUFFER / 24RDH RETRY COUNTER / 24RDH RETRY COUNTER / 24RDH RETRY COUNTER / 24 FE L2-81T, 188 FF 8 AIT / RET DEMSITY / STORE ABSEAS, 20 COMMAND / SET COMMAND TO SE / 13 SUE COMMAND TO SE / 13 SUE COMMAND TO SE / 13 SUE COMMAND TO SE / 14 SUE COMMAND TO SE / 15 SUE COMMAND TO SE / 15 SUE COMMAND SET DO S-MODE PHOTOCUL / 15 12-81T MOSE SET DO S-MODE PHOTOCUL / 15 12-81T MOSE SET SE 11, 2, 3) / CET SAVED COMMAND WORD / CET A MED COMMAND WORD / CET A MED (STTS R, 1, 2, 1) / COMMAND WORD DOWN TO THE / 24 LSO'S (STTS R, 1, 2, 1) / 13 TO SEE ON TRANSFER SEADY / 15 YE NOT SET LOOP JUTIL IT TOES / 15 SUE SECOND COMMAND WORD / CLEAR THE AC AND DO FILL LOOP F THAMBERNING DATA FROM THE PROSERAS FENTRY, TAD KNID DCA ETRY 361/F, TAD (NUFFER-1) DCA 436 TAD 301VEP DCA 201 TAD 301VEP DCA 201 TAD 034VANO TAD 034VANO 332 3335 6336 3336 3337 6317 6317 7318 7317 TAD DCA TAD LCD TAD AWN CLA JMP TAD CO44440 (+30 103P 9317 9321 1321 1322 1323 1324 2325 TAN CLL PTL RTL RAL STR JMP ENR V VHALT FOR A THANSPER RESULENT FUND BEFORE THANSPERHING SATA FROM THE PROGRAMS AUSTE SPENEM IN THE ACE! BECIUS BREADS V. VHAST FOR A DOME WARD TO SWOTCHTE THE COMPLETION OF THE FILL AUFFEH COMMAND PRICE TO ATENTING THE ERROR PLACE #397 | $775 #35 | Felic #351 | 5341 #314 | $786 inge. 378 FREST FOR TR FLAG FRE NOT SET, TEST FOR DANG FLAG FREST FOR DOWN FLAG SHP FILL 348 1308 FUDT THE DR DOME YET /140 170F PLAT 18 SET / /TEST FOR LIV EVENES St # FIRST FOR THE ENGOR FLAG FAS ERMORE + DE 2134 6744 2135 7478 FINISHED AND 1541 THE ENGINE SETAR BOUGHER LUCATION SETERS PANIS PETRY THE COMMAND JUTYL THE ENGINE RECOVERS AU GRUTHER FLAN CONTRA ANALYSIS OF R 4 550 PPPE 4 557 5144 9 547 7442 TSE ETHY JHP BETUR HLT PRETHY TO FILL THE SECTION BUPPER PHAND PARETY ERROR FIRE THANSPER MERIERT PLAN IS BET / PTRANSFER DATA FROM THE PROGRESS DATA HUPPER TO THE REST SECTOR BUPPER /311 1418 /342 5742 /343 /242 /344 /242 /344 5127 íse. VVIA AUTO INDEX REGISTER IN VTO THE RABI SECTOR BUFFER VCLA RECAUSE TOT WOR DOESN'T VLOOP UNTIL THE DOME FLAG SETS TAR 1 414 END CL4 JMP 139P MA-1573 ``` Figure 4-15 RX28 Fill Buffer Example ``` ATHE POLLOWING IS A PROGRAMMING ENAMPLE OF PROTOCOL REQUIRED TO / JEMPTY THE SECTOR BUFFER EEUTRY, TAN KWID DCA ETRY ESETJP, TAN (RUFFER-1) CLA ALB TAN MODE P345 B346 F347 1266 3272 1377 5318 1273 / 8 TRYS TO EMPTY THE SECTOR RUPPER /ETROR RETRY COUNTER /PHOGRAMS DATA BUFFER /AUTO INDEX REGISTER 18 / 8 IF 12-517, [PR 17 8 517 ] / 2 4EAM EMPTY PUFFER /GET DEMSITY #356 #351 TAN FUNCUL TAN FUNCUL TAN DELVEP DCA COMMAND TAN COMMAND #352 #353 #354 1275 1275 3276 1276 6781 1276 / CET DEMBITY /STORE ASSEMBLED COMMAND /GET COMMAND TO EX /SSUE COMMAND TO EX /SSUE COMMAND TO EX /SSUE COMMAND TO EX /SET SAVED COMMAND TO EX /SET SAVED COMMAND MORE /SET SAVED COMMAND MORE /GET A **SST'S (BITS 8,1,2,3) OF /COMMAND WORD OWN TO THE /A LSST'S (BITS 8,9,19,11) OF AC /III TO SAXED OF TRAMSPER READY /SF TR NOT SET LOOP UNTIL IT DOES /SSUE BECOND COMMAND AND /CLEAR THE AC AND DO EMPTY LOOP /GET OWER TO WEXT PAGE TAD LCD TAD #335 #356 #356 #36p #36p #362 6133 60447H0 AND BNA CLA JMP TAB ELOGP COMMAND 8345 8345 8345 8346 8376 8377 8377 8377 TAD CLL RTL ATL BAL STR JMP XOR 256 257 258 259 260 261 262 263 263 263 .-1 €LD0P PAGE $22222224567641434566764762222222222223333333 / /walt for a transfer request flab mefone transferring jata to the programs FOATA BUFFER FROM THE RHES SECTOR BUFFER NATE LOS T DOME APER 10 IMDICALE INT COMPPETION OL LHE EMBLA RALESE CUMMUMO ENIOS LO PLAS SERVE SHE SELECT 8430 6733 8431 7413 8432 5212 8433 6735 8434 5236 /TEST FOR TR FLAG /TR NOT BET, TERT FOR DONE FLAG /TR FLAG BET /TEST FOR DONE FLAG /NOT TR, OR DONE YET ELJOP, 818 848 JAP EMPTY 30N JHR ELDOP ITHE NONE PLAG IS SET FEST FOR ANY ERRORS 8434 6734 8436 7432 SER TEST FOR THE ERROP FLAG /NO ERRORS - 04 . VINCREMENT AND TEST THE ERROR RETRY PROGRAM LOCATION METROS YAND RETAY THE COMMAND UNTIL THE EVADOR RECOVERS AND JUSTIL THE ETRY COUNTER DARRESONS TO B 152 E187 1MP E3E71P MLT FRETHY TO EMPTY THE SECTOR BUPPER PART ERROR FINE THANSPER REQUEST FLAG IS SET PROFESS OF A TA TO THE PROGRAMM DATA NUFFER FROM THE GER STOR BUFFER 8412 8413 8414 ×6. VPSCH THE RIVEL SECTOR BUPPER TO THE PERSONNE SHT CTV VLOOP UNTIL THE HOME FLAS SETS DCA 1 ALB PAGE /THE FOLLOWING PROBRAM LOCATIONS ARE RESERVED FOR THE PROGRAMS DATA BUFFER 306 339 518 511 312 3348 1279 MA-1814 ``` Figure 4-16 RX28 Empty Buffer Example 4-22 #### 4.1.8 Restrictions and Programming Pitfalls A set of 11 restrictions and programming pitfalls for the RX8E is presented below. 1. When performing the following sequence of instructions, interrupts must be off. STR SKP JMP SDN JMP (done) (fill or empty buffer) If interrupts are not off, the following sequence of events will occur. Assume interrupts are enabled and the RX8E issues an interrupt request just before the SDN instruction; the SDN instruction will be executed as the last legal instruction before the processor takes over. However, since the done flag is cleared by the SDN instruction, the processor will not find the device that issued the interrupt. - 2. The program must issue an SER instruction to test for errors following an SDN instruction. - 3. For maximum data throughput for consecutive writes or reads in 8-bit mode, interleave every three sectors; in 12-bit mode, interleave every two sectors. (This of course depends on program overhead.) - 4. When issuing the IOT XDR at the end of a function to test the status, the instruction AND 377 must be given because the most significant bits (0-3) contain part of the previous command word. - 5. If an error occurs and the program executes a read error register function (111) (Paragraph 4.1.4.9), a parity error may occur for that command. The error code coming back would not be for the original error in which the read error register function was issued, but for the parity error resulting from the read error register function. Therefore, check for parity error with the read status function (101) before checking for errors with the read error register function (111). - 6. The SEL DRV RDY bit is present only at the time of the read status function (101) for either drive, or at completion of an Initialize for drive 0. - 7. It is not necessary to load the drive select bit into the command word when the command is Fill Buffer (000) or Empty Buffer (001). - 8. Sector Addressing: 1-26 or 1-328 (No sector 0) Track Addressing: 0-76 or 1-1148 - 9. If a read error register function (111) is desired, the program must perform this function before a read status function (101), because the content of the error register is always modified by a read status function. - 10. The instructions STR, SDN, SER also clear the respective flags after testing so that the software must store these flags if future reference to them is needed after performing one of these instructions. 11. Excessive use of the read status function (101) will result in drastically decreased throughput because a read status function requires between one and two diskette revolutions or about 250 ms to complete. #### 4.2 RX11 and RXV11 PROGRAMMING INFORMATION This section describes device registers, register and vector address assignments, programming specifications, and programming examples for the RX11 and RXV11 interfaces. All software control of the RX11/RXV11 is performed by means of two device registers: the command and status (RXCS) register and a multipurpose data buffer (RXDB) register. These registers have been assigned bus addresses (Paragraph 4.2.1) and can be read or loaded, with certain exceptions, using any instruction referring to their addresses. The RX02, which includes the mechanical drive(s), read/write electronics, and $\mu$ CPU controller, contains all the control circuitry required for implied seeks, automatic head position verification, and calculation and verification of the CRC; it has a buffer large enough to hold one full sector of diskette data (128 8-bit bytes). Information is serially passed between the interface and the RX02. A typical diskette write sequence, which is initiated by a user program, would occur in two steps: - 1. Fill Buffer A command to fill the buffer is moved into the RXCS. The Go bit (Paragraph 4.2.2.1) must be set. The program tests for transfer request (TR). When TR is detected, the program moves the first of 128 bytes of data to the RXDB. TR goes false while the byte is moved into the RX02. The program retests TR and moves another byte of data when TR is true. When the RX02 sector buffer is full, the Done bit will set, and an interrupt will occur if the program has enabled interrupts. - 2. Write Sector A command to write the contents of the buffer onto the disk is issued to the RXCS. Again the Go bit must be set. The program tests TR, and when TR is true, the program moves the desired sector address to the RXDB. TR goes false while the RX02 handles the sector address. The program again waits for TR and moves the desired track address to the RXDB, and again TR is negated. The RX02 locates the desired track and sector, verifies its location, and writes the contents of the sector buffer onto the diskette. When this is done, an interrupt will occur if the program has enabled interrupts. A typical diskette read occurs in just the reverse way: first locating and reading a sector into the buffer (read sector) and then unloading the buffer into core (empty buffer). In either case, the content of the buffer is not valid if Power Fail or Initialize follows a fill buffer or read sector function. #### 4.2.1 Register and Vector Addresses The RXCS register is normally assigned Unibus address 177170 and the RXDB register is assigned Unibus address 177172. The normal BR priority level is 5, but it can be changed by insertion of a different priority plug located on the interface module. The vector address is 264. #### 4.2.2 Register Description 4.2.2.1 RXCS - Command and Status (177170) - Loading this register while the RX02 is not busy and with bit 0=1 will initiate a function as described below and indicated in Figure 4-17. Bits 0-4 are write-only bits. Figure 4-17 RXCS Format (RX11, RXV11) #### Bit No. Description - O Go Initiates a command to RX02. This is a write-only bit. - 1-3 Function Select These bits code one of the eight possible functions listed below and described in Paragraph 4.2.3. These are write-only bits. | Code | Function | |------|---------------------------| | 000 | Fill Buffer | | 001 | Empty Buffer | | 010 | Write Sector | | 011 | Read Sector | | 100 | Not used | | 101 | Read Status | | 110 | Write Deleted Data Sector | | 111 | Read Error Register | - 4 Unit select This bit selects one of the two possible disks for execution of the desired function. This is a write-only bit. - Done This bit indicates the completion of a function. Done will generate an interrupt when asserted if Interrupt Enable (RX2CS bit 6) is set. This is a read-only bit. - Interrupt Enable This bit is set by the program to enable an interrupt when the RX02 has completed an operation (Done). The condition of this bit is normally determined at the time a function is initiated. This bit is cleared by Initialize and is a read/write bit. - 7 Transfer Request This bit signifies that the RX11 or RXVII needs data or has data available. This is a read-only bit. #### 8-13 Unused 14 RX Initialize - This bit is set by the program to initialize the RX11 or RXV11 without initializing all devices on the Unibus. This is a write-only bit. #### CAUTION Loading the lower byte of the RXCS will also load the upper byte of the RXCS. Upon setting this bit in the RXCS, the RX11 or RXV11 will negate Done and move the head position mechanism of drive 1 (if two are available) to track 0. Upon completion of a successful Initialize, the RX02 will zero the error and status register, set Initialize Done, and set RXES bit 7 (DRV RDY) if unit 0 is ready. It will also read sector 1 of track 1 on drive 0. #### Bit No. Description - Error This bit is set by the RX02 to indicate that an error has occurred during an attempt to execute a command. This read-only bit is cleared by the initiation of a new command or an Initialize (Paragraph 4.2.6). - **4.2.2.2 RXDB Data Buffer Register** (177172) This register serves as a general purpose data path between the RX02 and the interface. It may represent one of four RX02 registers according to the protocol of the function in progress (Paragraph 4.2.3). This register is read/write if the RX02 is not in the process of executing a command; that is, it may be manipulated without affecting the RX02 subsystem. If the RX02 is actively executing a command, this register will only accept data if RXCS bit 7 (TR) is set. In addition, valid data can only be read when TR is set. # CAUTION Violation of protocol in manipulation of this register may cause permanent data loss. 4.2.2.3 RXTA – RX Track Address (Figure 4-18) – This register is loaded to indicate on which of the 77 (1148) tracks a given function is to operate. It can be addressed only under the protocol of the function in progress (Paragraph 4.2.3). Bits 8-15 are unused and are ignored by the control. Figure 4-18 RXTA Format (RX11/RXV11) 4.2.2.4 RXSA - RX Sector Address (Figure 4-19) - This register is loaded to indicate on which of the 26 (328) sectors a given function is to operate. It can be addressed only under the protocol of the function in progress (Paragraph 4.2.3). Bits 8-15 are unused and are ignored by the control. Figure 4-19 RXSA Format (RX11/RXV11) 4.2.2.5 RXDB - RX Data Buffer (Figure 4-20) - All information transferred to and from the floppy media passes through this register and is addressable only under the protocol of the function in progress (Paragraph 4.2.3). Figure 4-20 RXDB Format (RX11/RXV11) 4.2.2.6 RXES – RX Error and Status (Figure 4-21) – This register contains the current error and status conditions of the drive selected by bit 4 (Unit Select) of the RXCS. This read-only register can be addressed only under the protocol of the function in progress (Paragraph 4.2.3). The RXES content is located in the RXDB upon completion of a function. Figure 4-21 RXES Format (RX11, RXV11) RXES bit assignments are: #### Bit No. Description - O CRC Error A cyclic redundancy check error was detected as information was retrieved from a data field of the diskette. The RXES is moved to the RXDB, and Error and Done are asserted. - Initialize Done This bit is asserted in the RXES to indicate completion of the Initialize routine which can be caused by RX02 power failure, system power failure, or programmable or Unibus Initialize. 3 #### Bit No. Description Density Error – This bit is asserted to indicate the density of the function in progress does not match the drive density. Upon detection of this error the control terminates the operation and Error and Done are asserted. #### NOTE Bits 4 and 5 are asserted for the occurrence of double density when the system is RX01-compatible. - 5 Drive Density This bit indicates the density of the diskette in the drive selected. When asserted, double density is indicated. - 6 Deleted Data Detected During data recovery, the identification mark preceding the data field was decoded as a deleted data mark (Paragraph 1.5.3.2). - Drive Ready This bit is asserted if the unit currently selected exists, is properly supplied with power, has a diskette installed correctly, has its door closed, and has a diskette up to speed. #### NOTE 1 The drive ready bit is only valid when retrieved via a read status function or at completion of Initialize when it indicates status of drive 0. #### NOTE 2 If the error bit was set in the RXCS but error bits are not set in the RXES, specific error conditions can be accessed via a read error register function (Paragraph 4.2.3.7). 8 Unit Select - Drive 0 is selected if this bit is "0"; drive 1 is selected if this bit is a "1." #### 4.2.3 Function Codes Following the strict protocol of the individual function, data storage and recovery on the RX11 and RXV11 occur with careful manipulation of the RXCS and RXDB registers. The penalty for violation of protocol can be permanent data loss. A summary of the function codes is presented below: | 000 | Fill Buffer | |-----|---------------------------| | 001 | Empty Buffer | | 010 | Write Sector | | 011 | Read Sector | | 100 | Not used | | 101 | Read Status | | 110 | Write Deleted Data Sector | | 111 | Read Error Register | The following paragraphs describe in detail the programming protocol associated with each function encoded and written into RXCS bits 1-3 if Done is set. 4.2.3.1 Fill Buffer (000) – This function is used to fill the RX02 buffer with 128 8-bit bytes of data from the host processor. Fill buffer is a complete function in itself; the function ends when the buffer has been filled. The contents of the buffer can be written onto the diskette by means of a subsequent write sector function, or the contents can be returned to the host processor by an empty buffer function. RXCS bit 4 (Unit Select) does not affect this function since no diskette drive is involved. When the command has been loaded, RXES, OUT, and Done are cleared. When the TR bit is asserted, the first byte of the data may be loaded into the data buffer. The control then clears TR and after supplying the appropriate number of shift pulses to store the data, again asserts TR. The same TR cycle will occur as each byte of data is loaded. The RX02 counts the bytes transferred; it will not accept less than 128 bytes and will ignore those in excess. Any read of the RXDB during the cycle of 128 transfers is ignored by the RX11/RXV11. When the complete buffer has been filled, the control asserts Done. 4.2.3.2 Empty Buffer (001) – This function is used to empty into the interface the buffer of the 128 data bytes loaded from a previous Read Sector or Fill Buffer command. This function will ignore RXCS bit 4 (Unit Select) and negate Done. For this function, TR and shift pulses are generated in the same manner as for the fill buffer but the buffer is emptied. When TR sets, the program may unload the first of 128 data bytes from the RXDB. Then the RX11/RXV11 again negates TR. When TR resets, the second byte of data may be unloaded from the RXDB, which again negates TR. Alternate checks on TR and data transfers from the RXDB continue until 128 bytes of data have been moved from the RXDB. Done sets, ending the operation. ## NOTE The empty buffer function does not destroy the contents of the sector buffer. 4.2.3.3 Write Sector (010) – This function is used to locate a desired track and sector and write the sector with the contents of the internal sector buffer. The initiation of this function clears TR and Done. When TR is asserted, the program must move the desired sector address into the RXDB, which will negate TR. When TR is again asserted, the program must load the desired track address into the RXDB, which will negate TR. If the desired track is not found, the RX11/RXV11 will abort the operation, move the contents of the RXES to the RXDB, set RXCS bit 15 (Error), assert Done, and initiate an interrupt if RXCS bit 6 (Interrupt Enable) is set. TR will remain negated while the RX02 attempts to locate the desired sector. If the RX02 is unable to locate the desired sector within two diskette revolutions, the RX11/RXV11 will abort the operation, move the contents of the RXES to the RXDB, set RXCS bit 15 (Error), assert Done, and initiate an interrupt if RXCS bit 6 (Interrupt Enable) is set. If the desired sector is successfully located, the RX11/RXV11 will write the 128 bytes stored in the internal buffer followed by a 16-bit CRC character that is automatically calculated by the RX02. The RX11/RXV11 ends the function by asserting Done and initiating an interrupt if RXCS bit 6 (Interrupt Enable) is set. #### NOTE 1 The contents of the sector buffer are not valid data after a power loss has been detected by the RX02. The write sector function, however, will be accepted as a valid function, and the random contents of the buffer will be written, followed by a valid CRC. #### NOTE 2 The write sector function does not destroy the contents of the sector buffer. 4.2.3.4 Read Sector (011) – This function is used to locate a desired track and sector and transfer the contents of the data field to the $\mu$ CPU controller sector buffer. The initiation of this function clears RXES, Done, and OUT. When TR is asserted, the program must load the desired sector address into the RXDB, which will negate TR. When TR is again asserted, the program must load the desired track address into the RXDB, which will negate TR. If the desired track is not found, the RX11/RXV11 will abort the operation, move the contents of the RXES to the RXDB, set RXCS bit 15 (Error), assert Done, and initiate an interrupt if RXCS bit 6 (Interrupt Enable) is set. TR and Done will remain negated while the RX02 attempts to locate the desired track and sector. If the RX02 is unable to locate the desired sector within two diskette revolutions after locating the presumably correct track, the RX11/RXV11 will abort the operation, move the contents of the RXES to the RXDB, set RXCS bit 15 (Error), assert Done, and initiate an interrupt if RXCS bit 6 (Interrupt Enable) is set. If the desired sector is successfully located, the control will attempt to locate a standard data address mark or a deleted data address mark. If either mark is properly located, the control will read data from the sector into the sector buffer. If the deleted data address mark was detected, the control will assert RXES bit 6 (DD). As data enters the sector buffer, a CRC is computed, based on the data field and CRC bytes previously recorded. A non-zero residue indicates that a read error has occurred. The control sets RXES bit 0 (CRC Error) and RXCS bit 15 (Error). The RX11/RXV11 ends the operation by moving the contents of the RXES to the RXDB, sets Done, and initiates an interrupt if RXCS bit 6 (Interrupt Enable) is set. 4.2.3.5 Read Status (101) – The RX11/RXV11 will negate RXCS bit 5 (Done) and begin to assemble the current contents of the RXES into the RXDB. RXES bit 7 (Drive Ready) will reflect the status of the drive selected by RXCS bit 4 (Unit Select) at the time the read status function was given. All other RXES bits will reflect the conditions created by the last command. RXES may be sampled when RXCS bit 5 (Done) is again asserted. An interrupt will occur if RXCS bit 6 (Interrupt Enable) is set. RXES bits are defined in Paragraph 4.2.2.6. #### NOTE The average time for this function is 250 ms. Excessive use of this function will result in substantially reduced throughput. - 4.2.3.6 Write Sector with Deleted Data (110) This operation is identical to function 010 (write sector) with the exception that a deleted data address mark precedes the data field instead of a standard data address mark (Paragraph 1.5.3.2). - 4.2.3.7 Read Error Code Function (111) The read error code function can be used to retrieve explicit error information provided by the $\mu$ CPU controller upon detection of the general error bit. The function is initiated, and bits 0–6 of the RXES are cleared. Out is asserted and Done is negated. The controller then generates the appropriate number of shift pulses to transfer the specific error code to the interface register and completes the function by asserting Done. The interface register can now be read and the error code interrogated to determine the type of failure that occurred (Paragraph 4.2.6). #### NOTE Care should be exercised in the use of this function, since under certain conditions, erroneous error information may result (Paragraph 4.2.5). 4.2.3.8 Power Fail - There is no actual function code associated with Power Fail. When the RX02 senses a loss of power, it will unload the head and abort all controller action. All status signals are invalid while power is low. When the RX02 senses the return of power, it will remove Done and begin a sequence to: - 1. Move drive 1 head position mechanism to track 0. - 2. Clear any active error bits. - 3. Read sector 1 of track 1 of drive 0 into the sector buffer. - 4. Set RXES bit 2 (Initialize Done) (Paragraph 4.2.2.6) after which Done is again asserted. - 5. Set Drive Ready of the RXES according to the status of drive 0. There is no guarantee that information being written at the time of a power failure will be retrievable. However, all other information on the diskette will remain unaltered. A method of aborting a function is through the use of RXCS bit 14 (RX Initialize). Another method is through the use of the system Initialize signal that is generated by the PDP-11 RESET instruction, the console START key, or system power failure. #### 4.2.4 Programming Examples 4.2.4.1 Read Data/Write Data – Figure 4-22 presents a program for implementing a write, write deleted data, or a read function, depending on the function code that is used. The first instructions set up the error retry counters, PTRY, CTRY, and STRY. The instruction RETRY moves the command word for a write, write deleted data, or read into the RXCS. The set of three instructions beginning at the label 1\$ moves the sector address to the RX11/RXVII after transfer request (TR), which is bit 7, has been set. The three instructions beginning at the label 2\$ move the track address to the RX11/RXVII after TR has been set. The group of instructions beginning at the label 3\$ looks for the done flag to set and checks for errors. An error condition, indicated by bit 15 setting, is checked beginning at ERFLAG. If bit 0 is set, a CRC error has occurred, and a branch is made to CRCER. If a parity error has occurred, a branch is made to PARER. If neither of the above occurs, a seek error is assumed to have occurred and a branch is made to SEEKER, where the system is initialized. In the case of a write function, the sector buffer is refilled by a JMP to FILLBUF. In the case of a read function, a JMP is made to EMPBUFF. ``` .ABS PROGRAMING EXAMPLES FOR THE RESERVES PLEXIBLE DISKETTE 123456789812334567898123222222233333333344444444445555 THE FOLLOWING IS THE RX11 STANDARD DEVICE ADDRESS AND VECTOR ADDRESS 177178 177172 177172 177172 177172 177172 , RXCS=177178 RXOB=177172 HXSA=177172 HXTA=177172 ; COMMAND STATUS REGISTER; DATA BUFFER REGISTER; SECTOR ADDRESS REGISTER; TRACM ADDRESS REGISTER; ERROR ETATUS REGISTER ; THE FOLLOWING IS A PROGRAMMING EXAMPLE OF THE PROTOCOL REQUIRED ITO WRITE, WRITE DELETED DATA. OR READ AT BEGTOR "8" (THE CONTENTS OF PROBRAM ILOGATION SECTOR) OF TRACK "?" (THE CONTENTS OF PROGRAM LOCATION TRACK) STARTI HOY #-18, PTRY HOY #-18, CTRY HOY #-18, STRY #12747 177770 088328 #12767 177778 008314 #12747 177778 888318 : PARITY RETRY COUNTER : CRC RETRY COUNTER : SEEK RETRY COUNTER WRITE, WRITE DELETED DATA, OR READ BITS 4 THRU I OF PROSMAN LOCATION COMMAND CONTAIN THE FUNCTION 3 THRU 1 IS THE COMMAND ( 4 . MAITE, 14 . MAITE DELETED DATA, 4 . READ) TSTB RXCS BEG 18 MOVP SECTOR, RXSA ; TEST FOR THE TRANSFER REQUEST FLAG ; SEO UNTIL THE TRANSFER REQUEST FLAG SETS ; LOAD SECTOR ADDRESS 850638 199767 177134 898834 861775 888836 114747 DJ8274 038274 177126 HALT FOR THE TRANSFER REQUEST FLAG THEN TRANSFER THE TRACK ADDRESS 888644 189767 177128 888698 881775 888699 116767 488262 TSTO MXCS OCO 25 HOVO TRACK, RKTA : TEST FOR THE TRAMSFER REQUEST FLAG : BEG UNTIL THE TRAMSFER REQUEST FLAG SETS : LOAD TRACK ADDRESS THE SECTOR AND TRACK ADDRESSES HAVE BEEN TRANSFERRED TO THE RESI SHEATT FOR THE DONE FLAG AND CHECK FOR ANY ERRORS FIF THE FUNCTION MAS COMPLETED SUGGESSPULLY ING ERROR FLAGS THEN HALT MIT #DONEBIT, RXGS MEG 38 TST RXGS BNC ERPLAG MALT 332767 381774 889767 881881 : TEST FOR THE DONE FLAG SETS : BED UNTIL THE DONE FLAG SETS : TEST FOR THE ERROR FLAG : BME IF AN ERROR MAS DOCUMED : DK = COMPLETED JERO48 177182 3$1 THE ERAOR FLAG 15 SET THE CONTENTS OF THE RES IS THE ERROR STATUS ; ;[f the rice bits 1 and 0 = 8 them some type of seek error occured ;[f the rice bit 8 = 1 them 1 crc error has occured ;[f the rice bit 1 = 1 them 1 partyy error has occured ERFLAGI BIT #3, RXES BCG SEEK BIT #2, RXES BCG CAC : TEST FOR CRC AND PARITY EMBORS ; NOT A PARITY OR GRC CHUST) BE A SEEK ; YEST FOR PARITY EMBOR ; NOT A PARITY ERROR (MUST) BE A CRC A PARETY ERROR HAS OCCURED FINGREMENT AND TEST THE PARITY ERROR RETRY COUNTER PROBRAM LOCATION " PTRY " AND RETRY THE " COMMAND " UNTIL THE PARTTY ERROR RECOVERS ION UNTIL THE PTRY COUNTER OVERFLOHS TO B 88812# 289267 858124 981336 988126 #6886 INC PTRY SNE RETRY WALT 240505 ; RETRY THE COMMAND : HARD PARITY ERROR IA CRC EMMOM HAS QCCUMED ILNCREMENT AND TEST THE CRG ERROR RETRY COUNTER PROGRAM LOCATION R CTRY " AND RETRY THE COMMAND UNTIL THE GRG ERROR RECOVERS FOR UNTIL THE CTRY COUNTER OVERFLOWS TO E 885247 381332 INC CTRY 000174 ; RETRY THE COMMAND : MARO CRC ERROR HALT 91 92 93 94 95 97 98 THE ERROR FLAG 15 SET ITHE ERROR IS CHOT) A PARITY ERROR AND 18 CHOTS A GRC ERROR THEREFORE IT HUST BE A SEEK ERROR 183 181 182 183 184 185 186 187 INCREMENT AND TEST THE SEEK ERROR RETRY COUNTER PROGRAM LOCATION " STRY " AND RETRY THE COMMAND UNTIL THE SEEK ERROR RECOVERS IOR UNTIL THE CTRY COUNTER OVERFLOWS TO . 889267 881323 889888 848168 : RETRY THE SOMMANS ; HARD SEEK FRADA ``` Figure 4-22 RX11/RXV11 Write/Write Deleted Data/Read Example In each of the PAR, CRC, and SEEK routines, the command sequence is retried 10 times by decrementing the respective retry counter. If an error persists after 10 tries, it is a hard error. The retry counters can be set up to retry as many times as desired. #### NOTE A fill buffer function is performed before a write function, and an empty buffer function is performed after a read function. 4.2.4.2 Empty Buffer Function - Figure 4-23 shows a program for implementing an empty buffer function. The first instruction sets the number of error retries to 10. The address of the memory buffer is placed in register R0, and the Empty Buffer command is placed in the RXCS. Existence of a parity error is checked starting at instruction 3\$. If a parity error is detected, the Empty Buffer command is loaded again. If an error persists for 10 retries, the error is considered hard. If no error is indicated, the program looks for the transfer request (TR) flag to set. The error flag is retested if TR is not set. Once TR sets, a byte is moved from the RX11/RXV11 sector buffer to the core locations of BUFFER. The process continues until the sector buffer is empty and the Done bit is set. 4.2.4.3 Fill Buffer Function - Figure 4-24 presents a program to implement a fill buffer function. It is very similar to the empty buffer example. #### 4.2.5 Restrictions and Programming Pitfalls A set of restrictions and programming pitfalls for the RX11/RXV11 is presented below. - Depending on how much data handling is done by the program between sectors, the minimum interleave of two sectors may be used, but to be safe a three-sector interleave is recommended. - 2. If an error occurs and the program executes a read error code function (111), a parity error may occur for that command. The error status would not be for the error in which the read error code function was originally required. - 3. The DRV SEL RDY bit is only updated at the time of a read status function (101) for both drives, and after an Initialize, depending on the status of drive 0. At the termination of any other functions it reflects the drive status of the last Read Status or Initialize command. - 4. It is not required to load the Drive Select bit into the RXCS when the command is Fill Buffer (000) or Empty Buffer (010). - 5. Sector Addressing: 1-26 (No sector 0) Track Addressing: 0-76 - 6. A power failure causing the recalibration of the drives will result in a Done condition, the same as finishing reading a sector. However, during a power failure, RXES bit 2 (Initialize Done) will set. Checking this bit will indicate a power fail condition. - Excessive use of the read status function (101) will result in drastically decreased throughput, because a read status function requires between one and two diskette revolutions or about 250 ms to complete. ``` 168 161 THE FOLLOWING IS A PROGRAMMING EXAMPLE OF PROTOCOL REQUIRED TO 162 163 164 165 EMPTY THE SECTOR BUFFER OF 128 8-814 BYTES 177778 096342 ÉENTRYI MOV #-18, PTRY Esetup: Mov #Buffer, Hø 688242 888238 312767 312786 884956 ; 8 TRYS TO EMPTY THE SECTOR BUFFER ; PROHORANS DATA BUFFER ; ISSUE THE COMMANO J16767 U08854 174786 HOV COMMAND, MXCS 167 168 169 178 171 172 173 . WALT FOR A TRANSFER REQUEST FLAG BEFORE TRANSFERRING DATA TO THE PROGRAMS DATA BUFFER FROM THE RXB1 SECTOR BUFFER WALT FOR A DONE FLAG TO INDICATE THE COMPLETION OF THE EMPTY BUFFER COMMAND 174 175 176 177 IPRIOR TO TESTIN G THE ERROR FLAG 109767 001014 032767 001771 ; TEST FOR TRANSFER REQUEST FLAG ; SHE IF TRANSFER REQUEST FLAG IS SET ; TEST FOR DONE FLAG 889262 889266 176722 HAT EMPTY BIT SDONEBIT, RXCS 178 179 888278 888276 238848 176672 FEG UNTIL THE DONE FLAG BETS BEG ELOOP 181 182 THE DONE FLAG IS SET TEST FOR ANY ERRORS CONLY ERROR POSSIBLE IS A PARITY ERROR) 183 184 205767 966396 176664 186 187 000304 000306 001801 000000 : NO ERRORS - OK - COMPLETE 189 198 191 192 INGFEMENT AND TEST THE PARITY ERROR RETRY PROGRAM LOCATION " PTRY " FAND RETRY THE COMMAND UNTIL THE ERROR RECOVERS 193 194 195 196 197 OR UNTIL THE PTRY CUNTER OVERFLOWS TO B INC PTRY ONE ESETUP HALT 200318 005267 238612 200314 201355 : RETRY TO EMPTY THE SECTOR BUFFER : MARD PARTTY ERROR 000000 196 199 200 201 THE TRANSFER REQUEST FLAG IS SET TRANSFER DATA TO THE PROGRAM DATA BUFFER FROM THE RXB1 SECTOR BUFFER 202 988328 116739 984324 989756 HOVS RXDS, P(KS)+ BR ELCOP 203 176646 206 207 ITHE FOLLOWING 3 PROCHAM LOCATIONS ARE THE ERROR RETRY COUNTERS 208 209 200326 PTRV: : PARITY ERROR RETRY COUNTER : CRC ERROR RETRY COUNTER : SEEK ERROR RETRY COUNTER 996909 338668 210 STRY: 211 212 213 PROGRAM LOCATION " COMMAND " CONTAINS THE COMMAND TO BE ISSUED VIA THE LCD LOT 214 215 SHRITE (4), HRITE DELETED GATA (14), OR READ (6), OR EMPTY BUFPER (2) 000334 000000 COMMAND: : 4, 14, 6, aR 2 + (GD B)T 1 = 1) IPROGRAM LOCATION " SECTOR " CONTAINS THE SECTOR ADDRESS (1 TO 32 OCTAL) 688334 088868 : 1 TO 38 OCTAL 222 223 224 PROGRAM LOCATION " TRACK " CONTAINS THE TRACK ADDRESS (# TO 114 OCTAL) 068346 000000 TRACK! 8 ; $ TO 114 DETAL 225 226 227 PROGRAM EQUIVALENTS 228 229 028849 DONEBIT#45 1N:T=40560 BUFFERM, #BUFFER+288 230 208342 231 ENO. ``` Figure 4-23 RX11/RXV11 Empty Buffer Example ``` THE FOLLOWING IS A PROGRAMMING EXAMPLE OF THE PROTOCOL REQUIRED TO 111 112 113 114 115 116 117 FILL THE BECTOR BUFFER WITH 128 6-817 BYTES NOTE: THE DATA TO FILL THE SECTOR BUFFER CAN BE ASSEMBLED IN CORE IN THE EVEN ADDRESSES BYTES OF 129 WORDS OR IN BOTH BYTES OF 44 MONDS FENTRY: MOV #-18, PTRY SETUPI MOV #BUFFER, RB MOV COMMAND, MXCS ; B TRYS TO FILL THE SECTOR SUPPER ; PROGRAMS DATA SUFFER ; ISSUE THE COMMAND #12767 177770 888142 118 119 912708 000342 020140 128 316767 121 122 123 124 IWAIT FOR A TRANSFER MEGUEST FLAG BEFORE TRANSFERRING DATA FROM THE PROGRAMS DATA BUFFER TO THE RXB1 SECTOR BUFFER 126 127 128 129 138 INAIT FOR A COME FLAT TO INDICATE THE COMPLETION OF THE FILL BUFFER COMMAND PRIOR TO TESTING THE ERROR FLAG : TEST FOR TRANSFER REQUEST FLAG : 2CO IF TRANSFER REQUEST FLAG SET : TEST FOR THE OONE FLAG : BEQ UNTIL THE DONE FLAG SETS 088176 195767 176766 TSTB RXCS 131 068202 008204 881414 832767 BIT POONEBIT, RXCS 000040 176796 BEG LOOP 134 135 136 137 138 THE DONE PLAG IS SET ITEST FOR ANY ERRORS CONLY ERROR POSSIBLE IS A PARTTY ERROR! 176758 005767 001001 00000 139 140 TST RXCS 000214 000220 141 142 143 144 145 : NO EARORS . DK . COMPLETE INCREMENT AND TEST THE PARITY ERROR RETRY PROGRAM LOCATION " PTRY " IAND RETRY THE COMMAND UNTIL THE EARDR RECOVERS 147 IOR UNTIL THE PTRY COUNTER OVERFLOWS TO 9 149 150 000224 000230 005267 001355 INC PTRY ONE SETUP 000076 13: : RETRY TO FILL THE SECTOR SUFFER 151 152 153 154 155 222500 ; HARD PARITY ERROR THE TRANSFER REQUEST FLAG IS BET TRANSFER DATA FROM THE PROGRAMS DATA SUFFER TO THE REST SECTOR SUFFER 156 000234 000240 113067 176732 MOVE #(REJ+, MXDS BR LDGP ; PROGRAMS DATA BUFFER IS 64 NORDE IN LENGTH ``` Figure 4-24 RX11/RXV11 Fill Buffer Example #### 4.2.6 Error Recovery There are two error indications given by the RX11/RXV11 system. The read status function (Paragraph 4.2.3.5) will assemble the current contents of the RXES (Paragraph 4.2.2.6), which can be sampled to determine errors. The read error code function (Paragraph 4.2.3.7) can also be used to retrieve explicit error information. The RX11/RXV11 interface register can be interrogated to determine the type of failure that occurred. A list of error codes follows. #### NOTE A read status function is not necessary if the DRV RDY bit is not going to be interrogated because the RX2ES is in the interface register at the completion of every function. | Octal | | | | | | | | | |-------|-----------------------------------------------------------------------------------|--|--|--|--|--|--|--| | Code | Error Code Meaning | | | | | | | | | 0010 | Drive 0 failed to see home on Initialize | | | | | | | | | 0020 | Drive 1 failed to see home on Initialize | | | | | | | | | 0040 | Tried to access a track greater than 77 | | | | | | | | | 0050 | Home was found before desired track was reached | | | | | | | | | 0070 | Desired sector could not be found after looking at 52 headers (2 revolutions) | | | | | | | | | 0110 | More than 40 μs and no SEP clock seen | | | | | | | | | 0120 | A preamble could not be found | | | | | | | | | 0130 | Preamble found but no ID mark found within allowable time span | | | | | | | | | 0140 | CRC error on what appeared to be a header. Error is not asserted | | | | | | | | | 0150 | The header track address of a good header does not compare with the desired track | | | | | | | | | 0160 | Too many tries for an IDAM (identifies header) | | | | | | | | | 0200 | CRC error on reading the sector from the disk | | | | | | | | | 0220 | R/W electronics failed maintenance mode test | | | | | | | | | 0240 | Density Error | | | | | | | | #### 4.3 RX211 and RXV21 PROGRAMMING INFORMATION This section describes device registers, register and vector address assignments, programming specifications, and programming examples for the RX211 and RXV21 interfaces. All software control of the RX211/RXV21 is performed by means of two device registers: the command and status register (RX2CS) and a multipurpose data buffer register (RX2DB) which have been assigned bus addresses and can be read or loaded. The RX02 contains all the control circuitry required to read from and write on the disk and to calculate and verify the CRC. It has a buffer large enough to hold one full sector of diskette data (128 or 256 8-bit bytes). Information is serially passed between the interface and the RX02. A typical diskette write sequence, which is initiated by a user program, would occur in two steps: Fill Buffer - A command to fill the buffer is moved into the RX2CS. The Go bit must be set. The program tests for TR. When TR is detected, the program moves the desired word count into the RX2DB. TR goes false while the word count is moved to the RX02. The program retests TR and moves the bus address into the RX2DB. The device now requests bus mastership and DMA's one data word at a time into the RX2DB and shifts it across the RX02 data bus serially one 8-bit byte at a time into the sector buffer. When the word count register overflows (if necessary, the RX02 control zero-fills the remainder of the sector buffer) the Done bit is set, and an interrupt will occur if the program has enabled interrupts. Write Sector - A command to write the contents of the sector buffer onto the disk is moved into the RX2CS. The program tests TR and when TR is set, moves the desired sector address to the RX2DB. TR remains false while the sector address is shifted to the RX02 control. The control retests TR and when it is again set, moves the desired track address register to the RX2DB. Again TR is negated. The RX02 locates the desired track and sector and compares the diskette density against the assigned function density and writes the contents of the sector buffer onto the disk if the densities agree. When the write operation is completed, the Done bit is set and an interrupt will occur if the program has enabled interrupts. A typical disk read operation occurs in the reverse order. First, the desired track and sector are located and the contents of the sector are read into the sector buffer (read sector). Then the contents of the sector buffer is unloaded into memory (empty buffer). In either case, the contents of the sector buffer are not valid if either a Power Fail or Initialize follows a fill buffer or read sector function. #### 4.3.1 Register and Vector Addresses The RX211/RXV21 use two registers for communicating with the host computer: the command and status register (RX2CS) normally assigned bus address 177170 and the data buffer register (RX2DB) normally assigned bus address 177172. The vector address is 264. #### 4.3.2 Register Description 4.3.2.1 RX2CS - Command and Status (177170) - Loading this register while the RX02 is not busy and with bit 0=1 will initiate a function as described below and indicated in Figure 4-25. Figure 4-25 RX2CS Format (RX211/RXV21) #### Bit No. Description - O Go Initiates a command to RX02. This is a write-only bit. - Function Select These bits code one of the eight possible functions described in Paragraph 4.3.3 and listed below. These are write-only bits. | Code | Function | |------|---------------------------| | 000 | Fill Buffer | | 001 | Empty Buffer | | 010 | Write Sector | | 011 | Read Sector | | 100 | Set Media Density | | 101 | Read Status | | 110 | Write Deleted Data Sector | | 111 | Read Error Code | | | | - 4 Unit select This bit selects one of the two possible disks for execution of the desired function. This bit is readable only when Done is set, at which time it indicates the unit previously selected. This is a read/write bit. - 5 Done This bit indicates the completion of a function. Done will generate an interrupt when asserted if Interrupt Enable (RX2CS bit 6) is set. This is a read-only bit. #### Bit No. Description - Interrupt Enable This bit is set by the program to enable an interrupt when the RX02 has completed an operation (Done). The condition of this bit is normally determined at the time a function is initiated. This bit is cleared by Initialize and is a read/write bit. - 7 Transfer Request This bit signifies that the RX211/RXV21 needs data or has data available. This is a read-only bit. - B Density This bit determines the density of the function to be executed. This bit is readable only when Done is set, at which time it indicates the density of the function previously executed. This is a read/write bit. - 9-10 Reserved for future use. Must be written as zero. - 11 RX02 This bit is set by the interface to inform the programmer that this is an RX02 system. This is a read-only bit. - 12-13 Extended address These bits are used to declare an extended bus address. These are write-only bits. - 14 RX211/RXV21 Initialize This bit is set by the program to initialize the RX211/RXV21 without initializing all devices on the Unibus. This is a write-only bit. ### CAUTION Loading the lower byte of the RX2CS will also load the upper byte of the RX2CS. Upon setting this bit in the RX2CS, the RX211/RXV21 will negate Done and move the head position mechanism of both drives (if two are available) to track 0. Upon completion of a successful Initialize, the RX02 will zero the error and status register, and set Initialize Done. It will also read sector 1 of track 1 on drive 0 into the buffer. - Error This bit is set by the RX02 to indicate that an error has occurred during an attempt to execute a command. This read-only bit is cleared by the initiation of a new command or an Initialize. - 4.3.2.2 RX2DB Data Buffer Register (177172) This register serves as a general purpose data path between the RX02 and the interface. It may represent one of six RX02 registers according to the protocol of the function in progress (Paragraph 4.3.3). This register is read/write if the RX02 is not in the process of executing a command; that is, it may be manipulated without affecting the RX02 subsystem. If the RX02 is actively executing a command, this register will only accept data if RX2CS bit 7 (TR) is set. In addition, valid data can only be read when TR is set. #### CAUTION Violation of protocol in manipulation of this register may cause permanent data loss. 4.3.2.3 RX2TA - RX Track Address (Figure 4-26) - This register is loaded to indicate on which of the 1148 (0-76<sub>10</sub>) tracks a given function is to operate. It can be addressed only under the protocol of the function in progress (Paragraph 4.3.3). Bits 8-15 are unused and are ignored by the control. Figure 4-26 RX2TA Format (RX211/RXV21) 4.3.2.4 RX2SA - RX Sector Address (Figure 4-27) - This register is loaded to indicate on which of the 32<sub>8</sub> (1-26<sub>10</sub>) sectors a given function is to operate. It can be addressed only under the protocol of the function in progress (Paragraph 4.3.3). Figure 4-27 RX2SA Format (RX211/RXV21) 4.3.2.5 RX2WC - RX Word Count Register (Figure 4-28) - For a double density sector the maximum word count is 128<sub>10</sub>. For a single density sector the maximum word count is 64<sub>10</sub>. If a word count is beyond the limit for the density indicated, the control asserts Word Count Overflow (bit 10 of RX2ES). This is a write-only register. The actual word count and not the 2's complement of the word count is loaded into the register. Figure 4-28 RX2WC Format (RX211/RXV21) 4.3.2.6 RX2BA - RX Bus Address Register (Figure 4-29) - This register specifies the bus address of data transferred during fill buffer, empty buffer, and read definitive error operations. Incrementation takes place after a memory transaction has occurred. The RX2BA, therefore, is loaded with the address of the first data word to be transferred. This is a 16-bit, write-only register (Paragraph 4.3.3). Figure 4-29 RX2BA and RX2DB Format (RX211/RXV21) 4.3.2.7 RX2DB – RX Data Buffer (Figure 4-29) – All information transferred to and from the floppy media passes through this register and is addressable only under the protocol of the function in progress (Paragraph 4.3.3). **4.3.2.8 RX2ES - RX Error and Status** (Figure 4-30) – This register contains the current error and status conditions of the drive selected by bit 4 (Unit Select) of the RX2CS. This read-only register can be addressed only under the protocol of the function in progress (Paragraph 4.3.3). The RX2ES is located in the RX2DB upon completion of a function. Figure 4-30 RX2ES Format (RX211/RXV21) RXES bit assignments are: #### Bit No. Description - O CRC Error A cyclic redundancy check error was detected as information was retrieved from a data field of the diskette. The data collected must be considered invalid. The RX2ES is moved to the RX2DB, and Error and Done are asserted. It is suggested that the data transfer be retried up to 10 times, as most errors are recoverable (soft). - Initialize Done This bit is asserted in the RX2ES to indicate completion of the Initialize routine which can be caused by RX02 power failure, system power failure, or programmable or bus Initialize. - RX AC LO This bit is set by the interface to indicate a power failure in the RX02 subsystem. - Density Error This bit indicates that the density of the function in progress does not match the drive density. Upon detection of this error the control terminates the operation and asserts Error and Done. #### Bit No. Description - 5 Drive Density This bit indicates the density of the diskette in the drive selected (indicated by bit 8). The density of the drive is determined during read and write sector operations. - Deleted Data This bit indicates that in the course of recovering data, the "deleted data" address mark was detected at the beginning of the data field. The Drv Den bit indicates whether the mark was a single or double density deleted data address mark. The data following the mark will be collected and transferred normally, as the deleted data mark has no further significance other than to establish drive density. Any alteration of files or actual deletion of data due to this mark must be accomplished by user software. - Drive Ready This bit indicates that the selected drive is ready if bit 7=1 and all conditions for disk operation are satisfied, such as door closed, power okay, diskette up to speed, etc. The RX02 may be presumed to be ready to perform any operation. This bit is only valid when retrieved via a read status function or initialize. - 8 Unit Select This bit indicates that drive 0 is selected if bit 8=0. This bit indicates the drive that is currently selected. - Word Count Overflow This bit indicates that the word count is beyond sector size. The fill or empty buffer operation is terminated and Error and Done are set. - Nonexistent Memory Error This bit is set by the interface when a DMA transfer is being performed and the memory address specified in RX2BA is nonexistent. #### 4.3.3 Function Codes Following the strict protocol of the individual function, data storage and recovery on the RX211/RXV21 occur with careful manipulation of the RX2CS and RX2DB registers. The penalty for violation of protocol can be permanent data loss. A summary of the function codes is presented below: | 000 | Fill Buffer | |-----|---------------------------| | 001 | Empty Buffer | | 010 | Write Sector | | 011 | Read Sector | | 100 | Set Media Density | | 101 | Read Status | | 110 | Write Deleted Data Sector | | 111 | Read Error Code | The following paragraphs describe in detail the programming protocol associated with each function encoded and written into RX2CS bits 1-3 if Done is set. 4.3.3.1 Fill Buffer (000) - This function is used to fill the RX02 data buffer with the number of words of data specified by the RX2WC register. Fill buffer is a complete function in itself: the function ends when RX2WC overflows, and if necessary, the control has zero-filled the remainder of the buffer. The contents of the buffer may be written on the disk by means of a subsequent Write Sector command or returned to the host processor by an Empty Buffer command. If the word count is too large, the function is terminated, Error and Done are asserted, and the Word Count overflow bit is set in RX2ES. To initiate this function the RX2CS is loaded with the function. Bit 4 of the RX2CS (Unit Select) does not affect this function since no disk operation is involved. Bit 8 (Density) must be properly selected since this determines theword count limit. When the command has been loaded, the Done bit (RX2CS bit 5) goes false. When the TR bit is asserted the RX2WC may be loaded into the data buffer register. When TR is again asserted, the RX2BA may be loaded into the RX2DB. The data words are transferred directly from memory and when RX2WC overflows and the control has zero-filled the remainder of the sector buffer, if necessary, Done is asserted ending the operation. If bit 6 RX2CS (Interrupt Enable) is set, an interrupt is initiated. Any read of the RX2DB during the data transfer is ignored by the interface. After Done is true the RX2ES is located in the RX2DB register. 4.3.3.2 Empty Buffer (001) - This function is used to empty the contents of the internal buffer through the RX211/RXV21 for use by the host processor. This data is in the buffer as the result of a previous Fill Buffer or Read Sector command. The programming protocol for this function is identical to that for the Fill Buffer command. The RX2CS is loaded with the command to initiate the function. (This function will ignore bit 4 RX2CS, Unit Select). RX2CS bit 8 (Density) must be selected to allow the proper word count limit. When the command has been loaded, the Done bit (RX2CS bit 5) goes false. When the TR bit is asserted, the RX2WC may be loaded into the RX2DB. When TR is again asserted the RX2BA may be loaded into the RX2DB. The RX211/RXV21 assembles one word of data at a time and transfers it directly to memory. Transfers occur until word count overflow, at which time the operation is complete and Done goes true. If bit 6 RX2CS (Interrupt Enable) is set, an interrupt is initiated. After Done is true, the RX2ES is located in the data buffer register. 4.3.3.3 Write Sector (010) – This function is used to locate a desired sector on the diskette and fill it with the contents of the internal buffer. The initiation of the function clears RX2ES, TR, and Done. When TR is asserted, the program must load the desired sector address into RX2DB, which will drop TR. When TR is again asserted, the program must load the desired track address into the RX2DB, which will drop TR. TR will remain unasserted while the RX02 attempts to locate the desired sector. The diskette density is determined at this time and is compared to the function density. If the densities do not agree, the operation is terminated; bit 4 RX2ES is set, RX2ES is moved to the RX2DB, Error (bit 15 RX2CS) is set, Done is asserted, and an interrupt is initiated, if bit 6 RX2CS (Interrupt Enable) is set. If the densities agree but the RX02 is unable to locate the desired sector within two diskette revolutions, the interface will abort the operation, move the contents of RX2ES to the RX2DB, set Error (bit 15 RX2CS), assert Done, and initiate an interrupt if bit 6 RX2CS (Interrupt Enable) is set. If the desired sector has been reached and the densities agree, the RX211/RXV21 will write the 128<sub>10</sub> or 64<sub>10</sub> words stored in the internal buffer followed by a CRC character which is automatically calculated by the RX02. The RX211/RXV21 ends the function by asserting Done and if bit 6 RX2CS (Interrupt Enable) is set, initiating an interrupt. #### **CAUTION** The contents of the sector buffer are not valid data after a power loss has been detected by the RX02. However, write sector will be accepted as a valid instruction and the (random) contents of the buffer will be written, followed by a valid CRC. #### NOTE The contents of the sector buffer are not destroyed during a write sector operation. 4.3.3.4 Read Sector (011) – This function is used to locate the desired sector and transfer the contents of the data field to the internal buffer in the control. This function may also be used to retrieve rapidly (5 ms) the current status of the drive selected. The initiation of this function clears RX2ES, TR, and Done. When TR is asserted the program must load the desired sector address into the RX2DB, which will drop TR. When TR is again asserted, the program must load the desired track address into the RX2DB, which will drop TR. TR and Done will remain negated while the RX02 attempts to locate the desired sector. If the RX02 is unable to locate the desired sector within two diskette revolutions for any reason, the RXV21/RX211 will abort the operation, set Done and Error (bit 15 RX2CS), move the contents of the RX2ES to the RX2DB, and if bit 6 RX2CS (Interrupt Enable) is set, initiate an interrupt. If the desired sector is successfully located, the control reads the data address mark and determines the density of the diskette. If the diskette (drive) density does not agree with the function density the operation is terminated and Done and Error (bit 15 RX2CS) are asserted. Bit 4 RX2ES is set (Density Error) and the RX2ES is moved to the RX2DB. If bit 6 RX2CS (Interrupt Enable) is set, an interrupt is initiated. If a legal data mark is successfully located, and the control and densities agree, the control will read data from the sector into the internal buffer. If a deleted data address mark was detected, the control will set bit 6 RX2ES (DD). As data enters the internal buffer, a CRC is computed based on the data field and the CRC bytes previously recorded. A non-zero residue indicates that a read error has occurred and the control sets bit 0 RX2ES (CRC error) and bit 15 RX2CS (Error). The RX211/RXV21 ends the operation by asserting Done and moving the contents of the RX2ES into the RX2DB. If bit 6 RX2CS is set, an interrupt is initiated. If the desired sector is successfully located, the densities agree, and the data is transferred with no CRC error, Done will be set and if bit 6 RX2CS (Interrupt Enable) is set the RX211/RXV21 initiates an interrupt. 4.3.3.5 Set Media Density (100) – This function causes the entire diskette to be reassigned to a new density. Bit 8 RX2CS (Density) indicates the new density. The control reformats the diskette by writing new data address marks (double or single density) and zeroing all of the data fields on the diskette. The function is initiated by loading the RX2CS with the command. Initiation of the function clears RX2ES and Done. When TR is set, an ASCII "I" (111) must be loaded into the RX2DB to complete the protocol. This extra character is a safeguard against an error in loading the command. When the control recognizes this character it begins executing the command. The control starts at sector 1, track 0 and reads the header information, then starts a write operation. If the header information is damaged, the control will abort the operation. If the operation is successfully completed, Done is set and if bit 6 RX2CS (Interrupt Enable) is set, an interrupt is initiated. #### **CAUTION** This operation takes about 15 seconds and should not be interrupted. If for any reason the operation is interrupted, an illegal diskette has been generated which may have data marks of both densities. This diskette should again be completely reformatted. - 4.3.3.6 Maintenance Read Status (101) This function is initiated by loading the RX2CS with the command. Done is cleared. The Drive Ready bit (bit 7 RX2ES) is updated by counting index pulses in the control. The Drive Density is updated by loading the head of the selected drive and reading the first data mark. The RX2ES is moved into the RX2DB. The RX2CS may be sampled when Done (bit 5 RX2CS) is again asserted and if bit RX2CS (Interrupt Enable) is set, an interrupt will occur. This operation requires approximately 250 ms to complete. - 4.3.3.7 Write Sector with Deleted Data (110) This operation is identical to function 010 (write sector) with the exception that a deleted data address mark is written preceding the data rather than the standard data address mark. The Density bit associated with the function indicates whether a single or double density deleted data address mark will be written. - 4.3.3.8 Read Error Code (111) The read error code function implies a read extended status. In addition to the specific error code a dump of the control's internal scratch pad registers also occurs. This is the only way that the word count register can be retrieved. This function is used to retrieve specific information as well as drive status information depending upon detection of the general Error bit. The transfer of the registers is a DMA transfer. The function is initiated by loading the RX2CS with the command and then Done goes false. When TR is true, the RX2BA may be loaded into the RX2DB and TR goes false. The registers are assembled one word at a time and transferred directly to memory. #### Register Protocol | Word 1 < 7:0> | Definitive Error Codes | | |-----------------|----------------------------------------|---| | Word 1 < 15:8> | Word Count Register | | | Word 2 < 7:0> | Current Track Address of Drive 0 | | | Word 2 < 15:8> | Current Track Address of Drive 1 | | | Word 3 <7:0> | Target Track of Current Disk Access | | | Word 3 < 15:8> | Target Sector of Current Disk Access | | | Word 4 < 7> | Unnit Select Bit | * | | Word 4 < 5> | Head Load Bit | * | | Word 4 <6><4> | Drive Density Bit of Both Drives | * | | Word 4 < 0> | Density of Read Error Register Command | * | | Word 4 < 15:8 > | Track Address of Selected Drive | † | 4.3.3.9 RX02 Power Fail - When the RX02 control senses a loss of power within the RX02, it will unload the head and abort all controller action. The RXAC L line is asserted to indicate to the RX211/RXV21 that subsystem power is gone. The RX211/RXV21 asserts Done and Error and sets the RXAC L bit in the RX2ES. When the RX02 senses the return of power, it will remove Done and begin a sequence to: - 1. Move each drive head position mechanism to track 0 - 2. Clear any active error bits - 3. Read sector 1 of track 1, on drive 0 - 4. Assert Initialize Done in the RXES. <sup>\*</sup> For DMA interfaces the controller status soft register is sent to the interface at the end of the command. The four status bits are included in an 8-bit word. Unit Select = bit 7, Density of Drive 1 = bit 6, Head Load = bit 5, Density of Drive 0 = bit 4, Density of Read Error Register Command = bit 0. <sup>†</sup> The Track Address of the Selected Drive – Error is only meaningful on a code 150 error. The register contains the address of the cylinder that the head reacheed on a seek error. Upon completion of the power up sequence, Done is again asserted. There is no guarantee that information being written at the time of a power failure will be retrievable; however, all other information on the diskette will remain unaltered. #### 4.3.4 Error Recovery There are two error indications given by the RX211/RXV21 system. The maintenance read status function (Paragraph 4.3.3.6) will assemble the current contents of the RX2ES which can be sampled to determine errors. The read error code function (Paragraph 4.3.3.8) can also be retrieved for explicit error information. The RX211/RXV21 interface register can be interrogated to determine the type of failure that occurred. The error codes and their meaning are listed below. | Octal | | |--------|------------------------------------------------------------------------------------| | Code | Error Code Meaning | | 0010 | Drive 0 failed to see home on Initialize. | | 0020 | Drive 1 failed to see home on Initialize. | | 0040 | Tried to access a track greater than 76 | | 0050 | Home was found before desired track was reached. | | 0070 | Desired sector could not be found after looking at 52 headers (2 revolutions). | | 0110 | More than 40 µs and no SEP clock seen | | 0120 | A preamble could not be found. | | 0130 | Preamble found but no ID mark found within allowable time span | | 0150 | The header track address of a good header does not compare with the desired track. | | 0160 | Too many tries for an IDAM (identifies header) | | Ú i 7Ű | Data AM not found in allotted time | | 0200 | CRC error on reading the sector from the disk. No code appears in the ERREG. | | 0220 | R/W electronics failed maintenance mode test. | | 0230 | Word count overflow | | 0240 | Density Error | | 0250 | Wrong key word for set media density command | #### 4.3.5 RX211/RXV21 Programming Examples #### 4.3.5.1 Write/Fill Buffer Figure 4-31 illustrates a program to write data on a disk by performing write and fill buffer subroutines. Initially, the write subroutine tests to see if there is an error from the last operation. If there is an error, a branch is made and the write subroutine is not performed; otherwise a jump is made to the fill buffer subroutine. (Before data can be written the RX02 sector buffer must be filled.) The Fill Buffer command is set, the density (single or double) is set, and the command is loaded in the RX02/RXCS. After a TR is received, the word count (for either 128 or 256 bytes of data) is loaded in the RX02/RXDB. After another TR is received, the starting address where data will be retrieved from memory is loaded in the RX02/RXDB. The RX02 controller fills the sector buffer with the number of bytes indicated then the RX02 controller sets the Done bit. (If an Error is detected, the Error bit is set in the RXCS and the program halts.) The program returns to the write subroutine, the drive is selected, the write command and interrupt enable are set, the density is set, and the command is loaded in the RX02/RXCS. There is a wait for TR, then the sector address is loaded in the RX02/RXDB; there is another wait for TR and the track address is loaded in the RX02/RXDB. The data loaded in the sector buffer is written by the RX02 controller on the selected drive (disk) at the selected track and sector. While the controller writes the data, the program waits for an interrupt (which signifies the completion of write data) to occur in order to return to the main program. | | | | | .88TIL ROPULE 4.8 - WRITE SUBRUTINE | | | | |-----------------|---------------|----------------|-----------------|-------------------------------------|-------------------|----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 001164 | 845767 | ##1#7 <b>6</b> | | QUIPUT: | TAT | FIR | JIF FIN1 +LAG | | 081172 | 001041 | | | | <b>医</b> 阿拉 | EMDOUT | JIF FINI PLAG<br>JEGUALS ZEPO THEM | | 001174 | ##4747 | 846186 | | | JBK | PC,0UBUF2 | IFILL RXWZ WOFFER | | ##12 <b>0</b> 8 | 800240 | | | | NOP | · - | • | | 081202 | <b>B16767</b> | 801032 | 90102F | | ROY | UTI,CMD | 18EFECJ DAIAE | | 901210 | 052767 | 400145 | 001029 | | 918 | #1 <b>05</b> ,CMD | JAET TO WHITE BECTOR + INT EMABLE JAET DEMAILS | | 001216 | 856767 | ##1052 | <b>601012</b> | | 815 | DEMBIX, CAD | ISET DEMBITY | | 001224 | #10777 | 841866 | 801476 | | MOV | CPD: BRACE | ILAKA CHEMBUD | | 001232 | 004757 | ###71# | | | bis<br>hov<br>jsr | CPD/BRACE<br>PC/Anip | JGG A-AIT THAMBFER READY | | ##1236 | 845767 | 801036 | | | T31 | FIN | 11F FIB1 FLAG | | ##1242 | 941815 | | | | HWE | ENDOUR | ) IF FINI FLAG<br> EQUALS 22RO THEN | | w#1244 | #16777 | 841484 | *** | | NO 4 | ZA, PRIDU | LOAD SECTOR ADDRESS | | 001252 | 994767 | 893679 | | | JBR | PC/ANIP | EQUALS ZERU THEN<br> LOAD SECTOR ADDRESS<br> GO AGAIT TRANSFIR READY<br> IF FIRIT * LAG<br> EGUALS ZERU THEN<br> LOAD TRACK AUDRESS<br> PAIT FOR INTERRUPT<br> TRETURM | | 9#1756 | 405767 | Belane | | | TST | F1> | ILF FIMI STAG | | ##124Z | 001085 | | | | <b>Q</b> NE | ENDOUT | JEGUALS ZERO THEN | | 961264 | 816777 | #64762 | 44144 | | MOV | TA, OHIDB | ILDAD TRACK AUDRESS | | <b>●</b> ⊌1272 | 884767 | RAB 500 | | | Jõk | PC, INTER | JEALT FOR INTERRUPT | | ##1276 | 449297 | | | EMDOULI | RTS | PC | J P E T U H M | | | | | | | | 4.1 * FILL PX# | T DALLER | | 66136E | #12767 | ##### 1 | 000730 | CUBU#21 | MOV | #1.CmD | ISET FILL BUFFER COMMAND | | ##13mb | 856767 | 909762 | 806722 | | <b>B15</b> | DEMATY, CMD | SET DENSITY | | 0r1314 | W15777 | BFE716 | 841646 | | HOV<br>JSR | CPL, WEXCS | I BOAD COMMAND | | 681322 | 664767 | 006628 | | | JSR | | | | | | 820736 | | | TST | FIH | FIF FIN1 FLAG | | | #01024 | | | | BFE | ENDOU2 | FEGUALS ZERO THEN | | | | | 846770 | | MOY | wDCMT,#RXDB | FIF FINI FLAG<br>FEGUALS ZERO THEN<br>FLOAD WORD COUNT<br>FWAIT FOR "TR" | | | | *** | | | JSK | PC , A m T P | PWAIT FOR "TR" | | | 005767 | 000716 | | | 78 F | fia | ;IF FINI FLAG | | B#1352 | | | | | BHE | ENDOU2 | FEQUALS ZERO THEM | | | | | # <b>##</b> 750 | | MOV | OFFICE SERVICE | IIF FINE FLAG<br>FEQUALS ZERO THEM<br>ILOAD WASE ADR FOR OUTPUT WOFFER | | | 884767 | | | | JBR | PC.A+UN | INAIT FOR "DONE" | | | 895767 | 90 ≥ 676 | | | TŠT | FIN | IIF FINI PLAG<br>Jeguala Zeng Then | | | 001084 | | | | BWE | ENDOU2 | JEQUALS ZENG THEN | | | | 868730 | | | 181 | | ILL DEALCE CHOOK BIL | | | 100001 | | | | APL | FMDG63 | ; IS BET THEN | | | | | | | HALT | | JERROR HALT | | PP1464 | 000297 | | | EMD0f31 | | PC | ) PETURA | | | | | | ****** | | | жд.1851 | Figure 4-31 RX211/RXV21 Write/Fill Buffer Example #### 4.3.5.2 Read/Empty Buffer Figure 4-32 illustrates a program to read data from the disk by performing read and empty buffer subroutines. The drive to be read is selected, the read command and interrupt enable are set, the density is set, and the command is loaded in the RX02/RXCS. There is a wait for TR and then the sector address is loaded in the RX02/RXDB; there is another wait for TR, and the track address is loaded in the RX02/RXDB. While the RX02 controller reads data from the selected location on the selected disk into the RX02 sector buffer, the program waits for an interrupt to occur and then there is a jump to the empty buffer subroutine. The empty buffer command is set, the density is set, and the command is loaded into the RX02/RXCS. After a TR is received, the word count is loaded into the RX02/RXDB; there is another wait for TR and the address in memory where the data is to be stored is loaded into the RX02/RXDB. The data is emptied from the sector buffer by the RX02 controller, and when the buffer is emptied, there is a return to the main program. ``` .8811L MODULE 2.8 . READ SUBROUTINE 021406 080240 071410 016767 001416 052767 MOV BIS 004624 84462P SELECT DRIVE #187,CMD DESSIT,CMD CAU,BMACS PC,AAIA &A,PRAGB | THE READ COMMAND + INT END | SET DENSITY | LUAD COMMAND 809167 ###612 #52767 #56767 #16777 #16777 #16777 #84767 #84767 #84767 ##1424 EP1432 EP1446 ##1444 ##1452 #8#67E FOV ***** IGO AWAIT TRANSFER REALY JSK 468664 ...... MAN JOON SECTOR ADDRESS JOON TRACK STORESS JWAIT FOR INTERRUPT JTHEN GET HXW2 MUFFER #8#476 #8#576 #8##74 PC,A+TH TP,BHXUH PC,I+TER 484 689546 ##1456 HUY 441444 ##147# 886442 486 PC.INBUT2 ##8287 SBITE MODILE 2.2 . EMPTY HXP2 BUFFER #3.CHD DENSIY.CHD CMD,#HACS PC.A.TH Ev1476 812767 464732 INBURZE HOF ISET EMPTY BUFFER COMMAND JEST EMPTY BUFFLE C JEST DEVSITY JEST LOAD COMMAND JEST FIRE FIRE D JEGISTOS ZEFO ##1564 856767 891512 816777 #F#564 #P#524 004518 MUE DO 400 11.5R 001524 685767 801534 681614 001532 814777 601546 884767 151 44E 88454E 7 1 × E-DIN2 ADC: 1, WEXUB ITHER LOAD WORD COUNT | PAIT FOR "IR" DO | IF FINI FLAG 966234 048572 POY 601546 641544 661554 J54 731 ereszv 495767 P I N 001557 001084 001552 012777 ENCIN2 FEGUALS ZERO THEN LOAD MASE ANDR FOR INDUT BUFFER J#2744 #88552 MOV erbüt, erküm ##1562 ###24# ##1562 ###2#7 . OP PC ENDINGS HTS J RETURN SBITE MODULE WARR - AGAIT TRANSFER READY SUBPOLITING PPPRET TIPE OUT COUNTER PRET IF TRANSFER READY SET PIF SO! RR PRUMP TIME OUT COUNTER TOCHT TOCHT 892146 895967 964966 ##2152 ##2167 ##2162 ##2166 ##2174 ##2172 932777 991983 895267 969296 HF0116 101 BIT BAE 24 TOCPT 864644 11 IT NOT TIPED DUTE BR B#1371 878740 NOP 969287 ``` WA-1882 Figure 4-32 RX211/RXV21 Read/Empty Buffer Example ## CHAPTER 5 THEORY OF OPERATION This chapter describes the functional operation of the hardware and $\mu$ CPU software of the RX02 Floppy Disk System. This information combined with the programming information and descriptions contained in the other chapters should give the reader an understanding of the RX02 Floppy Disk System theory of operation. The first section of this chapter describes the overall system block diagram and the interconnection between system assemblies; the second section describes the interface modules; and the third section describes the assemblies housed within the RX02 cabinet. (Reference should be made to the PDP-11 Peripherals Handbook, the Microcomputer Handbook and the PDP-8 Small Computer Handbook for input/output transfer information for each computer.) #### 5.1 OVERALL SYSTEM BLOCK DIAGRAM The floppy disk system consists of four elements (Figure 5-1): - 1. Drive mechanics, which includes actuators and transducers (up to two per controller) to read/write data. - 2. Read/write electronics, which transfers control and data signals between drive mechanics and control logic. - 3. Microprogrammed controller, which includes all control logic. - 4. Bus interface module, which transfers control and data signals between the host processor bus and the RX02 microprogrammed controller. Operation of the RX02 Floppy Disk System is governed by the host processor. General functions (such as write data, read data) to be performed are initiated by the processor and coupled through the interface module to the $\mu$ CPU controller. The $\mu$ CPU decodes the general function, and using its own microprogram, initiates specific functions to accomplish the general function. The $\mu$ CPU output governs the read/write electronics which in turn develop the necessary signals to position the read/write heads in the desired location in order to read or write data. The data paths between each of the elements is bidirectional so that for reading, the data flow is from the disk to the read/write electronics, to the $\mu$ CPU, to the interface, and then to the host processor; for writing, the data flow is reversed. #### 5.1.1 Omnibus to RX8E/RX28 Interface Signals The RX8E/RX28 interface communicates with the PDP-8 Omnibus via the signals shown in Figure 5-2 and described below. DATA BUS – Twelve parallel bits of data are transferred along a bidirectional bus for both input and output data between the AC register in the processor and the interface register in the interface module. Figure 5-1 RX02 System Block Diagram Figure 5-2 Omnibus to RX8E/RX28 Interface Signals MEMORY DATA BUS - This signal provides I/O transfer (IOT) instructions from memory to the interface. TP3 H, TP4 H - These signals are used to clear the flag and clock the interface register of the interface in transferring data along the data bus. INTERNAL I/O - This signal is grounded by the interface selector decoder to inhibit decoding any internal Omnibus I/O transfer (IOT) instructions. Failure to ground this line will result in long IOT timing. SKIPL – An IOT checks the flag for a ONE state. If the flag is set, SKIPL is asserted and the address of the program counter (PC) plus one is loaded into the central processor memory address (CPMA) register to implement a skip. INT RQST L – This signal is part of the Omnibus interrupt structure. It is the method by which the interface signals the processor that it has data to be serviced. C0, C1 - Signals C0 and C1 determine the type of transfer between the interface and the processor. These signals control the data path within the processor and determine if data is to be placed on the data bus or received from the data bus. They are also used to develop the necessary load control signals required to load either the accumulator (AC) or the program counter (PC) in the processor. INIT H - INIT H is a signal used to clear all flags in the interface and initialize the RX02. I/O PAUSE L – This signal is used to gate the select and operation codes into the programmed I/O interface of the PDP-8 decoders. #### 5.1.2 Unibus to RX11/RX211 Interface Signals The RX11/RX211 interface communicates with the PDP-11 Unibus via the signals shown in Figure 5-3 and described below. ADDRESS (A Lines) - The 18 address lines are used by the CPU to select the device register addresses of the RX11/RX211 which are 177170 (RXCS) and 177172 (RXDB). DATA (D Lines) - The 16 parallel data lines are used to transfer information in and out of the interface. MSYNL – This signal is the master synchronization control signal that is initiated by the device that has control of the Unibus for data transmission. SSYNL - This signal is the slave synchronization control signal that is initiated in response to an MSYNL signal from the processor or another device that has control of the Unibus and is about to send data. NPR L - This signal from the processor will inhibit the interface from issuing a bus grant. # NOTE The RX11 is not an NPR device. The RX211 is an NPR device. C1 L - This bus signal is coded by the master device to control the slave in Data In mode (passing data to the Unibus) if it is negated, and Data Out mode (passing data from the Unibus) if it is asserted. Figure 5-3 Unibus to RX11/RX211 Interface Signals $INIT\ L$ - This is the signal asserted by the processor when the START key on the console is pressed, when a RESET instruction is executed, or when the power fail sequence occurs. This signal will initialize the system. $INTR\ L$ – This signal is asserted by the interface when it has bus control during an interrupt sequence. It directs the processor to go to interrupt service routine. SACK L - This signal is sent by the interface to the processor in acknowledgment of Unibus control being transferred to it. This signal inhibits further bus grants by the processor. BBSY L - This is the signal sent by the interface when asserting master control of the Unibus. This signal follows the SACK L signal. BR (7:4) – These four priority bus request lines are used by the interface to request bus mastership. Each device of the same priority level passes a grant signal to the next device on the line, unless it has requested bus control; in this case, the requesting device blocks the signal from the following devices and assumes bus control. BG(7:4) – These are four priority bus grant lines corresponding to the four request lines. The processor uses them to respond to a specific bus request. #### 5.1.3 LSI-11 Bus to RXV11/RXV21 Interface Signals The RXV11 or RXV21 interface module communicates with the LSI-11 via signals shown in Figure 5-4 and described below. BDAL0:15L (Data/Address) - The 16 data/address lines are used by the CPU to communicate data and address information in and out of the interface module. Figure 5-4 LSI-11 Bus to RXV11/RXV21 Interface Signals BDIN L - This signal is used with BSYNCL to indicate that the CPU is ready to accept data. When used without BYSNCL, it is used to indicate that the CPU has an interrupt in progress. BDOUT L - This signal is used by the CPU to indicate that valid data is available on BDAL 0-15. BRPLYL - This signal is asserted by the interface module to indicate to the CPU that it has either accepted data from the bus or placed data on the bus. BSYNC L – This signal is the master synchronization control signal asserted by the master device when it has control of the bus for transmitting an address. BIRQ L - The interface asserts this signal to indicate to the CPU that it has data to be processed. BIAK IL, BIAK OL - BIAK IL, interrupt acknowledge in, is asserted by the CPU in response to a BIRQL. If the interface is not asserting BIRQL, it will pass the signal via BIAK OL to the next device. BBS7 L - The master device asserts this signal when an address in the 28K-38K range is placed on the bus. BINIT L – This signal is asserted by the CPU to initialize or clear the interface module as well as all devices connected to the I/O bus. BDMGI L, BDMGO L - BDMGI L, DMA grant-input, is asserted by the CPU and routed to the first device on the bus. If the device is not requesting the bus, the signal is routed to the next device via BDMGO L. BWTBT L - This signal, write/byte, is asserted during BSYNC L to indicate that an output sequence is to follow; it is also asserted during BDOUT L for byte addressing. BAD16 L, BAD17 L - Extended address bits. BDMRL - This signal, direct memory access request, is asserted by the interface to request bus mastership. BPOK H - This signal indicates the processor power supply operation is normal. BSACK L - This signal is asserted by the interface to indicate it is bus master. #### 5.1.4 Interface Module to $\mu$ CPU Controller Signals The $\mu$ CPU controller and interface modules communicate via the signals shown in Figure 5-5 and described below. Figure 5-5 Interface to $\mu$ CPU Controller Signals RX INIT L - The RX02 will negate DONE L and move the head position mechanism of drive ! (if it exists) to track 0. The RX02 will also read sector 1 of track 1 of drive 0 and then assert DONE L without error upon successful completion of the function. RX DONE L – This signal, asserted low, indicates that there is no RX02 function in progress. Initiating any function will cause DONE L to be negated for the duration of that function. Attempting to initiate any function other than Initialize while DONE L is negated is illegal and may result in an error. RX RUN L - This signal initiates communication between interface and controller. RUN L, asserted while DONE L is true, passes a command from interface to controller serially. DONE L will be negated until the command has been executed (or until Initialize is asserted). RUN L, asserted while DONE L is false, signals transfer of data to or from the controller. All control lines to the controller must be stable 75 ns before RUN L is asserted. RX OUT L - This signal indicates the direction in which the RX02 is prepared to transfer data. When OUT L is asserted, the direction of transfer is from controller to interface. When OUT L is negated, the direction is from interface to controller. OUT L is never asserted while DONE L is true, and OUT L is negated by Initialize. RX TRANSFER REQUEST L (TRL) – This signal with RUN L and OUT L forms a bidirectional handshake set. On transfers from controller to interface (OUT L asserted), TR L going true indicates that the next data element has been transferred to the interface register. The transfer of the following data element will be initiated by asserting RUN L. This will negate TR L until the new data element has been assembled in the interface. On transfers from interface to controller (OUT L negated), TR asserted indicates that the controller is prepared to accept the next element of data. The arrival of the new data element will be signaled by assertion of RUN L. Assertion of RUN L while TR L is negated is an error. RX DATA L - This is a bidirectional line for transfer of data to and from the controller. A parity bit is appended to the serial data stream by the interface when the direction of the data transfer is into the controller. The controller will interrogate the parity bit for validity. RX SHIFT L – The SHIFT L pulse strobes information to or from the controller bit-by-bit via the DATA line. 1. Interface to Controller Transfer - OUT is negated and the transfer of either commands or data words begins with the assertion of RUN L. Following the assertion of RUN L, DONE L or TR L will be negated and a number of SHIFT L pulses will occur. The number depends on the length of the data element to be passed. The first bit of data (or command) must be stable when RUN L is asserted. The SHIFT L pulse width is 200 ns nominal. SHIFT L pulses will not occur more often than every 400 ns. Subsequent bits of data may be brought up on the trailing edge of SHIFT L. DONE L or TR L will be reasserted following the last SHIFT L pulse. 2. Controller to Interface Transfer - OUT is asserted and the assertion of TR L indicates the controller's readiness to transfer data. Assertion of RUN L will negate TR L and initiate a train of SHIFT L pulses. The data is to be sampled on the leading edge of SHIFT L and is valid only while SHIFT L is asserted. TR L will be reasserted at the end of each element of data. DONE L will be asserted following transfer of the last element of data in a block. RX 12 Bit L – This signal is asserted by the interface to controller and determines the number of shift pulses generated by the controller for each byte transferred. Signal 12 Bit L asserted will produce 12 SHIFT L pulses for data transfer between the interface and controller upon the assertion of RUN L. Signal 12 Bit L negated will produce eight SHIFT L pulses for data transfer between the interface and controller upon the assertion of RUN L. This line must remain asserted throughout the entire data transfer. When data is transferred, the most significant bit is transferred first. #### NOTE Signal 12 Bit L is only asserted by a PDP-8 interface for 12-bit words. It is never asserted by a PDP-11 or LSI-11 interface. RX ERROR L – This is an error summary bit generated by the controller that sets when any error is detected. The detection of ERROR L stops all controller action and asserts DONE L and the Error flag. This line is cleared by INIT L or the initiation of a new function. RX DMA MODE H - This line is asserted to indicate direct memory access mode of operation. RX AC L - This line is asserted when the RX02 has lost power. #### 5.1.5 µCPU Controller to Read/Write Electronics Signals The $\mu$ CPU controller and read/write electronics communicate via the signals shown in Figure 5-6 and described below. Figure 5-6 µCPU Controller to Read/Write Electronics Signals DRV OUT/ABOVE TRK 43— When writing data, this signal is asserted by the controller to select the lower of two write current levels when operating on a track above 43. As the head moves closer to the center of the disk, the bit density increases as linear velocity decreases, necessitating a reduction in write current. When reading data, this signal determines the direction in which the head will move in response to a STEP L signal; when OUT/ABOVE TRK 43 is asserted, the heads will travel toward the outer edge of the disk. DRV WRITE DATA - This signal conveys the complete data stream to the read/write electronics at TTL logic levels, Each transition on this line results in a flux reversal on the disk. DRV SEP DATA H – This signal conveys the complete data stream recovered from the diskette. It is asserted with READ STROBE H and remains valid for 4 $\mu$ s for single density data and 2 $\mu$ s for double density data. DRV SEL DKI H - This signal uniquely selects one of the two possible disk drives. The assertion of this line will select logical drive 1 for use. Unit 0 is physically the left-hand unit in the rack. DRV WRITE GATE H- This signal is asserted by the controller to enable the selected write drivers. This level must be asserted prior to the beginning of the data field to be written and is negated after the last bit of the data field. This timing is completely under microprogram control. DRV ERASE H - This signal is used in conjunction with DRV WRITE GATE H to enable the tunnel erase drivers. It is asserted and negated after the assertion of DRV WRITE GATE H, with timing determined by the microprogrammed controller. DRV LOAD HEAD H - This signal is asserted by the controller to hold the media against the selected head. DRV STEP L – This signal is asserted twice by the controller to change head position by one track in a direction determined by signal OUT H. There are two step pulses per track for each track to be stepped (6 ms step time per track). DRV SEL TRK O H - This signal is asserted by the selected drive to indicate that its head is positioned over track O. DRV SEL INDEX H - This signal is asserted by the selected drive to indicate that the head index hole has been detected. This occurs once per revolution and is used by the control to time operations and detect "up to speed." ACLOL - This signal is asserted by an Initialize signal from the controller to the drives, during and after a loss of power (an initialize is provided over this line). DRV READ STROBE H – This signal is asserted by the selected drive to indicate that SEP DATA H and SEP CLK H are valid and may be stored. This signal is asserted for approximately 1 $\mu$ s every 4 $\mu$ s for single density and every 2 $\mu$ s for double density. DRV SEL HD O H - This line (for future use) selects one of two possible heads on a disk drive. DRV SEP CLK H – This line indicates that a separated clock has been detected in a data stream. SEP CLOCK H is asserted with READ STROBE H and remains valid for 4 $\mu$ s for single density and for 2 $\mu$ ss for double density. DRV READ 2 F L - This signal controls the density at which the phase lock loop (PLL) will acquire and/or maintain phase lock. DRV LOCK CLK H - This signal controls the phase lock loop (PLL) and preamble detection so that the PLL will acquire phase lock during the six bytes of zeros preceding the ID, Data, or deleted data address marks. The PLL does not function when LOCK CLK H is negated. DRV MAINT MODE H - When asserted, the R/W electronics are exercised without storing or retrieving data from the media. This mode tests the digitized portion of R/W electronics including preamble recognition circuitry, the PLL, and the data separator. #### 5.1.6 Read/Write Electronics to Drive Signals The read/write electronics and drive(s) communicate through five sets of signals per drive as shown in Figure 5-7 and described below. The plug designations for the cabling are also shown in Figure 5-7. HEAD - This is an analog signal that conveys data to and from the drive head. Figure 5-7 Read/Write Electronics to Drive Signals INDEX – This is a set of signals connected to a LED-phototransistor pair which locates the index hole for determination of diskette rotational position and speed. TRACK 00 - This is a set of signals connected to a LED-phototransistor pair, which indicates positioning at track 0. HEAD STEPPER - This signal is output from the read/write electronics, which moves the head from track to track. HEAD LOAD SOLENOID – These signals activate a solenoid to hold the head against the diskette during a read/write operation. The head is unloaded from the diskette to reduce diskette wear when not performing a read/write operation. #### 5.2 INTERFACE MODULES BLOCK DIAGRAM DESCRIPTION The following paragraphs contain functional block diagram descriptions of each of the interface modules used with the RX02. #### 5.2.1 RX8E/RX28 Interface (M8357) Block Diagram Description Figure 5-8 presents a block diagram of the RX8E/RX28 interface. The E references on the diagram are IC chip designations on the RX8/RX28 print set, which is a separate document. 5.2.1.1 Device Select and IOT Decoder – The device select and IOT decoder logic decodes instructions from the memory data bus and generates signals to the interrupt control and skip logic, the C line control logic, and the sequence and function control logic. Figure 5-8 RX8E/RX28 Interface Block Diagram Device selection codes are determined by the switch configuration with relation to the state of MD6, MD7, and MD8. When the correct code for the RX8E/RX28 is input to the device select logic on MD03 L-MD08 L and I/O PAUSE L is asserted, MD09 L-MD11 L are decoded by the decoder E41 and signal INT I/O is asserted on the Omnibus. I/O PAUSE L is present anytime an IOT instruction is being executed by the program. INT I/O L prevents the processor from executing other I/O transfers (IOTs) while this instruction is being executed. Decoder E41 is a BCD to decimal decoder. All 0s applied to inputs D0-D3 (D3 is MSB) will cause pin 1, which is unused, to be asserted low. An input of 001 will cause signal LCD IOT L to be asserted. An input of 010 (decimal 2) will cause XFER IOT L to be asserted. Therefore, for each function code input on MD09 L-MD11 L, only one of the decoder output lines will be asserted. The function codes are further explained in Paragraph 4.1.2. 5.2.1.2 Interrupt Control and Skip Logic – The interrupt control logic asserts the BUS INT RQST L signal on the Omnibus. Bit 11 of the data bus must be set and an INTERRUPT IOT L must be decoded by the interface to set the interrupt enable flip-flop. The combination of the interrupt enable and buffered done flip-flops will assert BUS INT RQST L. Setting the buffered done flip-flop indicates that no RX02 function is currently in progress. The skip logic implements the three IOT commands Skip on Transfer Request Flag (STR), Skip on Error Flag (SER), and Skip on Done Flag (SDN) as described in Paragraph 4.1.2. ## NOTE When using these instructions, the respective flags are cleared after they are tested. Signal SKIP L will be asserted if any of the above instructions are decoded by the IOT decoder and the respective flag has been asserted by the RX02. The RX8E/RX28 asserts the flags by causing a positive transition on the clock inputs of flip-flops XFER REQ, ERR, and DONE. The signal MAINT (1) L will directly set the skip flags to allow the skip IOTs to assert the BUS SKIP L signal when decoded by the IOT decoder. - 5.2.1.3 C Line Select Logic The C line select logic (E10, E12, E14) controls the direction of data flow between the processor AC and the data bus and determines whether or not the AC is cleared upon completion of the transfer. CO L will be asserted during a load command (LCD) instruction when signal LCD IOT L is asserted. Assertion of C1 L requires XFER IOT H to be asserted and either MAINT (1) L or B DONE L to be asserted or WRT H to be negated. Data transfers occur under the control of the C bits according to Table 5-1. - 5.2.1.4 Interface Register The interface register (E9, E21, E3) is made up of three 8271 4-bit shift registers. This register temporarily stores data during transfers from the Omnibus to the RX02 $\mu$ CPU controller or during transfers from the $\mu$ CPU controller to the Omnibus. During a data transfer from the Omnibus (Fill Buffer), the 12 parallel data lines to the register are enabled by signal RX8 SEL L from the device select logic. Data is parallel-loaded into the register when signals ENB BUFF LOAD L and CLK BUFF L are asserted. In shifting data out of the register serially for transmission to the $\mu$ CPU controller, ENB BUFF LOAD L must be negated. Signal CLK BUFF L from the sequence and function control logic clocks data out of the buffer (Paragraph 5.2.1.5). During data transfer to the Omnibus (Empty Buffer), serial data from the $\mu$ CPU controller is shifted into the buffer. ENB BUFF LOAD L must be negated while CLK BUFF L supplies the clock pulses. Table 5-1 C Line Transfer Control Signals | Type of Transfer | C0 | C1 | Action Required by RX8E/RX28 Interface | Action by Processor | |--------------------------------------|----|----|--------------------------------------------------------|-------------------------------------------------| | Output AC to data bus; AC unchanged. | Н | Н | Load data bus into buffer. | Transfers AC to data bus. AC remains unchanged. | | Output AC to data<br>bus; AC cleared | L | н | Load data bus into buffer.<br>Ground C0. | Transfers AC to data bus and clears AC. | | In put AC-ORed with peripheral data | н | L | Gate peripheral data to data bus.<br>Ground C1. | AC-ORed with peripheral data. | | Jam input data bus to AC. | L | L | Gate peripheral data to data bus.<br>Ground C0 and C1. | Transfers data bus to AC register. | The parallel data is enabled from the outputs of the register when MAINT (1) H, RDH, or B DONE H is asserted, and when XFER IOT L is asserted as decoded by the IOT decoder. Only eight bits of data will be output if signal 8/12 (0) H is low; otherwise, 12 bits will be transmitted. ## **5.2.1.5** Sequence and Function Control Logic – The sequence and function control logic performs six distinct functions: - Controls loading and shifting of the interface register to and from the μCPU controller. - Senses 8- or 12-bit mode and outputs RX 12 BIT L. - 3. Senses maintenance conditions. - 4. Generates INIT L signal to the $\mu$ CPU controller. - 5. Generates RUN L signal to the $\mu$ CPU controller. - 6. Generates a parity bit for the serial bit stream to the RX02. Interface register operation is controlled by signals ENB BUFF LOAD L and CLK BUFF L generated by the sequence and function control logic. To assert ENB BUFF LOAD L, signal RX OUT L cannot be asserted and either RX TRANSFER REQUEST L or RX DONE L must be asserted. In parallel data entry to the buffer, CLK BUFF L will be asserted if any of the following conditions hold: - ENB BUFF LOAD L is asserted - 2. Either LCD OR XDR instructions are being performed - Signal BUS TP3 H is asserted. In serial data entry to the buffer, the CLK BUFF L pulses are derived from the RX SHIFT L pulses from the $\mu$ CPU controller. The 8/12 flip-flop will set and signal 8/12 (1) H will be asserted if BUS DATA 5 L is asserted during a Load Command (LCD) operation. Signal 8/12 (1) H is used to control whether 8 or 12 bits of data are transferred to or from the Omnibus and whether 8 or 12 bits of data are transferred between the interface and the $\mu$ CPU controller. The MAINT flip-flop will set, and signal MAINT (1) H will be asserted if BUS DATA 4 L is asserted during a LCD operation. Signal MAINT (1) H is used to allow parallel writing and reading of the interface register from the Omnibus. It is also used to assert signal RUN L and C line control signals. An initialize signal to the $\mu$ CPU controller (RX INIT L) is generated either by a BUS INIT H signal from the Omnibus or an INIT IOT L decoded from the IOT decoder. The RUN L signal, which is used to initiate communication between the interface and $\mu$ CPU controller, is asserted by setting the run flip-flop. This flip-flop is clocked either in Command Transfer mode when LCD IOT H is asserted or Data Transfer mode to or from the $\mu$ CPU controller when XFER IOT H is asserted. (RUN L cannot be asserted if DONE L is asserted.) RX BUSY L and INIT L must both be high for a RUN L signal to be asserted. Assertion of either RX BUSY L or INIT L will clear the run flip-flop. #### 5.2.2 RX11 Interface (M7846) Block Diagram Description A block diagram of the RX11 interface is shown in Figure 5-9. The E references are IC chip designations on the RX11 print set, which is a separate document. 5.2.2.1 Address Decoder – The address decoder determines whether this interface is being addressed and whether control information or data is being transferred. The hardware E20, E24, E27, E30 is a logic network that decodes two discrete addresses assigned to the RX11. Address bits (17:13) must always be asserted to satisfy the decoder. The state of address bits A (12:03) is determined by the placement of jumpers A12-A3 on the board. For each of these bits, one 8242 exclusive-NOR gate is used. Insertion of an jumper for a particular bit position stores a 0 on one leg of the 8242 so that a 1 appearing on the other leg causes the output to go low. This is a mismatch condition which is met when the associated address bit is a 1. When both legs match (1s or 0s on both), the output is high. The output of these 12 gates are wire-ORed and applied to pin 9 of the E28 gate. Pin 10 of thiss gate receives the NANDed signal of A (17:13) and BUS MSYN. Pin 8, the output of this gate, is signal REG SELECT L and is asserted when the proper Unibus addresses are decoded. The states of address bits A02 and A01 and REG SELECT L are used to produce signals SELECT 00 H or SELECT 02 H. If BUS A01 L is asserted, SELECT 02 H is asserted. If BUS A01 L is negated, SELECT 00 H is asserted. These signals, in turn, allow access to the RXCS register when SELECT 00 H is asserted, or to the RXDB register when SELECT 02 H is asserted. (Refer to Paragraph 4.2 for register descriptions.) 5.2.2.2 Data Path Selection – Data path selection logic provides the input/output path for data. Signal BUS C1 L from the Unibus controls whether a Data Out or Data In operation is to be executed. Assertion of BUS C1 L indicates Data Out (from Unibus), and negation of BUS C1 L indicates Data In (to Unibus). Signals OUT H and its complement IN H are derived from BUS C1 L and are input to bus transceivers E4 and E7. With BUS C1 L negated and SELECT 02 asserted, all eight bits from the data buffer are enabled through the bus transceivers. With BUS C1 L negated and SELECT 00 H asserted, only lines BUS D04-BUS D07, providing control and status information (RXCS), are enabled. With BUS C1 L asserted, none of the transceivers are enabled, and data is being input from the Unibus on lines BUS D00-BUS D07. Multiplexer E1 controls passage of status and control information (RXCS) in the form of signals DONE H, INIT ENB (1) H, and TRANSFER REQUEST H from the sequence and function control logic or passage of data from the read/write buffer register (RXDB). If SELECT 02 H is asserted, data is output from E1; if SELECT 02 H is negated, control information (RXCS) is output from E1. Figure 5-9 RX11 Interface Block Diagram 5.2.2.3 Interface Data Buffer Register – The interface register E5 is an 8-bit, parallel load, shift register. Data transfer through the register can take place from the Unibus to the $\mu$ CPU controller or from the $\mu$ CPU controller to the Unibus. In data transfer to the RX11 from the Unibus, parallel data is loaded into the register when RX BUSY H is negated and LOAD H is asserted. Data is serially shifted in the register from $Q_A$ to $Q_H$ by the B SHIFT H signal derived from the $\mu$ CPU controller when RX BUSY H is asserted. Serial data is shifted to the sequence and function control logic, which transmits data to the $\mu$ CPU controller (Paragraph 5.2.2.4). Data is assembled in serial fashion for parallel transfer on the Unibus. Serial data is input at B SER DATA H and shifted by B SHIFT H when RX BUSY H is asserted and LOAD H is negated. The eight bits of parallel data appearing at the output of the buffer are input to the data path selection logic for transmission to the Unibus. 5.2.2.4 Sequence and Function Control Logic – The sequence and function control logic provides key signals to control the interface register and the interrupt control logic as shown in Figure 5-9. Operation of this circuitry is controlled by signals from the $\mu$ CPU controller and SELECT 00 H and SELECT 02 H from the address decoder. Signals RX TRANSFER REQUEST L, RX OUT L, RX DONE L, AND RX RUN L control data transfer between the interface and the $\mu$ CPU controller. The RX RUN L signal initiates communication between the RX11 interface and the $\mu$ CPU controller. The run flip-flop E37 is set in passing either a command from interface to controller or data between interface and controller. RUN asserted while Done is true passes a command from interface to controller. Run asserted while Done is false signals transfer of data to or from the controller. Once a particular function has been decoded by the $\mu$ CPU controller, it requests a data transfer by assertion of RX TRANSFER REQUEST L. Access of the RXDB in the RX11 interface sets the run flip-flop and thereby asserts RX RUN L. The run flip-flop is cleared either by assertion of B INIT H or BUSY H. RX BUSY H is asserted when both RX TRANSFER REQUEST L and RX DONE L are negated. Assertion of RX BUSY H also allows the interface register to shift serially in communicating between $\mu$ CPU controller and interface. RX OUT L from the $\mu$ CPU controller determines in which direction the data transfer is about to take place. When RX OUT L is asserted, the direction of data transfer is from controller to interface. When RX OUT L is negated, the direction of data transfer is from interface to controller. On transfers from controller to interface, assertion of RX TRANSFER REQUEST L indicates that the next data element has been assembled in the RXDB. Transfer of the next data element is initiated by RX RUN L. On transfers from interface to controller, assertion of RX TRANSFER-REQUEST L indicates that the controller is prepared to accept the next element of data. Arrival of the next data element will be signaled by assertion of RX RUN L. The three signals DONE H, INT ENB (1) H, and TRANSFER REQUEST H from the sequence and function control logic to the data path selection logic represent the three bits that may be read in the control and status (RXCS) register. A functional programming description of this register is given in Paragraph 4.2. During serial data transfer from the RXDB, binary counter E3 and flip-flop E2 are used to count eight bits of data and to append the parity bit to the data element. An error indication from the $\mu$ CPU controller results in assertion of RX ERROR L. This indication is passed to the Unibus when a read from the RXCS to the Unibus is performed. When this occurs, signal BUS D15 L is asserted. - 5.2.2.5 Interrupt Control Logic The interrupt control logic receives and generates the control signals required for the RX11 to become bus master. With signals DONE H and INT ENB H both asserted, BUS REQUEST L will be generated if the SACK and BBSY flip-flops, E3, are not set. The BUS REQUEST L signal is routed to the appropriate bus request line (normally BR5) through the priority plug. Etch on the plug selects both request and grant lines. When the bus grant signal is generated by the processor, it is routed via the priority plug and becomes signal BG IN H. This signal clocks the GRANT flip-flop E25 and the SACK flip-flop E31. The SACK flip-flop is set because the RX11 had requested bus mastership. The SACK flip-flop is cleared and the BBSY flip-flop set when BUS BBSY L, BUS SSYN L, and BG IN H are negated on the Unibus. Thus the BUS BBSY L signal will be asserted again by the RX11, which is now bus master. The BBSY signal is inverted and applied to the vector address generator, generating the BUS INTR L signal and the vector address of 264. - 5.2.2.6 Vector Address Generator The vector address generator consists of eight bus drivers E35, E38 that are used to generate a vector address and the BUS INTR L signals. When BUS BBSY L is asserted by the RX11, the inputs to the bus drivers are active. Seven drivers are connected to the Unibus data lines D (08:02) via jumpers. The placement of these jumpers determines the vector address. #### 5.2.3 RXV11 Interface (M7946) Block Diagram Description Command and data transfers between the LSI-11 processor and the RXVII are executed under program control via this module. Figure 5-10 is a block diagram illustrating the logic functions of the interface. The E references on the diagram are IC chip designations on the the RXVII print set which is a separate document. - 5.2.3.1 Address Decoding Logic Address decoding occurs on the leading edge of BSYNC L assertion. SYNC H clocks address decoding logic to produce an active or passive ME H signal. The ME H signal is a result of comparing DAL REC2-12 H bits to the address configured on address jumpers W7-W17 at SYNC H time. When the RXV11's address is decoded, ME H goes active, enabling an RXV11/LSI-11 bus data or command transfer. Note that address bit DAL REC 1 H is applied to I/O control logic; this bit is used in selecting either command/status (CS) or data buffer (DB) data transfers. - 5.2.3.2 I/O Control Logic I/O control logic circuits control the actual command, status, or read/write data transfer between the LSI-11 Bus and the addressed RXV11 register. Control signals CS H and DB H are generated by this logic function in response to address bit DAL REC 1 H to select either the RXCS or RXDB register. The actual signal sequence for LSI-11 Bus cycle operations involving this function are as described in the *Microcomputer Handbook*. - 5.2.3.3 RX Data Buffer (RXDB) Register The RXDB (E25) is the main command/data interface function. It is an 8-bit parallel load, parallel read shift register. Parallel load occurs during DATO bus cycle execution; RX BUSY H loads command or write data bits present on DAL REC 0-7 H into the shift register. B SHIFT L pulses then serially shift the command or data byte bits out of RXDB bit D07 L and into the serial bus interface and parity logic. Serial command/data and parity bits are then shifted to the controller via the bidirectional RX DATA L signal. During a data read operation, the process is reversed. Controller serial data bits are received via the RX DATA L signal, serial bus interface and parity logic, and shifted into the RXDB via SER DATA H. Once the data byte is available, a DATI bus cycle can be initiated. Parallel read data bits D0-7 L are gated through input data select logic and routed over TDAL 0-7 H to bus transceivers which place the read data onto BDAL 0-7 L. 5.2.3.4 RX Command/Status (RXCS) Register – The RXCS function is actually not a register. It is a group of command/status bits which are program-accessible via a register address. Only 10 of the 16 RXCS bits are used. Six are write-only bits, three are read-only bits, and one is a read/write bit. Figure 5-10 RXVII Interface Block Diagram During an RXCS read operation, CS H and READ CS H go high, enabling the status of ERROR H, TR, INT ENB (1) H, and DONE bits onto BDAL 15 L, BDAL 7 L, BDAL 6 L, and BDAL 5 L, respectively. Note that input data select logic routes bits 5, 6, and 7 as during the RXDB read operation. During an RXCS write operation either a command (contained in RXCS bits 1-3) is being transmitted to the RX02, interrupts are being enabled or disabled (RXCS bit 6 set or reset), or the RXV11 is being initialized (RXCS bit 14 is set). RXCS bit 0 (Go bit) is a logical 1 during an RXCS write operation when a command transfer is being executed. This causes the RXDB to parallel-load the command byte and serially transmit it to the controller, as previously described for a data write operation. When RXCS bit 0 is a logical 0 during an RXCS write operation, the command bits are not transmitted to the controller. Instead, the RXV11 is either being initialized (RXCS bit 14 = 1) or the INT ENB (RXCS bit 6) bit is being set or reset. - 5.2.3.5 Status and Control Signal Interface Logic The status and control signal interface logic is the control interface between the controller and the RXVII interface logic. All control and timing signals required for command or status transfers between the RXVII interface and the RX02 directly involve this logic function. TR, DONE, and ERROR RXCS signals are produced by this logic function. - 5.2.3.6 Interrupt Control Logic The interrupt control logic function contains the interrupt enable flip-flop (RXCS bit 6). When set, the circuit requests interrupt service when the DONE H signal goes active. The interrupt sequence is initiated by the logic when it asserts BIRQ L. The processor responds by asserting BIAK! L and BDIN L, causing VECTOR H and VECTOR L to go to their respective active states. VECTOR H and VECTOR L cause input data select logic to enable the vector address, configured by jumpers W1-W6, onto the BDAL bus. The actual sequence of operations for interrupt operation is described in the *Microcomputer Handbook*. - 5.2.3.7 Initialize Logic Initialize logic is activated whenever a DATO cycle is executed with the RXCS, and BDAL 14 L is asserted. This is equivalent to writing a logical 1 into RXCS bit 14. The logic responds by generating an active RX INIT L signal (pulse) which initializes the floppy disk drive. RX INIT L only remains active for the duration of the bus cycle. #### 5.2.4 RX211 Interface (M8256) Block Diagram Description The RX211 transfers commands and data between the RX02 Controller and the PDP-11. The RX211 is an NPR device which functions as a slave when receiving commands from the PDP-11 and functions as a master when making data transfers. The interface is selected for use by a unique address (normally 177170 for command and status register and 177172 for the data buffer register) which is decoded by the interface so that the command or data can be processed. Figure 5-11 is a block diagram of the RX211 showing the major signal flow to/from the various functional groupings of the module. The E references on the diagram are IC chip designations on the RX211 print set which is a separate document. 5.2.4.1 Address Decoder, Buffer Selector, SSYN Register – When the PDP-11 has a command to be processed by the RX211, address data (BA) and a delayed MSYN signal are placed on the bus. The address bits are decoded by the address Decoder, which by placement of jumpers on E74 (jumper inserted = 0, jumper removed = 1) so that the address and jumper are equal, asserts REG SEL L when MSYN is asserted with the correct address. (Address bits 13:17 are always high.) The REG SEL L along with PROC OUT, which determines direction of transfer, enables the buffer selector circuits to decode BA01, 02 to develop signals which enable the data on the data lines to be entered either into the command and status (C&S) buffer or into the data buffer. When BA01, 02 are both low, data is entered into the C&S buffer, and when BA01 is high and BA02 is low, data is entered into the data buffer. The asserted REG SEL L is also applied to and enables the SSYN register which generates delayed SSYN OUT signals that are applied to the interface control to establish RUN conditions and to the PDP-11 to indicate that the address has been recognized. - 5.2.4.2 Command and Status Buffer Command information on the data lines is entered into the command and status (C&S) buffer circuits when WRT CSR H and SEL CSR H are asserted. The command data is entered in register E37 by WRT CSR H and shifted to the output of multiplexer E14, E8 as MDATA by SEL CSR H. When SEL CSR H is negated, data from the data buffer is output from E14, E8 as MDATA. - 5.2.4.3 Data Buffer The data buffer receives data either from the PDP-11 or from RX02 Controller and couples the particular data to the receiving device via the data input/output circuit. Data from the PDP-11 is parallel loaded into the data buffer E5, E20 when EN SHIFT, developed internally by TR and BDONE, is negated and the clock signal is asserted. The parallel data is shifted serially through the buffer from Data 0 to Data 7 and from Data 8 to Data 15 when EN SHIFT is asserted and the clock signal is asserted. The serial data to be output to the RX02 Controller is coupled to the interface control circuits by bits Data 7, 11, 15. (Data is transferred in 8-bit bytes and commands are transferred in 12-bit format.) SER DATA from the RX02 Controller is serially loaded into the data buffer E5, E20 when EN SHIFT is asserted and shifted by the clock signal. The parallel output of the data buffer is coupled to the data input/output circuits. The buffer clock signal used to shift the data in the buffer is enabled by SHIFT and MSYN CLR EN, RX OUT, WRT REG. - 5.2.4.4 Data Input/Output and TRANSMIT DATA CIRCUIT The data input/output couples the data to be processed between the PDP-11 and the RX02. The inputs to the E1, E2, E4, E7 are C&S data and data buffer data. When data is to be coupled through E1, 2, 3, 7, XMIT DATA L is asserted and the data is available at the output as BD (00:15). For commands, XMIT DATA L is enabled by REG SEL L, and C&S data is applied as MDATA which is subsequently serially shifted through the data buffer to the controller via the interface control. Data buffer data is applied as both MDATA and DATA 1, 2, 10, 12:14 which are parallel loaded on the bus for transfer to the PDP-11. When data is to be applied on the bus from the PDP-11, XMIT DATA L is disabled by RX OUT and PROC OUT. During data transfers, MSYN CLR EN and EN ADDR L are low so that XMIT DATA L is controlled by RX OUT which toggles according to the direction of data transfer from interface to controller or controller to interface. - 5.2.4.5 Address Circuits The address circuits consist of an address counter and address input/output gates which provide the means to transfer data directly to or from PDP-11 memory. For a fill or empty buffer command, the address counter (E61, 55, 49, 32, 26) is loaded with a memory address via the data buffer. For either of these commands, LOAD BAR and WRT REG PLS are asserted and the counter is loaded with BD 01:15. The output of the counter is coupled through the address input/output gates to the bus as BUSA (01:15) which represents the starting address to enter or read from PDP-11 memory. The address counter is incremented after each word (16-bit) data transfer by EN ADDR L which is toggled by the bus control circuit which operates in the NPR mode for the data transfer to fill or empty the controller buffer. - 5.2.4.6 Interface Control Circuits The interface control circuits establish the conditions to transfer commands and data to/from the controller. The function to be performed is identified as fill buffer, empty buffer, read error code, or other by FUNCT 0, 1, 2. When a command is to be transferred, BD00, BDONE, WRT CSR, and SSYN OUT L are used within the interface control (E39, E41) to develop a GO signal which asserts RX RUN indicating a command transfer to the controller (while RX DONE is asserted). Data for a command is coupled through the interface control (E9, E15) to the controller via DATA 11 and RX DATA L as a 12-bit word; the SHIFT L signal is used to sequence the interface control. If the function to be performed is fill buffer, empty buffer, or read error code, an NPR REQ is generated to initiate a request for bus mastership. The RX211 establishes bus mastership after data is in the interface buffer. Data is transferred between the controller and the interface in 8-bit bytes using ENA 8 bit or ENA 16 bit to load the controller data in the data buffer or using DATA 7 or DATA 15 to couple data buffer data to the controller. When RX OUT is negated, the TR signal is asserted when the controller is ready to accept the next element of data; when RX OUT is asserted, the TR signal is asserted when a byte of data is transferred from the controller. The RX DONE signal is Figure 5-11 RX211 Interface Module Block Diagram asserted when the function to be performed is completed. After RX DONE is asserted, the 12-bit error status register is transferred; then B DDONE is asserted to establish conditions for performing a new function. - 5.2.4.7 Bus Control Circuits The bus control circuits generate the signals to establish bus mastership along with front-end, tail-end, and data deskew delays required during data transfers. When an NPR REQ is generated by the interface control, a BUS NPR is developed by E30 and applied to the PDP-11 processor. When the bus control circuit receives BUS NPG, it generates an acknowledge, BUS SACK L, a BUS BSY and a delayed (≈200 ns) BUS MSYN indicating it has bus control. EN ADDR L is asserted to enable the memory address to be placed on the bus. SSYN IN is applied from the slave (memory) to indicate conclusioon of data transfer and clears the master Sync (MSYN CLR EN) subsequently negating BUS BSY so another device may take over as bus master. - 5.2.4.8 Interrupt Circuits The interrupt circuits are used to generate an interrupt to return to execution of the PDP-11 program after an RX02 function is completed. When an RX02 function is completed, BDONE is asserted and if BD06 (interupt enable) of the command and status word was set, a Bus Request is generated to gain control of the bus in order to place the vector address on the bus. [Bus Request is routed to BR (04:07) by the priority plug.] A bus grant from the processor is routed by the priority plug as BG, which is used by E31 to generate a BR SACK signal that generates a B BSY OUT L; the vector generator is enabled and the vector address (BD 02:08) and INTR L are output to the processor. After receipt of the vector address data, the processor asserts SSYN and subsequently bus mastership is released. # 5.2.5 RXV21 Interface (M8029) Block Diagram Description The RXV21 interface transfers commands and data between the RX02 Controller and the LSI-11. The RXV21 is an NPR device which functions as a slave when receiving commands from the LSI-11 and functions as a master when making data transfers. The interface is selected for use by a unique address (normally 177170 for the command and status register and 177172 for the data buffer register) which is decoded by the interface so that a command or data can be processed. Figure 5-12 is a block diagram of the RXV21 showing the major signal flow to/from the various functional grouping of the module. The E references on the diagram are IC chip designations on the RXV21 print set which is a separate document. - 5.2.5.1 Input/Output Transceiver, Buffer Selector When the LSI-11 has a command to be processed by the RXV21, address data BDAL and a BSYNC signal are placed on the bus. The address bits are decoded by the input/output transceiver, which by placement of jumpers (W1 to W11 jumper inserted = 1, jumper removed = 0) so that the jumper and address are equal, asserts MATCH when BSYNC is asserted with the correct address. MATCH along with BSYNC, which determines direction of transfer, enables the buffer selector to decode TSBUS1 and to develop signals which enable data to be entered either into the C&S buffer or into the data buffer. When TS BUS 1 is negated, data is entered into the C&S buffer (WRT CSR PLS is asserted), and when TS Bus 1 is asserted data is entered into the data buffer (WRT DB asserted). The asserted WRT CSR and WRT DB signals are also applied to the interface control to be used to establish RUN conditions. - 5.2.5.2 Command and Status Buffer Command information on the data/address lines is entered into the command and status (C&S) buffer circuits (E43) when WRT CSR PLS is asserted. Command data is shifted to the output of E38, E39 as TS Bus data by RD CSR L which is asserted when the command is placed on the input lines. The function to be performed is contained in TS BUS 1, 2, 3 which are coupled to the interface control as FUNCT 0, 1, 2 in order to establish the conditions to subsequently shift the 12-bit command to the controller. Figure 5-12 RXV21 Interface Module Block Diagram - 5.2.5.3 Data Buffer The data buffer receives data from either the LSI-11 or the controller and couples the particular data to the receiving device via the input/output transceiver. Data from the LSI-11 is parallel-loaded into the data buffer E37, E33 when signals (LO SEL 0 and DB SEL 1), developed internally by WRT DB, WRT CSR, RX DONE, are both asserted and the clock signal developed by SHIFT input is asserted. The parallel data is shifted serially through the buffer from Data 0 to Data 7 and from Data 8 to Data 15 when SHIFT is asserted. The serial data, which is to be output to the controller, is coupled to the interface control circuits by bits Data 7, 11, 15; data is transferred in 8-bit bytes and commands are transferred in 12-bit format. SER DATA from the controller is serial-loaded into the data buffer using ENA 8-bit L and H to enable the high order and low order byte and shifting the data by the clock signal. (The buffer clock signal is enabled by SHIFT and PROC OUT and SRPLY, or LOAD BAR or MDIN.) When 8 bits of data are in the buffer its parallel output is coupled through the input/output circuits to the LSI-11. - 5.2.5.4 Input/Output Transceiver and Transmit/Receive Data Circuit The input/output transceiver couples the data to be processed between the LSI-11 and the controller. Inputs to E31, E36, E41, E45 are C&S data or data buffer data and LSI-11 data/address. When data is to be coupled from the LSI-11 through the input/output, DAL REC is asserted and the data is available as TS BUS 00:15. The DAL REC signal is enabled by negating RD DB, RD CSR, EN DATA and EN ADDR. The TS BUS data is applied to the C&S buffer and the data buffer and all data (commands and data) are subsequently serially shifted through the data buffer to the controller via the interface control. When data is to be coupled to the LSI-11, XMIT EN is asserted and data buffer data or status data are coupled through the input/output transceiver to the bus for transfer to the LSI-11. The XMIT EN signal is asserted by negating RD DB or RD CSR or by asserting EN ADDR or EN DATA. Status data are output when RD CSR is applied to the C&S buffer circuits and data from the data buffer are output when RD DB is applied to the data buffer. The direction of data transfer from the interface to the controller or from the controller to the interface is determined within the buffer selector circuits according to the state of BD IN or BD OUT. - 5.2.5.5 Address Circuits The address circuits consist of a counter which provides the means to directly address the LSI-11 memory for data transfers. For a fill or empty buffer command, the address counter (E46, E47) is loaded with a memory address via the data buffer. For either of these commands, LOAD BAR is asserted and the counter is loaded from TS Bus 00:15. (For an extended address, TS Bus 12, 13 are loaded into E 32 when the counter reaches maximum by WRT CSR and WRT CSR PLS during a command word input so that bits BAD 16, 17 are available.) The output of the counter is coupled through the input/output transceiver to the bus as BDAL 0:15 which represents the starting address to enter or read from the LSI-11 memory. The address counter is incremented after each word (16 bits) transfer by EN ADDR L which is toggled by the bus control circuit operating in the NPR mode for the data transfer to fill or empty the controller sector buffer. - 5.2.5.6 Interface Control Circuits The interface control circuits establish the conditions to transfer commands and data to/from the controller. The function to be performed is identified as fill buffer, empty buffer, read error code, or other by FUNCT 0, 1, 2. When a command is to be transferred, TS Bus 0, B DONE, WRT CSR are used within the interface control (E17) to develop a Go signal which asserts RX RUN indicating a command transfer to the controller while RX DONE is asserted. The command word is coupled through the interface control (E13, E48, E35) to the controller via Data 11 and RX DATA L as a 12-bit word; the RX SHIFT signal from the controller is used to step the interface control through its sequence. If the function to be performed is fill buffer, empty buffer, or read error code, an NPR REQ is generated to initiate a request for bus mastership. (If RX AC L0 is asserted indicating a power loss in the controller, NPR REQ is inhibited.) The RXV21 establishes bus mastership after data is in the interface buffer. Data is transferred between the controller and the interface in 8-bit bytes using ENA 8-bit L and H to load the controller SER DATA in the data buffer or using DATA 7 or DATA 15 to couple data buffer data to the controller. The RX OUT signal indicates the direction of transfer. When RX OUT is negated, the TR signal is asserted when the controller is ready to accept the next element of data, and when RX OUT is asserted, the TR signal is asserted when a byte of data is transferred from the controller. The RX DONE signal is asserted when the function to be performed is completed. After RX DONE is asserted, 12-bit error status is transferred, then B DONE is asserted to establish conditions for performing a new function. - 5.2.5.7 Bus Control Circuits The bus control circuits generate the signals to establish bus mastership during data transfers. When an NPR REQ is generated by the interface control, a BMDRL signal is developed by E7 and applied to the LSI-11 processor. A bus grant (BMGI) is applied to the bus control circuitry (BRPLY and BSYNC are negated) to grant bus mastership and an acknowledge (BSACK L asserted) is generated indicating the interface has bus mastership. Signal EN ADDR L is asserted to enable memory address to be placed on the bus. After becoming master, B SYNC L and either BD IN L or BD OUT L are asserted, data is placed on the Bus, BRPLY is received, the BD IN or BD OUT is negated, B SYNC is negated, and bus mastership is released. - 5.2.5.8 Interrupt Circuits The interrupt circuits are used to generate an interrupt to return to the execution of the LSI-11 program after an RX02 function is completed. When an RX02 function is completed, B DONE is asserted and if TS BUS 6 (interrupt enable) of the command and status word was set, a BIRQ (bus request) is generated to gain control of the bus in order to place the vectoraddress on the bus. A bus grant (BIAKI) from the processor is routed by the priority daisy-chain and is used by E26 to generate ENB VEC which enables the vector address (BDAL 02:08) from the input/output transceiver and BRPLY (via the buffer selector). After receipt of the vector address, the processor terminates BD IN and BIAKO and subsequently bus mastership is released. # 5.3 UNIT LEVEL DESCRIPTION The following paragraphs provide a functional description of the units housed within the RX02 cabinet. There is a block diagram description of the $\mu$ CPU controller, the read/write electronics, and the mechanical drive; there is also a brief description of the $\mu$ CPU software. These units contain all the components necessary to rotate the disk, position the read/write heads, and perform the desired functions (write, read data). (Signal flow and interconnection between these units and the interface module are described in Paragraph 5.1.) ## 5.3.1 Microprogrammed Controller (M7744) Hardware Description This section describes the hardware operation of the controller. (The $\mu$ CPU software is described in Paragraph 5.3.2.) Figure 5-13 is a detailed block diagram of the controller showing the major signal flow to/from the various functional groupings that develop the signals to accomplish the various RX02 functions (e.g., write data, read data, etc.). The E references on the diagram are IC chip designations on the controller print set which is a separate document. 5.3.1.1 PROM, ROM Register, Processor and Sequencer Circuits – Operation of the controller is controlled by the PROM, ROM register, microprocessor, and microsequencer circuits which function as a computer control unit. The PROM contains a 1538, 16-bit word microprogram which determines controller operation. The output of the PROM, which is determined by the ROM ADDR (10:0) input from the microsequencer address register, is applied to the ROM register and microprocessor. The ROM register is used to store the microinstruction and subsequently controls operation of the microprocessor, microsequencer, and the various other circuits which develop the control signals to accomplish the desired microinstruction function. The microprocessor performs arithmetic and logical operations specified in the 16-bit microinstructions of program and provides an 8-bit data and status output ( $\mu$ DAT 0:7) that contains eight branch conditions for the branch selector. There are seven types of microinstructions contained in the microprogram: arithmetical and logical, branch (condition high and condition low), I/O (input/output), Jump and JSR instructions. The formats for the various instructions output from the ROM register are shown in Figures 5-14, 5-15, 5-16 and 5-17. Figure 5-13 μCPU Controller Block Diagram (Sheet 1 of 2) Figure 5-13 μCPU Controller Block Diagram (Sheet 2 of 2) Figure 5-14 Arithmetic and Logical Instruction Format Figure 5-15 Branch Instruction Format Figure 5-16 I/O Instruction Format Figure 5-17 JMP/JSR Instruction Format For an arithmetic and logical instruction the output of ROM REG bit 15 is equal to 1; this signifies that this instruction is to be performed by the microprocessor. ROM REG bits 02, 03, 04 indicate the source of data (ROM REG, ROM OUT, or internal inputs) for the microprocessor; ROM REG bits 11, 12, 13, 14 provide A and B RAM addresses for the processor; ROM REG bits 05, 06, 07 indicate the function to be performed by the microprocessor (add, subtract, etc.); and ROM REG bits 8, 9, 10 are decoded by DST decoder E37 when bit 15 is a 1 to indicate the data destination within the microprocessor and also the output of the microprocessor. The output of the microprocessor is applied to the $\mu$ DAT storage register E52, E58 which is loaded whenever the destination code $\mu$ DAT DST 0, 1, 2 is other than 0, 0, 1, respectively; this code indicates no storage (i.e., NO-OP – no change to data registers in 2901) and a constant is input to the microprocessor for the microinstruction immediately before the microinstruction when NO-OP occurs. The constant input to the microprocessor for arithmetic operations is contained in PROM outputs, ROM OUT 2 to 7, 11 and 12 which are used on the microinstruction currently at the output of the ROM register. When the constant is loaded in the ROM register, a NO-OP or "waste" cycle occurs and the microprocessor is unmodified. For a branch instruction, ROM REG bits 15 and 14 are 0 and 1, respectively; this signifies that this is a branch condition as decoded by branch decoder E26. ROM REG bits 13, 12, 11, 10, and 9 indicate the branch condition which is decoded by the 32-to-1 branch selector E12, E25. ROM REG bit 8 indicates whether a high or low signal will cause a successful branch. An unsuccessful branch takes one cycle and causes the microprocessor program to be incremented by one. A successful branch takes the cycles and branches to the address formed by bits (07:00) concatenated with the microprogram counter three high order bits. For an I/O instruction, ROM REG bits 15, 14, 13 are 0, 0, and 1, respectively; these bits are decoded by I/O OP decoder E23. ROM REG bits 12, 11, 10 and 9 indicate the I/O function to be performed which is detected by I/O function decoder E16. ROM REG bits 8 and 7 are decoded as C0 and C1 which determines the state (setting, resetting, or toggling a flip-flop) of I/O function control circuits E1, 2, 13, 14, 15, 17, and 18. For JMP and JSR instructions, ROM REG bits 15, 14, 13, and 12 are 0000 (JMP) and 0001 (JSR) respectively; these bits are decoded by the microsequencer control E31, 37, 40 and 41. ROM REG bits 10-1 contain the microprogram address of the jump. As each microinstruction is output from the PROM, the next instruction is determined by the microsequencer address register. The output of the microsequencer register is governed by the microsequencer control (E31, 37, 40, 41) and the wait/incrementer (E34, E35). The microsequencer control decodes ROM REG bits 00, 13:15 and generates the $\mu$ SEQ FILE EN, $\mu$ SEQ PUSH, $\mu$ SEQ S0, and $\mu$ SEQ S1 signals that determine the microsequencer internal source for the next address. The wait/incrementer and decoding of the micro op code generates the $\mu$ SEQ CN H signal which is used either to increment the microsequencer register to the next sequential address or to hold the microsequencer register to the current address, in which case the same microinstruction is repeated until the wait/incrementer overflows or a successful branch occurs. After an arithmetic and logic instruction, the next PROM address is from the microsequencer internal program counter which enables the program to continue in sequence. After a successful branch instruction, the nexxt PROM address is from the microsequencer program counter bits (10:8) concatenated with the microsequencer D inputs (ROM REG bits 07:00) which enables the microprogram to branch to an address other than the next sequential address. (For a write double density branch, the ROM ADDR 0R0, 0R1 signals are ORed into the least significant bits of the microinstruction and a normal successful branch is never performed.) For an unsuccessful branch, the microprogram counter is incremented. After an I/O instruction, the next PROM address is from the microsequencer internal program counter. When the wait bit (ROM REG bit 4) is set in an I/O instruction immediately before a branch instruction, the program is incremented by uSEO CN H after a wait and a successful branch occurs; if the branch is unsuccessful, the program is incremented after the wait elapses. (The incrementer countt is set to zero and when a successful branch occurs, the count is preset to 256 and the $\mu$ SEQ CN H goes high.) For either JMP or JSR instructions, the program jumps unconditionally to the PROM address which is contained in the current ROM REG (10:00) inputs applied to the R inputs of the microsequencer register; the program returns to the next instruction after the JSR instruction via the address stored in the microsequencer internal file. 5.3.1.2 Branch Control Circuits - The branch control circuits, which econsist of the branch selector (E12, E25), the Branch Cond High or Low (E24), the branch function decoder (E26), and the ROM ADDR OR gate (E26), detect when a branch condition is to be performed and develop a low SUC BRAN IN L signal to indicate a successful branch. There are 32 branch conditions that are used for the microprogram. When a branch instruction is at the output of the ROM register, a low ROM REG bit 13 enables the branch selector to decode ROM REG bits 12, 11, 10, and 9 which contain the code for the particular branch. (MUX E12 is used for branches 0-17g and MUX E25 is used for branches 208-378.) The output of the branch selector, which is the inverse of the input, is applied to branch condition T or F gate which is enabled by the BRANCH signal (ROM REG 15, 14 = 0, 1) to develop a low SUC BRAN IN L when some branch conditions are false (ROM REG 08 = 0) and when some conditions are true (ROM REG 08 = 1). The low SUC BRAN IN L signal, which indicates a successful branch, forces the BRANCH signal false and after being applied to the synchronizer storage register, enables the microsequencer to increment to the next microinstruction address. The ROM ADDR OR gate provides the ROM ADDR 0R0, 0R1 to the microsequencer to modify the PROM address during double density writing (ROM REG bits 13, 12, 11, 10 = 1111) while a branch condition is incomplete; this only happens for branch conditions 368 and 378. If it is assumed that the ROM REG output contains a branch instruction (01 00110 000 110 000) to test for write data, the following events would occur. ROM REG bits 15 and 14 are 0 and 1, respectively, so the BRANCH signal at E26 is high. ROM REG bits 13, 12, 11, 10, 9, are 0, 0, 1, 1, 0 respectively so that MUX E12 is enabled by ROM REG bit 13 low and the WRT DAT L input to the MUX is selected to be output from the MUX E12. ROM REG bit 8 is 0 so a branch will occur when the write data condition (WRT DAT L) is false. So for this instruction, when write data is not in process (WRT DAT L = 1), a branch will occur (SUC BRAN IN L = 0) and the microprogram will go to instruction 060. (ROM REG bits 7, 6, 5, 4, 3, 2, 1, 0 are 00110000 respectively.) 5.3.1.3 1/O Control Circuits - The I/O control circuits which consist of the I/O OP decoder (E23), the I/O function decoder (E16) and the I/O function control (E1, 2, 13, 14, 15, 17, 18), detect when an I/O (input/output) function is to be performed and develop the appropriate signals (RX DATA L. RX OUT L, etc.) to accomplish the desired results (read data, write data, etc.). There are 16 I/O functions that are to be accomplished by the microprogram. When an I/O instruction is at the outputof the ROM register, ROM REG bits 15, 14, 13 (001) are decoded by the I/O OP decoder to enable the I/O function decoder to decode ROM REG bits 12, 11, 10, 9 which contain the code for the particular I/O function. The output of the decoder is 1 of 16 clock signals, operating at the rate of TP3 L (50 ns pulse every 200 ns), which are applied to the I/O function control circuits, the CRC, and the buffer control; these circuits develop interface signals between the controller and the R/W electronics and the interface modules. The I/O clock signals trigger the control circuits to set, clear, etc. according to the enabling signals C0, C1 which are generated by ROM REG bits 8 and 7 (00-Toggle, 01-set, 10clear, 11-no op). The clock signals (BUF DAT CLK and BUF WRT CLK) applied to the buffer control are used to write/read buffer data also according to the enabling signals C0, C1. As each I/O control flip-flop is triggered, its output is applied to selection gates where, according to the bus enabled (DRV BUSS H = R/W, DRV BUSS L = interface), the desired signal is available at the controller output. If it is assumed that the ROM REG output contains an I/O instruction (001 000 1010 000 000) to set Write Gate, the following events would occur. ROM REG bits 15, 14, and 13 are 001 respectively so the I/O OP H signal at E23 is high. ROM REG bits 12, 11, 10, 9 are 0001, so that when TP3 L goes low, the IOB 1 CLK L signal goes low at the output of E16. The IOB 1 CLK L signal is applied to and sets E13 making IOB 1 (1) H high because ROM REG bits 8 and 7 are 0 and 1 respectively. With IOB (1) H high, it is ANDed with a DRV BUSS H signal, which would have been generated prior in the microprogram instructions, so DRV WT GATE H signal is applied to the R/W electronics to enable the write drive. 5.3.1.4 Sector Buffer and Control Circuits - The sector buffer circuits which consist of buffer control (E50), sector buffer address counter (E51, 57, 63) and the sector buffer (E56, E62) stores a sector of data either input from the interface module or input from the R/W electronics. The stored data from the interface module is subsequently written on the disk and the stored data from the R/W electronics (read from the disk) is subsequently output to the interface module. Whether the sector buffer stores or outputs data is determined by the WRITE ENABLE output of buffer control E50. When WRITE ENABLE is low, data can be stored in the buffer (C1 H asserted and BUF WRT CLK L asserted) and when WRITE ENABLE is high, data can be output from the buffer (C0 H asserted and BUF WRT CLK L asserted). The data is input to the sector buffer serially via the buffer control (BUF DATA IN H) which is applied from the data selector and CRC circuit. The BUF DATA IN H signal is applied to flip-flop E50 which is triggered by BUF DAT CLK L once for each bit; E50 is set or cleared according to the data to be entered, and the BUF DAT IN (1) H output of E50 is input to the sector buffer and also to the branch selector where the program tests for a write data condition. The data is output serially from the sector buffer as SEC BUF OUT (1) H when WRITE ENABLE is negated, and the buffer is either emptied or filled according to the BUF ADDR output of the buffer address counter. The buffer address counter can be preset to count either 1024 (single density data) or 2048 (double density data) and then it outputs a SEC BUF OVF (overflow) to the data selector and branch selector circuits when an overflow occurs. The counter is preset when ROM REG bit 13 is 1 (I/O function) and ROM REG bits 9 to 12 contain the I/O function code 16; the counter is preset to count 1024 when CO H is low and C1 H is high and it is preset to count 2048 when both C0 H and C1 H are low. Once the counter is preset, it is incremented by TP3 L whenever ROM REG bit 5 is asserted during an I/O function. As the counter is incremented, a new address is applied to the sector buffer in order to either fill the buffer or empty the buffer; the buffer address is always sequential up to 1023 or 2047. 5.3.1.5 Data Selection and CRC Circuits – The data selection and CRC circuits, which consist of a 4-to-1 MUX E44 and 16-bit shifter E43, controls what data is input to the sector buffer, when data is output from the sector buffer, and also generates a CRC character to be written on the disk and checks the CRC character read from the disk. When data is to be input to the sector buffer, RX DATA H from the interface module is selected at E44 if ROM REG bits 7 and 8 are 1 and 0 respectively, and DRV SEP DATA H from the R/W electronics is selected if ROM REG bits 7 and 8 are both 0. The BUF DAT IN H serial output of E44 is the same as the input ("1" in "1" out, "0" in "0" out). When data stored in the sector buffer is to be output, SEC BUF OUT B is selected as the input at E44 when ROM REG bits 7 and 8 are 0 and 1 respectively, and the output CRC IN is applied to the I/O function control circuits for subsequent data output to the interface or R/W electronics. The CRC character is calculated when data is being written on the disk by applying the CRC IN to CRC generator E43 at the same time it is being used as an output to the driver in the R/W electronics. The CRC generator E43 is preset, to implement the $2_{16} + 2_{12} + 2_5 + 1$ polynomial, by a low DRV BUSS H when data is to be input from the interface. The CRC E43 is enabled by a high input from flip-flop E13 and data is clocked into the CRC by TP3 L. The CRC generator remains enabled until SEC BUF OVF H occurs at which time CRC OUT occurs and the CRC character (16 bits) is written. After the data field has been written, the CRC register contains the remainder of the division by the polynomial, which is a two-byte character that is written after the data field. While the data is being output from the buffer and while the CRC character is being output, WRT DAT L is low to indicate that writing a sector of data is still in progress. After the CRC character is written, WRT DONE L goes low and the microprogram branches to another instruction. The CRC character is checked when data is being read from the disk by using DRV SEP DATA to develop CRC INN at E44 at the same time DRV SEP DATA is being used to develop BUF DAT IN. The CRC IN is applied to CRC E43 which checks all bits including the CRC bits. The data and CRC bits are divided by the same polynomial so that if an error is detected, CRC ERR H goes high; otherwise it remains low. 5.3.1.6 Timing and Synchronizing Circuits - The timing circuits consist of a 20 MHz oscillator E27 and a counter E28. This circuit develops 5 MHz SYS CCLK H AND SYS CLK L signals and a 5 MHz TP3 L signal that has a 50 ns pulse width. These timing signals are used throughout the controller to time the shifting and storing of data. The synchronizing circuits consist of two flip-flops, E11 and E19. These circuits are used to synchronize external signals and delayed internal signals to coincide with timed events within the controller. Pulsed signals such as DRV SEL INDEX, as well as signals with levels, are clocked into E11 by SYS CLK L and then shifted into E19 by SYS CLK H, thus synchronizing these signals with events of the microsequencer, microprocessor, ROM register, etc. which are all clocked by SYS CLK H. 5.3.1.7 Power Fail Circuit – The power fail circuit is used to clear the controller registers and stop timing when the RX02 is initialized or loses power. When power is first applied, RX INIT L is low and forces both DRV AC L and INIT L low to clear the various registers; then two transistors within the circuit conduct and force both DRV AC L and INIT L high so the various registers are ready to operate. When power is lost in the RX02, these same two transistors stop conducting and DRV AC L and INIT L are both forced low. #### 5.3.2 Microprogrammed Controller Software Description The following paragraphs provide a brief description of the various subroutines of the controller microprogram. The flowcharts presented in Figures 5-18 to 5-30 provide a guide through the microprogram listing which is contained in the RX02 print set. - 5.3.2.1 Initialize Routine (Figure 5-18) This subroutine starts at microinstruction 0. When the host processor initializes or there is a power loss in the RX02, the program counter is cleared and the RX02 stops. When the microcode initialize is negated, unit (drive) one is selected and the head is stepped in and out, then unit zero is selected and the head is stepped in and out. If errors are found, error (error code 010 for drive 0 and error code 020 for drive 1) and done are set. If there are no errors, a maintenance mode check is initiated in order to check out the read path of the read/write electronics. If there are no errors in the maintenance check, drive zero is checked to see if it is up to operating speed and the ready condition is flagged. The density is determined and sector 1 of track 1 is loaded into the sector buffer of the controller, the drive status is set into the interface register, and then the routine ends. - 5.3.2.2 Find Header (FIND HD) Subroutine (Figure 5-19) This subroutine which starts at micro-instruction 400 is used to locate the identification (data, clock) address mark of the sector header field. A search is made for the header ID, and if this is successful, the track and sector are compared with the target track and sector. If there is a mismatch between tracks and sector, the mismatch is flagged. A byte of zeros is read and a check is made for CRCC errors; if there is an error, the header bad start count is incremented and the header search continues. If there is no error but there is a mismatch between the target track and the actual track read, error and done are set (error code 150). If there are no errors, the subroutine returns to the calling routine. Figure 5-18 Initialize Routine Flowchart Figure 5-19 Find Header Subroutine Flowchart - 5.3.2.3 Read Address Mark (RDAM) Subroutine (Figure 5-20) This subroutine which starts at microinstruction 471 is used to identify the address mark. A check is made for single or double density, the drive bus is selected, and lock clock is set to enable a read from the drive. There is a 51 $\mu$ s wait for Read Strobe to occur. If there is no read strobe, an error (error code 120 for nonexistent drive) is set, but if read strobe occurs, a check is made for separated data (a nonzero first bit). If data "one" is not detected before 255 zeros have passed, error is set. Each bit of the header ID byte is checked for the appropriate data and separated data, and when the ID is identified, the subroutine returns to the calling routine. If no IDAM is found, error and done are set (error code 160). - 5.3.2.4 Read (RD) Sector Subroutine (Figure 5-21) This subroutine which starts at microinstruction 1657 is used to read a sector of data into the sector buffer. First the track and sector are located, the data address mark is read, and density is checked. Data is read from the disk, written into the buffer, and applied to the CRC. When the complete sector is written into the buffer, CRC is read and if there is no error, the function is ended (OK DONE). If there is a CRC error, error and done are set (error code 200). - 5.3.2.5 Write/Write Sector Subroutine (Figure 5-22) The write sector and write routines start at microinstructions 363 and 124, respectively, and they are used to write a sector of data on the disk. The write sector subroutine starts by locating the track and sector and then goes to the write subroutine. Data is written on the diskette a single sector at a time. To write data in a sector, the drive bus is selected, the high or low level write current is selected, the density is determined, the data from the sector buffer [either 1024 bits (single density) or 2048 bits (double density)] is written, the CRC (16-bits) is written, and then the postamble is written. The DAM (data address mark) appropriate to either a write or write sector command is written immediately before the data field. - 5.3.2.6 Read Error Register (RDERRG) and Set Density (SET DEN) Subroutines (Figure 5-23) The RDERRG subroutine which starts at microinstruction 1336 is used to apply error status to the interface register. The set density subroutine which starts at microinstruction 1251 is used to set the density (data address mark) for each sector of each track on the diskette. The set density subroutine starts by filling the sector buffer with zeros and then selecting target track 0 and target sector 1. The appropriate density is written on sector 1 of track 0 and the sector is filled with zeros. The sector count is incremented until all sectors of a track have the appropriate density and all zeros; then the track count is incremented. When all sectors of all tracks are filled with the appropriate density and zeros, the subroutine returns to the calling routine. The RDERRG subroutine starts by asserting RX OUT to establish that the direction of data transfer is to the interface module. If the operating configuration is the same as an RX01 (no DMA interface), the content of the error register is output to the interface register. But if there is a DMA interface, the word count, current track 0, current track 1, target track, target sector, and soft status registers are applied to the interface and the subroutine exits to OK DONE. - 5.3.2.7 Fill/Empty Buffer Routine (Figure 5-24) This routine which starts at microinstruction 1000 is used to fill or empty the sector buffer with single or double density data. The direction for data transfer is determined and OUT is set accordingly; then it is determined if the interface is DMA or programmed I/O. The appropriate word or byte count is set according to single or double density and 8-bit or 12-bit mode. The buffer address is incremented or decremented as appropriate for the fill or empty commands and then the routine exits to OK DONE. (When filling the buffer for word counts less than maximum, the unused portion of the buffer is filled with zeros.) - 5.3.2.8 Find Track Subroutine (Figure 5-25) This subroutine which starts at microinstruction 1124 is used to locate the target track for a particular drive and then to step the read/write head to that track. Figure 5-20 Read Address Mask Subroutine Flowchart (Sheet 1 of 3) Figure 5-20 Read Address Mask Subroutine Flowchart (Sheet 2 of 3) Figure 5-20 Read Address Mask Subroutine Flowchart (Sheet 3 of 3) Figure 5-21 Read Sector Subroutine Flowchart Figure 5-22 Write/Write Sector Subroutine Flowchart (Sheet 1 of 2) Figure 5-22 Write/Write Sector Subroutine Flowchart (Sheet 2 of 2) Figure 5-23 Read Error Register and Set Density Subroutines Flowchart Figure 5-24 Fill/Empty Buffer Routine Flowchart Figure 5-25 Select Drive and Find Track Subroutines Flowchart The drive is determined and then the track address is checked to be sure it is a legal address. If the address is illegal, error (code 040) and done are set, but if the address is legal, the desired drive bus is selected and the direction for head movement is selected. The head is stepped to the target track. (If home is found before the target track, error - code 050 - and done are set.) On a write command if the heads have been unloaded, the DMA of the sector previous to the desired sector is read to determine if the diskette is of the appropriate density. If there is a density error, error and done are set (error code 240). After correct density is determined, the target sector is restored and the subroutine exits to the calling routine. - **5.3.2.9** Decode command (DECCMD) Routine (Figure 5-26) This routine which starts at microinstruction 1400 is used to decode the command from the host processor and subsequently to branch to the routine to perform the desired function. Transfer request is cleared, the direction of transfer is set to in, done is set, and the command is entered. The 8-bit or 12-bit mode is determined, done is cleared, and the function to be performed is decoded (write data, fill, etc.) and this routine jumps to the particular routine. - 5.3.2.10 Maintenance Read Status (MRDST) and Check Ready (CHKRDY) Subroutines (Figure 5-27) The MRDST and CHKRDY subroutines start at microinstructions 646 and 656, respectively. These subroutines are used to check the speed and density of the drive selected and to set the ready bit. - 5.3.2.11 Get Parameter (GET PAR), Step Head (STEPHD), Wait, Wait Run, and Write Zeros (WRTS) Subroutines (Figure 5-28) The GET PAR subroutine which starts at microinstruction 767 is used to store target track and sector. (The high order three bits of the 8-bit sector byte are masked.) The STEP HD subroutine starts at microinstruction 1741 and is used to step the read/write head to the target track; two step pulses are applied to the head motor to move the head one track. The WAIT subroutine which starts at microinstruction 1762 is used for delays in 100 µs multiples. The WAIT RN subroutine which starts at microinstruction 357 is used to time out (200 for RX02 DMA configurations, indefinitely for RX01 configuration and RX02 programmed I/O configurations) the wait for RUN to be asserted for data transfers to/from the interface module. If a timeout occurs, the routine asserts error and done. The WRTOS subroutine starts at microinstruction 326 and it is used to write zeros for the sync field (six bytes). - 5.3.2.12 Find Sector (FINDSE), Send Word 12 (SNDW12), Send Word 8 (SNDW8), Get Command (GET CMD), and Get Word (GET WRD) Subroutines (Figure 5-29) The FINDSE subroutine which starts at microinstruction 1543 is used to locate the target sector by comparing the current sector location of the read/write head with the target sector until a match is found, or if no match is made, an error (code 070) is set. The SNDW12 and SNDW8 subroutines start at microinstructions 1567 and 1621, respectively. These subroutines are used to send 8-bit or 12-bit words to the interface; for the 12-bit mode high order bits 8-11 are shifted so that they are the next four bits transmitted after the low order bits (0-7). The GET CMD and GET WRD subroutines start at microinstruction 752 and 1625, respectively. These subroutines are used to get the command (the length of the word in the command depends on 8-bit or 12-bit mode) and store it so the function contained in the command can be performed. - 5.3.2.13 Maintenance Check Ready (MAINT CHK) Subroutine (Figure 5-30) This subroutine which starts at microinstruction 721 is used to set maintenance mode and check the read/write electronics during maintenance (troubleshooting) by writing zeros and reading these same zeros to generate SEP DATA and SEP CLK signals. If an error occurs, error code 220 is set in the error register, and if no errors occur, maintenance mode is cleared and the routine returns to the calling routine. Figure 5-26 Decode Command Routine Flowchart (Sheet 1 of 2) Figure 5-26 Decode Command Routine Flowchart (Sheet 2 of 2) Figure 5-27 Maintenance Read Status and Check Ready Subroutines Flowchart Figure 5-28 Get Parameter, Step Head, Wait, Wait Run, and Write Zeros Subroutines Flowchart Figure 5-29 Find Sector, Send Word 12, Send Word 8, Get Command and Get Word Flowchart Subroutines Figure 5-30 Maintenance Check Ready Subroutine Flowchart ## 5.3.3 Read/Write Block Diagram Description The read/write electronics transfer data between the drive(s) heads and the controller. Data and control commands are processed so that the desired drive and head are selected and then data is either read from or written on the disk. Figure 5-31 is a block diagram of the read/write electronics which shows the signal flow to/from the major functional circuits of the assembly. The E references on the diagram are IC chip designations on the read/write print set. - 5.3.3.1 Drive and Head Control The drive and head control circuits consist of the head load control (E53, Q26, Q27) and the stepper motor control (E1 to E10, E57 to E61, Q12 to Q19). The head and drive selected are determined by DRV SEL DK1 which is applied to both circuits along with SEL DKO. The DRV AC L signal is used to initialize both the head load and motor control circuits; so when DRV SEL DKI is asserted, the drives and step counters for drive 1 motor are enabled and the step counting and driver circuits for drive 0 are disabled. The direction in which the head moves is determined by DRV OUT/ABOVE TRK 43; when it is asserted, the head moves out toward the edge and when the signal is negated, the head moves toward the center. With the drive selected, the head motor is stepped to the desired track using two step pulses (DRV STEP L) for each track moved. With the head positioned over the desired track, the DRV LOAD HEAD signal is asserted to activate the head solenoid for the drive selected by the assertion or negation of DRV SEL DK1. The drive and head selected status is applied to the controller by the position data selector. - 5.3.3.2 Position Data Selection The position data selector couples drive track 0 and head index data to the controller. Track 0 and head index hole detection are each accomplished by a LED phototransistor pair which develops a pulse each time the index hole passes or when the head is positioned over track 0. The track 0 signal for each drive and the index hole signal for the head(s) of each drive are applied to data selector E56. The outputs, DRV SEL TRK 0 and DRV SEL INDX, are determined by which drive (SEL DKO) and head (DRV SEL HDO) are being used. When SEL HDO and SEL DKO are both asserted, the DRV SEL TRK0 output is for drive 0, track 0 and the DRV SEL INDX output is for drive 0, head 0. - 5.3.3.3 Read/Write Circuit The read/write circuits consist of the head select matrix and read/write control, the write current amplifier, the read current amplifier, and the read data detector (PLL, data separator, preamble detector, data gate). These circuits process the data to be written on the disk or the data to be retrieved from the disk. Data can be written on the disk when DRV WT GATE is asserted enabling the encoded DRV WT DATA to be coupled through the write current amplifiers to the drive head selected by SELDKO, SELDKI, SEL HDO. At the same time the write path is enabled by DRV WT GATE, the read path from the head select matrix is disabled. The DRV ERASE signal is asserted after DRV WT GATE to enable the erase amplifier in order to compensate for displacement between R/W pole and erase poles. The DRV OUT/ABOVE TRK 43 signal is used to disable a transistor in the write circuit and reduce the write current when writing on tracks above track 43; when closer to the center of the disk, bit density increases and less current is necessary. Data can be read from the selected disk when DRV WT GATE is negated which enables the read path from the head select matrix (E27). The signal from the disk is amplified by the read current amplifier and filter (E25, E23) which enhances the signal and reduces high frequency noise; the analog playback signal is digitized by differentiating the signal and detecting the zero crossover. The digitized data is coupled through the data gate to the data separator so that the data can be retrieved. The data is separated by developing a clock signal which operates at the frequency of the playback and then using the clock signal to gate the data. The data gate couples the digitized data to the PLL, data separator, and preamble detector when MAINT MODE is negated. (When MAINT MODE is asserted DRV WWT DATA is coupled to the PLL, data separator and preamble detector in order to test the operation of these circuits.) For data acquisition, the PLL has to be aligned and locked onto the data frequency during the preamble (six sync bytes of zeros). The preamble detector which is enabled when DRV Figure 5-31 Read/Write Electronics Block Diagram LOCK CLK is asserted by the controller counts the preamble bytes of zeros. After one byte of zeros, the PLL is enabled and begins to lock onto the data frequency. (The PLL generates a clock signal aligned to the data frequency by comparing the frequency of a VCO with the data frequency and adjusting the VCO until it approximates the data frequency.) The PLL locks onto the data frequency within four bytes of zeros unless a nonzero byte occurs which will reset the byte counter (E32, E40) and disable the PLL. After four bytes of zeros have been counted, FAST LOCK is negated which indicates that PLL is locked on. FAST LOCK enables the CLK and DATA to be processed by the data separator. The CLK signal is used to establish a window which will be high during data and low during a clock for both FM and MFM playbacks (Figure 5-32). A "1" bit in the playback when the window is high is set in the data latch and a "1" bit in the playback when the window is low is set in the clock latch. Data and clock bits are latched in E48, and synced in E50 and subsequently stored in the 3-bit clock register and the 3-bit data register E55. (The 3-bit register is necessary because of modified MFM encoding.) When data is MFM encoded, DRV RD 3F is asserted by the controller and the PLL clock and data decoding are adjusted accordingly. DRV READ STROBE is asserted as DRV SEP DATA and DRV SEP CLK are available at the output. The SEP DATA or SEP CLK signal is asserted for 4 us for single density data and for 2 us for double density data. Figure 5-32 Data SYNC Timing Diagram ## 5.3.4 Mechanical Drive Description The mechanical drive consists of four major parts: - 1. Drive mechanism - 2. Spindle mechanism - 3. Positioning mechanism - 4. Head load mechanism The mechanical structure of the drive is shown in Figure 5-33; each section is described in the following paragraphs. 5.3.4.1 Drive Mechanism – The drive system provides rotational diskette movement using a single phase motor selected to match primary power of the controller system (Figure 5-34). The diskette drive attains ready status within 2 seconds of primary power application. A cooling fan is mounted on one end of the drive motor shaft. Rotation of the diskette is provided by a belt and pulley connected to the other end of the motor shaft. The drive pulley and belt are selected for either 50 or 60 Hz power to achieve a diskette rotational speed of 360 rpm. (See Paragraph 2.1.3.2 for complete input power modification requirements.) 5.3.4.2 Spindle Mechanism - The spindle mechanism consists of a centering cone and a load plate. In the unload position, the load plate is pivoted upward, creating an aperture through which the floppy diskette is inserted. In this position, the centering cone disengages the diskette from the drive mechanism. To load a diskette, the operator inserts the floppy diskette and presses down on the load handle which latches the load plate in the operating mode. The centering cone is mechanically linked to the load plate and is activated at the same time (Figure 5-35). The centering cone is an open splined nylon device that performs two functions: - Engages the diskette media and drive mechanism. - 2. Positions the diskette media in the correct track alignment. As the load plate is pivoted to the load position, the centering cone enters the floppy diskette center. At approximately 80 mils from the fully down position, a centering cone expander is automatically activated. This device then expands the centering cone, which grips the inner diameter of the diskette media in the correct track alignment. The track 0 position serves as the diskette drive reference track. This position is sensed by a photo-transducer, which generates track 0 status. This status is sent to the controller for initial track positioning. The controller generates step pulses to position the carriage from the current track to a new track. 5.3.4.3 Positioning Mechanism – The positioning mechanism comprises a carriage assembly and a bidirectional stepper motor (Figure 5-36). The stepper motor rotational movements are converted to linear motion by the rotor lead screw. The read/write head mount rides on the lead screw and is held in horizontal alignment. When the stepper motor is pulsed, the lead screw rotates clockwise or counterclockwise, moving the mount in or out. Figure 5-33 Disk Drive Mechanical System Figure 5-34 Drive Mechanism Figure 5-35 Centering Cone and Drive Hub Figure 5-36 Positioning Mechanism The stepper motor includes four pairs of quadrature windings. For positioning, one or more step pulses are sequentially applied to quadrature windings, causing an imbalance in the electromagnetic field. Consequently, the stepper motor rotor revolves through detent positions until the step pulses are halted. The rotor then locks in that position. The sequence in which the stepper motor quadrature windings are pulsed dictates rotational direction and subsequently higher or lower track addressing from a relative position. 5.3.4.4 Head Load Mechanism - The head load mechanism is basically a relay driver and a solenoid. When activated by signal LD HD from the controller, the spring-loaded head load pad is released and rests in parallel alignment with the floppy diskette surface. The disk clamping platform (located on the casting) provides the lower alignment dimensional surface, while the head load solenoid bar provides the upper alignment surface. In the load position, the read/write head rides between these two alignment surfaces and keeps the read/write head in contact with the diskette surface. The load pad is located behind the read/write head and holds the floppy diskette flat against the lower alignment block. To minimize diskette surface and head wear, the head is automatically disabled by the controller if no new command has been issued within 200 ms. (Head settling time is 25 ms.) # CHAPTER 6 MAINTENANCE This chapter contains information necessary to maintain and troubleshoot the RX02 Floppy Disk System. Included is equipment care information, troubleshooting procedures, diagnostic routines, and removal and replacement procedures. # 6.1 EQUIPMENT CARE There is no scheduled preventive maintenance to be performed on the equipment. However, the exterior of the equipment should be kept clean using a damp cloth; if necessary the internal chassis should be cleaned with a vacuum cleaner. #### NOTE There are no field adjustments to be made on the RX02. #### 6.2 TROUBLESHOOTING THE RX02 Sections are included for troubleshooting the RX02 with and without the use of diagnostics. When attempting to diagnose the failing component the following procedure is recommended. #### 6.2.1 M7744, M7745 Failures Place the replacement module on the existing M7745 module using a memory shield to prevent shorting. Remove the mounting hardware only when a module has been verified to be faulty. #### 6.2.2 Drive Failures If one drive is believed to be faulty, interchange the cables of drive 0 and drive 1. If failures remain with a given drive number, replace module M7745 or M7744. Remove the drive from the chassis only if failures continue. #### 6.3 TROUBLESHOOTING WITH DIAGNOSTICS Diagnostics consist of the RX02 Logic/Function Test, the RX02 Subsystem Performance Exerciser, and the DECX-11/DECX-8 modules. To load each diagnostic refer to the associated diagnostic documentation. Successful completion of the diagnostics will indicate that the system is operational. If error codes are displayed when running the performance exerciser or DECX refer to Table 6-2 to identify the probable cause of the error. #### NOTE The following procedure should only be used if the RX02 is the only loading device on the system and it is impossible to load the diagnostics. # 6.4 TROUBLESHOOTING WITHOUT A DIAGNOSTIC # 6.4.1 RX211 and RXV21 Systems - 1. Install a known good diskette in drive 0 - 2. Initialize processor - 3. Examine RX2CSR (777170): bits 11, 5 should be set; bit 15 should not be set. - a. no bit 11 replace interface - b. no bit 5 Table 6-1, Done bit timeout - c. bit 15 set Table 6-1, initialize error Table 6-1 Troubleshooting Chart | Problem | Probable Cause | Suggested Remedy | | | | |--------------------------------------------|------------------------------------|---------------------------------------------------------------------------------------------|--|--|--| | No indication of power (drive inoperative) | Power cord not connected | Check power cord connection. | | | | | | Blown fuse | Check fuse; replace if blown. | | | | | | Drive power connector disconnected | Check power cable connection to drive. | | | | | | Power supply fault | Check power supply output: +24 Vdc at P1-6 + 5 Vdc at P1-4 - 5 Vdc at P1-2 + 5 Vdc at P2-4 | | | | | | | + 5 Vdc at P2-4<br>+10 Vdc at P2-1 Controller | | | | | | | Replace power supply if voltages not correct. | | | | | Drive not ready | Door open | Close door. | | | | | | Diskette not spinning | Replace belt. | | | | | | Motor not rotating | Check ac power connector. | | | | | | M7745 module | Replace module. | | | | | | M7744 module | Replace module. | | | | | Cannot run diagnostics | Improperly loaded | Reload diagnostic. | | | | | | Interface problem | Replace interface. | | | | | | Possible CPU problem | Run CPU diagnostics. | | | | Table 6-1 Troubleshooting Chart (Cont) | Problem | Probable Cause | Suggested Remedy | | | |----------------------------------|-------------------------------------------|-------------------------------------|--|--| | Initialize Error | Interface cable inserted backward | Reverse cable. | | | | | Diskette problem | Replace diskette. | | | | | Switches not set properly | Check switch settings on M7745. | | | | | M7744 module | Replace M7744. | | | | | M7745 module | Replace M7745. | | | | Done bit timeout | Switches not set properly on M7744 module | Check switch settings on M7744. | | | | | M7744 module | Replace M7744. | | | | | Interface module | Replace interface. | | | | TR bit timeout | M7744 module | Replace M7744. | | | | | Interface module | Replace interface. | | | | Set Density Error | Diskette<br>M7745<br>M7744 | | | | | Data error but no CRC error | M7744 | Replace M7744. | | | | | Interface | Replace interface. | | | | For RX211 and RXV21 only | Interface | Replace interface. | | | | Fill Buffer Error | NPR jumper on PDP-11<br>backplane not cut | Cut jumper. | | | | Empty Buffer Error | Interface | Replace interface. | | | | | M7744 module | Replace M7744. | | | | Inexpected interrupt to loc. xxx | Switch settings on interface | Check switch settings on interface. | | | | | Interface | Replace interface. | | | - 4. Examine RX2 ES (777172): bits 2, 7 should be set; bits 0, 1, 3, 4, 11 should not be set. - a. no bit 2 replace M7744 - b. no bit 7 Table 6-1, Drive not ready - c. bit 0 set Table 6-2, Code 200 - d. bit 1 set replace M7744 - e. bit 3 set Table 6-1; no RX02 power - f. bit 4 set replace diskette - g. bit 11 set replace interface. - 5. If neither address answers, replace the interface module or check switches (jumpers) on the interface. NOTE If RX2CS bit 15 is set and all bits of RX2EX are valid, load and execute the following program to obtain the definitive error code. | 001000 | 012701 | | MOV | #ADR,R1 | |--------|--------|---------------|------------------|-----------------------| | | 177170 | | | <i>y</i> | | 001004 | 032711 | 1 <b>\$</b> : | BIT | #40,(R1) | | | 000040 | - | — — <del>"</del> | H 124(211) | | 001010 | 001775 | | BEQ | 1\$ | | 001012 | 012711 | | MOV | #17,(R1) | | | 000017 | | 17101 | #17,(141) | | 001016 | 032711 | 2\$: | BIT | #200,(R1) | | | 000200 | 20. | 211 | #200,(ICI) | | 001022 | 001775 | | BEQ | 2\$ | | 001024 | 012761 | | MOV | #2000,2(R1) | | | 002000 | | 1.101 | #2000,2(R1) | | | 000002 | | | | | 001032 | 032711 | <b>3\$</b> : | BIT | #40,(R1) | | 001032 | 000040 | υφ. | DII | <del>//1</del> 0,(K1) | | 001036 | 001775 | | BEQ | 3\$ | | | | | • | <b>3</b> 3 | | 001040 | 000000 | | HALT | | | | | | | | Refer to Table 6-2 to correlate the definitive error code with the probable cause of error. Table 6-2 Error Code Probable Causes ## **Error Code** | 000 | 010 | 020 | 040 | 050 | 070 | 110 | 120 | 130 | 150 | 160 | 170 | 200 | 220 | 230 | 240 | 250 | |-------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|----------|-----|-----|-----|-----| | If | D | D | Е | С | Α | Α | Α | Α | С | С | Α | Α | С | Е | Α | Е | | Error | В | В | В | D | c | C | C | С | D | D | С | C | В | В | В | В | | Bit | ∤C | С | 1 | B | D | D | D | В | В | В | В | В | 1 | | E | | | is | | | | ŀ | В | В | В | 1 | ł . | | 1 | <u> </u> | ŀ | | С | ! | | set. | 1 | { | | | E | [ | G | | | Ì | 1 | l I | ĺ | ŀ | | [ | | | ł | } | | | | | E | | | | } | | | | | j | | | 1 | 1 | ı | I | | 1 | I | | | | 1 | I | E | I | I | ı | A = Diskette E = Interface module B = M7744 controller F = Cables C = M7745 R/W electronics G \* Power supply D = Drive ## 6.4.2 PDP-8 and CM05-8\* Based Systems - Insert a known good diskette into drive 0. - 2. Load and execute the following program to obtain the contents of the RX2ES and the definitive error codes. ``` 6007 200/ CAF 201/ 6755 SDN 202/ JMP-1 5201 203/ 6752 XDR 204/ 3214 DCA 214 205/ 1216 TAD 216 206/ 6751 LCD 207/ 6755 SDN 210/ 5207 JMP-I 211/ 6752 XDR 212/ 3215 DCA 215 213/ 7402 HALT 214/ 0 ERROR AND STATUS REGISTER 215/ 0 DEFINITIVE ERROR CODE, BITS 4 216/ 16 (4:11) ``` LOC 214 contains the RX2ES LOC 215 contains the definitive error code bits (4:11) (Table 6-2). RX2ES bits 4, 8, 9 should be set; bits 7, 10, 11 should not be set. - a. no bit 9 replace M7744; replace PDP-8 interface. - b. no bit 8 verify switch settings on M7744; replace M7744; replace interface module. - c. no bit 4 Table 6-1 (Drive not Ready) - d. bit 11 set Table 6-2 (Code 200 Error) - e. bit 10 set replace M7744; replace M7745 - f. bit 7 set replace diskette. If the program does not run, the M7744 controller module should be replaced. # 6.5 REMOVAL AND REPLACEMENT The following steps define the procedures for removing and replacing the subassemblies of the RX02 Floppy Disk System. #### 6.5.1 Module Replacement Procedures ## Floppy Disk Controller M7744 (Figure 6-1) - 1. Remove power from the RX02. - 2. Unscrew the three screws on the module and raise the module to the servicing position. - 3. Remove the plugs in connectors J1 and J2. For VT78 and VT178 consoles the MR78 Field Service ROM package is required to boot ODT into the console prior to entering the short diagnostic program. Figure 6-1 RX02 Component Location Diagram - 4. Lower the module and remove the three screws holding the module onto the hinge. - Remove the module. - 6. To install a module, perform steps 1-5 in reverse. - 7. Ensure that cable BC05L-15 is inserted with the red stripe on the cable nearest the front of the unit. # Read/Write Control, M7745 (Figure 6-1) - 1. Remove power from the RX02. - 2. Raise the floppy disk control module to the servicing position. - 3. Remove the plugs from connectors on the module, ensuring that they do not drop into the drive. - 4. Remove the eight screws holding the module to the frame and remove the module. - 5. To install a M7745, replace the screws and plugs removed in steps 3 and 4, ensuring that they are reinstalled into the correct connector (Table 6-3). Connector Description J1 Disk drive interface cable Power from H771 power supply J2 DK0(P3) Head cable DK0(P4) Stepper motor DK0(P5) Head load solenoid DK0(P6) Index signal Track 0 signal DK0(P7) DK1(P3) Head cable DK1(P4) Stepper motor DK1(P5) Head load solenoid DK1(P6) Index signal DK1(P7) Track 0 signal Table 6-3 M7745 Connectors #### H771 Power Supply Regulator, 70-10718 - With the power off, remove the plug from the regulator. - 2. Unscrew the leads going to the capacitors. Check the H771 prints to ensure that the wiring matches the prints. - 3. Remove the plugs from the M7745 and M7744. - 4. Remove the six screws holding the regulator to the power supply chassis. - 5. Replace the regulator by performing steps 1-4 in reverse. ## 6.5.2 Drive Replacement Procedure - 1. With power removed, remove the plenum and power plug from the rear of the drive (Figure 6-1). - 2. Raise the M7744 module to the service position. - 3. Remove the plugs for this drive (Table 6-3). - 4. Loosen the six screws securing the drive to the chassis. - 5. While holding the drive, remove the screws from the four corners. - 6. Carefully remove the remaining screws without allowing the drive to drop down. - 7. Slowly lower the drive, guiding the wiring as the drive is lowered. - 8. To install a drive, place the two center screws in the holes in the chassis. - 9. Raise the drive, guiding the wiring through the hole. - 10. With the drive centered, start the two screws carefully so as not to cross-thread them. Do not tighten these screws all the way. - 11. Start the remaining screws, being careful not to cross-thread them. - 12. Tighten all screws including the screws for the plenum. - 13. Insert the plugs listed in Table 6-3. - 14. Insert the power plug. - 15. Secure the M7744 module. ## 6.5.3 Front Handle Replacement Procedure - 1. Remove the drive carefully as described in Paragraph 6.5.2. - 2. While holding the cone, lift the cover into place and remove the two screws securing the handle to the cover. - 3. Remove the handle by pulling it through the openings in the bezel. - 4. Replace the handle but do not tighten the screws all the way. - 5. Adjust the handle so that the handle adapters do not interfere with the bezel. Latch the handle properly. - 6. Tighten the screws. - 7. Recheck for interference and replace the drive. #### 6.5.4 Drive Motor Replacement Procedures - 1. Remove the drive as described in Paragraph 6.4.2. - Remove the bottom cover. - Disconnect the motor wires. - 4. Remove the drive belt. - 5. Remove the pulley from the motor shaft. - 6. Remove the nuts securing the motor to the chassis and remove the motor. - 7. Insert the new motor and secure it loosely in place. - 8. Replace the pulley on the new motor shaft. - 9. Adjust the height of the motor pulley until the two pulleys are in line. (Pulley may be adjusted by placing a straight edge such as a scale between the two pulleys.) - 10. Place the DEC tool (part #9306353-3 for 50 Hz motor or 9306353-2 for 60 Hz motor) between the spindle pulley and motor pulley to measure the correct distance between both pulleys and then secure the motor in place (Figure 6-2). - 11. Place the drive belt on the pulleys. - 12. Replace the drive bottom cover and then reinstall the drive. Figure 6-2 Drive Motor Positioning Diagram # 6.5.5 Drive Belt Replacement Procedures - Discard the old belt. - 2. Clean the pulleys and motor shaft with freon, 90% alcohol, or a suitable non-oil base solvent. - 3. Loosen the drive motor nuts. - 4. Place the belt spacer tool (9306353-2 for 60 Hz motor, or 9306353-3 for 50 Hz motor) between the pulleys (motor and spindle) and move the motor so that the tool is snug (Figure 6-2). - 5. Tighten the motor nuts to secure the motor. - 6. First loop the belt over the motor pulley; then loop the belt over the spindle pulley. - 7. The belt will now be mounted with the correct tension. #### NOTE The belt used is made of nylon, not rubber, and it will not exert more tension if it is stretched beyond the diameter set by the tool. If the belt is stretched beyond the distance set by the belt spacer tool, it will be damaged because of the belt construction. # 6.5.6 Quick Check For Belt on Pulleys The RX02 belt is easily checked by sliding it forward on slides and viewing the belt path through the opening between the sheet metal chassis and the bottom cover. # APPENDIX A RX02 SUMMARY | Interface | Density | Computer | | | |-------------|------------------|-------------------|--|--| | RX8E-M8357 | Single | PDP-8 - Prog I/O | | | | RX28-M8357 | Single or double | PDP-8 - Prog I/O | | | | RX11-M7846 | Single | PDP-11 - Prog I/O | | | | RX211-M8256 | Single or double | PDP-11 - DMA | | | | RXV11-M7946 | Single | LSI-11 – Prog I/O | | | | RXV21-M8029 | Single or double | LSI-11 – DMA | | | (Address for RX2C5 = 177170, for RX2E5 = 177172) # Controller M7744 # Interface RX8E/RX11/RXV11 RX211/RXV21 RX28 # **Switch Settings** | OFF<br>ON | | |-----------|-------------| | OFF | | | ON | <b>→</b> —I | | | ON<br>OFF | -Illegal settings # Read/Write Electronics M7745 Power supply H771A: 115 V/60 Hz, H771C: 115 V/50 Hz, H771D: 230 V/50 Hz Left Drive = Drive 0 Right Drive = Drive 1 Single Drive 60 Hz = RX02-CA Single Drive 50 Hz = RX02-CC Track Address: 0-114<sub>8</sub> (0-76) Sector Address: 1-32<sub>8</sub> (1-26) #### RX2CS #### RX28 RX2ES #### RXII/RXVII RXES #### RX211/RXV21 RX2ES MA-2051 # Temperature RX02 nonoperating: -35° to +60° C (-30° to +140° F) 15° to 32° C (50° to 90° F) operating: media nonoperating: -35° to 52° C (-30° to 125° F) Relative Humidity RX02 25° C (77° F) max wet bulb operating: 2° C (36° F) min dew point 20% to 80% rel humidity 5% to 98% rel humidity (no condensation) nonoperating: media 10% to 80% rel humidity nonoperating: Electrical AC power input 4 A at 115 Vac 2 A at 230 Vac RX02 5 A @ +5 Vdc, 25 W; 0.14 A @ -5 Vdc, 0.7 W; 1.3 A @ +24 Vdc, 31 W Interface module M7946, M8029 1.8 A@ +5 Vdc M7846, M8256 1.8 A @ +5 Vdc M8357 1.5 A @ +5 Vdc Figure A-1 RX02 System Interconnection Diagram (Sheet 2 of 2) | | Fold Here | | |--------------------------|-----------------------------------------------------------------|---------------------------------| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | — Do Not Tear - Fold Here and Staple — - | | | | | | | | | FIRST CLASS | | | | PERMIT NO. 33<br>MAYNARD, MASS. | | BUSINESS REPLY MAIL | | | | | SARY IF MAILED IN THE UNITED STATES | | | Postage will be paid by: | | | | | | | | | | | | | Digital Equipment Corporation | | | | Technical Documentation Department Maynard, Massachusetts 01754 | | . # RX02 FLOPPY DISK SYSTEM TECHNICAL MANUAL EK-0RX02-TM-001 Your comments and suggestions will help us in our continuous effort to improve the quality and usefulness of our publications. | written, etc.? Is it easy to use? | nanual? In your judgment is it complete, accurate, well organized, well | |-----------------------------------------------------------------------|-------------------------------------------------------------------------| | | | | | | | What faults or errors have you found it | in the manual? | | | | | Does this manual satisfy the need you | think it was intended to satisfy? | | | Why? | | | the Technical Documentation Catalog, which contains information on | | Name | Street | | | City | | | State/Country | | | Zip | | Additional copies of this document are Digital Equipment Corporation | available from: | | 444 Whitney Street<br>Northboro, Ma 01532 | | Order No. EK-0RX02-TM-001 Attention: Communications Services (NR2/M15) Customer Services Section