## MODEL DQ614 DISC CONTROLLER INSTRUCTION MANUAL # ## MODEL DQ614 DISC CONTROLLER INSTRUCTION MANUAL **April 1983** Copyright ©1983 by Distributed Logic Corporation Printed in the United States of America ### TABLE OF CONTENTS | Section | | Pag | |---------------------------------|-----------------------------------------------------------------------|--------------| | 1 | DESCRIPTION | 1- | | | Introduction | . 1- | | | Controller Characteristics | . 1- | | | LSI-11 Q Bus Interface | . 1- | | | Interrupt | 1- | | | Disc Interface | 1- | | · . · · · · · · · · · · · · · · | Operating System Compatibility | 1- | | | Controller Specifications | | | 2 | INSTALLATION | 2- | | | Inspection | 2-3 | | | Pre-Installation Checks | 2-: | | | Installation | | | 3 | OPERATION | 3-1 | | | Introduction | 3-1 | | | Precautions and Preoperation Checks | 3-1 | | | Bootstrap Switches | 3-1 | | | Bootstrap Procedure | 3-1 | | | Format and Test Programs | 3-1 | | | Diagnostic Test Program | 3-4 | | | Test Controller Test Disc Drive | 3-4<br>3-4 | | | Format | ე-4 | | 7 | Sequential Read | 3-5 | | | Selected Read | 3-5 | | | Random Seek, Read | 3-5 | | | Random Seek, Write Data, Read Data, Compare Test | 3-5 | | | Test ECC Logic | 3-5 | | | Assign Alternate Track | 3-6 | | 4 | PROGRAMMING | 4-1 | | | Programming Definitions | 4-1 | | | Operations | 4-1 | | | Interrupts | 4-2 | | | Diagnostic | 4-2 | | | Control/Status Register | 4-3 | | | Bus Address Register | 4-4 | | | Disc Address Register | 4-5 | | | RLDA on a SEEK Command | 4-5 | | | RLDA on a READ or WRITE Data Command RLDA on a GET STATUS Command | 4-5 | | | Multipurpose Register | 4.6 | | | During Read/Write Command for Word Count | 4-0<br>4-7 | | | During a Get Status Command | 4-7 | | | Address Extension Register | 4-8 | | 5 | TROUBLESHOOTING AND THEORY | | | | Basic System Troubleshooting | 5-1<br>5-1 | | | Controller Symptoms | 5-1 | | | Physical Layout | 5-1<br>5-1 | | | Term Listing | 5-1 | | | Adjustment Procedure for Data Separator | 5-1 | | | Theory | 5-6 | | | Computer Interface | 5-6 | | | Microprocessor Functions | 5-7 | | | RAM Data Buffer | 5-8 | | | Peripheral Interface-Write Data Path | 5-8 | | · • • • | ECC — Write | 5-8 | | | MFM — Write | 5-8 | | | Peripheral Interface — Read Data Path Phase I calcad I can Pead Data | 5-14 | | | Phase-Locked Loop — Read Data | | | | ECC — Read | 2 1 G | | | Clocks | 7-10<br>5-16 | | 3 | LOGICS | )-TO | ## ILLUSTRATIONS | Figure | | Page | |------------|-----------------------------------------------|------------| | 1-1 | Disc Controller System Simplified Diagram | . 1-1 | | 2-1 | Controller Configuration | . 2-2 | | 2-2 | Typical Backplane Configuration | 2-4 | | 4-1 | Register Summary | 4-2 | | 5-1 | Board Layout | 5-3 | | 5-2 | Simplified Block Diagram | 5-6 | | 5-3 | Ram Address Chip Select Timing | 5-9 | | 5-4 | Write Data Path | 5-10 | | 5-5 | Write Timing PAL002 | 5-11 | | 5-6 | ECC Timing | 5-11 | | 5-7 | MFM Timing | 5-19 | | 5-8 | Peak Shift | 5 10 | | 5-9 | Address Mark and KILL Timing | 5 19 | | 5-10 | Read Data Path | 9-19 | | 5-11 | Simplified Diagram of Phase-Locked Loop | 0-14 | | 5-12 | PLL Timing with No Phase Error | 9-19 | | 5-13 | PLL Timing with Phase Error | 9-19 | | 5-14 | Byte Clock Control | 9-10 | | 5-15 | Clocks | 5-17 | | 0.10 | Clocks | 5-17 | | | | | | | TABLES | | | Table | | Page | | | | | | 1-1 | Controller/Q-Bus Interface Lines | 1-2 | | 1-2 | Controller to Drive I/O Interface — "A" Cable | 1-3 | | 1-3 | Controller to Drive Data Cable — "B" Cable | 1-4 | | 2-1 | Configuration Switches | 2-3 | | 2-2 | Component and Jumper Options | 2-3<br>0 0 | | - <b>-</b> | Component and a uniper Options | 2-3 | | 5-1 | Controller Symptoms | 5-2 | | 5-2 | Term Listing | 5-4 | | 5-3 | Enable Precompensation | 5-10 | #### SECTION 1 DESCRIPTION #### INTRODUCTION This manual describes the installation, operation, programming, troubleshooting, and theory of operation of Distributed Logic Corporation (DILOG) Model DQ614 Disc Controller. The controller interfaces DEC\* LSI-11 based computer systems to ST506 compatible Winchester disc drives. The complete controller occupies one dual-wide module in the backplane. Full sector buffering in the controller matches the transfer rate of the disc drive and the CPU. The controller is software compatible with DEC drivers, emulating RL01/RL02 drives. #### CONTROLLER CHARACTERISTICS The disc controller links the LSI-11 computer to one or two disc storage units. Commands from the computer are received and interpreted by the controller and translated into a form compatible with the disc units. Buffering and signal timing for data transfers between the computer and the discs are performed by the controller. A microprocessor is the sequence and timing center of the controller. The control information is stored as firmware instructions in read-only-memory (ROM) on the controller board. One section of \*DEC is a registered trademark of Digital Equipment Corporation. the ROM contains a diagnostic program that tests the functional operation of the controller. This self-test is done automatically each time power is applied or under operator control by pressing the RESET switch. A green diagnostic indicator on the controller board lights if self-test passes. Data transfers are directly to and from the computer memory using the DMA facility of the LSI-11 I/O bus. In addition, the controller monitors the status of the disc units and the data being transferred and presents this information to the computer upon request. An error correction code (ECC) with a 32-bit checkword corrects error bursts up to 11 bits. To compensate for media errors, bad sectors are skipped and alternates assigned, and there is an automatic retry feature for read errors. The controller is capable of addressing two megawords and controlling up to two disc drives in various configurations up to a total on-line capacity of 40 megabytes. Figure 1-1 is a simplified diagram of a disc system. #### LSI-11 Q BUS INTERFACE Commands, data and status transfers between the controller and the computer are executed via the parallel I/O bus (Q bus) of the computer. Data transfers are direct to memory via the DMA facility of the Q bus; commands and status are under programmed I/O. Controller/Q bus interface lines are listed in Table 1-1. Figure 1-1. Disc Controller System Simplified Diagram Table 1-1. Controller/Q-Bus Interface Lines | BUS PIN | MNEMONIC | INPUT/<br>OUTPUT | | |-----------------------------------------------------------------------------------------|----------------------------------------------|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------| | AJ1, AM1, RT1, BJ1,<br>BM1, BT1, BC2, CJ1,<br>CM1, CT1, CC2, DJ1,<br>DM1, DT1, DC2 | GND | 0 | Signal Ground and DC return. | | AN1 | BDMR L | 0 | Direct Memory Access (DMA) request from controller: active low. | | AP1 | BHALT L | N/A | Stops program execution. Refresh and DMA is enabled. Console operation is enabled. | | AR1 | BREF L | N/A | Memory Refresh. | | BA1 | BDCOK H | ı | DC power ok. All DC voltages are normal. | | BB1 | врок н | N/A | Primary power ok. When low activates power fail trap sequence. | | BN1 | BSACK L | 0 | Select Acknowledge. Interlocked with BDMGO indicating controller is bus master in a DMA sequence. | | BR1 | BEVNT L | N/A | External Event Interrupt Request. | | BV1, AA2, BA2, CA2,<br>DA2 | +5 | I | + 5 volt system power. | | AD2, BD2 | + 12 | N/A | + 12 volt system power. | | AE2 | BDOUT L | I/O | Data Out. Valid data from bus master is on the bus. Interlocked with BRPLY. | | AF2 | BRPLY L | 1/0 | Reply from slave to BDOUT or BDIN and during IAK. | | AH2 | BDIN L | 1/0 | Data Input. Input transfer to master (states master is ready for data). Interlocked with BRPLY. | | AJ2 | BSYNC L | 1/0 | Synchronize: becomes active when master places address on bus; stays active during transfer. | | AK2 | BWTBT L | 1/0 | Write Byte: indicates output sequence to follow (DATO or DATOB) or marks byte address time during a DATOB. | | AL2 | BIRQ L | | Interrupt Request. | | AM2<br>AN2<br>CM2<br>CN2 | BIAK1I L<br>BIAK1O L<br>BIAK2I L<br>BIAK2O L | 0 | Serial Interrupt Acknowledge input and output lines routed from Q-Bus, through devices, and back to processor to establish and interrupt priority chain. | | AT2 | BINIT L | i i | nitialize. Clears devices on I/O bus. | | AU2, AV2, BE2, BF2,<br>BH2, BJ2, BK2, BL2,<br>BM2, BN2, BP2, BR2,<br>BS2, BT2, BU2, BV2 | BDAL0 L<br>through<br>BDAL15 L | 1/0 | Data/address lines, 0-15. | | AR2<br>AS2<br>CR2<br>CS2 | BDMG11 L<br>BDMG10 L<br>BDMG21 L<br>BDMG20 L | 0 0 | OMA Grant Input and Output. Serial DMA priority line from computer, through devices and back to computer. | | AP2 | BBS7 L | I E | Bank 7 Select. Asserted by bus master when address in upper 4K bank is placed on the bus. | | AC1, AD1, BC1, BD1,<br>BE1, BF1 | BDAL 16 L<br>-BDAL 21 L | O E | xtended Address Bits 16-21 | #### INTERRUPT The interrupt vector address is factory set to address 160. The vector address is programmed in a PROM on the controller, allowing user selection. Interrupt requests are generated under the following conditions: - 1. A hard error occurs. - 2. A soft error occurs. Soft errors are checksum errors (CSE). - The designated number of words has been transferred. - 4. A selected disc drive has accepted a seek or drive reset command. - 5. A seek or drive reset function has been completed. #### DISC INTERFACE The controller interfaces with one or two disc drives through 34- and 20-pin cables. If two drives are used, the 34-pin control cable is daisy chained to drive 0 and 1. The 20-pin data cables are connected separately from the controller to each drive. The maximum cable length is 20 feet. Table 1-2 lists the control interface signals. Table 1-3 lists the data interface signals. #### OPERATING SYSTEM COMPATIBILITY RT11: The emulation is transparent to the RT11 version 4.0 operating system, using the standard device handler supplied by DEC. RSX11\*: The emulation is transparent to the RSX11 version 4.0 operating system, using the standard device handler supplied by DEC. RSTS\*: The emulation is transparent to the RSTS version 7.1 operating system, using the standarad device handler supplied by DEC. #### CONTROLLER SPECIFICATIONS† - Mechanical The DQ614 is completely contained on one dual module 8.62 inches high by 5.19 inches wide and plugs into and requires one dual slot in any DEC LSI-11 backplane. - Computer I/O— - Register Addresses (PROM selectable) - Control/Status Register (RLCS) 774 400 - Bus Address Register (RLBA) 774 402 - Disc Address Register (RLDA) 774 404 - Multipurpose Register (RLMP) 774 406 - Address Extension Register (RLAE) 774 410 - Data Transfer - Method: DMA - Maximum block size transferred in a single operation is 16K words. - Bus Load - 1 std unit load - Address Ranges - Computer Memory: to 2 megawords - Interrupt Vector—Four interrupt levels jumper selectable. Factory set to Address 160, level 5. - \*RSX and RSTS are registered trademarks of Digital Equipment Corporation. Table 1-2. Controller To Drive I/O Interface — "A" Cable | | <del></del> | | |--------------------------------|-------------|------------| | Signal Name (DILOG Term) | Pin | Source | | Ground | 1 | | | REDUCE WRITE CURRENT | | | | (REDUCE I) | 2 | Controller | | Ground | 3 | | | HEAD SELECT 3 (HESL3) | 4 | Controller | | Ground | 5 | | | WRITE GATE | 6 | Controller | | Ground | 7 | | | SEEK COMPLETE (SEEK COMP) | 8 | Drive | | Ground | 9 | | | TRACK 0 | 10 | Drive | | Ground | 11 | | | WRITE FAULT (FAULT) | 12 | Drive | | Ground | 13 | | | HEAD SELECT 1 (HESL1) | 14 | Controller | | Ground | 15 | | | SELECT/NOT USED | 16 | Drive | | Ground | 17 | _ | | HEAD SELECT 2 (HESL2) | 18 | Controller | | Ground | 19 | | | INDEX | 20 | Drive | | Ground | 21 | | | READY | 22 | Drive | | Ground<br>STEP | 23 | | | | 24 | Controller | | Ground | 25 | | | DRIVE SELECT 1 (DRSL1) Ground | 26 | Controller | | | 27 | | | DRIVE SELECT 2 (DRSL2) | 28 | Controller | | Ground | 29 | | | DRIVE SELECT 3 (DRSL3) | 30 | Controller | | Ground | 31 | | | NOT USED | 32 | | | Ground | 33 | | | DIRECTION IN | 34 | Controller | - Disc Drive I/O - Connector—One 34-pin flat ribbon cable and two 20-pin flat ribbon cables. - Signal: ST506 compatible - Power: +5 volts @ 3.5 amps (typical), +12 volts at 300 milliamps from computer power supply. - Environment: Operating temperature 0°C to 45°C., humidity 0 to 70% non-condensing. - Shipping Weight: 5 pounds including documentation and cables. - Shock—Non-repetitive of less than 0.5G. †Specifications subject to change without notice. Table 1-3. Controller to Drive Data Cable — "B" Cable | Signal | Pin | J2<br>Term | J3<br>Term | Source | |----------------|-----|---------------------------------------|-----------------------|------------| | DRIVE SELECTED | 1 | DRIVE SELECTED<br>UNIT 0 | DRIVE SELECTED UNIT 1 | Drive | | Ground | 2 | _ | - | _ | | Reserved | 3 | _ | | | | Ground | 4 | | _ | _ | | Reserved | 5 | · · · · · · · · · · · · · · · · · · · | _ | _ | | Ground | 6 | <del></del> : | | | | Reserved | 7 | | | | | Ground | 8 | · | _ | | | Reserved | 9 | _ | _ | | | Spare | 10 | | <u>-</u> | | | Ground | 11 | _ | _ | | | Ground | 12 | | | | | WRITE DATA + | 13 | WDAT0 + | WDAT1 + | Controller | | WRITE DATA - | 14 | WDAT0 - | WDAT1 - | Controller | | Ground | 15 | | | | | Ground | 16 | . <del></del> | _ | | | READ DATA + | 17 | RDAT0 + | RDAT1 + | Drive | | READ DATA - | 18 | RDATO - | RDAT1 - | Drive | | Ground | 19 | | <u></u> | | | Ground | 20 | _ | | | #### SECTION 2 INSTALLATION #### INSPECTION The padded shipping carton that contains the controller board also contains an instruction manual and may contain cables if this option is exercised. The controller is completely contained on the dual-size printed circuit board. Disc drives, if supplied, are contained in separate shipping cartons. Inspect the controller and cables for damage. #### CAUTION If damage to any of the components is noted, do not install. Immediately inform the carrier and DILOG. Installation instructions for the disc drive are contained in the disc drive manual. Before installing any components of the disc system, read Sections 1, 2 and 3 of this manual. Figure 2-1 illustrates the configuration of the controller. Table 2-1 lists the configuration switch setting, and Table 2-2 lists component and jumper options. Ensure the board is properly configured before installing. #### PRE-INSTALLATION CHECKS There are various LSI-11 configurations, many of which were installed before DEC made a hard disc available for LSI-11 based systems. Certain configurations require minor modifications before operating the disc system. These modifications are as follows: - A. If the system contains a REV11-C module, it must be placed closer to the processor module (higher priority) than the controller if the DMA refresh logic on the REV11-C is enabled. - B. If the 4K memory on the DK11-F is not used and the memory in the system does not require external refresh, the DMA refresh logic on the REV11-C should be disabled by removing jumper W2 on the REV11-C module. - C. If the system contains a REV11-A module, the refresh DMA logic must be disabled since the module must be placed at the end of the bus (REV11-A contains bus terminator). - D. If the REV11-C module is installed, cut the etch to pin 12 on circuit D30 (top of board) and add a jumper between pin 12 and pin 13 of D30. - E. If the system requires more than one backplane, place the REV-11 terminator in the last available location in the last backplane. #### INSTALLATION To install the controller module, proceed as follows: #### **CAUTION** Remove DC power from mounting assembly before inserting or removing the controller module. Damage to the backplane assembly may occur if the controller module is plugged in backwards. Select the backplane location into which the controller is to be inserted. Be sure that the disc controller is the lowest priority DMA device in the computer except if the DMA refresh/bootstrap ROM option module is installed in the system. The lowest priority device is the device farthest from the processor module. Note that the controller contains a bootstrap ROM. #### NOTE The controller may be inserted into any A-B connector slot, all of which are Q-bus slots. On some backplanes, C-D slots may be Q-bus slots or may be interconnect slots. Before inserting the controller in any C-D slot, check the appropriate DEC documentation. There are several backplane assemblies available from DEC and other manufacturers. Figure 2-2 shows typical backplane configurations. Note that the processor module is always installed in the first location of the backplane or in the first location in the first backplane of multiple backplane systems. It is important that all option slots between the processor and the disc controller be filled to ensure that the daisy-chained interrupt (BIAK) and DMA (BDMG) signal be complete to the controller slots. If there must be empty slots between the controller and any option boards, the following backplane jumpers must be installed: | FROM | ТО | SIGNAL | |--------------------------|--------------------|----------------------| | C0 x N2<br>C0 x S2 | C0 × M2<br>C0 × R2 | BIAK1/L0<br>BDMG1/L0 | | <b>†</b> | 1 | <i>55</i> | | Last Full<br>Option Slot | Controller Slot | | | | | | Figure 2-1. Controller Configuration Table 2-1. Configuration Switches | SWITCH | POSITION | DESCRIPTION | | | | |------------|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | S1 | ON | The ECC syndrome is saved during a read operation. Upon detection of an error, the controller can use the syndrome to determine if the error is correctable. If correctable, the controller will transparently correct the error. | | | | | | OFF | The ECC syndrome is discarded during a read operation. Upon detection of an error, the controller will determine that the error is uncorrectable (because of the lack of proper syndrome). This mode should be used by the operator when running diagnostics, so that all media flaws can be detected and mapped out. | | | | | <b>S</b> 2 | ON<br>OFF | Controller bootstrap enabled. Controller bootstrap disabled. | | | | | S3, S4 | | Identify, to the microprocessor, the last logical RL unit that exists on physical drive zero: SW3 SW4 PHYSICAL ZERO PHYSICAL ONE | | | | | | | OFF OFF DL0 DL1, DL2, DL3 OFF ON DL0, DL1 DL2, DL3 ON OFF DL0, DL1, DL2 DL3 ON ON DL0, DL1, DL2, DL3 | | | | | <b>S</b> 5 | ON | Controller assumes alternate address for bootstrap ROM of 175 000. (Must be used for LSI 11/23 plus CPU, module M8189.) | | | | | | OFF | Controller assumes primary address for bootstrap ROM of 173 000 | | | | When shipped from the factory, all switches will be off if the order is for a controller only. If the order is for drive integration, the switches will be set for that configuration. Table 2-2. Component and Jumper Options | OPTION | LOCATION | DESCRIPTION | | | | |-----------------------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | Special Bootstrap* | U38 | PROM—allows the user to incorporate bootstrap programs not supported by DILOG. | | | | | Loop back data stream | U22-U23 | JP1—Jumper removed (etch cut) forces the write logic to create a data stream which can be looped back into the read logic. Troubleshooting aid. | | | | | Abort Precompensation | U32 | JP2—Jumper removed (etch cut) aborts the controller precompensation logic when writing data. Troubleshooting aid. | | | | | Interrupt Level | U70 | JP3, JP4, JP5—This option consists of cutting etches and installing wires. For the interrupt levels, the jumpers are connected as follows: | | | | | | | JP3 JP4 JP5 | | | | | | Inter<br>Inter | rupt Level 4 B-C B-C B-C rupt Level 5 B-C B-C A-B rupt Level 6 B-C A-B B-C rupt Level 7 A-B A-B B-C | | | | <sup>\*</sup> If the special bootstrap option is required, the sales order should indicate this. The loop back data stream and abort precompensation will not have the etch cut when shipped. The interrupt level shipped from the factory is Level 5, Address 160. 2. To the controller connectors, install cables J1, J2, and J3, respectively. Ensure the pin 1's are oriented as shown in the illustration. #### Note It may be necessary to remove the strain relief bar on the J3 cable to install the connector. 3. Gently position the module slot connectors into the backplane and press until the connectors are firmly seated into the backplane. - Apply equal pressure to both sides of the controller when installing or removing. - 4. Route the cables to the drive; assure pins are properly aligned; and connect the cables. Ensure that the bus terminator is installed in the last drive in the system. - 5. Refer to the disc drive manual, the computer manual, and Section 3 of this manual, for operating instructions. #### DDV11-B BACKPLANE MODULE INSERTION SIDE NOTE MEMORY CAN BE INSTALLED IN ANY SLOT; IT IS NOT PRIORITY DEPENDENT AND DOES NOT NEED TO BE ADJACENT TO THE PROCESSOR. CONTROLLERS ARE ALSO COMPATIBLE WITH H9273A MODULES. Figure 2-2. Typical Backplane Configuration ## SECTION 3 OPERATION #### INTRODUCTION This section contains procedures for operating the computer system with the controller and a disc drive or drives. An understanding of DEC operating procedures is assumed. ## PRECAUTIONS AND PREOPERATIONAL CHECKS The following precautions should be observed while operating the system. Failure to observe these precautions could damage the controller, the disc, the computer, or could erase a portion or all of the stored software. - 1. Ensure all switches listed in Table 2-1 are properly set. - 2. Ensure all jumpers listed in Table 2-2 are properly installed. - 3. Verify that the controller board is firmly seated in the backplane connection. - 4. Verify that the cables are properly installed in the controller and in the disc drive. - 5. Apply power to the drive, the computer and the terminal. - 6. Verify that the green diagnostic LED on the edge of the controller board lights. #### **BOOTSTRAP SWITCHES** When switch 2 is on (closed), the controller bootstrap is enabled. The DILOG program will boot the system for RL01/RL02 or RX02 Floppy disc dual density. When switch 2 is off (open), the bootstrap is disabled, and the controller will boot from the standard DEC REV-11 module. When switch 5 is on (closed), the controller will assume the alternate address 175000 for the bootstrap ROM. When switch 5 is off (open), the controller will assume the primary address 173000 for the boostrap ROM #### Note If a system has more than one device with bootstrap capabilities enabled, the bootstraps must be at different addresses. #### **BOOTSTRAP PROCEDURE** The following assumes the system is in ODT mode. Note that the bootstrap can be used under processor Power Up Mode 2 conditions. Refer to the appropriate DEC manual for a discussion of the Power Up Modes. Further note that the disc drive does not need to be READY to enter the bootstrap. Reset the system by pressing RESET or enter the following (characters underlined are output by the system; characters not underlined are input by the operator): - <u>@</u> 173000G or 175000G Depends on switch and jumper configuration above. - \* Respond for appropriate logical unit with DY0 or DY1 <CR> for RX02 or DL0, DL1, DL2 or DL3 <CR> if RL01/RL02. #### FORMAT AND TEST PROGRAMS To format the disc, the operator identifies the drive type, the emulation (RL01 or RL02) and the alternate cylinders required, and the program basically does the rest. For testing, the operator identifies the test and the unit, and the program exercises the system. To run the program, load the medium and enter R DQ614 after the program is loaded. The following will appear: ARE YOU RUNNING THE DIAGNOSTIC VIA A CRT. (Y OR N)? ENTER NUMBER OF DRIVES ON SUB-SYSTEM (1 OR 2)? If the answer to the first question is no, the program will not list current cylinder addresses (a printout, for example, would be too extensive). To the second question, answer 1 or 2. The disc drive menu will appear next listing a sequential number, the name of the manufacturer and the model number. The following will also appear: XXX DRIVE (0 or 1) XXX ENTER THE NUMBER CORRESPONDING TO THE DISC DRIVE. OR The number to be entered is the sequence number on the list not the model number. Manufacturers and models are listed below. Select the next page of the menu by pressing N or the previous page by pressing P. If the drive to be formatted is not listed in the menu, press E and the following will appear: ENTER NUMBER OF HEADS (D) ENTER NUMBER OF CYLINDERS(D) REDUCE WRITE CURRENT AT CYLINDER (NOT USED) Default <CR> START PRECOMPENSATION AT CYLINDER (NOT USED) ENTER NUMBER CORRESPONDING TO PROPER STEP RATE: 1 = 26 US 2 = 280 US 3 = 2.1 MS 4 = 3.0 MS The information above is taken from the manufacturer's specifications. Head and cylinder number are entered in decimal (D). Write current and precompensation requests do not require responses for all drives. If no response is required, press the carriage return for an answer. For the step rate, enter the sequence number and not the timing value. After the drive is selected, the disc configuration will be selected: DISC CONFIGURATION XXX DRIVE 0 XXX ENTER NUMBER CORRESPONDING TO THE TYPE OF RL UNIT 1 = RL01 (10240 Blocks; XXX CYLINDERS) 2 = RL02 (20480 Blocks; XXX CYLINDERS) (XXX) = CYLINDERS NOT YET ALLOCATED YOU HAVE XXX CYLINDERS USE THE <TAB> TO ENTER TYPE OF RL UNIT CARRIAGE RETURN COMPLETES CONFIGURATION PROCEDURE DL0: ( ) DL1: ( ) DL2: ( ) DL3: Use the tab when entering the type of RL unit (1 or 2). Use the carriage return to exit after a physical drive is partitioned. The program will automatically calculate the number of cylinders remaining after the selection of the RL unit. The operator has the option of selecting a truncated unit or allocating the remaining cylinders as alternates, or a combination of both. If the remainder is less than 1 megabyte, the program automatically allocates the remainder as alternates. The alternate cylinders that are allocated are for the physical drive and not the logical unit. The operator allocates the alternate cylinders and the program calculates and allocates the truncated unit. The following is an example: The first logical unit is to be an RL01 and there are 65 cylinders remaining, 5 of which are to be alternates and 60 truncated. The following underlined numbers or keys are entered: DL0: <u>1<TAB></u> (65) DL1: <u><CR></u> ( )DL2: ( ) DL3: ENTER NUMBER OF ALTERNATE CYLINDERS (D)? 5 < CR> #### Note If there is no tab on the terminal, use control I. If two drives are selected, the cursor may appear at DL1, DL2, or DL3, depending upon how many logical units are selected. In the previous example, if two drives are selected, the cursor will be positioned at DL2. A truncated unit of 60 cylinders will appear in DL1. The following will appear: DL0: 1 (65) DL1: ( ) DL2: ( ) DL3: When all logical units are partitioned, the summation message will be similar to the following: #### DISC SUBSYSTEM CONFIGURATION | LOGICAL | PHYSICA: | L | RECORD | |----------------|----------|-----------|--------| | UNIT | DRIVE | MEGABYTES | SIZE | | DL0 | 0 | 10.48 | 20480 | | DL1 | 0 | 4.17 | 8160 | | $\mathbf{DL2}$ | 1 | 5.24 | 10240 | | DL3 | 1 | 5.24 | 10240 | PHYSICAL DRIVE 0 HAS 30 ALTERNATE TRACKS PHYSICAL DRIVE 1 HAS 54 ALTERNATE TRACKS SET SWITCH 3 OFF SET SWITCH 4 ON ARE YOU SURE (Y OR N)? Partitioning is then completed. 1. AMPEX PYSIX 8 The following is a partial list of manufacturers and model numbers that can be formatted: 11. EVOTEK ET-5510 | | | | | 7 ( C 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | |---|----|-------------------|-----|-------------------------------------------| | | | AMPEX PYSIX 13 | 12. | ET-5520 | | | | AMPEX PYSIX 16 | 13. | ET-5530 | | | | | 14. | ET-5540 | | | 5. | AMPEX PYSIX 27 | 15. | FUJITSU M2231A | | | 6. | COMPUTER | 16. | FUJITSU M2232A | | | | MEMORIES CMI-5410 | 17. | INTERNATIONAL | | | 7. | CMI 5412 | | <b>MEMORIES IMI-5006</b> | | | 8. | CMI 5616 | 18. | IMI-5006H | | | 9. | CMI 5619 | 19. | IMI-5012H | | 1 | 0. | CMI 5640 | 20. | IMI-5018H | | | | | | | | 21. MINISCRIBE 1006 | 46. RMS/DISCTRON 519 | |----------------------------------------------------------------------|-----------------------| | 22. MINISCRIBE 1012 | 47. RMS/DISCTRON 526 | | 23. MINISCRIBE 3006 | 48. SEAGATE ST406 | | 24. MINISCRIBE 3010 | 49. SEAGATE ST412 | | 25. MINISCRIBE 4010 | 50. SEAGATE ST419 | | 26. MINISCRIBE 4020 | 51. SEAGATE ST506 | | 27. MITSUBISHI 4861 | 52. SHUGART SA602 | | 28. MITSUBISHI 4862 | 53. SHUGART SA604 | | 29. MITSUBISHI 4863 | 54. SHUGART SA606 | | 30. OLIVETTI HD562/11 | 55. SYQUEST SO306 | | 31. RODIME 102<br>32. RODIME 104<br>33. RODIME 202 | 56. TANDON 602E | | 32. RODIME 104 | 57. TANDON 602S | | 33. RODIME 202 | 58. TANDON 603E | | 34. RODIME 203<br>35. RODIME 204<br>36. RODIME 206<br>37. RODIME 208 | 59. TANDON 603S | | 35. RODIME 204 | 60. TEXAS INSTRU- | | 36. RODIME 206 | MENTS TI-506 | | 37. RODIME 208 | 61. TI-525/61 | | 38. RMS/DISCTRON 503 | 62. TI-525/122 | | 39. RMS/DISCTRON 504 | 63. ATASI 3020 | | 40. RMS/DISCTRON 506 | 64. ATASI 3033 | | 41. RMS/DISCTRON 509 | 65. ATASI 3046 | | 42. RMS/DISCTRON 512 | 66. OLIVETTI HD562/13 | | 43. RMS/DISCTRON 513 | 67. MEMOREX 306 | | 44. RMS/DISCTRON 514 | 68. MEMOREX 310 | | 45. RMS/DISCTRON 518 | | | | | #### DIAGNOSTIC TEST PROGRAM The format/test program contains the following: - 1. TEST CONTROLLER - A. Registers - B. Data Buffer - 2. TEST DISC DRIVE - A. Disc Ready - B. Disc Restore (seek to cylinder 0) - 3. FORMAT - A. Write Headers - B. Read Headers - C. Write Data Test Pattern - D. Read Data Test Pattern - 4. SEQUENTIAL READ - 5. SELECTED READ - 6. RANDOM SEEK, READ - 7. RANDOM SEEK, WRITE, READ, AND COMPARE - 8. TEST ECC LOGIC - 9. ASSIGN ALTERNATE TRACK #### Test Controller The program will automatically test the controller registers and data buffer. The program will only display error messages during this test; the display will be: #### DATA BUFFER ERROR or the mnemonics of the seven controller registers, the location and contents (in Octal). The display of the registers is followed by a 4-line message to aid in isolating the specific problem. #### Note Whenever an error occurs and the registers are displayed, an audio alarm signal is generated to notify the operator. The 4-line message is as follows: | DISC ADDRESS | HEAD | |----------------------|------| | CYLINDER | | | TYPE OF COMMAND | | | CONTROL STATUS ERROI | R | | DRIVE STATUS | | "DISC" lists the head and cylinder (in decimal) where the error occurred. An example of Type of Command is Read Data Command. An example of Control Status is Seek Error. The Drive Status will display: USE C TO CONTINUE USE O TO TRANSFER TO ODT USE L TO REBOOT YOUR SYSTEM "C" is used to continue the test. "O" is used for ODT (on-line debugging technique), "L" is used to initiate the system bootstrap. #### **Test Disc Drive** After the controller test is performed, the program will automatically test the drive for ready and restore. The disc address is not displayed during this test. #### **Format** The operator may either select logical units sequentially or select one or more specific logical units to be formatted. Program messages are presented for formatting in logical unit number sequence, i.e.: FORMAT DL0 (Y OR N)? FORMAT DL1 (Y OR N)? FORMAT DL2 (Y OR N)? FORMAT DL3 (Y OR N)? FORMAT ALTERNATE CYLINDERS (DRIVE 0 OR DRIVE 1) #### Note Before any write operation, the program will display ARE YOU SURE? This aids the operator in preventing reformatting of a previously formatted logical unit (possibly destroying good data). During formatting, the following messages will appear sequentially: | WRITING HEADERS CURRENT CYLINDER ADDRESS | | |-------------------------------------------------------|--| | READING HEADERS | | | CURRENT CYLINDER ADDRESS WRITING DATA TEST PATTERN | | | CURRENT CYLINDER ADDRESS | | | READING DATA TEST PATTERN<br>CURRENT CYLINDER ADDRESS | | When reading and writing headers, the program will display the cylinder addresses sequentially. The test pattern tests are also sequentially selected, and the cylinder address displayed will correspond to current address being read. After each logical unit is formatted, the display will be: DL\_\_\_\_ FORMAT AND VERIFICATION COMPLETE #### Sequential Read For this test, the display will be: SEQUENTIAL READ (ALL CYLINDERS AND HEADS?) If the response is No, the program will jump to the Selected Read test. If the response is Yes, the current cylinder address is displayed as each cylinder is read. If an error is detected, the register contents and location are displayed with the 4-line identification message, and the following: ## ASSIGN ALTERNATE TRACK FOR DEFECTIVE TRACK? If no alternates (spares) are available, the following will be displayed: #### NO ALTERNATE CYLINDER AVAILABLE When marking or assigning alternate tracks, the following error messages may occur: TRACK HAS ALREADY BEEN MARKED DEFECTIVE TRACK HAS ALREADY BEEN MARKED ALTERNATE #### Selected Read For this test, the display will be: READ DLO (Y OR N)? If the response is No, the next logical unit will be displayed. If the response is Yes, the current cylinder address is displayed and each cylinder is read. If an error is detected, the register contents and location are displayed with the 4-line identification message. The ASSIGN ALTERNATE TRACK message appears, and error messages if the track has been marked DEFECTIVE or ALTERNATE. #### Random Seek, Read For this test, the display will be: ## RANDOM SEEK, READ OF DRIVE (ALL CYLINDERS AND HEADS)? This test selects a random cylinder, logical unit, and a sector address within the cylinder. The test then reads data and tests for errors. All logical units are used in this test. Alternate cylinders cannot be assigned during this test. The terminal keyboard space (SP) character is used to exit this test. If an error is detected, the register content and locations are displayed with the 4-line identification message. This check also ensures controller mapping is correct. ### Random Seek, Write Data, Read Data, Compare Test If the response is No, each logical unit will appear in sequence until the response is Yes: DL0? DL1? DL2? DL3? This test selects a random cylinder address and random sector address and writes five sectors (2560 bytes) of random data. The data written is then read into CPU memory and compared for read errors. This test allows logical units to be tested. The terminal keyboard space character (SP) is used to exit from this test. This test ensures that the controller is executing the write check command correctly and ensures that the controller is zero-filling the disc correctly. #### Test ECC Logic The following message will appear for this test: TEST ECC? DL0:? DL1:? **DL2:?** DL3:? ARE YOU SURE? If ECC testing is selected, answering "Y" to "TEST ECC?" the program will prompt the operator to specify a unit. The unit selected will then be used to test the ECC logic. #### Note The unit selected will be written on. The program selects whether a correctable or noncorrectable error is to be programmed; then the program creates an error; writes the sector with the error to the disc; reads to memory; then the program decides whether the error is noncorrectable or correctable. If noncorrectable, the program checks to ensure an error has been returned by the controller. If correctable, the program checks to make sure there has been no error returned by the controller, and checks to ensure the error was corrected in the proper manner. If this test fails, the message is one or more of the following: CONTROLLER INDICATES CORRECTABLE ERROR CONTROLLER INDICATES NONCORRECT-ABLE ERROR ERROR BURST IS CORRECTABLE ## ERROR BURST IS NONCORRECTABLE ERROR BURST WAS NOT CORRECTED The space character (SP) is used to exit from this test. #### Assign Alternate Track This test may be used if the disc drive manufacturer provides a map describing defective tracks. The message is: ASSIGN ALTERNATE TRACK FOR DEFECTIVE TRACK (Y OR N)? If the response is No, the program will revert to: USE R TO REPEAT USE O TO TRANSFER TO ODT USE L TO REBOOT YOUR SYSTEM If the response is Yes, the display will be: PHYSICAL DRIVE (0 or 1)? (Only if two drives are present) CYLINDER ADDRESS (0 TO \_\_\_\_) Enter the cylinder address, in decimal, of the defective track. If the cylinder address entered is incorrect, the message will be repeated. | The next message will be: | | |---------------------------|---| | HEAD ADDRESS (0 TO _ | ) | Enter the head address, in decimal, of the defective track. If the head address entered is incorrect, the message will be repeated. The next message will be: | MAP OUT | | | |------------------|------|--| | CYLINDER | HEAD | | | ARE YOU SURE? (Y | OR N | | If No, the program will repeat the first message of this test. If Yes, an alternate cylinder is assigned and the message is: ALTERNATE CYLINDER ASSIGNED Other messages to appear may be: TRACK ALREADY MARKED DEFECTIVE or TRACK ALREADY MARKED ALTERNATE The program will then repeat the first message of this test. #### SECTION 4 PROGRAMMING #### PROGRAMMING DEFINITIONS Function — The expected activity of the disc system (write, seek, read, etc.). Command — To initiate a function (halt, clear, go, etc.) Operations — One or more orders executed in a prescribed sequence that causes a function to be performed. Address — The binary code placed in the BDAL0-15 lines by the bus master to select a register in a slave device. Note memory other than computer internal memory, i.e., peripheral device registers, the upper 4K (28-32K) address space is used. Register — An associated group of memory elements that react to a single address and store information (status, control, data) for use by other assemblies of the total computer system. #### **OPERATIONS** WRITE—When the controller is given a write command it will perform the mapping algorithm, do an implied seek if one is necessary, and then do the write operation. The controller will perform spiral operations until the word count is exhausted, unlike the real RL controller. READ—The read is performed like the write, except for the direction of data flow. RESTORE—The real RL controller does not have an implicit restore command, so the restore operation has been incorporated into the "Get Status" command. When a "Get Status" is performed, and bit 4 of the RLDA register is set, the selected disc drive will be positioned to track zero. WRITE FORMAT—When a write command is issued to the controller and bit 15 of the RLMP register is a zero, the write data command will be changed to a write format command. Format commands read/write a fixed buffer size of 51 words. The format commands start and end at the index signal from the disc. There are 3 words from the table for each of the 17 headers in a track. The physical position of a header in the table determines its physical position in the track. When a read/write command is issued with bits 15 and 14 reset, the firmware responds to this as a format command with inhibit seek. The firmware will perform the desired format command on the head addressed by the RLDA in map override form, but will not do any seek previous to the command. When read/write command is issued with bits 15 reset and bit 14 set, the firmware responds to this as a format command with seek and map override. The firmware will use the RLDA as real head and cylinder addresses, will seek to the desired position in the disc and perform the desired read/write format function. The general flow of a program to format the disc is of a 4 pass operation. In pass one the headers are written, and the controller erases all the data fields. In pass two the headers are verified. In pass three the disc data fields are written and in pass four the data fields are verified. The initial command in the formatting program is to do a restore on the physical unit. The restore command does not require any cylinder calculations, so it can be performed on an unformatted disc drive. When the drive has been restored to track zero, then head zero can be written with a write format/inhibit seek. This command, since it also does no cylinder calculations can be performed on an unformatted disc drive. Once cylinder zero, head zero has been formatted, then commands with seeks can be performed. READ FORMAT—When a read command is issued to the controller and bit 15 of the RLMP is a zero, the read data command will be changed to a read format command. SEEK—Since the physical characteristics of the disc do not match the RL01/RL02 it is emulating, the normal seek command is essentially worthless and does no operation on the real disc. All read/write commands are preceded with an implied seek operation that is performed by the firmware. Whenever the firmware is required to do an implied seek, it will verify its new disk position (format commands excepted). An implied seek will also occur when a command continues across a real disc cylinder boundary. The implied seek operation consists of reading the first available header. The firmware then calculates the difference in real cylinders between its present position, and the desired position. The firmware then issues step pulses to the disc at timed intervals. When the heads have settled at the new cylinder, a header is read and the cylinder address is verified by firmware to be correct. WRITE CHECK—The command begins like a read command, and finds the requested sector on the disc, and reads it into the controller's data buffer. The firmware will then DMA data from the computer and compare the data against the data in the buffer. A miscompare will set the data error status. CONTROLLER CLEAR—The command will clear the RLBA and RLAE and RLDA registers and the error status in the RLCS register. The RLMP most significant byte will be cleared, then bits 15 and 14 set (to avoid accidental format commands). The RLMP least significant byte will be loaded with the revision number of the microcode. This command duplicates the effects of a bus initialization, except the microcode does not do the self test. WRITE DIAGNOSTIC MODE—The command is restricted to a one sector operation. It is also to be done only on the last physical sector in a track. The command is a write data command with bit 14 of the RLMP cleared. The word count is to be one sector plus 2 words. The RLMP value is then octal 137376. The command will write the data buffer and instead of appending the 32 bit controller generated ECC check character to the end of the buffer, it will write the last two words of the data buffer as the ECC characters. READ DIAGNOSTIC MODE—The command is restricted to a one sector operation. There is no restriction on the disc address. The data buffer passed to memory will begin with the third word of the data field. The last two words of the data buffer will contain the ECC check character read from the disc. The data error status is indeterminate during this command, and should be ignored. #### **INTERRUPTS** The controller will interrupt after commands complete if bit 6 of the RLCS is set. Note that doing a BIS of bit 6 to the RLCS does not give an interrupt, as in some other controllers. #### **DIAGNOSTIC** The diagnostic is named DQ614, available from the software department. The revision of the diagnostic will be displayed on the startup message. Figure 4-1. Register Summary The Control/Status Register (RLCS) has the bus address 774 400. The purpose of the register is to pass commands to the controller, and to pass status back to the program. #### BIT(S) DESCRIPTION OO DRIVE READY—When set, indicates drive is ready. 01, 02, 03 FUNCTION CODE—The function code is a three bit field that defines one of eight possible commands to the controller. COMMAND 0 (0 0 0) Controller Reset—This command will reset the controller and the internal flags. At the completion of the command the revision number of the microcode will be in the LSB of the multipurpose register. This command is similar to the Bus Initialization signal except that the "INIT" signal also causes the microprocessor to perform its self test. COMMAND 1 Write Check—This command will compare a table in memory against the data on the disc. A miscompare will set the uncorrectable error status. The controller will not perform error correction on the data read from the disc. COMMAND 2 Get Status—This command is used to obtain the drive status, restore the disc, (0 1 0) and Read/Write into the controller data buffer for diagnostic purposes. The exact operation is determined by bits in the RLDA Register. COMMAND 3 Seek—This command will present status to the program to indicate a seek is performed, but no action will really take place. The controller functions with transparent seeking taking place after the mapping algorithm is performed, so this command is essentially a NO-OP. COMMAND 4 Read Headers—This command will present status to the program to indicate a read headers is performed but no action will really take place. The software uses this command in conjunction with the seek command, which is also essentially a NO-OP as this one. COMMAND 5 Write Data—This command will write data blocks onto the disc. Alternately if (1 0 1) bit 15 of the multipurpose register is a zero, the command will write headers onto the disc, and erase the data fields (a write format command). COMMAND 6 Read Data—This command will read data blocks from the disc. Alternately if $(1\ 1\ 0)$ bit 15 of the multipurpose register is a zero, the command will read headers from the disc. (A read format command.) COMMAND 7 Read Data—This command will function as command six, but if command six $(1\ 1\ 1)$ encounters an uncorrectable data field it will stop, and not transfer bad data. This command will transfer the bad data before halting the operation. 04, 05 BUS ADDRESS EXTENSION BITS (17 and 16)—These bits are Bus Extension bits 17(5) and 16(6). These are identical to bits 1 and 0 of RLAE Register and can be set by writing into either register. These bits increment everytime the RLBA Register overflows. 06 INTERRUPT ENABLE—When set, this bit allows the controller to interrupt the processor at the end of an operation. CONTROLLER ENABLE—When cleared by the software, this bit indicates that the controller 07 is to start an operation. When set by the controller, this bit indicates that the controller is ready to accept another command. 08-09 DRIVE SELECT—These bits determine which of four logical units is selected. 10 OPERATION INCOMPLETE—The Operation Incomplete status when set, indicates that the controller passed the initial requirements to start the operation, but that an error was encountered during operations. 11 UNCORRECTABLE DATA ERROR—The ECC Error Status when set, indicates that the controller has made two attempts to read the data and has been unable to correct the error. Refer to Table 2-1 for the implications of Switch one on this status. 12 HEADER NOT FOUND—The Header Not Found status when set, indicates that the controller has searched the data track for three spins of the disc and has not been able to locate the desired data block. 13 NON-EXISTENT MEMORY-The Non-Existent Memory status when set, indicates that during a DMA cycle the controller as Bus Master, did not receive a response from the memory addressed within 20 $\mu$ s. 14 DRIVE ERROR—The Drive Error bit when set, indicates the controller has determined that there exists a problem in the drive that will not allow the command to proceed further. This bit can be set if the controller determines that (1) The drive has gone "NOT READY", (2) The drive fault line goes true, (3) The drive selected status from the drive goes false during a command, (4) During any transparent seek operation if the controller detects a positioning error during its verify positioning cycle, (5) If the continuation of an operation will attempt to exceed the end of a logical unit. 15 COMPOSITE ERROR—The Composite Error bit when set, indicates that one or more of the error bits (14-10) is set. ## BUS ADDRESS REGISTER (RLBA) 774 402 | 15 | * * * * * * * * * * * * * * * * * * * * | | | 00 | |---------------|-----------------------------------------|--|-------------------|----| | Berger Berger | | | a valgering page. | | The address of RLBA is 774 402. The bits of this register contain the bus address of data transferred during read or write check operations. The register is incremented by two at the end of each transfer. If the system has extended memory, the RLBA will overflow to the EX MEM bits (04, 05) of the RLCS to reflect the extended bus address. This is a read/write register cleared by INIT or RESET functions. ## DISC ADDRESS REGISTER 774 404 (RLDA) The Disc Address register has the bus address of 774 404. The purpose of the register is to pass disc addresses to the controller. #### RLDA on a SEEK command. | BIT(S) | DESCRIPTION | |------------------------|--------------------------------------| | Carlo National Control | Louise har was to the control of the | 00 Must be 1 01 Must be 0 DIRECTION—This bit indicates the direction in which a seek is to take place. When the bit is set, the heads move to a higher cylinder address. When the bit is cleared, the heads move to a lower cylinder address. 03 Must be 0 HEAD SELECT—This bit indicates which head (disc surface) is to be selected. Set=lower, clear=upper. 05-06 Reserved 07-15 CYLINDER ADDRESS DIFFERENCE—These bits indicate the number of cylinders the heads are to move on a seek. ## RLDA on a READ or WRITE data command. (RL01/RL02 Disc Address) BIT(S) DESCRIPTION 00-05 SECTOR ADDRESS—These bits indicate the addressed sector. HEAD SELECT—This bit indicates which head (disc surface) is to be selected. Set=lower, clear=upper. 07-15 CYLINDER ADDRESS—These bits indicate the address of the cylinder being accessed. | BIT(S) | DESCRIPTION | |-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 00 | Must be 1 | | 01 | GET STATUS—When set, enables status to be put into the Multipurpose Register by Get Status function code. | | 02 | Must be 0 | | 03 | RESET—When set, causes the drive to clear its Error Register before sending a status word to the Controller. | | 04 | RESTORE—When set, this bit causes the heads to return to cylinder 0. | | 05 | READ/WRITE TO DATA BUFFER—When set on a get status command, allows access to the controller internal data buffer. When the programmer outputs a word to the Multipurpose Register it will be written into the internal data buffer. When the programmer inputs a word from the Multipurpose Register the word will be read from the internal data buffer. | | 06-07 | Must be 0 | | 08-15 | Not Used | | <ul> <li>Control of the control control</li></ul> | | ## MULTIPURPOSE REGISTER 774 406 (RLMP) The Multipurpose register has the bus address of 774 406. The purpose of the register is to pass the word count to the controller on a read/write com- mand, and to pass disc status back to the program on a get status, and to move data into/out of the controller buffer during a diagnostic test. #### **During Read/Write Command for Word Count** #### BIT(S) DESCRIPTION WORD COUNT—These bits are the 2's complement of the total number of words to be transferred during a read, write or write check operation. The register is incremented by one after each transfer. When the register overflows (all WC bits go to zero), the transfer is completed and the controller action is terminated at the end of the current disc sector. 14-15 These bits indicate the following: 15, 14 SET; Read/write data command. 15 SET, 14 CLEAR; Read/write data command with ECC Diagnostic Mode. 15 CLEAR, 14 SET; Format command with seek. 15 CLEAR, 14 CLEAR; Format command with no seek. #### **During a Get Status Command** RLMP is used to read/write the data buffer by using the GET STATUS command with bit 5 or RLDA. | BIT(S) | DEFINITION | |--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 00 | Always 1. | | 01 | Always 0. | | 02, 04 | DRIVE READY—When bits 02 and 04 are set, the drive is ready for operation. | | 05-06 | Always 0. | | 07 | RL02 STATUS—When set drive is RL02. When clear drive is RL01. | | 08-12 | Always 0. | | 13 | Not Used | | 14-15 | DRIVE FAULT—Sets if an error condition is detected within the drive and is prohibiting all operations. This bit is reset manually by clearing the fault condition within the drive. | ## ADDRESS EXTENSION REGISTER 774 410 (RLAE) The Address Extension register has the bus address 774 410. The purpose of the register is to hold the extra memory address bits not held in the RLBA. ## SECTION 5 TROUBLESHOOTING AND THEORY This section describes troubleshooting procedures at three levels of complexity: basic system, controller symptoms and detailed analysis. Basic system troubleshooting procedures are visual checks not requiring test equipment and may be performed by the operator. Controller symptom procedures may require a scope, meter, extender board or diagnostics and should be performed by a technician. Detailed analysis is troubleshooting at the IC level, and is presented for engineers or system analysts for controller evaluation. The latter method may require the use of test equipment and the material presented here: board layout, term listing, theory of operation and logic diagrams. #### CAUTION Any troubleshooting requires a familiarity with the installation and operation procedures in this manual, the appropriate DEC manual, and the disc drive manufacturers manual. Ensure power is off when connecting or disconnecting board or plugs. #### BASIC SYSTEM TROUBLESHOOTING The following should be checked before power is applied: - 1. Verify that all signal and power cables are properly connected. Ribbon cable connectors are *not* keyed. The arrows on the connectors should be properly aligned. - 2. Verify that all switches are properly set as described in Sections 2 and 3. - 3. Verify that all modules are properly seated in the computer and properly oriented. The following should be checked during or after application of power: - 1. Verify that the computer and disc drive generate the proper responses when the system is powered up. - 2. Verify that the computer panel switches are set correctly. - 3. Verify that the console can be operated in the local mode. If not, the console may be defective. 4. Verify that the green diagnostic light on the controller is on. #### CONTROLLER SYMPTOMS Controller symptoms, possible causes and checks/corrective action are described in Table 5-1. Voltage checks should be performed before troubleshooting more complex problems. The +12V source is shown on sheet 11 (AD2), and the +5V source may be checked from any component shown on the other logic diagrams. #### PHYSICAL LAYOUT The physical layout of the board is shown in Figure 5-1. Column and row numbers on the layout correspond to the numbers on each IC on the logic diagrams. #### **TERM LISTING** The input and output terms for each logic diagram are described in Table 5-2. The sources and destinations refer to the sheet numbers on the logic diagrams. ## ADJUSTMENT PROCEDURE FOR DATA SEPARATOR This procedure should be performed only when a component is changed in the phase-locked loop circuitry. A two-channel oscilloscope, a frequency counter, and an extender board are required for this adjustment. #### **CAUTION** This adjustment is factory set and the components sealed with glyptol. The adjustment should be performed in field by a qualified technician only. Component locations are shown on Figure 2-1. Proceed as follows: - 1. Place the controller to an extender board. - 2. Power up the computer and run to warm-up the controller to operating temperature. #### Note Do not connect the drive for this adjustment. Table 5-1. Controller Symptoms | Symptom | Possible Causes | Check/Corrective Action | |-------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Green DIAG light on the controller is OFF. | 1. Microprocessor section of controller inoperative: a. Bad oscillator (Sheet 11,U12,Y1) b. Short or open on board c. Bad IC d. PROMs not properly seated (U13 through U8) | Controller/Place controller on extender board. With a scope, check the pins on the 2901 (Sheet 6). All pins except power and | | tween console and computer. ing" Q Bus: a. DEN always low (Sheet 3) b. Shorted bus tranceiver IC. c. Bad CPU board. | | Computer interface logic of controller/ a. Check signal DEN for constant assertion. b. Check I/O IC's. Remove controller board to see if trouble goes away. (Ensure slot is filled or jumpered.) c. Run CPU diagnostics. | | | | 3. Disc/Consult the disc manufacturer's manual for proper setting of disc switches. Check cable connections. Controller Registers/Using ODT, examine controller register RLCS, bit 0 and 8 and 9. These bits represent DISC UNIT READY AND SELECTED and must be present for proper communication. Using ODT, deposit "ones" and "zeros" in the remaining disc registers and verify proper register data. | | 4. Data transferred to/<br>from disc incorrect | 4. Multiple Causes: a. Bad memory in backplane b. Noise or intermittent source of DC power in computer. c. Bad IC in disc I/O section of controller. d. Bad area on disc. e. Disc heads not properly aligned. | <ul> <li>4. Computer-controller-disc/</li> <li>a. Run memory diagnostics.</li> <li>b. Check AC and DC power.</li> <li>c. While operating, check lines from controller to disc with a scope for short or open.</li> <li>d. Run the Test and Format Program (Section 3). If errors occur at the same place on the disc, it is probably a bad area on the disc. Assign alternate tracks as specefied in Section 3.</li> <li>e. Consult disc drive manufacturer's manual and align heads.</li> </ul> | | 5. Intermittent failure—<br>Controller runs for a<br>short time after power<br>is applied and then<br>fails. | 5. Failure of heat sense component on controller. | 5. Isolate the bad component by using heat and cooling methods (heat gun, freon spray) and replace the bad component. | Figure 5-1. Board Layout Table 5-2. Term Listing Table 5-2. Term Listing (Continued) | Term Source Destination Description AMSRCH + BBS7 10 BUS BUS Peripheral Address Select Peripheral Address Select BDIN BUS (AH2) 1 BUS Peripheral Address Select Peripheral Address Select BUS BUS Data In BUS DATA IN DATA BUS DATA DATA IN BUS DATA DATA BUS DATA DATA BUS DATA DATA BUS DATA CARD BUS DATA CARD BUS DATA DATA DATA BUS BATA DATA BATA DATA BATA DATA BATA DATA BAT | | | ` | | | |----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|-------------|----------|-------------|------------------------| | BBS7 | | Term | Source | Destination | Description | | BBS7+ | | | BUS | | Bus Peripheral Address | | BDIN | | BBS7+ | 1 ' . ' | 3 | Peripheral Address | | BDIN+ BUS 2 Bus D/R0 | | BDIN | | 1. | | | BDA01 BUS (AV2) (BE2) 2 Bus D/R1 BDA02 BUS BUS (BE2) 2 Bus D/R3 BDA03 BUS (BF2) 2 Bus D/R3 BDA04 BUS (BF2) 2 Bus D/R4 BDA05 BUS (BUS) 2 Bus D/R5 BDA06 BUS (BV2) 2 Bus D/R6 BDA07 BUS (BK2) 2 Bus D/R7 BDA08 BUS (BW2) 2 Bus D/R8 BDA09 BUS (BM2) 2 Bus D/R9 BDA10 BUS (BM2) 2 Bus D/R10 BDA11 BUS (BP2) 2 Bus D/R10 BDA11 BUS (BP2) 2 Bus D/R11 BDA12 BUS (BP2) 2 Bus D/R13 BDA14 BUS (BY2) 2 Bus D/R13 BDA15 BUS (BV2) 2 Bus D/R14 BDA16 BUS (BV2) 3 Address Extension Bit 16 BDA17 BUS (BV2) 1 Bus Extension Bit 17 BDA18 BUS (BC1) | | | 1<br>BUS | | | | BDA02 BUS (BE2) BUS D/R2 | | BDA01 | BUS | 2 | Bus D/R1 | | BDA03 BUS (BF2) BUS D/R3 | ١ | BDA02 | BUS | 2 | Bus D/R2 | | BDA04 BUS (BH2) 2 Bus D/R4 BDA05 BUS (BJ2) 2 Bus D/R5 BDA06 BUS (BK2) 2 Bus D/R6 BDA07 BUS (BK2) 2 Bus D/R7 BDA08 BUS (BM2) 2 Bus D/R9 BDA09 BUS (BM2) 2 Bus D/R9 BDA10 BUS (BV2) 2 Bus D/R10 BDA11 BUS (BP2) 2 Bus D/R10 BDA11 BUS (BR2) 2 Bus D/R11 BDA12 BUS (BR2) 2 Bus D/R12 BDA13 BUS (BS2) 2 Bus D/R12 BDA14 BUS (BT2) 2 Bus D/R13 BDA15 BUS (BU2) 2 Bus D/R14 BDA15 BUS (BV2) 3 Address Extension Bit 16 BDA17 BUS (BV2) 3 Address Extension Bit 17 BDA18 BUS (BC1) 3 Address Extension Bit 18 BDA19 BUS (BD1) 3 Address Extension Bit 19 BDA19 | | BDA03 | BUS | 2 | Bus D/R3 | | BDA05 BUS (BJ2) 2 Bus D/R5 BDA06 BUS (BK2) 2 Bus D/R6 BDA07 BUS (BK2) 2 Bus D/R7 BDA08 BUS (BM2) 2 Bus D/R8 BDA09 BUS (BM2) 2 Bus D/R9 BDA10 BUS (BP2) 2 Bus D/R10 BDA11 BUS (BP2) 2 Bus D/R10 BDA12 BUS (BR2) 2 Bus D/R10 BDA12 BUS (BR2) 2 Bus D/R11 BDA12 BUS (BS2) 2 Bus D/R12 BDA13 BUS (BS2) 2 Bus D/R13 BDA14 BUS (BU2) 2 Bus D/R14 BDA15 BUS (BU2) 2 Bus D/R15 BDA16 BUS (BV2) 1 Bus Extension Bit 16 BDA17 BUS (BV2) 3 Address Extension Bit 17 BDAL18 BUS (BC1) 3 Address Extension Bit 18 BDAL20 BUS (BE1) 3 Address Extension Bit 19 BDAL21 | | BDA04 | BUS | 2 | Bus D/R4 | | BDA06 BUS (BK2) 2 Bus D/R6 BDA07 BUS (BL2) 2 Bus D/R7 BDA08 BUS (BM2) 2 Bus D/R8 BDA09 BUS (BN2) 2 Bus D/R9 BDA10 BUS (BN2) 2 Bus D/R10 BDA11 BUS (BR2) 2 Bus D/R10 BDA11 BUS (BR2) 2 Bus D/R11 BDA12 BUS (BR2) 2 Bus D/R12 BDA13 BUS (BS2) 2 Bus D/R13 BDA14 BUS (BU2) 2 Bus D/R15 BDA15 BUS (BU2) 3 Bus D/R15 BDA16 BUS (BU2) 3 Bus Extension Bit 16 (AC1) BUS (BV2) 3 Address Extension Bit 17 (AD1) BUS (BC1) 3 Address Extension Bit 18 BDAL19 BUS (BC1) 3 Address Extension Bit 19 BDAL20 BUS (BE1) 3 Address Extension Bit 19 BDAL21 BUS (BE1) 3 Address Extension Bit 19 | | BDA05 | BUS | 2 | Bus D/R5 | | BDA07 BUS (BL2) 2 Bus D/R7 BDA08 BUS (BM2) 2 Bus D/R8 BDA09 BUS (BM2) 2 Bus D/R9 BDA10 BUS (BN2) 2 Bus D/R10 BDA11 BUS (BP2) 2 Bus D/R11 BDA12 BUS (BS2) 2 Bus D/R12 BDA13 BUS (BS2) 2 Bus D/R13 BDA14 BUS (BU2) 2 Bus D/R14 BDA15 BUS (BU2) 2 Bus D/R15 BDA16 BUS (BV2) 3 Bus Extension Bit 16 BDA17 BUS (BV2) 1 Bus Extension Bit 17 BDAL18 BUS (BC1) 3 Address Extension Bit 18 BDAL19 BUS (BC1) 3 Address Extension Bit 18 BDAL20 BUS (BC1) 3 Address Extension Bit 19 BDAL21 BUS (BE1) 3 Address Extension Bit 20 BDMGI BUS (BE1) 3 Address Extension Bit 20 BDMGI BUS (BE1) 3 BUS DMA Grant In | - | BDA06 | BUS | 2 | Bus D/R6 | | BDA08 BUS (BM2) 2 Bus D/R8 BDA09 BUS (BM2) 2 Bus D/R9 BDA10 BUS (BP2) 2 Bus D/R10 BDA11 BUS (BP2) 2 Bus D/R11 BDA12 BUS (BS2) 2 Bus D/R12 BDA13 BUS (BS2) 2 Bus D/R13 BDA14 BUS (BU2) 2 Bus D/R14 BDA15 BUS (BU2) 2 Bus D/R15 BDA16 BUS (BV2) 3 Bus Extension Bit 16 BDA17 BUS (AC1) 1 Bus Extension Bit 17 BDA18 BUS (AC1) 1 Bus Extension Bit 17 BDA19 BUS (BC1) 3 Address Extension Bit 18 BDAL19 BUS (BC1) 3 Address Extension Bit 19 BDAL20 BUS (BE1) 3 Address Extension Bit 20 BDAL21 BUS (BE1) 3 Address Extension Bit 20 BDMGI BUS (BE1) 3 BUS DMA Grant In BUS (AR2) BUS DMA Grant Out AUS DATE OUT | 1 | BDA07 | BUS | 2 | Bus D/R7 | | BDA09 | | BDA08 | BUS | 2 | Bus D/R8 | | BDA10 | | BDA09 | BUS | 2 | Bus D/R9 | | BDA11 | | BDA10 | BUS | 2 | Bus D/R10 | | BDA12 BUS (BS2) 2 Bus D/R12 BDA13 BUS (BT2) 2 Bus D/R13 BDA14 BUS (BU2) 2 Bus D/R14 BDA15 BUS (BV2) 2 Bus D/R15 BDA16 BUS (BV2) 1 Bus Extension Bit 16 BDA17 BUS (AC1) 1 Bus Extension Bit 17 BDAL18 BUS (BC1) 3 Address Extension Bit 18 BDAL19 BUS (BC1) 3 Address Extension Bit 19 BDAL20 BUS (BE1) 3 Address Extension Bit 20 BDAL21 BUS (BE1) 3 Address Extension Bit 20 BDMGI BUS (BF1) 3 Address Extension Bit 21 BDMGI BUS (BF1) 3 BUS DMA Grant In (AR2) BDMR BUS (AS2) 1 Bus DMA Grant Out (AS2) BDMR BUS (AN1) 1 Bus Data Out (AS2) BDOUT (AE2) 1 BUS (AS2) 1 BOUT + 1 1 9 Data Out (AS2) BIAKI BUS (AN2) | | BDA11 | BUS | 2 | Bus D/R11 | | BDA13 | 1 | BDA12 | BUS | 2 | Bus D/R12 | | BDA14 BUS (BU2) 2 Bus D/R14 BDA15 BUS (BV2) 2 Bus D/R15 BDA16 BUS (AC1) 1 Bus Extension Bit 16 BDA17 BUS (AC1) 1 Bus Extension Bit 17 BDAL18 BUS (BC1) 3 Address Extension Bit 18 BDAL19 BUS (BC1) 3 Address Extension Bit 19 BDAL20 BUS (BE1) 3 Address Extension Bit 20 BDAL21 BUS 3 Address Extension Bit 21 BDMGI BUS 3 Address Extension Bit 21 BDMGI BUS 3 Address Extension Bit 21 BDMGI BUS 3 Address Extension Bit 21 BDMGI BUS 3 BUS DMA Grant In BDMG 4 BUS 4 BUS Bus DMA Grant Out BUS 5 1 Bus Data Out BUS 6 1 Bus Data Out BUS 7 1 Bus Interrupt Acknowledge In BUS 8 1 Bus Interrupt Acknowledge Output BINIT 8 1 Bus Interrupt Acknowledge Output BU | 1 | BDA13 | BUS | 2 | Bus D/R13 | | BDA15 BUS (BV2) BUS D/R15 | | BDA14 | BUS | 2 | Bus D/R14 | | BDA16 BUS (AC1) 1 Bus Extension Bit 16 BDA17 BUS 1 Bus Extension Bit 17 BDAL18 BUS 3 Address Extension Bit 18 BDAL19 BUS 3 Address Extension Bit 19 BDAL20 BUS 3 Address Extension Bit 20 BDAL21 BUS 3 Address Extension Bit 20 BDMGI BUS 3 Address Extension Bit 21 BDMGI BUS 1 Bus DMA Grant In BDMG BUS 1 Bus DMA Grant Out BDMG BUS 1 Q Bus Request BDMR BUS 1 Bus Data Out BDOUT BUS 1 Bus Data Out BDOUT + 1 9 Data Out BUS 1 Bus Interrupt Acknowledge In BIAKO BUS 1 Bus Interrupt Acknowledge Output BUS 1 Initialize—Clear Devices on I/O Bus BIRQ4 BUS 3 Host Interrupt Request | ŀ | BDA15 | BUS | 2 | Bus D/R15 | | BDA17 | l | BDA16 | BUS | 1 | Bus Extension Bit 16 | | BDAL18 BUS (BC1) 3 Address Extension Bit 18 BDAL19 BUS (BD1) 3 Address Extension Bit 19 BDAL20 BUS (BE1) 3 Address Extension Bit 20 BDAL21 BUS (BE1) 21 Address Extension Bit 21 BDMGI BUS (BF1) 21 Bus DMA Grant In BDMGO BUS (AR2) 1 Bus DMA Grant Out BDMR BUS (AN1) 1 Q Bus Request BDOUT BUS (AR2) 1 Bus Data Out BDOUT (AE2) BUS (AE2) 1 Bus Interrupt Acknowledge In BIAKI BUS (AN2) 1 Bus Interrupt Acknowledge Output BINIT (BUS (AT2) 1 Initialize—Clear Devices on I/O Bus BIRQ4 BUS (AT2) 3 Host Interrupt Request | ı | BDA17 | BUS | 1 | Bus Extension Bit 17 | | BDAL19 BUS (BD1) 3 Address Extension Bit 19 BDAL20 BUS (BE1) 3 Address Extension Bit 20 BDAL21 BUS (BF1) 3 Address Extension Bit 21 BDMGI BUS (AR2) 1 Bus DMA Grant In BDMGO BUS (AS2) 1 Bus DMA Grant Out BDMR BUS (AS2) 1 Q Bus Request BDOUT BUS (AN1) 1 Bus Data Out BDOUT + 1 (AE2) 9 Data Out BDOUT + 1 (AE2) 9 Data Out BIAKI BUS (AM2) 1 Bus Interrupt Acknowledge In BIAKO BUS (AN2) 1 Bus Interrupt Acknowledge Output BINIT BUS (AT2) 1 Initialize—Clear Devices on I/O Bus BIRQ4 BUS 3 4 Host Interrupt Request | I | BDAL18 | BUS | , з | | | BDAL20 BUS (BE1) 3 Address Extension Bit 20 BDAL21 BUS (BF1) 3 Address Extension Bit 21 BDMGI BUS (BF1) 1 Bus DMA Grant In BDMGO BUS (AR2) 1 Bus DMA Grant Out BDMR BUS (AS2) 1 Q Bus Request BDOUT BUS (AR2) 1 Bus Data Out BDOUT + 1 (AE2) 9 Data Out Enable Buffer Ful BIAKI BUS (AM2) 1 Bus Interrupt Acknowledge In BIAKO BUS (AN2) 1 Bus Interrupt Acknowledge Output BINIT BUS (AT2) 1 Initialize—Clear Devices on I/O Bus BIRQ4 BUS 3 Host Interrupt Request | E | BDAL19 | BUS | 3 | Address Extension Bit | | BDAL21 BUS (BF1) 3 Address Extension Bit 21 BDMGI BUS (AR2) 1 Bus DMA Grant In BDMGO BUS (AS2) 1 Bus DMA Grant Out BDMR BUS (AS2) 1 Q Bus Request BDOUT BUS (AN1) 1 Bus Data Out BDOUT + 1 (AE2) 9 Data Out Enable Buffer Ful BIAKI BUS (AM2) 1 Bus Interrupt Acknowledge In BIAKO BUS (AN2) 1 Bus Interrupt Acknowledge Output BINIT BUS (AT2) 1 Initialize—Clear Devices on I/O Bus BIRQ4 BUS 3 4 Host Interrupt Request | E | BDAL20 | BUS | 3 | Address Extension Bit | | BDMGI BUS (AR2) 1 Bus DMA Grant In BDMGO BUS (AR2) 1 Bus DMA Grant Out BDMR BUS (AS2) 1 Q Bus Request BDMR BUS (AN1) 1 Bus Data Out BDOUT 1 9 Data Out BDOUT+ 1 9 Data Out BFULE+ 10 8 Enable Buffer Ful BIAKI BUS 1 Bus Interrupt Acknow-ledge In BIAKO BUS 1 Bus Interrupt Acknow-ledge Output BINIT BUS 1 Initialize—Clear Devices on I/O Bus BIRQ4 BUS 3 Host Interrupt Request | E | BDAL21 | BUS | 3 | Address Extension Bit | | BDMGO BUS (AS2) 1 Bus DMA Grant Out BDMR BUS (AN1) 1 Q Bus Request BDOUT BUS (AN1) 1 Bus Data Out BDOUT+ 1 (AE2) 9 Data Out Enable Buffer Ful BFULE+ 10 8 BUS (AM2) 1 Bus Interrupt Acknowledge In BIAKI BUS 1 Bus Interrupt Acknowledge In (AN2) 1 Bus Interrupt Acknowledge Output Initialize—Clear (AN2) BINIT BUS (AT2) BUS 3 1 Initialize—Clear Devices on I/O Bus Host Interrupt Request | E | BDMGI | BUS | 1 | | | BDMR | E | BDMGO | BUS | 1 | Bus DMA Grant Out | | BDOUT | E | BDMR | BUS | 1 | Q Bus Request | | BDOUT + | E | BDOUT | BUS | 1 | Bus Data Out | | BFULE+ BIAKI BUS (AM2) BIAKO BUS (AN2) BINIT BUS (AT2) BIRQ4 BUS | Е | BDOUT+ | | 9 | Data Out | | BIAKO BUS (AN2) BINIT BUS (AT2) BIRQ4 BIS (AM2) BUS 1 BUS 1 Initialize—Clear Devices on I/O Bus Host Interrupt Request | | | | 8 | Enable Buffer Ful | | BIAKO BUS (AN2) BINIT BUS (AT2) BIRQ4 BUS 1 Bus Interrupt Acknow-ledge Output Initialize—Clear Devices on I/O Bus Host Interrupt Request | В | A 40 TO A 5 | | | | | BINIT BUS 1 Initialize—Clear Devices on I/O Bus BIRQ4 BUS 3 Host Interrupt Request | В | | BUS | 1 | Bus Interrupt Acknow- | | BIRQ4 BUS 3 Host Interrupt Request | В | INIT | BUS | 1 | Initialize—Clear | | (AL2) 4 | В | IRQ4 | BUS | 3 | Host Interrupt Request | | | _ | | (AL2) | | 4 | | Term | Source | Destination | Description | |--------------------------|-----------------------|-----------------|------------------------------------------------------------| | BIRQ5 | BUS | 3 | Host Interrupt Request | | BIRQ6 | (AA1)<br>BUS | 3 | 5<br>Host Interrupt Request | | BIRQ7 | (AB1)<br>BUS<br>(BP1) | | 6<br>Host Interrupt Request | | BIT+ | 8<br>8 | 12<br>13 | 9th Serial Data Path Bit | | BIT4+<br>BPOK | BUS | 10 | Half Byte Flag for ECC<br>Primary Power OK | | BRPLY | (BB1)<br>BUS<br>(AF2) | 1 | Q Bus Reply | | BSACK | BUS<br>(DN1) | 1 | DMA Request<br>Acknowledge | | BSYNC | BUS<br>(AJ2) | 1 | Synchronize I/O Address | | вwтвт | BUS<br>(AK2) | 1 | Control Write Byte | | BYT8+<br>BYT16+ | ` 7 ′<br>7 | 8<br>8 | End Postamble Byte<br>End Data Time Byte | | CI+<br>CP0 | 5<br>7 | 6<br>2 | Carry In<br>Control Pulse 0 | | CP2 – | 7 | 5 | Control Pulse 2 | | CP3 –<br>CP4 – | 7<br>7 | 10<br>9 | Control Pulse 3 Control Pulse 4 | | CP5 - | 7 | 10 | Control Pulse 5 | | CP6 –<br>COUT + | 7<br>6 | 8, 12<br>5 | Control Pulse 6<br>Carry Out | | CORRV+ | 11 | 10 | Voltage Correction for VCO | | CR1-0/<br>CR1-2 | 4 | 5, 6 | Microcode Instruction | | CR1-3<br>CR1-4/<br>CR1-6 | 3<br>4 | 6<br>6, 9 | Microcode Instruction<br>Microcode Instruction | | CR1-7<br>CR2-0/ | 4 4 | 6<br>5 | Microcode Instruction<br>Microcode Instruction | | CR2-1<br>CR2-2/ | 4 | 6 | Microcode Instruction | | CR2-7<br>CR3-1/<br>CR3-4 | 4 | 9 | Microcode Instruction | | CR3-0<br>CR3-5/<br>CR3-7 | 4 4 | 5<br>6 | Microcode Instruction<br>Microcode Instruction | | CR4-0 | 4 | 10, 5 | Microcode Instruction | | CR4-1<br>CR4-2/<br>CR4-4 | 4 | 1, 5, 7<br>3, 5 | Microcode Instruction Microcode Instruction | | CR4-5/<br>CR4-7 | 4 | 5 | Microcode Instruction | | CR5-0/<br>CR5-3 | 4 | 1, 5, 7 | Microcode Instruction | | CR5-4/<br>CR5-7 | 4 | 5, 7 | Microcode Instruction | | CSA0+<br>CSA9+ | 5 | 4 | Control Store Memory<br>Address | | CSTART - | 3 8 | 11 | Clock Start | | CTCHME+<br>DATAIN+ | 12 | | Parking Oscillator or<br>Read Data<br>Serial Data to Shift | | DATO+/ | | | Register | | DAT7+ | 7 | 8 | Data Buffer Data Bus | | DEN – | 3 | | Enable Data | | DEN+<br>DIR | 10<br>10 | | Enable Data Direction of Seek | | DMGI+ | 1 | 3 | DMA Grant In | | D0+/D1+ | 2 | 4, 6, 7, 9 | D Bus Bits 0-1 | | | | <del></del> | · · · · · · · · · · · · · · · · · · · | Table 5-1. Term Listing (Continued) | ٠ | Term | Source | Destination | on Description | |------|------------------------------------------------------------------------------------------|------------------------------------------------|---------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------| | | D0 + /D1 +<br>D2 + /D7 +<br>D6 + /D7 +<br>DRSL0<br>DRSL1<br>DRVSL1 -<br>DRVSL0<br>EADD - | 1<br>2<br>1<br>10<br>10<br>33, 1<br>J2, 1<br>3 | 2, 4, 6, 7,<br>3, 4, 6, 7,<br>2, 4, 6, 7,<br>J1, 26<br>J1, 28<br>10<br>10 | 9 D Bus Bits 2-7<br>9 D Bus Bits 6-7<br>Select Drive 0<br>Select Drive 1<br>Drive 1 Selected<br>Drive 0 Selected<br>Enable Address Q Bus | | | ECCEN+<br>ECCERR+<br>ECCTIM- | 13<br>13<br>13 | 12<br>8, 12<br>8, 12 | Control ECC Enable ECC Error ECC Byte Time-End | | | ENDC +<br>EMUX -<br>EPCOMP + | 7<br>8<br>10 | 8<br>13<br>13 | Block End Count End of Header or Data Enable Precompensa- | | | FAULT<br>GSCLK –<br>HESL1<br>HESL2<br>HESL3<br>IAKI + | J1, 12<br>11<br>10<br>10<br>10<br>10 | 10<br>5<br>J1, 14<br>J1, 18<br>J1, 4<br>3 | tion of Write Drive Fault System Clock Head 1 Select Head 2 Select Head 3 Select Host Interrupt | | | IAKIG –<br>INDEX<br>INIT +<br>LXR0 – | 3<br>9<br>1<br>9 | 9<br>J1, 20<br>3<br>2 | Acknowledge In<br>Interrupt Acknowledge<br>Disc Index Mark<br>Initialize<br>Destination Decode- | | | LXR1 – | 9 | 2 | Transceiver Clock Destination Decode- | | ŀ | LXR2 — | 9 | 7 | Transceiver Clock Destination Decode- | | l | LXR3 — | 9 | 8 | Load Address Register Destination Decode- | | l | _XR4 — | 9 | 10 | Load Y Register Destination Decode- System Control | | L | _XR5 — | 9 | 10 | Register Destination Decode- | | | -XR6 — | 9 | 1, 3 | Drive Control Destination Decode- Transceiver and Extension Clock | | | .Y+<br>/FIO+ | 8 | 7<br>5 | Load Y<br>Manufactured Instruc- | | 1 | IEWBYT+ | 8 | 13 | tion Bit 0 for 2910<br>New Byte to Shift<br>Register | | RRRR | CCLK -<br>AMEN -<br>DATO<br>DATO +<br>DAT1 -<br>DAT1 +<br>DOS +<br>EADY - | 3<br>8<br>10<br>10<br>10<br>10<br>11<br>11 | 1, 7<br>7<br>J2, 18<br>J2, 17<br>JJ, 18<br>J3, 17<br>8<br>9 | Clock Enable Buffer Read Data Drive 0 Read Data Drive 0 Read Data Drive 1 Read Data Drive 1 Read Data Drive 1 Read Data One Shot Ready | | R | EDUCI<br>ESET —<br>MFM | 10<br>3<br>10 | J1, 2<br>1, 4, 5, 10<br>8 | Reduce Write Current<br>Controller Reset<br>Read Modified Fre- | | R | OMCLK -<br>PLY +<br>SYNC + | 11<br>1<br>1 | 4, 8, 13<br>3, 9<br>2, 9 | quency Modulation<br>200NS Clock<br>Reply From Slave<br>Synchronize 2901 to | | SI | CLK -<br>EEK<br>OMPLETE | 11<br>9 | 3, 6, 9<br>J1, 8 | Host I/O Lines<br>150NS Hi, 50NS Lo<br>Disc Seek Complete | | | _IN+ | 3 | 5 | Slave Interrupt<br>Acknowledge Request | | SF | REN+ | 13 | 8 | Shift Register Enable | Table 5-2. Term Listing (Continued) | | Term | Source | Destination | Description | |---|-------------------------------------|--------------------|----------------------------------------------------------------------|----------------------------------------------------------------------------------------------------| | | STEP<br>STOP- | 10<br>8 | J1, 24<br>9, 10 | Step Pulse to Disc<br>Read or Write | | | TIAKO<br>TDMG +<br>TDMR + | 3<br>3<br>10 | 1<br>1<br>1, 3 | Operation Complete<br>Interrupt Acknowledge<br>Bus Grant to D/R<br>Transmit Direct<br>Memory Grant | | | TIRQ+<br>TRACK<br>ZERO | 10<br>9 | J1, 10 | Interrupt Request<br>Disc Track Zero | | | TSACK –<br>UNCLAMP +<br>UNLOCK + | 3<br>10<br>10 | 1, 9<br>11<br>9 | System Acknowledge<br>Reset PLL<br>Voltage Correction for | | | VCO+ | 11 | 8 | VCO Status<br>Voltage Controlled | | | VEC+ | 5 | 4 | Oscillator<br>Vector Address | | | WDATA +<br>WDAT0 -<br>WDAT0 + | 12<br>18<br>10 | 13<br>J2, 14 | Register Out Write Data Write Data Drive 0 | | | WDAT1 -<br>WDAT1 +<br>WOS + | 10<br>10<br>9 | J2, 13<br>J3, 14<br>J3, 13<br>10 | Write Data Drive 0 Write Data Drive 1 Write Data Drive 1 Write One Shot | | | WPLS –<br>WPROT0<br>WPROT1<br>WGT + | 13<br>1<br>1<br>10 | 9<br>J2, 5<br>J3, 5<br>9, 13 | Write Pulse Write Protect Unit 0 Write Protect Unit 1 Write Gate | | | WRAM –<br>WREN +<br>WRITE | 8<br>10<br>10 | 7<br>8<br>J1, 6 | Write to RAM<br>Write Enable<br>Write Gate | | | GATE<br>XSD0 – /<br>XSD1 – | 9 | 2 | Enable Transceivers | | | XSD3 –<br>XSD5 – | 9 | 7<br>1, 3 | Enable Bus Driver<br>Enable Transceivers-<br>Extension Bits | | 2 | XSD6 - | 9 | . 7 | Enable Boot PROM<br>Switched | | ; | XSD7 - | 9 | 7 | Enable Boot PROM<br>Ungated | | | YD- | 8 | 7 | Enable Buffer Address<br>Register | | 1 | (0+/Y1+<br>(2+/Y3+<br>(4+/Y5+ | 6<br>6<br>6 | 1, 2, 5, 7, 10<br>2, 3, 5, 7, 10<br>2, 3, 5, 7, 10<br>1, 2, 5, 7, 10 | Y Bus<br>Y Bus<br>Y Bus | | Z | /7+<br>ZERO+<br>1+<br>0 MHZ+ | 6<br>6<br>11<br>11 | 2, 5, 7, 10<br>5<br>8 | 7 Bus<br>2901 Output at Zero<br>50NS Pulse (phase 1)<br>10 MHZ Clock | - 3. Connect channel A to TP1 (RDOS+). - 4. Adjust R4 (channel A) for 110 nanoseconds high and 90 nanoseconds low as shown: - 5. Connect the frequency counter to TP2 (VCO-). - 6. Observe 10.0 MHz on the frequency counter. This is the value at which VCO locks. - 7. Jumper TP3 (VCLAMP+) to ground. - 8. The frequency counter should be at 8.5 MHz. If required, adjust C8 to 8.5 MHz +0.25, -0 MHz. - 9. Remove ground from TP3. - 10. Connect channel B to U58, pin 1 (CORRV+). - Observe the voltage and note for later reference (step 17). The voltage should be 3.0 ±0.2V and the VCO locked at 10 MHz. - 12. If these values are not present, repeat step 7 through 11 to speed up or slow down the VCO to obtain the proper voltage. - 13. Disconnect the frequency counter. - 14. Connect channel B to TP2. - 15. The following relationship between channel A and channel B must occur. As shown, the leading edge of the pulse on channel A should be $55 \pm 5$ nanoseconds from the trailing edge of the channel B pulse so that the X-Y transition of channel B is approximately centered with the channel A pulse. - 16. If there is jitter on channel B, R4 should be readjusted to eliminate jitter. - 17. Carefully seal the components with glyptol to avoid changing the settings. Before the glyptol sets check U58, pin 1 (voltage noted in step 11). If out of adjustment, quickly readjust C8 before the glyptol sets. - 18. Disconnect the oscilloscope and counter, remove the extender board, and seat the board in proper slot. - 19. Refer to the procedures in Section 3 for operation. #### THEORY The controller may be examined as five functions: computer interface, microprocessor, data buffer, peripheral interface-write, and peripheral interface-read. Signals from and to the computer are described in Section 1, Table 1-1. Signals from and to the disc drive are described in Tables 1-2 and 1-3. Figure 5-2 is a simplified block diagram illustrating the interfaces and some of the functional components. Single lines in the illustration represent serial data and the wider lines represent parallel data. Clock timing is illustrated at the end of this section, and the circuit is shown on Sheet 11. #### Computer Interface The purpose of the computer interface is to (1) buffer lines between the Q-Bus of the LSI-11 computer and the controller, and (2) to synchronize information transfers. The controller is a slave device during initialization and status-transfer sequences. The controller is bus master during data transfers and either receives data from or outputs data to the computer memory via the LSI-11 DMA facility. The control lines request information transfers, select the type and direction of transfers, and synchronize the transfers. The control lines are unidirectional and used for "bus arbitration." Bus synchronization is fully controlled by the controller microprocessor. This allows the computer bus to be used by other devices when the disc controller is busy with internal functions and controller/disc data transfers. Figure 5-2. Simplified Block Diagram All bus signals in this section are described in Table 1-1 or in the term listing. Control transceiver signals for the Q bus are shown on Sheet 1, components U65 through U68. Data and address transceiver are shown on Sheet 2. The bus control signals are designated BD and bus address and data signals are designated BDA. The latter are distributed as DBUS signals D0-D7. On Sheet 3 there are two components designated PAL003 and PAL005. These components are called programmable arrayed logics. The PAL's can function as eight OR gates with eight AND gates of 32 inputs each with inverters, all of which are programmable. The outputs, F1 through F4 in U69 and F1 through F6 in U64, function as the outputs of flip flops. The Interrupt Protocol, PAL003 on Sheet 3 is defined by components U69, U70, flip flop U34 and gate U12B. Bus Interrupt and Controller Interrupt Request lines, BIRQ4-7 and JP3-5, respectively, from U70, are input to the PAL for interrupt priority determination. The signal BDIN (Data In) starts the Interrupt Acknowledge Sequence in U69. The output flip flop F2 samples the states of the bus and controller interrupt request lines. F2 will set if the controller is requesting an interrupt and there is no higher level interrupting device. When IAKI (Host Interrupt Acknowledge In) is received from the CPU, the state of F2 will determine if F3 is set (indicating the controller has the priority) or if F4 is reset (indicating the controller has lost the priority). Bus transceiver U63 is for bits 18 through 21 of the 22-bit extension. These bits are held in the bus extension register, address 774 410. PAL005 is the DMA Protocol and Sequence control. Flip flops F1 and F2 synchronize the DMA grant signal and determine if the controller is involved in the DMA queue. If the controller is requesting a DMA cycle, F3 will set notifying the microprocessor that it is the bus master. If the controller is not in the queue, F4 will reset which will pass the acknowledge to a lower priority. Flip flops F5 and F6 monitor the bus controls and will handle the address/data multiplexing involved when the microprocessor is the bus master. The output MFIO+ monitors the 3-bit field that is assigned to the microcode sequencer (U1, Sheet 5) and constructs the fourth bit that the sequencer requires. #### **Microprocessor Functions** The microprocessor (Sheet 6) is the timing and control center of the controller. The microprocessor is controlled by instructions stored in programmable read-only memory (PROM). The instructions, called "firmware," cause the microprocessor to operate in a prescribed manner during each of the computer-selected functions. The functions are established by a series of instructions issued by the LSI-11. Because the disc and computer transfer data at different rates, it is necessary to buffer data going to and from the disc. High-speed RAM allows a full sector of data to be buffered during read and write operations. All data transfer and computer/disc protocol are under microprocessor control. This feature allows modification of controller operating characteristics by making only changes to the firmware. Input/out- put logic remains essentially unchanged. The output from the microprocessor is the "Y Bus." Y Bus data governs all controller operations by acting as the controller source for all receivers and drivers either directly or through the source/destination decode IC's. The "D Bus" is the data input of the microprocessor. Tri-state drivers allow many signal sources to be connected to the bus while only one at a time is enabled by the source/destination decode logic on Sheet 9. The following list describes D Bus enabling signals: | Function | Term | Component<br>Enabled | Sheet | | |-------------------------|-------|----------------------|-------|--| | Data Transceivers MSB | XSD0- | U59, U60 | 2 | | | Data Transceivers LSB | XSD1- | U61, U62 | 2 | | | Q Bus Status | XSD2- | U29 | 9 | | | Data Buffer | XSD3- | U39, U40 | 7 | | | Disc Drive Status | XSD4- | U28 | 9 | | | Q Bus Control/Extension | XSD5- | U68 | 1, 3 | | | Bootstrap Enable | XSD6- | U12, U38 | 7 | | | Constant Enable | XSD7- | U12, U38 | 7 | | All data on the D Bus is under control of the firmware as decoded by U27 on Sheet 9. The microprocessor selects the proper input data by enabling one of the above lines. The Y Bus is the microprocessor output. Output of the microcode PROMs (Sheet 4) is decoded by U26 (Sheet 9) to select the destination of the data on the Y bus. The following list describes Y Bus enabling signals. | Function | Term | Component<br>Enabled | Sheet | | |------------------------------------------|-------|----------------------|-------|--| | Transceiver Driver Clock<br>MSB | LXR0- | U59, U60 | 2 | | | Transceiver Driver Clock<br>LSB | LXR1- | U61, U62, | 2 | | | Buffer Address Register and Byte Counter | LXR2- | U44, U51,<br>U52 | 7 | | | RAM Write Control | LXR3- | U34, U54 | 8 | | | System Control Register | LXR4- | U30 | 10 | | | Drive Control/Head Select | LXR5- | U4 | 10 | | | Q Bus Control/Extension | XLR6- | U68 | 1, 3 | | The microprogram sequencer, shown on Sheet 5, advances the program counter to the next address unless the condition code signal is active (output Z from PAL001). When CC is active, the jump address from the microcode is input to the sequencer. Internal flip flops in PAL001 update the current microprocessor status. When signal CR3-0 is high, the flip flops retain the last microprocessor status. Bits CR4-5, -6, and -7 determine the condition code to test on conditional jump instructions to the sequencer. These signals are: | Bit 7 | Bit 6 | Bit 5 | Description | |-------|-------|-------|--------------------| | 0 | . 0 | 0 | Carry latch false | | 0 | 0 | 1 | ALU equal to zero | | 0 | ļ | 0 | Carry latch true | | 0 | 1 | 1 | ALU not zero | | 1 | 0 | 0 | Bit latch true | | 1 | 0 | 1 | Slave latch true | | 1 | 1 , | 0 | Bit latch false | | 1 | 1 | 1 | Unconditioned jump | The carry input (CI) signal to the microprocessor is determined by CR2-: | Bit 1 | Bit 0 | Description | |-------|-------|---------------------| | 0 | 0 | No carry input | | 0 | 1 | Bit test flop input | | 1 | 0 | Carry latch input | | 1 | 1 | Force carry input | #### RAM Data Buffer The RAM data buffer is shown on Sheet 7. Data transfers to and from the buffer are both two-step operations. First, an entire sector of data is loaded into the buffer during a read or write operation. Once loaded, the contents of the buffer are then transferred to disc or memory in a completely separate operation. During a write operation, address and parallel data (Y00-Y07) are transferred from memory via the microprocessor to the storage latch U42 and the data buffer address register, U51 and U52. The data is then transferred to the buffer and output (DAT0-DAT7) to the shift register. During a read operation, parallel data is transferred from the shift register and input (DAT0-DAT7) to the data buffer. Timing for RAM address and chip select is shown in Figure 5-3. #### Peripheral Interface-Write Data Path A simplified diagram of the write path is shown in Figure 5-4. Parallel inputs (DAT0-DAT7) from the buffer are transferred to the shift register U43, Sheet 8. The output from QH is serial data which is selected by the read/write multiplexer, U57. The output Y0 is transmitted to flip flop U45, which creates a ninth bit, or holding bit, for the ECC register to permit ECC timing to catch up with the rest of the logic. The output signal from the flip flop is BIT+. The outputs F1, F2, F3, F4, and F5 of PAL002 are described under "Read Data Paths." The resulting output of F6 PAL002 is the enabling signal for the data buffer to write. The signal F7 (NEWBYT+) is used on a write operation to flag the byte boundary for the shift register and the read/write sequencer (PAL006, Sheet 13). The signal F8 (STOP—) indicates to the microcode that a read/write operation is complete. The term WRAM- from gate U32 determines whether the logic writes to the buffer during a read operation or reads from the buffer during a write operation. The timing is shown in Figure 5-5. #### ECC - Write The ECC (error correction code) logic is shown on Sheet 12. The timing for ECC is shown in Figure 5-6. During a write operation, data (BIT+), is input to multiplexer U24 and to parity generator U36. The calculated check sum from U36 is input to the multiplexer at ECC time; the signal ECCTIM— goes low when the multiplexer shifts from the data path to ECC characters at the end of a field. The components U37, U48, U49, and U50 are parallel-out shift registers which generate the 32-bit polynomial, or check character. Switch 1 and flip flop U53 are used during a read operation and are described below. The output during a write operation is WDATA+ which is input to the write sequencer. #### MFM - Write The logic for the write sequencer and MFM encoding is shown on Sheet 13. The MFM (modified frequency modulation) encoding circuit basically accepts NRZI data, adds clocks, and rearranges the single output pulse stream to contain data and clock pulses. The circuit also compensates for the magnetic flux density phenomenon of peak shift; in high density packing, the pulses have a tendency to separate themselves at the point where a high frequency pulse stream meets a lower frequency pulse stream. The pulse stream (WDATA+) from the ECC circuit is input to the write sequencer, PAL006, and to MFM encoding, PAL004. The single output stream of pulses is represented by WPLS—. The timing is shown in Figure 5-7 where "0" represents a clock pulse and "1" represents a data pulse on the WPLS— stream. (To simplify the diagram, EPCOMP (enable precompensation) and KILL (omit one pulse) are ignored at this time. The conditions for arranging the pulses are as follows: - 1. If the WMFM cell is to hold a "0" (clock), a pulse will occur at the beginning of a cell. - 2. If the WMFM cell is to hold a "1" (data, a pulse will occur at the center of a cell. - 3. Pulses at the beginning of a cell are suppressed if the previous cell contains a "1". - 4. There is never more than one pulse, either clock or data, in any bit cell. The above conditions for placing a pulse on the stream are shown on the timing diagram. The output at F1, PAL006, is determined by ROMCLK— Figure 5-3. Ram Address Chip Select Timing Figure 5-4. Write Data Path and WDATA+. The equation for this relationship is F1=ROMCLK · WDATA + /ROMCLK · F1. The pulse stream may be further modified to compensate for peak shift. This phenomenon is illustrated in Figure 5-8. The outputs F1, F2, and F3 of PAL004 produce the MFM pulses: F1 produces the late pulse, 20 nanoseconds delay; F2 produces the center pulse, 10 nanoseconds delay; and F3 produces the early pulse, no delay. The center pulse is illustrated on the timing diagram by F2, PAL004. Table 5-3 lists the conditions for precompensation. F4 and F5 are internal flip flops in PAL004. The signal WDATA is input at C PAL004, and DATA is from F1 PAL006 to input A PAL004. Table 5-3. Enable Precompensation | | TERM | l | | | ОИТРИТ | | | |-----------------------------------------------------------------------------------------------------------------------------------------|---------------------------------|-------------------------------------------|----------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------|--------|-----------|----| | F5 F4 | DATA | WDATA | ENABLE | PULSE | F1 | F2 | F3 | | X X 0 X 0 X 1 X 0 0 0 0 0 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 0 1 0 0 0 1 0 0 0 1 0 0 0 0 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | 1<br>1<br>1<br>1<br>0<br>0<br>0 | X<br>0<br>1<br>0<br>1<br>X<br>0<br>0<br>0 | EPCOMP<br>EPCOMP<br>EPCOMP<br>EPCOMP<br>EPCOMP<br>EPCOMP<br>EPCOMP<br>EPCOMP<br>EPCOMP | DATA CENTER DATA CENTER DATA LATE DATA EARLY DATA CENTER CLOCK CENTER CLOCK CENTER CLOCK LATE CLOCK LATE CLOCK CENTER | L | 000 000 0 | E | The signal EPCOMP (enable precompensation) on the table is false from cylinder zero until the disc reaches the cylinder identified during formatting, "Start Precompensation at Cylinder \_\_\_\_." This value is taken from the disc manufacturer's specification. The pulse column identifies data or clock and center, early or late. The output column identifies the flip flop outputs of PAL004 and whether the pulse is centered, early, or late. Other outputs from PAL006 are as follows: F2 controls the enabling of the ECC register so that preamble information does not corrupt the polynomial. F3 delays the NEWBYT signal during writing to get the ECC timing into the time domain of the BIT+ flip flop (Sheet 8). F4 prepares for ECC time during a read operation and will enable the read ECC sync flip flop, U46, Sheet 13. F5 disables the write shift register (Sheet 8) during write format until the RAM enters a new header partition. F6 latches the output of the KILL flip flop (F8, PAL004) and remembers that the address mark is already written so that all succeeding X 'A1' characters do not get their clocks stripped. F7 is used in conjunction with F5 to hold the write shift register reset. F8 is used to signal that the ECC character time has arrived during a write command. The output of F8, PAL004 (KILL) is used to create a unique pulse pattern for the address mark by "stripping" or omitting one clock pulse from the WPLS stream. The timing is illustrated in Figure 5-9. From MFM encoding the pulse stream is input to the write one shot (U33, Sheet 9) where each pulse is shaped ("stretched") into a 70 nanosecond pulse for transmittal to the drive. The stream is then multiplexed to write data by U6, Sheet 10, and driven by the driver U5 as WDAT0 or WDAT1. Figure 5-8. Peak Shift Figure 5-9. Address Mark and KILL Timing #### Peripheral Interface - Read Data Path A simplified diagram of the read data path is shown in Figure 5-10. The logic for read data inputs from the drive to the controller is shown on Sheet 10. The encoded pulse stream, RDAT0 for the first drive and RDAT1 for the second, are received by U7. Signals DRVSL0 and DRVSL1 are input to the U6 multiplexer selecting the drive and the pulse stream. The selected output of U6 is Y2, RMFM+, read modified frequency modulation. This signal is transmitted to the read/write multiplexer U57, Sheet 8. The output Y2 of U57 is determined by read signals RMFM + and AMSRCH (address mark search). When both are high, the CTCHME+ (catch me) signal is active. The latter is a pulse that is input to the phase-locked loop circuit where the controller timing "catches up" with the pulse stream. #### Phase-Locked Loop - Read Data The purpose of the phase-locked loop circuit, shown on Sheet 11, is to bring the timing on the controller in phase with data on the disc. A simplified diagram of the circuit is shown in Figure 5-11. Component U47 is used at the input of the circuit as the temperature compensation reference. At the output, U47 is used for the analog conversion of phase difference. Because of temperature drift, both segments of the component change at approximately the same rate. The output of the compensation reference is transmitted to the *negative* input of the analog inverter, U58, and the output of the analog converter is transmitted to the *positive* input of U58. The analog inverter compares the phase error and the reference and corrects the voltage for the input of the voltage controlled oscillator, U35. The timing of the circuit, with and without phase error, is shown in Figures 5-12 and 5-13. The term VCO+ is the output of the voltage controlled oscillator. The AMSRCH+ (address mark search) flip flop indicates that a read operation is taking place. The term VCO+ is the clock input for the digitized phase difference flip flop, U46. This term and RDOS (read data one shot) determine the center of the phase as shown in the illustrations. If there is no phase error, the outputs of U47, which are PLS+ and PLS-, will be 55 nanoseconds each; both will be high and low for an equal time period. As frequency of read data (RDOS) increases, PLS+ remains low longer, and PLS2— remains high for a shorter time, as shown in Figure 5-11. The exaggerated phase error shown in the example occurs when both PLS1+ and PLS2— are low for 76NS and high for 34NS. Notice that the 90NS high and low times are constant in both illustrations. The 110NS segment of the cycle is also constant; the trailing edges of PLS1+ and PLS2— shift left Figure 5-10. Read Data Path relative to the center of this segment, whereas the leading edges of the pulses remain constant. This offset from center represents the phase error and is transmitted to the analog inverter, U58, where the voltage correction is made for the VCO. If the width of PLS2— is greater than PLS1+, RDOS is slower than the reference clock and must be phase shifted in the other direction. #### ECC - Read From the phase-locked loop circuit, RDOS is transmitted to DC flip flop U45 (pin 2), Sheet 8, where the signal is synchronized with the VCO signal. This signal is then selected by multiplexer U57 for a read operation and output at Y0, U57, to a second flip flop, U45 (pin 12). The latter flip flop acts Figure 5-11. Simplified Diagram of Phase-Locked Loop Figure 5-12. PLL Timing with No Phase Error Figure 5-13. PLL Timing with Phase Error as a holding bit, or ninth bit, to permit the ECC circuits to catch up with the rest of the logic. The output of this flip flop is BIT+ which goes to the ECC logic. The data stream is also transmitted to U55 (PAL002) from the first flip flop. This PAL is described below. The ECC logic is shown on Sheet 12. BIT+ is transmitted to the parity generator, U36, and to multiplexer U24. The components U37, U48, U49 and U50 are 8-bit serial-in, parallel-out shift registers. These components divide data from the disc and generate a 32-bit remainder word. If the remainder is not zero, a "syndrome" is created. If the remainder is equal to zero, there is no error. The output of U36, pin 5, is the even sum of the 32-bit parity generator. Odd parity from U36, pin 6, to U24, Y3 is output to flip flop U53. The flip flop monitors the 32-bit syndrome. If there are zero's output from the flip flop there is no error, and the output ECCERR+ is false. If there is an error, then ECCERR+ is true. When ECCTIM— is a high signal to U24, the output Y0 reads BIT+. When ECCTIM goes low Y0 reads from the parity generator through switch 1. At ECC time, the pulse stream becomes the syndrome and is read into the data buffer right behind the data from the disc. The data and syndrome (DATAIN+) are read into the microcode to determine if the error is correctable or uncorrectable. When Switch 1 is OFF (open), the syndrome is discarded, and from Y0, thirty-two 1's will flag the controller that the error is uncorrectable. The switch is used when running diagnostics so that media flaws can be detected and mapped. When the switch is ON (closed), a valid syndrome is transmitted to the RAM. The signal CP6— resets the ECC register and error flip flop. The signal ECCEN+ is active when ECC time is false. This term from Y1 enables U48. The signal prohibits extraneous pulses from being entered into the ECC polynomial, e.g., address mark or sync pulses. The signal DATAIN+ is transmitted to the read/ write shift register (Sheet 8) for parallel transfer to the data buffer. ## Address Mark Detect and Byte Clock Control - Read The logic for address mark detect is shown on Sheet 8. As serial data (DATAIN+) is transmitted to the shift register, the data stream from the phase-locked loop circuit (RDOS) is transmitted to PAL002, address mark detect, through flip flop U45, pin 5. The outputs of PAL002 flip flops F1, F2, F3 and F4 are used to form a four bit state machine that scans the incoming data stream from the U45 flip flop for the unique pattern of the address mark character. When the address mark is detected, the flip flops lock into hexidecimal state 'F' (1111). Flip flop F5 is used to detect the locking action of the state machine and will begin to toggle when this occurs. F5 is then used to divide the VCO clock in half and be synchronized to the data domain of the incoming data stream. F6 is used to control the RAM buffer cycling on read/write commands. This timing relationship is shown in Figure 5-14. At bit count 8, F6 is stable 1 bit time to enable one byte from the shift register to be input to the RAM. The output F5 from the pal is a 5 MHz clock gated (U11, pin 2) with the 10 MHz VCO clock (U11, pin 1). The resulting signal (U11, pin 3) is a 5 MHz clock in the middle of the data domain, which goes to B3 of the multiplexer and is output (Y3) to the 3-bit counter U44. The flip flop F7 is used during a write operation. F8 (STOP—) indicates that the read/write operation is complete, and this is transmitted to the microcode. #### Clocks The controller clock logic is shown on Sheet 13. The timing relationship is shown in Figure 5-15. Figure 5-15. Clocks •