# The Tarbell Floppy Disk Interface





(213) 538-4251

(213) 538-2254

# This Document was scanned and contributed by:

Barry A. Watzman



20620 South Leapwood Avenue, Suite P Carson, California 90746

(213) 538-4251 (213) 538-2254



The Tarbell Floppy Disk Interface is a programmed-data-transfer (not DMA) device. It plugs into your IMSAI or ALTAIR\* computer, and is designed to work with a variety of standard-size floppy disk drives. It includes a 32-byte ROM bootstrap program, which is automatically enabled when the computer RESET button is pushed, and which switches itself out after the bootstrap has run. In this way, no part of your memory needs to be dedicated to Read-Only-Memory (ROM). The interface runs at the standard speed of 250,000 bits per second, and the normal formatted capacity per diskette is 256 kilobytes. Places for two connectors are provided on the board. One 50-pin header connector and a cable with the mating connector are provided with the interface kit. The drive end of the cable has no connector, but a 50-pin edge connector may be added for \$10.00. There are four extra IC slots to allow you to do your own thing, and the connector pins come out to jumper pads, so you can adapt to different drives. The manual has the connections detailed for popular drives. An on-board dip-switch is used to select the device address, disable the bootstrap, and write-protect. Circuitry is included to run up to four drives, and eight can be accessed by using the spare IC slots.

The Tarbell Floppy Disk Interface and other related items can be bought in pieces, so that it's not necessary to make a single large outlay of cash. Because of this policy, the 6-month warranty will be limited to only those items traceable to Tarbell Electronics. Notice that we are offering the CP/M floppy disk operating system, which is described on another page. An owner's manual for the interface is included with the kit or the bare board, and is also available separately.

| Floppy Disk Interface Kit<br>CP/M Operating System (on disk)<br>CP/M System Manual Set (6)<br>BASIC-E Compiler Manual<br>GSI 110 Floppy Disk Drive<br>Power Supply for 1 GSI 110                                                                                                                                                                                          | 190.00<br>70.00<br>25.00<br>5.00<br>525.00<br>75.00                                                | NOTE: These prices are<br>subject to change without<br>notice. There are no discount    |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------|
| Floppy Disk Interface Manual Bare Floppy Disk Interface Board Kit with all parts except 1771 Western Digital 1771 FDC IC Assembled Floppy Disk Interface PerSci 270 Dual Floppy Disk Drive Power Supply for PerSci 270 Blank Formatted Diskette BASIC-E Source Listing (PL/M) Additional Charge for Special Cable Package of IC Sockets (35) CBASIC on disk CBASIC manual | 5.00<br>40.00<br>150.00<br>60.00<br>265.00<br>1295.00<br>10.00<br>15.00<br>10.00<br>10.00<br>85.00 | for complete systems; just add the prices together to find the total for your purchase. |

Since Tarbell Electronics does not wish to get into the business of selling complete systems, we encourage you to buy your system, including the floppy disk drive, from your local dealer. If you add up the prices of the first six items, however, you can see that a complete floppy disk system including software and hardware can be had for less than a thousand dollars. Note that the Tarbell Floppy Disk Interface is not designed to work with double-density or mini-floppys, although it will work with multiple and double-sided drives. The drives that it has worked with so far include the Shugart 800/801, the Innovex 410, the Innovex 220 (modified by a jumper change), the GSI 110, the CDC 803, and the PerSci 270, the PerSci 70, the Wangco/Orbis 76, the Pertec 400, and the Calcomp 140. The on-board bootstrap may not work reliably with some Z-80 CPU's and some dynamic memories. Ask your local dealer about possible conflicts, as it may be necessary to use ROM on another board.

The first deliveries were made July 2, 1977. Delivery from the factory is 3-4 weeks after receiving your order, and individuals must send cash in advance. For faster delivery, check with your local dealer.

<sup>\*</sup> ALTAIR is a trademark/tradename of MITS, Inc.

## CP/M™ BY DIGITAL RESEARCH — A COMPLETE FLOPPY DISK OPERATING SYSTEM FOR THE TARBELL FLOPPY DISK INTERFACE.

The CP/M Disk operating system has been in existence for over two years in various manufacturer's products, and thus has had extensive field testing. It is now being made available to the hobby community. It is licensed software, and copying for other individuals is prohibited. We feel this is justified, as the cost, \$100, is low for such a good system.

The following commands are built in to the operating system:

DIR List all or selected portions of the directory (file list)

TYPE Type the contents of an ASCII file on the console

REN Rename a file to a different name
ERA Erase a file or files from the disk
SAVE Save memory on disk for later load

The following programs are included on the disk, and are invoked just like commands by typing the name:

PIP Peripheral Interchange Program moves files around

SUBMIT Batch processing program for predefined list of commands

ED A really nice, string-oriented text editor

ASM Assembler to convert assembly language to machine code
DDT Dynamic Debugging Tool for memory dumps, loads, traces

LOAD Convert hex file to memory image file

DUMP Dump file in hex onto console

SYSGEN Generates new CP/M systems for backup

BASIC BASIC-E compiler has both sequential and random file access

RUN Run-time interpreter for BASIC-E programs

STAT Prints the amount of disk storage still available and amount used for each file

CPM Generates different sized CP/M systems

COPY Copies from one disk onto another, track by track

TAPELIB Provides extensive disk-to-cassette facilities.

The following source files are included on the disk:

CASDSK Transfers the named file from Tarbell cassette to disk
DSKCAS Transfers the named file from disk to Tarbell cassette
SBOOT Cold-Start loader which is loaded by bootstrap program
CBIOS Customer's Basic Input/Output System includes all drivers

FORMAT Reformats crashed diskettes

COPY Assembly language source for program above

Tarbell Electronics provides the system modified to work with the Tarbell floppy disk interface and a simple console interface, such as a teletype. The console is addressed with port O for status and port 1 for data. Bit O of status low means keyboard ready, and bit 7 of status low means printer ready. It is set up to work in 24 kbytes. The documentation includes a listing of the BIOS, and instructions which will enable you to patch the CBIOS for your own system.

As of March 1, 1978 the CP/M User's Group had 24 diskettes full of software. It costs \$4 to get on the mailing list, and the diskettes are \$8 each.

### DOCUMENTATION:

CP/M FEATURES AND FACILITIES MANUAL
CP/M EDITOR, ASSEMBLER, AND DEBUGGER MANUALS
CP/M INTERFACE GUIDE
CP/M SYSTEM ALTERATION GUIDE
TARBELL CP/M USER'S GUIDE

### **BASIC-E Compiler Description**

This compiler is a public-domain piece of software written by Gordon E. Eubanks, Jr. As provided by Tarbell Electronics, it is meant to work with the CP/M<sup>™</sup> Disk Operating System. With the CP/M, it requires about 20K bytes of main memory. Since it is a compiler, as opposed to an interpreter, it has some advantages: 1) the program will probably run faster than with an interpreter, 2) the program will probably use less memory than with an interpreter. There are also some disadvantages: 1) it is not as easy to develop a program, because editing must be done separately, 2) it cannot be easily used with a cassette, because there are several steps that are not easily and quickly performed by a cassette unit, 3) In this version there is no PEEK or POKE, no PRINT USING, no CALL to machine code programs, and no LPRINT. These are all available in CBASIC, which costs \$100.00.

The following statements are valid in BASIC-E:

FOR, NEXT, FILE, CLOSE, GOSUB, GOTO, INPUT, LET, ON, PRINT, READ, RESTORE, RETURN, RANDOMIZE, OUT, STOP, DATA, DEF, DIM, END, IF, REM, ELSE, THEN.

The following built-in functions are valid in BASIC-E:

ABS, ASC, ATN, CHR\$ COS, COSH, FRE, INP, INT, LEFT\$, LEN, LOG, MID\$, POS, RIGHT\$, RND, SGN, SIN, SINH, STR\$, SQR, TAB, TAN, VAL, EXP.

The following logical connectives are available: AND, EQ, GE, GT, LE, LT, NE, NOT, OR, <, >, =.

There are 26 compiler error messages, and 23 run-time error messages, all of two characters each.

Disk files may be read, written or updated by the BASIC-E program using both sequential and random access. There are blocked and unblocked files. The program can select any disk available to CP/M.

Using the BASIC-E compiler consists of three main steps:

- 1) The source program is created on disk using the Editor.
- 2) The source is compiled by the compiler, which produces an intermediate file.
- 3) The intermediate file is then run by the run-time monitor.

Line numbers need only be used on statements to which control is passed, and do not have to be in ascending order. Using identifiers longer than two characters and indenting statements to enhance readability does not affect the size of the object file created by the compiler. The first 31 characters of identifiers are used by the compiler.

The 40-page manual is available for \$5.00.

The compiler and run-time monitor are included on our CP/M diskette, and are also available separately on a diskette for \$10.00.

The complete listing, which is written mostly in PL/M, is available for \$15.00.

| 1                        | OVERVIEW                                                                                                                                                                                       |
|--------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1-1<br>1-2<br>1-3<br>1-4 | Introducing the Tarbell Floppy Disk Interface<br>Operating Instructions/General Notes<br>Important Cautions<br>Software Support                                                                |
| 2                        | THEORY OF OPERATION                                                                                                                                                                            |
|                          | (helpful to read before assembly or operation but not a necessity)                                                                                                                             |
| 3                        | ASSEMBLING THE INTERFACE BOARD (KIT UNITS)                                                                                                                                                     |
| 3-1<br>3-2<br>3-3        | Parts Drawing Parts List Step-by-step Assembly                                                                                                                                                 |
| 4                        | SETTING THE JUMPERS                                                                                                                                                                            |
| 4-1<br>4-2               | Using the Jumper Pads<br>Jumper Set-Ups for                                                                                                                                                    |
|                          | a) CDC BR803A i) Pertec FD511 b) Innovex 210 j) Calcomp 140 c) Innovex 410 k) Calcomp 143 d) GSI/Siemens l) Pertec FD400 FDD 100-8 & 220-8 m) Memorex 550 e) PerSci 270/277 f) Shugart 800/851 |
| 5                        | CHECKOUT                                                                                                                                                                                       |
| 5-1<br>5-2<br>5-3<br>5-4 | Visual Inspection<br>Installing the 1771<br>Interconnecting Drive and Interface<br>Operational Tests                                                                                           |
| 6                        | FIRMWARE AND DRIVERS                                                                                                                                                                           |
| 6-1<br>6-2               | The Hardware Bootstrap<br>Writing Driver Routines                                                                                                                                              |
| 7                        | REFERENCE INFORMATION                                                                                                                                                                          |
| 7-3<br>7-4<br>7-5        | Schematic Pin Function List Warranty Statement If you have problems                                                                                                                            |

The Tarbell Floppy Disk Interface is a programmed-data-transfer (not DMA) device. It plugs into your IMSAI or ALTAIR\* computer, and is designed to work with a variety of standard-size floppy disk drives. It includes a 32-byte ROM bootstrap program, which is automatically enabled when the computer RESET button is pushed, and which switches itself out after the bootstrap has run. In this way, no part of your memory needs to be dedicated to Read-Only-Memory (ROM). The interface runs at the standard speed of 250,000 bits per second, and the normal formatted capacity per diskette is 256 kilobytes. Places for two connectors are provided on the board. One 50-pin header connector and a cable with the mating connector are provided with the interface kit. The drive end of the cable has no connector, but a 50-pin edge connector may be added for \$10.00. There are four extra IC slots to allow you to do your own thing, and the connector pins come out to jumper pads, so you can adapt to different drives. The manual has the connections detailed for popular drives. An on-board dip-switch is used to select the device address, disable the bootstrap, and write-protect. Circuitry is included to run up to four drives, and eight can be accessed by using the spare IC slots.

The Tarbell Floppy Disk Interface and other related items can be bought in pieces, so that it's not necessary to make a single large outlay of cash. Because of this policy, the 6-month warranty will be limited to only those items traceable to Tarbell Electronics. Notice that we are offering the CP/M floppy disk operating system, which is described on another page. An owner's manual for the interface is included with the kit or the bare board, and is also available separately.

| Floppy Disk Interface Kit<br>CP/M Operating System (on disk)<br>CP/M System Manual Set (6)<br>BASIC-E Compiler Manual | 190.00<br>70.00<br>25.00<br>5.00 |                                                          |
|-----------------------------------------------------------------------------------------------------------------------|----------------------------------|----------------------------------------------------------|
| GSI/Siemens 110 8" Floppy Disk Drive                                                                                  | 525.00                           | NOTE: These prices are                                   |
| Power Supply for 1 GSI 110                                                                                            | 75.00                            | subject to change without notice. There are no discounts |
| Floppy Disk Interface Manual                                                                                          | 5.00                             | for complete systems; just                               |
| Bare Floppy Disk Interface Board                                                                                      | 40.00                            | add the prices together to find                          |
| Kit with all parts except 1771                                                                                        | 150.00                           | the total for your purchase.                             |
| Western Digital 1771 FDC IC                                                                                           | 60.00                            |                                                          |
| Assembled Floppy Disk Interface                                                                                       | 265.00                           |                                                          |
| PerSci 270 Dual Floppy Disk Drive                                                                                     | 1295.00                          |                                                          |
| Power Supply for PerSci 270                                                                                           | 125.00                           |                                                          |
| Blank Formatted Diskette                                                                                              | 10.00                            |                                                          |
| BASIC-E Source Listing (PL/M)                                                                                         | 15.00                            |                                                          |
| Additional Charge for Special Cable                                                                                   | 10.00                            |                                                          |
| Package of IC Sockets (35)                                                                                            | 10.00                            |                                                          |
| CBASIC on disk                                                                                                        | 85.00                            |                                                          |
| CBASIC manual                                                                                                         | 15.00                            |                                                          |

Since Tarbell Electronics does not wish to get into the business of selling complete systems, we encourage you to buy your system, including the floppy disk drive, from your local dealer. If you add up the prices of the first six items, however, you can see that a complete floppy disk system including software and hardware can be had for less than a thousand dollars. Note that the Tarbell Floppy Disk Interface is not designed to work with double-density or mini-floppys, although it will work with multiple and double-sided drives. The drives that it has worked with so far include the Shugart 800/801, the Innovex 410, the Innovex 220 (modified by a jumper change), the GSI 110, the CDC 803, and the PerSci 270, the PerSci 70, the Wangco/Orbis 76, the Pertec 400, and the Calcomp 140. The interface may not work reliably with some dynamic memories.

The first deliveries were made July 2, 1977. Delivery from the factory is 3-4 weeks after receiving your order, and individuals must send cash in advance. For faster delivery, check with your local dealer.

<sup>\*</sup> ALTAIR is a trademark/tradename of MITS, Inc.

### OPERATING INSTRUCTIONS

One nice thing about using a floppy disk is that the operation of the hardware is fairly simple:

- 1. Turn on computer power.
- 2. Turn on disk power.
- 3. Put a diskette into the drive and close the door.
- 4. Press the reset button on the computer.
- 5. Press the run button on the computer.

At this time, the hardware bootstrap routine automatically reads in the first sector of track zero, and runs it. This 128 byte module contains a more sophisticated loader which brings in the main operating system and runs it. Therefore, you should see the header that the operating system prints when it first comes up. In CP/M, this is something like "CPM V1.3". From this point on, you need to refer to your manual on CP/M (or whatever operating system you're using).

When you're all done, the shut-down procedure is as follows:

- 1. Open the disk drive door and remove the diskette.
- 2. Turn off the power to the disk drive.
- 3. Turn off the computer power.

### GENERAL NOTES ABOUT USING YOUR DISK SYSTEM

- 1. In general, floppy disk drives are a very reliable method of storing data if nothing else goes wrong in the computer. As with any external medium, however, there will be some errors. These are normally detected by the interface and the software. The manual on your disk drive should have some figures as to the reliability of your particular unit. As a rule, you can expect the Tarbell floppy disk interface and your floppy disk drive to work for many days at a time without an error.
- 2. On the other hand, remember that your floppy disk interface is an on-line device; that is, the computer can write onto it any time, unless the write-protect is on. This has its advantages, but it also means that the disk is always subject to wipe-out,

destroying some or all of the information on it. All it takes is a software error, power-line glitch or a temporary hardware malfunction to lose many hours, days, and even weeks of work if you only have that single copy.

It is therefore desirable to keep frequent back-ups of your files. This can be done by copying files to another diskette or to cassette. In this way, only the information entered since the last backup can be destroyed.

- 3. When first using any operating system, including CPM, run it in the write-protected mode for a little bit. Then make a back-up copy as soon as possible.
- 4. Note that CP/M always loads a program for execution at 100 hex. If it is desired to run a program at zero, such as basic, it must first be loaded at 100 hex and then moved down.
- 5. When the bootstrap switch (7) is on, a reset will gate the bootstrap program onto the bus. Even programs that run in other parts of the memory may be adversely affected if you attempt to run them before the bootstrap is disabled. Although the bootstrap is normally disabled automatically, there may be times when you want to disable it manually. This can be done by putting front panel data switch 5 to the upposition and doing an examine, or by turning off dip-switch 7.
- 6, There is a difference in the reliability of different manufacturer's diskette media. We at Tarbell Electronics have not yet decided which ones are the best. Ask your friends who know. Try several kinds. You will find that you get more errors on some than on others.
- 7. Diskettes are usually initialized by the manufacturer in some way. IBM format dictates a certain sequence of information about track number, sector number, fill characters, etc. on each track. The proper format for IBM compatibility is shown in the 1771 data sheet.

- 1. All RAM boards used in this disk operating system must have no wait states.
- 2. Take extreme care in handling the FD1771B-01 integrated circuit. Being a MOS device, it is liable to destruction from static charge induced by excessive handling--and it's expensive.
- 3. Before removing or installing the floppy disk interface board or any board in your computer, turn off the power and wait for at least ten seconds to let the capacitors discharge.
- 4. Before turning the computer power or the disk power on or off, be sure that the disk door is open, and preferably that the diskette is removed—so any transients won't wipe out the disk.
- 5. Always turn on the computer power before the disk power, and turn off the disk power before the computer power.

### **BASIC-E Compiler Description**

This compiler is a public-domain piece of software written by Gordon E. Eubanks, Jr. As provided by Tarbell Electronics, it is meant to work with the CP/M™ Disk Operating System. With the CP/M, it requires about 20K bytes of main memory. Since it is a compiler, as opposed to an interpreter, it has some advantages: 1) the program will probably run faster than with an interpreter, 2) the program will probably use less memory than with an interpreter. There are also some disadvantages: 1) it is not as easy to develop a program, because editing must be done separately, 2) it cannot be easily used with a cassette, because there are several steps that are not easily and quickly performed by a cassette unit, 3) In this version there is no PEEK or POKE, no PRINT USING, no CALL to machine code programs, and no LPRINT. These are all available in CBASIC, which costs \$100.00.

The following statements are valid in BASIC-E:

FOR, NEXT, FILE, CLOSE, GOSUB, GOTO, INPUT, LET, ON, PRINT, READ, RESTORE, RETURN, RANDOMIZE, OUT, STOP, DATA, DEF, DIM, END, IF, REM, ELSE, THEN.

The following built-in functions are valid in BASIC-E:

ABS, ASC, ATN, CHR\$ COS, COSH, FRE, INP, INT, LEFT\$, LEN, LOG, MID\$, PO\$, RIGHT\$, RND, SGN, SIN, SINH, STR\$, SQR, TAB, TAN, VAL, EXP.

The following logical connectives are available: AND, EQ, GE, GT, LE, LT, NE, NOT, OR, <, >, =.

There are 26 compiler error messages, and 23 run-time error messages, all of two characters each.

Disk files may be read, written or updated by the BASIC-E program using both sequential and random access. There are blocked and unblocked files. The program can select any disk available to CP/M.

Using the BASIC-E compiler consists of three main steps:

- 1) The source program is created on disk using the Editor.
- 2) The source is compiled by the compiler, which produces an intermediate file.
- 3) The intermediate file is then run by the run-time monitor.

Line numbers need only be used on statements to which control is passed, and do not have to be in ascending order. Using identifiers longer than two characters and indenting statements to enhance readability does not affect the size of the object file created by the compiler. The first 31 characters of identifiers are used by the compiler.

The 40-page manual is available for \$5.00.

The compiler and run-time monitor are included on our CP/M diskette, and are also available separately on a diskette for \$10.00.

The complete listing, which is written mostly in PL/M, is available for \$15.00.

# CP/M™ BY DIGITAL RESEARCH — A COMPLETE FLOPPY DISK OPERATING SYSTEM FOR THE TARBELL FLOPPY DISK INTERFACE.

The CP/M Disk operating system has been in existence for over two years in various manufacturer's products, and thus has had extensive field testing. It is now being made available to the hobby community. It is licensed software, and copying for other individuals is prohibited. We feel this is justified, as the cost, \$100, is low for such a good system.

The following commands are built in to the operating system:

DIR List all or selected portions of the directory (file list)

TYPE Type the contents of an ASCII file on the console

REN Rename a file to a different name
ERA Erase a file or files from the disk
SAVE Save memory on disk for later load

The following programs are included on the disk, and are invoked just like commands by typing the name:

PIP Peripheral Interchange Program moves files around

SUBMIT Batch processing program for predefined list of commands

ED A really nice, string-oriented text editor

ASM Assembler to convert assembly language to machine code
DDT Dynamic Debugging Tool for memory dumps, loads, traces

LOAD Convert hex file to memory image file

DUMP Dump file in hex onto console

SYSGEN Generates new CP/M systems for backup

BASIC BASIC-E compiler has both sequential and random file access

RUN Run-time interpreter for BASIC-E programs

STAT Prints the amount of disk storage still available and amount used for each file

CPM Generates different sized CP/M systems

COPY Copies from one disk onto another, track by track

TAPELIB Provides extensive disk-to-cassette facilities.

The following source files are included on the disk:

CASDSK Transfers the named file from Tarbell cassette to disk
DSKCAS Transfers the named file from disk to Tarbell cassette
SBOOT Cold-Start loader which is loaded by bootstrap program
CBIOS Customer's Basic Input/Output System includes all drivers

FORMAT Reformats crashed diskettes

COPY Assembly language source for program above

INV Basic inventory program

Tarbell Electronics provides the system modified to work with the Tarbell floppy disk interface and a simple console interface, such as a teletype. The console is addressed with port O for status and port 1 for data. Bit O of status low means keyboard ready, and bit 7 of status low means printer ready. It is set up to work in 24 kbytes. The documentation includes a listing of the BIOS, and instructions which will enable you to patch the CBIOS for your own system.

As of March 1, 1978 the CP/M User's Group had 24 diskettes full of software. It costs \$4 to get on the mailing list, and the diskettes are \$8 each. The address is 164 West 83rd Street, New York, New York 10024.

### DOCUMENTATION:

CP/M FEATURES AND FACILITIES MANUAL
CP/M EDITOR, ASSEMBLER, AND DEBUGGER MANUALS
CP/M INTERFACE GUIDE
CP/M SYSTEM ALTERATION GUIDE
TARBELL CP/M USER'S GUIDE

### THEORY OF OPERATION

The internal operation of a floppy disk system is probably the most complicated part of a micro-computer system. The hardware and software interact very closely. For best understanding, you should be familiar with both the 8080 machine/assembly language, and the common logic operations. Some understanding of the S-100 bus is also desirable. Remember to take into account any differences in your system's I/O setup as you follow the circuit.

Since the Tarbell Floppy Disk Interface is designed around the Western Digital 1771 Floppy Disk Integrated Circuit, it would be helpful to skim over the data sheets (reproduced in the appendix with the manufacturer's permission). The main thing is to get a feeling for what the 1771 does in order to get a perspective of how it fits into the circuit.

ABOUT READING THE SCHEMATIC: note that lines of most drives are true when low--that is, a low voltage is a logic one. Active low lines have an asterisk following their name (e.g., RDY\*). The convention of this schematic is that a darkened dot is a possible connection to a floppy disk drive; an open circle is a pad for a possible jumper wire; a little square with a number in it is a pin on the 100-pin S-100 bus; and a line with none of these, but a name close to it, is a connection to another line with the same name.

To see what we need in the interface, let's see what it must connect to on each side. On the computer side, we have two simple instructions: input a byte (IN), and output a byte (OUT).

On the side of the floppy disk, we have many different things to be concerned with. First, the data lines going to and from the floppy drive are serial (one bit at a time). Thus we must have some way to convert parallel computer data to serial data on the drive side.

Next, the drive has several control lines. These are lines that tell the drive what to do. For example, there are two lines to tell the drive to move the head in or out. There's another line that tells the drive to engage the head against the disk surface (normally the head is not in contact to reduce wear on the disk and on the head). Another control line is usually used to reset the drive electronics and return the head back to the zero (outside) track. There's a set

of lines on some drives to select one drive out of several on a "daisy-chain" bus.

Still other lines tell the drive whether to read or write, and to write with how much current. All of these control lines need to be driven by the interface, normally at high-current TTL levels.

There are also a set of status lines which originate in the drive and come back to the interface. These lines tell the interface what is going on in the drive.

There is usually a ready line, set true when the drive is up to speed and a disk is in place. The index line has a pulse on it that indicates when the index hole in the diskette passes by the opening made for it. This is used by the interface to determine which sector is which on the track.

Some drives have a way to detect a notch cut out of the diskette holder, which indicates that disk is not to be written upon (write protected). There is usually a line going back to the interface to indicate this condition, so the controller can feed the information back to a program, and so the interface won't try to write to the disk. Another line indicates when the head is at track zero. Some drives have a write-fault flip-flop, which is set by an attempt to write when it was not possible. The output of this flip-flop is sometimes a status line.

You may begin to see now one reason why the floppy disk system is complicated: there are a lot of status and control lines to keep up with.

### DEVICE-SELECTION (BOARD ADDRESSING)

The first task of the interface is to recognize when the program sets the hardware for a read or a write operation to the disk. Selection circuitry is used to recognize 5 of the 256 possible I/O addresses. In this way, the floppy disk interface will respond only to the I/O instructions given to it, and not to those intended for other interfaces. The components associated with this process are located in the lower part of the schematic, slightly to right of the middle. These are dip-switch S-1 (5 positions used here), DM8131 U25 (a 6-bit comparator), 74LS32 OR gates U27, a 3-input NAND gate from 74LS10 U43, plus a few inverters.

The comparator checks for a match between the 5 high bits of the device address (lines A3, A4, A5, A6, and A7) and the bit pattern set on the dip switch. If the five lines (B1-B5) on the left each have the same logic level as the ones on the right (T1-T5), then the

comparator output at pin 9 goes low, indicating the disk interface is being selected. For any other combination, pin 9 goes high, and the instruction on the bus if left for some other interface.

Since the lower three address bits (A0, lAl and A2) can be any one of eight combinations, eight I/O ports out of the possible 256 are selected for use with the disk interface. Which set of eight depends on the upper five bits selected by the dip-switch.

From now on, let's assume that the upper five bits match—that is, an input or output instruction has been put on the bus with the correct address for the disk interface, so that the comparator output goes low). Note that this output goes up to an input on each of two OR gates (these gates are drawn as AND gates, to indicate that because of the inverted input signals, the AND function is being performed—ie. when both inputs of a gate are low, the output of the gate is low. On the top one of these two gates, pin 4 is connected to address line A2. So when A2 is low (and we've already said pin 5 is low), the gate's output at pin 6 is also low (active). This line is called CS\*, for chip—select—not, and is connected to the 1771 chip—select line. This line, then, will be active anytime there is a transfer to be made between the computer and the 1771.

A similar decoding scheme sets each of the other individual operations. The table below shows how the address decoding scheme is set up, and the lines that are active for each situation.

| A2 | Al | A0 | FUNCTION OUT    | FUNCTION IN LIN  | NE ACTIVE   |
|----|----|----|-----------------|------------------|-------------|
| 0  | 0  | 0  | Command to 1771 | Status from 1771 | CS*         |
| 0  | 0  | 1  | Track to 1771   | Track from 1771  | CS*         |
| 0  | 1  | 0  | Sector to 1771  | Sector from 1771 | CS*         |
| 0  | 1  | 1  | Data to 1771    | Data from 1771   | CS*         |
| 1  | 0  | 0  | decoded by U56  | see table below  | U43-6,U27-8 |
| 1  | 0  | 1  | Not used        | Not used         |             |
| 1  | 1  | 0  | Not used        | Not used         |             |
| 1  | 1  | 1  | Not used        | Not used         |             |

Notice that no further decoding of address bits A0 and A1 is required to perform the first four functions in the table. That's because these functions are decoded inside the 1771. Notice also that U-55 pin 4 is fed by U3-3, which is true when PDBIN is high and SINP\* is low (both true). This indicates to the 1771 that an input (1771-to-computer) operation is taking place. U55-2 is fed by U43-6, which is true when an output (computer-to-1771) transfer is taking place; PWR\* and SOUT are both true.

If A2, A1 and A0 are 1, 0 and 0 respectively, and the other five I/O address bits match the setting of

switch S1, gates U44, U43, U27 and U25 (all in lower right) pull line IO\* down. This line, along with an active low signal from U43 (when SOUT and PWR\* inverted are true) enables U56 (a 3-to-8 line decoder). This is the fifth state given in the table above. Enabling U56 allows it to pull one of its output lines low in accordance to the state of the three least-significant data-out lines, D0, D1, and D2 which are the inputs to the decoder. Only the top three of the available 8 outputs are used: Y5, Y6, and Y7. This actually decodes the bottom three combinations of D0, D1, and D2, since these lines are active low (inverted). The table below shows what these combinations are used for:

