# DISK 2" & SELECTOR CHANNEL" TECHNICAL MANUAL IEEE 696 / S-100 # ARBITRATED 24 BIT DMA HARD DISK CONTROLLER FOR SHUGART SA4000 AND FUJITSU 2300 SERIES DRIVES A **EUDBUUT** COMPANY # **CONTENTS** | DISK 2 SECTION | |--------------------------------------| | About Disk 2 | | Technical Overview | | Switch Setting and Option Selection | | Formatting a Hard Disk | | Jumper & Switch Settings | | Programming the Disk 2 | | Control/Status Register | | Theory of Operation | | On the Bus Side - I/O Ports | | DMA Interface | | On the Disk Side - Disk Interface | | In the Middle - Disk data | | Logic Diagram | | Parts List | | Component Layout | | SELECTOR CHANNEL SECTION | | About Selector Channel | | Technical Overview | | Switch Settings and Option Selection | | Programming the Selector Channel | | Theory of Operation | | Logic Diagram 29-3 | | Parts List | | Component Layout | | SERVICE AND WARRANTY INFORMATION | DISK 2 & SELECTOR CHANNEL Copyright ©1982 CompuPro Hayward, CA 94545 First Printing: February 1982 Latest Printing: April 1983 DISCLAIMER - CompuPro makes no representations or warranties with respect to the contents hereof and specifically disclaims any implied warranties of merchantability or fitness for any particular purpose. Further, CompuPro reserves the right to revise this publication and to make any changes from time to time in the content hereof without obligation of CompuPro to notify any person of such revision or changes. Registered trademarks: CompuPro; CompuPro. CP/M; Digital Research. Trademarks: DISK 2 & Selector Channel; W.J. Godbout: CP/M 80; CP/M-86; MP/M-86 and Digital Research; Digital Research. Contents of this document were proofread with the aid of SpellGuard a product from SORCIM Inc. Santa Clara, CA. All rights reserved. No part of this publication may be reproducted or transmitted in any form, or by any means, without the written permission of CompuPro. Printed and assembled in the United States of America. ### **ABOUT DISK 2** Congratulations on your purchase of the DISK 2 hard disk controller and the SELECTOR channel. These boards are designed for maximum performance applications featuring full physical and electrical compatibility with the IEEE 696/S-100 specifications. The boards implement a temporary master interface capable of transferring data directly between a hard disk and memory at data rates up to 1 MBYTE per second. The boards may directly access the full 16 MBYTE extended address range of the bus while requiring only three I/O port addresses for their operation. ### TECHNICAL OVERVIEW The DISK 2 board features a standard IEEE 696/S-100 edge connector along its bottom edge and a set of ribbon cable connectors along the top which will directly accept up to four Winchester type hard disk drives of a given type selected from a variety of manufacturers, models and capacities. The DISK 2 contains all of the hardware necessary for control of the drives including the ability to format. The board also contains the necessary hardware to arbitrate for and accept the bus as a temporary master per the IEEE 696/S-100 specification and to transfer data thereon. The SELECTOR channel contains all of the hardware for generation of address, status and control signals required for temporary master operation of the DISK 2. The two board combination functions exactly as a temporary master per the bus specifications. No interconnections (other than the bus itself) are required between the boards for operation and all bus signals are used in there normal way. The DISK 2 performs no useful function without a SELECTOR channel, but the SELECTOR channel may be shared by other controllers designed to use it. # SWITCH SETTING AND OPTION SELECTION | | SWITCH 1 | FUNCTION | |----|------------|------------------------------| | 1 | _ | Not Used | | 2 | P3 | DMA PRIORITY (MSB)-\ | | 3 | ₽2 | DMA PRIORITY ON - "O" | | 4 | P1 | DMA PRIORITY OFF = "1" | | 5 | PO | DMA PRIORITY (LSB)-/ | | 6 | 20 | 2048 Byte Sectors | | 7 | 10 | 1024 Buta Costona | | 8 | 5 | 512 Byte Sectors ONLY ONE ON | | 9 | 2 | 256 Byte Sectors AT ANY TIME | | 10 | 1 | 128 Byte Sectors/ | | | SWITCH 2 | | | 1 | <b>A</b> 7 | Port Address (MSB) | | 2 | A6 | •• # I | | 3 | A5 | " " ON = "O" 👂 🗀 ८ ह | | 4 | A4 | OFF = "1" | | 5 | A3 | 94 mg | | 6 | A2 | <b>₩</b> •• | | 7 | A1 | Port Address (LSB) | | 8 | - | Not Used | **PORT SELECTION:** The DISK 2 is controlled through two I/O ports. A pair of consecutively addressed ports are selected by setting SW2-1 through SW2-7 according to the seven most significant bits of the desired port address. The CompuPro standard for the DISK 2 is ports C8 and C9. DMA PRIORITY: When requesting the bus for transfer of data as a temporary master, the DISK 2 will arbitrate with a priority which is set by switches SW1-2 through SW1-5. Priority 15 is the highest while 0 is the lowest. When assigning a priority to the DISK 2 bus transfers, all other DMA devices must be taken into consideration. If the DISK 2 has a higher priority then when any conflict occurs the DISK 2 will win the arbitration, but if the other requesting device can complete its operation in only a short time it could be overall faster to give the slower device a higher priority. Latency time for each DMA devices and the amount of bus access time required by each DMA device will help determine which device should have which priority for optimum system throughput. SECTOR SIZE: The DISK 2 may read, write and format sector sizes from 128 bytes to 2048 bytes. The desired sector size is selected by SWI positions 6-10 according to the table. Only one of these switches may be on at a time. (Changing sector sizes also requires adjustments in the drives and software, and reformatting the drives). In addition to setting switches as described above, a number of options are selected by means of jumpers. INTERRUPT VECTOR SELECTION: Use of interrupts is not required by the CP/M supplied with the DISK 2/SELECTOR CHANNEL board set. But, if the use of an interrupt is desired to allow the CPU to process other tasks concurrent with a DISK 2 operation, installation of a jumper in one of the locations from J7 to J14 will result in ATTN, (the "done" flag) asserting one of the vectored interrupt lines VIO through VI7 respectively. The flag may be reset through the control register (See Programming). If the use of an interrupt is desired, and a vectored interrupt controller is not available, jumper J15 will result in ATTN asserting INT. An interrupt on this line may be sensed directly by the CPU. Note that ATTN will come up asserted after a RESET. WRITE CLOCK PHASE: All of the Shugart compatible drives (such as the Memorex 100 series and the Fujitsu 2300 series) require jumper J6 (between U25 & U26) in the C\* position while Shugart SA4000 series drives require that J6 be in the C position. ### FORMATTING A HARD DISK Before using your hard disk, you must format it with the "DISK2" utility provided with your CP/M 80 and CP/M 86 system disks. The "DISK2" program will format, verify and test your hard disk drive. The different options that can be used are in the following list. USAGE: DISK2 {options} 1: At least one option must be specified such as the drive type. You can mix any of the options. Options consist of: | m10 | Set drive type to Fujitsu 10 Mbyte | |--------------|-----------------------------------------| | m20 | Set drive type to Fujitsu 20 Mbyte | | m26 | Set drive type to Shugart 26 Mbyte* | | <b>m</b> 10m | Set drive type to Memorex 10 Mbyte* | | drive # | Format selected drive | | format | Format headers | | data | Write out data fields with E5H | | test | Perform a data field test | | seek | Perform a seek test | | all | Perform format, data test, seek test | | Bkew # | Set skewing of disk to specified number | | | This option goes along with hardware | | | settings. | <sup>\*</sup> Although the DISK 2 program will format these drives, The CompuPro CP/M 80 and CP/M 86 systems are not configured for them. If an option is not specified then the following defaults are used: Defaults - M20 skew of 2 sector size 1024 drive 0 no tests or formatting Examples - disk2 format data disk2 m20 all disk2 data disk2 format data drive 1 skew 3 m10 ### JUMPER & SWITCH SETTINGS # LSI FUJITSU 2300 & NEW MEMOREX 100 SERIES | S1<br>(Jumper) | SWI | sw2 | SW3 | SW4 | SW5 | |----------------|-----------------------------------------------------------------------------------------|------------------------------------------------|-----------------------------|-------------------------------------------------------------|-----------------| | (agmher) | OFF ON | OFF ON | OFF ON | OFF ON | OFF ON | | 23 | <pre> &lt; 1 2 &gt; &lt; 3 &lt; 4 &lt; 5 &lt; 6 7 &gt; 4 </pre> | < 1 < 2<br>3 ><br>4 ><br>< 5<br>6 ><br>< 7 < 8 | 1 > 2 > < 3 < 4 < 5 < 6 < 7 | <pre>&lt; 1 &lt; 2 &lt; 3 &lt; 4 &lt; 5 &lt; 6 &lt; 7</pre> | 1 > 2 > 3 > < 4 | | | <b>\</b> * | ` 0 | 8 > | < 8 | | | FUJITSU | \$1 | S | W1 | s | W2 . | SW | 13 | SW4 | | | |---------------------|-------------|------|-------------|--------|----------------|----------|--------|-------|-----|--| | 2300 | (Jumper) | OFF | ON | OFF | ON | OFF | ON | OFF | ON | | | 2300 | 2-3 | < | 1 | < | 1 | | 1 > | < 1 | | | | | | • | 2 > | < | 2 | | 2 > | < 2 | | | | | <b>S2</b> | < | 3 | | 3 > | < | 3 | < : | 3 | | | | (Jumper) | ે | 4 | | 4 > | < | 4 | < 4 | 4 | | | | 12 | ~ ~ | 5 | < | 5 | < | 5 | · < : | 5 | | | | + 4 | ે | 6 | • | 6 > | <b>〈</b> | 5<br>6 | | 5 | | | | <b>S</b> 3 | ` | 7 > | < | 7 | < | 7 | | 7 | | | | (Jumper) | | 8 | ζ. | 8 | | 8 > | < : | 8 | | | | 12 | ` | | • | _ | | | | | | | | 12 | | | | | | | | | | | | | | | | | | | | | | | SHUGART | LSB | | | | | | | MSB | MSB | | | <u>sa</u> 4000 | | | <del></del> | 6 7 | 8 | 9 | 10 | 11 | 12 | | | JUMPER | 1 2 3 | 4 . | _ | • | · . | in | | out | in | | | | out out i | a in | in | out or | ut in | | | | | | | | | | | | _ | | | | | | | x | DS1 / 2,3,4 | ST | | RY | 13 | <u> </u> | | T | С | | | <del></del> | in / out | in | | in | 11 | | | 1n | out | | | out | In / out | -11 | | | _ | | | | | | | 00 / 70 | D | E | 81 | / S2 | 41 | H | E1. | E2,E3 | R | | | SC / BC<br>in / out | in | out | | / out | | t out | - | conn. | in | | | 10 / OUC | *** | ~~, | | . , | | | | | | | | s | F | SL | | GR | D | L1 | | | | | | out | out | in | | in | O <sup>1</sup> | ut | | | | | | 000 | | | | | | | | | | | # PROGRAMMING THE DISK 2 All functions of the DISK 2 are controlled through a pair of I/O ports whose addresses are selected by SWITCH 2. The lower addressed port is the control/status port. Data written to this port is placed in the CTL register while reading this port will return the contents of the STATUS register. The upper port is the DATA port. Writing to this port will send a byte of data to a data register previously selected by setting the CTL register. Reading the DATA port will cause a STEP pulse to be sent to the previously selected drive (drive selection will be discussed below). No valid data is returned by the read. ### CONTROL/STATUS REGISTER | BIT | CTL ( WRITE ) | STATUS<br>( READ ) | |--------|---------------|--------------------| | 7 | ATTN* | ATTN* | | 6 | RUN | TIME OUT | | 5 | OP2 | CRC ERROR | | 4 | OP1 | OVER RUN | | 3 | OP0 | READY* | | 2 | FAULT CLR | SEEK COMPLETE* | | _<br>1 | us1 | WRITE FAULT* | | ō | บรอ | TRACK 0* | <sup>\*</sup> indicates an active low signal While the STATUS register may be read at any time, it might be in either a transparent or a latched state. If it is transparent, the data returned is the current state of the registers inputs. If it is latched, data returned was the input data at the time the register was latched. The current state is indicated by the ATTN\* bit, ATTN\* true (low) indicating a latched condition. The ATTN\* bit may be controlled through the CTL register to make the STATUS register transparent. There are four registers which may be written through the DATA port. To write a specific register, the register number is first stored in the CTL register bits OP1 and OPO as shown in the table below. This will direct a byte of data written on a subsequent transfer via the DATA port to the appropriate register. | OP1 | OPO | DATA REGISTER | | |------------------|-------------|-------------------------------------|---------------------------------------------------------| | 0<br>0<br>1<br>1 | 0<br>1<br>0 | DRIVE<br>CYLINDER<br>HEAD<br>SECTOR | SEE STATUS/CONTROL<br>CHART ABOVE FOR<br>BIT ASSIGNMENT | DRIVE SELECTION AND STATUS: Up to four drives may share the control cable which is connected to the 50 pin ribbon connector and runs "daisy chained" to each of the drives. There is a unique DRIVE SELECT line in the cable for each of the drives. Only one of these select lines may be active at a time. The selected drive will respond to the control output lines on the cable and drive its status onto the input lines. The select lines are driven from the four high order bits of the DRIVE register. Bit 4 selects the first drive, bit 5 the second etc. The READY\* bit in the status register is driven by the READY line of the selected drive. Similarly the status lines WRITE FAULT\*, SEEK COMPLETE\* and TRACK O\* all reflect the status of the selected drive. HEAD POSITIONING: Most drives require that the controller software remember the current track. To position the read/write heads at a new track, the drive is selected and the DATA port is read a number of times equal to the difference between the current track and the new track. Each read from the DATA port will send a STEP pulse to the selected drive causing its heads to move one track. The direction of the STEP is controlled by the OP2 bit of the CTL register. OP2 in the CTL register drives the DIRECTION\* line in the control cable. Most drives use stepping motors or other positioning devices with limited step rates. (See drive specifications for maximum step rates). Inside the boxes below are features that may be available on your drives and are for use by the more experienced system programmers. <sup>\*</sup> Many of the newer drives feature a fast seek mode. These drives will accept and accumulate STEP pulses at a very high rate without moving the access mechanism. After all of the pulses are received, the SEEK is performed at a much higher average track per second rate than would be achieved stepping one track at a time. (See drive specifications). The DISK 2 board can accommodate this feature if your drive has it. HEAD SETTLING TIME: After a seek, the hard disk require a significant amount of time (in the order of one revolution) for the heads to settle before reading or writing is attempted. The software must provide this delay starting with the receipt of SEEK COMPLETE. This time period can be found in your drive specifications. - \* Some of the newer drives provide a jumper option which will delay the SEEK COMPLETE indication by the required head settling period eliminating this burden from the drive software. - \* The DISK 2 automatic functions are interlocked to SEEK COMPLETE. As an alternative to the use of a timer for generation of the head setting delay in a multiprogramming application, the disk software may issue a NULL command immediately following the step pulses of the seek. The NULL command will not begin until the drive indicates a SEEK COMPLETE. NULL has no function other than to fail with a TIME OUT indication after two index pulses from the drive. This completion would interrupt the CPU indicating that the drive was ready to accept a read or write command. If the available drives include the option of delaying SEEK COMPLETE by the head settling time, the disk software may issue a READ DATA or WRITE DATA immediately following the step pulses. Again, the interlock will hold off the automatic operation until SEEK COMPLETE is indicated. READ SELECTION: Prior to any data transfer operation to the disk, the software must select a read/write head. The drives will have at least one and sometimes two heads for each surface of each platter used for data storage. The control cable includes 4 head address lines. The lines are driven by the lower four bits of the DRIVE register, Bit 0 being the least significant. The required nibble selecting one of up to sixteen heads, as appropriate for the drive, will normally be stored in the DRIVE register at the same time that the drive is selected since this is the function of the upper nibble in the register. AUTONATIC OPERATIONS: On the disk, each data field is preceded by a unique header field which was written when the disk was formatted. A read or write operation consists of searching the entire track of the currently selected drive and head for the header record of the desired sector. Once the header is found, the data field immediately following the header may be read or written. Because of the high data transfer rate of the disk, all of these operations occur too quickly for direct software control. For this reason, the DISK 2 contains an FSM (finite state machine) which performs these functions automatically. THE NULL COMMAND: (COMMAND 00) This command was mentioned above under head settling time however its primary application is to align sectors relative to index during formatting. It is issued in the same way as a READ DATA except with a NULL operation code. The CYLINDER, HEAD and SECTOR register are not required and no SELECTOR CHANNEL programming is required because no data is transferred. A ready drive must be selected as a source for index or the DISK 2 will fail to complete the operation. THE READ DATA COMMAND: (COMMAND 01) Prior to issuing a READ DATA command, the location of the required sector must be determined and the drive, track and head selection processes completed so that once the read begins, the sector may be found. This selection processes has all been described above. Since the READ DATA will be performed automatically, the memory address to which the data will be transferred and the identity of the sector header must all be determined before the operation is begun. (See the SELECTOR CHANNEL manual for programming considerations). The header fields contain a three byte code. During a search, these bytes are compared against the contents of the CYLINDER, HEAD and SECTOR registers. These are DATA registers whose contents may be loaded as described above. The contents of the CYLINDER, HEAD and SECTOR registers have no affect on the selection process, they are only used as a source of data for matching headers. Once all of the data has been loaded, the command byte may be written to the CTL register. The command byte must contain the following: US1 & USO: These bits must contain the drive number and be consistent with the contents of the DRIVE register. FAULT CLR: Must be 0 . OP2 - OPO: Must contain the operation code for the desired function. (See Op Code Table). RUN: Must be 1 indicating an automatic operation. ATTN\*: Must be a 1 (false) making the status register transparent and indicating busy. Once the command has been issued, the CPU is free to perform other tasks. The DISK 2 will transfer the sector to memory automatically once it is found. Completion of the operation is indicated by the ATTN\* bit of the STATUS register which may optionally result in an interrupt. RESULT STATUS: It is possible that an automatic operation may not complete satisfactorily. After any automatic operation, the STATUS register should be read, and it contents which were latched at the moment of completion should be evaluated. The resulting status from a successful read will be a 3 (or a 2 if track 0 is being read). If an error has occurred, the bits from the STATUS register should be evaluated with the following priority: **READY**\* (Bit 3) If the drive had lost its ready state, no data transfers may occur. TIME OUT will probably also be true. Check for wrong drive selected. May also be caused by a power line dip or drive failure. TIME OUT (Bit 6) Automatic commands will be terminated and the time out indication set if two index pulses are received from the drive before an operation is completed. This allows between one and two complete passes of the track to find a header. TIME OUT would indicate that the header was not found. Since soft errors may occur, the original command should be retried a few times. If the TIME OUT persists, a READ HEADER command may be used to read any header on the track. This header found would indicate if the wrong track or head was being searched. A wrong track could result from a drive seek error. If the track was wrong, the drive should be homed to track 0 and the seek performed again. If all of the above are correct and the header is still unreadable, a hard error is indicated. OVER RUE (Bit 5) This bit indicates that the request for use of the bus was not acknowledged quickly enough and some or all of the data may have failed to make it to memory. If the OVER RUN was due to collisions with other DMA devices or CPU response to the bus request, it may be resolved through retries. If this status persists and none of the data was transferred, the SELECTOR CHANNEL programming and bus DMA capability should be verified. If some of the data is being transferred, possibly incorrect, the combination of the bus clock rate and memory speed as controlled by wait states may not be fast enough for the drive being used. CRC ERROR (Bit 6) This bit indicates that the CRC check word computed on the data as it was read from the disk did not match the check word which followed the data field. This again may result from a "soft" read error. The operation should be retried. THE WRITE DATA COMMAND: (COMMAND 02) The WRITE DATA procedure is the same as the READ DATA procedure except the command sent to the CTL register must have the write operation code in the OP2 - OPO bits. An additional status may occur on a write operation, namely WRITE FAULT. This status signal is bit 2 in the STATUS register. This status may result from attempting some kind of illegal operation but would normally indicate a drive malfunction. WRITE FAULT must be reset through FAULT CLEAR in the CTL register before the disk will respond to any new commands. After each write operation the status should be checked and if there are any errors they should be checked in the same priority as during a read operation with the WRITE FAULT error checked just after the READY\* bit. THE WRITE HEADER COMMAND: (COMMAND 03) This is the primitive command used in formatting a drive. The command will write a sector header record upon receipt of the next sector pulse from the disk. The three data bytes for the field will be read directly from memory. To format a track, the program must issue a sequence of WRITE HEADER commands, one for each sector on the track. Each command must be issued immediately after the preceding one completes so that it will be pending when the next sector pulse is received from the disk. As an aid to issuing the commands quickly, the data field for all of the headers on a track should be computed in advance and placed in a buffer. As each command is executed, it advances the address register in the SELECTOR CHANNEL by three bytes leaving it pointed at the data for the next field. If tracks are to be formatted with sectors in a specific position relative to index, the first WRITE HEADER command should be issued immediately upon completion of a NULL command ( which occurs at index). While the data placed in the header fields is arbitrary as far as the hardware is concerned, the cylinder, head and sector numbers are recommended. (See track format) THE READ HEADER COMMAND: (COMMAND 04) As described above in resolving a TIME OUT status, one may issue a READ HEADER command. This command will transfer the three data bytes of the next header field which passes under the head directly to memory. The requirements for issuing the command are the same as for a READ DATA except the CYLINDER, HEAD and SECTOR registers need not be loaded and only three bytes will be transferred. As in a READ DATA COMMAND, error checking should be done after each operation. ### THEORY OF OPERATION ### ON THE BUS SIDE - THE I/O PORTS The S-100 bus data strobes PWR\* and PDBIN are ORed to produce a common strobe. This strobe is further qualified by the octal comparitor U51 if the bus address lines Al-A7 match the port address selected by SW2, and the bus status is I/O. The decoder U40 distributes the combined board select and strobe signal into two write strobes and two read strobes using the least significant bus address line AO and the I/O status. Data from the CPU is buffered onto the board by U36 which is a latch, but always in its transparent mode. This internal data bus goes to all of the software setable registers, namely CTL (U35), CYLINDER (U55), HEAD (U54), SECTOR (U56) and DRIVE (U38). The CTL register is strobed directly by one of the two write strobes derived above while the data registers CYLINDER, HEAD, SECTOR and DRIVE receive their strobes from a second decoder, also in U40, which distributes the second write strobe according to the two least significant bits of the operation code. The first of the two read strobes enables the STATUS register (U37) to drive its contents directly onto the CPU's data input bus. The second "read" strobe does not do a read at all. It drive the STEP\* line in the disk interface cable through buffer U50. ### ON THE BUS SIDE - THE DMA INTERFACE The DISK 2 performs all data transfers between the disk and memory directly as opposed to techniques in which the CPU would read or write a byte of data at a time from the controller and then write or read the byte as appropriate to main memory. While CPU data transfer worked perfectly well for floppy disk transfer rates, the byte rate of a hard disk does not allow nearly enough time for the bus cycles required to do the two data transfers and fetch the required instructions. One alternative to the speed problem is to read the data to a RAM buffer on the controller and then, after the disk transfer has completed, the CPU could transfer data between the buffer and memory. While this technique is sometimes used, most applications requiring a high performance disk are better served by eliminating the need for the CPU to transfer the data at all, not just postponing it. DMA operations are described in the IEEE 696/S-100 specifications as temporary master operations because the controller will temporarily take over as bus master generating all bus control signals normally provided by the CPU and transferring data to memory on the CPU's data output bus or receiving them from memory on the data input bus. The DISK 2 performs these operations in conjunction with the SELECTOR CHANNEL. While the SELECTOR CHANNEL is physically a second board, the two boards are required to work together to provide the temporary master as described in the specifications. When the finite state machine anticipates a requirement to access memory, it will assert the signal Q4. The gate U34 will wait for the bus hold and hold acknowledge signals HOLD\* and HLDA to both be logically false (indicating that no other temporary master is currently using the bus) and then set APRIO, the assert priority latch, starting the bus arbitration process. APRIO asserts the bus HOLD\* line and enables the system of gates consisting of U43, U44 and U45 to drive the DMA priority set by switches SW2 positions 2-5 onto the DMA arbitration lines DMAO\* - DMA3\*. The function of the gates is to disable less significant bits of the priority if another device is asserting a higher priority. If any of the bits are disabled, the IMHI (I'm high) will be false. By the time HLDA is received from the CPU, IMHI will have settled. If the arbitration was lost (another device of higher priority wanted the bus at the same time) U15 will clear APRIO. If this occurs, APRIO will set again for another try as soon as the bus is available. Meanwhile, over in the SC (SELECTOR CHANNEL), a circuit monitoring the arbitration and comparing the winning number with the contents of its priority register will observe the DISK 2 winning the bus, and perform the required exchange of bus mastership with the CPU. The DISK 2, on finding that the SC had disabled the CPU status lines will set a latch (U18) which in turn will enable the DISK 2's driver for the bus control line pSYNC. These completes the process of obtaining the bus. Nothing else will happen until it is time to start a cycle. When the finite state machine wishes to transfer a byte, it will set the DRQ flip-flop (U16). U17 will allow the first stage of U20 to clear at the next rising edge of the bus clock. The output of this stage will enable pSYNC via U20. At the following bus clock, the same output will cause the next stage of U20 to clear. The output of this stage will negate pSYNC also via U20. In response to the pSYNC, the SC will generate the strobes required for the transfer, extending them as required to satisfy any wait requests. U20 will latch the occurrence of the strobe in the third stage of U20 and use the fact that this stage is set and the absence of strobes to clear DRQ with U17. This process of setting DRQ, generating a pSYNC and clearing DRQ will repeat for each byte to be transferred between the DISK 2 and memory. When the finite state machine determines that it will no longer require access to the bus, it will negate Q4. This will clear APRIO disabling the assertion of HOLD\* and the priority lines. This is the signal for the SC to transfers the mastership of the bus back to the CPU. The latch U18 will assure that the DISK 2 will drive the pSYNC line until the SC releases the status disable line SDSB\*. # ON THE DISK SIDE - THE DISK INTERFACE The DISK 2 has five connectors along its upper edge for the connection of drives. The four twenty pin connectors J1 - J4 carry high speed differential data and clock signals between the DISK 2 and the corresponding drive. J5 carries single ended open collector control and status lines between the controller and all of the connected drives. Four of the signals in this connector, DRIVE-SEL1\* through DRIVE-SEL4\* enable one of the connected drives to use the balance of the lines which are multiplexed. The select lines are driven from the upper nibble of the DRIVE register (U38) via the buffers U22 and U23. The lower nibble of the DRIVE register drives HEAD-SEL1\* through HEAD-SEL4\* also using buffers in U22 and U23. In a given application, less than four drives may be connected and the drives may have fewer than sixteen heads. In addition the STEP\* control line which was pulsed by reading the DISK 2 data port as described above, the controller drives four other control lines. DIRECTION\* which controls the direction during step- ping and FAULT-CLR\* which is used to reset a drive WRITE-FAULT status are driven from the OP2 and FAULT-CLR bits in the CTL register through buffers U22 and U23. The last two control output lines READ-GATE\* and WRITE-GATE\* are generated by the finite state machine (to be described below) and share the buffers in U22 and U23. Five input lines from the control cable are terminated and used on the DISK 2. They are DRIVE-READY\*, TRACKO\*, WRITE-FAULT\*, INDEX\* and SECTOR-CLK\*. Each of the signal connectors on Jl-J4 have a pair of differential line drivers and a pair of differential line receivers associated with it. The line drivers send the differential signals WRITE-CLOCK and WRITE-DATA to the disk. Each differential signal has a + and a - phased signal line associated with it. The WRITE-DATA and WRITE-CLOCK for all of the drives are driven from the common internal single ended signals WRITE-DATA and SEL-CLK. The line receivers receive the differential signals READ-DATA and PLO-CLK from each of the drives. The READ-DATA signals are converted to single ended signals RD1\* - RD4\* by the line receivers. RD1\* - RD4\* are then ORed by U14 to provide the combined READ-DATA. The PLO-CLK signals from the drives are converted to their single ended equivalents CKl - CK4 by their line receivers. The CTL register bits USl and USO (for Unit Select) are used by the multiplexor Ul3 to select one of these signals to be the internal clock. The signal SEL-CLK is jumper selected from either the internal clock or its complement thus returning the PLO-CLK received from the drive back to the drive as a WRITE-CLOCK. This is required because the time delay of the round trip would introduce enough skew to make the interpretation of the WRITE-DATA at the drive unreliable if the data were clocked in with the source of PLO-CLK. The selection of internal CLOCK or CLOCK\* is required because of an inconsistency in some drives. The signal cables also contain a single ended signal SEEK-COMPLETE\*. The lines from the four drive are terminated and multiplexed again by Ul3 to provide SEEK-COMPLETE\*. ### IN THE MIDDLE - THE DISK DATA Data is transferred between the controller and disk in a bit serial format. The bit rates vary with the type of drive but are in the order of 5 MHz. The READ-DATA signal is delayed by one bit time in Ull to become READ-DLY and presented to the input of an octal shift register U58. Bytes of data are available in parallel at the outputs of the shift register every eight bit times. The broadside output of the shift register connects to the controllers internal shift register bus, the SR bus. During a disk read, the bytes are captured from the SR bus by the octal register U52 which then drives the data onto the computers data output bus lines. U52 is clocked by the output of Ull which will have a rising edge in the center of the last bit time. The READ-DLY signal is delayed one more bit time by U24 to provide READ-2-DLY\*. This signal is ORed in U25-3 with a signal from U25-6 which will be false during a read. The READ-2-DLY is then shifted into a sixteen bit shift register formed by the two octal parts U41 and U42. This shift register has exclusive ORed feedback from its last bit to its first and two points in between, the specific connection of which results in the register accumulating the CRC check code for the read data. The control circuitry must compare the CRC computed as the data is read with the CRC code read from the disk immediately following the data. If the CRC computed during the read matches the CRC computed and stored during the write operation, the data is, in all probability, correct. The calculated CRC is available at the output of U26-3. This signal is connected to the left shift serial input of the shift register U56, so that the CRC may be brought into the last bit of the shift register by reversing the direction of shifting. This bit of the shift register is available on the Qh output and called WRITE-DATA. The output of U26-3 is the exclusive OR of WRITE-DATA (the computed CRC) and READ-2-DLY (the CRC read from the disk). A non-compare may be latched by U24, the SET-NE flip-flop. Writing the disk uses much of the same hardware as read. Data read from memory on the data input bus is latched in U53 and held there until the end of a byte time of the hard disk at which point it is parallel loaded by the shift register from the SR bus. The serial output of the shift register, WRITE-DATA, is sent to the disk. During a write operation, U25-6 is enabled while all of the READ-DATA signals are zero so that the CRC register will be computing the CRC code for the write data. After all of the data has been written, the direction of the shift register is reversed causing the CRC to be shifted into the left shift input and out to the disk on the WRITE-DATA line. Besides writing data and CRC codes, the controller must also be capable of writing preambles (sequences of zeroes) and mark characters (in this case, an FFh). These constats are available on the SR bus from U57. In addition to all of the above, the controller must identify the header field for the desired record before any data is read or written. The three bytes of header data to be matched are stored in the data registers CYLINDER, HEAD and SECTOR. The contents of these registers may be gated onto the SR bus. During a read, the contents of a data register may be compared with data coming from the disk using the same hardware which is used for checking the CRC. The data register information is parallel loaded into the shift register at the start of a byte time. As the read data is shifting through READ-2-DLY, the shift register is shifted to the right, bringing the bits of the data word one at a time into the WRITE-DATA position. The two are compared and any non-compare is latched in SET-NE. While all of the preceding discussion about reading and writing the disk discussed the capabilities of the shift register, the various sources of the SR bus, the CRC generator, the compare logic and the DMA data input and output registers, no mention of how and when any of these facilities are invoked was mentioned. The source for all of these control signals is a finite state machine (FSM) implemented with bipolar PROMs and latches. At the end of every byte time of the hard disk, a sixteen bit wide control word is read from the PROMs U47 & U48 into a register U30 and U31. The contents of these registers will control all of the other hardware for the next byte time as well as influencing which word will be read from the PROM next. The PROM address is made up of three components. The first is the operation code which is obtained from the OP2 - OPO bits of the CTL register allowing up to eight instructions. The next field consists of K4 - KO, the current state, allowing a maximum of thirty two states. The last field is only one bit, the signal ALT. ALT allows the selection of one of two possible next states which shall be called normal and alternate. Thus every cycle of the machine is a conditional branch. There are sixteen bits of PROM output. One field of five bits contains the next state which become the current state K4 - KC as it is loaded into the latch. Another field is latched to produce SA2 - SAO. This is the SR bus address and selects which of all of the SR bus sources discussed above will actually drive the bus during the next byte time. The SR bus address lines are decoded by (U39). The next field contain NEXTA - NEXTC. These are the address lines to the multiplexor U25 which selects which condition will generate ALT for the current cycle. There are four additional signals in the state vector. CRC\* and LOAD control the operation of the shift register. The shift register normally shifts one bit to the right every bit time. If LOAD is true, the shift register will parallel load instead of shift in each bit 7 time. If CRC\* is asserted, the shift register will shift to the left every bit time. READ and WRITE are buffered to become READ-GATE\* and WRITE-GATE\*. These are disk control signals which will be asserted just prior to the start of the next byte. U33 is a four stage shift register which divides CLK by eight to form byte times. Its outputs, each of which is available in both true and complement form, make available a unique rising and falling edge for each bit time. One output, the signal \*a\*, provides a rising edge used to clock the state register consisting of U30 and U31. This loads the control vector for the following byte time. In the state register, bits KO - K4 contain the present state number. NEXTA - NEXTC contain the branch condition which is used in selection of the following state. SAO - SA2 contain the address of the SR bus source for the current byte time. All four of the remaining bits are reclocked into U32 by \$d\$ which occurs one bit time prior to the start of the next byte. Two of the resulting outputs are READ and WRITE, the signals which control READ-GATE\* and WRITE-GATE\*. The other two lines are LOAD and CRC\*. U34 qualifies LOAD with \$a\$ and \$d\$. This will force the Sl control input of the shift register to be asserted during bit 7 if LOAD is true resulting in the shift register doing a parallel load at the start of the next byte time. The signal CRC\* asserts Sl while negating SO causing the shift register to reverse its direction for an entire byte time if CRC\* is true. The inputs of the STATE register all come from the outputs of a pair of PROM's U47 and U48. The address in the PROM's consists of three parts. The first field is OP2 - OPO, the current command. The next is KO - K4, the current state number. The last input is a signal called ALT for alternate. Thus for every state of every command one of two exits is selected by the state of ALT. ALT originates at the output of U29, a multiplexor which selects one of eight conditions based on NEXTA - NEXTC. Its output, SET-ALT is reclocked by U32 to provide ALT. In designing the PROM, many states repeat for fixed numbers of byte times. This kind of action is attained by having a state transition to itself if ALT is false and advancing to the next state if ALT is true. Most of the ALT multiplexor inputs are of this form. These include N1, N2, N4, N8 and NX. N1 is always true. N2 - N8 allow states with the implied durations. NX is switch selected to one of N128, N256, N512, N1024 or N2048 depending on the disk formatting. The remaining multiplexor inputs are RUN, which allows 0 states to wait for the machine to be turned on, NE which allows it to verify a header or CRC match, and SEC which allows it to wait for the the next SECTOR\* from the disk. The byte times all come from the byte counter U27 and U28 which counts once each byte time due to \*b\* and is reset at the start of each new state by ALT and sa\* in U46. SEC is the SECTOR\* signal from the disk latched by U18 to hold it presence for at least one byte time. The control software should verify a READY status from the selected drive before starting an automatic operation for two reasons. First, the finite state machine is clocked by the disk and so will hang if a non-existent or not ready disk is selected. The second is that the TIME-OUT mechanism which is used to halt the machine if, for example, a header is not found uses INDEX\* from the selected drive. Index clocks one of the counters in U27. This counter is held in a cleared state until RUN and SEEK-COMPLETE are true by U46. If a operation fails to complete in two passes of the index from the time it starts, TIME-OUT will be generated clearing and halting the machine. The PROM code implements the track formats/timing diagrams as shown below in Figure 1. This diagram relates the various states of the four-major operations to the position of the disk (i.e. relative to sector pulses and recorded data). Note that all of the functions wait for the start of a sector. READ HEADER or WRITE HEADER will proceed to completion on finding a header. READ DATA and WRITE DATA will loop and wait for the next sector if the current sector header does not match the desired cylinder, head and sector number and have a current CRC check code. Not all signals change state on byte boundaries. Figure 2 shows the timing of various signals relative to the clock phases. Note that the state responsible for a given action is generally about one byte ahead of the data on the disk. This is because writing a byte of data to the disk or checking a byte of data read from the disk requires that data be read from a register during the preceding byte time and loaded into the shift register at the very start of the following byte time. In the singular case of reading data from disk to memory, the command in the current byte causes the byte of data read during the following byte to be enabled onto the SR bus from which it will be captured just prior to the start of the third byte by the DO register. During the third byte time, the data will be sent to memory. Figure 2. DISK 2: TIMING OF VARIOUS SIGNAL RELATIVE TO THE CLOCK PHASES. # PARTS LIST | | | | <u> </u> | | | |-------------|------------|----------|-------------|----------|----------------------------------| | $\ $ | SEMICO | NDUCTORS | | | RESISTORS | | ∦ | UNIT# | PART# | UNIT# | PARTS# | VALUE | | ╢ | v1 | 7805 | บ33 | 74LS175 | R1,2 4.7K Ohm | | I | <b>U2</b> | 7805 | U34 | 74LS10 | R3,4 110 Ohm | | 11 | บ3 | 9638 | <b>U35</b> | 74LS273 | R5,6 4.7K Ohm | | 1 | <b>U</b> 4 | 9637 | U36 | 74LS373 | R7,8 110 Ohm | | ]] | บ5 | 9638 | 73ט | 74LS373 | R9,10 4.7K Ohm<br>R11,12 110 Ohm | | ∦ | V6 | 9637 | U38 | 74LS273 | R13,14 4.7K Ohm | | Ш | <b>u7</b> | 9638 | U39 | 74LS138 | R15,16 110 Ohm | | ∦ | ឋ8 | 9637 | U40 | 74LS139 | R17-19 330 Ohm | | 1 | <b>U9</b> | 9638 | U41 | 74LS273 | R20-24 220 Ohm | | $\parallel$ | <b>U10</b> | 9637 | U42 | 74LS273 | R25-27 330 Ohm | | 11 | U11 | 74LS74 | U43 | 74LS32 | R28 68 Ohm | | $\parallel$ | U12 | 74LS00 | U44 | 74LS08 | R29-36 1K Ohm | | 11 | U13 | 74LS153 | U45 | 74LS38 | SR1 2.7K-5 SIP | | 1 | UI4 | 74LS20 | υ46 | 74LS00 | SR2 2.7K-5 SIP | | - {{ | <b>U15</b> | 74LS32 | บ47 | 177P-1 | | | I | <b>U16</b> | 74LS74 | U48 | 1779-2 | | | $\parallel$ | <b>U17</b> | 74LS00 | U49 | 74LS273 | }} | | I | U18 | 74LS279 | U50 | 74LS125 | | | 11 | U19 | 74LS04 | <b>U51</b> | 25LS2521 | | | 11 | U20 | 74LS175 | U52 | 74LS374 | 11 | | H | ¥21 | 74LS02 | U53 | 74LS373 | 1 | | - ]] | U22 | 7406/16 | U54 | 74LS374 | 1 | | ∦ | <b>U23</b> | 7406/16 | <b>U</b> 55 | 74LS374 | - (( | | $\parallel$ | <b>U24</b> | 74LS74 | บ56 | 74LS374 | | | 1 | บ25 | 74LS00 | ช57 | 74LS373 | | | ii | <b>U26</b> | 74LS86 | U58 | 74LS299 | (1 | | I | <b>U27</b> | 74LS393 | Q1 | 2N2222 | | | 11 | U28 | 74LS393 | | | 1 | | | U29 | 74LS151 | | | | | | U30 | 74LS273 | | | 11 | | | <b>U31</b> | 74LS273 | DIODE | PART# | 1) | | | <b>U32</b> | 74LS273 | <b>D</b> 1 | 1N747 | | | 11 | | | ] | | | # ABOUT SELECTOR CHANNEL The SELECTOR CHANNEL is an IEEE 696/S-100 compatible board which is designed to provide all of the bus address, status and control strobes required by a temporary master (DMA device) designed to use it. The combination of a selector channel and companion device controller are the functionally equivalent to a single board temporary master. The hardware on the SELECTOR CHANNEL however may be shared by a number of device controllers. ### **TECHNICAL OVERVIEW** The SELECTOR CHANNEL has a single I/O port through which the CPU or other bus master may program the identification of the device controller to be supported as well as the addresses of and types of cycles to be generated. When the selected device is granted access to the bus, the SELECTOR CHANNEL will exchange mastership of all of the address, status and control lines with the CPU and generate cycles as requested by the device controller. In addition, the SELECTOR CHANNEL has a BOOT function which may be used to initialize the system from one of the devices whose controllers share the SELECTOR CHANNEL. # SWITCH SETTINGS AND OPTION SELECTION The SELECTOR CHANNEL's I/O port may be addressed anywhere in the OOh - FFh range using switches SW1-3 through SW1-10. SW1-1 is used to enable the on board BOOT EPROM. SW1-2 is used to enable one wait state minimum for all DMA cycles generated by the SELECTOR CHANNEL. Weit states may also be requested in software when the SELECTOR CHANNEL is programmed and the SELECTOR CHANNEL will honor wait states requested by bus slaves during temporary master cycles which is supports. In addition to Switch 1, the SELECTOR CHANNEL has a number of options which are controlled by the installation of push-on jumpers. Jl - J4 enable one through four wait states respectively for the on board EPROM. As the SELECTOR CHANNEL is shipped, J4 is connected by a trace to allow maximum access for slow EPROMS. If fewer EPROM wait states are required, this trace may be cut and a jumper may be installed in one of the other locations. These waits are only generated when initially booting a system with the EPROM, so the insertions of waits will not adversely affect system operation. The SELECTOR CHANNEL uses a 2716 type EPROM which has a capacity of 2 K bytes. Since this capacity is greater than required for most boot operations, jumpering is provided which will allow the space to be divided into several smaller code segments and the selection of one of them. This will enable a single standard KPROM to hold boot code for a number of device controllers and configurations. Jumper locations J8 through J10 allow the corresponding address lines of the EPROM to be tied to the corresponding bus address lines providing a larger address range or to be tied high and low in any combination selecting a section of code within the 2716. # PROGRAMMING THE SELECTOR CHANNEL - 8 6 The first step in programming the SELECTOR CHANNEL is to do a read from its I/O port. The read operation will disable the SELECTOR CHANNEL during the following four write cycles preventing it from supporting any temporary master cycles while it has a partial program. No data is returned by the read. The SELECTOR CHANNEL powers up in this disabled state. The SELECTOR CHANNEL must then be sent a sequence of exactly four bytes. They are as follows: (1) A23-A16 The extended address byte (3) A7-A0 The low address byte (2) A15-A8 The high address byte (4) MODE The mode control byte Three address bytes are required because the SELECTOR CHANNEL addresses the full 24 bit extended address range of the IEEE 696/S-100 bus. An extended address byte must be sent even if the memory or I/O devices which will be addressed are going ignore its contents. Example: to send address OFFFFO the bytes in order would be OF, FF, and FO. The mode byte is made up of two parts. The bits in the upper nibble control the mode as follows: | BIT | NAME | FUNCTION | |------------|-------|------------------------------------------------------------------------------------------------------------------------------------------------| | <b>D7</b> | W/R* | Write / Read relative to the bus slave (memory or I/O port). | | D6 | IO/M* | IO / Memory - controls the status of cycles generated. Also, memory addresses are incremented on multi-byte transfers. I/O addresses are not. | | <b>D</b> 5 | U/D* | Up / Down - A memory address may be counted up or down after each byte. | | D4 | WAIT | WAIT - Imposes a single wait state for each bus cycles supported. | The lower nibble of the MODE byte contains the identification of the controller to be supported. This nibble should contain the compliment of the device priority. | BIT | NAME | FUNCTION | |-----------|--------|-------------------------------------------------------| | <b>D3</b> | DMA 3* | Select complement of DMA device that Selector Channel | | D2 | DMA 2* | will work with. | | D1 | DMA 1* | | | D0 | DMA 0* | | Once the SELECTOR CHANNEL has been programmed, it will respond to all cycles requested by the selected device. The SELECTOR CHANNEL function is independent of wheather the device does individual cycles or burst mode transfers. The SELECTOR CHANNEL may also support a sequence of burst mode transfers to successive locations without reprogramming. If a controller function for which the SELECTOR CHANNEL may have transferred one or more bytes of data is going to be repeated, the SELECTOR CHANNEL must be reprogrammed. The SELECTOR CHANNEL may be disabled at any time by reading its I/O port. ### THEORY OF OPERATION The octal comparator U26 decodes the SELECTOR CHANNEL'S I/O port address qualified by I/O status to provide BD-SEL\*. The bus reset signal RESET\* or BD-SEL\* in conjunction with the read strobe pDBIN will disable the SELECTOR CHANNEL by clearing the counter U10. U10 will count write cycles since it is clocked by BD-SEL\* and pWR\*, the bus write strobe. After four write cycles, CLEAR\* which is obtained from the Qd output of U10 will hang U10 by disqualifying its clock and enable the SELECTOR CHANNEL to respond to the selected controller. All data sent to the SELECTOR CHANNEL is loaded into the MODE register U17. The output of U17 is connected in parallel to the least significant byte of address counter formed by the four bit counters U6 and U16. Similarly, the output of the low byte of the counter provides the input to the high byte counter U3 and U13 which in turn provides the input to the extended byte counter U4 and U14. Thus the MODE register and three bytes of address counter form a four stage, eight bit wide shift register. The counters are set to load rather than count whenever the SELECTOR CHANNEL is not actually involved in a temporary master cycle. A LD-STB derived from BD-SEL\* and pWR\* clocks the address counters as well the MODE register causing the shifts. The low, high and extended address counters have associated bus drivers U25, U22 and U23 respectively, which are enabled during master cycles. The IO/M\* and W/R\* status bits of the MODE register are decoded by U7 along with the generalized strobes. The resulting status is driven onto the bus by U18 during master cycles while the strobes are output by U24. The XFER1 flip-flop (U5) is used to detect that the selected controller has obtained the bus. The flip-flop will set at the first falling edge of the bus clock following the combination of HOLD\*, HLDA and IMHI all being true. IMHI indicates a match between the priority of the device holding the bus and the target device whose priority number is stored in the low nibble of the MODE register. When XFER1 sets, it indicates the start of the overlap period during which the permanent and temporary masters both drive the command lines. If XFER1 is set, XFER2 in U12 will set at the next rising edge of the clock. XFER2 enables the balance of the bus drivers and disables the remainder of the masters bus drivers. Once XFER2 has set, the SELECTOR CHANNEL will wait for cycles to be requested by the controller. When the device controller is ready to transfer a byte of data, it will generate the bus signal pSYNC. When the SELECTOR CHANNEL detects pSYNC, it will set and latch the BC flip-flop (U5). BC will generate pSTVAL\* via U15 and U24 and cause U12 to generate a bus cycle as follows: At the following rising edge of bus clock, BC will be loaded by Ul2 to become STB-ENA. At the same time, another flip-flop in Ul2 will load the logical OR of all of the possible sources of WAIT (XRDY, RDY or INT-WAIT\*). On the rising edge of clock following the loading of a ready condition, STB-INH will set, terminating the strobe. At the next falling edge of the clock STB-INH will allow BC to clear, clocking the address counters. When the controller is finished with the bus, it will remove the signal HOLD\*. The following edge of the clock will remove XFER2 and the negative edge after that will remove XFER1. The on board boot EPROM may share address space with RAM memory which responds to PHANTOM\*. The BOOT latch (U30) is enabled at RESET\* and will assert PHANTOM\* (if SW1-1 is ON) on all CPU memory reads, disabling the RAM and enabling the on board EPROM. PHANTOM\* is not asserted during temporary master operations, thus allowing data transfers between the device controller and RAM. The BOOT latch will be reset the first time the CPU writes to RAM. The EPROM (U27) receives its addresses directly from the bus. The data driver (U28) places it output on the data input bus during memory reads when the boot is enabled. The counter U19 implements wait states by pulling RDY low for a selected number of clock cycles of strobe. # PARTS LIST | UNIT#<br>U1<br>U2<br>U3<br>U4<br>U5<br>U6<br>U7<br>U8 | PART# 7805 74LS02 74LS169 74LS169 74LS74 74LS169 74LS139 74LS00 | U20<br>U21<br>U22<br>U23<br>U24<br>U25<br>U26<br>U27 | 741S38<br>741S266<br>741S244<br>741S244<br>741S244<br>741S244<br>251S2523<br>2716<br>(optional | |-------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------|------------------------------------------------------|------------------------------------------------------------------------------------------------| | U9<br>U10<br>U11<br>U12<br>U13<br>U14<br>U15<br>U16<br>U17<br>U18 | 74LS04<br>74LS93<br>74LS02<br>74LS175<br>74LS169<br>74LS10<br>74LS169<br>74LS273<br>74LS240<br>74LS175 | U28<br>U29<br>U30<br>RESIS<br>R1<br>R2<br>R3<br>SR1 | 74LS244<br>74LS02<br>74LS00<br>TORS<br>VALUE<br>4.7K Ohn<br>4.7K Ohn<br>5.1K Ohn | COMPONENT LAYOUT