# MXV22 DISK CONTROLLER REFERENCE MANUAL ## MXV22 DISK CONTROLLER REFERENCE MANUAL 810010-102 Rev. A June 1984 ### DISCLAIMER OF WARRANTIES Copyright 1989 - 1990 Micro Technology. All rights reserved. No part of this publication may be reproduced, transmitted, transcribed, stored in a retrieval system, or translated into any language or computer language, in any form or by any means; electronic, mechanical, optical, manual or otherwise; without the prior written permission of Micro Technology, 5065 East Hunter Avenue, Anaheim, California 92807. The information in this document is subject to change without notice and should not be construed as a commitment by Micro Technology. Micro Technology assumes no responsibility for any errors that may appear in this document. The software, if any, described in this document is furnished under a license and may be used or copied only in accordance with the terms of such license. No responsibility is assumed for the use or reliability of software or equipment that is not supplied by Micro Technology. Micro Technology reserves the right to revise this publication and make changes to any products described herein for the purpose of product improvement at any time, without obligation by Micro Technology to notify any person of such revision or changes. Printed in the U.S.A. ### **Preface** The purpose of this manual is to provide the user adequate information to configure and operate the MXV22 floppy disk controller. The information provided should clarify the controller connection to any Shugart compatible drive and assist in the selection of associated interface options. Both register definition and command protocol are provided for reference and as an aid in development of user software. Operational procedures outline the use of the controller features as well as explaining operation in an RT-11 or RSX11M software environment. ### Contents | Pf | aGI | |--------------------------------------------------------|----------| | SECTION 1 GENERAL INFORMATION | | | | | | 1. INTRODUCTION | . 1 | | 1.2. COMPATIBILITY | â | | | ã | | 1.2.1. Logical Track Format | 3 | | 1.2.2. Sector Header Field | 4 | | 41 E O O Dava Field | | | | | | TICEON DOUBLE LINGUIGNED (PM) | _ | | | | | ** C: (* CyClic Redundancy Lnacy . | _ | | 1.3. SPECIFICATIONS | 8 | | | | | SECTION 2 INSTALLATION | _ | | | 9 | | 2. GENERAL | _ | | E.I. CONFIGURATION | _ | | Silil Muuress Vector Selection | _ | | 2.1.2. Device Interrupt Priority | 9 | | | 10 | | | | | 2.1.5. Step Rate Control | 12 | | 2.1.5. Step Rate Control | 13 | | 2.1.6. 22 Bit Addressing . | 14 | | 2.1.7. Miscellaneous Options | 14 | | 2.2. DRIVE CONFIGURATION | 15 | | 2.2.1 Drive Selection Signals | 20 | | 2.2.2. Head Load Signal | 20 | | 2.2.3. Motor Control | 20 | | | 21 | | CONTROLLER INSTRLLATION | 22 | | | 23 | | | | | SECTION 3 FUNCTIONAL DESCRIPTION | | | | | | 3. GENERAL | | | Sili KEGISIEK DEFINITIONS | _ | | 3.1.1. MAYUS ~ Command and Status Register (177170/0)) | - | | 3.1.2. MXVDB - Data Buffer (177172(8)) | <b>3</b> | | 3.1.3. Extended Status Register | | | 3.2.1. | ND PROTOCOL Fill Buffer Empty Buffe | ~ (000) . | | | | | | | | | | | | 79 | |----------------------|-------------------------------------------|-----------------------|-------|----------|------|-----|------|---|-----|------|-----|-----|---------|----------| | 3. 2. 3.<br>3. 2. 4. | Read Sector | or (010)<br>· (011) . | • • | • • | • • | • | • • | | • • | • | • • | • | • • | 34 | | 3. 2. 5.<br>3. 2. 6. | Set Media I<br>Read Status<br>Write Delet | Density<br>: (101) . | (100) | • • | • • | • • | • • | • | | • | • • | • | • • | 3£ | | 3.2.8. | Read Error | Code (1: | Sect | or ( | | • • | • • | • | • • | • | | • | : : | 37<br>37 | | SECTION 4 | | | | | | | | | | | | | | | | 4. GENER | AL<br>TRAPPING THE | CONTROL | | | | | | | | • | | • | | 39 | | 4.1. 50015 | Bootstrap C | nevation | LEK | • • | • • | • • | • • | • | • • | • | • • | ٠ | • • | 39 | | 4.2. FORMO | T OPERATIONS | ;<br>he.gr.to. | 1 | • • | • • | • • | • • | • | • • | • | • • | • | • • | 40 | | 4.3. FULL | WRITE OPERAT | TONG | • • | • • | • • | • • | • • | • | • • | • | • | • | • • | 460 | | 4.4. READ/ | EMPTY OPERAT | TONS | • • | • • | • • | • • | • • | • | • • | • • | • | 4 | • • | 4c | | 4.5. WRITE | CURRENT CON | ITROI | • • | • • | • • | • • | • • | • | • • | • • | • | 0 | | 43<br>44 | | 4.6. WRITE | PRECOMPENSA | TION | • • | | • • | | • • | • | • • | | • | • | • • | 44 | | 4.7. POWER | FAIL PROTEC | TION | | | | | : : | • | : : | | • | 11 | • • | 45 | | SECTION 5 | SOFTWARE CO | NSIDERAT | IONS | | | | | • | | | | | | 47 | | 5. GENERA | AL | | | | | | | | | | | | | 47 | | 5.1. OPERAT | TION USING R | T-11 | | | | | | | | | • | | | 47 | | 5.1.1. | Modifying R | X02 Driv | er f | or R | T11 | | | | | | • | | | 48 | | 5.1.2. | Creating a | DY-Compa | tible | e Sy | stem | Di⊊ | k or | a | DX- | base | ed | Sys | stem | 48 | | 5.2. OPERAT | TION WITH LA | YERED PR | ODUC. | TS . | | | | | | | | | | 49 | | 5.3. OPERAT | TION WITH RS | X11M | | | | | | • | | | | | | 49 | | 5.3.1. | Modifying R | X02 Driv | er R | 5X 1 1 I | ч. | | | • | | | • | | | 50 | | 5.4. DOUBLE | SIDED OPER | ATION RT | -11/ | RSX- | LIM. | • | | • | | • • | • | | | 50 | | 5.5. OPERAT | TON WITH OT | HER DEC | SOFT | NARE | | | | • | | | • | • | | 50 | | 5.6. OPERAT | ION WITH DE | C DIAGNO | STIC | • • | • • | • • | | • | | | • | • | | 50 | | 5.6.1. | Exceptions | | • • | • • | • • | • • | | • | • • | | • | • | • • | 50 | | | | | | | | | | | Α | pr | )e | n | di | x | | | | | | | | | | | | PP | | | <b></b> | | | | | | | | | | | | | | | | | | | APPENDIX A | | • • • • | | • • | | • • | | • | • • | • • | • | • | • • | 51 | | APPENDIX B | | | | • • | • • | | | • | | | • | • | • • | 53 | | | | | | | | | | | | | | | | | | APPENDIX | D | • | • | • | • | • | • | • | • | • | • | • | • | • | • | • | • | • | • | • | • | • | • | • | • | • | • | • | • | • | 57 | |----------|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|----| | APPENDIX | E | | • | • | • | • | • | • | • | • | • | • | • | • | • | | • | • | • | • | • | • | • | • | • | • | • | • | • | • | 59 | | APPENDIX | F | | | _ | | | | | | | | | | | | | | | | | | | | | | | | | | | ٠, | nga ) ## Section 1 General Information ### 1. INTRODUCTION The MXV22 is a dual density controller compatible with the DEC\* RXO2 floppy disk system. The MXV22 emulates two separate RXV21 controllers, each of which controls two 8-inch floppy disk drives. When configured with any Shugart compatible drive, it is a direct replacement for two complete RXO2 subsystems. The controller provides either single density encoding compatible with IBM 3740 equipment or double density encoding providing up to 1 Mbyte of storage on a single diskette. All electronics are contained on one dual-height board which plugs directly into any standard LSI-11 backplane and interfaces through a 50 conductor ribbon cable with up to four (4) Shugart compatible drives. All controllers are 100% tested and ready for operation. The primary controller registers are configured for the standard device address 177170(8) and interrupt vector 264(8). The secondary controller registers are configured with a device address of 177174(8) and interrupt vector 270(8). Interrupt level is factory set to level four. Features include: ### .22 bit addressing - .Transparent firmware bootstrap automatically loads either single or double density diskettes. - . Formatting capabilities permit writing sector headers, checking the written headers, and writing the data fields in the user selected density. - .Jumper selectable four-level device interrupt priority compatible with the LSI-11/23. - . Provides power fail protection for data integrity. - .Write current control signal for tracks greater than forty-three. - . Write precompensation for reduced error rates. - \*DEC, PDP-11, LSI-11, RSX, Unibus & Q bus are registered trademarks of Digital Equipment Corporation. ### 1.1. COMPONENTS The controller is provided with the following components: P/N 81010-07-2 Floppy disk controller H 81010-02-2 HXV22 disk controller manual ### 1.2. COMPATIBILITY This section discusses the aspects of hardware, software and media compatibility with Digital Equipment's RXO2 system. The information will aid the user in data interchanging with foreign systems. ### Hardvare The controller is compatible with the LSI-11, LSI-11/2 and LSI-11/23 processors. All circuitry is contained on one dual-wide board that plugs directly into any standard LSI-11 backplane. Alternate address selection and a four-level device interrupt priority scheme provide the user added flexibility for expanded system configurations. Shugart compatible drive logic is interfaced through a 50-pin ribbon cable. The connector pins are compatible with both the 800 and 850 series drives. ### Software The MXV22 is completely compatible with RXV21 register definition and command protocol. All DEC-supplied software designed to operate with the RX02 system will operate with the controller. ### Media The media used with the MXV22 are compatible with the IBM 3740 family of equipment. Either preformatted or blank soft sectored diskettes may be used with the controller. The following list summarizes the suggested media. IBM Single or Double Density DEC RX01/RX02 ### 1.2.1. 8 Inch Logical Track Format The diskette surface is divided into 77 concentric tracks numbered 0-76. Each track consists of 26 sectors numbered 1-26. The track begins and ends at the index address mark. The track is formatted in such a way that this "soft" index is preceded by the leading edge of the physical index hole in the diskette. Following the physical index are 40 bytes of "FF" data, 6 bytes of "0" data, and the index address mark indicating the beginning of the track. Following the index address mark is the post index gap consisting of 26 bytes of "FF" data and 6 bytes of "0" data. The next field is the sector header for sector 1. Following the data field is the data gap consisting of 28 bytes of "FF" data and 6 bytes of "0" data. This field leads to the next sector header. Following the 26th data record is the pre-index gap consisting of approximately 274 bytes of "FF" data. Each track is formatted in the above manner. Refer to Figure 1-1. The sector header field of each sector contains information describing the sector number, track number, and diskette side. All the above fields are recorded in FM except as noted in the following sections. Figure 1-1: 8-Inch Logical Track Format ### 1.2.2. Sector Header Field The header field consists of 7 bytes of information. Preceding the header is a field of 6 bytes of "zero" data for synchronization. The header and this preamble are always recorded in FM. - Byte 1. ID Address Mark A unique mark consisting of 1 byte of FE (hex) data with three missing clock-transitions using a C7 (hex) clock pattern. This mark is decoded by the controller and indicates the start of the sector header. - 2. Byte 2. Track Address This byte indicates the absolute (0-114(8)) track address. Each sector contains this track information to locate its position on one of the 77 tracks. - 3. Byte 3. Side This byte indicates the diskette side (0 or 1). - 4. Byte 4. Sector Address This byte indicates the absolute (1-32(8)) sector address. Each sector contains this information to identify its position on the track. - 5. Byte 5. "Zero" - 6. Byte 6, 7. CRC This is the 16 bit cyclic redundancy character and is calculated for each header from the first 5 bytes of information, using the IBM 3740 polynomial. (Refer to Cyclic Redundancy Check, Section 1.2.7.). ### 1.2.3. Data Field The data field consists of either 131(10) or 259(10) bytes of information depending upon the recording method. Preceding the data field is a field of 6 bytes of "zero" data for synchronization. The preamble and data address mark are always written in FM. The user data and CRC character are either written in FM or MFM modified depending upon the formatted diskette density. 1. Byte 1. Data Address Mark - A unique mark consisting of a data byte (see Table 1-1) with three missing clock transitions using a C7 (hex) clock pattern. This byte is always written in FM and is decoded by the controller to indicate the start of the data field, its recording method (FM vs MFM), and if the field is a deleted data field. | I ADDRESS<br>I MARK | - | INDICATED DENSITY | | DATA | <br> <br> | CLOCK | |---------------------|---|-------------------|---|------|-----------|-----------| | INDEX | 1 | NA | 1 | FC | I | D7 | | i ID | 1 | NA NA | 1 | FE | 1 | C7 | | | | FM | ı | FB | 1 | <b>C7</b> | | I DATA | 1 | Modified | 1 | FD | 1 | <b>C7</b> | | DELETED | | FN | 1 | F8 | ı | <b>C7</b> | | I DATA | | Modified | 1 | F9 | 1 | C7 | Table 1-1: Address Marks - Bytes 2-129 (FM) or Bytes 2-257 (MFM Modified). User Data. This field is recorded in either FM or MFM modified. Depending upon the encoding scheme, either 128 or 256 bytes of information can be stored. - 3. Bytes 130-131 or 258-259. CRC This is the 16 bit cyclic redundancy character and is calculated for each data field from the first 129 or 257 bytes of information using the IBM 3740 polynomial. (Refer to Cyclic Redundancy Check, Section 1.2.7.). These bytes are recorded with the same encoding scheme as the data field. ### 1.2.4. Recording Scheme Two recording schemes are used by the MXV22: double frequency (FM) and DEC modified Hiller code (MFM). FM is used for single density recording and is compatible with IBM 3740 or DEC RX01 media. DEC modified MFM is used for recording double density and is only compatible with the DEC RX02 system. ### 1.2.5. <u>Double Frequency (FM)</u> FM recording is characterized by a flux transition at the beginning of each bit cell which is commonly termed a clock pulse or transition as shown in Figure 1-2. A logic "one" is represented by a flux transition within the bit cell; a logic "zero" is represented by the lack of any flux transition within a bit cell. In FM the bit cell time is 4us. Figure 1-2: FM Recording Characteristics ### 1.2.6. DEC Modified MFM MFM recording consists of flux transitions for a logic "one" and no flux transitions for a logic "zero". A clock transition only occurs between two consecutive logic "zeros" as shown in Figure 1-3 below. The MFM bit cell time is 2us. Figure 1-3: MFH Recording Characteristics Table 1-2 summarizes the standard MFM encoding algorithm. | <b> </b> | DA | TA | l | - E | NCODED D | ATA | <br> <br> | |---------------|------|----|---|------|----------|-----|-----------| | —<br> <br> _ | DN-1 | DN | l | DN-1 | CN | DN | <br> <br> | | _ | 0 | 0 | 1 | 0 | 1 | 0 | ,<br> | | | 1 | 0 | 1 | 1 | 0 | 0 | ı | | | 0 | 1 | ı | 0 | 0 | 1 | . 1 | | | 1 | 1 | 1 | 1 | 0 | 1 | 1 | Table 1-2: Standard MFM Encoding Because single density headers are used for both FM and MFM recording formats, and since certain MFM patterns map into single density address marks, a modified algorithm is used. The mapping occurs when a data pattern of exactly four consecutive "ones" is encoded. Whenever this pattern is encoded a special algorithm is applied. Table 1-3 defines the encoding algorithm for this special case. | | | | | | | | | DAT | A | | | | | | | | |-----------|--------------------|---|------|----|---|-----|---------|-----------|-----------|----------|----------|----------|----------|----------|---------|-----------------| | DN- | -5 | 1 | DN-4 | l. | 1 | DN | _ | • | DN | _ | • | DN- | -1 | 1 | I | N | | ( | ) | 1 | 1 | | 1 | | 1 | 1 | | 1 | ١ | | - | - | | • | | X<br>CN-5 | 0<br>D <b>N</b> -5 | I | _ | _ | | N-3 | O<br>DN | ا<br>310- | 1<br>CN-2 | O<br>DN- | <br>-2 C | 0<br>N-1 | O<br>DN- | 1<br>-11 | 1<br>CN | O<br>D <b>n</b> | | | | | | | | | | | DAT | | | | | | | | Table 1-3: Modifying Algorithm (Special Case) When reading double density data fields the controller checks for a missing clock bit between two zero data cells, and if found, substitutes ones for the two zero data bits (generated by the special encoding algorithm). ### 1.2.7. Cyclic Redundancy Check Each sector header field and data field has two CRC characters appended. These 16 bits are the remainder that results when dividing the data bits [represented as a polynomial M(x)] by a generator polynomial G(x). The polynomial used for IBM 3740 is $G(x) = X^16 + X^12 + X^5 + 1$ . For the sector header the data bits include byte 1 thru 5. For an FM data field the data bits include byte 1 thru byte 129. For an MFM data field the data bits include byte 1 thru byte 257. ### 1.3. SPECIFICATIONS ### RECORDING TECHNIQUE: Single Density IBM 3740 FM Double Density DEC Modified MFM ### POWER REQUIREMENTS: Voltage Single 5V supply (from LSI-11 backplane) Current 2.5A typical ### ENVIRONMENTAL Temperature Humidity 0 degree - 45 degrees C 10% - 95% non-condensing ### Section 2 Installation ### 2. GENERAL The controller is shipped with standard options configured. The standard address 177170(8) and vector 264(8) are set. The device interrupt priority is set to level four. The firmware bootstrap is disabled. Most options are factory foil-etched to the most often used configuration. The foil jumpers must first be cut before the alternate jumpers are inserted. Refer to Tables 2-1, 2-2, and 2-3 for alternate options and Figure 2-1 for jumper location. Several of the options are selectable by using AMP 530153-2 pin jumpers. If these pin jumpers are not available use \$30 wire wrap. ### 2.1. CONFIGURATION ### 2.1.1. Address Vector Selection The controller is shipped with the DEC standard device address and vector assignments preset to 177170(8) and 264(8), respectively. Any change in these assignments would necessitate a change in system software. However, a dual address and vector option is selectable nabling a second register assignment at 177174(8) and 270(8), respectively. The dual address mode is used in applications requiring more than two drives. In this case the controller simulates the operation of two controllers as required by standard DEC software. To select this option remove the jumper between W16 and W17. Jumper W15 to W16 and jumper W7 to W8 as shown in Table 2-1. | OPTION | JUMPERS | | | | | | | | | | | | | |----------------------------------------------------|-----------------|---------|-----|--|--|--|--|--|--|--|--|--|--| | or rion | 1 15-16 | 16-17 | 7-8 | | | | | | | | | | | | Standard<br>Address/Vector#<br>177170/264 | I<br>I OUT<br>I | | OUT | | | | | | | | | | | | Dual<br>Address/Vector<br>177170/264<br>177174/270 | <br> IN<br> | ! OUT ! | IN | | | | | | | | | | | | *Factory Preset | | | | | | | | | | | | | | Table 2-1: Address/Vector Option Configuration ### 2.1.2. Device Interrupt Priority The MXV22 supports the four-level device interrupt priority scheme compatible with the LSI-11/23. The controller asserts interrupt requests and monitors higher level request lines during interrupt arbitration as described in Table 2-2. The level four request is always asserted by the controller, regardless of its priority, to maintain compatibility with the LSI-11 and LSI-11/2 processors. The interrupt priority level is configured to level four at the factory. If a different interrupt level is desired the following foil-etched jumpers must be cut. Refer to Table 2-2 for the proper jumpers to insert for the desired priority level. W19 - W20 W28 - W29 W22 - W23 W30 - W31 W24 - W25 | IMON | 1_ | | | | | | | | | JUMP | ER | 5 | | | | | | | | | |------|------------------|----------------------|-----|-------|-----|-------|-----|------|-----|------|-----|-------|-----|-------|-----|-------|-----|-------|-----|---------| | I | 11 | 18-19 | 71. | 19-20 | ) ; | 21-22 | 21: | 22-2 | 31: | 24-2 | 51: | 25-26 | 51: | 27-28 | 312 | 28-29 | 91: | 30-3: | 11: | 31-32 | | 15,6 | I | Out | 1 | In | 1 | Out | 1 | In | 1 | In | i | Out | 1 | Out | 1 | In | 1 | In | 1 | Out | | 16 | ı | Out | ı | In | ł | In | 1 | Out | 1 | In | 1 | Out | 1 | Out | 1 | In | 1 | Out | 1 | In | | 17 | 1 | In | ı | Out | ı | Out | 1 | In | 1 | Out | ı | In | ١ | In | 1 | Out | ī | In | 1 | Out | | None | H | In | 1 | Out | ì | In | 1 | Out | 1 | Out | 1 | In | 1 | In | 1 | Out | 1 | Out | 1 | In | | | 15,6<br>16<br>17 | 15,6 <br>16 <br>17 | | | | | | | | | | | | | | | | | | JUMPERS | Table 2-2: Priority Level Configuration Figure 2-1: Configuration Jumper Locations ### 2.1.3. Bootstrap The controller board incorporates a transparent firmware bootstrap. The bootstrap is initiated whenever program execution is started at location 173000(8) homing all drives to track 0. Next, track 1, sector 1, of unit 0 is read and diskette density is determined. If the diskette is single density, sectors 1, 3, 5, and 7 are loaded into memory starting at location 0. If the diskette is double density, sectors 1 and 3 are loaded. Program execution is then transferred to location 0. Controllers are shipped with this feature disabled. To enable the bootstrap remove the jumper between W42 and W43 and insert the jumper between W41 and W42 as shown in Table 2-3. ### HOTE Only one bootstrap should be enabled in a system for proper operation. If another bootstrap exists in the system, it must be disabled before enabling the controller bootstrap. | BOOTSTRAP | | JMPERS | | | |-----------------|---|--------|---|-------| | DOCISIRAF | 1 | 41-42 | l | 42-43 | | ENABLED | l | IN | l | OUT | | DISABLED * | ı | OUT | I | IN | | *Factory Preset | | | | , | Table 2-3: Bootstrap Option ### 2.1.4. Write Precompensation The MXV22 controller provides hardware write precompensation to reduce the bit shift exhibited by all drives as the recorded flux density increases. The controller recognizes the patterns which produce bit shift and precompensates the written pattern. This unique feature allows the controller to perform reliably with any Shugart compatible drive. Controllers are shipped with this feature enabled and it is recommended that for more reliable operation the feature not be disabled. However, if so desired, the feature can be defeated by cutting the foil-etched jumper between W12 and W13 and inserting a jumper between W13 and W14 as shown in Table 2-4. | WRITE | 1 | Jl | JMPERS | <b></b> | |-----------------|---|-------|--------|---------| | PRECOMPENSATION | i | 12-13 | ı | 13-14 | | ENABLED* | 1 | IN | ı | OUT | | DISABLED | 1 | OUT | | IN | Table 2-4: Write Precompensation ### 2.1.5. Step Rate Control Up to four drives can be interfaced with the MXV22 controller. These drives are organized into two pairs, each of which is associated with a particular register set. The first pair of drives (DS1/DS2) is associated with the primary register set (177170(8)) and the remaining pair (DS3/DS4) with the secondary register set (177174(8)). The controller is shipped configured with a 6ms step rate for both pair of drives. Alternate step rates can be selected for each pair of drives. Refer to Table 2-5 for desired step rate option and associated jumpers. | STEP | RAT | E ! | JU | JUMPERS | | | | | | | | |---------|-----|---------|-------|---------|-------|--|--|--|--|--|--| | DS1/DS2 | 1 | DS3/DS4 | 36-37 | 1 | 38-39 | | | | | | | | 6* | ı | 6* i | IN | | IN | | | | | | | | 3 | | 6 1 | OUT | 1 | IN | | | | | | | | 6 | 1 | 3 | IN | | OUT | | | | | | | | 3 | 1 | 3 | OUT | <br> | OUT | | | | | | | Table 2-5: Step Rate ### 2.1.6. 22 Bit Addressing The controller is shipped with 22 bit addressing disabled. Enabling this option provides extended address control during DMA transactions allowing the controller to transfer information throughout 22 bit address space. The additional four bits of address (A(18)-A(21)) are communicated to the controller as described in section 3.1.2. Before enabling this option it is necessary to modify the corresponding software drivers in order to maintain proper register communication as described in section 5. To enable 22-bit addressing jumper W46 and W47 as shown in Table 2-6. | <br> 22 BIT | JUMPERS | |-----------------|---------| | ADDRESSING | 46-47 | | ENABLED | IN | | DISABLED # | OUT | | *Factory Preset | | Table 2-6: 22 Bit Addressing ### 2.1.7. Miscellaneous Options There are several options related to factory configuration of the controller. These options must be configured as shown for proper operation of the controller. Refer to Table 2-7 for these options. During DMA operations if the bus address established extends into the peripheral address page the controller asserts bank select 7 (BS7) as required by normal bus protocol. If the application requires extended memory, overlapping the peripheral address page, this option can be disabled as indicated in Table 2-7. | 1 | | | | | | J | UMPER | S | | | | | | |---|-----------|-------|-----|----------|----------|----------------|-----------------------------------|-----|---------------------|-----|-----|-----|-----| | i | 1-2 | | 2-3 | | | | | | 33-34 | | | | | | 1 | OUT | 1 | IN | 1 | OUT | 1 | IN | į | | 1 | IN | 1 | - | | 1 | - | 1 | | 1 | - | 1 | - | ı | - | ١ | - | ı | IN | | 1 | - | 1 | | | | | | | | | | 1 | OUT | | | <br> <br> | I OUT | OUT | OUT IN | OUT IN | OUT IN OUT | 1-2 2-3 4-5 OUT OUT | 1-2 | OUT IN OUT IN | 1-2 | 1-2 | 1-2 | 1-2 | Table 2-7: Miscellaneous Options ### 2.2. DRIVE CONFIGURATION The controller provides an industry standard floppy interface compatible with most available drives. However, for proper operation, each drive must be configured with attention to several options. Tables 2-8 thru 2-12 summarize these options for several of the more popular drives. | | | - | DUAL | SINGLE | |----------|----------------------------|-------|-----------|---------| | OPTION | DESCRIPTION | DRIVE | O DRIVE 1 | DRIVE ( | | | Drive select 1 | IN | OUT | IN | | DS2 I | Drive select 2 | I OUT | IN | OUT | | DS3 I | Drive select 3 | OUT | OUT | OUT | | DS4 I | Drive select 4 | I OUT | OUT | OUT | | A I | Radial head loading option | I IN | IN | IN | | B i | Radial head loading option | IN | IN | IN | | C I | Head load option | I | IN | IN | | D I | In use option | I OUT | OUT | OUT | | X i | Radial head loading option | I OUT | OUT | OUT | | WP I | Inhibit write when protect | IN | IN | IN | | NP i | Allow write when protect | I OUT | OUT | OUT | | DS I | Stepper power from drive | I IN | IN | IN | | 1 | select | 1 | | | | HL I | Stepper power from head | I OUT | OUT | OUT | | I | load | 1 | | | | 2S* | Two sided status output | I IN | IN | IN | | ZI | In use from drive select | I OUT | OUT | OUT | | Y I | In use from head load | I IN | IN | IN | | R I | Ready output | IIN | IN | IN | | I I | Index output | IN | IN | IN | | DC I | Disk change output | i X | X | X | | S I | Sector output | I X | X | X | | 800/8501 | Sector option disable | IN | IN | IN | | | Sector option enable | I OUT | OUT | OUT | | L I | -5V DC bias | IN | IN | IN | | T1 | Termination HL | I OUT | IN | IN | | T2 | Termination drive select | IN | IN | IN | | T3 I | Termination direction | I OUT | IN | IN | | T4 | Termination step | OUT | IN | IN | | T5 ! | Termination write data | I OUT | IN | IN | | . T6 I | Termination write gate | OUT | IN | IN | | | | | | | | * Shug | art 850 series drives only | | | | Table 2-8: Shugart 801/851 Drive Configuration | U9 SI SE TR RTR 2S DC S1 | Terminations for multiplexed<br> inputs<br> Internal write current switch<br> External write current switch<br> True ready output | i<br>I X | OUT | DRIVE ( | |-----------------------------------|-----------------------------------------------------------------------------------------------------------------------------------|----------|------------|---------| | SI<br>SE<br>TR<br>RTR<br>2S<br>DC | Internal write current switch External write current switch True ready output | f<br>I X | | IN | | SE<br>TR<br>RTR<br>2S<br>DC | Internal write current switch External write current switch True ready output | | | | | TR<br>RTR<br>2S<br>DC | External write current switch True ready output | | 40 | | | RTR<br>2S<br>DC | True ready output | | X<br>X | X | | 2S<br>DC | | IN | IN | X<br>In | | DC | Radial true ready ** | IN | IN | IN | | | Two-sided status output# | IN | IN | IN | | Si | Disk change option | OUT | OUT | DUT | | | Side select option using | OUT | OUT | OUT | | | direction select * | | • | 50. | | <b>S</b> 2 | Side select input # | IN | IN | IN | | S3 | | OUT | OUT | OUT | | | idrive select | 1 | | 150. | | B, 2B, 3B, 4E | | OUT | OUT | OUT | | | drive melect | · . | J <b>.</b> | | | D | Alternate input-in-use | OUT | OUT | OUT | | MS | Motor on from drive select | IN | IN | IN | | MO | Alternate input-motor-on | OUT | OUT | OUT | | NMO | Alternate input-multiplexed | OUT | OUT | OUT | | | Imotor on ** | | | | | MD | Motor off delay | IN | IN | IN | | R | Ready output | IN | IN | X.N | | RR | Radial ready | IN | IN | IN | | SR | IStandard ready ** | IN | IN | 1.N | | MT | Modified true ready (outputs | OUT | OUT | OUT | | | Itrue ready on pin 22)** | | | | | DS1 | Drive select 1 | IN | OUT | IN | | | Drive select 2 | OUT | IN | OUT | | DS3 | Drive select 3 | OUT | OUT | CUT | | DS4 | Drive select 4 | OUT | OUT | OUT | | Y | Door lock/activity light | IN | IN | IN | | _ | lactivated from motor on ** | | | | | Z | Door lock/activity light | OUT | OUT | OUT | | | lactivated from drive select**! | | | | | PD | Stepper power down | OUT | OUT | OUT | | WP | Inhibit write when write | IN | IN | IN | | ND | Iprotected | | | | | | Allow write when write | OUT | OUT | OUT | | | Iprotected | | | | | TS | Data separation option select! | OUT | OUT | OUT | Table 2-9: Shugart 810/860 Drive Configuration | | l DEGERATOR | | DUAL | SINGLE | |-------------------|-------------------------------|-------|-----------|---------| | OPTION | DESCRIPTION | DKIVE | O DRIVE 1 | DRIVE O | | DS1 | Drive select 1 | I IN | OUT | IN | | 1 DS2 | Drive select 2 | OUT | IN | OUT | | DS3 | Drive select 3 | OUT | OUT | OUT | | DS4 | Drive select 4 | OUT | OUT | OUT | | ! A, B | Radial head load | IN | IN | IN | | 1 X | Radial head load | OUT | OUT | OUT | | i Z | In use from drive select | OUT | OUT | OUT | | ! HL | Stepper power from head load | OUT | OUT | OUT | | l R | iAlternate output ready pad | IN | IN | IN | | iI | Alternate output index pad | IN | IN | IN | | i C | Alternate input head load | IN | IN | IN | | i D | Alternate input-in-use | I OUT | OUT | OUT | | I DC | Alternate output disk change | OUT | OUT | OUT | | 1 2S | Alternate output 2-sided disk | IN | IN | IN | | I DS | Stepper power from drive | I | | | | i | select | I | | | | I Y | In use from head load | I IN | IN | IN | | I DL | Door lock latch | OUT | OUT | OUT | | RR | Radial ready | IN | IN | IN | | I RI | Radial index | IN | IN | IN | | I WP | Inhibit write when write | IIN | IN | IN | | 1 | Iprotect | l | | | | NP NP | Allow write when write | I OUT | OUT | OUT | | l | Iprotect | I | | | | 1D1, D2, D4, DDS | Drive address select | OUT | OUT | OUT | | B1-B4 | Two-sided drive select | OUT | OUT | OUT | | S1, S3 | | OUT | OUT | OUT | | I 52 | | IN | IN | IN | | I <b>T4</b> 0 | Test track 40 | OUT | OUT | OUT | | HA HA | Test actuate head load | OUT | OUT | OUT | | 14, 6, 8, 10, 12, | Alternate I/O pins | OUT | OUT | OUT | | 116, 18, 24 | I | I | | | Table 2-10: Qume 842 Drive Configuration | 1 | | | | | |-------------------|-------------------------------|-------|-------------------|-------------------| | OPTION | DESCRIPTION | DRIVE | DUAL<br>O DRIVE 1 | SINGLE<br>Drive o | | ! DS1 | Drive select 1 | IN | OUT | IN | | DS2 | Drive select 2 | OUT | IN. | OUT | | DS3 | Drive select 3 | OUT | OUT | OUT | | DS4 | Drive select 4 | OUT | OUT | OUT | | l A, B | Radial head load | IN | IN | IN | | I X | Radial head load | OUT | OUT | OUT | | l Z | In use from drive select | OUT | OUT | OUT | | I HL | Stepper power from head load | OUT | OUT | OUT | | I R | iAlternate output ready pad | IN | IN | IN | | ! I | | IN | IN | IN | | I C | Alternate input head load | I IN | IN | IN | | I D | Alternate input-in-use | OUT | OUT | OUT | | I DC | Alternate output disk change | OUT | OUT | OUT | | 1 25 | Alternate output 2-sided disk | IN | IN | IN | | I Y | In use from head load | IN | IN | IN | | ! DL | Door lock latch | OUT | OUT | OUT | | I RR | Radial ready | IN | IN | IN | | I RI | Radial index | IN | IN | IN | | ! WP | Inhibit write when write | IN | IN | IN | | 1 | protect | | | | | I NP | Allow write when write | OUT | OUT | OUT | | 124 22 24 22 | Iprotect | | | | | | SIDrive address select | OUT | OUT | OUT | | B1-B4 | Two-sided drive select | OUT | OUT | OUT | | 51,53 | Head select option | OUT | OUT | OUT | | 1 S2 | Head select option | IN | IN | IN | | ! T40 | Test track 40 | OUT | OUT | OUT | | ! HA | Test actuate head load | OUT | OUT | OUT | | 14, 6, 8, 10, 12, | Alternate I/O pins | OUT | OUT | OUT | | 116, 18, 24 | 1 | | | | | SF | Switch filter | IN | IN | IN | | l SP | | OUT | OUT | OUT | | | | | | 001 | Table 2-11: Qume 242 Drive Configuration | OPTION | DESCRIPTION | DRIVE | DUAL<br>O DRIVE 1 | SINGLE<br>DRIVE | |------------|------------------------------------------------|-------|-------------------|-----------------| | DS1 | Drive select 1 | IN | OUT | IN | | DS2 | Drive select 2 | OUT | IN | OUT | | DS3 | IDrive select 3 | OUT | OUT | OUT | | DS4 | Drive select 4 | OUT | OUT | OUT | | Z | In use from drive select | OUT | OUT | OUT | | X | Radial head load | OUT | OUT | OUT | | R | Alternate output ready pad | IN | IN | IN | | I | Alternate output index pad | IN | IN | IN | | D | Alternate input-in-use | OUT | OUT | OUT | | DC | | OUT | OUT | OUT | | 25 | | IN | IN | IN | | DS | | IN | IN | IN | | DL | Diskette lever (optional) | OUT | OUT | OUT | | Y | In use from head load | OUT | OUT | OUT | | HL | Stepper power from head load | IN | IN | IN | | С | | IN | IN | IN | | RR | Radial ready | IN | IN | IN | | RM | Ready modified | OUT | OUT | OUT | | RI | Radial index | IN | IN | IN | | WP | | IN | IN | IN | | NP | | OUT | OUT | OUT | | B1-B4 | Side select option using <br> drive select* | OUT | OUT | OUT | | S1 | | OUT | OUT | OUT | | S2 | | IN | IN | IN | | <b>S</b> 3 | | OUT | OUT | OUT | | Mi | Spindle motor option | IN | IN | IN | | <b>M2</b> | Spindle motor option | OUT | OUT | OUT | | MC1-MC4 | Notor control select | OUT | OUT | OUT | Table 2-12 Tandon TM848-1/848-2 Drive Configuration ### 2.2.1. Drive Selection Signals The controller provides four radial drive select signals. Each drive must be configured to one of the appropriate drive select signals. Drive select 1 and drive select 2 (DS1/DS2) are associated with the primary register set (177170(8)) while drive select 3 and drive select 4 (DS3/DS4) are associated with the secondary register set (177174(8)). Upon initiation of a function the controller selects the appropriate drive, performs the operation and after ten revolutions of inactivity deselects the drive. ### 2.2.2. Head Load Signal A separate head load signal is provided to prolong media life. The read/write heads are only loaded on the media during read/write operations. All other operations are completed with the heads in the unloaded position. Because step positioning can take place with the heads unloaded, the drive must be configured to provide stepper power independent of head loading. ### 2.2.3. Motor Control The controller has been configured for ease of use with the never DC motor drives. A motor on signal is provided and is activated by the controller upon the initiation of any function. Before the drive is used for read/write operations, a motor delay timer insures the drive is up to speed. After ten revolutions of inactivity, the signal is deselected, prolonging the life of the drive. The motor on delay timer has been configured to operate with drives jumpered with motor on as a function of drive select. When a drive is selected the motor on signal is set. If the motor on signal was previously set the drive ready status is immediately interrogated and if valid, the function is initiated. If the drive is not ready a motor on delay is issued after which the drive ready status is again interrogated. A valid ready status initiates the function while a not ready status results in a error being reported and the operation aborted. ### 2.3. CABLING A 50-conductor ribbon cable connects to any Shugart compatible drive(s). If the optional cable is purchased with the controller, connect the socket connector to the 50-pin header located at the edge of the controller board. Observe the alignment of pin 1 of the socket connector and header as indicated by the arrows shown in Figure 2-2. The two 50-pin connectors should be connected to the corresponding drives, again observing the location of pin 1. If the optional cable is purchased from an independent source, the following list of materials (or equivalent) will help in the construction of the required cable. | QTY | DESCRIPTION | MFG | NUMBER | |------|---------------------------|-----|-----------| | 1 ea | 50 pin socket connector | ЗМ | 3425-3000 | | 2 ea | 50 pin edge connector | 3M | 3415-0001 | | A/R | 50 conductor ribbon cable | 3H | 3365/50 | Figure 2-2: Drive/Controller Cabling The connector pins illustrated in Figure 2-3 are compatible with both the Shugart 800 series and 850 series drives. Any drive that has both a Shugart compatible interface and connector should function properly with the controller. ``` ----| 1 | 2 |---->TG 43 |----| 3 | 4 |---->MOTOR ON 1----15161 1----17181 |----| 9 | 10 | <----TWO SIDED 1----|11 |12 | |----|13 |14 |---->SIDE SELECT 1----115 | 116 | 1---- | 17 | 18 | ----> HEAD LOAD |----|19 |20 |<----INDEX |----|21 |22 |<----READY 1----123 124 1 1----125 126 1---->DRIVE SELECT 1 1----127 | 128 | ----> DRIVE SELECT 2 |----|31 |32 |---->DRIVE SELECT 4 |----|33 |34 |---->DIRECTION 1----135 | 136 | 1---->STEP |----|37 |38 |---->WRITE DATA 1----139 | 40 | ----> WRITE GATE |----|41 |42 |<----TRACK 00 |----|43 |44 |<----\WRITE PROTECT 1----145 146 1<----READ DATA 1----147 | 48 | 1----149 150 1 1 ``` Figure 2-3: Connector Pin Definitions ### 2.4. CONTROLLER INSTALLATION The controller can be inserted and will function in any LSI-11 bus slot provided that both interrupt and DMA continuity are maintained. Since these signals are daisy chained through the bus slots, no unused slots between the LSI-11 processor and the floppy controller may exist. Determine the order that the priority chain follows by consulting the documentation supplied with the LSI-11 system. Note that when two interrupts of the same priority level are asserted, the closer a device is located to the processor, the higher its priority. ### 2.5. INITIAL OPERATION AND CHECKOUT Before the following procedures are done and for purposes of checkout, verify that the controller has been configured with two drives as described in Sections 2.1-2.4. ### NOTE The bootstrap must be disabled for the following procedures. - Apply power to the drive(s). - 2. Place the Run/Halt switch on the processor to the Halt position and turn on the processor. An "0" character should be printed on the terminal signifying that console ODT has been entered. Both drives (first drive 1, then drive 0) will step the heads inward 2-tracks, then step the heads outward until the home signal is detected. The heads will not load. If the above events do not occur, check the cabling and drive power supplies. - 3. Place a preformatted scratch diskette in drive O. - 4. If the standard address assignment is selected, open the CS register using ODT by typing 177170/ on the terminal. The processor will display the contents of the CS register. If the controller is operating properly a 004040(8) should be printed. Deposit a 40000(8) in the CS register by typing 40000 <CR>. This command will initialize the controller. Both drives should calibrate for home position. First, drive 1 steps inward 2 tracks then outward one track at a time until the drive indicates track O has been reached. The procedure is repeated on drive 0. After both drives are calibrated, the head on drive 0 is loaded. Sector 1 of track 1 on drive 0 is read into the controller buffer. This operation is indicated by the in-use LED on the drive indicating the head load The LED will remain on for a short time after the operation. read operation is complete. - If, after initializing, the drives do not calibrate or the LED is not activated, check the cabling and power supplies. - 5. Reopen the CS register (location 177170(8)) using ODT as described above. The contents of this location should be 004040(8). Examining the next location 177172(8) by using the line feed key or typing in 177172/ should yield either a 204(8), 244(8), 206(8) or 246(8). For a detailed description of the register protocol and bit definition, refer to Section 3. - 6. If the above procedures function as described, the controller is ready for use. Either diagnostics or an operating system can be booted. For details on bootstrapping refer to Section 4. - 7. If the above procedures cannot be validated, consult the factory or your local representative for assistance. ## Section 3 Functional Description ### 3. GENERAL This section describes device registers and command protocol for the MXV22. All software control of the MXV22 is performed by means of two sets of two device registers: the command and status (MXVCS) register and a multipurpose data buffer (MXVDB) register. These registers are assigned the bus address 177170(8) and 177172(8), respectively, for the primary register set and 177174(8) and 177176(8), respectively, for the secondary register set. The registers can be read or loaded, with a few exceptions, using any instruction referring to their addresses. The MXVCS register passes control information from the CPU to the controller and reports status and error information from the controller to the CPU. The MXVDB is provided for additional control and status information between the CPU and the controller. The information that is present in the MXVDB at any given time is a function of the controller operation in progress. The controller contains a sector buffer capable of storing a complete sector. For read/write operations the buffer is either "filled" before a write command or "emptied" after a read command under DMA control. During a write command the controller locates the desired sector and the buffer information is transferred to the diskette. During a read operation the desired sector is located and the sector data are transferred to the buffer. ### 3.1. REGISTER DEFINITIONS ### 3.1.1. MXVCS - Command and Status Register (177170(8) or 177174(8)) The format of the MXVCS register is shown below. Functions are initiated by loading the command and status (CS) register, when not busy (bit 5=1), with bit 0=1. Command protocol is discussed in detail in section 3.2. | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------|------|------|-----|----------|-------------|---------------|-----|----------|----------------|------|--------------|----|-------|-----|-----| | ERR | INT | EXT | ADD | RX<br>02 | 122<br>1EBL | I HD<br>I SEL | DEN | ITR<br>I | INT <br> ENB | DN Q | UNT <br> SEL | FU | JNCT: | ION | 1G0 | | BIT D | ESCR | IPT] | ON | | | | | | | -70 | (**** | | | | | - ERROR: This bit is set by the controller to indicate that an error has occurred during an attempt to execute a command. This bit is cleared by the initiation of a new command or by setting the initialize bit. When an error is detected the MXVES is read into the MXVDB. This bit is a read-only bit. - 14 MXV22 INITIALIZE: This bit is set by the program to initialize the controller without initializing all the devices on the LSI-11 bus. This is a write-only bit. ### CAUTION Loading the lower byte of the MXVCS will also load the upper byte of the MXVCS. When this bit is set, the controller will negate Done and move the head position mechanism of drive 1 (if two drives are available) to track 0. When completed, the controller will repeat the operation on drive 0. The controller will then clear the error and status register, set Initialize Done, and set Drive Ready if drive 0 is ready. Finally, the controller will read sector 1, track 1, of drive 0. - EXTENDED ADDRESS BITS: These bits are used to specify an extended bus address. Bit 12 = MA16. Bit 13 = MA17. These are write-only bits. - 11 RX02: This bit is asserted by the controller to indicate that this is an RX02 type system. This is a read-only bit. - 22 BIT ADDRESSING ENABLED: This bit is normally read as a zero. If 22 bit addressing is enabled and fill/empty buffer or read error code commands are initiated this bit will be set along with transfer ready (TR). - OP HEAD SELECT: This bit selects one of the two possible sides of the disk for execution of the desired function. When cleared, side 0 is selected, when set, side 1 is selected. This is a read/write bit. - OB DENSITY SELECT: This bit selects either single or double density operation. When cleared, single density is selected; when set, double density is selected. This is a read/write bit. - O7 TRANSFER REQUEST: This bit signifies that the controller needs data or has data available. This is a read-only bit. - OF INTERRUPT ENABLE: This bit is set by the program to enable an interrupt when the controller has completed an operation and asserted the Done bit. The condition of this bit is cleared by initialize. This is a read/write bit. - O5 DONE: This bit indicates the completion of a function. Done will generate an interrupt when asserted if interrupt enable (MXVCS bit 6) is set. This is a read-only bit. - 04 UNIT SELECT: This bit selects one of the two possible disks for execution of the desired function. This is a read/write bit. - 03-01 FUNCTION SELECT: These bits code one of the eight possible functions described in detail within this section. These are write-only bits. - 000 Fill Buffer - 001 Empty Buffer - 010 Write Sector - 011 Read Sector - 100 Set Media Density/Format - 101 Read Status - 110 Write Deleted Data Sector - 111 Read Error Code - 00 GO: Initiates a command (write-only bit). ### 3.1.2. MXVDB - Data Buffer (177172(8) or 177176(8)) This register serves as a general purpose data path between the controller and the LSI-11. It will represent one of seven registers according to the protocol of the function in process. These registers include the MXVDB, MXVTA, MXVSA, MXVWC, MXVBA, MXVBAE and MXVES. This register is a read/write register if the controller is not in the process of executing a command (i.e., it may be manipulated without affecting the controller). When the controller is executing a command, the register can only be accessed when MXVCS bit 7 (TR) is set. | Data | Buff | er Re | aiste | r (MXVDB) | |------|------|-------|-------|-----------| | | | | | | All information transferred to and from the floppy media passes through the MXVDB register and is addressable only under the protocol of the function in progress. ### MXVDB FORMAT ### Track Address Register (MXVTA) This register is loaded to indicate on which of the 115(8) (77 decimal) tracks a given function is to operate. It can be addressed only under the protocol of the function in progress. Bits 8 through 15 are not used and are ignored. | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | | 5 4 | 1 | 3 | 2 | 1 | 0 | |----|----|----|----|-----------|----|------|------|---|---|---|-----|------------|---|---|---|---| | | | | | | | 1/// | | _ | I | 1 | 1 | 1 | 1 | 1 | | | | \ | | | | \/<br>USE | | | HXVI | • | | | | \/<br>0-11 | | | | / | ### Sector Address Register (MXVSA) This register is loaded to indicate on which of the 32(8) (26 decimal) sectors a given function is to operate. It can be addressed only under the protocol of the function in progress. Bits 8 through 15 are not used and are ignored. MXVSA FORMAT ## Word Count Register (MXVWC) This register is loaded with the number of words (maximum of 128 decimal) to be transferred. At the end of each transfer the word count register is decremented. When the contents of the register are decremented to zero transfers are terminated; Done is set (MXVCS bit 5); and, if enabled, an interrupt is requested. If the word count is greater than the limit for the density specified, the controller asserts a Word Count Overflow (bit 10 of the MXVES). This register can be addressed only under the protocol of the function in progress. Bits 8 through 15 are not used and are ignored. | 15 | 14 | 13 | | | 10 | | | | | 5 | 4 | 3 | 2 | 1 | ( | 0 | |------------|------|------|------|-----------|------|-------|-----|-----------|---|---|------|---|-----------|-----------|-----------|-----------| | 1/// | 1/// | 1/// | 1/// | 1/// | 1/// | 1///1 | /// | 1 | 1 | | | | <br> <br> | <br> <br> | <br> <br> | <br> <br> | | <i>(</i> / | *** | | | /<br>USED | | | | \<br>C FN | | C | -\/- | | | | | / | # Bus Address Register (MXVBA) This register is used to generate the bus address which specifies the location to and from which data are to be transferred. The register is incremented after each transfer. It will increment across 32K boundary lines via the extended address bits in the control and status register and the bus address extension register. Systems with only 16 address bits will "wrap around" to location zero when the extended address bits are incremented. This register can be addressed only under the protocol of the function in progress. Bit 0 is not used and is ignored. | 15 | | | | | | | | | | | | | _ | 0 | |-----|---|---|---|---|---|------|--------|------|---|---|---|---|---|-------| | 1 1 | f | 1 | 1 | i | 1 | <br> | !<br>! | <br> | 1 | 1 | 1 | ı | i | 1///1 | #### **MXVBA FORMAT** # Bus Address Extension Register (MXVBAE) This register contains the extended address bits (A18-A21) when 22 bit addressing is enabled. Bits 4 thru 15 are not used and are ignored. **MXVBAE FORMAT** #### Error and Status Register (MXVES) This register contains the current error and status conditions of the drive selected by bit 4 (Unit Select) of the MXVCS. This read-only register can be addressed only under the protocol of the function in progress. The MXVES is loaded in the MXVDB upon completion of a function. | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | _ | | _ | - | | _ | _ | | | • | | _ | | |----|----|----|---|---|---|-----|----|---|---|---|---|---|---|-----|----|---|---|----|---|----|-----------|------------|----------|---|----------|----|-----|-----|----|-----|-----|---|-------|----------|---|---|----------|----------|---|----|---|---|----|---|----|----------|---|-----|---|----------| | 1. | // | '/ | 1 | 1 | , | , | / | 1 | / | / | / | 1 | / | ' / | // | / | 1 | XX | M | 16 | IC<br>OVI | 11<br>F 11 | HD<br>SE | L | 1U<br>1S | N1 | r I | I D | R' | V I | I I | D | | )R<br>)E | V | | DI<br>El | EN<br>RR | 1 | AC | ; | 1 | II | ) | 13 | 51<br>R[ | D | I C | R | -<br>C ( | | | | | - | | | ٠ - | ١. | / | - | | _ | _ | | | | | | | • | | | - | | - | | | - | | | | | - | <br>- | - | • | • | • • | • • | • | | - | - | | | - | | - | | | • | #### **MXVES FORMAT** #### BIT DESCRIPTION #### 15-12 Not Used. - NONEXISTENT MEMORY ERROR: This bit is asserted by the controller when the memory address specified for a DMA operation is nonexistent. - WORD COUNT OVERFLOW: This bit indicates that the word count specified is greater than the limit for the density selected. Upon detecting this error the controller terminates the fill or empty buffer operation and asserts the Error and Done bits. - 09 HEAD SELECT: This bit indicates the side currently selected. If cleared, it indicates drive 0; if set, it indicates side 1. - OB UNIT SELECT: This bit indicates the drive currently selected. If cleared, it indicates drive 0; if set, it indicates drive 1. - O7 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. This bit is only valid when retrieved via a read status function or at the completion of initialize when it indicates the status of drive O. - OF DELETED DATA: During data recovery, the identification mark preceding the data field was decoded as a deleted data mark. - OF DRIVE DENSITY: The bit indicates the density of the diskette in the selected drive. When zero, it indicates single density; when set to one, it indicates double density. - DENSITY ERROR: A density error was detected as the information was retrieved from the data field of the diskette (a density error occurs when the density selected differs from that of the data field). Upon detecting this error the controller loads the MXVES into the MXVDB and asserts the Error and Done bits. - 03 ACLO: Set by the controller to indicate a power failure. - O2 INITIALIZE DONE: This bit is asserted to indicate completion of the initialize routine, which can be caused by system power failure or programmable LSI-11 bus initialize. - O1 SIDE READY: This bit is asserted by the controller when a double-sided drive is selected, is ready, and has double-sided media inserted. The assertion of this bit indicates that side 1 of the selected drive is available for read and write operations. - OCC ERROR: A cyclic redundancy check error was detected as information was retrieved from a data field of the diskette. The information stored in the buffer should be considered invalid. Upon detection of this error the controller loads the MXVES into the MXVDB and asserts the Error and Done bits. # 3.1.3. Extended Status Registers The controller has four internal status registers. These registers provide specific error information in the form of error codes as well as drive status information depending upon the general error type. The registers can be retrieved by a read error code function as described in Section 3.2.8. # Word 1 <7:0> - Definitive Error Code # Octal Code Error Code Meaning - 040 Tried to access a track greater than 76. - 050 Home was found before desired track was reached. - O70 Desired sector could not be found after looking at 52 headers (2 revolutions). - 120 A preamble could not be found. - The header track address of a good header does not compare with the desired track. - 160 Too many tries for an IDAM (identifies header). - 170 Data AM not found in allotted time. - 200 CRC error on reading the sector from the disk. - 240 Density Error - 250 Wrong Key word for Set Hedia Density Command - 260 Illegal Data AM - 270 Invalid POK during write sequence 300 Drive not ready. 310 Drive write protected. #### Word 1 <15:8> - Not Used This register is always cleared by the controller. #### Word 2 <7:0> - Current Track Address of Drive 0 This register is cleared during the initialize command in order to synchronize with actual track position. The register is updated with each seek on drive 0 and maintains current track position. #### Word 2 <15:8> - Current Track Address of Drive 1 This register is cleared during the initialize command in order to synchronize with actual track position. The register is updated with each seek on drive 1 and maintains current track position. ## Word 3 <7:0> - Target Track of Current Disk Access If legal, the track specified for the last read/write command is saved in this register. #### Word 3 <15:8> - Target Sector of Current Disk Access The sector specified for the last read/write command is saved in this register. #### Word 4 <15:8> - Track Address of Selected Drive This register contains the track address read from the sector header of the desired sector during the last read/write command. #### 3.2. COMMAND PROTOCOL Data storage and recovery using the MXV22 controller is accomplished by careful manipulation of the MXVCS and MXVDB registers according to the strict protocol of the individual functions. The penalty for violation of protocol can be permanent loss of data. Each of the functions are encoded and written into the command and status register bits 1-3 as described in Section 3.1.1. The detailed protocol for each function is described below. #### 3.2.1. Fill Buffer (000) This function is used to fill the controller buffer with data from the host processor. The number of words to transfer is specified by the host. The command density bit determines the buffer size (64 or 128 words). The controller zero-fills the remaining buffer space. If the word count is too large for the density selected, the function is aborted, Error and Done are asserted and the Word Count Overflow bit is set in the MXVES. The contents of the buffer may be written on the diskette with a subsequent write sector command or returned to the host processor using an empty buffer command. When the command is loaded, MXVCS bit 5 (Done) is negated. MXVCS bit 8 (density) must be set to define the buffer size. MXVCS bits 12 and 13 (extended address bits A16 and A17) must also be asserted to define the extended memory segment used with the buffer address, yet to be specified, to form the absolute memory address of the data to be transferred. MXVCS bit 4 (unit select) and bit 9 (head select) are ignored since no drive operation is required. When MXVCS bit 7 (TR) is first asserted, the program must move the word count into the MXVDB which will negate TR. When the controller again asserts TR, the program must move the buffer address into the MXVDB. If 22 bit addressing is enabled, MXVCS bit 10 (22 EBL) is set, the controller again asserts TR and the program can move the extended address bits (A18-A21) into the MXVDB. If nothing is moved into the MXVDB (BAE REG) within a timeout period the controller assumes zeroes defaulting to 18 bit addressing mode. The controller then negates TR, initiates a DMA cycle, and transfers the first word from the host processor to the controller buffer. At the end of the transfer the word count register is decremented and the buffer address is incremented by two. This cycle is repeated until the word count register becomes zero. The controller zero-fills the remaining buffer space, sets the Done bit, and if enabled, causes an interrupt request. After Done is asserted the MXVES is moved into the MXVDB. During the Data Transaction, if any non-existent memory is addressed, the controller will time out and abort the function. The Error and Done bits will be asserted. MXVES bit 11 (NXM) will be set and the MXVES will be moved into the MXVDB; if enabled, an interrupt request will be generated. # 3.2.2. Empty Buffer (001) This function is used to transfer the contents of the controller to the host processor. The number of words to transfer is specified by the host. The command density bit determines the maximum legal word count. If the word count specified is too large for the density selected the function is aborted, Error and Done are asserted and the Word Count Overflow bit is set in the MXVES. The contents of the buffer may be transferred to the host as many times as desired or may be written on the diskette with a subsequent write sector command. Unless a fill buffer or read sector command is issued, the controller buffer is not destroyed. When the command is loaded, MXVCS bit 5 (Done) is negated, MXVCS bit 8 (density) must be set to allow the proper word count limit. MXVCS bits 12 and 13 (extended address bits A16 and A17) must also be asserted to define the extended memory segment used with the buffer address, yet to be specified, to form the absolute memory destination address. MXVCS bit 4 (unit select) and bit 9 (head select) are ignored since no drive operation is required. When MXVCS bit 7 (TR) is first asserted the program must move the word count into the MXVDB which will negate TR. When the controller again asserts TR the program must move the buffer address into the MXVDB. If 22 bit addressing is enabled, MXVCS bit 10 (22 EBL) is set, the controller again asserts TR and the program can move the extended address bits (A18-A21) into the MXVDB. If nothing is moved into the MXVDB (BAE REG) within a timeout period the controller assumes zeroes defaulting to 18 bit addressing mode. The controller then negates TR, initiates a DMA, and transfers the first word of the buffer to the host processor. At the end of the transfer, the word count register is decremented and the buffer address register is incremented by two. This cycle is repeated until the word count register becomes zero. The controller then sets the Done bit and if enabled causes an interrupt request. After Done is asserted the MXVES is moved into the MXVDB. During the DMA transaction, if any non-existent memory is addressed, the controller will time out and abort the function. The Error and Done bits will be asserted. MXVES bit 11 (NXM) will be set and the MXVES will be moved into the MXVDB. If enabled, an interrupt request will be generated. #### 3.2.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. When the MXVCS is loaded with this command, the MXVES is cleared and both the TR and Done bits are negated. When TR is first asserted the program must load the desired sector address into the MXVDB which will negate TR. When TR is again asserted the program must load the desired track address into the MXVDB which will negate TR. The controller then seeks the desired track and attempts to locate the desired sector. The desired track is compared with the track field of the sector header. If they do not match the operation is aborted, the Error and Done bits are asserted, the MXVES is moved into the MXVDB, and if enabled the controller will assert an interrupt request. A data address mark is read to determine the diskette density. If the densities of the function and the diskette do not agree, the controller will abort the operation, assert the Error and Done bits and set MXVES bit 4 (Density Error) and load the MXVES into the MXVDB. If enabled, an interrupt request will be generated. If the densities agree but the controller is unable to locate the desired sector within two diskette revolutions, the controller will abort the operation, move the contents of MXVES into MXVDB, assert the Error and Done bits, and if enabled, assert an interrupt request. If the desired track and sector are located and the densities agree, the controller will write the contents of the internal sector buffer followed by a CRC character, all in the function selected density. The controller completes the operation by moving the MXVES to the MXVDB, asserts Done, and if enabled, asserts an interrupt request. #### CAUTION The contents of the internal sector buffer are lost during a power failure. However, after power is brought back to normal, a write sector command will cause the random contents of the buffer to be written on the diskette with a valid CRC character. #### NOTE The contents of the sector buffer are not destroyed by a write sector operation. # 3.2.4. Read Sector (011) This function is used to locate the desired track and sector and transfer the contents of the data field into the controller's internal sector buffer. When the MXVCS is loaded with this command, the MXVES is cleared and both the TR and Done bits are negated. When TR is first asserted the program must load the desired sector address into the MXVDB which will negate TR. When TR is again asserted the program must load the desired track address into the MXVDB which will negate TR. Both the TR and Done bits remain negated while the controller attempts to locate the desired sector. If after two revolutions the controller is unable to locate the desired sector, the operation is aborted. The controller will move the MXVES into the MXVDB, assert the Error and Done bits, and if enabled, assert an interrupt request. When the desired sector is located, the controller will then compare the desired track with the track field of the sector header. If they do not match, the operation is aborted. The Error and Done bits are asserted, the MXVES is moved into the MXVDB, and if enabled, the controller asserts an interrupt request. If a legal data address mark is located and the densities of the diskette and function agree, the controller will read the data from the sector into the internal buffer. If the data address mark indicated a deleted data field, MXVES bit 6 (DD) is set. As data are stored in the internal buffer, a CRC is computed on the data and the CRC bytes recorded. A non-zero result indicates a read error. When a CRC error is encountered, the controller sets MXVES bit 0 (CRC), moves the MXVES into the MXVDB, asserts the Error and Done bits, and if enabled, asserts an interrupt request. If the desired sector is located, the density of the diskette and function agree, and the data are transferred with no CRC error, the controller will assert Done, and if enabled, will assert an interrupt request. # 3.2.5. Set Media Density (100) This function is dual purpose. The controller can set the media density by rewriting all the data address marks (single or double density) and writing zero data fields in the selected density. controller can also "reformat" the entire diskette by rewriting both the sector headers and the data fields. The data fields are written in the selected density preceded by the corresponding data address mark. Both commands are initiated by the set media function but differ in the keyword required by the controller to execute the command. When the MXVCS is loaded with the command, the MXVES is cleared and the Done bit is negated. When TR is set, the program must respond with a keyword. This keyword must be deposited in the MXVDB to complete the protocol. When the controller recognizes this character, it begins executing the command. If an illegal keyword is used, the operation is The MXVES is moved into the MXVDB, the Error and Done bits If the keyword used is a 111(8), the controller initiates a set media density operation. This operation starts at track 0, sector 1. Each sector header is located and a write operation is initiated. A data field is written with zero data in the density selected. If an error occurs reading any header, the operation is aborted. The MXVES is moved into the MXVDB, the Error and Done bits are set, and if enabled, the controller asserts and interrupt request. If the operation is successfully completed, Done is set and if enabled, the controller asserts an interrupt request. are set, and if enabled, the controller asserts an interrupt request. If the keyword used is a 222(8), the controller initiates a format operation. This function starts at the physical index of track 0. Each track is written first with an index address mark, then 26 sector headers are written sequentially about the track. When each track has been written, the controller initiates a set media density function as described above. The following input string will format the selected unit, in the desired density. | 777170/ | 4040 | XXXX <lf< th=""><th>&gt;</th></lf<> | > | |---------|--------|---------------------------------------|--------| | 177172/ | 000000 | 222 <cr< td=""><td>;<br/>;</td></cr<> | ;<br>; | #### CAUTION The set media density function takes about 15 seconds and the format function takes about 45 seconds. Neither should be interrupted. If either operation is interrupted, an illegal diskette has been generated, and the operation should be repeated. If an error occurs during a set media density function or a format function, an illegal diskette has been generated. The operation should be repeated. ## 3.2.6. Read Status (101) This function is used to update the drive status information and is initiated by loading the command into the MXVCS. The Done bit is negated. MXVES bit 7 (Drive Ready) is updated by sampling the drive ready status line. Drive density is updated by loading the head of the selected drive and reading the first data address mark. The controller then moves the MXVES into the MXVDB, asserts Done, and if enabled, asserts an interrupt request. This operation requires about 250ms to complete. #### NOTE If double-sided media are mounted in a double-sided drive, MXVES bit 1 (side ready is set). # 3.2.7. Write Deleted Data Sector (110) This operation is identical to Write Sector (010) with one exception. The data address mark preceding the data is not the standard data address mark. A single or double density deleted data address mark is written according to the density of the function. # 3.2.8. Read Error Code (111) This function is used to retrieve the extended status registers and is initiated by loading the MXVCS with the command. The Done bit is negated. When TR is asserted, the program must load the Bus Address into the MXVDB. If 22 bit addressing is enabled, MXVCS bit 10 (22 EBL) is set, the controller again asserts TR and the program can move the extended address bits (A18-A21) into the MXVDB. If nothing is moved into the MXVDB (BAE REG) within a timeout period the controller assumes zeroes defaulting to 18 bit addressing mode. The controller then negates TR and assembles one word at a time and, under DMA control, transfers them to memory starting at the address specified. If non-existent memory is encountered during the transfer, the operation is aborted. The Error and Done bits will be asserted, MXVES bit 11 (NXM) will be set, and the MXVES will be moved into the MXVDB. If enabled, an interrupt request will be generated. When all four words have been transferred the Done bit is set and if enabled, an interrupt request is generated. # Section 4 Controller Operations #### 4. GENERAL This section provides the user pertinent information concerning the description and use of the controller functions. The functions covered include: bootstrapping, formatting, fill/write operations, read/empty operations, write current control, write precompensation, and power fail protection. #### 4.1. BOOTSTRAPPING THE CONTROLLER If the bootstrap is enabled as described in Section 2.1.3, the controller will respond to the standard bootstrap address 173000(8). The controller is bootstrapped by typing 773000G while in console ODT. This causes a bus INIT and transfers program execution to location 173000(8). An alternate method is to strap the LSI-11 processor to power up Mode 2. In this mode, when a power up occurs, the processor automatically starts execution at 173000(8). Power-up strapping procedures for the LSI-11 processor can be found in the Microcomputer Processors Handbook.\* To boot either a single or double density diskette use the following procedure: - 1. Place the diskette in drive O. - If the processor is strapped for power-up Mode 2, operate the INIT (boot) switch or cycle DC power OFF and ON. - If the processor is not strapped for power up Mode 2 while in console ODT, type 773000G. <sup>\*</sup>Published by Digital Equipment Corporation. Maynard, Mass., 1979. #### 4.1.1. Bootstrap Operation The bootstrap is not a standard ROM program. It uses the controller's microprocessor to capture the bus; to read block 0 of the diskette into memory starting at location 0; and finally to transfer program execution to memory location 0. Any attempt to read location 173000(8) will result in a non-existent memory trap. The controller only responds to this address immediately after a bus INIT. For this reason the bootstrap "transparent". When the processor attempts to fetch location 173000(8) following a bus INIT, the controller responds by passing the processor a "CLEAR RO" instruction. The processor clears RO and then attempts to fetch location 173002(8). The controller passes the processor a \*LOAD IMMEDIATE" instruction with R1 as the destination. The processor then attempts to fetch the source operand from location 173004(8). controller passes the the device address 177170(8) if the standard address is selected. The processor moves the address into R1 and then attempts to fetch location 173006(8). The controller first asserts a Direct Memory Access Request (DMR) then passes the processor a "CLEAR instruction. Before the processor executes the instruction it passes bus mastership to the controller. The controller moves a \*BRANCH TO CURRENT LOCATION\* instruction (777(8)) into memory location O under DMA control. When the controller releases bus mastership the processor executes the "CLEAR PC" instruction and, in so doing, transfers program execution to location 0. The processor is thus forced to loop at location 0. The controller initiates a Read Status function on drive 0 to determine diskette density. If the diskette is single density the controller reads sectors 1, 3, 5, and 7 of track 1 of drive 0 into locations 2 through 176, 200 through 376, 400 through 576, and 600 through 776 respectively. If the diskette is double density the controller reads sectors 1 and 3 of track 1 of drive 0 into locations 2 through 376, and 400 through 776 respectively. Finally, the controller DMA's location O with a NOP instruction (240(8)) allowing the processor to execute the system bootstrap. If there is no diskette in drive O nothing will be transferred to memory and the processor will continue to loop at location 0 until halted. #### 4.2. FORMAT OPERATIONS The controller has the capability of formatting diskettes in a specified density. The formatting is accomplished in two passes. During pass 1, an index address mark is written on track 0 following the index hole. Twenty-six sector headers, appropriately spaced, are written following the index address. Each of the remaining 76 tracks is written in the same manner. When track 76 is completed, pass 2 is initiated. The controller seeks track 0 and write a zero data field in sector 1 using the selected density. The remaining sectors are written in the same manner. The format command selects diskette density, unit and side (for dual headed drives). Table 4-1 lists the various command word formats. | | | Unit O | | Unit 1 | |--------------------------------------------------------------------------------------------------------|----------------|---------------------------------------|------|---------------------------------------| | Single Density Side 0<br> Single Density Side 1<br> Double Density Side 0<br> Double Density Side 1 | <br> <br> <br> | 11(8)<br>1011(8)<br>411(8)<br>1411(8) | <br> | 31(8)<br>1031(8)<br>431(8)<br>1431(8) | Table 4-1: Command Word Formats Figure 4-1 illustrates a format subroutine. The format command is loaded into MXVCS. When TR is set, the keyword 222(8) is loaded into MXVDB. When the diskette has been formatted a return is made. #### FORMAT: ``` MOV #11, CMD ; FORMAT BIS DENS, CMD ; DENSITY BIS UNIT, CMD :UNIT BIS SIDE, CMD ;SIDE MOV CMD, @#MXVCS ;SELECT FUNCTION JSR PC, TRWAIT :WAIT FOR TR MOV #222, @#MXVDB : KEYWORD JSR PC, DNWAIT ; WAIT FOR DONE TST @#MXVCS ; ERROR BMI FRMERR ;BR IF SO RTS PC ``` # FRMERR: Figure 4-1: Format Subroutine Alternatively a diskette can be formatted using console ODT. Open the CS register and deposit the appropriate command. Then deposit the format key word 222(8) in the DB register. The following is an example of formatting unit 0 side 0 in double density. | 177170/ | 004040 | 411 <lf></lf> | |---------|--------|---------------| | 177172/ | 000000 | 222 <cr></cr> | ### 4.3. FILL/WRITE OPERATIONS Figure 4-2 illustrates subroutines to write data on a diskette which is done by performing a fill buffer operation followed by a write sector. The Fill Buffer command, specifying single or double density is loaded into the MXVCS. When TR is set, the word count is loaded into the MXVDB. When TR is again set, the bus address of the data is loaded into the MXVDB. If 22 bit addressing is enabled TR is again set and the extended address bits are moved into the MXVDB. A return is made when the controller's sector buffer is filled. The Write Sector command (specifying density, unit and side) is loaded into the MXVCS. When TR is set the sector address is loaded into the MXVDB. When TR is again set, the track address is loaded into the MXVDB. When the contents of the controller's sector buffer are written at the selected sector, a return is made. ``` FILLBF: MOV #1, CMD :FILL BUFFER BIS DENS, CMD :DENSITY CHD, @#HXVCS MOV ;SELECT FUNCTION JSR PC, TRWAIT :WAIT FOR TR MOV COUNT. @#MXVDB ; WORD COUNT JSR PC. TRWAIT MOV #BUFOUT, @#MXVDB BUS ADDRESS OF DATA JSR PC. DNWAIT :WAIT FOR DONE KOV #EXTAD, @#MXVDB :EXTENDED ADDRESS BITS* JSR PC. DNWAIT :WAIT FOR DONE* TST @#MXVCS :ERROR BMI ERFIL ; BR IF SO RTS PC ERFIL: WSECT: YOM #5, CMD ; WRITE. SECTOR BIS DENS, CMD :DENSITY BIS UNIT. CMD :UNIT BIS SIDE, CMD SIDE MOV CHD, OPHXVCS ;SELECT FUNCTION PC, TRWAIT JSR ; WAIT FOR TR YOY SECTOR, @#MXVDB :SECTOR JSR PC TRWAIT MOV TRACK @#MXVDB : TRACK JSR PC. DRWAIT :WAIT FOR DONE TST @#MXVCS :ERROR WSERR BMI ;BR IF SO ``` #### WSERR: RTS PC \*Only required if 22 bit addressing is enabled! Figure 4-2: Write Data Subroutines # 4.4. READ/EMPTY OPERATIONS RSECT: MOV #7. CMD Figure 4-3 illustrates subroutines to read data from a diskette which is done by performing a Read Sector operation followed by an Empty Buffer operation. The Read Sector command (specifying density, unit and side) is loaded into the MXVCS. When TR is set the sector address is loaded into the HXVDB. When TR is again set, the track address is loaded into the When the contents of the selected sector are read into the controller's sector buffer, a return is made. The Empty Buffer command, specifying density, is loaded into the MXVCS. When TR is set, the word count is loaded into the MXVDB. When TR is again set, the bus address of storage buffer is loaded into the MXVDB. If 22 bit addressing is enabled TR is again asserted and the extended address bits are loaded into the MXVDB. A return is made after the contents of the controller's buffer are transferred to the memory storage buffer. ``` ; READ SECTOR DENS, CMD BIS :DENSITY BIS UNIT, CMD ;UNIT BIS SIDE. CMD :SIDE YOM CMD, @#MDVCS :SELECT FUNCTION JSR PC. TRWAIT ; WAIT FOR TR MOV SECTOR, @#MDVDB :SECTOR JSR PC, TRWAIT MOV TRACK. @#MXVDB : TRACK JSR PC. DNWAIT :WAIT FOR DONE TST @#MXVCS : ERROR BMI RSERR :BR IF SO RTS PC RSERR: EMPBF: #3. CMD YOK EMPTY BUFFER BIS DENS, CMD ; DENSITY YOM CMD, @#MXVCS :SELECT FUNCTION JSR PC. TRWAIT ; WAIT FOR TR YOM COUNT, @#MXVDB :WORD COUNT JSR PC, TRWAIT MOV #BUFFIN, @#MXVDB BUS ADDRESS FOR DATA JSR PC. DNWAIT :WAIT FOR DONE MOV #EXTAD, @#MXVDB ;EXTENDED ADDRESS BITS* JSR PC. DNWAIT ; WAIT FOR DONE* TST @#MXVCS : ERROR BMI EREMP BR IF SO RTS PC EREMP: ``` \*Only required if 22 bit addressing is enabled! Figure 4-3: Read Data Subroutines ## 4.5. WRITE CURRENT CONTROL The controller provides a Write Current Control signal (TG43) which is asserted whenever a track address greater than 43 is accessed. This signal is required by some drives to reduce the effects of write saturation on the inner tracks. Since the Shugart 800 series drives do not require this signal, the controller is shipped with this feature disabled. However, Shugart 850 series double sided drives require this signal (refer to the Shugart Double Sided Diskette Storage Drive manual section 7.13). This signal is provided on pin 2 of the 50 pin ribbon connector and is enabled according to section 2.1.4. ### 4.6. WRITE PRECOMPENSATION Bit shift occurs on both single and double density diskettes. This shift is more noticeable with double density due to the smaller bit cell size and corresponding data and clock windows. Some aspects of bit shift are predictable and are dealt with the precompensation scheme implemented in this controller; unpredictable effects are reduced by using PLL techniques. Predictable bit-shift effects result from normal read/write operation. Data are recorded by flux changes in the gap of the read/write head. These flux changes produce changes in magnetization which induces current in the read/write head. Since this change in current is not instantaneous, it takes a finite time to build up to a peak and return to zero. When the magnetic flux changes are close together the previous current transition may not reach zero before a second transition occurs. The summation of current pulses produces shifted peaks. Because the flux changes are closer together on the inner tracks (43 through 76) the bit shift is greater in this area. Values of up to ±350ns are typical. Other causes of bit shift are induced by variation in disk drive rotational speed. The specified $\pm 2\%$ variation will produce bit shifts of $\pm 40$ ns. Incomplete erasure of previously recorded data can produce bit shifts of up to 50ns. Other miscellaneous components of bit shift include instantaneous speed variation, electrical noise, radial track alignment and nonsymmetry of the read/write head and associated electronics. These effects can produce up to $\pm 10$ ns of bit shift, bringing the total effect to $\pm 450$ ns. Since the data/clock window for double density is only 1000ns, a ±450ns bit shift leaves only a 50ns margin before soft errors begin to occur. To improve this margin the controller incorporates a scheme to recognize the data patterns which produce excessive bit shift and introduces a compensating bit shift. For tracks greater than forty-three the recorded bits are shifted 165ns early, or late, as determined by the two previously recorded bits and the subsequent two bits to be recorded. The controller also incorporates a phase-locked data recovery scheme which dynamically adjusts the recovery clock frequency to the data, reducing bit shifts due to rotational speed errors. These two features improve data recovery margins by 175ns or more, providing approximately 225ns of margin. # 4.7. POWER FAIL PROTECTION The controller continuously monitors both the BPOK and BDCOK bus signals. Refer to the Microcomputer Processors Handbook for detailed descriptions of these signals. When asserted, BPOK signals an impending DC power failure and guarantees 4ms of operation before BDCOK is asserted and DC power fails. Assertion of BDCOK indicates invalid DC power. This signal is hardwired in the controller as an interlock on the Write Gate signal. When BDCOK is asserted the Write Gate signal is blocked and write operations are prevented. Before initiating a write sequence, the controller interrogates the BPOK line. If an impending DC failure is indicated the operation is aborted. # Section 5 Software Considerations #### 5. GENERAL The MXV22 controller configured for 18-bit addressing can be used with all software designed to communicate with DEC's RXV21 controller. This is of particular importance when using software not supported by the driver changes presented in this section. This section describes the changes required to RT-11 and RSX-11M in order to take advantage of the 22-bit DMA support provided by the MXV22 controller. Once the changes described in this section have been incorporated into the applicable drivers the system software can be used with the MXV22 controller configured in either 18-bit or 22-bit modes. #### 5.1. OPERATION USING RT-11 Operations involving the MXV22 controller are logically equivalent to those of the RXV21 except a modified "DY" driver is required when configured in 22-bit mode. Several techniques can be used to incorporate the changes described in section 5.1.1; however, the changes can not be performed on the "DY" via the MXV22 controller without attention to the caution noted in section 5. The MXV22 (and RX02) controller requires a different handler than the programmed I/O controllers. This new handler is configured to utilize the DMA transfer scheme of the controller. In addition, diskette density is determined by the handler without system intervention, allowing the use of either single or double density diskettes interchangeably. This handler, designated "DY", is available in RT11-VO3B and later revisions. Although earlier versions of RT-11 can be used, only the changes to V4.0 and V5.0 are provided in this document. Changes to earlier versions can be accomplished using the methodology described here and the judicious placement of similar code. Earlier version will also require modification to the Bootstrap program BSTRAP. # 5.1.1. Modifying RXO2 Driver for RT11 Changes listed in Appendix A through D are those required to modify DEC's V4.0 and/or V5.0 RX02 driver for operation with the MXV22 controller. Changes listed in the Appendix are in a format expected by the Source Language Patch program (SLP). Generate a file "DYHXV.DIF" using an editor of your choice containing the appropriate changes listed in the Appendix. Use the following steps to include the changes: .RUN SLP \*DYMXV=DY.DYMXV #### NOTE Changes to applicable drivers are identified by level and/or version numbers. Be certain that the correct level and/or version is being used as input to the program SLP. The file DYMXV.MAC will contain the new MXV22 compatible driver. Assemble, link and install the new driver using the method described in your RT-11 System Generation Manual. # 5.1.2. Creating a DY-Compatible System Disk on a DX-based System The MXV22 controller requires the DY-based RT-11 monitor rather than the DX-based RT-11 monitor. The following procedures explain how to create a DY-based system. Using an RXO1 or equivalent system, or system which has an RXO1 or equivalent peripheral device, the monitor file and other associated system files should be copied onto a single density diskette. These files can be obtained from the binary distribution media or by performing a SYSGEN and specifying DY as the system device (refer to the RT11 System Generation Manual). The following commands will initialize the diskette and copy the necessary files to Drive 1: - . INIT/NOQUERY DX1: - . COPY/SYS DEV: SWAP. SYS DX1: - . COPY/SYS DEV:RT11xx.SYS DX1: - . COPY/SYS DEV: DY. SYS DX1: - . COPY/SYS DEV:TT. SYS DX1: - . COPY DEV: DIR. SAV DX1: - . COPY DEV: PIP. SAV DX1: - . COPY DEV: DUP. SAV DX1: The bootstrap must then be copied from the monitor file to block 0 of the diskette. The following command will accomplish this on the diskette in drive 1. #### . COPY/BOOT: DY DX1: RT11xx DX1: This diskette can be used with the MXV22 controller but it is single density. To build a double density diskette the user must first format a diskette to double density as explained in Section 4.2 Boot the single density system diskette in drive 0. Use the following commands to initialize the formatted diskette in drive 1 and copy the system software from drive 0 to drive 1. - . INIT/NOQUERY DY1: - .COPY/SYS DY: \*. \* DY1: Finally, copy the bootstrap to block 0 of the diskette in drive 1. .COPY/BOOT DY1:RT11xx DY1: The diskette in drive 1 can now be booted as a double density system diskette. #### 5.2. OPERATION WITH LAYERED PRODUCTS Using the driver modifications described for RT-11, layered products such as TSX-Plus V3.01, and SHARE 11 can be used to provide 22-bit system support with the MXV22 controller. #### 5.3. OPERATION WITH RSX11M Extended address support provided by the MXV22 controller is incorporated by the DYDRV changes listed in Appendix E. An additional change is required to the device data I/O structure. The file SYSTB. MAC created by Phase I of SYSGEN must be edited prior to assembly and task building process. Characteristic word one of the Unit Control Block (UCB) must be edited to reflect 22-bit direct addressing support for the DYDRV device. Refer to section 4 of the Guide to Writing An I/O Driver for details. An alternate method of changing the UCB is to use the utility Task/File Patch program ZAP. Use the RSX11M.MAP file to locate the UCB entries ".DYO" and ".DY1". The fifth word of these tables should be amended to include the setting of bit 8: | LOCATION | OLD VALUE | NEW VALUE | |-----------|-----------|---------------------| | .DYO + 10 | dddddd | dddddd! 400 | | .DY1 - 10 | dddddd | dddddd! <b>4</b> 00 | # 5.3.1. Modifying RXO2 Driver RSX11M Changes to the RXO2 driver program DYDRV. MAC are provided in Appendix E. The changes are referenced to the distributed Version 3.02. Changes listed in Appendix E are in the format expected by the Source Language Input Program (SLP). These change can be incorporated into the standard driver using methods described in Section 17 of the RSX-11 Utilities Manual. #### 5. 4. DOUBLE SIDED OPERATION RT-11/RSX-11M Change for RT-11 double sided support are listed in Appendices B and D. These changes can be used with the 22-bit changes. Appendix F contains the changes required for RSX-11M double sided support. #### 5.5. OPERATION WITH OTHER DEC SOFTWARE The MXV22 Controller used in 18-bit mode emulates the operation of the RXV21. This is particularly important when using programs or systems that might require access to the RXO2 type device. #### NOTE Operation of the XXDP Diagnostic program require that the MXV22 be configured to emulate the RXV21 in 18-bit mode. #### 5.6. OPERATION WITH DEC DIAGNOSTIC The MXV22 Controller operates with the following DEC XXDP Diagnostic programs: - 1. CZRXDAO RXO2 SS Performance Exercise. - 2. CZRXDBO RXO2 SS Performance Exerciser. - 3. CZRXEAO RXO2 Formatter Program. #### 5.6.1. Exceptions The following changes to the DEC RXO2 Diagostics may be required when testing the MXV22 Controller. ## Program ZRXFAO The watchdog timeout interval for the set media density function may have to be increased when the processor is an LSI 11/23 or the selected step rate is six (6) milliseconds. | LOCATION | OLD VALUE | NEW VALUE | |----------|-----------|-----------| | 002474 | 000004 | 000040 | | 012152 | 000004 | 000040 | | 032720 | 000004 | 000040 | # Appendix A ``` The following changes are for incorporating 22-bit support into RT-11 Version 4.0 of DY.MAC Edit Level 2 via the Source Language Patch program (SLP): -/. DRDEF/,,/; MXV22/ . MCALL . MTPS -/. IIF NDF DY$DD/../:MXV22/ REMOVE THIS LINE TO DISABLE 22-BIT ADDRESSING .IIF NDF $22BIT, $22BIT = 0 . IF NE $22BIT DYTYP=2000 . ENDC -/@$MPPTR/+1,,/;MXV22/ .IF EQ $22BIT -/BIS/,,/;MXV22/ . IFF MOV @SP, -(SP) ASL esp ASL @SP MOV (SP)+, EXMBIT-1 SWAB @SP BIC #^C<30000>,@SP BIS (SP)+,R4 -/. ENDC/,,/;MXV22/ . ENDC -/BUFRAD:/+3,,/;MXV22/ . IF NE $22BIT #40000, RO BIT ; BOUNDARY CROSSED? BEQ 8$ ; BRANCH IF NOT INCB EXMBIT BIC #40000, RO : REMOVE BIT -/. ENDC/, , /; MXV22/ . ENDC -/BPL DYERR2/,.,/;MXV22/ BPL 5$ ;BRIF DONE . IF NE $22BIT BIT #DYTYP, @R4 ; IN 22-BIT MODE ;BRIF NO BEQ MOV ;EXTENDED ADDRESS BITS EXMBIT-1, RO ; HOUSEKEEP CLRB RO BIS RO, R3 :INTO WORD COUNT REGISTER 65: ``` . ENDC ``` -/BPL DYERR2/,.,/:MXV22/ BPL 5$ ; BRIF DONE . IF NE $22BIT #DYTYP, eR4 BIT PROTOCOL COMPLETE BNE 3$ 2$: . IFTF -/MOV R2,/,,/;MXV22/ . IFT . MTPS #0 RESTORE STATUS . ENDC -/RTS/,,/:MXV22/ . IF NE $22BIT 3$: . MTPS #340 ; BLOCK INTERRUPTS MOV R2, @R5 MOVB EXMBIT, R2 45: MOV @R4.RO GET STATUS BIT #CSINIT!CSTR, RO ; WAIT READY/INIT BNE 2$ :LAST TRANSFER BIT #CSDONE, RO ; WAIT DONE BEQ 4$ :FOR ONE . MTPS #0 ; RESTORE STATUS . IFTF 5$: JMP DYERR2 . IFT . BYTE 0 EXMBIT: .BYTE O ;EXTENDED MEMORY ADDR BITS . ENDC -/8$:/+2,,/;MXV22/ . IF NE $22BIT BIT #DYTYP, eR4 ;22-BIT CONTROLLER? BEQ 22$ ; IF EQUAL NO! CLRB 23$ 22$: . ENDC -/MOV/,,/;MXV22/ . IF NE $22BIT 23$: BR 9$ JSR PC. WAIT ONE MORE TRANSFER FOR 22-BIT CLR 0R5 . ENDC -/WAIT:/,.,/;MXV22/ WAIT: BIT #CSINIT!CSTR, @R4; TRANSFER? BNE 11$ BITB #CSTR!CSDONE, @R4;TRANSFER OR DONE? / ``` # Appendix B The following changes are for incorporating double sided support into RT-11 Version 4.0 of DY. MAC Edit Level 2 via the Source Language Patch program (SLP): ``` -/.IIF NDF DY$DD/,,/;2SIDED/ DY$DS=1 MAXLSN=DYDSIZ*4 DBSID2=2 -/DOXFER:/,,/;2SIDED/ MOV DYLSN,R3 -/DYLSN/,.,/;2SIDED/ ``` # Appendix C ``` Version 5.0 of DY. MAC Edit Level 0 via the Source Language Patch program (SLP): -/. DRDEF/,,/;22-BIT/ . MCALL . MTPS -/DY$DD/,,/;22-BIT/ $22BIT = 1 ; REMOVE THIS LINE TO DISABLE 22-BIT ADDRESSING .IIF NDF $22BIT, $22BIT =0 ;NO 22-BIT ADDRESSING .IF NE $22BIT DYTYP = 2000 :22-BIT CONTROLLER MODE . ENDC .IIF NDF DYSDS, DYSDS = 0 ;SINGLE HEADED FLOPPY DRIVE .IIF NE DYSDS, DYSDS = 1 ;DOUBLE SIDED FLOPPY DRIVE -/JSR PC, @$MPPTR/+1, , /: 22-BIT/ .IF EQ $22BIT ; NOT A MXV22 -/BIS 35$/,,/;22-BIT/ . IFF : MXV22 MOV @SP, -(SP) :MAKE ANOTHER COPY ASL @SP ; POSITION ADDRESS INTO ASL esp :UPPER BYTE MOV (SP)+, EXMBIT-1 ;ODD ADDRESS CAPTURES ODD BYTE SWAB @SP :POSITION BITS TO 12 AND 13 BIC #^C<30000>, @SP :ISOLATE THEM BIS (SP)+, R4 ; INCLUDE IN COMMAND WORD . ENDC -/ADD #10000/,,/;22-BIT/ . IF NE $22BIT :MXV22 BIT #40000, RO ; BOUNDRY CROSSED? BEQ 8$ ; BRANCH IF NOT INCB EXMBIT :DO 22-BIT ADDRESSING BIC #40000.R0 ; REMOVE BIT . ENDC -/BFL DYERR2/,.,/;22-BIT/ BPL 5$ ;BRIF DONE .IF NE $22BIT BIT #DYTYP, @R4 ; MXV22 IN 22-BIT MODE BEQ 6$ BRIF NO YOM EXMBIT-1, RO EXTENDED ADDRESS BITS CLRB RO : HOUSEKEEP BIS RO, R3 ; INTO WORD COUNT REGISTER 6$: . ENDC ``` The following changes are for incorporating 22-bit support into RT-11 ``` -/BPL DYERR2/,.,/:22-BIT/ 5$ BPL ; BRIF DONE . IF NE $22BIT ;MXV22 BIT #DYTYP, @R4 ;PROTOCOL COMPLETE BNE 3$ ; NO 25: . IFTF -/MOV R2, /, /; 22-BIT/ . IFT .MTPS #0 ; RESTORE SAVED STATUS . ENDC -/RTS/,,/:22-BIT/ . IF NE $22BIT 3$: . MTPS ; BLOCK INTERRUPTS #340 MOV R2, @R5 MOVB EXMBIT, R2 :GET EXTENDED ADDRESS BITS 45: MOV eR4, RO GET STATUS ; WAIT READY/INIT/TRANSFER REQUEST BIT #CSINIT:CSTR, RO BNE 2$ ;LAST TRANSFER BIT #CSDONE, RO ; WAIT DONE BEQ 4$ :FOR ONE .MTPS #0 :RESTORE STATUS . IFTF 5$: JMP DYERR2 :GO PROCESS ERROR . IFT . BYTE EXMBIT: . BYTE O EXTENDED MEMORY ADDR. BITS . ENDC -/8$: JSR/+2,,/;22-BIT/ . IF NE $22BIT BIT #DYTYP, @R4 :22-BIT CONTROLLER? BEQ 22$ ; IF EQUAL NO! CLRB 23$ 22$: . ENDC -/MOV R2, /, , /; 22-BIT/ . IF NE $22BIT 235: BR 95 PC, WAIT JSR ; ONE MORE TRANSFER FOR 22-BIT CLR eR5 . ENDC -/WAIT:/,.,/;22-BIT/ WAIT: BIT #CSINIT!CSTR, @R4 ; TRANSFER? BNE 11$ BITB #CSTR!CSDONE, @R4 :TRANSFER OR DONE? 1 ``` # Appendix D The following changes are for incorporating double sided support into RT-11 Version 5.0 of DY.MAC Edit Level 0 via the Source Language Patch program (SLP): ``` -/ALT:/+1,,/;2SIDED/ DYSDS :SET DOUBLE SIDED -/DDNBLK/,.,/;2SIDED/ DDNBLK = DYDSIZ*2*<DY$DS+1> ; DOUBLE DENSITY NO. OF BLOCKS MAXLSN = DYDSIZ*4 ; MAXIMUM LOGICAL SECTORS DBSID2 = ; DOUBLE SIDED BIT 3$/,/;2SIDED/ -/BIT #ESDN, /, /BEQ . IF NE DYSDS ; DOUBLE HEADED #DBSID2, @R5 BIT ; DOUBLE SIDED DISKETTE MOUNTED BEQ 2$ ; BRIF SINGLE -/ASL/,,/;2SIDED/ 2$: . ENDC BIT #ESDN, @R5 ;SINGLE OR DOUBLE DENSITY BEQ 3$ ;BRIF SINGLE ASL @SP ; DOUBLE THE SIZE AGAIN -/DOXFER:/+1,.,/;2SIDED/ -/MOV DYLSN/,,/;2SIDED/ . IF NE DYSDS ;2 HEADS CMP R3. #MAXLSN ;SECTORS REACHED CAPACITY BLT 1$ ; NO BIS #CSHEAD, RO ; CHANGE SIDES SUB #MAXLSN, R3 ; MODULO SECTOR NUMBER 15: . ENDC MOV RO, eR4 START FUNCTION ``` # Appendix E The following changes are for incorporating 22-Bit support for RSX-11M into DYDRV.MAC Version 3.02 via Source Language Input Program (SLP): ``` -/03.02/,,/;22-BIT/ :ENABLE MXV22 CONDITIONAL CODE MXV22 -/SDEN/,,/;22-BIT/ ; 22-BIT CONTROLLER BIT ADREXT = 2000 -/M$$MGE/,,/;22-BIT/ . IF DF MXY22 . IFF -/. ENDC/,,/;22-BIT/ . ENDC -/M$$MGE/,,/;22-BIT/ . IF DF MXV22 MOVB U. BUF+1(R5), RO ; EXTENDED MEMORY BITS ROR RO ROR RO RO, I. PRM+16(R1); SAVE BA18-BA21 MOVB . REPT ROR RO . ENDM BIC #147777, RO ; ISOLATE BA16 & BA17 MOV RO, U. BUF(R5) : INITIALIZE CSR WORD . IFF -/. ENDC/, , /; 22-BIT/ . ENDC -/M$$EXT/,,/;22-BIT/ . IF DF MXV22 . IFF -/. ENDC/, , /; 22-BIT/ . ENDC -/140$:/,,/;22-BIT/ BIT #ADREXT, (R2) ; 22-BIT BEQ 145$ ; GET UPPER BYTE SWAB R1 I.PRM+16(R3), R1 : SET BA 18-21 BISB SWAB ; REPOSITION 145$: ``` ``` -/280$:/,.,/22-BIT/ BR 281$ ; TRACK NO. COULD BE 111 RO, #'I 2809: CMP ; END REGISTER PROTOCOL BEQ 285$ ; IF EQ EXIT 2815: BIT #ADREXT, (R2) ; 22-BIT CONTROLLER ? BEQ 285$ : IF EQ NO MTPS #340 ;;; BLOCK INTERRUPTS MOV RO, RXDB(R2) ;;; BUFFER ADDRESS 283$: BIT #TR!INIT, (R2) ;;; READY FOR LAST WORD ? BNE 284$ BITB #TR!DONE, (R2) ;;; READY FOR LAST WORD ? BEQ 283$ ;;; BMI 284$ ;;; MTPS #0 ;;; BR 160$ ; ERROR, NO TRANSFER REQUEST 284$: MOV I.PRM+16(R3), RO ;;; EXTENDED ADDRESS BITS 285$: MOV RO, RXDB(R2) ; OR ;;; LOAD TRACK, BUFFER ;;; ADDRESS, OR ASCII I MTPS #0 ; OR ;;; -/#10000/,,/;22-BIT/ . IF DF MXV22 BIT #40000, U. BUF(R5); CHECK FOR OVERFLOW BEQ ; NOT YET BIC #40000, U. BUF(R5) ; HOUSEKEEP INC I.PRM+16(R3) ; UPDATE BA18-BA21 135: . ENDC / ``` # Appendix F ``` The following changes are for incorporating double sided support for RSX-11M into DYDRV. MAC Version 3.02 via Source Language Input Program (SLP): -/03.02/,,/;22-BIT/ -/RSAE/,,/;2SIDED/ SSIDED = 20000 SECOND SIDE INDICATOR BIT (U.CW2) -/DOUBLE/,,/;2SIDED/ DOUDOU = 1976. ; DOUBLE SIDED & DOUBLE DENSITY -/SDEN/,,/;2SIDED/ DSIDED = 1000 ; DOUBLE SIDED BIT (U.CW2) -/CRCERR/,,/;2SIDED/ SIDES ; DOUBLE SIDED MEDIA -/220$:/,,/;2SIDED/ BIT #SSIDED, U. CW2(R5); IS IT SECOND SIDE OPERATION? BEQ 225$ ; IF EQ NO BIS #DSIDED, U. BUF(R5); USE SECOND SIDE 2255: -/420$:/,.,/;2SIDED/ #SILO:SCHAR:SSIDED:ERR1, U. CW2(R5); CLEAR BITS -/440$:/,.,/;2SIDED/ ; RETRY WITH CORRECT DENSITY TO ENSURE VALID DISKETTE STATUS MOV #DEN, RO ; CHANGE DENSITY FOR RETRY XOR RO. U. CW2(R5) ; SET UP DENSITY BIT IN U.CW2(R5) BR DYSEC : TRY AGAIN 4405: BIC #SCHAR!DEN!DSIDED, U. CW2(R5); CLEAR FLAGS -/450$:/,.,/;2SIDED/ 450$: #SIDES, I. PRM+6(R1); IS IT DOUBLE SIDED? BIT BEQ : IF EQ NO MOV #DOUDOU, U. CW3(R5) : DOUBLE THE MAXIMUM LBN'S BIS #DSIDED, U. CW2(R5); SET THE DOUBLE SIDED BIT 455$: MOV #IS.SUC&377,RO ; SET SUCCESS -/460$:/,.,/;2SIDED/ 460$: BIT #DEN, U. CW2(R5) ; CHECK FOR CORRECT DENSITY BEQ 465$ ; SINGLE DENSITY BIS #SDEN. RO : SET UP DOUBLE DENSITY 465$: MOV RO, (R2) ; INITIATE FUNCTION ``` ``` -/560$:/,.,/;2SIDED/ 560$: #SIDES, I. PRM-6(R1); IS IT DOUBLE SIDED? BIT BEQ ; IF EQ NO #DSIDED, U. CW2(R5) ; SET DOUBLE SIDED BIT BIS MOV #DOUDOU, U. CW3(R5) ; DOUBLE MAX LBN'S 565$: RO, I. PRM+10(R1); STORE LOGICAL SECTOR NUMBER MOV -/#INTEBL/,.,/;2SIDED/ -/MOVB/,,/:2SIDED/ BIS #INTEBL, (R2) ; ENABLE INTERRUPTS -/, #77./,/BHI/,/;2SIDED/ CMP RO, #76. ; IS IT SECOND SIDE? -/BITB/,,/;2SIDED/ BEQ 23$ ; IF EQ NO, IT'S A LOGICAL BLOCK CMP #76.,RO ; YES BEQ 30$ ; IF EQ ALLOW ACCESS TO #76. SUB #77.,RO ; CHANGE SIDES - PHYBLK ACCESS BR 25$ ; CHANGE READ HEADS 23$: SUB #76.,RO ; ADJUST FOR SECOND SIDE 25$: BIT #DSIDED, U. CW2(R5); TWO SIDE MEDIA? -/BEQ/,,/;2SIDED/ BIS #SSIDED, U. CW2(R5); SET HEAD 1 SELECT BIT 1 ``` 5065 East Hunter Avenue Anaheim, California 92807