| D2 | D1 | D0 | Y | U56- | FUNCTION DESCRIPTION                     |
|----|----|----|---|------|------------------------------------------|
| 0  | 0  | 0  | 7 | 7    | Pad E-32, can be used to pulse RST* line |
|    |    |    |   | 9    | Inverted, then to E-14 for SO* line      |
| 0  | 1  | 0  | 5 | 10   | Strobes data bits 4,5,6,7 into latch U40 |

### BUFFERS

Once the board has been selected and the operation decoded, the actual data transfers are done by a series of buffers.

The buffers in this interface have three main purposes: 1) To protect the expensive LSI chip (1771 IC) from voltage transients on external lines; 2) To provide sufficient drive current for the lines that need it; 3) To provide multiplexing (switching) of two data paths. The signal that comes out of a buffer is either the same signal that went in or simply the inverted form of what went in.

Looking in the lower left corner of the schematic, we see a row of 12 buffers. All the data inputs for these buffers come from the disk drives(s), and all the outputs go someplace in the interface. The line on the top of each buffer is the control line. When this line is low, the buffer is active--that is, the output equals the input for that buffer. When the control line is high, the output for that buffer is floating in an open state so it does not affect any connecting circuits. Notice that every other buffer is hooked to the same control line, and that there are two main control lines. One control line activates the buffers that have signals from drive number 0, the other control line activates the buffers that have signals from drive number 1. Thus the buffer acting as a 12-line to 6-line multiplexer. Thus the buffers are This multiplexing operation is only necessary if there more than one drive, and the drives do not have multiplexers built in (most late-model drives do).

Also notice the 120 ohm resistors on the inputs of these buffers. They have two purposes. One is to

match the normal low line impedance so that ringing caused by reflections will be minimized. The other is to make it difficult for external noise to provide enough current to cause a false signal on the line. The six outputs of these buffer pairs will be called by their signal name, while their inputs are named by the signal line plus the number of the drive (i.e., RDY, RDYO, and RDY1).

Next move your eye on the schematic up and slightly to the right. There is a row of five 7438 2-input NAND high- current open-collector gates. These are used as buffers in this interface. Their main advantage is that they are capable of supplying the high current required by the floppy drive(s). They also can double as NAND gates. As set by the jumpers, they are used to send the appropriate signals from the 1771 to the various disk control lines (see the 1771 data sheet and your drive's manual for a full explanation of the various lines). If both inputs to these gates are a logic high, the output is low. To the right, in the middle of the schematic, are seven more of these 7438 buffers. These too go to the drive(s).

About two thirds of the way to the right near the top of the schematic, there are two rows of 8 These buffers buffer/inverters each. link the computer input and output data busses to the 1771 data bus. The inputs to the left row of buffers come from S-100 bus. The control lines for all these the buffers are connected together. When this control line is low, the data on the output data bus is inverted and gated onto the 1771 data bus. The gates on the right hand side do the reverse: when their control line is low, the data on the 1771 data bus is gated onto the computer's input data bus.

The last set of buffers is on the far right-hand side of the schematic, and is a row of nine non-inverting buffers. Their purpose is to suspend the usual CPU control of the data bus and gate the proper control signals onto the S-100 status lines to put the bootstrap in operation. When their common control line is low, whatever is on their inputs is gated to their outputs. Once the bootstrap is completed, U43, U34, and U37 relinquish control back to the bus.

Bootstrap is initiated by NOR gate U28 (lower right) receiving Power On Clear (also generated by RESET) from the computer, which sets flip-flop U34 (upper right). The not-Q output, if passed by Sl position 5, is the bootstrap signal. This gates those nine buffers, and is used along with a signal from U37 (upper right) to activate U27 (middle) during the read cycle, thus reading from the 82S123 memory but writing through the bus to regular RAM.

### TIMING CIRCUITS, SEPERATOR, AND PROCESSOR HOLD

At the lower right of the schematic, Ul, U2, Ul7, U33, U34, U35, and U36 form the clock and data seperator, which operates on the raw data which comes in on the line wich runs across the very bottom of the schematic. The actual clock oscillator circuit (also lower right) is composed of two sectons of Ul7 plus the 4MHz crystal Yl. Grounding pin 25 of the 1771 (XTDS\*) disables the internal seperator.

On the bottom middle, the INTRQ and DRQ signals from the 1771 are used to control the run or wait state of the CPU through gates U30 and U57 and bus signals PRDY or XRDY. These circuits allow the 1771 to temporarily suspend execution of the next CPU instruction until an internal process has been completed.

### HEAD-LOAD CIRCUIT

The 1771 checks for head-load by looking at the HLT line 10 milliseconds after the HLD line is activated. U41 and U57, in the upper-left corner of the schematic, sample the HLD line and generate the proper delay to allow for the physical head-load time of the drive before passing the signal on to the HLT input of the 1771.

### STEP-IN AND STEP-OUT CIRCUIT

The 1771 signals your drive to step the head in or out by providing a short pulse from the step output and a DIRC output which is high for stepping in and low for stepping out. These signals must be reformatted for many drives, and they must be buffered. The circuitry at U59, U51 and U61, all in the upper left side, perform these tasks.

Most drives require a longer step pulse than is output at pin 15 of the 1771, so one-shot U51 is used to stretch the pulse out. For drives which require a step signal and the same polarity direction signal, like the Innovex 410, the other signals are simply buffered and then routed to the drives by the appropriate jumpers. For drives like the CDC BR803A, which require a step-in and step-out line, the jumpers are set to make these circuits decode those signals from the DIRC and step lines.

A few drives require step signals faster than those generated by the 1771. The line into pin 1 of buffer U59 can be driven directly by the computer, and can therefore be pulsed at a much faster rate. However,

in this case, the program must keep track of the number of pulses that this line puts out, plus observing any timing constraints.

WRITE DATA, WRITE GATE, TRACK GREATER THAN 43

The write data, write gate, and track greater-than-43 signals control the write-to-disk functions. The circuits to control these signals are just above the middle left.

The write-data line contains the actual data mixed with a clock signal. From pin 31 of the 1771, it goes through buffer U57, and line driver U62, and then out through the jumpers to the disk. The TG43 line which tells the drive to reduce the head current while writing on the physically smaller tracks is set high when the track number is higher than 43. From the 1771 pin 29, it goes to U35, where it can be inverted for drives which require the opposite polarity, and then through driver U62 and the jumpers out to the disk.

The write-gate signal tells the drive that it is time to start a write operation. It comes out of the 1771 pin 30, is buffered by U57, and NANDed with the write protect signal at U62, where it goes to the jumper pads and the disk. The write gate signal can only go active (low) when switch position 6 of DIP-switch Sl is off, providing a logic 1 to pin 5 of U62. This switch allows you to prevent any write operation to the disk, regardless of any deliberate or accidental commands in the program. When this switch is not in the protect position, any time the write-gate is driven high from pin 30 of the 1771, the disk will be overwritten.

POWER SUPPLY (VOLTAGE REGULATOR) SECTION

The interface requires +5 Volts, +12 Volts, and -5 Volts. These are provided by on-board regulators driven from the unregulated DC voltages of the S-100 bus.

A 7805 (LM309) regulator supplies the +5 Volts. To make it run a little cooler, a 15 Ohm 2 watt resistor has been placed in parallel to bypass some of the current while still allowing the regulator to control the voltage.

The +12 Volt DC is regulated by a 12 Volt zener and 120 ohm resistor, since this supply must only provide a small amount of current. The -5 Volt supply is a similar zener-resistor pair.



1/4 W resistors



2 W resistor



LED



disc capacitor



electrolytic capacitor



mylar capacitors



DIP switch



integrated circuits



resistor networks



crystal



1771



40-pin socket



16-pin Bocket



50-pin header

| QTY                                                                                               | PART NO.                                                                                                                                                                                                                                      | REF. NUMBERS                                                                                                                                | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|---------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2<br>3<br>4<br>3<br>1<br>1<br>2<br>3<br>3<br>1<br>1<br>2<br>3<br>1<br>1<br>2<br>3<br>1<br>1       | 74LS161 74LS00 74LS04 74LS367 74LS368 82S123 DM8131 74LS32 74LS08 74LS175 74LS74 74LS86 74LS123 7438 74LS10 8T97 FD1771 74LS138 7805UC                                                                                                        | U1,2 U3,45 U17,44,59 U18,19,24,30 U20,21,22 U23 U25 U27,29 U28,36,63 U33,37,40 U34 U35 U41,51 U42,61,62 U43 U52,53,57 U55 U56 U65           | 4-Bit Binary Counter Quad 2-Input NAND Gate Hex Inverter Hex Tri-State Buffer Hex Tri-State Inverter 32-Byte PROM 6-Bit Digital Comparitor Quad 2-Input OR Gate Quad 2-Input AND Gate Quad Latch Dual Type-D Flip-Flop Quad Exclusive-OR Gate Dual Retriggerable 1-shot Quad 2-Input NAND Buffer O/C Triple 3-Input NAND Gate Hex Tri-State Buffer Floppy Disk Controller 3-8 Line Decoder 5-Volt Regulator                                                                                                                                                                              |
| 14<br>1<br>4<br>1<br>2<br>2<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1 | 120-1/2W<br>15K-1/4W<br>4.7K-1/4W<br>510-1/4W<br>33K-1/4W<br>10K-1/4W<br>470-1/2W<br>15-2W<br>1K-1/4W<br>2.2K-1/4W<br>330-1/4W<br>1KNW8<br>4.7KNW6<br>22MFD<br>33MFD<br>.1MFD<br>4.7MFD<br>390PF<br>1N751<br>1N4742<br>LED<br>CY3A<br>DIP-SW7 | R1-12,19,24 R13 R14,16,20,30 R15 R17,18 R21,22 R23 R27 R28,33 R29 (For Tests) Z1 Z2 C1,3 C2 C4,6,8-21 C5 C22 VR1 VR2 (For Tests) Y1 U26(S1) | 120 Ohm 1/2 Watt Resistor 15 Kohm 1/4 Watt Resistor 4.7 Kohm 1/4 Watt Resistor 510 Ohm 1/4 Watt Resistor 33 Kohm 1/4 Watt Resistor 10 Kohm 1/4 Watt Resistor 10 Kohm 1/2 Watt Resistor 15 Ohm 2 Watt Resistor 15 Ohm 2 Watt Resistor 1 Kohm 1/4 Watt Resistor 2.2 Kohm 1/4 Watt Resistor 330 Ohm 1/4 Watt Resistor 1 Kohm Resistor Network (8-pin) 4.7 Kohm Res. Network (6-pin) 22 Mfd 25-Volt Capacitor 33 Mfd 10% Capacitor .1 Mfd 10-Volt Capacitor 4.7 Mfd 10% Capacitor 5.1-Volt 1/2 Watt Zener 12-Volt 1 Watt Zener Light-Emitting Diode 4 MHz Crystal 7 or 8-Position Dip-Switch |
| 1<br>1<br>2                                                                                       | HS1<br>Set#6<br>Set#2                                                                                                                                                                                                                         | HS1<br>(For HS1)<br>(For Header)                                                                                                            | Heat Sink<br>#6 Screw, Nut, Washer<br>#2 Screw, Nut, Washer                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 1<br>1<br>1<br>1                                                                                  | 1011<br>FDCABLE<br>HDR-50<br>DIP-S16<br>DIP-S40                                                                                                                                                                                               | PCB<br>In Header<br>At J1<br>At U23<br>At U55                                                                                               | Printed Circuit Board<br>50-Cond. Cable & 1 Connector<br>50-pin Header Connector<br>16-Pin Dip Socket<br>40-Pin Dip Socket                                                                                                                                                                                                                                                                                                                                                                                                                                                               |

| QTY                                                                                     | PART NO.                                                                                                                                                                                                                                                        | REF. NUMBERS                                                                                                                                          | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|-----------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2<br>3<br>4<br>3<br>1<br>1<br>2<br>3<br>3<br>1<br>1<br>2<br>3<br>1<br>1<br>1<br>1       | 74LS161 74LS00 74LS04 74LS367 74LS368 82S123 DM8131 74LS32 74LS08 74LS175 74LS74 74LS86 74LS123 7438 74LS10 8T97 FD1771 74LS138 7805UC                                                                                                                          | U1,2 U3,45 U17,44,59 U18,19,24,30 U20,21,22 U23 U25 U27,29 U28,36,63 U33,37,40 U34 U35 U41,51 U42,61,62 U43 U52,53,57 U55 U56 U65                     | 4-Bit Binary Counter Quad 2-Input NAND Gate Hex Inverter Hex Tri-State Buffer Hex Tri-State Inverter 32-Byte PROM 6-Bit Digital Comparitor Quad 2-Input OR Gate Quad 2-Input AND Gate Quad Latch Dual Type-D Flip-Flop Quad Exclusive-OR Gate Dual Retriggerable 1-shot Quad 2-Input NAND Buffer O/C Triple 3-Input NAND Gate Hex Tri-State Buffer Floppy Disk Controller 3-8 Line Decoder 5-Volt Regulator                                                                                                                                                                                                                      |
| 14<br>1<br>6<br>1<br>2<br>3<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1 | 120-1/2W<br>15K-1/4W<br>4.7K-1/4W<br>510-1/4W<br>33K-1/4W<br>10K-1/4W<br>470-1/2W<br>15-2W<br>1K-1/4W<br>2.2K-1/4W<br>330-1/4W<br>1KNW8<br>4.7KNW6<br>22MFD<br>33MFD<br>.1MFD<br>4.7MFD<br>390PF<br>100PF<br>100PF<br>1N751<br>1N4742<br>LED<br>CY3A<br>DIP-SW7 | R1-12,19,24 R13 R14,16,20,30,35 R15 R17,18 R21,22,34 R23 R27 R28,33 R29 (For Tests) Z1 Z2 C1,3 C2 C4,6,8-21 C5 C22 C24 VR1 VR2 (For Tests) Y1 U26(S1) | 120 Ohm 1/2 Watt Resistor 15 Kohm 1/4 Watt Resistor 36 4.7 Kohm 1/4 Watt Resistor 510 Ohm 1/4 Watt Resistor 33 Kohm 1/4 Watt Resistor 10 Kohm 1/4 Watt Resistor 470 Ohm 1/2 Watt Resistor 15 Ohm 2 Watt Resistor 1 Kohm 1/4 Watt Resistor 1 Kohm 1/4 Watt Resistor 2.2 Kohm 1/4 Watt Resistor 330 Ohm 1/4 Watt Resistor 1 Kohm Resistor Network (8-pin) 4.7 Kohm Res. Network (6-pin) 22 Mfd 25-Volt Capacitor 33 Mfd 10% Capacitor 1 Mfd 10-Volt Capacitor 4.7 Mfd 10% Capacitor 390 Pfd Capacitor 100 Pfd Capacitor 5.1-Volt 1/2 Watt Zener 12-Volt 1 Watt Zener Light-Emitting Diode 4 MHz Crystal 7 or 8-Position Dip-Switch |
| 1<br>1<br>2                                                                             | HS1<br>Set#6<br>Set#2                                                                                                                                                                                                                                           | HS1<br>(For HS1)<br>(For Header)                                                                                                                      | Heat Sink<br>#6 Screw, Nut, Washer<br>#2 Screw, Nut, Washer                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 1<br>1<br>1<br>1                                                                        | 1011<br>FDCABLE<br>HDR-50<br>DIP-S16<br>DIP-S40                                                                                                                                                                                                                 | PCB<br>In Header<br>At J1<br>At U23<br>At U55                                                                                                         | Printed Circuit Board<br>50-Cond. Cable & 1 Connector<br>50-pin Header Connector<br>16-Pin Dip Socket<br>40-Pin Dip Socket                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |

There are two major changes on the rev C boards:

- 1. Changes have been incorporated to allow operation on SOL-20 (Processor Technology) computers without the additional cuts and jumpers that are specified in step 4 on page 7-9 of this manual.
- 2. Changes have been incorporated to allow operation with Z-80 CPU boards by using the phantom line (pin 67). The jumpers required are listed below. The steps on page 7-8 are only valid for Z-80 operation with rev A, and are no longer valid for revision C.

Whether you're going to operate your interface with an 8080 or with a Z80 CPU, install the following items:

- ( ) A 100 pf disc ceramic capacitor at C24.
- () A 10 kohm 1/4 watt resistor (brown, black, orange) at R34.
- () A 4.7 kohm 1/4 watt resistor (yellow, violet, red) at R35.
- () The write protect switch (S1-6) now has three options: If you want the switch to protect
  - 1. only even numbered drives, jumper E36 to E31.
  - 2. only odd numbered drives, jumper E36 to E42.
  - 3. all drives, jumper E36 to E37.

If you are going to operate your interface with a Z-80 CPU, or with an 8080 CPU and a memory with a phantom line, the memory located at address zero should have a phantom line (pin 67) which disables the memory when it is low. Then install the following items:

- () A jumper wire between E59 and E60.
- () A jumper wire between E63 and E58.
- () A 4.7 kohm 1/4 watt resistor (yellow, violet, red) at R36.
- () A jumper wire between E56 and E65.

If you are going to operate with an 8080 CPU without using the phantom line (standard), install the following items:

- () A jumper between E63 and E64.
- () A jumper between E56 and E57.
- () A jumper between E61 and E62.

### ASSEMBLY

The assembly of the disc interface consists of a series of small steps, each one of which should be checked before proceeding to the next one. You should have a computer mainframe of the IMSAI or ALTAIR\* type available.

You may elect, of course, to disregard the detailed instructions and just mount the components as shown in the assembly drawing, plug the board in, and hope for the best. If you do take this route, please at least check the voltages that go to the 1771 chip before this last part is installed (+5, -5, +12). Be sure to leave R27 out until you have all the IC's installed.

### NOTES:

- 1) When the instructions say "install board in mainframe in test configuration", make sure mainframe power has been off for at least 10 seconds, then install the board in any slot. No other interface board or memory board should be in the mainframe unless specified in the instructions. At the end of the test, turn off mainframe power and wait at least 10 seconds before removing the disk interface board.
- 2) "Locate and install" means find the indicated parts, mount each one as shown on the circuit board diagram, and solder them in place.
- 3) Some of the tests require use of the front panel that is normally included on an IMSAI or ALTAIR\* computer. If your computer does not have a front panel with several lights and switches, you will have to skip over these sections.

\*\*\*\*\*

### 1. Inspection

- () Check the printed circuit board carefully for flaws.

  Look especially closely for any shorts between traces which
  might later be covered under a socket or an IC.
- () Check contents of the kit against parts list. If any parts are missing, contact Tarbell Electronics for prompt replacement. If you have any extra parts, be sure and note this too, so they won't confuse you later on.
- 2. Construct LED (Light-Emitting-Diode) Tester
- () Find the 330 ohm resistor (orange, orange, brown) and the LED. As shown in the diagram, solder the LED anode (usually the anode is marked in red, or the cathode is a wider lead) to the resistor. Connect the LED cathode to a two-foot length of scrap flexible insulated wire (18-24 gauge is best). Strip about 1/4 inch from the end of the wire. This assembly will be referred to as the "LED probe".

<sup>\*</sup> ALTAIR is a trademark/tradename of MITS, Inc.



- 3. Install 40-pin socket
- () Find the 40-pin socket. Using the parts layout diagram, orient the socket so the notch indicating pin 1 faces the top of the card and pin 1 fits in the square pad.
- () Insert the socket, and carefully check that every pin is showing through on the solder side of the board.
- ( ) Hold the socket in firmly and solder all pins.
- 4. -5 Volt regulator
- ( ) Locate and install the following components:
  - () R23--470 ohm 1/2 watt resistor (yellow, violet, brown)
  - ( ) VR1--5.1 volt zener diode (marked 1N751); make sure polarity band is at left
  - () C9--.1 MFD 10-volt disc ceramic capacitor.

Test--Install board in mainframe in the test configuration.

- () Temporarily connect the resistor end of the LED probe to a circuit ground. Touch the end of the wire from the probe to the left end of R23, which connects to the -16 volt bus. Notice the relative brightness of the LED.
- ( ) Move the wire to the right end of R23. The glow should be considerably less but not extinct.
- () If you have a voltmeter or oscilloscope, check that voltage at the right end of R23 is -5.1 within 10%.
- 5. +5 Volt regulator
- () Find the parts for the 5-volt regulator: () 7805 or LM309 3-pin IC; () regulator heat sink; () #6-32 mounting screw, and matching nut and washer;
- () Using the assembly diagram, position the regulator at U65. Insert the leads through the appropriate holes.
- () With the heat sink in place between the regulator and the board, bend the regulator pins over and fasten the regulator body against the heat sink with the screw and washer on the solder side of the board and the nut on the parts side. Solder the regulator in.
- () Install a 22 mfd. capacitor at Cl observing polarity shown on diagram.
- () Install the other 22 mfd. capacitor at C3, again observing polarity.

Test--Install the board in the computer mainframe in the test configuration.

- ( ) Connect the wire lead end of the LED probe to a good circuit ground. This end will remain connected for the rest of the asembly process. Touch the resistor end of the probe to the bottom lead of the +5 volt regulator (U65). Note the relative brightness.
- () Move the probe to the middle lead of the regulator. The light should go out altogether if not, this pin is not properly grounded.
- () Move the probe to the top lead of the regulator. The LED should glow with slightly less brightness than at the bottom lead.
- ( ) The top lead should measure +5 volts within 10% using a voltmeter or oscilloscope.

### 6. +12 Volt regulator

- ( ) Locate and install the following parts:
  - () R24--120 ohm 1/2 watt carbon resistor (brown, red, brown)
  - () VR2--12-volt 1 watt zener diode (marked 1N4742); be sure to place the polarity band of VR2 at right, as shown on the assembly diagram. On diodes marked with color bands, the end toward which the colors are grouped is the right end.
  - () C10--.1 Mfd 10-volt disc ceramic capacitor.

Test--Install the board in the test configuration.

- () Place the tip of the LED probe on the left end of R24 and notice the brightness.
- () Touch the probe to the right end of R24. Check that the glow is less, but still quite visible.
- () If you have an oscilloscope or voltmeter, the voltage at the right end of R24 should be +12 volts within 10%.

NOTE--Do not proceed until you are confident the foregoing circuits are working properly. If not, they might damage the 1771 IC or other expensive chips.

### 7. Primary address circuit

- ( ) Locate and install the following parts:
  - ( ) U24--74LS367 hex buffer IC.
  - () U25--DM8131 6-bit comparator IC.
- () Install the 4.7K 6-pin in-line resistor network at Z2 with the dot in the square pad.
- () Install switch s1 (7-position or 8-position DIP switch) in the upper 14 holes at U26, with switch #1 oriented toward the top of the board. If it is a 7-position switch, there will be two empty holes left at the bottom. If it's a 8-position, you have an extra switch for your own purposes.

### Test--Install board in test configuration.

- Set all switch positions off.
- () Using the computer's front panel switches, examine location F8 (hex).
- () Using the LED probe, check that pin 9 of IC 25 is in the low state (out).
- () Check that the LED goes on if any of the address switch positions (S1 1 to 5) on the board are changed.

( ) Reset the switches, and check that the LED goes on if any other location smaller than F8 is examined. Secondary Address Gate Circuitry Locate and install the following components: () U28--74LS08 quad 2-input and gate IC U30--74L\$367 hex buffer IC ( ) U57--8T97 hex buffer IC R20--4.7K ohms 1/4 watt resistor (yellow, violet, red) R16--4.7K ohms 1/4 watt resistor (yellow, violet, red) ( ) R14--4.7K ohms 1/4 watt resistor (yellow, violet, red) ( ) R15--510 ohm 1/4 watt resistor (green, brown, brown) ( ) C8--.1MFD 10 volt disc ceramic capacitor ) R28--1K ohm 1/4 watt resistor (brown, black, red) ) R33--1K ohm 1/4 watt resistor (brown, black, red) Test--Install board in test configuration. Connect probe to U28 pin 8. Push reset switch on computer. Pin 8 should go low (LED out). Push the external clear switch on computer. Pin 8 should go low. Command Logic decoding gates Locate and install the following components: () U27--74LS32 quad 2-input OR gate IC. U43--74LS10 triple 3-input NAND gate IC. ( ) ( ) U44--74LS04 hex invertor IC. Test--Install the board in the test configuration. Set all switch positions to off. This sets the base address to F8 (hex). Use the LED probe to look at U27 pin 6 and U27 pin 8 for high (LED on) or low (LED off) states as follows-examine each location shown in the address table below, and check that U27 pin 6 and 8 shows the indicated state: FUNCTION ADDRESS U27 PIN 6 U27 PIN 8 Status/Command Port F8 Low High High Track Command F9 Low High Sector Command FA Low FBLow High Data Port FCHigh Low Wait/Control Port High High Unused FDFEHigh High High FF High 10. Read-write-control decoding gates. Locate and install the following components: () U3--74LS00 quad 2-input NAND gate IC. U22--74LS368 hex invertor/buffer IC. ( ) U29--74LS32 quad 2-input OR gate IC.

| TestInstall board in test configuration.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| () Install a memory card addressed at location 0. Using the computer's front panel switches, load this data:  ADDRESS DATA  0000 DB  0001 F8  0002 C3  0003 00  0004 00                                                                                                                                                                                                                                                                                                                                                                                              |
| Note: If you have an ALTAIR 8800b, it may be easier to put the port number in the upper 8 address switches, and the byte to output in the lower 8 switches.                                                                                                                                                                                                                                                                                                                                                                                                          |
| () Connect probe to U29 pin 11. Examine location 0 and single step. When the input light on your front panel comes on, U29 pin 11 should go low.                                                                                                                                                                                                                                                                                                                                                                                                                     |
| () Install (with power off) a memory card addressed at 0. Using the computer front panel switches, deposit D3 (hex) at                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| location 0. Examine location 0. Attach probe to U43 pin 6.  () Check that the probe indicates a high state. Single step computer using the front panel switch. When the front panel "out" light goes on, U43 pin 6 should go low.                                                                                                                                                                                                                                                                                                                                    |
| 11. Bus Control                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| <ul> <li>() Locate and install the following components:</li> <li>() R292.2K ohm 1/4 watt resistor (red, red, red).</li> <li>() U3474LS74 dual type D flip-flop IC.</li> <li>() U1874LS367 hex buffer IC.</li> <li>() U1974LS367 hex buffer IC.</li> <li>() U2074LS368 hex inverter/buffer IC.</li> <li>() U2174LS368 hex inverter/buffer IC.</li> <li>() U1774LS04 hex inverter IC.</li> <li>() U3774LS175 quad latch IC.</li> </ul>                                                                                                                                |
| TestInstall board in test configuration.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| () Set switch position 7 off. Turn power on and hit the reset switch. Front panel lights "MEMR", "M1" and "WO" should be on. (WO will not be on on the ALTAIR 8800b)                                                                                                                                                                                                                                                                                                                                                                                                 |
| () Set switch 7 to on. Front panel lights "WO" and "WAIT" should be on (except 8800b). All data lights are on.                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 12. Oscillator section                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| <ul> <li>() Locate and install the following components:</li> <li>() C61 microfarad capacitor.</li> <li>() U3374LS175 quad latch IC.</li> <li>() Z11K ohm in-line 8-pin resistor network with dot at square pad hole.</li> <li>() Install the 4 Mhz crystal at Y1. If your crystal has mounting holes in the side of the case, thread a small piece of wire through the holes in the crystal case and solder to the board at each end to hold the crystal down. The metal case of the crystal should be insulated from the mounting surface on the board.</li> </ul> |
| TestInstall the board in the test configuration.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

() If possible, use an oscilloscope to look at pin 6 of U17. You should see a 4 MHz square wave.

| ( )  | If no scope is available, use the LED probe. First, touch the probe to Ul7 pin 14. Note the LED intensity. Now, touch the probe to pin 6, Ul7. The LED should still glow but less intensely. If the LED is as bright as at pin 14, or is not on, then the oscillator is not                                                  |
|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ( )  | working. Using the probe, check that U33 pin 10 also shows a glow between the intensity at U17 pin 14 and nothing.                                                                                                                                                                                                           |
| 13.  | Install rest of clock/data separator.                                                                                                                                                                                                                                                                                        |
| ( )  | Locate and install the following components: () U3574LS86 quad exclusive OR gate IC () U174LS161 binary counter IC () U274LS161 binary counter IC                                                                                                                                                                            |
| Ther | e is no test for this section.                                                                                                                                                                                                                                                                                               |
| 14.  | Data I/O buffers and status/control                                                                                                                                                                                                                                                                                          |
| ( )  | Locate and install the following components: () U2316 pin IC socket for 82S123 PROM () U3674LS08 quad 2-input AND gate IC () Install the 82S123 programmable read-only memory IC in the socket at U23.                                                                                                                       |
| Test | Install the board in the test configuration.                                                                                                                                                                                                                                                                                 |
| ( )  | Set switch position 7 to off. Hit the reset button on computer.  Move switch position 7 to on. Data bus should now be DB (hex).  Using the examine switch, check the next 31 bytes against the bootstrap program 0000: DB FC AF 6F 67 3C D3 FA 3E 8C D3 F8 DB FC B7 F2 0010: 19 00 DB FB 77 23 C3 OC 00 DB F8 B7 CA 7D 00 76 |
| 15.  | Install remaining components.                                                                                                                                                                                                                                                                                                |
| ( )  | <pre>Install the thirteen 120 ohm 1/2 watt resistors at the following locations: ( ) R1, ( ) R2, ( ) R3, ( ) R4, ( ) R5, ( ) R6, ( ) R7, ( ) R8, ( ) R9, ( ) R10, ( ) R11, ( ) R12, ( ) R19.</pre>                                                                                                                           |
| ( )  | Install the eleven .1 MFD disc ceramic capacitors at the following locations: ( ) Cl1, ( ) Cl2, ( ) Cl3, ( ) Cl4, ( ) Cl5, ( ) Cl6, ( ) Cl7, ( ) Cl8, ( ) Cl9, ( ) C20, ( ) C21.                                                                                                                                             |
| ( )  | <pre>Install the following components: () U528T97 hex buffer IC. () U538T97 hex buffer IC. () U4574LS00 quad 2-input NAND gate IC () R2715 ohm 2 watt resistor (brown, green, black) () R2110K 1/4 watt resistor (brown, black, orange) () R2210K 1/4 watt resistor (brown, black, orange)</pre>                             |

U59--74LS04 Hex inverter IC ( ) U41--74LS123 dual one-shot IC ( ) R18--33 Kohm 1/4 watt resistor (orange, orange, orange) C5--4.7 Mfd 10% Capacitor ( ) U51--74LS123 dual one-shot IC ( ) R17--33 Kohm 1/4 watt resistor (orange, orange, orange) ( ) ( ) C4--.1 mfd Capacitor R13--15 Kohm 1/4 watt resistor (brown, green, orange) ( ) C2--33 mfd capacitor ( ) R30--4.7 Kohm 1/4 watt resistor (yellow, violet, red) ) ) U61--7438 quad 2-input NAND buffer IC U62--7438 quad 2-input NAND buffer IC U63--74LS08 quad 2-input AND gate IC ( ) U40--74LS175 quad latch IC U56--74LS138 3-8 line decoder IC ( ) ( ) U42--7438 quad 2-input NAND buffer IC ( ) C22--390 pf disk ceramic capacitor

1

- 16. 50-Pin Connector
- () Mount the 50-pin connector from the component side of the board at J1. Check that all the pins show through on the solder side.
- () Using the number 2 screws from the rear side of the board and the nuts on the component side, screw the connector down tight.
- () Solder each one of the 50 connector pins on the solder side.

  Make sure that none have been overlooked.

NOTE: The connector position J2 is provided in case you have two drives which do not have a select feature. This may be true of some of the older models, and will require 2 seperate cables and the use of the input multiplexer. Most of the newer drives may be daisy-chained on the same cable.

\* \* \* \* \* \* \*

You should now be all out of components, except for the cable and the 1771 IC. If you have components left over, use the parts list and the assembly diagram to make sure that a properpart has been installed at each position. If so, you may just have extra parts.

Check to see that the following slots on the board are not used:

- ( ) U\$6, ( ) U47, ( ) U48, ( ) U58, ( ) U64--spare IC slots ( ) R34 and ( ) C24--for the spare one-shot ( ) C7 not used.
- ( ) If you have a Z-80 CPU card, read page 7-8 before proceeding.
- ( ) If you have a Processor Technology SOL computer, read page 7-9 before proceeding.

The system of jumper pads on the Tarbell floppy disk interface is designed to allow maximum flexibility in matching the interface to yur floppy disk drive requirements. There are also four spare IC slots that may be used in conjunction with the jumper pads to implement special circuits.

We have worked out the jumper positions for several of the popular drives, and will be doing some more. If you work out your own jumper set-up for a drive that is not listed, or if you find something wrong with the set-ups we have, please write to us and let us know what you did.

If you want to set up your own drive configurations, the functions of the jumper pads are as follows:

- 1. Some drives (see individual listings) require a connector on the end of the 50-line ribbon cable which should only be installed using a special tool. Tarbell Electronics has the connectors and the tool, and can install one on your cable for \$10.
- 2. At the board end of the cable, the connector pins are numbered alternately from 1 to 50 going from left to right. All the odd-numbered ones are grounded, so the signal leads are numbered 2, 4, 6, 8 ... 48, and 50.
- 3. When installing the power supply, use fairly heavy wire (at least 16 gauge), and twist each power line with a ground line. Before plugging in the drive, check the voltages on each pin of the connector with a voltmeter.
- 4. Also, it is a good idea to do a continuity check on each of the interconnections between board and drive before you fire your drive up the first time. Look especially for inadvertently-switched lines and cold solder joints.
- E1,E3 Inputs to 7438 NAND buffer which drives SO\* line to floppy drive. Must both be high to make SO\* line active (low).
- E5,E7 Inputs to 7438 NAND buffer which drives SI\* line to floppy drive. Must both be high to make SI\* line active (low).
- E8,E9 Both come from the output of a one-shot which is triggered by the 1771 step output. These are active high. The repetition rate of these pulses is dependent upon bits 0 and 1 of a type 1 command to the 1771 as shown in table 1 on page 7-2-4.
- E10,E11 These pads are both connected to the pull-up line #2, which has a 1k pull-up resistor to +5 volts.
- E12 This active low line is an inverted version of the DIRC step direction line which comes out of the 1771.

  This line is low for step-in and high for step-out.
- E13 This line is just the inverted version of E12; that is, it is low for step-out and high for step-in.

- This line will produce a positive-going pulse for one computer clock time, when an OUT instruction is given to port XXXXX100 (X's are selected by Dip-switch) and the data sent out from register A in the 8080 has the lower bits 001 (MSB first). This line is used to pulse the SO\* line at a higher rate than the 1771 can do directly. This may be necessary when using a floppy disk drive with a high step rate, such as the PerSci drives.
- E15-E27 Interface to disk lines: See pin function page for details.

  E28 This line is active high when an OUT instruction is given to port XXXXX100 as above, only the data is UU00U010.

  (U means that the corresponding bit has no effect on this line). This line may be used to activate the HLD3 line through E38.
- This line controls which set of lines is selected that come from the floppy disk drive. When E29 is low, the line names ending in a zero (RDYO, INDXO, etc.) are selected; these are marked R1, R3, R5, R7, R9, and R11 on the top right hand side of the board. When E29 is high, the line names ending in a one are selected; these are marked R2, R4, R6, R8, R10, and R12 on the board.
- E30 This pad is connected directly to ground, and may be used to always select the 0 lines, when connected to E29 above.
- This is connected to the least significant bit (Bit 4) of the latch, and may be used to select the lines ending in a 0 or a 1 under software control, when connected to E29 above. This line is set according to bit 4 of the output instruction when the lower bits are 010, and the address is XXXXX100.
- E32 This is a pulsed active low line, similar in operation to that of E14, except the low data bits need to be 000. When connected to E34, it may be used to pulse the RST\* line.
- E33 This line is connected to the ltach bit 3 inverted. It may be used to make RST\* stay high or low, when hooked to E34.
- This is hooked to an input of a NAND gate, the other of which is the internal master reset line. When either of these lines goes low, the RST\* line is activated. The RST\* line can be used either as a reset line for the floppy drive, or it ca be used for a third drive-select line in systems incorporating binary select.
- E35 The active high output line of the spare one-shot in U41. E36 The negative-going trigger input of the spare one-shot.
- E37 The positive-going trigger input of the spare one-shot.
- E38,E39 These are the two inputs to the 7438 buffer gate that activates the HLD3 line going to the drive. If E38 is hooked to E28, and E39 is hooked to E53, then HLD3 is treated the same way as HLD0, HLD1, and HLD2. These four lines can then be used to select four drives in a radial-select fashion. As an alternative, E39 may be connected to pull-up E40, and E38 can be connected to E52 (latch Q2\*) or E42 (latch Q1\*) and used for another disk control line.

- E40 Connected to pull-up line #3, 1K to +5 volts.
- An input to a 1-4 decoder, normally connected to E52. E41
- E42 Connected to latch bit 1 inverted.
- E43 Goes directly to the ready line (an input) on the 1771. The 1771 will not perform a read or write operation without this line being active high. Connect to E44 if your drive has a ready line, and E45 if it doesn't.
- E44 Comes from the selected disk drive's ready line, after which it is inverted to make it in proper phase for E43.
- E45 Is the output of a one-shot which is triggered by the selected drive's INDX (index) line. This can be used as a ready line, in case your particular drive doesn't have one. The one-shot, being of the retriggerable type, stays high as soon as the index pulses come close enough together to indicate that eh disk is turning properly.
- E46 This line comes from pin 3 of the computer bus, which is called PRDY.
- This line comes from pin 72 of the computer bus, which E47 is called XRDY.
- E48 This line is used to stall the machine in the wait state for operations that must respond quickly, such as read and write. It is also activated for each read operation so that some time can be allowed for the output fo the 1771 to settle. It should be connected to E47 on IMSAI computers, and to E46 on ALTAIR computers -- at least the ones we've seen. If you want to double check your machine, look at the schematic of the front panel on your computer. Either pin 3 (E46) or pin 72 (E47) will be connected to the output of a gate. Connect E48 to the other one. Also note that some other memory and I/O boards use one or both of these lines to introduce WAIT In some cases, a design error was made on the board such that the tri-state circuit driving the PRDY or XRDY line is activated at a time during which the the Tarbell FDI board is also using this line. This may cause improper operation, and may be corrected in most cases by just disconnecting this line on the offending board, since they are only used on slow memory boards. When E49 is connected to E50 (ground), TG43\* going to E49 drive is active low when TG43 coming from 1771 is active
- If the drive requires TG43\* to be the opposite polarity, don't install this jumper.
- E50 Ground for possible connection to E49.
- E51 HLD (head-load) line buffered from 1771 pin 28. line is active (high) when the 1771 decides that the head should be loaded against the disk. See the 1771 data sheet for further detail on the operation of this line.
- E52 Latch bit 2 inverted, usually connected to E41.
- E5.3 Common input on 7438 buffer gates which drive HLD lines is usually connected to either E51 or E40. to disk;
- E54 Latch bit 2 non-inverted; may be connected to E55.
- E5.5 Input to gate which drives E23. Connected to E54 or E51.
- NOTE: Be sure to hook up E48; either to E46 or E47. See details above.

- () Make a one-one connection from the 50-pin connector(s) on the top of the PC board (J1 and J2), through the 50-pin ribbon cable(s), to the connector(s) for your drive(s), except for pins 41 and 42. Since there are no pins 51 and 52 on the cable, pins 41 and 42 of the cable should be connected to pins 51 and 52 on the drive connector.
- ( ) See the general jumper set-up instructions for information about:
  - 1) pin numbering at J1;
  - power supply connections;
  - 3) pre-operational checks;
  - 4) whether to hook E48 to E46 or E47.

```
Following are the jumpers to install for a 1 or 2-drive system:
        PAD
                NAME
                         TO
                                 NAME
( )
        E48
                                 See page 4-1-3.
( )
        R11
                RDAT0*
                         J1-20
                                 Read data (composite) drive 0
 )
        R12
                RDAT1*
                         J2-20
                                 Read data (composite) drive 1
        E19
( )
                HLD0*
                         J1-26
                                 Head load drive 0
( )
        E20
                HLD1*
                         J2-26
                                 Head load drive 1
( )
        R7
                         J1-28
                                 Track 0 drive 0
                TR00*
                                 Track 0 drive 1
 )
        R8
                TR01*
                         J2-28
( )
        R3
                INDX0*
                         J1-32 Index drive 0
                         J2-32 Index drive 1
J1-36 Low current drive 0
(
 )
        R4
                INDX1*
        E18
  )
                TG43*
 )
        E18
                TG43*
                         J2-36 Low current drive 1
( )
        R9
                WRFLTO* J1-40 Write fault drive 0
 )
        R10
                WRFLT1* J2-40 Write fault drive 1
(
( )
        E22
                SO*
                         J1-44 Step out drive 0
( )
        E22
                SO*
                         J2-44
                                 Step out drive 1
                         J1-46
(
 )
        E21
                SI*
                                 Step in drive 0
 )
        E21
                SI*
                                 Step in drive 1
                         J2-46
        E16
 )
                WG*
                         J1-48
                                 Write enable drive 0
(
( )
        E16
                WG*
                         J2-48
                                 Write enable drive 1
NOTE:
       Each write enable line should be anded with the Head load
       line before going to the drive, or the write fault unhooked.
        E15
( )
                WD*
                         J1-50
                                 Write data drive 0
( )
        E15
                WD*
                         J2-50
                                 Write data drive 1
 )
        E26
                RST*
                         J1-42
                                 Write fault reset drive 0
( )
        E26
                RST*
                         J2-42
                                 Write fault reset drive 1
( )
        E13
                         E5
                                 High for step-in
( )
        E12
                         E1
                                 High for step-out
 )
        E9
                         E3
                                 High for any step
 )
        E8
                         E7
                                 High for any step
( )
        E49
                         E50
                                 TG43* goes low for low current
 )
        E43
                         E45
                                 There is no ready line
        E31
  )
                         E29
                                 Use the input multiplexer
 )
        E32
                         E34
                                 Software write-fault reset
(
 )
        E52
                         E41
                                 Maybe more drives someday
(
 )
        E51
                         E53
                                 Head-load hook-up
       Since the heads on two drives will move together on this
Note:
```

system, the CBIOS in CP/M should have DUAL EQU TRUE.

### POWER HOOK-UP

<sup>+5</sup> Volts DC - pins 2&4 on both drives

<sup>-5</sup> Volts DC - pin 6 on both drives

<sup>+24</sup> Volts DC - pins 12 & 14 on both drives

### JUMPER SET-UP FOR INNOVEX 210/220

() Make a one-one connection from J1, the 50-pin connector on the left hand side of the PC board, through the 50-pin ribbon cable, to the connector for your drive. If you have more than one drive, the cable can be connected to all of them in parallel (daisy chained). All but the last drive in the chain should have their terminating resistors removed. The 4 select lines should be wired one to a drive.

See the general jumper set-up instructions in section 4-1 for information about:
() the special connector at the drive end
() pin numbering at J1
() power connections
() pre-operational checks

Following are the jumpers to install:

() where to install jumper at E48

|                                               | PAD                                                                          | NAME                                                                   | TO                                                                                 | Drive                                                                                      | NAME                                                                                                                                                                                                                          |
|-----------------------------------------------|------------------------------------------------------------------------------|------------------------------------------------------------------------|------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ( ) ( ) ( ) ( ) ( ) ( ) ( ) ( ) ( ) ( )       | E18 E23 R3 R1 E19 E20 E17 E25 E22 E21 E15 E16 R7 R5 R11 R9 E26               | HLD1*<br>HLD2*<br>HLD3*<br>SO*<br>SI*<br>WD*<br>WG*<br>TR00*<br>WRPT0* | J1-46                                                                              | L21<br>L18<br>L5<br>L8<br>L13<br>L13<br>L13<br>L15<br>L6<br>L10<br>L7<br>L12<br>L16<br>L17 | Current select Head Load Index Ready Drive select on drive 0 Drive select on drive 1 Drive select on drive 2 Drive select on drive 3 Direction Step Write data Write gate Track zero Write protect Raw data File unsafe Reset |
| ( )<br>( )<br>( )<br>( )<br>( )<br>( )<br>( ) | E1<br>E3<br>E5<br>E7<br>E29<br>E43<br>E38<br>E51<br>E53<br>E39<br>E52<br>E48 |                                                                        | E13<br>E11<br>E10<br>E9<br>E30<br>E44<br>E28<br>E55<br>E40<br>E40<br>E41<br>E46 or | E <b>4</b> 7                                                                               | Direction hook-up Pull-up Pull-up Step hook-up Use only 0 half of MUX. Get ready signal from drive Select Drive 3 hook-up Head load to DS0 line Pull-up Pull-up Activates 1-4 decoder. See page 4-1-3                         |

### DC POWER CONNECTIONS TO DRIVE AC POWER CONNECTIONS TO DRIVE

| ( | ) | +24 VOLTS DC   | R2,L2 (       | )  | 117 VOLTS AC | PO4-3 |
|---|---|----------------|---------------|----|--------------|-------|
| ( | ) | 24 VOLT RETURN | R3,L3 (       | .) | FRAME GROUND | PO4-2 |
| ( | ) | -5 VOLTS DC    | R20,L20 (     | )  | 117 VOLTS AC | PO4-1 |
| ( | ) | +5 VOLTS DC    | Rll,Lll       |    |              |       |
| ( | ) | LOGIC GROUND   | R1,L1,R22,L22 |    |              |       |

NOTE: Don't confuse the R numbers directly above with resistor numbers on the interface board. These R's are drive connector pins.

Be sure all return lines are connected together at the power supply end.

RAW DATA OPTION

### JUMPER AREA





- () Make a one-one connection from the 50-pin connector on the left hand side of the PC Board (J1), through the 50-pin ribbon cable, to the connector for your drive(s).
- () If you have more than one drive, they should all be connected in parallel (daisy-chained). Each drive has a select jumper on it, which connects it's internal select logic to one of the four select lines. At least one drive should be selected as drive 0. Any other drives should each be selected to numbers 1 through 3. The terminating resistors should be removed from all drives except the last one on the daisy-chain.
- () See the general jumper set-up instructions for information about:
  - 1) the special connector at the drive end
  - 2) pin numbering at J1
  - 3) power supply connections
  - 4) pre-operational checks
  - 5) where to connect the jumper at E48
- () Z-80 users see page 7-8, SOL users see page 7-9.

Following are the jumpers to install for 1 to 4 drives:

|                                                      | PAD                                                                                               | NAME                                                              | TO                                                                                 | DESCRIPTION                                                                                                                                                                    |
|------------------------------------------------------|---------------------------------------------------------------------------------------------------|-------------------------------------------------------------------|------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ( )<br>( )<br>( )<br>( )<br>( )<br>( )<br>( )<br>( ) | E18<br>E23<br>R3<br>R1<br>E19<br>E20<br>E17<br>E25<br>E22<br>E21<br>E15<br>E16<br>R7<br>R5<br>R11 | INDX0* RDY0* HLD0* HLD1* HLD2* HLD3* SO* SI* WD* WG* TR00* WRPT0* | J1-32<br>J1-34<br>J1-36<br>J1-38<br>J1-40<br>J1-42<br>J1-44                        | Index Ready Drive select 0 Drive select 1 Drive select 2 Drive select 3 Direction Step Write data Write gate Track zero                                                        |
| ( )<br>( )<br>( )<br>( )<br>( )<br>( )<br>( )        | E1<br>E3<br>E5<br>E7<br>E29<br>E39<br>E28<br>E41<br>E51<br>E53<br>E53                             |                                                                   | E13<br>E11<br>E10<br>E8<br>E30<br>E40<br>E38<br>E52<br>E55<br>E44<br>E40<br>E46 or | Direction polarity Pull-up Pull-up Normal Step line Always select 0 lines Pull-up For HLD3 Use all of decoder For head-load Use drive's ready line Pull-up E47 See page 4-1-3. |

### (Innovex 410 -- continued)

If more than one drive is used, each drive should have its select jumper changed (on the drive) so that each drive uses a different select line. Also only the last drive in the daisy chain should have the terminating resistors left in. Those on all other drives should be removed.

| DC Power Requirements                       | AC Power Requirements                    |  |  |  |
|---------------------------------------------|------------------------------------------|--|--|--|
| Pin 1 +24 Volts DC<br>Pin 2 +24 Volt return | Pin 1 110 Volts AC<br>Pin 2 Frame ground |  |  |  |
| Pin 3 -5 Volt return                        | Pin 3 110 Volts return                   |  |  |  |
| Pin 4 -5 Volts DC                           |                                          |  |  |  |
| Pin 5 +5 Volts DC                           |                                          |  |  |  |
| Pin 6 +5 Volts return                       |                                          |  |  |  |

Be sure all return lines are connected together at the power supply end. JUMPER SET-UP FOR SIEMENS FDD 100-8 (formerly GSI-110) and for SIEMENS FDD 220-8 (double-sided drive)

- () Make a one-one connection from the 50-pin connector on the left hand side of the PC Board (J1), through the 50-pin ribbon cable, to the connector for your drive(s).
- () If you have more than one drive, they should all be connected in parallel (daisy-chained). Each drive has a select jumper on it, which connects it's internal select logic to one of the four select lines. At least one drive should be selected as drive 0. Any other drives should each be selected to numbers 1 through 3. The terminating resistors should be removed from all drives except the last one on the daisy-chain.
- () See the general jumper set-up instructions for information about:
  - 1) the special connector at the drive end
  - 2) pin numbering at J1
  - 3) power supply connections
  - 4) pre-operational checks
  - 5) where to connect the jumper at E48
- ( ) Z-80 users see page 7-8, SOL users see page 7-9.

Following are the jumpers to install for 1 to 4 drives:

|   |    | PAD | NAME    | TO    | DESCRIPTION               |
|---|----|-----|---------|-------|---------------------------|
| ( | )  | E26 | RST*    | J1-14 | Side select               |
| ( | )  | E18 | TG43*   | J1-16 |                           |
| 7 | Ś  | E18 | TG43*   | J1-2  | Current select            |
| 7 | ί. | E23 | DS0*    | J1-18 |                           |
| 7 | ,  | R3  | INDX0*  | J1-20 |                           |
| ( | )  | R1  | RDY0*   | J1-22 |                           |
| 7 | ′  | E19 | HLDO*   |       | <b>-</b>                  |
| > | ,  | E20 | HLD1*   |       |                           |
|   | ,  | E17 |         | J1-30 |                           |
| ( | ,  | E17 | HLD3*   | J1-30 |                           |
|   | ′  | E23 | SO*     | J1-34 |                           |
| > | ,  | E21 | SI*     | J1-34 |                           |
|   | ,  | E15 | WD*     | J1-38 | ~                         |
| ( | ,  | E16 | WG*     | J1-30 |                           |
|   | )  | R7  | TR00*   |       |                           |
|   | ,  | R5  | WRPTO*  |       |                           |
| , | ,  | R11 | RDATO*  |       | Write protect<br>Raw data |
| ( | ,  | E1  | RDATO " | E13   |                           |
| ( | ,  |     |         |       | Direction polarity        |
| , | ,  | E3  |         | E11   | Pull-up                   |
| > | ,  | E5  |         | E10   | Pull-up                   |
| ( | )  | E7  |         | E8    | Normal Step line          |
| ( | ,  | E29 |         | E30   | Always select 0 lines     |
| , | )  | E39 |         | E40   | Pull-up                   |
| ( | )  | E28 |         | E38   | For HLD3                  |
| ( | )  | E41 |         | E52   | Use all of decoder        |
| ( | ,  | E49 |         | E50   | current select polarity   |
| , | )  | E51 |         | E55   | For head-load             |
| ( | )  | E43 |         | E44   | Use drive's ready line    |
| ( | )  | E53 |         | E40   | Pull-up                   |
| ( | )  | E48 |         |       | E47 See page 4-1-3.       |
| ( | )  | E33 |         | E34   | Latch bit 3               |

### GSI 110 DRIVE CONNECTIONS

DC Power Requirements at P4

| Pin No. | DC Voltage  | Tolerance | Current    | Max. Ripple |
|---------|-------------|-----------|------------|-------------|
| 1       | +24 VDC     | 1.2 VDC   | 1.7 A. Max | 100 mv      |
| 2       | +24V return |           |            |             |
| 3       | -5V return  |           |            |             |
| 4       | -5 VDC      | .25 VDC   | .07 A. Max | 50 mv       |
| 5       | +5 VDC      | .25 VDC   | 1.0 A. Max | 50 mv       |
| 6       | +5V return  |           |            |             |

### AC Power Requirements at P5

- Pin 1 90-127 VAC 60 Hz @ .5 Amps
- Pin 2 Frame Ground
- Pin 3 90-127 V Return

Be sure all return lines are connected together at the power supply end, and all connections are solid.

Jumpers and/or plugs on Drive Electronics Board

Drive A Drive B Drive C Drive D

Radial Sel 0 Radial Sel 1 Radial Sel 2 Radial Sel 3

NOTE: Radial Sel 0 is sometimes etched on PC board, and if so, will have to be cut for drives other than drive A.

The terminating resistor network in the socket at location 3D should be removed from all but the last drive on the cable. It is most convenient to make this drive A.

```
See the general jumpe set-up section (4-1) for information about:

() the special connector at the drive end of the 50-pin cable

() pin numbering at 50-pin header connector J1

() power supply connections

() pre-operational checks

() where to connect E48
```

() Make a one-one connection from the 50-pin connector on the left hand side of the PC board (J1), through the 50-pin ribbon cable, to the connector for your drive. Make sure that pin 1 on J1 matches up with pin 1 on your drive.

Following are the jumpers to install:

```
PAD
                NAME
                        TO
                        J1-18
( )
        E19
                HLD0*
                                Drive Select 2 Left
                        J1-4
                                Drive Select 2 Right
( )
        E20
                HLD1*
                        J1-20
( )
        R3
                INDX0*
                                Index 0
                        J1-8
                                Index 1
( )
        R4
                INDX1*
        R1
                        J1-22
                                Ready 0
( )
                RDY0*
        R2
                RDY1*
                        J1-6
                                Ready 1
( )
        E23
                        J1-28
                                Drive Select 1 Right
                DS0*
( )
Note: E23 is at top of board, not in middle. See page 7-3.
       E24
                DS1*
                        J1-2
( )
( )
        E25
                HLD3*
                        J1-26
                                Drive Select 1 Left
( )
                        J1-12
        E26
                RST*
                                Restore
        E27
                SCMP*
                        J1-10 Seek Complete
( )
( )
       E22
                SO*
                        J1-34
                                Direction Select
 )
        E21
                SI*
                        J1-36
                                Step
( )
        E15
                WD*
                        J1-38
                                Write Data
( )
        E16
                WG*
                        J1-40
                                Write Gate
  )
                TR00*
                        J1-42
                                Track Zero
        R7
                TR01*
                        J1-42
                                Track Zero (Remove or Disconnect Res. R8)
( )
        R8
( )
        R5
                WRPT0*
                        J1-44
                                Write Protect 0
( )
                        J1-30
                                Write Protect 1
        R6
                WRPT1*
                        J1-46 Read Data
( )
        R11
                RDATO*
                                Read Data (Remove or Disconnect Res. R12)
( )
        R12
                RDAT1*
                        J1-46
( )
        E30
                GND
                        J1-24
                                Spindle Motor Enable
        E48
                        E46 or E47 See page 4-1-3.
( )
                                Make Direction Select = 1771- Direction
        E1
                        E13
( )
        E3
                        E11
                                Pull-up for U61 pin 12
( )
                                Pull-up for U61 pin 10
( )
        E5
                        E10
                                Make PerSci Step = 1771 Step Stretched.
( )
        E7
                        E8
       After initial tests, connect E7 to E14 instead of to E8. This
will allow it to work with the Fast-Seek CP/M which is now distributed.
                                 Use On-Board Multiplexer for 2 Sides.
( )
        E29
                        E31
( )
        E33
                        E34
                                 Use Bit 3 of Ltch for PerSci Restore.
( )
        E39
                        E40
                                Pull-up for U42 pin 10.
                                Pull-up so HLDO and HLD1 alternate
        E41
( )
                        E40
        E52
                                Use Q2* of latch for drive select 1 left.
( )
                        E38
( )
        E43
                        E44
                                 Ready lines from PerSci to 1771 Ready.
        E51
                        E53
                                 Connect Drivers to Head-load line.
( )
                                Use DS0 on Bit 2 of latch.
( )
        E54
                        E55
```

### ADDITIONAL PERSCI 270/277 NOTES

### Power Supply Connections

| Pin No. | Signal             | Notes                                        |
|---------|--------------------|----------------------------------------------|
| 1       | Chassis Gnd        | Should be hooked to house ground (3rd prong) |
| 2       | +5V DC @ 2.2 A.    | Connect to +5 volts on CP206 Power Supply    |
| 3       | +7-10V UNREG @ 2A. | Connect to small 5 volt supply and turn      |
|         |                    | that supply all the way up.                  |
| 4       | KEY                |                                              |
| 5       | +24V DC @ 1.2A.    | Connect to +24 volts on CP206 power supply   |
| 6       | GND                | Connect to other grounds including chassis   |
| 7       | GND                | Same as above                                |
| 8       | GND                | Same as above                                |
| 9       | GND                | Same as above                                |
| 10      | -5V DC @ .2A.      | Connect to -5 volts on CP206 supply          |

When installing the power cable, use fairly heavy wire, and twist each power line with a ground line. Before plugging into the drive, check the voltages on each pin of the connector with a voltmeter. Be sure all return lines are connected together at the power supply end.

Conversion of the PerSci 277 to 270 Configuration

The PerSci 277 drive select lines are the same as the head-load lines. A disk has to be selected, however, to receive a ready signal from it. Thus, a head has to be loaded before it is possible to determine whether a disk is ready. We feel that the 270 configuration is better, which seperates the select and head load functions.

These are the jumpers that should be on the PerSci 270 main board for rev G or lower:

| A-B   | D-E | G-F   | H <b>-</b> J | MP    | AY-AT | R-S   | AJ-AH |
|-------|-----|-------|--------------|-------|-------|-------|-------|
| AX-AB | X-W | AE-AD | BC-BA        | AM-AL | W1    | BE-BD |       |

These are the jumpers that should be on the PerSci 270 main board for rev H or higher:

| A-B   | D-E | <b>G-</b> F | H-J   | M-P   | AY-AT | R-S   | AJ-AH |
|-------|-----|-------------|-------|-------|-------|-------|-------|
| AC-AB | X-W | AE-AD       | BB-BA | AM-AL | W1    | BE-BD | BK-BM |
| AV-AW |     |             |       |       |       |       |       |

If you have only one Dual PerSci, you should have nothing in the socket at U11.

If you have two Dual PerSci's, put the following jumpers onto two header plugs, and plug them into U11 on both drives:

| on | drive  | 1   | (A&B) | 10  | to  | 5 |
|----|--------|-----|-------|-----|-----|---|
| on | drive  | 2   | (C&D) | 12  | to  | 3 |
| on | both o | dri | lves  | 7 t | 0.5 | 3 |

- () Make a one-one connection from the 50-pin connector on the left hand side of the PC Board (J1), through the 50-pin ribbon cable, to the connector for your drive(s).
- () If you have more than one drive, they should all be connected in parallel (daisy-chained). Each drive has a select jumper on it, which connects it's internal select logic to one of the four select lines. At least one drive should be selected as drive 0. Any other drives should each be selected to numbers 1 through 3. The terminating resistors should be removed from all drives except the last one on the daisy-chain.
- () See the general jumper set-up instructions for information about:
  - 1) the special connector at the drive end
  - 2) pin numbering at J1

NAME

PAD

- 3) power supply connections
- 4) pre-operational checks
- 5) where to connect the jumper at E48

TO

() Z-80 users see page 7-8, SOL users see page 7-9.

Following are the jumpers to install for 1 to 4 drives:

DESCRIPTION

| ((((((((((((((((((((((((((((((((((((((( | ) | E23<br>R3<br>R1<br>E19<br>E20<br>E17<br>E25<br>E22<br>E21<br>E15<br>E16<br>R7<br>R5<br>R11 | WD*<br>WG*<br>TR00* | J1-32<br>J1-34<br>J1-36<br>J1-38<br>J1-40<br>J1-42<br>J1-44                        | Drive select 0 Drive select 1 Drive select 2 Drive select 3 Direction Step Write data Write gate Track zero                                                                    |
|-----------------------------------------|---|--------------------------------------------------------------------------------------------|---------------------|------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ((((((((((((((((((((((((((((((((((((((( | ) | E1<br>E3<br>E5<br>E7<br>E29<br>E39<br>E28<br>E41<br>E51<br>E43<br>E53<br>E48               |                     | E13<br>E11<br>E10<br>E8<br>E30<br>E40<br>E38<br>E52<br>E55<br>E44<br>E40<br>E46 or | Direction polarity Pull-up Pull-up Normal Step line Always select 0 lines Pull-up For HLD3 Use all of decoder For head-load Use drive's ready line Pull-up E47 See page 4-1-3. |

### DC POWER REQUIREMENTS

### AC POWER REQUIREMENTS

| Pin | 1 | +24 volts DC    | Pin 1 | 110 volts AC     |
|-----|---|-----------------|-------|------------------|
| Pin | 2 | +24 volt return | Pin 2 | frame ground     |
| Pin | 3 | -5 volt return  | Pin 3 | 110 volts return |
| Pin | 4 | -5 volts DC     |       |                  |
| Pin | 5 | +5 volts DC     |       |                  |
| Pin | 6 | +5 volts return |       |                  |

Be sure all return lines are connected solidly together at the power supply end.

The following Jumpers should be installed on the Drive(s):

| Drive 0 (A)                                             | Drive 1 (B)           | Drive 2 (C)           | Drive 3 (D)       |
|---------------------------------------------------------|-----------------------|-----------------------|-------------------|
| A<br>B<br>C<br>Y<br>T2<br>DS<br>800 (NOT 801)<br>L • [] | A B C Y T2 DS 800 L • | A B C Y T2 DS 800 L • | A B C Y T2 DS 800 |
| DS1<br>T3<br>T4<br>T5<br>T6                             | DS2                   | DS3                   | DS4               |

NOTE: Some drives may come with jumper X installed. Be sure to remove it if it is.

```
See the general jumper set-up section (4-1) for information about:

() the special connector at the drive end of the 50-pin cable

() pin numbering at 50-pin header connector J1

() power supply connections

() pre-operational checks

() where to connect E48

() Make a one-one connection from the 50-pin connector on the
```

left hand side of the PC board (J1), through the 50-pin connector on the left hand side of the PC board (J1), through the 50-pin ribbon cable, to the connector for your drive. Make sure that pin 1 on J1 matches up with pin 1 on your drive.

Following are the jumpers to install:

|       | PAD        | NAME T     | ТО            | NAME                                      |
|-------|------------|------------|---------------|-------------------------------------------|
| ( )   | E19        | HLD0*      | J1-18         | Drive Select 2 Left                       |
| ( )   | E20        | HLD1*      | J1-4          | Drive Select 2 Right                      |
| ( )   | R3         | INDX0*     | J1-20         | Index 0                                   |
| ( )   | R4         | INDX1*     | J1-8          | Index 1                                   |
| ( )   | R1         | RDY0*      | J1-22         | Ready 0                                   |
| ( )   | R2         | RDY1*      | J1 <b>-</b> 6 | Ready 1                                   |
| ( )   | E23        | DS0*       | J1-28         | Drive Select 1 Right                      |
|       | E23 is at  | top of bo  | oard, no      | ot in middle. See page 7-3.               |
| ( )   | E24        | DS1*       | J1-2          |                                           |
| ( )   | E25        | HLD3*      | J1-26         | Drive Select 1 Left                       |
| ( )   | E26        | RST*       | J1-12         | Restore                                   |
| ( )   | E27        | SCMP*      | J1-10         | Seek Complete                             |
| ( )   | E22        | SO*        | J1-34         | Direction Select                          |
| ( )   | E21        | SI*        | J1-36         | Step                                      |
| ( )   | E15        | WD*        | J1-38         | Write Data                                |
| ( )   | E16        | WG*        | J1-40         | Write Gate                                |
| ( )   | R7         | TR00*      | J1-42         | Track Zero                                |
| ( )   | R8         | TR01*      | J1-42         | Track Zero (Remove or Disconnect Res. R8) |
| ( )   | R5         | WRPTO*     | J1-44         | Write Protect 0                           |
| ( )   | R6         | WRPT1*     | J1-30         | Write Protect 1                           |
| ( )   | R11        | RDATO*     |               |                                           |
| ( )   | R12        | RDAT1*     |               |                                           |
| ( )   | E30        | GND        | J1-24         | Spindle Motor Enable                      |
| ( )   | E48        | 1          | E46 or E      | E47 See page 4-1-3.                       |
| ( )   | E1         |            | E13           | Make Direction Select = 1771 Direction    |
| ( )   | E3         | 1          | E11           | Pull-up for U61 pin 12                    |
| ( )   | E5         | ]          | E10           | Pull-up for U61 pin 10                    |
| ( )   | E7         | ]          | E8            | Make PerSci Step = 1771 Step Stretched.   |
| Note: | After in   | itial test | ts, conr      | nect E7 to E14 instead of to E8. This     |
| will  | allow it t | o work wi  | th the I      | Fast-Seek CP/M which is now distributed.  |
| ( )   | E29        | ]          | E31           | Use On-Board Multiplexer for 2 Sides.     |
| ( )   | E33        |            | E34           | Use Bit 3 of Ltch for PerSci Restore.     |
| ( )   | E39        |            | E40           | Pull-up for U42 pin 10.                   |
| ( )   | E41        |            | E40           | Pull-up so HLDO and HLD1 alternate        |
| ( )   | E52        |            | E38           | Use Q2* of latch for drive select 1 left. |
| ( )   | E43        |            | E44           | Ready lines from PerSci to 1771 Ready.    |
| ( )   | E51        |            | E53           | Connect Drivers to Head-load line.        |
| ( )   | E54        |            | E55           | Use DSO on Bit 2 of latch.                |

### JUMPER SET-UP FOR WANGCO/ORBIS 76

Notes: due to grounding of enven numbered pins:

- () One end of the 50 pin conductor cable must be reversed. This may be accomplished by folding the cable or reversing the header socket when installing it.
- () The wires that connect to Wangco/Orbis pin numbers 40-50 must be cut to prevent shorting the D.C. power supply lines directly to ground.
- () Due to an interlock system in the Wangco/Orbis, a disk must be inserted and the door closed before any tests or system runs can be made.

Following are the jumpers to install on the Tarbell FDI board:

|                                        | PAD                                                                                              | NAME                                                           | TO                                                                                                                                  | Description                                                                                                                                                                                                     |
|----------------------------------------|--------------------------------------------------------------------------------------------------|----------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ()<br>()<br>()<br>()<br>()<br>()<br>() | E15<br>E16<br>E18<br>E19<br>E21<br>E22<br>E23<br>E24<br>E26<br>R1<br>R3<br>R5<br>R7<br>R9<br>R11 | HLD0* SI* SO* DSO/SME* DSI/DSL* RST* RDY0* INDX0* WRPT0* TR00* | J1-38<br>J1-34<br>J1-24<br>J1-18<br>J1-22<br>J1-20<br>J1-50<br>J1-12<br>J1-44<br>J1-40<br>J1-30<br>J1-28<br>J1-28<br>J1-32<br>J1-46 | Head Load 0 Step in Step out Disk select 0 Disk select 1 Restore Ready 0 Index 0 Write protect Track 00 Write Fault                                                                                             |
| ( )<br>( )<br>( )<br>( )<br>( )<br>( ) | E1<br>E3<br>E5<br>E7<br>E29<br>E43<br>E49<br>E53<br>E41<br>E28<br>E38<br>E48                     |                                                                | E13<br>E11<br>E10<br>E8<br>E30<br>E44<br>E50<br>E51<br>E52<br>E39<br>E40<br>E55                                                     | Direction select Pull up U61 pin 12 Pull up U41 pin 10 Normal Step line Always select 0 lines Use drive's ready line Current select polarity Connect Head-load into decoder Use all of decoder For HLD3 Pull-up |

### WANGCO/ORBIS CONNECTONS

### Note:

Not all of the jumper pads are silk screened on the board. Use the schematic to help you locate them.

The following drawings will help you locate the most difficult pads.



The positive to negative pin numbering can be accomplished by:

1) Installing a header socket reversed (neatest) or 2) Folding the cable,

# WANGCO/ORBIS TO TARBELL BUS

| Wangco/Orbis     |            | <u>Tarbell</u>                   |
|------------------|------------|----------------------------------|
| Data Address A   | 1          | 50 Disk Select O                 |
| Кеу              | 3          | 48 N/C                           |
| Read Data        | 5          | 46 Read Data O                   |
| Ready            | 7          | 44 Ready O                       |
| Sector           | 9          | 42 N/C                           |
| Index            | 11         | 40 Index 0                       |
| Write Data       | 13         | 38 Write Data                    |
| Reserved         | 15         | 36 N/C                           |
| Write Gate       | 17         | 34 Jumper to No. 30              |
| File Unsafe      | 19         | 32 Write Fault O                 |
| Write Enable     | 21         | 30 Write Gate                    |
| Track 0 0        | 23         | 28 Track 0 0                     |
| Unsafe Reset     | 25         | 26 Restore                       |
| Low Current      | 27         | 24 Track > 43                    |
| Step             | 29         | 22 Step In                       |
| In (direction)   | 31         | 20 Step Out                      |
| Load Head        | 3 <b>3</b> | 18 Head Load O                   |
| Separate Clock   | 35         | 16 N/C                           |
| Separate Data    | 37         | 14 N/C                           |
| Drive Address B  | 39         | 12 Disk Select 1                 |
|                  | 41         | 10                               |
| D.C. Power Lines | 43         | 8                                |
|                  | 45         | 6 N/C Cut appropriate            |
|                  | 47         | wires on the 50 conductor ribbor |
|                  | 49         | cable.                           |

# JUMPER SET-UP FOR PERTEC FD511 \*FOR DUAL DRIVES

Since the Pertec FD511 can be Daisy chained up to 4 drives, connect on one end of a 50-pin ribbon cable one or two standard 3M connectors alow enough space for drives to be about 1 inch or more apart. On the other end of the 50-pin cable a connector with individual pins has to be used because all the odd numbered pins are ground on the interface board. Use a 50-pin connector such as made by EECO part #H-4920, and connect as follows. This connector has individual pins.

|               | Interi        |                           |                                  | ble                                                                             | Discription                   |
|---------------|---------------|---------------------------|----------------------------------|---------------------------------------------------------------------------------|-------------------------------|
| PAD           | NAME          | J1                        | WIRE NO.                         | TO P1                                                                           | NAME                          |
| E25           | DSO           | 2                         | 1                                | 2                                                                               | Select Drive O                |
| *E24          | DS1           | 4                         | 2                                | 4                                                                               | Select Drive 1                |
| 7740          | GND           | 3<br>6                    | 4                                | 3                                                                               | GND                           |
| E19           | HLDO          | 6                         | 6<br>7                           | 6                                                                               | Engages Head on Drive O       |
| *E20          | HLD1          | 8                         | 7                                | 8                                                                               | Engages Head on Drive 1       |
| FAC           | GND           | 11                        | 10                               | 11                                                                              | GND                           |
| E16           | WG            | 14                        | 11                               | 14                                                                              | Write Gate Enable             |
| EAO           | GND           | 13                        | 12                               | 13                                                                              | GND                           |
| E18           | TG43<br>GND   | 16                        | 15<br>16                         | 16                                                                              | Track is 44T076               |
| E15           | WD            | 15<br>18                  | 10                               | 15<br>18                                                                        | GND<br>Write Data             |
| E 15          | GND           | 17                        | 17<br>18                         | 10                                                                              | GND                           |
| E22           | so            | 20                        | 19                               | 17<br>20                                                                        | Direction                     |
| منا منافعات   | GND           |                           | 20                               | 10                                                                              | GND                           |
| E21           | <b>S1</b>     | 19<br>22                  | 21                               | 19<br>22<br>21                                                                  | Step                          |
|               | GND           | 21                        | 21<br>22                         | 21                                                                              | GND                           |
| R11           | RDATO         | 30                        | 29                               | 30                                                                              | Read Data Drive O+1           |
|               | GND           | 30<br>29                  | 29<br>30<br>29<br>32<br>46       | 29                                                                              | GND                           |
| *R12          | RDAT1         | 30                        | 29 1                             | 30                                                                              | Remove R12                    |
| R7            | TROO          | 34                        | 32                               | 34                                                                              | Track O Drive O+1             |
|               | GND           | 35                        | 46                               | 35                                                                              | GND                           |
| *R8           | TRO1          | 34                        | 32                               | 34                                                                              | Remove R8                     |
| R5            | WRPTO         | 36                        | 33                               | 36                                                                              | Write Protect Drive O+1       |
|               | GND           | 37                        | 32<br>33<br>34<br>33<br>31<br>46 | 37                                                                              | GND                           |
| *R6           | WRPT1         | 36                        | 33                               | 36                                                                              | Remove R6                     |
| R1            | RDYO          | 32                        | 31                               | 32                                                                              | Selected and Ready Drive O+1  |
| ****          | GND           | 30454676232<br>3333333333 | 46                               | 30<br>30<br>30<br>30<br>30<br>30<br>30<br>30<br>30<br>30<br>30<br>30<br>30<br>3 | GND                           |
| *R2           | RDY1          | 32                        | 31<br>45                         | 32                                                                              | Remove R2                     |
| R3            | INDXO         | 46                        | 45                               | 46                                                                              | Index Mark Detected Drive 1+2 |
| *R4           | GND           | 45                        | 46                               | 45                                                                              | GND<br>Bernaria P/I           |
| E27           | INDX1<br>SCMP | 46<br>40                  | 45                               | 46<br>40                                                                        | Remove R4                     |
| E/ /          | GND           | 41                        | 41<br>40                         | 40                                                                              | Seek Complete<br>  GND        |
| see note u46. |               | 38                        | 75<br>75                         | 38                                                                              | Door Lock Enable              |
| 1000 400      | GND           | 39                        | 35<br>34                         | 39                                                                              | GND                           |

Add: To u46

1 3

Note for one drive connect to E19 instead of u46 Pin 3

Note u46.3

### JUMPERS

|                          |       | Discription                          |
|--------------------------|-------|--------------------------------------|
| 13/                      | E13   | Make Direction Select                |
| <b>E</b> 3               | E11   | Pull-Up for U61 Pin 12               |
| <b>E</b> 5               | E10   | Pull-Up for U61 Pin 10               |
| <b>E</b> 5<br><b>E</b> 7 | E8    | Make Step Stretched                  |
| *E29                     | E31   | Use On-Board Multiplier for 2 Drives |
| E43                      | E44   | Connect Ready Line To 1771B          |
| E47<br>E42               | E48   | Connect to RRDY                      |
| <b>E4</b> 2              | E38   | Connect for Select O                 |
| E39                      | E40   | Pull-Up for U42 Pin 10               |
| E19                      | U46.1 | Door Lock Enable Drive O             |
| *E20                     | U46.2 | Door Lock Enable Drive 1             |

| DC POWER |                        | AC POWER |                |
|----------|------------------------|----------|----------------|
| PIN NO.  | Supply VOLTAGE         | PIN NO.  | SUPPLY         |
| 1        | -5V(-12/-15) DC        | 1        | 115V AC (HIGH) |
| 2        | Return (-5,-12/-15) DC | 2        | GND            |
| 3        | +5V DC                 | 3        | 115V AC (LOW)  |
| 4        | Return (+5V)           |          |                |
| 5        | KEY                    |          |                |
| 6        | Return (+24V)          |          |                |
| 7        | +24V DC                |          |                |

See the general jumper set-up section (4-1) for information about:

- () pin numbering at 50-pin header connector J1
- ( ) power supply connections
- () pre-operational checks
- () where to connect E48
- () Starting with pin 1, make a 1-1 connection from the 50-pin connector J1 through the ribbon cable, to the connector for your drive. Tape off any remaining unused lines.

Following are the jumpers to install on the Tarbell FDI board:

|                                               | PAD                                                                                 | NAME                                                                    | Conn. To                                                                                                        | NAME                                                                                                                                                                                        |
|-----------------------------------------------|-------------------------------------------------------------------------------------|-------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ( )<br>( )<br>( )<br>( )<br>( )<br>( )<br>( ) | E18<br>E19<br>E20<br>E23<br>R3<br>R1<br>E15<br>E22<br>E21<br>R11<br>R7<br>R5<br>E16 | TG43* HLD0* HLD1* DS0* INDX0* RDY0* WD* S0* S1* RDAT0* TR00* WRPT0* WG* | J1-24<br>J1-16<br>J1-14<br>J1-20<br>J1-26<br>J1-22<br>J1-32<br>J1-6<br>J1-8<br>J1-38<br>J1-18<br>J1-30<br>J1-34 | Current select above TK43 Drive Select 0 Drive Select 1 Head load Index Ready Write Data gate Direction Step Raw Data Track Zero Write Protect Write Gate                                   |
| ( )<br>( )<br>( )<br>( )<br>( )<br>( )<br>( ) | E41<br>E51<br>E1<br>E3<br>E5<br>E7<br>E29<br>E43<br>E28<br>E39<br>E39<br>E48        | HLD SELO* READY                                                         | E52<br>E55<br>E12<br>E11<br>E10<br>E8<br>E30<br>E44<br>E38<br>E53<br>E40<br>E46 or E47                          | Enable 4-1 decoder Head Load Signal Drives SO* direction Pull-up Pull-up SI for step pulse Ground for select MUX 0. Select Ready from Drive Hook up for HLD3 Pull-up Pull-up See Page 4-1-3 |

On drive 0, cut trace that goes from pin 14 to pins 10 & 12. On drive 1, cut trace that goes from pin 14 to pins 10 & 12, cut the trace that goes to pin 16, and jumper from pin 14 to trace that went to pin 16.

Drive Power Supply Connector:

| PIN | FUNCTION     |                                             |
|-----|--------------|---------------------------------------------|
| 1   | +5 volts DC  | NOTE: Be very careful when plugging the     |
| 2   | GND          | ribbon connector into the drive.            |
| 3   | +24 volts DC | Severe damage can result from not doing so. |

- () Make a one-one connection from the 50-pin connector on the left hand side of the PC Board (J1), through the 50-pin ribbon cable, to the connector for your drive(s).
- () If you have more than one drive, they should all be connected in parallel (daisy-chained). Each drive has a select jumper on it, which connects it's internal select logic to one of the four select lines. At least one drive should be selected as drive 0. Any other drives should each be selected to numbers 1 through 3. The terminating resistors should be removed from all drives except the last one on the daisy-chain.
- () See the general jumper set-up instructions for information about:
  - 1) the special connector at the drive end
  - 2) pin numbering at J1
  - 3) power supply connections
  - 4) pre-operational checks
  - 5) where to connect the jumper at E48
- () Z-80 users see page 7-8, SOL users see page 7-9.

Following are the jumpers to install for 1 to 4 drives:

|                                         |                                         | PAD                                                                                               | NAME                                                                                     | TO                                                                                        | DESCRIPTION                                                                                                                                                                                          |
|-----------------------------------------|-----------------------------------------|---------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ((((((((((((((((((((((((((((((((((((((( | ) ) ) ) ) ) ) ) ) ) ) ) ) ) ) ) ) ) ) ) | E18<br>E26<br>E23<br>R3<br>R1<br>E19<br>E20<br>E17<br>E25<br>E22<br>E15<br>E16<br>R7<br>R5<br>R11 | TG43* RST* DS0* INDX0* RDY0* HLD0* HLD1* HLD2* HLD3* SO* SI* WD* WG* TR00* WRPT0* RDAT0* |                                                                                           | Index Ready Drive select 0 Drive select 1 Drive select 2 Drive select 3 Direction Step Write data Write gate Track zero                                                                              |
| ((((((((((((((((((((((((((((((((((((((( | )                                       | E1<br>E3<br>E5<br>E7<br>E29<br>E33<br>E39<br>E28<br>E41<br>E51<br>E43<br>E53<br>E48               |                                                                                          | E13<br>E11<br>E10<br>E8<br>E30<br>E34<br>E40<br>E38<br>E52<br>E55<br>E44<br>E40<br>E46 Or | Direction polarity Pull-up Pull-up Normal Step line Always select 0 lines Q3 selects other side Pull-up For HLD3 Use all of decoder For head-load Use drive's ready line Pull-up E47 See page 4-1-3. |

### JUMPER SET-UP FOR PERTEC FD400 IN ALTAIR 88DCDD SYSTEM

The jumper set-up on this page is for those users who have an ALTAIR\* 88DCDD disk system. After your cable is wired, you will be able to unplug your ALTAIR controller from the disk cabinet, and plug your Tarbell controller cable in. This will enable you to run the Tarbell CP/M\*\* disk operating system. First connect the pads on the Tarbell board to the J1 signal pads (the first number) in the upper left hand corner of the board. Then make up the 50-pin cable. One end is already made up to plug into J1. The other end should be stripped and soldered to a mating 37-pin connector for your ALTAIR cabinet, according to the right half of the chart. For example, cable pin 10 is connected to connector pin 5, and cable pin 9 to connector pin 24.

- () See page 4-1-1 about pin numbering at J1 and preoperational checks.
- () Z-80 users see page 7-8, SOL users see page 7-9.

| ( )  | 2-80                                                                                         | users see                                                                                   | page 7-0, 50                                                                                  | DL users                                                                                                                                              | see page 7-9.                                                                                                                                                                      |
|------|----------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      | PAD                                                                                          | NAME                                                                                        | TARBELL<br>SIG,GND                                                                            | 37-PIN<br>SIG,GND                                                                                                                                     | DESCRIPTION                                                                                                                                                                        |
| ( )  | E23<br>E24<br>E25<br>GND<br>GND<br>GND                                                       | WD* WG* WG* TG43* INDX0* RDY0* Ground SI* SO* DS1* HLD3* ground ground ground ground RDAT0* | J1-36,35<br>J1-38,37<br>J1-20,19                                                              | 5,24<br>3,22<br>4,23<br>2,21<br>9,28<br>1,20<br>13,31<br>6,25<br>7,26<br>15,33<br>14,32<br>8,27<br>16,34<br>17,35<br>18,36<br>19,37<br>10,29<br>11,30 | Write Data Trim Erase Write Gate Current Select Index Ready Disk always enabled Step In Step Out Drive Select 0 Drive Select 1 Head Load DA-C DA-D NXT DE* GND Track Zero Raw Data |
| CONN | ECT                                                                                          |                                                                                             | TO COM                                                                                        | MENT                                                                                                                                                  |                                                                                                                                                                                    |
| ( )  | E1<br>E3<br>E5<br>E7<br>E29<br>Cut 1<br>E31<br>E39<br>E49<br>E51<br>E41<br>E52<br>E43<br>E48 | line going                                                                                  | E9 Step E13 Step E8 Norm E30 Alwa to U40 pin 2 Use E40 Pull E50 Curs E38 HLD E52 Use E55 Disl | nal Step<br>ays select<br>2 at U40.<br>Q1-not<br>1-up<br>rent select<br>all of c<br>c select<br>drive's                                               | ct 0 lines  ect polarity d-load decoder 0 ready line                                                                                                                               |

### JUMPER SET-UP FOR MEMOREX 550

- () Make a one-one connection from the 50-pin connector on the left hand side of the PC Board (J1), through the 50-pin ribbon cable, to the connector for your drive(s).
- () If you have more than one drive, they should all be connected in parallel (daisy-chained). Each drive has a select jumper on it, which connects it's internal select logic to one of the four select lines. At least one drive should be selected as drive 0. Any other drives should each be selected to numbers 1 through 3. The terminating resistors should be removed from all drives except the last one on the daisy-chain.
- ( ) See the general jumper set-up instructions for information about:
  - 1) the special connector at the drive end
  - 2) pin numbering at J1
  - 3) power supply connections
  - 4) pre-operational checks
  - 5) where to connect the jumper at E48
- () Z-80 users see page 7-8, SOL users see page 7-9.

Following are the jumpers to install for 1 to 4 drives:

|                 | PAD                                                                                 | NAME                                                            | TO                                                                                                                                | DESCRIPTION                                                                                                                                                                 |
|-----------------|-------------------------------------------------------------------------------------|-----------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ( ) ( ) ( ) ( ) | E23<br>R3<br>R1<br>E19<br>E20<br>E17<br>E25<br>E21<br>E15<br>E16<br>R7<br>R5<br>R11 | DS0* INDX0* RDY0* HLD0* HLD1* HLD2* HLD3* SO* SI* WD* WG* TR00* | J1-18<br>J1-20<br>J1-22<br>J1-26<br>J1-28<br>J1-30<br>J1-32<br>J1-34<br>J1-36<br>J1-38<br>J1-40<br>J1-42<br>J1-44<br>J1-46<br>E13 | Head-load Index Ready Drive select 0 Drive select 1 Drive select 2 Drive select 3 Direction Step Write data Write gate Track zero Write protect Raw data Direction polarity |
| ( )             | E3<br>E5                                                                            |                                                                 | E11<br>E10                                                                                                                        | Pull-up<br>Pull-up                                                                                                                                                          |
| ( )             | E7                                                                                  |                                                                 | E8                                                                                                                                | Normal Step line                                                                                                                                                            |
| ( )             | E29                                                                                 |                                                                 | E30                                                                                                                               | Aways select 0 lines                                                                                                                                                        |
| ( )             | E39                                                                                 |                                                                 | E40                                                                                                                               | Pull-up                                                                                                                                                                     |
| ( )             | E28                                                                                 |                                                                 | E38                                                                                                                               | For HLD3                                                                                                                                                                    |
| ( )             | E41                                                                                 |                                                                 | E52                                                                                                                               | Use all of decoder                                                                                                                                                          |
| ( )             | E51                                                                                 |                                                                 | E55                                                                                                                               | For head-load                                                                                                                                                               |
| ( )             | E43                                                                                 |                                                                 | E44                                                                                                                               | Use drive's ready line                                                                                                                                                      |
| ( )             | E53                                                                                 |                                                                 | E40                                                                                                                               | Pull-up                                                                                                                                                                     |
| ( )             | E48                                                                                 |                                                                 | E46 or                                                                                                                            | E47 See page 4-1-3.                                                                                                                                                         |

### VISUAL INSPECTION

It is always a good idea to give the board a thorough visual inspection before using it in your system. If you haven't yet done so, now is the time to thoroughly clean the board. Scrape with a sharp point between lines and pins that are close together to remove microscopic conductive particles. The board may work fine, but if you don't clean it, it is possible for conductance of these particles to build up over a period of time. After the scraping operation, alcohol may be used to wash the solder side of the board. If the edge connector looks dirty or tarnished, a pencil eraser can be used to clean it. Look for solder bridges, components not in right, jumper wires touching, anything that looks wrong. Many times it is easy to spot something that would cost you many hours or days of work later on.

On the component side, look for loose pieces of wire, solder, and other particles. Just about anything can conduct and cause a problem sometime. If you use sockets for the other IC's, make sure that none of them have pins turned under. This is not easy to spot, and has caused considerable loss of time, money, and energy in the past. Look at each pin very closely.

On the solder side, look for joints which are not shiny. If you find any, resolder them. Wiggle jumpers on the top of the board and watch the bottom to make sure the connections are soldered solidly.

# INSTALLING THE 1771

If you have a voltmeter or other measuring device, you might want to check the voltages on the 40 pin IC socket before mounting the 1771B.

TEST: PIN 1 -5 VOLTS
PIN 20 GROUND
PIN 21 +5 VOLTS
PIN 40 +12 VOLTS

NOTE: If you have not installed any IC's, but have allready installed R27, first install several IC's before measuring the +5 volts.

Find the Pin l position (upper left) of the socket at U55. To reduce the probability of damage due to static discharge, touch the 1771 leads as little as possible, avoid wearing synthetic clothing, and avoid carpet that tends to build up static charge (you know--when you touch things they spark).

Lay the 1771 carefully on top of the socket. Check thoroughly that all pins line up with the socket holes. Apply even pressure to both ends and middle of the package, and push down until it is firmly seated.

### INTERCONNECTING DRIVE, INTERFACE, AND POWER SUPPLY

Now is a good time to concern yourself with the installation and maintenance manual that hopefully came with your floppy disk drive. First check the power supply requirements and select a suitable unit (If you need help, Tarbell Electronics will be glad to select a power supply to fit your needs).

Most of the recently manufactured drives have a six pin Molex connector for the electronics board. A three pin connector is often used for the AC connections (if any). Connect this AC up first. Check carefully and make sure you're right before you plug it in.

The diagram below shows the normal hook-ups:



### OPERATIONAL TESTS

CAUTION---For the following system tests set switch position 6 to on and position 7 to off.

- Do not set write inhibit switch off until you are sure you are ready to write onto the disk.
- Do not use your CP/M diskette for these preliminary tests.

System configuration:

Floppy disk interface card with drive and power supply connected; Computer mainframe; front panel; CPU; power supply; with 16K bytes minimum memory (no wait states) addressed continuously from 0000 hex to 3FFF hex.

The console input/output interface is assumed to have the characteristics defined below. If not, it will be necessary to change port numbers and status bits in this procedure to work with your set-up.

| Input status  | port | 00 | Ready=bit | 0 | low |
|---------------|------|----|-----------|---|-----|
| Input data    | port | 01 |           |   |     |
| Output status | port | 00 | Ready=bit | 7 | low |
| Output data   | port | 01 | _         |   |     |

### MASTER RESET TEST

- ( ) With all power off, move the head out about half way by turning the shaft of the stepper motor.
- () Turn on computer power, then turn on drive power.

  Press system reset. The head should move to track 0 (outside) and stop.

If the stepper chatters in the home position, then the track 0 flag did not go low, or if it did, the 1771 pin 31 did not see it. If the head goes toward track 76, then reverse jumper E3 from E12 to E13.

If the head does not step at all check U55 pin 15 and U51 and associated timing components R17, C4. If you have a scope then U55 should put out a string of pulses like those shown below:



() Push RESET on your computer. U55 pin 19 should go low (LED out, if you use the LED probe).

### STEP IN/OUT TEST

() Load the following program at location 0000 hex (switch position 7 should be off):

\*\*\*CAUTION--Do not press run for these tests or you will run the head into the limits.

| ADDRESS | MACHINE CODE | ASSEMBLY CODE   | COMMENTS      |
|---------|--------------|-----------------|---------------|
| 0000    | 3E 43        | START MVI A,43H | Load step in  |
| 0002    | D3 F8        | OUT OF 8H       | Issue step in |
| 0004    | C3 00 00     | JMP START       | Do it again   |

- () Single step through the above program. Immediately before the C3, the head will move out one track. Step through this about 5 times.
- () Examine at 0001 hex. (Do not press reset) Replace the step in (43) with step out (63 hex).
- () Examine at 0000 hex. Single step again but this time the head should step toward track 00 (outside track).

We can now do these things: reset, step in, step out. These commands (plus seek) comprise the type 1 commands, and do not require diskette or diskette loading, or door closed.

### SEEK TEST

( ) Deposit following program:

| 0000 | DB FF    | START: | IN  | SNSW  | ;Read sense switches. |
|------|----------|--------|-----|-------|-----------------------|
| 0002 | D3 FB    |        | OUT | DDATA | ;Track # to data reg. |
| 0004 | 3E 13    |        | MVI | А,13Н | ;Load seek command.   |
| 0006 | D3 F8    |        | OUT | DCOM  | ; Issue seek command. |
| 8000 | C3 00 00 | 1      | JMP | START | ;Do it again.         |
| 0008 | C3 00 00 |        | JMP | START | ;Do it again.         |

- ( ) Turn drive power on, mount disk, close door.
- ( ) Examine at zero. Again, do not press RESET button as this would run the boot.
- () Set sense switches to 05 hex and single step through the program. The drive should go to track 5--of course you can't tell exactly which track it's going to, but keeping in mind that the tracks are numbered from 0 (outside) to 76 (inside), you should be able to tell if there is a drastic difference from what it should be.
- () You can put the run switch on now, and enter various combinations, but don't enter a combination into the sense switches any higher than 3F hex.

This concludes testing of the type 1 commands.

### TYPE 2 COMMANDS

These commands are read a sector and write a sector. But before we read or write, we need to know if we can load the head.

( ) Put this program into memory at the addresses shown:

| 0000 | 3E | 8C |    | START: | MVI | A,8CH | ;Load read command.   |
|------|----|----|----|--------|-----|-------|-----------------------|
| 0002 | D3 | F8 |    |        | OUT | DCOM  | ; Issue read command. |
| 0004 | C3 | 00 | 00 |        | JMP | START | ;Do it again.         |

For these commands we need the ready line low from the drive. Ready is defined within the drive, usually as all these conditions: a diskette is mounted, the door is closed, the disk is up to speed.

() With the disk running and loaded, single step the program above. After the second instruction, the head should load. When the head loads it will be only for a very short time--if the read request is not re-issued after two revolutions of the disk, it will unload. You can tell when the head loads, because there will be a definite click. If your drive is open, you may also see the solenoid activate.

### READ A SECTOR

This routine is a modified version of the boot program.

( ) Address a RAM board at the location called RAMADDR in the program and load the following program at location 00:

```
90rC =
               WAIT
                        EQU ØFCH
00F8 =
               DCOM
                        EQU ØF8H
00FB =
               DDATA
                        EQU ØFBH
00F8 =
               STAT
                        EQU ØF8H
00FA =
                        EQU ØFAH
               SECT
CØØØ =
               RAMADD
                        EQU 0C000H ; CAN BE ANY RAM ADDRESS
0000 DBFC
               BEGIN
                       IN WAIT
                                    JWAIT FOR HOME
0002 2100C0
                       LXI H, RAMADD; START LOCATION IN RAM
0005 3E01
                       MVI A, 01H ; LOAD SECTOR NUMBER
0007 D3FA
                       OUT SECT
                                    LOAD SECTOR REGISTER
0009 3E8C
                       MVI A,8CH
                                    JGET READ COMMAND
600B D3F8
                       OUT DCOM
                                   JISSUE READ COMMAND
000D DBFC
               RLOOP
                       IN WAIT
                                   ; WAIT FOR DRQ OR INTRQ
000F B7
                       ORA A
                                    SET FLAGS
0010 F21A00
                       JP RDONE
                                   JOONE IF INTRO
0013 DBFB
                                    JREAD A BYTE
                       IN DDATA
0015 77
                       A.M VOM
                                    MOVE IT TO RAM
0016 23
                       INX H
                                    JBUMP RAM ADDRESS
0017 C30D00
                       JMP RLOOP
                                   3GO BACK FOR MORE
001A DBF8
               RDONE
                       IN STAT
                                   FREAD STATUS WORD
001C B7
                       ORA A
                                    SET FLAGS
001D 322200
                       STA $+5
                                   SAVE STAT WORD
0020 76
                       HLT
                                   STOP
```

- () Clear 10 to 20 bytes at the start of RAMADD so you can check to see if any data was entered.
- () Mount a fresh diskette and run the above program. The RAMADD and next 127 bytes should contain the data fill byte; IBM uses E5 (hex), but other manufacturers may use something different.

If the RAM did not load then examine the location of the status word (F8 hex) and check the bits against the 1771 Status Bits For Type II and III Commands (page 12 of the 1771 data sheet) to see if this explains the problem.

### WRITE A SECTOR

The purpose of this routine is to write one sector and halt.

- () Turn the write-protect switch (51-6) off.
- () Select a location in memory for RAMADD and load it with a recognizable data pattern.
- () Load the following program at location 0:

| 00FC         | = .    | WAIT   | EQU ØFCH      |                             |
|--------------|--------|--------|---------------|-----------------------------|
| 00F8         | =      | STAT   | EQU ØF8H      |                             |
| 00F8         | =      | DCOM   | EQU ØF8H      |                             |
| 00FB         | =      | DDATA  | EQU OFBH      |                             |
| 00FA         | =      | SECT   | EQU ØFAH      | •                           |
| CØØØ         | =      | RAMADD | EQU ØCØØØH    |                             |
|              |        | 3      |               |                             |
| 0000         | DBFC   |        | IN WAIT       | WAIT FOR HOME               |
| 0002         | 2100C0 |        | LXI H, RAMADD | SET ADDRESS POINTER         |
| <b>00</b> 05 | 3EØ1   |        | MVI A,01      | LOAD SECTOR NUMBER          |
| 0007         | D3FA   |        | OUT SECT      | OUTPUT TO CONTROLLER        |
| <b>00</b> 09 | 3EAC   |        | MVI A, ØACH   | LOAD SECTOR WRITE COMMAND   |
| <b>00</b> 0B | D3F8   |        | OUT DCOM      | JOUTPUT TO COMMAND REGISTER |
| <b>00</b> 0D | DBFC   | WLOOP  | IN WAIT       | WAIT FOR INTRO OR DRO       |
| <b>00</b> 0F | B7     |        | ORA A         | SET FLAGS                   |
| 0010         | F21A00 |        | JP DONE       | JUMP WHEN INTRO             |
| 0013         | 7 E    |        | MOV A,M       | LOAD DATA FROM RAM          |
| 0014         | D3FB   |        | OUT DDATA     | WRITE ON DISK               |
| 0016         | 23     |        | INX H         | BUMP RAM POINTER            |
| 0017         | C30D00 |        | JMP WLOOP'    | GET MORE                    |
| 001A         | DBF8   | DONE   | IN STAT       | READ STAT                   |
| 001C         | E6FD   |        | ANI ØFDH      | MASK NON ERR BITS           |
| Ø01E         | 322200 |        | STA \$+4      | SAVE STAT WORD              |
| 0021         | 76     |        | HLT           |                             |

() Run the program. Clear the 128 bytes starting at RAMADD and run the read one sector program given previously. Check that the data is restored.

If the write is not successful, check the status bits against the table after writing and before reading.

### THE BOOTSTRAP

### HARD BØSTSTRAP PROGRAM (ON 625123 PROM)

| <b>ADDR</b> | MACH CODE | LABEL    | ASY LANGUAGE | C SMMENTS               |
|-------------|-----------|----------|--------------|-------------------------|
| 0000        | DB FC     | BOST:    | IN WAIT      | JVAIT FOR HOME.         |
| 0002        | AF        |          | XRA A        | JC ØMPLETE.             |
| 0003        | 6F        |          | MØV LA       | JSET L=0.               |
| 0004        | 67        |          | MOV HA       | JH4L=0.                 |
| 0005        | 36        |          | INR A        | JSET A=1.               |
| 0006        | D3 FA     |          | SUT SECT     | JSECTOR = 1.            |
| 0008        | 3E 8C     |          | MVI A, 8CH   | JREAD SECTOR.           |
| 000A        | D3 F8     |          | SUT DC SM    |                         |
| 0000        | DB FC     | RLOOP:   | IN WAIT      | JVAIT FOR DRQ OR INTRQ. |
| OOOE        | <b>B7</b> |          | GRA A        | JSET FLAGS.             |
| 000F        | F2 19 00  |          | JP RDONE     | JOSNE IF INTRQ.         |
| 0012        | DB FB     |          | IN DDATA     | JREAD A BYTE OF DATA.   |
| 0014        | 77        |          | NOV M.A      | JPUT INTO MEMORY.       |
| 0015        | 23        |          | INX H        | JINCRÉMENT POINTER.     |
| 0016        | C3 OC OO  |          | JMP RLSOP    | JDS IT AGAIN.           |
| 0019        | DB F8     | RD SNE : | IN DSTAT     | JREAD DISK STATUS.      |
| 001B        | B7        |          | GRA A        | JSET FLAGS.             |
| 001C        | CA 7D 00  |          | JZ 07DH      | ; IF ZERS, GS TS SBOOT. |
| 001F        | 76        |          | HLT          | JDISK ERROR, SO HALT.   |
|             |           | FTIAW    | EQU OFCH     | ·                       |
|             |           | SECT :   | EQU OFAH     |                         |
|             |           | DC SM:   | equ of sh    |                         |
|             |           | DDATA:   | EQU OFBH     |                         |
|             |           | DSTAT :  | equ of sh    |                         |

This program will be executed whenever the bootstrap enable switch (Sl position 71) is on and RESET is pushed. Its purpose is to read the first sector of track 0 into memory starting at 0000 hex, and then execute it. If an error is detected, the program puts the computer in the halt state—you may try again by pressing RESET, or stop your computer by pressing RESET and STOP at the same time. If you do not wish to use this PROM bootstrap, a similar program may be run elsewhere in memory (with addresses relocated), as long as the memory it runs in has no wait states and is above 00F1 hex.

Locating a program at address 0 to read from the disk into memory at zero would normally be impossible since the programwould be overwritten by the sector loaded, thus destroying the bootstrap before it was finished. The special hardware tricks played on the board make

this possible by controlling the bus to write into main memory while reading from the PROM bootstrap.

Note that the upper five bits of I/O instructions are always high, to match the standard setting of the dip switch. If the dip switch were set for a different device address, the upper five bits on all the I/O commands would have to be adjusted accordingly, and you would have to change the 82S123 PROM.

The first instruction is "IN WAIT" (port FC). This instruction tells the interface board to force a hardware wait until either the DRQ or INTRQ outputs of the 1771 go true--these signals tell the computer (program) that the interface is ready to do something. In this case, we're waiting for INTRO to go true, which tells us that the head is in the "home" position (track 0).

"XRA A" makes register A zero, and "MOV L,A" and "MOV H,A" make registers H and L zero. The "INR A" makes reg A=1. Now when we do the "OUT SECT", this is a type 1 command to the sector register in the 1771 (see the data sheets), and sets this register to 1 (for sector 1). With the "MVI A,8CH", we set reg A up for a read operation (type 2). Bits 7,6,5 are 100 as shown in the command summary. Bit 4 is 0 because we want a single record. Bit 3 is 1 for IBM format. Bit 2 is 1 to make the head load at the beginning of the read operation. We then do an output "OUT DCOM" to make it all happen.

The next "IN WAIT" is used to wait for each data byte, and it also retrieves the status which indicates end of operation. "ORA A" sets the flags so we can tell whether to jump out of the loop. If the most significant bit is 0, the interface is indicating that it was the INTRQ that caused the end of the wait. If 1, it was the DRQ, indicating some data is ready to process. IN DDATA" actually reads the data from the 1771 data register into the 8080 register A. "MOV M,A" of course transfers the data to memory. "INX H" increments the memory data pointer register. "JMP RLOOP" transfers control back to the beginning of the loop to do it again.

When the INTRQ goes true, indicating an end of the read operation or an error, a transfer to "RDONE" is made. There, the "IN DSTAT" reads the disk status from the 1771 status register. The meaning of each

bit is shown in the 1771 data sheets. The way it's set up, if all bits are zero, it's a good read ("ORA A sets the flags) and a transfer is made to the program at 7D hex. If not, a HLT is executed, and the operator may press reset to try again.

If a CP/M disk is being used, the sector brought into memory contains the Cold-start Loader. This program then reads the next 51 sectors into memory, which is the CP/M operating system. The last thing the Cold-start Loader does is to jump into the CP/M system, at the location that contains the instruction "JMP BOOT", which is the start of CBIOS.

In this way, the system is completely auto-loading, and requires no other ROM (read-only-memory). If desired, the bootstrap program ROM can be temporary disabled after a reset by doing an EXAMINE from the front panel with address/data switch 5 on the front panel in the on position. It can be more permenantly disabled by switching switch #7 on the interface to the "off" position.

If desired, the bootstrap can be located in another ROM, perhaps as part of an existing monitor. In this case, it is important that the memory in which the bootstrap program actually runs has no wait states. If the ROM in your present system does require wait states, it is still possible to use it for a bootstrap by using a routine that moves the bootstrap down into RAM, then jumps to it. An example of such a program is shown on the following page.

```
; EXTERNAL CP/M BOOTSTRAP
                ; THIS PROGRAM CAN RUN IN SLOW READ-ONLY MEMORY.
                ; IT MOVES THE ACTUAL BOOTSTRAP DOWN INTO RAM,
                ; THEN JUMPS TO IT.
FF00
                         ORG
                              OFFOOH
                                          JADDRESS OF ROM.
                                          GET LOCAL ADR OF BOOT.
FF00 2113FF
                         LXI
                              H,RBOOT
FF03 110030
                         LXI
                              D.BOOT
                                          ; WHERE THE BOOT GOES.
FF06 0E20
                         MUI
                              C.ENDBT-BOOT
                                             JNUMBER OF BYTES.
FF08 7E
                MLOOP:
                         MOV
                              A.M
                                          JGET A BYTE FROM ROM.
FF09 12
                                          JPUT THE BYTE IN RAM.
                         STAX D
FFOA 23
                         INX
                              Ħ
                                          JINCREMENT ROM POINTER.
                                          JINCREMENT RAM POINTER.
FFOB 13
                         INX
                              D
FFOC OD
                         DCR
                              C
                                          JDECREMENT BYTE COUNTER.
FFOD C208FF
                         JNZ
                              MLOOP
                                          ;DO UNTIL C = 0.
FF10 C30030
                                          THOP TO BOOT WHEN DONE.
                         JMP .
                              BOOT
                RBOOT:
                                          ;BOOT'S PLACE IN ROM.
3000
                         ORG
                              3000H
                                          BOOT'S PLACE IN RAM.
3000 DBFC
                BOOT:
                         IN
                              WAIT
                                          ; WAIT FOR HOME.
3002 AF
                         XRA
                              A
                                          JCOMPLETE .
3003 6F
                         MOV
                              L.A
                                          SET L=0.
3004 67
                         MOV
                              H.A
                                          3SET H=0 .
3005 3C
                                          SET A=1.
                         INR
                              A
3006 D3FA
                         OUT
                              SECT
                                          SET SECTOR = 1.
3008 3E8C
                         MVI
                              A,8CH
                                          JSEND COMMAND TO READ
300A D3F8
                         OUT
                              DCOM
                                          3SECTOR TO 1771.
300C DBFC
                RLOOP:
                         IN
                              WAIT
                                          JWAIT FOR DRQ OR INTRQ .
300E B7
                         ORA
                                          JSET FLAGS .
300F F21930
                         JP
                              RDONE
                                          DONE IF INTRQ.
3012 DBFB
                                          FREAD THE DATA.
                         IN
                              DDATA
3014 77
                         MOV
                              M.A
                                          PUT INTO MEMORY.
3015 23
                         INX
                              H
                                          ; INCREMENT MEMORY POINTER .
3016 C30C30
                         JMP
                              RLOOP
                                          FREAD ANOTHER BYTE.
3019 DBF8
                RDONE:
                         IN
                              DSTAT
                                          FREAD DISK STATUS.
301B B7
                         ORA
                                          ;SET 8080 FLAGS.
                              Α
301C CA7D00
                         JZ
                                          ;GO TO SBOOT IF ZERO.
                              7DH
301F 76
                         HLT
                                          JHALT IF ERROR.
                ENDBT:
                                          ; END OF BOOTSTRAP.
OOFC =
                WAIT:
                         EQU
                              OFCH
                                          ; WAIT COMMAND .
                SECT:
00FA =
                         EQU
                              OFAH
                                          SECTOR REGISTER PORT.
00F8 =
                DCOM:
                         EQU
                              OF8H
                                          31771 COMMAND PORT.
00FB =
                DDATA:
                         EQU
                              OFBH
                                          31771 DATA PORT-
00F8 =
                DSTAT:
                         EQU
                              OFSH
                                          31771 STATUS PORT.
3020
                         END
```

### WRITING DRIVER ROUTINES

Most driver routines will follow a similar form as the bootstrap program. The first step, then, is to familiarize yourself with that program.

Then, consult the 1771 data sheet. Note the various options, and decide what you want done--read or write, track #, etc.

Next, combine these with the sample driver routines in the next section. While the interior hardware of the interface may be complex, the software need not be at all. Make sure you load the proper registers, issue commands, and check for results.

### SAMPLE DRIVER ROUTINES

The easiest way to write your driver routines at first is to splice together blocks of existing, working programs. The following routines should serve as a good starting point--but remember to make any necessary changes to correspond to your system's peculiarities.

To move head to home (track 0):

| HOME : | MV I<br>OUT | A,ODOH<br>DC@M | CLEAR ANY PENDING COMMAND.                        |
|--------|-------------|----------------|---------------------------------------------------|
| HOME1: | IN<br>RRC   | DSTAT          | FREAD INTERFACE STATUS.  FLEEK AT LEAST SIG. BIT. |
|        | JC          | Høme 1         | WAIT FOR NOT BUSY.                                |
|        | IVM         | A.3            | JGET BITS FOR HOME COMMAND.                       |
|        | ØUT         | DCØM           | JISSUE HOME COMMAND.                              |
|        | IN          | WAIT           | JUAIT FOR INTRO (END OF SP.).                     |
|        | ØRA         | A              | JSET FLAGS.                                       |
|        | MUI         | A.1            |                                                   |
|        |             |                | JSET UP ERRØR INDICATØR.                          |
|        | JM          |                | JERROR IF DRQ INSTEAD OF INTRQ.                   |
|        | IN          | DSTAT          | FREAD DISK INTERFACE STATUS.                      |
|        | MØV         | E.A            | JSAVE IN REGISTER E.                              |
|        | ANI         | 4              | JLOOK AT BIT 2.                                   |
|        | JZ          | HERR           | JERROR IF NOT AT TRACK 0.                         |
|        | MØV         | A,E            | JGET STATUS BACK.                                 |
|        | ANI         | 91H            | MASK NØN-ERRØR BITS.                              |
|        | RET         |                | JRETURN IF NO ERROR.                              |
| HERR:  | MVI         | A.1            |                                                   |
|        |             |                | JSET HARDWARE ERROR.                              |
|        | ØRA         | A              | JSET FLAGS.                                       |
|        | RET         |                | FRETURN FROM HOME ROUTINE.                        |

To select the drive whose number is in register C:

```
SELECT: MOV
            A,C
                        GET DISK NO. INTO A FROM C.
        CMA
                        ; INVERT BECAUSE LATCH INVERTED.
                        ; CLEAR ALL BUT 2 LEAST SIG. BITS.
        ANI
        RAL!RAL!RAL!RAL; SHIFT BITS LEFT 4 PLACES.
                       ;GET CODE TO SET LATCH.
        ORI
       OUT
            DEXT
                        ; SEND TO EXTENDED COMMAND PORT.
        RET
                        ; RETURN FROM SELECT ROUTINE.
                        ; DISK 1771 COMMAND PORT. (OUT)
DCOM:
       EQU OF8H
DSTAT: EQU OF 8H
                        ;DISK 1771 STATUS PORT. (IN)
                        ;DISK 1771 TRACK REGISTER PORT. (IN/OUT)
       EOU OF 9H
TRACK:
SECTP:
       EQU
             OFAH
                        ; DISK 1771 SECTOR REGISTER PORT. (IN/OUT)
DDATA: EQU OFBH
                       ;DISK 1771 DATA PORT. (IN/OUT)
       EQU OFCH
                       ;DISK WAIT (XRDY/PRDY) PORT. (IN)
WAIT:
DEXT:
                       ; DISK EXTENDED COMMAND PORT. (OUT)
       EQU OFCH
```

To Read or Write a Sector, see the listings in the operational tests section (pages 5-4-3 and 5-4-4).

To perform a SEEK (go to a specified track) operation, the following routine may be used if the desired track is in register A:

```
OUT
SEEK:
             DDATA
                         ;SEND TRACK TO DATA REGISTER.
BUSY:
        IN
             DSTAT
                         ; READ DISK STATUS.
                         ;LOOK AT BIT 0 (BUSY).
        RRC
                        ;WAIT IN LOOP TILL NOT BUSY.
        JC
             BUSY
                        ;SET FOR 10 MS STEP.
        MVI
             A,12H
        OUT
             DCOM
                         ; ISSUE SEEK COMMAND.
        IN
             WAIT
                        ; WAIT FOR INTRQ.
        RET
                         ; RETURN FROM SEEK ROUTINE.
```

NOTE: If you are using a drive with a Fast-Seek operation, such as the PerSci models 70 or 270, the 1771 is not quite capable of putting out the step signals fast enough to take full advantage of the drive seek speed. In this case, the line connected to E14 can be strobed by the software fast enough. The software for seeking, however, is then a little more involved, because it has to keep track of the track number and count the number of step pulses. The PerSci version of CP/M by Tarbell Electronics implements this software. Copies of the BIOS (Basic Input/Output System) for either the PerSci or Standard versions of CP/M are available in listing form free from Tarbell Electronics.

**QUAD 2-INPUT NAND GATE** 



### 74LS00)

| INF | PUTS | OUT |
|-----|------|-----|
| 1   | 2    | 3   |
| 0   | 0    | /   |
| 0   | 1    |     |
| - 1 | 0    |     |
|     |      | 0   |

**HEX INVERTER** 



### 9LS04 (54LS/74LS04)



QUAD 2-INPUT AND GATE



9LS08 (54LS/74L808)

| INI | PUTS | OUT |
|-----|------|-----|
|     | 2    | 3   |
| 0   | 0    | 0   |
| 0   | 1    | 0   |
| /   | 0    | 0   |
| 1   | 1    | 1   |

### TRIPLE 3-INPUT NAND GATE



## 9LS10 (54LS/74LS10)

| (1  | INPUTS |   |     |  |  |
|-----|--------|---|-----|--|--|
| 3   | 4      | 5 | 6   |  |  |
| 0   | 0      | 0 |     |  |  |
| 0   | 0      |   | 1   |  |  |
| 0   | -      | 0 |     |  |  |
| 0   | 1      | 1 | 1   |  |  |
| - 1 | 0      | 0 | 1   |  |  |
|     | 0      |   |     |  |  |
| i   | ł      | 0 | - 1 |  |  |
| 1   |        |   | 0   |  |  |

### 7438 quad 2-input NAND buffer

### (open collector)

### general description

These are quad two-input NAND buffers. The DM5437/DM7437 has a normal TTL "Darlington" output configuration whereas the DM5438/DM7438 has an open-collector. Aside from the output, the circuitry is identical.

### features

- Series 54/74 TTL and DTL compatible
- Input clamping diodes
- Typical noise immunity

1 V

■ Fan Out

30

### schematic and connection diagrams





### 8T97 HEX TRI-STATE INVERTERS



| INPU | TS | OUTPUT |
|------|----|--------|
| DIS  | IN | OUT    |
| Н    | X  | Hi-Z   |
| L    | Н  | H      |
| L    | L  | L      |

### 741574

### DUAL D-TYPE POSITIVE EDGE-TRIGGERED FLIP-FLOP

**DESCRIPTION** – The 9LS74 (54LS/74LS74) dual edge-triggered flip-flop utilizes Schottky TTL circuitry to produce high speed D-type flip-flops. Each flip-flop has individual clear and set inputs, and also complementary  $\Omega$  and  $\overline{\Omega}$  outputs.

Information at input D is transferred to the Q output on the positive-going edge of the clock pulse. Clock triggering occurs at a voltage level of the clock pulse and is not directly related to the transition time of the positive-going pulse. When the clock input is at either the HIGH or the LOW level, the D input signal has no effect.



### MODE SELECT - TRUTH TABLE

| INPUTS         |                |                                       | OUTPUTS     |                                                                                                                                                                                                                                           |
|----------------|----------------|---------------------------------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| S <sub>D</sub> | C <sub>D</sub> | D                                     | Q           | ã                                                                                                                                                                                                                                         |
| L              | н              | ×                                     | н           | Ĺ                                                                                                                                                                                                                                         |
| н              | L              | ×                                     | L           | н                                                                                                                                                                                                                                         |
| L              | L              | ×                                     | н           | н                                                                                                                                                                                                                                         |
| н              | н              | h                                     | н           | L                                                                                                                                                                                                                                         |
| н              | н              | 1                                     | L           | н                                                                                                                                                                                                                                         |
|                | H<br>L<br>H    | S <sub>D</sub>   C <sub>D</sub>     H | SD   CD   D | \$\overline{S_D}\$         \$\overline{C_D}\$         D         Q           L         H         X         H           H         L         X         L           L         L         X         H           H         H         h         H |

<sup>\*</sup>Both outputs will be HIGH while both  $\overline{S}_D$  and  $\overline{C}_D$  are LOW, but the output states are unpredictable if  $\overline{S}_D$  and  $\overline{C}_D$  go HIGH simultaneously.

H,h = HIGH Voltage Level

L,I = LOW Voltage Level

X = Don't Care

I, h (q) = Lower case letters indicate the state of the referenced input (or output) one set-up time prior to the LOW to HIGH clock transition.

# 74LS86

### **QUAD 2-INPUT EXCLUSIVE OR GATE**



|   | TAUTH TABLE |     |      |  |  |  |
|---|-------------|-----|------|--|--|--|
|   | 11          | OUT |      |  |  |  |
| 1 | A           | 'Z  |      |  |  |  |
|   | L           | L   | · L  |  |  |  |
|   | L           | н   | Н .  |  |  |  |
|   | н           | L   | н [] |  |  |  |
|   | н           | Н   | L    |  |  |  |

# **DUAL RETRIGGERABLE** MONOSTABLE MULTIVIBRATORS WITH CLEAR

- Functionally and Mechanically Identical to SN54122/SN74122 and SN54123/SN74123
- Retriggerable for Very Long Output Pulses, Up to 100% Duty Cycle
- **Overriding Clear Terminates Output Pulse**
- Low Power Dissipation:

'LS122 . . . 30 mW Typical 'LS123 . . . 60 mW Typical

### description

The 'LS122 and 'LS123 multivibrators feature d-c triggering from gated low-level-active (A) and highlevel-active (B) inputs, and also provide overriding direct clear inputs. Complementary outputs are provided. The retrigger capability simplifies the generation of output pulses of extremely long duration. By triggering the input before the output pulse is terminated, the output pulse may be extended. The overriding clear capability permits any output pulse to be terminated at a predetermined time independently of the timing components R and C. Enough Schmitt hysteresis is provided to ensure jitter-free triggering from the B inputs with transition rates as slow as 1 volt per second. Figure 1 illustrates triggering the one-shot with the high-level-active (B) inputs.

### LS123 FUNCTION TABLE (SEE NOTE 1)

| INP   | OUTPUTS |   |    |   |
|-------|---------|---|----|---|
| CLEAR | Α       | 8 | Q  | ā |
| L     | Х       | Х | L. | Н |
| х     | н       | X | L  | н |
| X,    | х       | L | L  | н |
| н     | L       | † | л  | U |
| н     | ţ       | н | л  | น |
| t     | L       | н | v  | v |



- NOTES: 1. H = high level (steady state), L = low level (steady state), † = transition from low to high level, L = transition from high to low level, It = one high-level pulse, "If = one low-level pulse, X = Irrelevent (any input, including transitions).
- To use the internal timing resistor of 'LS122, connect Rint to V<sub>CC</sub>.
   An extract timing capacitor may be connected between C<sub>ext</sub> and R<sub>ext</sub>/C<sub>ext</sub> (positive).
  - 4. For accurate repeatable pulse wild'irs, connect an external resistor between R<sub>BXt</sub>/C<sub>ext</sub> and V<sub>CC</sub> with R<sub>Int</sub> open circuited.

    5. To obtain variable pulse widths, connect external variable resistance between R<sub>int</sub> or R<sub>BXt</sub>/C<sub>ext</sub> and V<sub>CC</sub>.

### CONNECTION DIAGRAMS **TO-220 PLASTIC POWER PACKAGE** (TOP VIEW)

### 7805

- **OUTPUT CURRENT IN EXCESS OF 1 AMP**
- NO EXTERNAL COMPONENTS
- INTERNAL THERMAL OVERLOAD PROTECTION
- INTERNAL SHORT CIRCUIT CURRENT LIMITING
- **OUTPUT TRANSISTOR SAFE-AREA COMPENSATION**
- AVAILABLE IN THE PLASTIC TO-220 AND THE METAL TO-3 PACKAGE

### **ABSOLUTE MAXIMUM RATINGS**

Input Voltage (5 V through 18 V) 35 V (24 V) 40 V Internal Power Dissipation (Note 1) Internally Limited Storage Temperature Range -65°C to +150°C Operating Junction Temperature Range 0"C to +125"C Lead Temperature (Soldering, 60 second time limit) TO-3 Package 300°C (Soldering, O second time limit) TO-220 Package 230°C

### 74LS138

FUNCTIONAL DESCRIPTION — The 9LS138 is a high speed 1-of-8 Decoder/Demultiplexer fabricated with the low power Schottky barrier diode process. The decoder accepts three binary weighted inputs  $(A_0, A_1, A_2)$  and when enabled provides eight mutually exclusive active LOW outputs  $(\overline{0}_0, \overline{0}_7)$ . The 9LS138 features three Enable inputs, two active LOW  $(\overline{E}_1, \overline{E}_2)$  and one active HIGH  $(E_3)$ . All outputs will be HIGH unless  $\overline{E}_1$  and  $\overline{E}_2$  are LOW and  $E_3$  is HIGH. This multiple enable function allows easy parallel expansion of the device to a 1-of-32 (5 lines to 32 lines) decoder with just four 9LS138s and one inverter. (See Figure a.)

The 9LS138 can be used as an 8-output demultiplexer by using one of the active LOW Enable inputs as the data input and the other Enable inputs as strobes. The Enable inputs which are not used must be permanently tied to their appropriate active HIGH or active LOW state.

TRUTH TABLE

| INPUTS |    |    |    |                | OUTPUTS        |                |                |                |            |                |                |                |                |
|--------|----|----|----|----------------|----------------|----------------|----------------|----------------|------------|----------------|----------------|----------------|----------------|
| Ē1     | Ē2 | E3 | Ao | A <sub>1</sub> | A <sub>2</sub> | ō <sub>0</sub> | ō <sub>1</sub> | ō <sub>2</sub> | <u>0</u> 3 | Ō <sub>4</sub> | ō <sub>5</sub> | ō <sub>6</sub> | ō <sub>7</sub> |
| н      | ×  | ×  | ×  | ×              | ×              | н              | н              | Н              | Н          | н              | Н              | н              | н              |
| ×      | н  | X  | ×  | ×              | ×              | н              | н              | H              | н          | н              | н              | н              | н              |
| X      | X  | L  | x  | ×              | ×              | н              | н              | н              | н          | н              | н              | н              | н              |
| L      | L  | н  | L. | L              | L              | L              | н              | н              | н          | н              | н              | H              | н              |
| L      | L  | н  | н  | L              | L              | н              | L              | н              | н          | н              | н              | н              | н              |
| L      | L  | H  | L  | н              | i.             | н              | н              | L              | н          | н              | н              | н              | н              |
| L      | Ł  | н  | н  | н              | Ł              | н              | н              | н              | L          | н              | н              | Н              | н              |
| L      | L  | н  | L  | L              | н              | н              | н              | н              | н          | L              | н              | н              | н              |
| Ł      | L  | н  | н  | L              | н              | н              | н              | н              | н          | н              | L              | н              | н              |
| L      | L  | н  | L  | н              | н              | н              | н              | н              | н          | н              | н              | L              | н              |
| L      | L  | н  | н  | н              | н              | н              | н              | н              | н          | н              | н              | H              | Ł              |

LOADING (Note a)

DESCRIPTION — The LSTTL/MSI 9LS138 (54LS/74LS138) is a high speed 1-of-8 Decoder/Demultiplexer. This device is ideally suited for high speed bipolar memory chip select address decoding. The multiple input enables allow parallel expansion to a 1-of-24 decoder using just three 9LS138 devices or to a 1-of-32 decoder using four 9LS138s and one inverter. The 9LS138 is fabricated with the Schottky barrier diode process for high speed and is completely compatible with all Fairchild TTL families.

- DEMULTIPLEXING CAPABILITY
- MULTIPLE INPUT ENABLE FOR EASY EXPANSION
- TYPICAL POWER DISSIPATION OF 32 mW
- ACTIVE LOW MUTUALLY EXCLUSIVE OUTPUTS
- INPUT CLAMP DIODES LIMIT HIGH SPEED TERMINATION EFFECTS
- . FULLY TTL AND CMOS COMPATIBLE

### LOGIC SYMBOL



V<sub>CC</sub> = Pin 16 GND = Pin 8

### PIN NAMES

|                                   |                             | HIGH     | LOW          |
|-----------------------------------|-----------------------------|----------|--------------|
| $A_0 - A_2$                       | Address Inputs              | 0.5 U.L. | 0.25 U.L.    |
| $\overline{E}_1, \overline{E}_2$  | Enable (Active LOW) Inputs  | 0.5 U.L. | 0.25 U.L.    |
| E <sub>3</sub>                    | Enable (Active HIGH) Input  | 0.5 U.L. | 0.25 U.L.    |
| $\overline{O}_0 - \overline{O}_7$ | Active LOW Outputs (Note b) | 10 U.L.  | 5 (2.5) U.L. |

### NOTES:

- a. 1 TTL Unit Load (U.L.) = 40 μA HIGH/1.6 mA LOW.
- The Output LOW drive factor is 2.5 U.L. for Military (XM) and 5 U.L. for Commercial (XC) Temperature Ranges.

# CONNECTION DIAGRAM DIP (TOP VIEW)

# 

### NOTE: The Flatpak version has the same pinouts (Connection Diagram) as the Dual In-Line Package.

### LOGIC DIAGRAM



## 74LS175

## QUAD D FLIP-FLOP

**DESCRIPTION** — The LSTTL/MSI 9LS175 (54LS/74LS175) is a high speed Quad D Flip-Flop. The device is useful for general flip-flop requirements where clock and clear inputs are common. The information on the D inputs is stored during the LOW to HIGH clock transition. Both true and complemented outputs of each flip-flop are provided. A Master Reset input resets all flip-flops, independent of the Clock or D inputs, when LOW.

The 9LS175 is fabricated with the Schottky barrier diode process for high speed and is completely compatible with all Fairchild TTL families.

- EDGE-TRIGGERED D-TYPE INPUTS
- BUFFERED-POSITIVE EDGE-TRIGGERED CLOCK
- CLOCK TO OUTPUT DELAYS OF 14 ns
- ASYNCHRONOUS COMMON RESET
- TRUE AND COMPLEMENT OUTPUT
- INPUT CLAMP DIODES LIMIT HIGH SPEED TERMINATION EFFECTS
- FULLY TTL AND CMOS COMPATIBLE

| PIN NAMES                                   | _                                    | LOADING (Note a) |             |  |
|---------------------------------------------|--------------------------------------|------------------|-------------|--|
|                                             |                                      | HIGH             | LOW         |  |
| $D_0 - D_3$                                 | Data Inputs                          | 0.5 U.L.         | 0.25 U.L.   |  |
| CP                                          | Glock (Active HIGH Going Edge) Input | 0.5 U.L.         | 0.25 U.L.   |  |
| MR                                          | Master Reset (Active LOW) Input      | 0.5 U.L.         | 0.25 U.L.   |  |
| $\overline{\sigma}^0 - \overline{\sigma}^3$ | True Outputs (Note b)                | 10 U.L.          | 5(2.5) U.L. |  |
| $\underline{o}^0 - \underline{o}^3$         | Complemented Outputs (Note b)        | 10 U.L.          | 5(2.5) U.L. |  |

#### NOTES:

- a. 1 TTL Unit Load (U.L.) = 40 µA HIGH/1.6 mA LOW.
- b. The Output LOW drive factor is 2.5 U.L. for Military (XM) and 5 U.L. for Commercial (XC) Temperature Ranges.





#### **DM8131**

#### 6-bit unified bus comparator

#### general description

The DM7131/DM8131, DM7136/DM8136 compare two binary words of two-to-six-bits in length and indicates matching bit-for-bit of the two words. Inputs for one word are 54/74 series-compatible TTL inputs, whereas those of the second word are high impedance receivers driven by a terminated data bus. These bus inputs include 1V typical hysteresis which provides 1.8V noise immunity. The DM7131/DM8131 has active pull up output and goes to the low state upon comparison. The DM7136/DM8136 has open-collector output which goes to high state upon comparison and is expandable to n bits by collector-ORing. Both devices have an output latch which is strobe controlled.

The transfer of information to the output occurs when the  $\overline{\text{STROBE}}$  input goes from a logic "1"

to logic "0" state. Inputs may be changed while the STROBE is at the logic "1" level without affecting the state of output. These devices are useful as address comparators in computer systems utilizing unified data bus organization.

#### features

Low bus input current

15 μA typ

High bus input noise immunity

1.8V typ

■ High fan out

- Input clamping diodes
- Output compatible with TTL circuits
- Output latch provision

#### logic and connection diagrams





# 82S123

# 256-BIT BIPOLAR TRI-STATE PROGRAMMABLE ROM

#### **DESCRIPTION**

The 82S23 (open Collector Outputs) and the 82S123 (Tristate Outputs) are Bipolar 256 Bit Read Only Memories organized as 32 words by 8 bits per word. They are Field-Programmable, which means that custom patterns are immediately available by following the simple fusing procedure given in this data sheet. A chip enable line is provided and the outputs are bare collector or Tristate to allow for memory expansion capability.

The 82S23 and 82S123 are fully TTL compatible and include on-the-chip decoding. Typical access time is 35 nS.

#### **FEATURES**

- PNP INPUTS
- BUFFERED ADDRESS LINES
- ON THE CHIP DECODING
- A CHIP ENABLE LINE
- OPEN COLLECTOR OR TRISTATE OUTPUTS
- DIODE PROTECTED INPUTS
- NO SEPARATE "FUSING" PINS
- BOARD PROGRAMMABLE

#### **LOGIC DIAGRAM**



#### INPUT/OUTPUT SCHEMATIC DIAGRAMS





## HEX 3-STATE BUFFER SEPARATE 2-BIT AND 4-BIT SECTIONS



**TRUTH TABLE** 

| INP | UTS | OUTDUT |
|-----|-----|--------|
| E   | D   | OUTPUT |
| L   | L   | L      |
| L   | Н   | н      |
| Н   | Х   | (Z)    |

#### 74LS368

## HEX 3-STATE INVERTER BUFFER SEPARATE 2-BIT AND 4-BIT SECTIONS



TRUTH TABLE

| INP | UTS | OUTPUT |
|-----|-----|--------|
| Ē   | Đ   | OUTPUT |
| L   | L   | Н      |
| L   | Н   | L      |
| Н   | Х   | (Z)    |

**DESCRIPTION** — The 9LS365/366/367/368 are high speed hex buffers with 3-state outputs. They are organized as single 6-bit or 2-bit/4-bit, with inverting or non-inverting data (D) paths. The outputs are designed to drive 15 TTL Unit Loads or 60 Low Power Schottky loads when the Enable ( $\overline{E}$ ) is LOW.

When the Output Enable Input  $(\overline{E})$  is HIGH, the outputs are forced to a high impedance "off" state. If the outputs of the 3-state devices are tied together, all but one device must be in the high impedance state to avoid high currents that would exceed the maximum ratings. Designers should ensure that Output Enable signals to 3-state devices whose outputs are tied together are designed so there is no overlap.

#### 74LS32

#### QUAD 2-INPUT OR GATE



| INP | INPUTS |   |  |  |
|-----|--------|---|--|--|
|     | 2      | 3 |  |  |
| 0   | 0 0    |   |  |  |
| 0   | 1      | 1 |  |  |
| 1   | 0      | 1 |  |  |
| 1   | 1      | 1 |  |  |

## 74LS161

#### LOGIC SYMBOL

**DESCRIPTION** — The 9LS160/161/162/163 are high-speed 4-bit synchronous counters. They are edge-triggered, synchronously presettable, and cascadable MSI building blocks for counting, memory addressing, frequency division and other applications. The 9LS160 and 9LS162 count modulo 10 (BCD). The 9LS161 and 9LS163 count modulo 16

The 9LS160 and 9LS161 have an asynchronous Master Reset (Clear) input that overrides, and is independent of, the clock and all other control inputs. The 9LS162 and 9LS163 have a Synchronous Reset (Clear) input that overrides all other control inputs, but is active only during the rising clock edge.

|                    | BCD (Modulo 10) | Binary (Modulo 16) |
|--------------------|-----------------|--------------------|
| Asynchronous Reset | 9LS160          | 9LS161             |
| Synchronous Reset  | 9LS162          | 9LS163             |



V<sub>CC</sub> = Pin 16 GND = Pin 8

- SYNCHRONOUS COUNTING AND LOADING
- TWO COUNT ENABLE INPUTS FOR HIGH SPEED SYNCHRONOUS EXPANSION
- TERMINAL COUNT FULLY DECODED
- EDGE-TRIGGERED OPERATION
- TYPICAL COUNT RATE OF 35 MHz
- FULLY TTL AND CMOS COMPATIBLE

#### **CONNECTION DIAGRAMS** DIP (TOP VIEW)

| , <del>□ -</del> <del>-</del> <del>-</del> <del>-</del> <del>-</del> <del>-</del> <del>-</del> <del>-</del> <del>-</del> <del>-</del> | V <sub>CC</sub> | <b>1</b> 16 |
|---------------------------------------------------------------------------------------------------------------------------------------|-----------------|-------------|
| 2 CP                                                                                                                                  | TC              | <b>1</b> 15 |
| 3 ☐ Po                                                                                                                                | 0               | <b>b</b> 14 |
| 4 🗆 P1                                                                                                                                | Δ <sub>1</sub>  | 13          |
| 5 P2                                                                                                                                  | $\alpha_2$      | 12          |
| 6 ☐ P3                                                                                                                                | Q3              | þ,,         |
| 7 CE                                                                                                                                  | P CET           | <u>۱</u> ۰۰ |
| 8 GN                                                                                                                                  | D PE            | þ۰          |

#### **PIN NAMES**

|                                |                                      | HIGH     | LOW          |  |  |
|--------------------------------|--------------------------------------|----------|--------------|--|--|
| PE                             | Parallel Enable (Active LOW) Input   | 0.6 U.L. | 0.3 U.L.     |  |  |
| P <sub>0</sub> -P <sub>3</sub> | Parallel Inputs                      | 0.5 U.L. | 0.25 U.L.    |  |  |
| CEP                            | Count Enable Parallel Input          | 0.6 U.L. | 0.3 U.L.     |  |  |
| CET                            | Count Enable Trickle Input           | 1.0 U.L. | 0.5 U.L.     |  |  |
| CP                             | Clock (Active HIGH Going Edge) Input | 0.6 U.L. | 0.3 U.L.     |  |  |
| MR                             | Master Reset (Active LOW) Input      | 0.5 U.L. | 0.25 U.L.    |  |  |
| SR                             | Synchronous Reset (Active LOW) Input | 0.5 U.L. | 0.25 U.L.    |  |  |
| $Q_0$ - $Q_3$                  | Parallel Outputs (Note b)            | 10 U.L.  | 5 (2.5) U.L. |  |  |
| TC                             | Terminal Count Output (Note b)       | 10 U.L.  | 5 (2.5) U.L. |  |  |
|                                |                                      |          |              |  |  |

- b. The Output LOW drive factor is 2.5 U.L. for Military (XM) and 5 U.L. for Commercial (XC)

#### STATE DIAGRAM

#### 9LS161 • 9LS163 LOGIC EQUATIONS Count Enable = CEP ● CET ● PE 0-1-2-1-4 TC for 9LS160 & 9LS162 = CET • Q0 • Q1 • Q2 • Q3 TC for 9LS161 & 9LS163 = CET $\circ \Omega_0 \circ \Omega_1 \circ \Omega_2 \circ \Omega_3$ Preset = PE ● CP+ (rising clock edge) Reset = MR (9LS160 & 9LS161) Reset = SR • CP+ (rising clock edge) 12-11-10-10-10 (9LS162 & 9LS163)

NOTE:

LOADING (Note a)

The Flatpak version has the same pinouts (Connection Diagram) as the Dual In-Line Package.

# WESTERN DIGITAL MOS/LSI

FD1771 A/B - 01 - 11

DATA SHEET

#### FLOPPY DISK FORMATTER/CONTROLLER

#### **GENERAL DESCRIPTION**

The FD1771 is a MOS/LSI device that performs the functions of a Floppy Disk Controller/Formatter. The device is designed to be included in the disk drive electronics, and contains a flexible interface organization that accomodates the interface signals from most drive manufactures. The FD1771 is compatible with the IBM 3740 data entry system format.

The processor interface consists of a 8-bit bi-directional bus for data, status, and control word transfers. The FD1771 is set up to operate on a multiplexed bus with other bus-oriented devices.

The FD1771 is fabricated in N-channel Silicon Gate MOS technology and is TTL compatible on all inputs and outputs.

#### **APPLICATIONS**

- o FLOPPY DISK DRIVE INTERFACE
- SINGLE OR MULTIPLE DRIVE
   CONTROLLER/FORMATTER
- 0 NEW MINI-FLOPPY CONTROLLER

#### **FEATURES**

- o SOFT SECTOR FORMAT COMPATIBILITY
- AUTOMATIC TRACK SEEK WITH VERIFICA— TION
- o READ MODE
  Single/Multiple Record Read with Automatic
  Sector Search or Entire Track Read
  Selectable 128 Byte or Variable Length Record
- o WRITE MODE
  Single/Multiple Record Write with Automatic
  Sector Search
  Entire Track Write for Diskette Initialization
- o PROGRAMMABLE CONTROLS
  Selectable Track to Track Stepping Time
  Selectable Head Settling and Head Engage Times
  Selectable Three Phase or Step and Direction and
  Head Positioning Motor Controls
- o SYSTEM COMPATIBILITY
  Double Buffering of Data 8 Bit Bi-Directional Bus for
  Data, Control and status
  DMA or Programmed Data Transfers
  All Inputs and Outputs are TTL Compatible
- No 5VDC Power Supply Required on 11 version



FD1771 SYSTEM BLOCK DIAGRAM FIG 1







FD1771 BLOCK DIAGRAM FIG 3

#### **ORGANIZATION**

The Floppy Disk Formatter block diagram is illustrated on Page 2. The primary sections include the parallel processor interface and the Floppy Disk interface.

Data Shift Register - This 8-bit register assembles serial data from the Read Data input (FDDATA) during Read operations and transfers serial data to the Write Data output during Write operations.

Data Register - This 8-bit register is used as a holding register during Disk Read and Write operations. In Disk Read operations the assembled data byte is transferred in parallel to the Data Register from the Data Shift Register. In Disk Write operations information is transferred in parallel from the Data Register to the Data Shift Register.

When executing the Seek command the Data Register holds the address of the desired Track position. This register can be loaded from the DAL and gated onto the DAL under processor control.

Track Register - This 8-bit register holds the track number of the current Read/Write head position. It is incremented by one every time the head is stepped in (towards track 76) and decremented by one when the head is stepped out (towards track 00). The contents of the register are compared with the recorded track number in the ID field during disk Read,

Write, and Verify operations. The Track Register can be loaded from or transferred to the DAL. This Register should not be loaded when this device is busy.

Sector Register (SR) - This 8-bit register holds the address of the desired sector position. The contents of the register are compared with the recorded sector number in the ID field during disk Read or Write operations. The Sector Register contents can be loaded from or transferred to the DAL. This register should not be loaded when the device is busy.

Command Register (CR) - This 8-bit register holds the command presently being executed. This register should not be loaded when the device is busy unless the execution of the current command is to be overridden. This latter action results in an interrupt. The command register can be loaded from the DAL, but not read onto the DAL.

Status Register (STR) - This 8-bit register holds device Status information. The meaning of the Status bits are a function of the contents of the Command Register. This register can be read onto the DAL, but not loaded from the DAL.

CRC Logic This logic is used to check or to generate the 16-bit Cyclic Redundancy Check (CRC). The polynomial is:  $G(x) = x \stackrel{1}{0} + x \stackrel{1}{1} + x \stackrel{5}{1} + 1$ .

The CRC includes all information starting with the address mark and up to the CRC characters. The CRC register is preset to ones prior to data being shifted through the circuit.

Arithmetic/Logic Unit (ALU) - The ALU is a serial comparator, incrementer, and decrementer and is used for register modification and comparisons with the disk recorded ID field.

AM Detector - The Address Mark detector is used to detect ID, Data, and Index address marks during Read and Write operations.

Timing and Control - All computer and Floppy Disk Interface controls are generated through this logic. The internal device timing is generated from a 2.0 MHz external crystal clock.

#### PROCESSOR INTERFACE

The interface to the processor is accomplished through the eight Data Access Lines (DAL) and associated control signals. The DAL are used to transfer Data, Status, and Control words out of, or into the FD1771. The DAL are three state buffers that are enabled as output drivers when Chip Select (CS) and Read Enable (RE) are active (low logic state) or act as input receivers when CS and Write Enable (WE) are active.

When transfer of data with the Floppy Disk Controller is required by the host processor, the device address is decoded and CS is made low. The least-significant address bits A1 and AO, combined with the signals RE during a Read operation or WE during a Write operation are interpreted as selecting the following registers:

| A1-AØ |   | READ (RE)       | WRITE (WE)       |  |  |  |
|-------|---|-----------------|------------------|--|--|--|
| Ø     | Ø | Status Register | Command Register |  |  |  |
| Ø     | 1 | Track Register  | Track Register   |  |  |  |
| 1     | Ø | Sector Register | Sector Register  |  |  |  |
| 1     | 1 | Data Register   | Data Register    |  |  |  |

During Direct Memory Access (DMA) types of data transfers between the Data Register of the FD1771 and the processor, the Data Request (DRQ) output is used in Data Transfer control. This signal also appears as status bit 1 during Read and Write operations.

On Disk Read operations the Data Request is activated (set high) when an assembled serial input byte is transferred in parallel to the Data Register. This bit is cleared when the Data Register is read by the processor. If the Data Register is read after one or more characters are lost, by having new data transferred into the register prior to processor readout, the Lost Data bit is set in the Status Register. The Read operation continues until the end of sector is reached.

On Disk Write operations the Data Request is activated when the Data Register transfers its contents to the Data Shift Register, and requires a new data byte. It is reset when the Data Register is loaded with new data by the processor. If new data is not loaded at the time the next serial byte is required by the Floppy Disk, a byte of zeroes is written on the diskette and the Lost Data bit is set in the Status Register.

The Lost Data bit and certain other bits in the Status Register will activate the interrupt request (INTRQ). The interrupt line is also activated with normal completion or abnormal termination of all controller operations. The INTRQ signal remains active until reset by reading the Status Register to the processor or by the loading of the Command Register. In addition, the INTRQ is generated if a Force Interrupt command condition is met.

#### FLOPPY DISK INTERFACE

The Floppy Disk interface consists of head positioning controls, write gate controls, and data transfers. A 2.0 MHz  $\pm$  1% square wave clock is required at the CLK input for internal control timing, (may be 1.0 MHz for mini floppy.)

#### **HEAD POSITIONING**

Four commands cause positioning of the Read-Write head (see Command Section). The period of each positioning step is specified by the r field in bits 1 and O of the command word. After the last directional step an additional 10 milliseconds of head settling time takes place. The four programmable stepping rates are tabulated below.

The rates (shown in Table 1) can be applied to a Three Phase Motor or a Step-Direction Motor through the device interface. When the 3PM input is connected to ground the device operates with a three-phase motor control interface, with one active low signal per phase on the three output signals PH1, PH2 and PH3. The stepping sequence, when stepping in, is Phases 1-2-3-1, and when stepping out, Phases 1-3-2-1. Phase 1 is active low after Master Reset. Note: PH3 needs an inverter if used.

The Step-Direction Motor Control interface is activated by leaving input  $\overline{3PM}$  open or connecting it to +5V. The Phase 1 pin  $\overline{PH1}$  becomes a Step pulse of 4 microseconds width. The Phase 2 pin  $\overline{PH2}$  becomes a direction control with a high voltage on this pin indicating a Step In, and a low voltage indicating a Step Out. The Direction output is valid a minimum of 24  $\mu s$  prior to the activation of the Step pulse.

When a Seek, Step or Restore command is executed an optional verification of Read-Write head position can be performed by setting bit 2 in the command word to a logic 1. The verification operation begins at the end of the 10 millisecond settling time after the head is loaded against the media. The track number from the first encountered ID Field is compared against the contents of the Track



Register. If the track numbers compare and the ID Field Cyclic Redundancy Check (CRC) is correct, the verify operation is complete. If track comparison is not made but the CRC checks, an interrupt is generated, the Seek Error status (Bit 4) is set and the Busy status bit is reset.

#### TABLE 1 STEPPING RATES

| r1               | r0               | 1771-X1<br>C <u>LK=2MH</u> Z<br>TEST=1 |                              | 1771 or-X1<br>C <u>LK=2MH</u> Z<br>TEST=0 |                   |
|------------------|------------------|----------------------------------------|------------------------------|-------------------------------------------|-------------------|
| 0<br>0<br>1<br>1 | 0<br>1<br>0<br>1 | 6ms<br>6ms<br>10ms<br>20ms             | 12ms<br>12ms<br>20ms<br>40ms | *APPROX.<br>400us                         | *APPROX.<br>800us |

<sup>\*</sup>For exact times consult WDC.

The Head Load (HLD) output controls the movement of the read/write head against the disk for data recording or retrieval. It is activated at the beginning of a Read, Write (E Flag On) or Verify Operation, or a Seek or Step operation with the head load bit, h, a logic one remains activated until the third index pulse following the last operation which uses the read/write head. Reading or Writing does not occur until a minimum of 10 msec delay after the HLD signal is made active. If executing the type 2 commands with the E flag off, there is no 10 msec delay and the head is assumed to be engaged. The delay is determined by sampling of the Head Load Timing (HLT) input after 10 msec. A high state input, generated from the Head Load output transition and delayed externally, identifies engagement of the head against the disk. In the Seek and Step commands, the head is loaded at the start of the command execution when the h bit is a logic one. In a verify command the head is loaded after stepping to the destination track on the disk whenever the h bit is a logic zero.

#### **DISK READ OPERATION**

The 2.0 MHz external clock provided to the device is internally divided by 4 to form the 500 KHz clock rate for data transfer. When reading data from a diskette this divider is synchronized to transitions of the Read Data (FDDATA) input. When a transition does not occur on the 500 KHz clock active state, the clock divider circuit injects a clock to maintain a continuous 500 KHz data clock. The 500 KHz data clock is further divided by 2 internally to separate the clock and information bits. The divider is phased to the information by the detection of the address mark.

In the internal data read and separation mode the Read Data input toggles from one state to the opposite state for each logic one bit of clock or information. This signal can be derived from the amplified, differentiated, and sliced Read Head signal, or by the output of a flipflop toggling on the Read Data pulses. This input is sampled by the 2 MHz clock to detect transitions.

The chip can also operate on externally separated data, as supplied by methods such as Phase Lock loop, One Shots, or variable frequency oscillators. This is accomplished by grounding the External Data Separator (XTDS) INPUT. When the Read Data input makes a high to-low transition, the information input to the FDDATA line is clocked into the Data Shift Register. The assembled 8 bit data from the Data Shift Register are then transferred to the Data Register.

The normal sector length for Read or Write operations with the IBM 3740 format is 128 bytes. This format or binary multiples of 128 bytes will be adopted by setting a logic 1 in Bit 3 of the Read and Write commands. Additionally, a variable sector length feature is provided which allows an indicator recorded in the ID Field to control the length of the sector. Variable sector lengths can be read or written in Read or Write commands respectively by setting a logic o in Bit 3 of the command word. The sector length indicator specifies the number of 16 byte groups or 16 x N, where N is equal to 1 to 256 groups. An indicator of all zeroes is interpreted as 256 sixteen byte groups.

#### **DISK WRITE OPERATION**

After data is loaded from the processor into the Data Register, and is transferred to the Data Shift Register, data will be shifted serially through the Write Data (WD) output. Interlaced with each bit of data is a positive clock pulse of 0.5  $\mu$ sec duration. This signal may be used to externally toggle a flip-flop to control the direction of Write Current flow.

When writing is to take place on the diskette the Write Gate (WG) output is activated, allowing current to flow into the Read/Write head. As a precaution to erroneous writing the first data byte must be loaded into the Data Register in response to a Data Request from the FD1771 before the Write Gate signal can be activated.

Writing is inhibited when the Write Protect input is a logic low, in which case any Write command is immediately terminated, an interrupt is generated and the Write Protect status bit is set. The Write Fault input, when activated, signifies a writing fault condition detected in disk drive electronics such as failure to detect write current flow when the Write Gate is activated. On detection of this fault the FD1771 terminates the current command, and sets the Write Fault bit (bit 5) in the Status Word. The Write Fault input should be made inactive when the Write Gate output becomes inactive.

Whenever a Read or Write command is received the FD1771 samples the READY input. If this input is logic low the command is not executed and an interrupt is generated. The Seek or Step commands are performed regardless of the state of the READY input.

#### **COMMAND DESCRIPTION**

The FD1771 will accept and execute eleven commands. Command words should only be loaded in the Command Register when the Busy status bit is off (Status bit 0). The one exception is the Force Interrupt command. Whenever a command is being executed, the Busy status bit is set. When a command is completed, an interrupt is generated and the Busy status bit is reset. The Status Register indicates whether the completed command encountered an error or was fault free. For ease of discussion, commands are divided into four types. Commands and types are summarized in table 2.

#### **COMMAND SUMMARY\***

|      |                 |   |   |   |   | В  | ITS |     |                |
|------|-----------------|---|---|---|---|----|-----|-----|----------------|
| TYPE | COMMAND         | 7 | 6 | 5 | 4 | 3  | 2   | 11  | 0              |
| 1    | Restore         | 0 | 0 | 0 | 0 | h  | V   | r1  | r <sub>0</sub> |
| 1    | Seek            | 0 | 0 | 0 | 1 | h  | V   | r1  | r0             |
| 1    | Step            | 0 | 0 | 1 | u | h  | V   | r1  | r <sub>0</sub> |
| 1    | Step In         | 0 | 1 | 0 | u | h  | V   | r1  | r0             |
| 1    | Step Out        | 0 | 1 | 1 | u | h  | V   | r1  | r0             |
| H    | Read Command    | 1 | 0 | 0 | m | b  | Ε   | 0   | 0              |
| 11   | Write Command   | 1 | 0 | 1 | m | b  | Е   | a 1 | a0             |
| 111  | Read Address    | 1 | 1 | 0 | 0 | 0  | 1   | 0   | 0              |
| Ш    | Read Track      | 1 | 1 | 1 | 0 | 0  | 1   | 0   | S              |
| 111  | Write Track     | 1 | 1 | 1 | 1 | 0  | 1   | 0   | 0              |
| IV   | Force Interrupt | 1 | 1 | 0 | 1 | 13 | 12  | 11  | 10             |

#### TABLE 2

\* = Shown in true form.

#### **FLAG SUMMARY**

| Τ | Υ | Ρ | Ε | 1 |
|---|---|---|---|---|
|   |   |   |   |   |

h = Head Load Flag (Bit 3)

h=1, Load head at beginning

h=0, Do not load head at beginning

V = Verify flag (Bit 2)

V=1, Verify on last track

V=0, No verify

r1r0 = Stepping motor rate (Bits 1-0)

Refer to Table 1 for rate summary

u = Update flag (Bit 4)

u=1, Update Track register

u=0, No update

#### TABLE 3

#### TYPE II

m = Multiple Record flag (Bit 4)

m = 0, Single Record

m = 1, Multiple Records

b = Block length flag (Bit 3)

b = 1, IBM format (128 to 1024 bytes)

b = 0, Non-IBM format (16 to 4096 bytes)

a1a0 = Data Address Mark (Bits 1-0)

a1a0 =00, FB (Data Mark)

a1a0 =01, FA (User defined)

a1a0 = 10, F9 (User defined)

a1a0 =11, F8 (Deleted Data Mark)

#### TABLE 4

#### TYPE III

s = Synchronize flag (Bit 0)

s=0, Synchronize to AM

s=1, Do Not Synchronize to AM

#### TYPE IV

li = Interrupt Condition flags (Bits 3-0)

In=1, Not Ready to Ready Transition

I<sub>1</sub>=1, Ready to Not Ready Transition

12=1, Index Pulse

13=1, Immedate interrupt

E = Enable HLD and 10 msec Delay

E=1, Enable HLD, HLT and 10 msec Delay

E=0, Head is assumed Engaged and there is no 10 msec Delay.

#### **TABLE 5**

#### **TYPE 1 COMMANDS**

The Type 1 Commands include the RESTORE, SEEK STEP, STEP-IN, AND STEP-OUT commands. Each of the Type 1 Commands contain a rate field (ror1), which determines the stepping motor rate as defined in Table 1, page four.

The type 1 Commands contain a head load flag (h) which determines if the head is to be loaded at the beginning of the command. If h=1, the head is loaded at the beginning of the command (HLD output is made active). If h=0, HLD is deactivated. Once the head is loaded, the head will remain engaged until the FD1771 receives a command that specifically disengages the head. If the FD1771 does not receive any commands after two revolutions of the disk, the head will be automatically disengaged (HLD made inactive). The Head Load Timing Input is sampled after a 10 ms delay, when reading or writing on the disk is to occur.

The Type 1 Commands also contain a verification (V) flag which determines if a verification operation is to take place on the destination track. If V = 1, a verification is performed, if V = 0, no verification is performed.

During verification, the head is loaded and after an internal 10 ms delay, the HLT input is sampled. When HLT is active (logic true), the first encountered ID field is read off the disk. The track address of the ID field is then compared to the Track Register; if there is a match and a valid ID CRC, the verification is complete, an interrupt is generated and the BUSY status bit is reset. If there is not a match but there is valid ID CRC, an interrupt is generated, the Seek Error status bit (Status bit 4) is set and the BUSY status bit is reset. If there is a match but not a valid CRC, the CRC error status bit is set (Status bit 3), and the next encountered ID field is read from the disk for the verification operation. If an ID field with a valid CRC cannot be found after two revolutions of the disk, the FD1771 terminates the operation and sends an interrupt, (INTRQ).

The STEP, STEP-IN, and STEP-OUT commands contain an UPDATE flag (U). When U=1, the track register is updated by one for each step. When U=0, the track register is not updated.

#### RESTORE (SEEK TRACK 0)

Upon receipt of this command the Track 00 (TROO) input is sampled. If TROO is active low indicating the Read-Write head is positioned over track 0, the Track Register is loaded with zeroes and an interrupt is generated. If TROO is not active low, stepping pulses (pins 15 to 17) at a rate specified by the r1r0 field are issued until the TROO input is activated. At this time the TR is loaded with zeroes and an interrupt is generated. If the

TROO input does not go active low after 255 stepping pulses, the FD1771 terminates operation, interrupts, and sets the Seek error status bit. Note that the RESTORE command is executed when MR goes from an active to an inactive state. A verification operation takes place if the V flag is set. The h bit allows the head to be loaded at the start of command.

#### SEEK

This command assumes that the Track Register contains the track number of the current position of the Read-Write head and the Data Register contains the desired track number. The FD1771 will update the Track register and issue stepping pulses in the appropriate direction until the contents of the Track register are equal to the contents of the data register (the desired track location). A verification operation takes place if the V flag is on. The h bit allows the head to be loaded at the start of the command. An interrupt is generated at the completion of the command.

#### **STEP**

Upon receipt of this command, the FD1771 issues one stepping pulse to the disk drive. The stepping motor direction is the same as in the previous step command. After a delay determined by the r1r0 field, a verification takes place if the V flag is on. If the u flag is on, the TR is updated. The h bit allows the head to be loaded at the start of the command. An interrupt is generated at the completion of the command.





#### STEP-IN

Upon receipt of this command, the FD1771 issues one stepping pulse in the direction towards track 76. If the u flag is on the Track Register is incremented by one. After a delay determined by the  $r_1$   $r_0$  field, a verification takes place if the V flag is on. The h bit allows the head to be loaded at the start of the command. An interrupt is generated at the completion of the command.

#### STEP-OUT

Upon receipt of this command, the FD1771 issues one stepping pulse in the direction towards track 0. If the u flag is on, the TR is decremented by one. After a delay determined by the r1r0 fleld, a verification takes place if the V flag is on. The h bit allows the head to be loaded at the start of the command. An interrupt is generated at the completion of the command.



'NOTE: \*1. IF TEST - D. THERE IS NO 10MS DELAY. 2. IF TROF - 1 AND CLK - 1 MHz, THIS IS A 20MS DELAY.

#### TYPE II COMMANDS

The Type II Commands include the Read Sector (s) and Write Sector (s) commands. Prior to loading the type II command into the COMMAND REGISTER, the computer must load the Sector Register with the desired sector number. Upon receipt of the type II command, the busy status Bit is set. If the E flag = 1 (this is the normal case) HLD is made active and HLT is sampled after a 10 msec delay. If the E flag is0, the head is assumed to be engaged and there is no 10 msec delay. The ID field and Data Field format are shown below:

When an ID field is located on the disk, the FD1771 compares the Track Number of the ID field with the Track register. If there is not a match, the next encountered ID field is read and a comparison is again made. If there was a match, the Sector Number of the ID field is compared with the Sector Register. If there is not a Sector match, the next encountered ID field is read off the disk and comparisons again made. If the ID field CRC is correct, the data field is then located and will be either written into, or read from depending upon the command. The FD1771 must find an Id field with a Track number, Sector number, and CRC within two revolutions of the disk; otherwise, the Record not found status bit is set (Status bit 3) and the command is terminated with an interrupt.

| GAP | ID<br>AM | TRACK<br>NUMBER | ZEROS | SECTOR<br>NUMBER | SECTOR<br>LENGTH | CRC<br>1 | CRC<br>2 | GAP   | DATA<br>AM | DATA FIELD | CRC<br>1 | CRC<br>2 |
|-----|----------|-----------------|-------|------------------|------------------|----------|----------|-------|------------|------------|----------|----------|
|     | ID FIELD |                 |       |                  |                  |          | DATA     | FIELD |            |            |          |          |

IDAM = ID Address Mark — DATA=(FE)<sub>16</sub> CLK = (C7)<sub>16</sub>
Data AM = Data Address Mark — DATA=(F8, F9, FA, or FB), CLK = (C7)<sub>16</sub>



Each of the Type II Commands contain a (b) flag which in conjunction with the sector length field contents of the ID determines the length (number of characters) of the Data field.

For IBM 3740 compatibility, the b flag should equal 1. The numbers of bytes in the data field (sector) is then 128 x  $2^n$  where n - 0,1,2,3.

For b=1

| Sector Length<br>Field (hex) | Number of bytes in sector (decimal) |
|------------------------------|-------------------------------------|
| 00                           | 128                                 |
| 01                           | 256                                 |
| 02                           | 512                                 |
| 03                           | 1024                                |

When the b flag equals zero, the sector length field (n) multiplied by 16 determines the number of bytes in the sector or data field as shown below:

For b = 0

| Sector Length Field (hex) | Number of bytes in sector (decimal) |
|---------------------------|-------------------------------------|
| 01                        | 16                                  |
| 02                        | 32                                  |
| 03                        | 48                                  |
| 04                        | 64                                  |
| •                         | •                                   |
| •                         | •                                   |
| •                         | •                                   |
| FF                        | 4080                                |
| 00                        | 4096                                |

Each of the type II commands also contain a (m) flag which determines if multiple records (sectors) are to be read or written, depending upon the command. If m=o a single sector is read or written and an interrupt is generated at the completion of the command. If m=1, multiple records are read or written with the sector register internally updated so that an address verification can occur on the next record. The FD1771 will continue to read or write multiple records and update the sector register until the sector register exceeds the number of sectors on the track or until the Force Interrupt command is loaded into the command register, which terminated the command and generates an interrupt.



\*1. IF TEST = 0, THERE IS NO 10MS DELAY.

2. IF TEST = 1 AND CLK = 1 MHz. THIS IS A 20MS DELAY.



#### **READ COMMAND**

Upon receipt of the Read command, the head is loaded, the BUSY status bit set, and when an ID field is encountered that has the correct track number, correct sector number, and correct CRC, the data field is presented to the computer. The Data Address Mark of the data field must be found within 28 bytes of the correct field; if not, the Record Not Found status bit is set and the operation is terminated. When the first character or byte of the data field has been shifted through the DSR, it is transferred to the DR, and DRQ is generated. When the next byte is accumulated in the DSR, it is transferred to the DR and another DRQ is generated. If the Computer has not read the previous contents of the DR before a new character is transferred that character is lost and the Lost Data Status bit is set. This sequence continues until the complete data field has been inputted to the computer. If there is a CRC error at the end of the data field, the CRC error status bit is set, and the command is terminated (even if it is a multiple record command).

At the end of the Read operation, the type of Data Address Mark encountered in the data field is recorded in the Status Register (Bits 5 and 6) as shown below:

| Status | Status | Data AM |
|--------|--------|---------|
| Bit 5  | Bit 6  | (HEX)_  |
| 0      | 0      | FB      |
| 0      | 1      | FA      |
| 1      | 0      | F9      |
| 1      | 1      | F8      |



#### **WRITE COMMAND**

Upon receipt of the Write command, the head is loaded (HLD active) and the Busy status bit is set. When an ID field is encountered that has the correct track number, correct sector number, and correct CRC, a DRQ is generated. The FD1771 counts off 11 bytes from the CRC field and the Write Gate (WG) output is made active if the DRQ is serviced (i.e., the DR has been loaded by the computer). If DRQ has not been serviced, the command is terminated and the Lost Data status bit is set. If the DRQ has been serviced, the WG is made active and six bytes of zeros are then written on the disk. At this time the Data Address Mark is then written on the disk as determined by the a 1a0field of the command as shown below:

| <u>a1</u> | <u>a0</u> | DATA MARK<br>(HEX) | CLOCK MARK<br>(HEX) |
|-----------|-----------|--------------------|---------------------|
| 0         | 0         | FB                 | ,C7                 |
| 0         | 1         | FA                 | C7                  |
| 1         | 0         | F9                 | C7                  |
| 1         | 1         | F8                 | C7                  |

The FD1771 then writes the data field and generates DRQ's to the computer. If the DRQ is not serviced in time for continuous writing the Lost Data Status Bit is set and a byte of zeros is written on the disk. The command is not terminated. After the last data byte has been written on the disk, the two-byte CRC is computed internally and written on the disk followed by one byte gap of logic ones. The WG output is then deactivated.



#### **TYPE III COMMANDS**

#### **READ ADDRESS**

Upon receipt of the Read Address command, the head is loaded and the BUSY Status Bit is set. The next encountered ID field is then read in from the disk, and the six data bytes of the ID field are assembled and transferred to the DR, and a DRQ is generated for each byte. The six bytes of the ID field are shown below:

|   | TRACK<br>ADDR | ZEROS | SECTOR<br>ADDRESS | SECTOR<br>LENGTH | CRC<br>1 | CRC<br>2 |
|---|---------------|-------|-------------------|------------------|----------|----------|
| į | 1             | 2     | 3                 | 4                | 5        | 6        |

Although the CRC characters are transferred to the computer, the FD1771 checks for validity and the CRC error status bit is set if there is a CRC error. The Sector Address of the ID field is written into the sector register. At the end of the operation an interrupt is generated and the BUSY Status is reset.

#### **READ TRACK**

Upon receipt of the Read Track command, the head is loaded and the BUSY Status bit is set. Reading starts with the leading edge of the first encountered index mark and continues until the next index pulse. As each byte is assembled it is transferred to the Data Register and the Data Request is generated for each byte. No CRC checking is performed. Gaps are included in the input data stream. If bit O (S) of the command is a 0, the accumulation of bytes is synchronized to each Address Mark encountered. Upon completion of the command, the interrupt is activated.

#### WRITE TRACK

Upon receipt of the Write Track command, the head is loaded and the BUSY Status bit is set. Writing starts with the leading edge of the first encountered index pulse and continues until the next index pulse, at which time the interrupt is activated. The Data Request is activated immediately upon recieving the command, but writing will not start until after the first byte has been loaded into the Data Register. If the DR has not been loaded by the time the index pulse is encountered the operation is terminated making the device Not Busy, the Lost Data Status Bit is set, and the Interrupt is activated. If a byte is not present in the DR When needed, a byte of zeros is substituted. Address Marks and CRC characters are written on the disk by detecting certain data byte patterns in the outgoing data stream as shown in the table below. The CRC generator is initialized when any data byte from F8 to FE is about to be transferred from the DR to the DSR.

#### CONTROL BYTES FOR INITIALIZATION

| DATA<br>PATTERN<br>(HEX) | INTERPRETATION   | CLOCK MARK<br>(HEX) |
|--------------------------|------------------|---------------------|
| F7                       | Write CRC Char.  | FF                  |
| F8                       | Data Addr. Mark  | C7                  |
| F9                       | Data Addr. Mark  | C7                  |
| FA                       | Data Addr. Mark  | C7                  |
| FB                       | Data Addr. Mark  | C7                  |
| FC                       | Index Addr. Mark | D7                  |
| FD                       | Spare            |                     |
| FE                       | ID Addr. Mark    | C7                  |

The Write Track command will not execute if the DINT input is grounded; instead the Write Protect Status bit is set and the interrupt is activated. Note that one F7 pattern generates 2 CRC characters.



FIG. 11 TYPE III COMMAND WRITE TRACK



FIG. 12 TYPE III COMMAND WRITE TRACK

#### **TYPE IV COMMAND**

#### FORCE INTERRUPT

This command can be loaded into the command register at any time. If there is a current command under execution (Busy Status Bit set), the command will be terminated and an interrupt will be generated when the condition specified in the  $I_0$  through  $I_3$  field is detected. The interrupt conditions are shown below:

 $I_0$  = Not-Ready-To-Ready-Transition

I<sub>1</sub> = Ready-To-Not-Ready Transition

I<sub>2</sub> = Every Index Pulse

I<sub>3</sub> = Immediate Interrupt

NOTE: If 1013=0, there is no interrupt generated but the current command is terminated and busy is reset.

### STATUS DESCRIPTION

Upon receipt of any command, except the Force Interrupt command, the BUSY Status bit is set and the rest of the status bits are updated or cleared for the new command. If the Force Interrupt Command is received when there is a current command under execution, the BUSY status bit is reset, and the rest of the status bits are unchanged. If the Force Interrupt command is received when there is not a current command under execution, the BUSY Status bit is reset and the rest of the status bits are updated or cleared. In this case, Status reflects the Type I commands.

The format of the Status Register is shown below:

| (BITS) |     |            |    |     |     |     |    |    |
|--------|-----|------------|----|-----|-----|-----|----|----|
| l      | _ 7 | <u> </u> 6 | 5  | L 4 | 3   | [ 2 | 1  | 0  |
| l      | S7  | \$6        | S5 | S4  | \$3 | S2  | S1 | S0 |

Status varies according to the type of command executed as shown in Table 6.

#### STATUS REGISTER SUMMARY

| BIT | ALL TYPE I<br>COMMANDS | READ ADDRESS | READ        | READ TRACK | WRITE         | WRITE TRACK |
|-----|------------------------|--------------|-------------|------------|---------------|-------------|
| S7  | NOT READY              | NOT READY    | NOT READY   | NOT READY  | NOT READY     | NOT READY   |
| S6  | WRITE PROTECT          | 0            | RECORD TYPE | 0          | WRITE PROTECT | WRITE       |
|     |                        |              |             |            |               | PROTECT     |
| S5  | HEAD ENGAGED           | 0            | RECORD TYPE | 0          | WRITE FAULT   | WRITE FAULT |
| S4  | SEEK ERROR             | ID NOT       | RECORD NOT  | 0          | RECORD NOT    | 0           |
|     |                        | FOUND        | FOUND       |            | FOUND         |             |
| S3  | CRC ERROR              | CRC ERROR    | CRC ERROR   | 0          | CRC ERROR     | 0           |
| S2  | TRACK 0                | LOST DATA    | LOST DATA   | LOST DATA  | LOST DATA     | LOST DATA   |
| S1  | INDEX                  | DRQ          | DRQ         | DRQ        | DRQ           | DRQ         |
| S0  | BUSY                   | BUSY         | BUSY        | BUSY       | BUSY          | BUSY        |
|     |                        |              |             |            |               |             |

TABLE 6

## STATUS FOR TYPE I COMMANDS

| BIT NAME       | MEANING                                                                                                                                                                            |
|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| S7 NOT READY   | This bit when set indicates the drive is not ready. When reset it indicates that the drive is ready. This bit is an inverted copy of the READY input and logically 'ored' with MR. |
| S6 PROTECTED   | When set, indicates Write Protect is activated. This bit is an inverted copy of $\overline{\text{WRPT}}$ input.                                                                    |
| S5 HEAD LOADED | When set, it indicates the head is loaded and engaged. This bit is a logical "and" of HLD and HLT signals.                                                                         |
| S4 SEEK ERROR  | When set, the desired track was not verified. This bit is reset to 0 when updated.                                                                                                 |
| S3 CRC ERROR   | When set, there was one or more CRC errors encountered on an unsuccessful track verification operation. This bit is reset to 0 when updated.                                       |
| S2 Track 00    | When set, indicates $\underline{\text{Read}}$ Write head is positioned to Track 0. This bit is an inverted copy of the $\overline{\text{TROO}}$ input.                             |
| S1 INDEX       | When <u>set</u> , indicates index mark detected from drive. This bit is an inverted copy of the IP input.                                                                          |
| S0 BUSY        | When set command is in progress. When reset no command is in progress.                                                                                                             |

## STATUS BITS FOR TYPE II AND III COMMANDS

| BIT NAME                         | MEANING                                                                                                                                                                                                                                            |
|----------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| S7 NOT READY                     | This bit when set indicates the drive is not ready. When reset, it indicates that the drive is ready. This bit is an inverted copy of the READY input and 'ored' with MR. The TYPE II and III Commands will not execute unless the drive is ready. |
| S6 RECORD TYPE/<br>WRITE PROTECT | On read Record: In indicates the MSB of record-type code from data field address mark. On Read Track: Not Used. On any Write Track: It indicates a Write Protect. This bit is reset when updated.                                                  |
| S5 RECORD TYPE/<br>WRITE FAULT   | On Read Record: It indicates the LSB of record-type code from data field address mark. On Read Track: Not Used. On any Write Track: It indicates a Write Fault. This bit is reset when updated.                                                    |
| S4 RECORD NOT<br>FOUND           | When set, it indicates that the desired track and sector were not found. This bit is reset when updated.                                                                                                                                           |
| S3 CRC ERROR                     | If S4 is set, an error is found in one or more ID fields; otherwise it indicates error in data field. This bit is reset when updated.                                                                                                              |
| S2 LOST DATA                     | When set, it indicates the computer did not respond to DRQ in one byte time. This bit is reset to zero when updated.                                                                                                                               |
| S1 DATA REQUEST                  | This bit is a copy of the DRQ output. When set, it indicates the DR is full on a Read operation or the DR is empty on a Write operation. This bit is reset to zero when updated.                                                                   |
| S0 BUSY                          | When set, command is under execution. When reset, no command is under execu-                                                                                                                                                                       |

tion.

#### FORMATTING THE DISK

(Refer to section on Type III commands for flow diagrams.)

Formatting the disk is a relatively simple task when operating programmed I/0 or when operating under DMA control with a large amount of memory. When operating under DMA with limited amount of memory, formatting is a more difficult task. This is because gaps as well as data must be provided at the computer interface.

Formatting the disk is accomplished by positioning the R/W head over the desired track number and issuing the Write Track command. Upon receipt of the Write Track command, the FD 1771 raises the data request signal. At this point in time, the user loads the data register with desired data to be written on the disk. For every byte of information to be written on the disk, a data request is generated. This sequence continues from one index mark to the next index mark. Normally, whatever data pattern appears in the data register is written on the disk with a clock mark of (FF)<sub>16</sub>. However, if the FD1771 detects a data pattern on F7 thru FE in the data register, this is interpreted as data address marks with missing clocks or CRC generation. For instance, an FE pattern will be interpreted as an ID address mark (DATA-FE, CLK-C7) and the CRC will be initialized. An F7 pattern will generate two CRC characters. As a consequence, the patterns F7 thru FE must not appear in the gaps, data fields, or ID fields. Also, CRC's must be generated by a F7 pattern.

Disks may be formatted in IBM 3740 formats with sector lengths of 128, 256, 512, or 1024 bytes, or may be formatted in non-IBM 3740 with sectors length of 16 to 4096 bytes in 16 byte increments. IBM 3740 at the present time only defines two formats. One format with 128 bytes/sector and the other with 256 bytes/sector. The next section deals with the IBM 3740 format with 128 bytes/sector and the following section details non-IBM formats.

#### IBM 3740 FORMATS - 128 BYTES/SECTOR

Shown in Figure 13, is the IBM format with 128 bytes/sector. In order to format this format, the user must issue the Write Track command, and load the data register with the following values. For every byte to be written, there is one data request.

| HEX VALUE OF              |
|---------------------------|
| BYTE WRITTEN              |
| 00 or FF                  |
| 00                        |
| FC (Index Mark)           |
| 00 or FF                  |
| 00                        |
| FE (ID Address Mark)      |
| Track Number (0 thru 4C)  |
| 00                        |
| Sector Number (1 thru 1A) |
| 00                        |
| F7 (2 CRC's written)      |
| 00 or FF                  |
| 00                        |
| FB (Data Address Mark)    |
| Data (IBM uses E5)        |
| F7 (2 CRC's written)      |
| 00 or FF                  |
| 00 or FF                  |
|                           |

- Write bracketed field 26 times
- \*\* Continue writing until FD1771 interrupts out. Approx. 247 bytes.



#### **NON-IBM FORMATS**

Non IBM Formats are very similar to the IBM formats except a different algorithum is used to ascertain the sector length from the sector length byte in the ID field. This permits a wide range of sector lengths from 16 to 4096 bytes. Refer to section V, Type II commands with b flag equal to zero. Note that F7 thru FE must not appear in the sector length byte of the ID field.

In formatting the FD1771, only two requirements regarding GAP sizes must be met. GAP 2 (i.e., the gap between the ID field and data field)must be 17 bytes of which the last 6 bytes must be zero and that every address mark be preceded by at least one byte of zeros. However, it is recommended that every GAP be at least 17 bytes long with 6 bytes of zeros. The FD1771 does not require the index address mark (i.e., DATA = FC, CLK = D7) and need not be present.

#### References:

- 1) IBM Diskette OEM Information GA21-9190-1
- 2) SA900 IBM Compatibility Reference Manual Shugart Associates.

FIG.13 TRACK FORMAT



#### **ELECTRICAL CHARACTERISTICS**

#### **MAXIMUM RATINGS**

| V <sub>DD</sub> With Respect to V <sub>BB</sub> (Ground) | +20  to - 0.3 V   |
|----------------------------------------------------------|-------------------|
| Max Voltage to Any Input With Respect to VBB             | +20  to  -0.3 V   |
| Operating Temperature                                    | 0°C to 70°C       |
| Storage Temperature                                      | - 55°C to + 125°C |

#### **OPERATING CHARACTERISTICS (DC)**

 $T_A = \emptyset$ °C to  $7\emptyset$ °C,  $V_{DD} = +12.\emptyset V \pm .6V$ ,  $V_{BB}^* = -5.\emptyset \pm .5V$ ,  $V_{SS} = \emptyset V$ ,  $V_{CC} = +5V \pm .25V$  $V_{DD} = 10$  ma Nominal,  $V_{CC} = 30$  ma Nominal,  $V_{BB}^* = 0.4$  µa Nominal

| SYMBOL          | CHARACTERISTIC                    | MIN | TYP | MAX    | UNITS | CONDITIONS                         |
|-----------------|-----------------------------------|-----|-----|--------|-------|------------------------------------|
| ILI             | Input Leagage                     |     |     | 10     | μΑ    | V <sub>IN</sub> = V <sub>DD</sub>  |
| ILO             | Output Leakage                    | 1   |     | 10     | μΑ    | V <sub>OUT</sub> = V <sub>DD</sub> |
| V <sub>IH</sub> | Input High Voltage                | 2.6 |     |        | V     |                                    |
| VIL             | Input Low Voltage<br>(All Inputs) |     |     | 0.8    | V     |                                    |
| VOH             | Output High Voltage               | 2.8 |     |        | V     | I <sub>0</sub> = -100 uA           |
| VOL             | Output Low Voltage                |     |     | 0.45** | V     | I <sub>O</sub> = 1.6 mA            |

NOTE: Vol ≤ .4V when interfacing with low Power Schottky parts (Io<1 ma) \*\*Write Gate VOL≤0.5V

#### TIMING CHARACTERISTICS

 $T_A = \emptyset \circ C$  to 70°C,  $V_{DD} = +12V \pm .6V$ ,  $V_{BB}^* = -5 \pm .25V$ ,  $V_{SS} = \emptyset V$ ,  $V_{CC} = +5 \pm .25V$ 

NOTE: Timings are given for 2 MHZ Clock. For those timings noted, values will double when chip is operated at 1 MHZ. Use 1 MHZ when using mini-floppy.

Read Operations \*VBB required for -01 version only. Pin 1 (VBB) is left open on -11 version.

| SYMBOL                | CHARACTERISTIC                                              | MIN              | TYP | MAX         | UNITS                | CONDITIONS              |
|-----------------------|-------------------------------------------------------------|------------------|-----|-------------|----------------------|-------------------------|
| TSET<br>THLD<br>TRE   | Setup ADDR & CS to RE Hold ADDR & CS from RE RE Pulse Width | 100<br>10<br>500 |     |             | nsec<br>nsec<br>nsec | 0 25 - 4                |
| TDRR<br>TIRR<br>TDACC | DRQ Reset from RE INTRQ Reset from RE Data Access from RE   | 300              |     | 500<br>3000 | nsec<br>nsec         | C <sub>L</sub> = 25 pf  |
| TDOH                  | Data Hold From RE                                           | 50               |     | 450<br>150  | nsec                 | Cլ= 25 pf<br>Cլ = 25 pf |



NOTE: 1. CS MAY BE PERMANENTLY TIED LOW IF DESIRED.
2. FOR READ TRACK COMMAND, THIS TIME MAY BE 12° TO 32°µSEC WHEN S = 0.

\*TIME DOUBLES WHEN CLK -- 1MHz.

| Write Operatio                  | ns                                                                                                                                   |                                |     |             |                                              |            |
|---------------------------------|--------------------------------------------------------------------------------------------------------------------------------------|--------------------------------|-----|-------------|----------------------------------------------|------------|
| SYMBOL                          | CHARACTERISTIC                                                                                                                       | MIN                            | TYP | MAX         | UNITS                                        | CONDITIONS |
| TSET THLD TWE TDRR TIRR TDS TDH | Setup ADDR & CS to WE Hold ADDR & CS from WE WE Pulse Width DRQ Reset from WE INTRQ Reset from WE Data Setup to WE Data Hold from WE | 100<br>10<br>350<br>250<br>150 |     | 500<br>3000 | nsec<br>nsec<br>nsec<br>nsec<br>nsec<br>nsec | See Note   |



NOTE: 1. CS MAY BE PERMANENTLY TIED LOW IF DESIRED.
2. WHEN WRITING DATA INTO SECTOR, TRACK, OR DATA REGISTER,
USER CANNOT READ THIS REGISTER UNTIL AT LEAST BASEC AFTER THE
RISING EDGE OF WE WHEN WRITING INTO THE COMMAND REGISTER,
STATUS IS NOT VALID UNTIL SOME 12 ASEC LATER. THESE TIMES ARE
DOUBLED WHEN CLK = 1 MHz.

\* = TIME DOUBLES WHEN CLK = 1 MHz.

External Data Separation (XTDS = 0)

|   | SYMBOL | CHARACTERISTIC        | MIN  | TYP | MAX | UNITS | CONDITIONS |
|---|--------|-----------------------|------|-----|-----|-------|------------|
| Ī | TPWX   | Pulse Width Rd Data & | 150  |     | 350 | nsec  |            |
|   |        | Rd Clock              |      |     |     |       |            |
| Į | TCX    | Clock Cycle Ext       | 2500 |     |     | nsec  |            |
|   | TDEX   | Data to Clock         | 500  |     |     | nsec  |            |
|   | TDDX   | Data to Data Cycle    | 2500 |     |     | nsec  |            |

**READ TIMING** 

XTDS = 0 EXTERNAL DATA SEPARATION NOTE: FDCLK & FDDATA may be reversed FD1771 decides what is clock and what is data



Internal Data Separation (XTDS = 1)

| SYMBOL      | CHARACTERISTIC                                   | MIN         | TYP | MAX          | UNITS        | CONDITIONS |
|-------------|--------------------------------------------------|-------------|-----|--------------|--------------|------------|
| TPWI<br>TCI | Pulse Width Data & Clock<br>Clock Cycle Internal | 150<br>3500 |     | 1000<br>5000 | nsec<br>nsec |            |

READ TIMING

XTDS≈1 INTERNAL DATA SEPARATION FDCLOCK MUST BE TIED HIGH



NOTE: INTERNAL DATA SEPARATION MAY WORK FOR SOME APPLICATIONS. HOWEVER, FOR APPLICATIONS REQUIRING HIGH DATE RECOVERY RELIABILITY, WDC RECOMMENDS EXTERNAL DATA SEPARATION BE USED.

Write Data Timing:

| SYMBOL | CHARACTERISTIC          | MIN | TYP  | MAX | UNITS | CONDITIONS                         |
|--------|-------------------------|-----|------|-----|-------|------------------------------------|
| TWGD   | Write Gate to Data      |     | 1200 |     | nsec  | 300 nsec ±<br>CLK tolerance        |
| TPWW   | Pulse Width Write Data  | 500 |      | 600 | nsec  |                                    |
| TCDW   | Clock to Data           |     | 2000 |     | nsec  | ±0.5%±                             |
| TCW    | Clock Cycle Write       |     | 4000 |     | nsec  | CLK tolerance ±0.5%± CLK tolerance |
| TWGH   | Write Gate Hold to Data | 0   |      | 100 | nsec  |                                    |

WRITE DATA TIMING



| Miscal   | laneous  | lir | nına. |
|----------|----------|-----|-------|
| 14113061 | iuiicous |     |       |

| SYMBOL                                                  | CHARACTERISTIC                                                                                                               | MIN                                  | TYP | MAX  | UNITS                              | CONDITIONS                                               |
|---------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------|--------------------------------------|-----|------|------------------------------------|----------------------------------------------------------|
| TCD <sub>1</sub> TCD <sub>2</sub> TSTP TDIR TMR TIP TWF | Clock Duty Clock Duty Step Pulse Output Dir Setup to Step Master Reset Pulse Width Index Pulse Width Write Fault Pulse Width | 175<br>210<br>3800<br>24<br>10<br>10 |     | 4200 | nsec nsec nsec usec usec usec usec | 2MHZ ± 1% See Note  These times doubled when CLK = 1 MHZ |

#### MISCELLANEOUS TIMING





#### **PIN OUTS**

| PIN NO.       | PIN NAME       | SYMBOL                            | <u>FUNCTION</u>                                                                                                                                                                                                                                                             |
|---------------|----------------|-----------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1<br>20<br>21 | Power Supplies | V <sub>BB</sub> /NC<br>VSS<br>VCC | - 5V for - 01 version/open for - 11 version<br>Ground<br>+5V                                                                                                                                                                                                                |
| 40            |                | <u>VDD</u>                        | +12V                                                                                                                                                                                                                                                                        |
| 19            | MASTER RESET   | MR •                              | A logic low on this input resets the device and loads "03" into the command register. The Not Ready (Status Bit 7) is reset during MR ACTIVE. When MR is brought to a logic high a Restore Command is executed, regardless of the state of the Ready signal from the drive. |

| PIN NO         | PIN NAME                                   | SYMBOL    | FUNCTION                                                                                                                                                                                                                                                                                         |
|----------------|--------------------------------------------|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Computer Inte  | rface:                                     |           | <del> </del>                                                                                                                                                                                                                                                                                     |
| 7-14           | DATA ACCESS LINES                          | DALØ-DAL7 | <ul> <li>Eight bit inverted Bidirectional bus used for transfer<br/>of data, control, and status. This bus is a receiver<br/>enabled by WE or a transmitter enabled by RE.</li> </ul>                                                                                                            |
| 3              | CHIP SELECT                                | CS        | <ul> <li>A logic low on this input selects the chip and enables<br/>computer communication with the device.</li> </ul>                                                                                                                                                                           |
| 5,6            | REGISTER SELECT LINES                      | A0, A1    | These inputs select the register to receive/transfer data on the DAL lines under RE and WE control:     A1                                                                                                                                                                                       |
| 4              | READ ENABLE                                | RE        | •A logic low on this input controls the placement of data from a selected register on the DAL when $\overline{\text{CS}}$ is low.                                                                                                                                                                |
| 2              | WRITE ENABLE                               | WE        | <ul> <li>A logic low on this input gates data on the DAL into<br/>the selected register when CS is low.</li> </ul>                                                                                                                                                                               |
| 38             | DATA REQUEST                               | DRQ       | •This open drain output indicates that the DR contains assembled data in Read operations, or the DR is empty in Write operations. This signal is reset when serviced by the computer through reading or loading the DR in Read or Write operation, respectively. Use 10K pull-up resistor to +5. |
| 39             | INTERRUPT REQUEST                          | INTRQ     | •This open drain output is set at the completion or termination of any operation and is reset when a new command is loaded into the command register. Use 10K pull-up resistor to +5.                                                                                                            |
| 24             | CLOCK                                      | CLK       | •This input requires a free-running 2 MHz $\pm$ 1% square wave clock for internal timing reference.                                                                                                                                                                                              |
| Floppy Disk In |                                            |           |                                                                                                                                                                                                                                                                                                  |
| 25             | EXTERNAL DATA SEPARATION                   | XTDS      | <ul> <li>A logic low on this input selects external data<br/>separation. A logic high or open selects the internal<br/>data separator.</li> </ul>                                                                                                                                                |
| 26             | FLOPPY DISK CLOCK<br>(External Separation) | FDCLOCK   | •This input receives the externally separated clock when XTDS = 0. If XTDS = 1, this input should be tied to a logic high.                                                                                                                                                                       |
| 27             | FLOPPY DISK DATA                           | FDDATA    | •This input receives the raw read disk data if $\overline{XTDS} = 1$ , or the externally separated data if $\overline{XTDS} = 0$ .                                                                                                                                                               |
| 31             | WRITE DATA                                 | WD        | <ul> <li>This output contains both clock and data bits of 500<br/>ns duration.</li> </ul>                                                                                                                                                                                                        |
| 28             | HEAD LOAD                                  | HLD       | •The HLD output controls the loading of the Read-                                                                                                                                                                                                                                                |
| 23             | HEAD LOAD TIMING                           | HLT       | Write head against the media. The HLT input is sam-<br>led after 10 ms. When a logic high is sampled on the<br>HLT input the head is assumed to be engaged.                                                                                                                                      |
| 15             | Phase 1/Step                               | PH1/STEP  | •If the 3PM input is a logic low the three phase motor                                                                                                                                                                                                                                           |
| 16             | Phase 2/Direction                          | PH2/DIRC  | control is selected and PH1, PH2, and PH3 outputs form a one active low signal out of three. PH1 is ac-                                                                                                                                                                                          |
| 17             | Phase 3                                    | PH3       | tive low after $\overline{\text{MR}}$ . If the $\overline{\text{3PM}}$ input is a logic high the step and direction motor control is selected. The step                                                                                                                                          |
| 18             | 3 Phase Motor Select                       | 3PM       | output contains a 4µsec high signal for each step and the direction output is active high when stepping in; active low when stepping out.                                                                                                                                                        |



| PIN NO.; | PIN NAME,             | SYMBOL, | FUNCTION                                                                                                                                                                                                                                                                                                                                                               |
|----------|-----------------------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 29       | Track Greater Than 43 | TG43    | <ul> <li>This output informs the drive that the Read-Write<br/>head is positioned between track 44-76. This output is<br/>valid only during Read and Write Commands.</li> </ul>                                                                                                                                                                                        |
| 30       | WRITE GATE            | WG      | <ul> <li>This output is made valid when writing is to be performed on the diskette.</li> </ul>                                                                                                                                                                                                                                                                         |
| 32       | Ready                 | READY   | •This input indicates disk readiness and is sampled<br>for a logic high before Read or Write commands are<br>performed. If Ready is low the Read or Write opera-<br>tion is not performed and an interrupt is generated. A<br>Seek operation is performed regardless of the state<br>of Ready. The Ready input appears in inverted format<br>as Status Register bit 7. |
| 33       | WRITE FAULT           | WF      | •This input detects writing faults indications from the drive. When WG = 1 and WF goes low the current Write command is terminated and the Write Fault status bit is set. The WF input should be made inactive (high) when WG becomes inactive.                                                                                                                        |
| 34       | TRACK 00              | TR00    | <ul> <li>This input informs the FD1771 that the Read-Write<br/>head is positioned over Track 00 when a logic low.</li> </ul>                                                                                                                                                                                                                                           |
| 35       | INDEX PULSE           | ĪP      | •Input, when low for a minimum of 10 µsec, informs the FD1771 when an index mark is encountered on the diskette.                                                                                                                                                                                                                                                       |
| 36       | WRITE PROTECT         | WPRT    | <ul> <li>This input is sampled whenever a Write Command is<br/>received. A logic low terminates the command and<br/>sets the Write Protect Status bit.</li> </ul>                                                                                                                                                                                                      |
| 37       | DISKINTIALIZATION     | DINT    | •The input is sampled whenever a Write Track command is received. If DINT = 0, the operation is terminated and the Write Protect Status bit is set.                                                                                                                                                                                                                    |
| 22       | TEST                  | TEST    | •This input is used for testing purposes only and should be tied to +5V or left open by the user.                                                                                                                                                                                                                                                                      |

This is a preliminary specification with tentative device parameters and may be subject to change after final product characterization is completed.

Information furnished by Western Digital Corporation is believed to be accurate and reliable. However, no responsibility is assumed by Western Digital Corporation for its use; nor any infringements of patents or other rights of third parties which may result from its use. No license is granted by implication or otherwise under any patent or patent rights of Western Digital Corporation. Western Digital Corporation reserves the right to change said circuitry at any time without notice.



3128 RED HILL AVENUE P.O. BOX 2180 NEWPORT BEACH, CALIFORNIA 92663 TELEPHONE: (714) 557-3550

TWX: 910-595-1139









7-4

OK FOR REV. D

#### FLOPPY DISK INTERFACE PIN FUNCTION LIST

#### INTERFACE-TØ-DISK

#### DISK-TØ-INTERFACE

| RI  | RDY0+    | READY 0         | TELLS 1771 THAT DISK G IS READY      |
|-----|----------|-----------------|--------------------------------------|
| R.  |          | REMDI U         |                                      |
| R2  | RDY1 *   | READY I         | TELLS 1771 THAT DISK 1 IS READY      |
| R3  | INDX0 *  | INDEX 0         | INDEX HARK HAS BEEN ENCOUNTERED ON O |
| R4  | INDX1 *  | INDEX 1         | INDEX MARK HAS BEEN ENCOUNTERED ON 1 |
| R5  | WRPTO*   | WRITE PROTECT 0 | TERMINATES ANY WRITE COMMAND TO 0    |
| R6  | WRPT1+   | WRITE PROTECT 1 | TERMINATES ANY WRITE COMMAND TO 1    |
| R7  | TR00*    | TRACKO O        | HEAD ON DISK O IS AT TRACK O         |
| R8  | TRO1+    | TRACKO 1        | HEAD ON DISK 1 IS AT TRACK O         |
| R9  | WRFLTO*  | WRITE FAULT 0   | TERMINATES ANY WRITE COMMAND TO 0    |
| RIO | WRFLT1 * | WRITE FAULT 1   | TERMINATES ANY WRITE COMMAND TO 1    |
| R11 | RDATO*   | READ DATA 0     | DATA AND CLOCK FROM DISK O           |
| R12 | RDAT1*   | READ DATA 1     | DÁTÁ AND CLOCK FROM DÍSK 1           |
| E27 | SCMP*    | SEEK COMPLETE   | SEEK OR RESTORE OPERATION COMPLETED  |

INTERFACE-TS-CSMPUTER

DATA IN LINE #0

WRITE SPERATION

98 SSTACK STACK SPERATION

GR SUND

INTERRUPT AC KROWLEDGE

#### COMPUTER-TS-INTERFACE

52

54

75

76

77

78

-16V

PSYNC

PDBIN

PWR\*

PRESET + RESET - NOT

#### 1 +8V +8 VØLTS UNREG. 3 XRDY EXTERNAL READY 18 STATBIS\* STATUS DISABLE 2 +16V +16 VØLTS UNREG. 25 PHASE ONE 41 DI2 DATA IN LINE #2 01 27 PWAIT WAIT STATE (MPU) 42 D13 DATA IN LINE #3 ADDRESS LINE #5 29 A5 43 . D17 DATA IN LINE #7 30 ADDRESS LINE #4 A4 FETCH FIRST BYTE. 44 Sñ1 31 A3 ADDRESS LINE #3 45 SEUT SUTPUT SPERATION 35 DATA GUT LINE #1 Del 46 SIMP INPUT SPERATION DATA SUT LINE #0 36 D 50 47 SMEMR MEMORY READ DATA SUT LINE #4 38 D64 48 SHLTA HALT ACKNOWLEDGE 39 DØ5 DATA GUT LINE #5 50 GMD GR SUND 40 DØ6 DATA GUT LINE #6 72 PRDY READY 45 SOUT SUTPUT SPERATION 91 DI4 DATA IN LINE #4 DATA IN LINE #5 46 SINP INPUT SPERATION 92 D15 50 GND GROUND 93 D16 DATA IN LINE #6 51 +BV +8 VØLTS UNREG. 94 D11 DATA IN LINE #1 -16 VOLTS UNREG. 95 DIO

97 S**Ý**8

100 GMD

EXTCLR\* EXTERNAL CLEAR-NOT 96 SINTA

\$080 SYNC LINE

WRITE-NGT

DATA BUS IN

| 79  | <b>A</b> 0 | Address line #0    |
|-----|------------|--------------------|
| 80  | A1         | Address line #1    |
| 81  | A2         | Address line #2    |
| 82  | <b>A</b> 6 | Address line #6    |
| 83  | A7         | Address line #7    |
| 88  | DO2        | Data Out line #2   |
| 89  | DO3        | Data Out line #3   |
| 90  | DO7        | Data Out line #7   |
| 99  | POC*       | Power-On-Clear-Not |
| 100 | GND        | Ground             |

Dip-Switch Functions (switch 1 at top, left is off)

| Switch | Function                                                                                                                                | Off Position  | On Position |
|--------|-----------------------------------------------------------------------------------------------------------------------------------------|---------------|-------------|
| 1      | Device Address Bit 7 Device Address Bit 6 Device Address Bit 5 Device Address Bit 4 Device Address Bit 3 Write Protect Bootstrap Unused | 1             | 0           |
| 2      |                                                                                                                                         | 1             | 0           |
| 3      |                                                                                                                                         | 1             | 0           |
| 4      |                                                                                                                                         | 1             | 0           |
| 5      |                                                                                                                                         | 1             | 0           |
| 6      |                                                                                                                                         | Not Protected | Protected   |
| 7      |                                                                                                                                         | Not Enabled   | Enabled     |

Normal running set-up is all switches off except #7.

#### TARBELL FLOPPY DISK INTERFACE FULL WARRANTY

- 1. Any faulty part which is returned within 6 months after the date of purchase will be replaced at no charge.
- 2. Any floppy disk interface kit which has been assembled, or any factory-assembled floppy disk interface, which does not work correctly, and is returned within 6 months after the date of purchase, will be restored to proper operating condition or replaced without charge.
- 3. Any floppy disk interface not covered by the above condition will be subject to a charge commensurate with the work required, but in no case will exceed \$50.00 without notification of the owner.
- 4. Parts can be returned directly to the address below for replacement. Complete floppy disk interfaces should be returned to the place of purchase. If this is not possible, or if it is very inconvenient, it may be returned to the address below, with proof of purchase.
- 5. Tarbell Electronics assumes no responsibility for consequential damages to other connected equipment, or for time lost, or programs lost because of interface malfunction.
- 6. If you are disatisfied with the operation of a Tarbell floppy disk interface, for any reason, your money will be cheerfully refunded, provided the unit is returned within the six month warranty period.
- 7. Tarbell Electronics does not warrant that the disk interface will work with all "S-100" computer systems, or with all floppy disk drives. Call the factory or ask your local dealer about any possible conflicts.
- 8. This warranty does not cover parts, or interfaces built from parts, which are not traceable to Tarbell Electronics.

Defective parts or interfaces should be sent to:

Tarbell Electronics 950 Dovlen Place Suite B Carson Ca.90746 If you have problems.....

- 1. Make sure no other peripheral interfaces are addressed at F8-FC.
- 2. If you used sockets, check each & every IC pin to make sure it got into the socket properly, and did not bend under.
- 3. Most return boards have jumper errors, so recheck them all. You may have confused an "E" pad with a feed-through hole.
- 4. Make sure the gold edge-connector on your board is clean, and positioned properly in it's socket. It may be cleaned with an eraser.
- 5. Measure the voltages on the interface and on the drive again; if possible, with a scope to detect ripple or noise.
- 6. Look at the 3 reset lines on the bus, with a scope if possible, and make sure they are a solid HI, with no fast glitches to ground. These are bus pins 75, 99, and 54. Pin 54 (EXTCR) may need a pull-up resistor in some computers, especially those without a front panel.
- 7. Make sure that all the drive power common lines are connected to each other at the power supply end, and that all connections are solid.
- 8. Sometimes the problems appear to be in the interface, but are in reality memory or other problems. Do not trust any of your "super" memory tests. The best way to determine if you have memory problems is to change your memory boards around and see if the problem changes.
- 9. Are you sure your diskette is ok, and you're putting it into the drive correctly? Remember, the CP/M you have may not match your I/O.
- 10. The problem could be in one or MORE of the following areas:
  - 1. Floppy Disk Interface
  - 2. The operator (you)
  - 3. The CPU board
  - 4. The front panel
  - 5. The motherboard
  - 6. Computer Power Supply
- 7. The disk drive
- 8. The disk drive power supply
- 9. The memory
- 10. The disk drive cable
- 11. The diskette
- 12. Another Interface

Just because some or all of these items work under other conditions or "test" good, doesn't mean they will necessarily work right with the interface. Some boards that are supposed to be "S-100" compatible are not necessarily so. Try replacing them one at a time or all at once to isolate the problem to one or more items.

11. If you would like to operate without a front panel, or if the MWRITE line is not generated on some other board in your system, you may generate this signal on the Tarbell FDI board by installing a 7402 and an 8T97 in the spare slots and make these connections:



If you want to use the Tarbell Floppy Disk Interface with a Z-80 CPU board, you will need to either have read-only memory (ROM) somewhere else in your system, or to make the modifications listed below, to boot up properly. This is because most Z-80 CPU boards do not create the same kind of bus signals as the ALTAIR\* or IMSAI CPU boards.

The modifications outlined below will work if the memory board at zero has a phantom line on pin 67, which disables the memory when it is low. Most late-model memory boards have this feature. Where it says "cut", use an exacto blade or other fine cutter to cut the etch on the board, being careful not to damage adjacent lines. Where it says to connect a jumper, you may have to tin the end of the jumper and tack it onto the point, if there is no jumper eyelet there. Many thanks to Siegmar G. Schmidt for these changes.

- 1. Cut the trace from U43 pin 1 to U22 pin 2.
- 2. Cut the trace from U27 pin 12 to U18-1, U18-15, and U19-1. Leave the trace from U27-12 to U26-7.
- 3. Cut the trace from U27 pin 13 to U37 pin 2.
- 4. Cut the trace from U57 pin 14 to board pin 27.
- 5. Connect a jumper from U43 pin 1 to board pin 44.
- 6. Connect a jumper from U59 pin 5 to board pin 47.
- 7. Connect a jumper from U59 pin 6 to U27 pin 13.
- 8. Connect a jumper from U27 pin 11 to U19 pin 15.
- 9. Connect a jumper from U19 pin 14 to ground.
- 10. Connect a jumper from U19 pin 13 to board pin 67.
- 11. Connect a jumper from U57 pin 15 to E36.
- 12. Connect a jumper from U41 pin 4 to U57 pin 14.
- 13. Connect a jumper from E37 to E40 (pull-up).
- 14. Install a 100 pf capacitor at C24.
- 15. Install a 10 kohm 1/4 watt resistor at R34.

<sup>\*</sup>ALTAIR is a trademark/tradename of MITS, Inc.

- The console port numbers used by the SOL conflict with the ones used by the Tarbell Floppy Disk Interface. This will require a change in both the coldstart loader (SBOOT or FBOOT), and in the Basic Input/Output System (CBIOS or FBIOS). We recommend changing the ports from F8 through FC to E8 through EC. If you want to use the on-board ROM, the port numbers in that would have to be changed too. Tarbell Electronics has these ROM's available for \$10.
- 2. There are three main ways that people have used to take care of the bootstrap situation. One way is to put the bootstrap program on cassette tape (relocated above 80 hex), then use the SOL monitor to read it in each time. Another alternative is to use some space in the SOL monitor ROM, such as the space normally used for an unused command. The third way is to get a ROM for our board that has the right port numbers, and then make the changes on our board shown in step 4 below.
- 3. The SOL generates a WAIT cycle for every I/O operation. To correct for this, disconnect pin 13 of U57 on our board.
- Unlike the standard bus, the data input and data output 4. lines are tied together in the SOL. This makes the bootstrap hardware inoperable. To correct for this incompatibility, perform the following steps:
  - Cut the line going from U27 pin 11 to U23 pin 15. a)
  - Connect a jumper from U27 pin 11 to U27 pin 2.
  - Connect a jumper from U27 pin 3 to U23 pin 15. Connect a jumper from U27 pin 1 to U59 pin 6. c)

  - e) Connect a jumper from U59 pin 5 to S-100 bus pin 78.
- 5. E48 should be connected to E46.
- If you use the bootstrap on the Tarbell board, the SOL bootstrap should be disabled.

Many thanks to Don Cole, who worked out these changes.

\*SOL IS A TRADEMARK/TRADENAME OF PROCESSOR TECHNOLOGY, INC.



#### **EDUCATION AND TRAINING DIVISION**

|          | Notes on 1771/Travbell I/o                |
|----------|-------------------------------------------|
|          | •                                         |
|          | Ports                                     |
|          | Board uses Five ports, E8, E9, EA, EB, EC |
|          | E8: Output, 1771 Commands                 |
|          | Input 1771 Status as follows:             |
|          | Bit Function                              |
|          |                                           |
|          | ф - Busy                                  |
|          | 1 - DRQ or Index                          |
| <u> </u> | Z - Track of on Lost DATA                 |
|          | 3 - CRC ERROR                             |
|          | 4 - Seeh ERROR / Record Not found         |
|          | 5 - Head Engaged / WRITE Fault            |
|          | 6 - Writz Project AT DRIVE ONLY           |
|          | 7 - Not Ready                             |
|          | The stand                                 |
|          | E9: Track To/FROM 1771 Frach Register     |
|          | EA: Sector " " Sector "                   |
|          | EB: DATA " " DATA "                       |
|          | EC: Latched I/O Port                      |
|          |                                           |
|          |                                           |
|          |                                           |

#### **EDUCATION AND TRAINING DIVISION**

| Port Ec used as Sellows:                                  |                |  |
|-----------------------------------------------------------|----------------|--|
|                                                           |                |  |
| ON Output:                                                |                |  |
| $\begin{array}{cccccccccccccccccccccccccccccccccccc$      | Not used       |  |
| be comes palse XXXX X \$601 => pad E-14, to Pulse SO (SK) | pout Beaser)   |  |
| XXXX X010 >> Strobe high order 4 bits into                | Lakh U40       |  |
| ON INPUT:                                                 |                |  |
| INPUT FROM THIS PORT CAUSE HARDWARE "WAIT"                |                |  |
| STATE UNTIL INTRA (Interript Rea) OR                      |                |  |
| DROX (DATA REQUEST) go truc.                              |                |  |
|                                                           |                |  |
| U40 is used for the following Sunctions:                  |                |  |
|                                                           |                |  |
| 00 DRIVE   Bit 10 of the Data Bus Becomes                 |                |  |
| 10) DRIVE 2 DRIVE   Select                                | <del>   </del> |  |
| Select Bit 20 of the Data Dus Becomes &                   | bt 2           |  |
| LES DRIVE & Select                                        | · 9···         |  |
| Bit 40 of the Data Bus Becomes                            |                |  |
| The Restore LINE (POC & EX+ C                             | lear also      |  |
| Restore the drive)                                        |                |  |
| Bit 8\$ of the Data Bus is used                           |                |  |
| IN the WAIT Logic (F) to p                                | revent a       |  |
| weit if Not desired cause in wait                         |                |  |
| wait for seek complete instead of D                       |                |  |
| X-21547 ORIG. 7/76                                        | / R15-143      |  |