# TABBLE DOUBLE DENSIT FLOPPY DISK INTERFACE owner's manual 950 DOVLEN PLACE • SUITE B • CARSON, CALIF. 90746 (213) 538-4251 • (213) 538-2254 Tarbell Double Density Floppy Disk Interface # COPYRIGHT (C) 1979,1980 TARBELL ELECTRONICS ALL RIGHTS RESERVED. NO PART OF THIS PUBLICATION MAY BE REPRODUCED, TRANSMITTED, TRANSCRIBED, STORED IN A RETRIEVAL SYSTEM, OR TRANSLATED INTO ANY LANGUAGE OR COMPUTER LANGUAGE, IN ANY FORM OR BY ANY MEANS, ELECTRONIC, MECHANICAL, MAGNETIC, OPTICAL, CHEMICAL, MANUAL OR OTHERWISE, WITHOUT THE PRIOR WRITTEN PERMISSION OF TARBELL ELECTRONICS, 950 DOVLEN PLACE, SUITE B, CARSON, CALIFORNIA, 90746 . The following addendum to the Tarbell Double Density manual provides jumper options involving the Qume DT8 for use with the Double Density interface board. | Drive<br>Desiginator | Drive<br>Option | |----------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------| | C<br>D<br>DC<br>2S | closed<br>open<br>open<br>open | | DS1<br>DS2<br>DS3<br>DS4 | <pre>drive select for A drive select for B } we treat the drive as drive select for C } one big drive for double drive select for D sided operation.</pre> | | T40<br>HA<br>Y<br>DL<br>DS | open open closed open closed | | SHUNT | | | A<br>B<br>X<br>R<br>I<br>Z<br>HL | closed closed open closed closed open open open | All other drive jumpers are left as is from the factory. 1 . # TABLE OF CONTENTS Section Nov 25,1980 | 1 | Introduction | |-----|-------------------------------------| | 2 | Software Integration | | 3 | | | 4 | Detail Theory of Operation | | 4 | Reset Circuit | | | Bootstrap Circuit and listing | | | Address Selection Circuit | | | Disk Control Circuit | | | | | | Direct Memory Access operation | | | Write Precompensation circuit | | | Data Recovery circuit | | 5 | Assembly Instructions | | 6 | Jumper Options | | | Normal Board Setup | | | Address Selection | | | XRDY or PRDY selection | | | Write Precompensation Selection | | | Bootstrap jumper | | | Persci drives | | | Interrupt option | | | Mwrite option | | | 8257 Clock option | | , | 1793 Read Delay option | | | Extra buffer chip | | 7 | Parts List | | 8 | Warranty | | 9 | <u> </u> | | 10 | IEEE S-100 BUS Specification | | | | | | | | 12 | Port and bit definitions | | 1.2 | | | 13 | | | 14 | | | Α | IC Data Silects/ who I carron notes | Description # INTRODUCTION TO THE TARBELL DOUBLE DENSITY FLOPPY DISK INTERFACE The Tarbell Double Density Interface is an IBM soft sector floppy disk interface using the Western Digital 1791/1793 Floppy Disk controller chip and built to the IEEE S-100 Standard. This interface is very similar to the now popular Tarbell Single Density Interface in function, but with many added new features. These features include operation as either single or double density, or both, direct memory access (DMA), and extended memory addressing capability, with processor speeds of either 2 or 4 Mhz. The on-board BOOTSTRAP feature allows full system memory of 64K by using the PHANTHOM line on the bus. Software available to run the double density controller is the widely used CP/M(R) disk operating system, and the new MP/M multi-tasking operating system. Both operating systems use an enhanced I/O system utilizing the new direct memory access capability, and automatic density select features that this product offers. The capacity of the Disk Operating System running under CP/M ver 1.4 in Double Density will be 476 Kbytes per disk, and 243 Kbytes Single Density per disk. These values will double when using Double Sided Drives. Under CPM ver 2.2, the storage capacity of the disk can increase by the use of the deblocking function in the BIOS. Below is a table showing the disk storage that is possible. Single Density Double Density Deblocked 512 x 16 243 Kbytes / side 476 Kbytes / side 600 Kbytes / side It should be noted that the capacities listed above are realized as a result of using the CP/M operating system. If this operating system were not used, then the disk could hold more data, because the disk may be formatted with sectors of 256,512,1024 bytes in length. For further information about this, consult the 1791/1793 data sheet for sector lengths that may be used. Note: CP/M and MP/M are trademark and tradenames of Digital Reaserch Post Office Box 579, Pacific Grove, California 93950. # SECTION 2: GETTING CP/M RUNNING WITH THE INTERFACE One of the major problems confronting the implementers of new micro-computer systems, has been the lack of input/output (I/O) standards. The emergence of Digital Research's CP/M(r) disk operating system as a standard I/O environment has contributed greatly to alleviating this problem. Now the problem is reduced to implementing CP/M on the target hardware system, which consists of tailoring the BIOS part of CP/M to the situation. Unfortunately, since we can't assume any particular console interface at the factory, there is no way to make the system generation completely automatic. Because of all the different possible system configurations, and because we try to update our hardware and software as quickly as possible, it has been difficult to create and maintain a set of documentation that is useful and correct for getting our double-density floppy disk interface working under CP/M. These instructions represent a major rewrite effort in this direction. We hope that most of the faults in the earlier instructions have been corrected in this set. These instructions explain how to get the Tarbell Double Density Floppy Disk Interface going with Digital Research's CP/M 1.4 or 2.x disk operating system. It is important not to try and make more than one change in your system at a time. For example, if you wish to go from our single density interface operating under CP/M 1.4, to our double density interface operating DMA under CP/M 2.2 with a different memory size, DON'T try to do it all at once. First the single-density to double density, then to DMA, then to 2.2, then to different memory size. Be sure that the title of the instructions you are going to use, matches the situation you have. If it doesn't, and you can't seem to find one that does match, call or write to us, and we'll try to help. If you don't think you are capable of carrying out the required instructions yourself, we can generate a customized system for you. Just have us send you an I/O tailoring questionaire. The cost is usually about \$50. #### INSTALLATION NOTES - 1. The MWRITE option available on our board is only for those computers where the MWRITE is not generated directly from the bus signals PWR and SOUT. It is not intended as a substitute for the normal MWRITE line, which must be implemented somewhere on the bus (usually on the CPU or front panel). - 2. Install the double density board as close to the CPU as possible, between the CPU and memory board(s). INSTRUCTIONS FOR GETTING THE TARBELL DOUBLE DENSITY INTERFACE OPERATING WITH CP/M 1.4 WHEN YOU HAVE CP/M 1.4 ALREADY GOING ON A TARBELL SINGLE-DENSITY INTERFACE - First make sure that your situation matches the title above. If it doesn't, find another sheet that does match. - 2. Check the option jumpers on your double-density board against the manual to make sure the board is addressed for EO through F8 (hex), and that all other options are correct. Use your current single-density interface, operating under CP/M 1.4 to do the following steps: - Use the FORMAT91 program on the public domain (provided with the interface) to format at least two disks. DON'T use any of your old format programs to do this. When it says "READY TO FORMAT?" be SURE to get the public domain disk out of there before typing Y. Test the disks using the DISKTEST program. - 4. Put one of the newly formatted disks in drive B. Put a disk with your normal CP/M 1.4 system and system programs in drive A. perform the following steps: - logged into drive A, type SYSGEN. Answer source as a) drive A, destination as drive B. Reboot. - type PIP with no arguments, then the following steps. b) \*B:=A:DDT.COM - \*B:=A:ASM.COM - \*B:=A:SYSGEN.COM - \*B:=A:ED.COM - while still in PIP program, remove your system diskette from drive A, and insert into drive A the Public Domain #2 diskette that came with the double-density interface. continue as shown below: \*B:=A:ABIOS24.ASM - \*B:=A:DBOOT24.ASM - 5. Now take out the public domain disk #2 and put it aside. Take the newly formatted disk out of drive B and put it into drive A. Boot up on it. It should come up normally, since a copy of your system was just put onto it. - 6. Using ED.COM, edit the ABIOS24.ASM to change the EQU's for your memory size, console, printer, drives, etc. Leave the DMACNTL and DUBSID EQU's set to FALSE. Set the MSIZE EQU to the same size as the CP/M 1.4 system you are now running on this disk. Be sure to set the console port numbers correctly. Exit from the editor. Rename the file to ABIOSxx.ASM, where xx is your MSIZE. - 8. Assemble ABIOSxx with ASM.COM. Print the .PRN file if desired, then erase it. - 9. Using ED.COM, edit DBOOT24.ASM. Set the MSIZE EQU to size used above. Leave the DOUBSID, DOUBDEN, and DMACNTL EQU's set to FALSE. Exit from the editor. Rename the file to DBOOTxx.ASM. - 10. Assemble DBOOTxx.ASM with ASM.COM. Print the .PRN file if desired, then erase it. - 11. Use SYSGEN to put a copy of your current CP/M 1.4 system onto the disk as a file. When it asks for source, answer A. When it asks for destination, press carriage-return to reboot. Then do a SAVE 32 CPMxx.COM, where xx is your system size. - 12. Use DDT to bring in the CPMxx.COM file and to overlay the BIOS and BOOT hex files onto it. Type DDT CPMxx.COM. Then type IABIOSxx.HEX. Then type Rbias where bias is in the table below: | 20 D480 24 C480 28 B480 32 | bias | |----------------------------|----------------------| | 36 9480 40 8480 44 7480 48 | A480<br>6480<br>2480 | Now type IDBOOTxx.HEX . Then type R900 . Then do Ctl-C. - 13. Next enter SYSGEN. When it asks for source, press return to skip. When it asks for destination, type A. At this point you may write this system onto more than one disk. After you are finished writing onto the disk(s), DON'T press return to reboot. - 14. You can now shut off your computer, remove the single density interface, and put the double-density interface in. Then turn your computer back on. - 15. The system you have just written onto one or more disks should now boot up correctly on the double-density interface. If it doesn't, check over the BIOS and BOOT .PRN files to make sure all EQU's were set correctly. Check your board to verify again that all the jumper options are right. If you still can't get it going, read section 2-3 of these instructions. - 16. If the system does come up correctly, congratulations! You are now running the double-density interface in non-DMA mode. If you want to operate double-density next, see section 2-2 of these instructions. If you want to try operating in DMA mode, go to step 6 in this section, changing the DMACNTL EQU to TRUE in both the BIOS and the BOOT .ASM files. The rest of the instructions are the same. - 17. Finally, if you notice any errors in this documentation, PLEASE call or write about it. HOW TO MAKE THE TARBELL DOUBLE DENSITY INTERFACE OPERATE IN THE DOUBLE DENSITY MODE ASSUMING YOU HAVE THE DOUBLE DENSITY INTERFACE OPERATING IN THE SINGLE DENSITY MODE. - l. Check your situation against the title above. If it doesn't match, look for other instructions that do. In order to operate in double density mode, you will either need to be operating at 4 or above 4 Mhz (Z80 or 8085), or you need to be operating in DMA mode. To set DMA mode, see step 16 of the instructions in section 2-1. - 2. Format some disks double density with DFORMAT, and test them using $\mathtt{DTEST}_{\:\raisebox{3.5pt}{\text{\circle*{1.5}}}}$ - 3. If you boot up on a single density system which was created using the auto-select I/O section (ABIOS or 2ABIOS), all you have to do is put the formatted double-density diskette in drive B. Files may be transferred to the new double density disk using PIP. Don't try to use the COPY utility to copy from single density to double density or vise-versa. - 4. If you want to put a system from the first two tracks on the single density disk onto a double density disk, SYSGEN alone will not work. This is because the first sector of the first track contains a byte which has to be DD (hex) for double density, and your single-density disk doesn't have that byte. To perform this operation correctly, follow these steps: - a) On your single density disk, edit the file called DBOOTxx.ASM to change the DOUBDEN EQU from FALSE to TRUE. It is important that the MSIZE match your current CP/M system size (xx). b) Assemble the new file: ASM DBOOTxx - c) Do a SYSGEN, answering source on A, skip the destination and reboot. Enter SAVE 34 CPMxx.COM where xx is system size. - d) Then overlay the CPMxx.COM system image with the new DBOOT: DDT CPMxx.COM IDBOOTxx.HEX R900 - e) Then press control-C to return to CP/M. f) Type B:, <cr> to log in drive B. Type A:, <cr>> - g) Then do another SYSGEN, this time skipping the source, and answering B to the destination. (This assumes you still have your double-density disk in B.) - 5. Now you can take the double density disk out of drive B and put it into drive A and boot up on it. # WHAT TO DO IF YOUR TARBELL DOUBLE DENSITY FLOPPY INTERFACE IS NOT WORKING - 1. Recheck the jumper options on the interface board against your manual in section 6. Note that manuals of boards rev B and earlier have an error in the board addressing section. People with these manuals can get a new manual free by sending us the cover of their old manual. - 2. Recheck the EQU's in the BIOS and BOOT .ASM files to make sure that all are set correctly. - 3. If you have a friend with a working Tarbell Double Interface, try using your interface in his computer. If his works and yours doesn't, there is probably something actually wrong with your interface. If so, you might want to consider sending it back to Tarbell for repair. If your interface does work in your friend's computer, the problem might be in your software, or in some other component of your system. Just because the other components of your system work under other circumstances, doesn't mean that there is nothing wrong with them. - 4. Another thing to check is the diskette that you're using. Is it formatted correctly? How do you know it is? - 5. Do you have dynamic memory in your computer. If so, how is it refreshed? It is possible that the way it is refreshed interferes with our interface, or that the way our interface works interferes with the memory's refresh circuitry. - 6. Does your CPU board fully implement the new IEEE S-100 standard? In particular, does it use pin 67 (the phantom line) for anything besides phantom? Does it implement the control-disable, data-disable, and status-disable lines? Does it implement the PSYNC, PHOLD, and PHLDA lines? Neither the SDS SBC-100 or SBC-200 CPU boards meet this requirement. - 7. Does the memory which occupies address 0000 in your system have a phantom line on pin 67? - 8. Do you have other boards in your system that use the XRDY and PRDY lines (pins 3 and 72) besides the Tarbell interface and the CPU? If so, it might be best to disconnect those lines completely. - 9. Since the Tarbell Double Density Floppy Disk Interface uses lines on your motherboard that aren't normally used, some of these lines could be shorted or open, or the connector pins could be dirty. - 10. Check your system power supply, with a scope if possible, to make sure that all your voltages are steady, clean, and the right level, both on the drives and the motherboard. It is very important that on the drive power supply, the 24 volt, 5 volt, and -5 volt returns be connected together at the power supply end. - ll. If you are having problems with the bootstrap, it's possible that C17 is not quite the right value to reduce the effects of ringing on the bus. You might try 100, 220, 390, 470, or 680 pf capacitors, in that order. The symptom is that the bootstrap flip-flop gets reset before it has a chance to read a complete sector if the value of C17 is to too small, or, the bootstrap will not release soon enough if the value of C17 is to big. The value of C17 is not as critical as it may seem, but it's value in some cases will be controlled to some extent by the noise and impedance effects of your computer bus. If you have a good fast scope, you can observe the bootstrap operation by looking at pin 19 on the 8257. This is the DRQ line, and it should be a series of short pulses that happen over a period of about 2 ms. If they don't last that long, you may have to adjust C17. - 12. If the DRQ line mentioned above never goes high at all, that means the interface is never receiving a valid data byte. This could be caused by a variety of factors, including a bad data separator component, bad 1793, bad drive, etc. - $13.\ \mbox{If the interface}$ is picking up excessive errors after warming up, it could be the 1793. We are now testing these IC's more carefully. \*\*\* NOTE \*\*\* If you decide to send the interface back for repair, be sure to include a copy of your receipt, showing the date you bought it. INSTRUCTIONS FOR GETTING THE TARBELL DOUBLE DENSITY INTERFACE OPERATING WITH CP/M 2.x WHEN YOU HAVE CP/M 2.x ALREADY GOING ON A TARBELL SINGLE-DENSITY INTERFACE - 1. First make sure that your situation matches the title above. If it doesn't, find another sheet that does match. - 2. Check the option jumpers on your double-density interface board against the manual to make sure the board is addressed for E0 through F8 (hex), and that all other options are correct. Use your current single density interface, operating under CP/M 2.x to do the following steps: - 3. Use the FORMAT91 program on the public domain #2 disk (provided with the interface) to format at least two disks. DON'T use any of your old format programs to do this. When it says "READY TO FORMAT?" be SURE to get the public domain disk out of there before typing Y. Test the disks using the DISKTEST program. - 4. Put one of the newly formatted disks in drive B. Put a disk with your normal CP/M 2.x system and system programs in drive A. Now perform the following steps: - a) logged into drive A, type SYSGEN. Answer source as drive A, destination as drive B. Reboot. - b) type PIP with no arguments, then the following steps. \*B:=A:CPM.COM \*B:=A:DDT.COM \*B:=A:ASM.COM \*B:=A:SYSGEN.COM \*B:=A:ED.COM c) while still in the PIP program, remove your system diskette from drive A, then insert into drive A the Public Domain #2 diskette that came with the double-density interface. Then continue as shown below: \*B:=A:2ABIOS24.ASM \*B:=A:2DBOOT24.ASM - 5. Now take out the public domain disk #2 and put it aside. Take the newly formatted disk out of drive B and put it into drive A. Boot up on it. It should come up normally, since a copy of your system was just put onto it. - 6. Using ED.COM, edit the 2ABIOS24.ASM to change the EQU's for your memory size, console, printer, drives, etc. Leave the DMACNTL and DUBSID EQU's set to FALSE. Set the MSIZE EQU to the same size as the CP/M 2.x system you are now running on this disk. Be sure to set the console port numbers correctly. If you have Shugart 800 drives, don't set the step rate any faster than 10 ms. Exit from the editor. Rename the file to 2ABIOSxx.ASM, where xx is your MSIZE. - 8. Assemble 2ABIOSxx with ASM.COM. Print the .PRN file if desired, then erase it. - 9. Using ED.COM, edit 2DBOOT24.ASM. Set the MSIZE EQU to the size used above. Leave the DOUBSID and DMACNTL EQU's set to FALSE. Exit from the editor. Rename the file to 2DBOOTxx.ASM. - 10. Assemble 2DBOOTxx.ASM with ASM.COM. Print the .PRN file if desired, then erase it. - 11. Use SYSGEN to put a copy of your current CP/M 2.x system onto the disk as a file. When it asks for source, answer A. When it asks for destination, press carriage-return to reboot. Then do a SAVE 34 CPMxx.COM, where xx is your system size. - 12. Use DDT to bring in the CPMxx.COM file and to overlay the BIOS and BOOT hex files onto it. Type DDT CPMxx.COM. Then type I2ABIOSxx.HEX. Then type Rbias where xx is MSIZE and bias is in the table below: | ХХ | bias | хх | bias | xx | bias | xx | bias | |----|----------------------|----|----------------------|----|----------------------|----|----------------------| | 36 | D580<br>9580<br>5580 | 40 | C580<br>8580<br>4580 | 44 | B580<br>7580<br>3580 | 48 | A580<br>6580<br>2580 | Now type I2DBOOTxx.HEX . Then type R900 . Then do Ctl-C. - 13. Next enter SYSGEN. When it asks for source, press return to skip. When it asks for destination, type A. At this point you may write this system onto more than one disk. After you are finished writing onto the disk(s), DON'T press return to reboot. - 14. You can now shut off your computer, remove the single-density interface, and put the double-density interface in. Then turn your computer back on. - 15. The system you have just written onto one or more disks should now boot up correctly on the double-density interface. If it doesn't, check over the BIOS and BOOT .PRN files to make sure all EQU's were set correctly. Check your board to verify again that all the jumper options are right. If you still can't get it going, read section 2-3 of these instructions. - 16. If the system does come up correctly, congratulations! You are now running the double-density interface in non-DMA mode. If you want to operate double-density next, see section 2-2 of these instructions. If you want to try operating in DMA mode, go to step 6 in this section, changing the DMACNTL EQU to TRUE in both the BIOS and the BOOT .ASM files. The rest of the instructions are the same. - 17. Finally, if you notice any errors in this documentation, PLEASE call or write about it. GETTING THE TARBELL VERSION OF CP/M 1.4 OR 2.X RUNNING ON YOUR TARBELL DOUBLE-DENSITY FLOPPY DISK INTERFACE WITHOUT A CURRENTLY RUNNING CP/M SYSTEM OF ANY KIND - 1. First make sure that your situation matches the title above. If not, you may find that another set of instructions will get your system going sooner. - 2. You need to have the following hardware installed: - a) An assembled and tested Tarbell Double Density Interface - b) At least 24k bytes of random access memory, of which at least the first 32 bytes can be disabled by phantom line pin 67 going low. - c) A Z-80, 8085, or 8080 CPU board which conforms to the IEEE S-100 standard. - d) A console interface of some type, preferably not memory—mapped video, which supports an alphanumeric keyboard and a CRT display or teleprinter. If possible, this interface should be addressed for status on port 0, data on port 1, with bit 0 of the status low meaning keyboard ready, and with bit 7 of the status low meaning CRT display ready. If these port and status requirements are met, the Tarbell CP/M 1.4 or 2.x disks for the DD controller should boot up with no further work. Just put the disk in, push reset, and run. Skip to step 8 if so. If not, you will need to fulfill the requirements of substep (e) below and continue. - e) Either a front panel or a ROM monitor (any ROM should be outside the 24k RAM), which allows depositing bytes into specified RAM addresses and executing at an address. - 3. If possible, have a friend make a copy of your original CP/M disk, and don't use it except to make further copies. Then use the copy for the following steps. - 4. Turn the computer on, then the CRT-keyboard, then the drive power. - 5. Put the CP/M disk into the disk drive (on most drives, the label on the disk should face the door of the drive). Close the door. Push reset (and run if you have one) buttons on the computer. - 6. The head should load against the disk and move in one track. If it doesn't do this, something is wrong with the hardware setup, and you should try a few times more. If it still doesn't do it, FIRST remove the diskette, then shut down the system. Something is either wrong with the hardware or the diskette. If so, have someone look at it or call Tarbell. If it does load and step ok, go onto the next step. - 7. Either stop the computer from running, if you have a front panel, or jump into your ROM monitor, if you have one. - 8. Look at the BIOS (Basic Input Output System) listing that came with our CP/M. Find the label BOOT. After the LXI SP instruction, you will see a series of NOP's. This area is reserved for initializing console interfaces that require it. Using either front panel or ROM, deposit the initialization routine required, if any, at the address indicated by the listing. There should be a copy of any required initialization routine in the manual on your console interface. Assembly language code for the initialization of some common console interfaces can be seen in the following lines on the page. - 9. Still looking at the BIOS listing, find the label CONST. Examine the code there for our "standard" interface. Put the code here to do a status check on your console interface. Notice that if your status bits are true when high, instead of low like ours, you will need to change the RNZ to an RZ. Other changes which might be required are the port number after the IN, and the mask after the ANI. Check your console interface manual for examples and instructions. - 10. The next routine is labeled CONIN. Deposit the code to read a byte from your console keyboard into register A. Notice that you might need to make similar changes, such as JNZ to JZ, mask, and port numbers. - ll. The last routine to change is labeled CONOT. Deposit the code to write the byte in register C to your console. Again, you might need to replace our JNZ with a JZ and make port number and mask changes. Be sure to end each of these routines with an RET instruction. - 12. This should be all the patches you need to make to the CP/M system residing in memory, to get going temporarily. Now examine the content of address 5A00 (hex), which should be a C3 (hex for JMP) and execute (run) at that location. - 13. Our BIOS should give you an opening message. If so, you're on the air, so go to step 14. If not, the system may not have loaded properly, and something may be wrong with the diskette or hardware setup. In that case, refer to section 2-3. - 14. If you haven't already done so, copy the system and files onto another disk. In order to do this, keep your system disk in drive A and put a blank disk into drive B. Then type: COPY ALL. This will copy your original disk onto the blank disk. Note that the system you are running is only in memory, and the system on the disk hasn't yet been modified. Leave the new disk in drive B until you press return to reboot. Then take the original disk out of drive A and never use it again except to copy it. Now remove the copy you made from drive B and label it exactly the same as the original. You will find that it is important to keep the disk labels current, as it is easy to get confused and make a mistake. Put the new copy into drive A for further work. Then press Ctl-C. - 15. The next thing to do is edit the BIOS and BOOT .ASM files and overlay them onto your system. Use the method described in the Tarbell CP/M 1.4 or 2.x User's Guide, as this will properly document all your changes and allow you to make use of memory larger than 24k. 16. The latest ABIOS (Auto-density select Basic Input Output System) is always available from Tarbell for \$15. Just ask for Public Domain Disk # 2. This is a disk which is regularly updated with our latest ABIOS 2ABIOS for the Tarbell Double Density Floppy Disk Interface. Other utilities are also maintained on this disk, such as format test routines. We also had room to include the source for the FORTH language from the Forth Interest Group. Their name and address included on the .ASM file. Following is a short description of each For further information, see the comments in the file itself, or the Tarbell CP/M User's Guide. The latest version of this disk is always available within 1 week from Tarbell for \$15. having problems, it's always wise to see if there is a newer version of this disk available than the one you have. 1. DBOOT24.ASM This is the secondary coldstart loader for CPM 1.4 only. ### 2. DDUMP.ASM & DDUMP.COM THIS IS A MODIFIED DUMP.COM FROM SAM SINGER AND FROM THE CP/M USERS GROUP. THIS PROGRAM WILL ALLOW YOU TO VIEW ONLY TRACKS 2 - 76 OF DOUBLE DENSITY DISK. THE ONLY LIMITATION IN THE PROGRAM IS THAT IT WILL NOT DUMP BY GROUP NUMBERS. ALL OTHER FEATURES ARE USEABLE. # 3. DFORMAT.ASM & DFORMAT.COM This is the double density format program. It will also format a double sided disk if asked to. This format program formats track 26, 128 byte sectors, tracks 1 - 76 in 51, 128 bytes sectors. #### 4. DTEST.ASM & DTEST.COM THIS PROGRAM IS USED TO TEST A DOUBLE DENSITY DISK FOR ERRORS. PROGRAM FIRST COMES UP IT WILL ASK YOU FOR A "TITLE:". YOU WHEN MAY TYPE IN ANYTHING YOU WANT SUCH AS <FORMATTED WITH 62.5 NSEC,187.5 NSEC> AND THEN A CNTL-P, CARRIAGE RET, OR IF YOU DON'T WANT JUST TYPE A CARRIAGE RET. THE TITLE ALLOWS YOU TO KEEP A ANYTHING, RUNNING TAB ON THE ERRORS AND USING CNTL-P WILL TURN ON LIST DEVICE FOR MAKING A HARDCOPY LISTING. THE NEXT QUESTION WILL BE STARTING TRACK. YOU MUST ANSWER THIS WITH A TRACK NUMBER THE REST OF THE PROGRAM SHOULD BE CLEAR. THIS PROGRAM READS TRACK AT A TIME AND KEEPS A RUNNING TAB OF ERRORS FOUND. DURING THE READING OF THE TRACK, IF A SECTOR IS BAD IT WILL DISPLAY NUMBER AND THE NUMBER OF RETRYS IT TOOK TO READ IT. IT SHOULD BE NOTED IT WILL DO 11 RETRYS MAX, AND THEN GO ON TO THE NEXT SECTOR. IT TAKES MORE THAN 10 RETRYS, THEN YOU SHOULD REFORMAT THE AGAIN, AS OUR DBIOS ONLY DOES 10 RETRYS BEFORE INDICATING A FAILURE. RETRYS ON THE ORDER OF 1 TO 5 IS TYPICAL, IF THEY OCCUR AT ALL, WITH THIS INTERFACE. THIS PROGRAM DOES NOT WRITE ON THE DISK, IT IS READ ONLY. ### 5. FORMAT.ASM & FORMAT.COM IF YOU ARE USING OUR OLD SINGLE DENSITY FORMAT PROGRAM, YOU WILL NOT BE ABLE TO READ THEM ON THE NEW INTERFACE IN SINGLE DENSITY. IS BECAUSE THERE IS A BYTE IN THE INNER RECORD GAPS THAT THE 1771 WILL READ BUT THE 1791/1793 WON'T. THIS FORMAT PROGRAM FIXES THAT PROBLEM FOR BOTH THE 1791/1793 AND WILL STILL ALLOW YOU TO USE IT WITH YOUR PRESENT 1771 CONTROLLER ALSO. YOU SHOULD DESTROY AND OLD COPIES OF THE OLD FORMAT PROGRAM YOU HAVE, AND USE THIS ONE FROM HERE ON OUT. THIS PROGRAM ALSO FORMATS A DOUBLE SIDED DISK. #### \*\*\* NOTE \*\*\* THIS FORMATS SINGLE DENSITY ONLY, 26 SECTORS OF 128 BYTES AND ONLY RUNS ON THE NEW CONTROLLER BOARD. # 6. FORMAT91.ASM & FORMAT91.COM This program will only run on the single-density interface. It will format disks in standard IBM single-density format, to read correctly on the double density interface. #### 7. DFRAND.ASM This is another format program, which only runs on the double-density interface, and which formats disks double-density in a random format. This is very useful to use in conjunction with the DTEST program, while setting up precomp. It gives a more realistic representation of the way that data may be present on the disk. Do NOT use this program to format disks that are to be used next with CP/M, as the directory needs to be filled with E5's. # 8. MACRO.LIB & SKEW.LIB THIS LIBRARY IS NECESSARY IF YOU HAVE DIGITALS MACRO ASSEMBLER AND WISH TO CHANGE AND ASSEMBLE DDUMP.ASM AND DTEST.ASM. THESE PROGRAMS USE MACROS. # 9. STAT.COM (FOR CPM V1.4 ONLY) THIS IS AN UPDATED VERSION OF THE STAT PROGRAM FOR THE ORIGINAL DISTURBUTION. IT FUNCTIONS THE SAME AS THE OLD ONE. THE ONLY IMPROVEMENT WAS TO MAKE IT DISPLAY THE CORRECT CAPACITY OF A DOUBLE DENSITY DISK. IT WILL STILL WORK SINGLE DENSITY. #### 10. ABIOS24.ASM THIS IS THE AUTO-DENSITY SELECT VERSION OF THE BIOS THIS BIOS WILL AUTOMATICALLY SELECT THE DENSITY OF THE DISK YOU ARE USING IN EITHER DRIVE, AND WILL ALLOW YOU TO CHANGE THE DENSITY AT IF YOU ARE GOING TO CHANGE THE DENSITY OF THE "A" DRIVE, YOU MUST HAVE A DISK WITH THE SAME SYSTEM SIZE AS THE ONE YOU REMOVED. FILE TRANSFERS FROM SINGLE TO DOUBLE OR DOUBLE TO SINGLE IS COMPLETELY = TRUE BEFORE YOU USE $\mathtt{SET}$ DOUBDEN YOU MUST AUTOMATIC. ABIOS24.ASM, AS THIS IS THE ONLY WAY THE AUTO-DENSITY CAPABILITY OF PROGRAM KNOWS IT IS LOOKING FOR A DOUBLE DENSITY DISK IN ANY DRIVE. 11. 2ABIOS24.ASM THIS IS THE AUTO-DENSITY SELECT VERSION FOR CPM V2.x AND THE NEW INTERFACE. THIS BIOS MUST BE USED WITH 2DBOOT24.ASM TO BRING UP PLEASE NOTE THAT 2ABIOS24 AND 2DBOOT24 ARE ONLY FOR CPM V2.x AND WILL NOT RUN ON CPM V1.4 OR CONVERSELY. # \*\*\* NOTE \*\*\* YOU MUST SET DMACNTL = TRUE IF YOU WILL BE RUNNING DOUBLE DENSITY at 2 MHz. 12. 2DBOOT24.ASM THIS IS THE SECONDARY COLD START LOADER FOR CPM V2.x FOR USE WITH 2ABIOS24.ASM. SEVERAL EQU'S APPEAR IN THIS LOADER. DMACNTL -SETTING THIS TRUE WILL ALLOW THE PROGRAM TO BOOT IN THE SYSTEM CONTROL. IF FALSE, SYSTEM UNDER PROGRAM DATA TRANSFER. BOOTS DOUBDEN - SETTING THIS TRUE PUTS THE SPECIAL ID BYTE INTO GENERATION OF A DOUBLE DENSITY SYSTEM DISK THAT WILL BE BOOTED IN FROM DRIVE 'A'. SETTING THIS FALSE ALLOWS BUILDING A SYSTEM SINGLE DENSITY DISK. THIS BYTE IS HOW THE SYSTEM KNOWS WHETHER OR NOT A SINGLE OR DOUBLE DENSITY IS ON LINE. # \*\*\*\* NOTE \*\*\*\* IF YOU HAVE TROUBLE READING A SINGLE DENSITY DISK CONTROLLER, YOU MAY HAVE A DISK WITH THE WRONG SECTOR FORMATTING. TO THIS FIND OUT, TAKE ANOTHER DISK AND USE THE NEW FORMAT.COM FILE ON THIS DISK TO REFORMAT IT. THEN USING YOUR OLD CONTROLLER, TRANSFER ALL THE PROGRAMS YOU WISH TO SAVE FROM THE DISK THAT WOULD NOT RUN ON THE NEW CONTROLLER BOARD TO THE NEWLY FORMATTED DISK. WE REALIZE THAT THIS IS ALSO A REAL HASSEL TOO, BUT IT IS A NECESSARY EVIL. BESIDES, THE NEW FROMATTED DISK WILL STILL WORK WITH THE OLD CONTROLLER BOARD. ## \*\*\* NOTE \*\*\* IF ALL ELSE FAILS, EVEN AFTER READING THE DIRECTIONS, FEEL FREE HERE AT TARBELL ELECTRONICS. AND IF YOU WOULD LIKE TO CALL ME DISCUSS ANYTHING ABOUT THE BOARD OR SOFTWARE, CALL ME. THANKS FOR INPUTS AND OUTPUTS ON THIS PRODUCT AND HOPE YOU FIND THIS PRODUCT BOTH INFORMATIVE AND FUN TO WORK WITH. > GERALD.W.MULCHIN ENGINEERING DEPT. TARBELL ELECTRONICS 213 538 4251 #### GENERAL THEORY of OPERATION The internal operation of a floppy disk operating system is probably the most complicated part of a micro-computer system. The hardware and software interact very closely, and therefore a very strong knowledge of 8080 assembly language and common logic operations is desirable to understand this section. Knowledge of the IEEE S-100 standard is also desirable, as there are some changes that have been made to the S-100 bus with this new specification. The IEEE S-100 Standard has been enclosed with this manual in the appendix, along with the data sheets for the rest of the integrated circuits used on the interface. The heart of the Double Density interface is the 1791/1793 Floppy Disk Controller Chip. This chip is very similar to the 1771 in operation, but now includes all the functions necessary to run Double Density. For your convenience, the 1791/1793 data sheet is included in the appendix. The interface may be broken down into subsections as follows: - 1. 1791/1793 disk controller chip. - 2. 8257 Direct Memory Access Controller chip. - Phase Locked Loop circuit. - 4. Write Precompensation circuit. - 5. General Drive and Computer interface. The 1791/1793 controls the actual reading or writing to the floppy disk, and in which density this will happen. The floppy controller chip contains 4 internal registers which are programmed by the computer through it's data and address lines. the four registers are as follows: - 1. status register - 2. track register - 3. sector register - 4. data register Review of the data sheet will help in understanding each function of these 4 registers. DDEN is used to control in which density the floppy disk controller chip will be operating. Low equals Double Density, High equals Single Density. EARLY and LATE control the Write Precompensation of the data being written to the disk. These two signals along with the TRK > 43 line control the amount of shift in time the bit that is being written to the disk is subjected. Precompensation during writing is a must because of the bit packing on the medium of the disk. This interface also has provisions for precompensation on tracks < 43, and it is recommended that a small amount be used. The amount of precompensation is a switch selection, and will be explained in the jumper options. READ GATE is an output used for synchronization of the data seperator circuit during read operations. A high on this pin indicates that a field of 'ones' (or zeros) has been found in the inner record gaps of the disk. The 8257 Direct Memory Access Controller chip controls the of computer data between the disk and computer. This device can be thought of as a high speed semi-intelligent cpu It contains 16 registers of which only 3 are used by this operation. floppy disk interface board. One is a command register, and the other two are byte pair data registers. During read and write operations, the 8257 must be initialized with the byte transfer count, the address of where the data is to go, and the type of transfer that is to occur, such as read or write. The 8257 can transfer up to 16384 bytes and put it into any memory locations within a normal 8080's addressing range. The important aspect about the 8257 is that it will transfer data to or from memory without the need of intervention other than being initally programmed by the cpu. After it been programmed, it alone transfers the data, and in fact removes cpu from the S-100 bus during these transfers. information about the 8257 is available in the INTEL data catalog and in the appendix of this manual. The Phase Locked Loop circuitry on this interface is necessary for reliable data recovery, especially while running under double density. It's function is to remove effects of data fluctuations during READ operations which may be the result of drive speed or power line changes, and general system noise. The Phase Locked Loop is used during Single and Double Density operation. This is accomplished by logic on the interface and is controlled by the DDEN line and an internal hardware latch. Tri-state switching is used to select the master oscillator timing clock. When in Single Density, the master clock is equal to 8 Mhz. Double Density selection causes the master clock to change to 16 Mhz. A close examination of the schematic will show these logic changes during density selects. The write precompensation is in general terms really a count down circuit, controlled by the EARLY, LATE, and TRK > 43 lines during writing operations. This applies only when operating in double density, as the EARLY and LATE signals are not active during single density. The count down circuit is clocked by the 16 Mhz oscillator circuit. The amount of precompensation is determined by the preset value jammed into the 74LS161 from the EARLY or LATE of the floppy chip. After this value is loaded, the 74LS161 counts until it reaches zero, at which time it writes the data to the disk. effect of this is to delay the time the bit would have been written to the disk, until it is actually written. The smallest amount of precompensation that may be realized from this circuit is: 1 / 16 Mhz = 62.5 nsec. Jumpers provided on the interface have been selected for optimum drive performance. Selection is based on manufacturer's recommendations for the drive in use, and our testing here at Tarbell Electronics. The computer interface for this board is based on the IEEE $\,$ 5-100 bus interface specification. It is not radically different from the old S-100 bus design, and should run with most S-100 products on the market. If you have any questions about your interface cards, check the section on S-100 compatible products in our manual. The Disk Interface occupies an address range from E0-EF hex for the DMA controller portion and F8-FD hex for the disk controller portion. A jumper is provided to allow the address range to be moved to 60-6F hex and 78-7D hex respectively, to avoid address conflicts with exsiting computer boards you may have in your system. This is explained in the jumper options section. The address ports are used as follows: ``` E0 hex 8257 address register (must be two bytes to this port) E1 hex 8257 word count register (must be two bytes to this port) ``` E8 hex 8257 command register (1 byte) F8 hex disk command port (input) F8 hex disk status port (output) F9 hex disk track port (input/output) FA hex disk sector port (input/output) FB hex disk data port (input/output) FC hex wait control port (input) FC hex drive select port (output) FD hex DMA end of operation port (input) FD hex extended address port (output) The extended address port (FD hex), allows the DMA controller to transfer data to and from memory beyond the normal 64k range of the 8080 cpu. This function is avalible for both read and write operations using the disk interface. The extended address lines are provided on the S-100 bus as described in the IEEE S-100 bus interface specification. The extended lines are A16-A23. To use the extended address function, user written software must supply an 8 bit value corresponding to the bank of memory you want to access, out to port FD hex before any read or write operations occur with the disk interface. During DMA operation, this 8 bit latch is enabled, placing its contents onto the extended address lines. The output of this latch is normally tri-state until the DMA controller becomes active. Also, this latch may be programmed at any time with any value you wish, except during an actual transfer by the DMA controller. You could even change this latch value between byte transfers if you wish. With optional decoding on memory boards, possible memory capacities can be theoretically 8 banks of 64k (512kbytes), to 256 banks of 64k (16 Megabytes). The interface is set up for Shugart 8" compatible drives, which means drives with a Shugart interface such as Shugart 800/801 and Siemens FDD 100-8,120-8, and 220-8 will interface directly to the controller board. There are many drives which fall into this catagory and we will be supplying updates as we go along for your convenience. At this time we at Tarbell Electronics have run the Shugart 800/801 and all 8" drives made by Siemens. This includes both single and double density. Persci drives model 270/277's are now supported with this interface. See the section on jumpers for an explanation and changes which must be made to support Persci drives. # DETAIL THEORY of OPERATION This section of the manual will deal in depth with the theory of operation of the double density board. The explanation will be broken down into sections within the board design. The following logic notation will be used: XX' = The logic name XX not, or the inversion of XX. #### 1. RESET circuit The floppy disk interface receives it's reset from line 75 (PRESET) on the S-100 bus whenever a power on sequence is initiated or whenever a RESET on the front panel of the computer is pushed. This line is active low (0) whenever a reset is pushed. The result of pushing a reset is to cause the floppy disk controller chip to do a restore of drive 0 to the home position, reset the DMA controller chip to the idle state, and the latch (U46), which is used for drive select, density select, and side select, to be cleared to the following condition, (a.) select drive 0, (b.) select single density, and (c.) select side 0. The reset line from the bus is first inverted by U9 (7404) to provide an active high (1) signal for the DMA controller chip U29 (8257). This signal is inverted again to provide an active low (0) reset for floppy controller chip, U31 (1791/1793), and for U46 (74LS174) an 6 bit latch. This active low reset signal also turns on the bootstrap circuit by pulling the preset line of U35 low. #### 2. BOOTSTRAP Circuit The bootstrap circuit is enabled during a power up sequence or the front panel reset switch. The reset causes a preset of flip-flop U35, a 7474 D-toggle flip flop, causing it's output, pin 5, to go high (1). This output is tied to one of three (3) inputs of U33, a 7411 3-input AND gate. The two other inputs come from the S-100 bus interface pins 47 (SMEMR), and 78 (PDBIN). The output of U33 is tied to the input of a 7406 (U87), which drives the PHANTOM line (67) U33 also also drives a hex inverter U34, which drives the chip select line on the Bootstrap Prom low, enabling the data outputs of the prom on to the data bus. When run is enabled on the computer, the contents of the prom are read onto the data bus and into the cpu Because this prom is only 32 bytes long, the method of instructions. disabling it when it has completed all its instructions, is to look at address line 5 of the S-100 bus. This address line is fed to one inputs of U47, a 7421 4-input AND gate. The other three (3) lines in to U47 are PHASE 1 (25), PSYNC (76), and SMI (44). computer has read all 32 bytes of the prom, and an attempt to read the 33rd byte is tried, address line 5 will go high (1), which causes one input of U47 to go high. The three other inputs of U47 will high, causing its output to go high. This output line then causes the output of U26, a 7404 inverter, to go LOW (0), resetting U35. When this flip flop is reset, its output, pin 5, will go low, disabling both the PHANTOM line and the Bootstrap Prom chip select. This action releases the the bus data lines back the their normal operating condition. During power up of your system, if you wish to disable the bootstrap circuitry, and have a front panel, you may raise address-data switch 5 and hit examine. This will turn off the bootstrap circuit, allowing you to access all computer memory. The bootstrap may be defeated entirely by using jumpers E8 to E9 on the disk interface. Using jumpers E9 to E10 enables the bootstrap during each reset. Below is a listing of the bootstrap prom for both the standard Tarbell disk ports, and for our non-standard disk ports. Our Model 101 is for people who wish to run the disk interface at addresses 60 to 7D hex. # STANDARD PROM BOOTSTRAP LISTING | 0000<br>00F8 =<br>00F8 =<br>00F8 =<br>00FA =<br>00FB =<br>00FC =<br>007D = | ;<br>DISK<br>DCOM<br>DSTAT<br>SECT<br>DDATA<br>WAIT<br>SBOOT | EQU<br>EQU<br>EQU<br>EQU<br>EQU | DISK+2<br>DISK+3<br>DISK+4 | COMMAND PORT. DISK STATUS PORT. SECTOR PORT. | |-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------|---------------------------------|--------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0000 DBFC 0002 AF 0003 6F 0004 67 0005 3C 0006 D3FA 0008 3E8C 000A D3F8 000C DBFC 000E B7 000F F21900 0012 DBFB 0014 77 0015 23 0016 C30C00 0019 DBF8 001B B7 001C CA7D00 001F 76 | BOOT: RLOOP: RDONE: | ORA JP IN MOV INX JMP | A SECT A,8CH DCOM WAIT A RDONE DDATA M,A H | ;WAIT FOR HOME.(caused by reset) ;CLEAR ACCUM. ;CLEAR REG L. ;CLEAR REG H. ;SET A = 1. ;START AT SECTOR 1. ;READ THE SECTOR. ;ISSUE THE COMMAND. ;WAIT FOR DRQ OR INTRQ. ;SET FLAGS. | | NON-STANDARD | BOOTSTRAP | PROM | LISTING | | |-------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------|---------------------------------------------------------|-----------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0000 | | ORG | 0 | ; PROM RUNS AT LOC ZERO. | | 0078 = 0078 = 007A = 007B = 007C = 007D = | DCOM<br>DSTAT<br>SECT<br>DDATA<br>WAIT | EQU<br>EQU<br>EQU<br>EQU | DISK<br>DISK+2<br>DISK+3<br>DISK+4 | ;BASE ADDRESS OF DISK PORTS. ;COMMAND PORT. ;DISK STATUS PORT. ;SECTOR PORT. ;DATA PORT. ;WAIT PORT. ;START OF SBOOT. | | 0000 DB7C<br>0002 AF<br>0003 6F<br>0004 67<br>0005 3C<br>0006 D37A<br>0008 3E8C<br>000A D378<br>000C DB7C<br>000E B7<br>000F F21900 | BOOT: RLOOP: | IN XRA MOV MOV INR OUT MVI OUT IN ORA JP IN MOV INX JMP | WAIT A L, A H, A A SECT A, 8CH DCOM WAIT A RDONE DDATA M, A H RLOOP DSTAT A | ;WAIT FOR HOME.(caused by reset) ;CLEAR ACCUM. ;CLEAR REG L. ;CLEAR REG H. ;SET A = 1. ;START AT SECTOR 1. ;READ THE SECTOR. ;ISSUE THE COMMAND. ;WAIT FOR DRQ OR INTRQ. ;SET FLAGS. ;DONE IF INTRQ. ;ELSE,GET A BYTE FROM DISK. ;PUT IT INTO MEMORY. ;BUMP POINTER. ;LOOP TILL DONE. ;READ DISK STATUS. ;SET THE FLAGS. | #### 3. ADDRESS SELECTION The double density controller board is selected based on the low order 8 address line values presented to the interface during an input or output instruction. The normal address range for this board is from EO hex to FD hex. There are provisions for changing the address range from 60 hex to 7D hex by means of jumpers E4,E5,and E6. The base address for the DMA controller (8257) is EO hex, with all possible 16 address from EO to EF hex available for use by the DMA controller chip. U33, a three input AND gate, is used to determine the base address of EO hex by tying address lines A7,A6,and A5 to its three inputs. You will notice that an inverter, U34, is in between one input of U33, and address line A7. By selecting the proper jumper at E4,E5, and E6, you may select a base address of either EO hex or 60 hex. By using the inverter, U34, you will select the base address of 60 hex. By not using the U34, but using the jumper which bypasses U34, you will select a base address of EO hex. The output of U34 is next AND'ed with the inversion of A4 through U26. This gate (U48) is used to allow selections from E0 hex to EF hex for I/O operations with the DMA controller. The output of U48 drives one of the inputs to U43 for selecting the DMA controller chip select line. The other input for U43 (7400), comes from U45 (7432). U45 determines whether the current I/O operation is an Input or an Output with the interface board. The signals SINP and SOUT are two status lines from the CPU card used to determine the I/O operation. Because these two signals will not occur together, they may be OR'ed together through U43 to provide just one general signal for I/O operation decoding. Disk I/O ports for the 1791/1793 floppy controller chip are decoded by U47, a 4 input AND gate. One input to U47 comes from U33's output, which is the address decode for the base address of Ex hex or 6x hex. Address lines 4 and 3 are tied to two of the other inputs of U47. Address line 2 is inverted through U26 (7404) and is the fourth input to U47. The Output of U47 goes high whenever any of the following address appear on the address bus, F8, F9, FA, and FB hex. Ports FC and FD hex are decoded by U27 (74LS138). The output of gate U33 is used for the enable input of U27. The other two enables of U27 are an enable when low function and are derived from the inversion of address lines 3 and 4 through two inverters U26. The output of inverter U26 pin 10 also goes to one input of gate U48. If address line 4 is high (eg. Port FC), The output of U26 pin 10 will be low (0), causing the output of gate U48 to be low, disabling the selection of any port with the base address of Ex hex. The 3 low address lines, A0, A1, and A2 determine which port is selected on the output of U27. Also, even though the low 3 lines of the address bus are used by U27, only two of the possible 8 ports are used by the disk interface board. Port decodes from U27 for F8, F9, FA, and FB are not used. Only Ports FC and FD hex are used. #### 4. DISK CONTROL circuit The 1791/1793 Floppy disk formatter/controller chip performs all the functions necessary to read or write data to a floppy disk drive. Both single and double density storage capabilities are supported. The chip is compatible with the IBM 3740 (FM) data format, IBM System 34 (MFM), or may be operated non-standard by using the controllers variable length sector capability. The floppy controller chip contains five (5) internal registers that can be read or be written to. These registers are used to write commands, read status, and read and write data to and from the floppy disk drive. These five registers are selected by providing the proper binary code on the AO and Al lines of the floppy chip in conjunction with either a read or write operation. The registers and their addresses are as follows: #### DETAIL THEORY of OPERATION | 0 0 0 Status Reg Command Reg 0 0 1 Track Reg Track Reg 0 1 0 Sector Reg Sector Reg 0 1 1 Data Reg Data Reg | CS' | Al | <b>A</b> 0 | $RE^{1} = 0$ | WE ' = 0 | | |------------------------------------------------------------------------------------------------------------|-----------------------|-----------------------|------------|-------------------------|-------------------------|--| | 1 x x Deserected Deserected | 0<br>0<br>0<br>0<br>0 | 0<br>0<br>1<br>1<br>x | | Track Reg<br>Sector Reg | Track Reg<br>Sector Reg | | The five internal registers of the floppy controller chip are through the internal interface data bus. The internal data bus is buffered by U71 (8208) and U72 (8208). U71 and U72 are 8 bit bi-directional transcievers which are used as bi-directional data buffers between the computer S-100 bus and the floppy disk interface internal data bus. These transceivers allow data travel in either direction depending upon whether the TRANS/REC' pin (11) is high or low. To program the floppy controller chip, AO,Al are selected for the desired operation. Write enable of U31 is made active low processor signal SOUT and PWR' gated together by U23 (7400). The data that the CPU wishes to program the floppy controller with, is now placed on the DOO - DO7 lines of the CPU card. This data is then presented to U71. Because we are not in the DMA mode of operation, the TRANS/REC' pin is already pulled low, causing the transceiver to be in receive mode. The data is then passed through U71 onto the internal data bus and into the floppy chip DALO - DAL7 lines. select, pin 3, of U31 is made active low by U48 (7408) output. One input of U48 comes from the DMA controller and the other input is from U43 which is the gating of the address port and the I/O mode desired. In this case, since we are programming the floppy controller, any port address in the range of F8 - FB hex gated together with SOUT will cause the data to be written to the controller chip. ## 5. Direct Memory Access The sequence of operations for a DMA access is as follows: - A. The Basic Input Output System (BIOS part of CP/M) program sends a series of initialization bytes to the 8257. These include the starting address in memory for the data, the number of bytes to transfer, and the type of command (read, write, verify) which is being requested. The port numbers for these and other transfers are listed on page 3-3 in this manual. - B. The BIOS then sends track number, sector number, and type of command (read or write) to the 1793. - C. The 1793 then causes the head to load against the media (we are assuming we're already on the correct track). When the 1793 finds a sector header that matches the track and sector number in it's registers, and is ready to write or read the first byte, it activates its DRQ line, which is fed to the 8257. This signifies that it is ready to transfer a byte. - D. Soon after receiving the input on its DRQO line, the 8257 makes its HRQ line go high. This is fed through an OR gate - to S-100 bus line PHOLD'. This notifies the CPU that there is a DMA request pending. - E. When the CPU finishes the cycle it is currently in, it sends back a PHLDA signal over the S-100 bus to the HLDA input on the 8257. This tells the 8257 that its DMA request has been granted, and that the CPU is in a HOLD state. - F. The 8257 then activates its AEN line, which indicates that it has a valid address on AO to A7 and DO to D7. This signal is ORed with the HRQ to keep PHOLD' active, and disables the CPU address and data lines using S-100 bus lines DO DSB' and ADR DSB'. AEN also is fed to (U41) and (U67), which gates the DD board's own status and control lines onto the S-100 bus (PWR', PDBIN, SMEMR, SINP, SOUT, PSYNC, MWRITE, SINTA, SHLTA, SM1). - G. A short time later, the 8257 activates its DACKO' line, which disables the CPU's status and control lines, using S-100 bus lines STAT DSB' and C/C DSB'. The time between step F and G provides the overlap time, during which both our DD board and the CPU board have control of these status and control lines. - H. At the same time as the DACKO' line is activated, the 8257 activates either its MEMR' line, or its I/OR' line, depending upon whether it's going to do a write or read respectively, to disk. Step I will explain what happens for a write operation, Step J for a read (from disk) operation. - I. For a write operation: The MEMR' line coming from the 8257 is used for several things. It is fed through U67 to S-100 lines PDBIN and SMEMR to the system memory to gate the memory onto the S-100 bus. It is also used to activate U72 so that the S-100 DI bus is fed into the DD board's internal data bus and therefore providing a path from the memory output to the 1793. A short time after the MEMR' signal, the I/OW' signal is fed from the 8257 to the WE' input on the 1793, which strobes the data into the 1793. The 1793 then writes the data onto the disk. - J. For a read operation: The I/OR' signal from the 8257 is fed to the 1793, gating the data in its register onto the data bus. This signal is also used to activate U71 in the outward direction, so that the data is fed onto the S-100 DO bus out to the system memory. (mod for rev-e) A short time after the I/OR' signal, the MEMW' signal is generated by the 8257. This is used to generate the S-100 bus line PWR', which strobes the data into memory. - K. After either step I or J above, the reverse sequence occurs, turning over control of the bus back to the CPU. #### 6. Write Precompensation The Write Precompensation circuit consists of a programmable counter, (U36), for delaying or advancing write data pulses during disk writes, a dip switch (SW-1) for adjusting the precompensation value, and the necessary decoding logic for early, late, and TRK > 43 (U12). #### DETAIL THEORY of OPERATION The 1793 produces along with it's write data pulses, two signals called 'early' and 'late'. These two signals, along with TRK > 43, are decoded by a 1 of 4 decoder circuit (U12) to select the switch setting from SW-1 for loading into the counter (U36). Loading the counter starts the counter down counting. If there is no early or late signal generated (no precomp needed), the programmable counter is loaded with a positive (0111) 7, which is the zero precompensation center reference value. Values from (0110) 6 through (0000) 0 are increasing late times, and values (1000) 8 through (1110) -2 are increasing early times. The programmable counter is clocked with 16 MHz during double density. Therefore, the minimum resolution is 62.5 nsec. After the counter has been loaded with the desired value of precompensation, the counter down counts until a carry is produced. The carry, delayed one (1) clock cycle by a D-toggle flip-flop(U35), is used to trigger a 250 nsec. one-shot. The output of the one-shot, after buffering, is the precompensated data which is written to the drive. The counter then remains stopped until a new data pulse is sent from the 1793, starting the whole process again. ## 7. Data Recovery Data recovery is provided by an on board Phase Locked Loop circuit. This circuit allows for maximum data recovery reliability, while rejecting drive speed variations and bit crowding. One shot (U74) conditions the data being read from the disk and provides RDATA\* to the 1793. It also provides data to the phase comparator (U55) which is part of the phase locked loop. The active filter network which consist of U55,R5,R6,R7,R8, C5,C6 and Q2 removes noise and jitter from the incoming data and provides a correction voltage to the voltage controlled oscillator (U53). This oscillator provides the master clock frequency necessary for a stable read clock signal (RCLK) for the 1793. This output is either divided by 2 or divided by 4, controlled by the DDEN line, to provide the necessary 500 KHz or 250 KHz RLCK signal for double density or single density operation. # DMA READ/WRITE CYCLE 500 NSES / DIV ### ASSEMBLY INSTRUCTIONS Before attempting any assembly operations, it is recommended that you read this section and the parts list section first. This will help put your mind into a comfortable state about what you are going to be doing with the board. - 1. () Locate and confirm that your kit contains all the parts listed in the parts list in this manual. Any errors found should be reported to Tarbell Electronics for corrective measures. Also, you should make any necessary changes which you receive from Tarbell Electronics, on your board at this time. - 2. ( ) If you are using sockets, install them at this time. - 3. ( ) Locate the 50 pin header connector and install it at the top of using the 2 2-56 x 3/8 mounting screws and hardware. - 4. ( ) Locate Q1, an LM-323 votage regulator, and the heatsink. Mount the regulator and heatsink on the board using the $4-40 \times 3/8$ screws and hardware. - 5. () Locate Q2, an MPS6571 transistor, and mount it as indicated by outline on the board. - 6. () Locate the crystal, Yl, and mount it on the board. Mount the crystal down close to the board. Then take a small piece of wire and push it through the hole that is to the left of crystal, and solder it. Then, take the other end of this wire and bend it over the top of the crystal and cut off all but 1/8" of it. Then solder the wire to the crystal can. Do not over heat the crystal can, or you may open the hermetic seal. - 7. () Using the parts list and using the board layout drawing, start mounting all the capacitors on the board. Be sure to observe the polarity of the tantalum capacitors Cl3,Cl4,Cl5. The little square block on the board is the end that the plus (+) lead of the capacitor goes into. - 8. ( ) Using the parts list and board layout drawing, mount all the resistors on the board. - 9. () Locate the dip switch and mount it. Note, if the dip switch you have has only 8 positions, you will have to mount the switch on the board starting at position 2 at the location on the board. There should be one open location at the top of the switch that is not used after you mount the switch. - 10. ( ) Do not mount the IC's at this time, as you will need to check the voltage regulators for proper output voltages. - 11.() After all the components are mounted, plug the board into your computer and check the voltage regulators for proper operation. CAUTION\*\* Be sure your computer is turned off before you plug in the board. The output of Ql should be approx. 5 volts +/- .5 volts. The output of CRl should be approx. 12 volts +/- .75 volts. ### ASSEMBLY INSTRUCTIONS - 12.() Using the parts list and board layout drawing, mount the IC's into their respective locations. Use ''GREAT'' caution with the two 40 pin IC's when mounting them as it is possible to bend or break some of the leads on the part. - 12.() This completes the assembly of the unit. On the following pages are the jumper options for setting up the board for your system. This board has very little jumpering required to get it running. The only jumpers that need setup are for address selection, XRDY or PRDY line, Write Precompensation value, and drive type selection. ### 1. Normal Board Setup The normal configuration is as follows: - a. Board address set for base address of EO hex. - b. PRDY line used for processor wait. - c. SW-1 set for 62.5 nsec on trk < 43 and 187.5 nsec for trk > 43. For normal operation with Shugart compatible drives, install jumpers as follows: - ( ) El3 to El5 - ( ) E4 to E6 <-- normally etched on the board ### NOTE \*\* The write precompensation may be the only adjustment you will have to make for your drives. ### 2. Address Selection This board may be addressed in one (1) of two (2) address areas in your computer. Either an address range of 60 - 7D hex or E0 - FD hex may be selected. You should beware of existing computer boards in your system which use these address ports for I/O operations, as a conflict may exist. Our I/O section for CP/M uses an address range of E0 - FD hex, as does our Standard bootstrap prom. | | ] | POR' | Γ | J | | | | | | |----|---|------|-----|---|-----|----|-----|--|--| | | - | | - | | | | | | | | E0 | | FD | Hex | | E19 | to | E20 | | | | 60 | _ | 7D | Hex | | E19 | to | E18 | | | ### 3. XRDY or PRDY selection Three possible configurations exist in the selection of the right line to use. These are, no front panel, front panel, and if you have a front panel, who made it. No Front Panel Jumper E1-E2 or E3-E2 Imsai Front Panel Jumper E1-E2 Altair Front Panel Jumper E3-E2 ### NOTE \*\* Be sure that other boards in your system do not use either the XRDY or PRDY lines improperly, as this would cause improper operation of this interface board. Things to beware of are memory boards which activate a tri-state driver in anticipation of memory wait states, or dynamic memory boards which require the use of this line for refresh operations, or memory boards which use slow memorys such as old, old 2102's. # 4. Write Precompensation Selection The selection of the write precompensation is based on the type of drive you are using and the amount of errors you are getting from the disk when you run our special disk test program. To properly set the precompensation, first set the dip switch Sl for a value of 62.5nsec for < 43 and 187.5 nsec for > 43 as shown in the Precomp Table in Fig.1 Next, format a good certified double density disk with our DFRAND.COM program. Then read the disk for errors using our DTEST.COM program. If you find any errors, then change the precompensation switch settings to another value in the table and run the sequence again. The initial values of 62.5nsec for < 43 and 187.5nsec for > 43 were found to be midrange values here at Tarbell Electronics. These values are with the switch positions 5 and 8 on (if there is a 9 position switch), or positions 4 and 7 on (if there is an 8 position switch). After you have found the proper settings for the precompensation switches, reformat the disk using the DFORMAT.COM program so that the disk will have the proper data in each sector required for CP/M operation. (E5 data fill) SW - 1 settings | | | Trk < | | | | | | <u>-</u> | Frk > 43 | 3<br> | | | |--------|-------|--------|----|----|-------|---|-------|----------|------------------------------------------|-------|-------|---| | - | -Earl | y | La | te | | E | arly- | | | | Late- | | | Pos | 1 | | 2 | 3 | | 4 | 5 | 6 | * The Care Care (See Care Care Care Care | 7 | 8 | 9 | | ns<br> | | ns<br> | | | ns | | | | ns | | | | | 62.5 | 1 | 62.5 | 0 | 0 | 62.5 | 0 | 1 | 1 | 62.5 | 0 | 0 | 0 | | Х | X | х | X | Х | 187.5 | 0 | 1 | 0 | 187.5 | 0 | 1 | 0 | | X | Х | 250.0 | 0 | 1 | 250.0 | 0 | 0 | 1 | 250.0 | 0 | ī | ĭ | | X | Х | х | x | x | 312.5 | 0 | Ō | 0 | 312.5 | ĭ | Ō | ń | | Х | Х | 375.0 | 1 | 0 | х | x | x | x | 375.0 | ī | 0 | i | | Х | х | X | х | х | x | x | x | x | 437.5 | î | 1 | | | х | х | 500.0 | | 1 | x | x | x | X | 500.0 | i | i | 1 | FIG 1 Note: x = not adjustable, 1 = on, 0 = off # 5. Bootstrap The on-board bootstrap may be enabled or disabled by jumpers E8, E9, and E10 as follows. Bootstrap enabled - Jumper E9 to E10 Bootstrap disabled - Jumper E9 to E8 ### 6. Persci drives If you have a Double Density board Rev. D or Rev. E, and want to run a Persci model 277/270 with it, then do the following changes to the board. - 1. On the double density interface: - a. on back side, cut the trace connecting E4 to E6 and jumper E4 to E5. (bypasses step one-shot) - b. Jumper Ell to El2. ( 1793 test pin) - c. Jumper El3 to El4. (seek complete line) Now you must make the Persci 277/270 look like a Shugart compatible drive. Thanks to John Mock of Bits & Bytes of Fullerton, we now have the all the changes. These are changes which you must make to the drive and in some cases will involve making trace cuts on the Persci drive. # Cuts to make: 1. Trace to P1-16 (back side) - 2. Trace between BL-BC (front side) - 3. Trace between Ull-12 and Ull-13 (back side) - 4. Trace between Ull-10 and Ull-11 (back side) - 5. Trace from Pl-2 to Ul-8 (front side) - 6. Trace to P1-30 (back side) - 7. Trace to P1-32 (back side) ### Jumpers to add: - 1. Ull-12 to P1-32 (back side) - 2. Ull-10 to P1-30 (back side) - 3. H to M (for head load) - 4. H to BL (for head load) Persci jumpers: (board assy.200263-007 rev N/S) 1() A - B 2() J - Z 3() K - L 4() N - P 5() T - S 6() U - V 7() BK-BM 8() BA-BB 9() AK-AH 10() X - W 11() AD-AE 12() AP-AR 13() AS-AT 14() AM-AN 15() BE-BD Jumpers E-D and G-F and AC-AB should be open. ### Drive select: | Drive 1 (A & B) | Drive 2 (C & D) | |----------------------------|-----------------------------------------| | Ull 13 to 2<br>Ull 11 to 4 | Ull 12 to 2<br>Ull 10 to 4<br>Remove Ul | Our bios packages for CP/M use with the double density board must have some of the equates changed for proper operation with the Persci 277/270, and 299. In the bios change HLAB EQU 0 to HLAB EQU 8 for head load at beginning of seeks. Set DUAL to TRUE as there are two heads moving together. These changes were tried on our Persci model 277/270 here at Tarbell Electronics which has a revision number of N/S. We are not sure about other revisions which Persci makes or about there operation in Double Density. You should probably consult the factory about any revisions you have which do not agree with our own. Operation with the Persci has been quite good in Single Density operation on the new controller. But Double Density has been poor. This is probably due to the fact that our Persci 277/270 is not rated for Double Density operation. This is probably due to head design. Adjusting the precompensation may help some what. # Persci 299 Jumpers The Double density interface has provisions on the 50 pin drive connector at the top to allow the connector to modified for small differences between drive manufactures. In particular, Persci drives. You will notice that each connection has a double feed through hole with a short etch line connecting each end. By cutting this line with a sharp ex-acto blade, the line may may be be broken open. To allow the persci 299 to work with our interface, some of these lines must be cut, and jumpers put on for the differences between Shugart and Persci. Below is a list of cuts and jumpers to make to this connector. CUTS (revision C to revision F only) Back side of board, cut trace connecting pin 2 and pin 16 of 50 pin connector. Front side of board, cut the following lines between feed-through holes: | C hole | X cut | C hole | Cut 2,4,6,8,12,14,16,18,24,30,32 as shown above. Jumpers are referenced as being placed in a FROM - TO fashion as shown below. | | [ | Coni | necto | or] | |---|--------|------|-------|------| | 2 | 4 | 6 | | etc. | | 0 | 0 | 0 - | | TO | | X | l<br>X | X | | cut | | 0 | <br> | 0 - | | FROM | | 1 | 1 | i | | | Jumpers to install: | FROM | TO | |------|----| | | | | 14 | 2 | | 32 | 4 | | 18 | 16 | | 30 | 18 | ## 7. Interrupt option Interrupts from the Floppy controller may be used to generate a interrupt to the CPU if desired. The large hole (E23) just above pin 8 of the S-100 connector is the output for the interrupt line. This is an active low signal and is normally tri-state. This line may be connected to any of the S-100 vector interrupt lines on the bus. You will need a vector interrupt card if you plan on using interrupts other than RST 7. The vector interrupt lines are defined in the S-100 standard on pages 10-1 to 10-5 of this manual. ### 8. MWRITE option If your memory boards require the MWRITE signal to write data into memory, and this signal is not generated on the cpu or front panel, then you will have to jumper El6 and El7 together. If your memory boards use PWR' for writing data into memory, then leave El6 to El7 open. # 9. 8257 Clock option The clock frequency for the DMA controller chip (8257) is derived from the master bus clock (pin 24) which comes from the CPU board. Because the 8257 runs at 2MHz you will have to select the right option for E23, E24, and E25. If your CPU is running at 2 MHz, jumper E25 to E24. If your CPU is running at 4 MHz, jumper E25 to E23. # 10. 1793 Read delay The 1793 has a hold time restriction when reading data or status from it. A one-shot has been provided to stall the CPU during any reading from ports F8 - FB Hex (78 - 7B Hex). This option is provided already connected on the board. This is the only WAIT, when running DMA operation, generated on the board. This option may be defeated by cutting the trace between E26 and E27 on the board. The only problem you may find if you cut this trace is that while running with a Z-80 at 4MHz, or an 8085 at 5 MHz, is that you may read the 1793 too fast. This is also a function of the 1793 you are using at the time. You may have to replace the jumper if you find you have any problems reliably reading the 1793. # 12. Extra buffer chip Located at U41 is an extra buffer for use as you may see fit. This buffer is an enabled Tri-state buffer of the non-inverting type. Jumpers are provided so you may use it. E21 = buffer input E22 = buffer output ``` Desiginator Oty. Descriptor Resistors R29 V 120 ohm 1/2 watt 220 ohm 1/8 watt R6 📈 R1,R3,R36 330 ohm 1/4 watt 3 R10, R12, R13, R14, R45, R46 470 ohm 1/4 watt 6 R8 🖍 470 ohm 1/8 watt 1 510 ohm 1/8 watt R39 1 R19, R22, R24 1 \text{ k ohm } 1/4 \text{ watt} 3 R7 🦟 1 K ohm 1/8 watt 1 R15,R16,R30,R31,R38,R20 2.2kohm 1/4 watt 6 R9, R1 1 2.4Kohm 1/8 watt 2. R40, R43 4.3Kohm 1/4 watt 2 R17,R18,R23,R25,R26, R48 4.7kohm 1/4 watt 6 5.1Kohm 1/8 watt R417R42 🔑 2 6.2Kohm 1/8 watt R5 /_ 1 R21, R27, R28, R47, R49 10 kohm 1/4 watt 5 R37,R35 - ' 33 kohm 1/4 watt 2 4116-003-221-331 Capacitors C9 r pf cap 18 C3,C4,C46 3 56 pf cap C7, C8, C17, C45 100 pf cap +/-5% 4 220 pf cap C12 / 1 C1 🗸 1 680 pf cap C6 / .0015 mfd cap 1 .0039 mfd cap C5 C11, C20, C21, C22, C23, C24, C25, C26, C27, C28 1 .1 mfd cap 23 C29, C30, C31, C32, C33, C34, C35, C36, C37, C38, C39,C40,C41,C42,C43 C10 - 4 4.7 mfd @ 10 volts 1 C13,C15 10 mfd @ 16 volts 2 C14 22 mfd @ 10 volts 1 Misc. Yl 16 MHz crystal 1 Q2 / MPS 6571 Transistor Q1 🐔 2N2222 Transistor 1 CR1 ~ 1N4742 12 volt 1 watt zener SW-1 9 position dip switch 1 1 2 Jumper Pins Jumper Blocks Hardware TO-3 Heatsink 1 4-40 \times 3/8 \text{ screw} 2 4-40 \times 1/4 \text{ nut} 2 # 4 washer ``` ### PARTS LIST ``` 2 2-56 \times 3/8 \text{ screw} 2 2-56 \times 3/16 \text{ nut} 2 # 2 washer Connectors 1 pin connector Jl 1 16 pin dip-socket U52 pin dip-socket U29,U31 IC's ** Note ** Equiv. 74LS parts may be used where indicated in list. 3 7400/74LS00 Quad Nand gate U12,U23,U43 4 7404/74LS04 Hex Inverter U9, U26, U34, U44 1 7404 Hex Inverter U66 1 74S04 Schottky Hex Inverter U85 1 7406 O.C.Hex Inverter U87 2 7407 Hex Buffer U13,U16 2 7408/74LS08 Quad And Gate U42,U48 1 7411/74LS11 3 Input And Gate U33 1 7413/74LS13 4 Input Schmitt Trigger U47 2 7432/74LS32 Quad Or Gate U45,U73 2 7438 O.C.Quad Nand Gate U21,U22 2 7474/74LS74 D Toggle Flip Flop U35,U77 1 7493 4 Bit Binary Counter U86 1 74LS109 Dual J-K Flip Flop U76 1 74LS113 Dual J-K Flip Flop U56 3 74LS123 Dual One Shot U10,U32,U64 1 82S123/5331 Bootstrap Prom U52 2 74125/74LS125 Quad Tri-state Buffer U25,U65 1 741S138/8205 Octal Decoder U27 1 74145 1 of 10 Decoder U24 1 74LS153 Dual 4 to 1 mux. U75 1 74LS161 Preset Counter U36 1 74174/74LS174 6 Bit Latch U46 2 74LS221 Dual One-shot U53,U74 2 74LS373 Octal Tri-state Latch U68,U69 3 8T97 Hex Tri-state Buffer U7, U67, U41 3 8208/8286/8304 Octal Transciever U28,U71,U72 1 MC4044 Phase Comparator U55 (Motorola) 1 LM 323 5 Volt 3 Amp Regulator 01 LSI chips 8257 DMA Controller Chip U29 1 1793/MB8877 Floppy Controller U31 ** Note ** U70 is not used. ``` # TARBELL DOUBLE DENSITY FLOPPY DISK INTERFACE FULL WARRANTY - 1. Any faulty component part purchased from Tarbell Electronics, which is returned within 6 months after the date of purchase will be replaced at no charge. Components returned under this part of the warranty should be with a letter explaining what is wrong with the part. - 2. 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 kit, which in the opinion of the manufacturer has been assembled with reasonable care, and is returned for repair within 6 months after the date of purchase, will be repaired for a charge commensurate with the work required. (parts will be free) but in no case will exceed \$100 without notification of the owner. - 4. Any floppy disk interface not covered by the above condition will be subject to a charge commensurate with the work and parts required, but in no case will exceed \$100 without notification of the owner. - 5. 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. - 6. Tarbell Electronics assumes no responsibility for consequential damages to other connected equipment, or for time lost, or programs or data lost, because of interface malfunction or incorrect documentation. - 7. If you are disatisfied with the operation of a factory-assembled Tarbell Double Density Floppy Disk Interface for any reason, your money will be cheerfully refunded, provided the unit is returned within the six month warranty period. - 8. 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 in your system. - 9. This warranty does not cover parts, or interfaces built from parts, which are not traceable to Tarbell Electronics. - 10. An interface which is assembled from a kit by a Tarbell dealer has only the parts covered by this warranty, not the labor. All interfaces which were sold as kits, will have a "K" marked on the solder side. The dealer may provide his own warranty in this case. TARBELL DOUBLE DENSITY FLOPPY DISK INTERFACE FULL WARRANTY Defective parts or interfaces covered under this warranty should be sent WITH PROOF OF PURCHASE (like a receipt) to: Tarbell Electronics 950 Dovlen Place, Suite B Carson, California 90746 # IEEE Specification, IEEE Task 696.1/D2 The following is a list of the IEEE pin functions, signals, type of signal, active level, and a description of the signal. The following conventions will be used: - 1. \* = inverted signal or the NOT function. - 2. M = master. - 3. B = bus. - 4. S = slave. - 5. O.C. = open collector. - 6. H = high or logic level 1 - 7. L = low or logic level 0 | Pin | Signal | Туре | Active | Level | Description | |-----|-----------|------|--------|-------|--------------------------------------------------------------------------------------------------------------------| | 1 | +8 volts | В | | | Instantaneous min greater than 7 volts, instantaneous max less than 25 volts, average max less than 11 volts. | | 2 | +16 volts | В | | | Instantaneous min greater than 14.5 volts, instantaneous max less than 35 volts, average max less than 21.5 volts. | | 3 | XRDY | S | Н | | One of two ready inputs to the current bus master. The bus is ready when both inputs are true (H). see pin 72. | | 4 | VIO* | s | L | o.c. | Vectored interrupt line 0. | | 5 | VIl* | S | L | o.c. | Vectored interrupt line 1. | | 6 | VI2* | S | L | o.c. | Vectored interrupt line 2. | | 7 | VI3* | S | L | 0.C. | Vectored interrupt line 3. | | 8 | VI4* | S | L | O.C. | Vectored interrupt line 4. | | 9 | VI5* | S | L | O.C. | Vectored interrupt line 5. | | 10 | VI6* | s S | L | O.C. | Vectored interrupt line 6. | | 11 | VI7* | S | L | o.c. | Vectored interrupt line 7. | | 12 | NMI* | S | L | 0.C. | Non-maskable interrupt line. | | 13 | PWRFAIL* | В | L | | Power fail bus signal. | | 14 | DMA3* | M | L | 0.C. | Temporary master priority bit 3. | | 15 | A18 | М | Н | | Extended address bit 18. | # IEEE Specification, IEEE Task 696.1/D2 | 1 | 6 Al6 | М | Н | | Extended address bit 16. | |-----------|--------------|--------------|---------|------|---------------------------------------------------------------------------------------------| | 1 | 7 A17 | M | Н | | extended address bit 17. | | 1 | 8 SDSB* | M | L | 0.C. | | | 1 | 9 CDSB* | М | L | O.C. | Disable signal for 8 control lines. | | 20 | O GND | В | | | Common with pin 100 | | 2] | L NDEF | | | | Not to be defined. Manufacturer must specify any use in detail. | | 22 | ADSB* | M | L | O.C. | Disable signal for 16 address lines. | | 23 | DODSB* | M | L | O.C. | Disable for 8 data out lines. | | 24 | Ф | В | Н | | Master timing signal for bus. | | 25 | pstval* | M | ${f L}$ | | Status valid signal. | | 26 | PHLDA | M | Н | | Control signal used in conjunction with HOLD* to coordinate bus/master transfer operations. | | 27 | RFU | | | | Reserved for future use. | | 28 | RFU | | | | Reserved for future use. | | 29 | <b>A</b> 5 | M | Н | | Address bit 5. | | 30 | A4 | M | Н | | Address bit 4. | | 31 | A3 | М | Н | | Address bit 3. | | 32 | A15 | M | Н | | Address bit 15. | | 33 | A12 | M | Н | i | Address bit 12. | | 3 4 | A9 | M | H | i | Address bit 9. | | 35 | DO1/DATA1 | M/MS | Н | Γ | Data out bit l,bidirectional bit l. | | 36 | DOO/DATAO | M/MS | Н | | Data out bit 0, bidirectional bit 0. | | 37 | AlO | М | Н | | Address bit 10. | | 38 | DO4/DATA4 | M/MS | Н | D | ata out bit 4,bidirectional bit 4. | | | - 1/ 2111114 | | | | | | 3 9 | DO5/DATA5 | M/MS | Н | | | | 3 9<br>40 | | M/MS<br>M/MS | H<br>H | D | ata out bit 5,bidirectional bit 5. ata out bit 6,bidirectional bit 6. | | 42 | DI3/DATA11 | s/ms | Н | | Data in bit 3, bidirectional bit 11. | |----|------------|------|---|------|-----------------------------------------------------------------------------------------------------------------------------------------------------| | 43 | DI7/DATA15 | s/ms | Н | | Data in bit 7, bidirectional bit 15. | | 44 | sMl | M | Н | | Status signal indicating current cycle is op-code fetch. | | 45 | SOUT | М | H | | Status signal indicating data transfer bus cycle to output device. | | 46 | sINP | M | Н | | Status signal indicating data transfer bus cycle from input device. | | 47 | SMEMR | M | Н | | Status signal identifying bus cycles which transfer data from memory to a bus master, which are not interrupt acknowledge instruction fetch cycles. | | 48 | sHLTA | M | Н | , | Status signal indicating a HALT instruction has been executed. | | 49 | CLOCK | В | | | 2 MHz (0.5%) 40-60% duty cycle.<br>Not required to be synchronous with<br>any other bus signal. | | 50 | GND | В | | | Common with pin 100. | | 51 | +8 volts | В | | | Common with pin 1. | | 52 | -16 volts | В | | | Instantaneous max less than -14.5 volts, instantaneous min greater than -35 volts, average min greater than -21.5 volts. | | 53 | GND | В | | | Common with pin 100. | | 54 | SLAVE CLR* | В | L | o.c. | Reset signal to reset bus slaves. Must be active with POC* and may also be generated by external means. | | 55 | DMA0* | M | L | o.c. | Temporary master priority bit 0. | | 56 | DMA1* | М | L | o.c. | Temporary master priority bit 1. | | 57 | DMA2* | М | L | o.c. | Temporary master priority bit 2. | | 58 | sXTRQ* | М | L | | Status signal which requests 16-bit slaves to assert SIXTN*. | | 59 | A19 | M | Н | | Extended address bit 19. | | 60 | SIXTN* | S | L | O.C. | Signal generated by 16-bit slaves in response to the 16-bit request signal | | | | | | | sxtro*. | |-----|--------|-----|---|------|----------------------------------------------------------------------------------------------------------------------------------------------------| | 6. | L A20 | М | H | Ī | Extended address bit 20. | | 62 | 2 A21 | М | Н | I | Extended address bit 21. | | 63 | A22 | M | Н | | Extended address bit 22. | | 6 4 | A23 | M | Н | | Extended address bit 23. | | 6 5 | NDEF | | | | Not to be defined signal. | | 66 | NDEF | | | | Not to be defined signal. | | 67 | | M/S | L | o.c. | Bus signal which disables normal slave devices and enables phantom slaves. Primarily used for bootstrapping systems without hardware front panels. | | 68 | MWRT | В | Н | | Gating of pWR*-sOUT. Signal must follow pWR* by no more than 30 ns. | | 69 | RFU | | | | Reserved for future use. | | 70 | GND | В | | | Common with pin 100. | | 71 | RFU | | | | Reserved for future use. | | 72 | RDY | S | Н | 0.C. | See comments for pin 3. | | 73 | INT* | S | L | 0.C. | Primary interrupt request bus signal. | | 74 | HOLD* | М | L | O.C. | | | 75 | RESET* | В | L | O.C. | Signal used to reset bus master devices. This signal must be active with POC* and may be generated by external means. | | 76 | psync | M | Н | | Control signal identifying BS1. | | 77 | pWR* | М | L | | Control signal signifying the presence of valid data on DO bus or data bus. | | 78 | pDBIN | М | Н | | Control signal that request data on the DI bus or data bus from the currently addressed slave. | | 79 | A0 | M | Н | | Address bit 0. | | 80 | Al | M | Н | | Address bit 1. | | 81 | A2 | М | Н | | Address bit 2. | # IEEE Specification, IEEE Task 696.1/D2 | 82 | A6 | M | Н | Address bit 6. | |-----|------------|------|-----|----------------------------------------------------------------------------------------------------------------------| | 83 | A7 | M | Н | Address bit 7. | | 84 | А8 | М | Н | Address bit 8. | | 85 | A13 | M | Н | Address bit 13. | | 86 | A14 | М | H | Address bit 14. | | 87 | All | М | Н | Address bit 11. | | 88 | DO2/DATA2 | M/MS | H. | Data out bit 2, bidirectional bit 2. | | 89 | DO3/DATA3 | M/MS | Н | Data out bit 3, bidirectional bit 3. | | 90 | DO7/DATA7 | M/MS | H | Data out bit 7, bidirectional bit 7. | | 91 | DI4/DATAl2 | s/Ms | Н | Data in bit 4, bidirectional bit 12. | | 92 | DI5/DATA13 | S/MS | Н | Data in bit 5, bidirectional bit 13. | | 93 | DI6/DATAl4 | S/MS | Н | Data in bit 6, bidirectional bit 13. | | 94 | DI1/DATA9 | S/MS | Н | Data in bit 1, bidirectional bit 9. | | 95 | DIO/DATA8 | S/MS | Н | Data in bit 0, bidirectional bit 8. | | 96 | SINTA | M | Н | Status signal identifying the bus input cycles that may follow an accepted interrupt request presented on INT*. | | 97 | sWO* | M | L | Status signal identifying a bus cycle which transfers data from a bus master to a slave. | | 98 | ERROR* | s | L O | .C. Bus status signal signifying an error condition during the present bus cycle. | | 99 | POC* | В | L | Power-on clear signal for all bus devices. During active condition, this signal must stay low for at least 10 msecs. | | 100 | GND | В | | System ground bus. | | | | | | | ) ### Compatible S-100 Products As a service to our customers, we have decided to provide information about other S-100 products that will work correctly with our new double density interface. The list below only represents those products that We here at Tarbell Electronics have tested ourselves, and does not imply that these are the only S-100 that the double density interface will work with, and it is hoped that our customers will provide us with additional information about other S-100 products that they have found works with our interface. ### CPU's Tarbell Z-80 CPU board, SSM CB-2 Z-80 BOARD, MicroDaSys Super-Z, Imsai 8080, Delta Products Z-80, Cromemco ZPU, S.D.Sales Z-80, Cromemco Single Card computer, Northstar Z-80, Godbout 8085/8088 CPU. \*\* NOTE \*\* S.D.Sales SBC-100 and SBC-200 will not work because there are no bus disable lines on their board. Ithica Audio Z-80 cpu's have been found to be unreliable with our double density interface when running with the DMA mode of operation. ### MEMORY Tarbell 32K static, Seals 32K static, Spacebyte 16K static, Industrial Microsystems 16K, and 32K static, Godbout 32K static, Measurement System & Control DM 6400 and DMB 6400 dynamic boards, Intersystems 64 K dynamic memory, California Computer Systems 16K static.(remove U52 pin 4 on CCI board.) (if you are using a Rev F or lower Double Density board, you will have to change sWO\* on CCI memory boards. Just remove this signal from the gate that it is driving, and jumper the input of this gate over to pWR\*). Microbyte 32K static, Trace 32k static. Central Data 64K Dynamic board (modified as follows: cut U21-12, jumper U21-3 to U21-11). \*\*\* Note \*\*\* TDL/XITAN "Static" memory will not work with this interface. ### I/O interfaces Processor Tech 3P+S, MITS SIO2, Thinker Toys Switcher, Vector Graphics Bit streamer, Dynabyte Intelligent CRT, S.D.Sales VDB-8024, Godbout Interfacer I, and II, Cromemco TUART, Imsai MIO, Imsai VIO. #### Drives Shugart SA-800/801, Siemens FDD 100-8, FDD 100-8D / 120-8 / 220-8, CDC 9606 2/3, Remex RFD 4000/4001, MFE model 700, Persci 270, Persci 299B, Calcomp 142M. \*\*\* Note \*\*\* If you are using a Siemens FDD 100-8D drive, check to see that your drive is jumpered center -> H, not center -> G. NOTE \*\*\*\* In order to use the Delta Products CPU, you must disable the Power-on-jump to the prom. The following modification to the CPU card will allow you to use the bootstrap on the floppy interface. 1.() Remove IC10c, bend pin 11 out away from the socket, and put IC10c back in. 2.() Ground pin 13 of IC13c. 3.() You may have to lower the value of C-17 on the disk board to improve coldboot operation, and you may have to remove the phase 1 line (pin 25 of S-100 bus on CPU board), to improve coldboot operation. 4.( ) Cut U9c pin 2 5.() Cut 5d pin 13 6.() Jumper 5b pin 6 to 6c pin 12. (puts 4 MHz on pin 24) 7.() Cut 7c pin 12 8.() Jumper 2a pin 13 to gnd. 9.() Jumper 2a pin 12 to 5b pin 22. 10.() Jumper 2a pin 11 to 7c pin 12. (puts extra delay in pWR \*) This modification now allows you to boot up our disk controller by pushing the front panel reset button. The Measurement System & Control dynamic memory card is not guaranteed to run with an 8080 cpu and our double density interface at 2 Mhz. They will run ok at 2 or 4 Mhz using Z-80 CPUs. If you are using the Cromemco ZPU card, we have found that has trouble doing a coldboot operation. This problem does not seem to exist with every single ZPU card, but we have found that if there is a problem that the following suggestions may be tried. 1.() Lower C-17 on the disk controller board to about 100pf. 2.() Try removing phase 1 from the CPU card (pin 25 of S-100 bus). If you are using a SSM CB-2 CPU board, you should have the board jumpered as follows: ``` ( ) E4 to E5 Normal Z-80 operation ( ) E6 to E7 2 MHz clock ``` 3. ( ) El6 to El7 Jump vector disabled 4. ( ) E22 to E23 8080 I/O address option 5. ( ) E26 to E27 POC resets Z-80 option 6. ( ) El to E44 sTVAL on line 25 7. ( ) E43 to E42 sTVAL on line 25 ( ) E35 to E36 mWRITE enabled (if no front panel being used) CB-2 Switches (facing CPU board reading left to right) SF - on-on-on-on SE - off-on-off-on ### Compatible S-100 Products ``` SC - on-off-off-off-off SD - on-off-off-off-off ``` If you are going to use the Godbout 8085/8088 CPU board, you should do the following: 1. Set up the option switches as follows: ``` S1 - XA3 on XAC off IOW off 5RS off 8RS on JOR off MW on or off (depends if you have a front panel) POS off ``` S2 - all off $$53 - 1 = on \\ 2-8 = off$$ Tarbell Double Density Board Change R25 and R26 to 2.2K ohm resistors. ### DISK TEST ROUTINES #### Test routines 1. 0009 C30000 The following routines are provided so that you may test your interface for proper operation. These routines involve both the TYPE 1 and TYPE 2 commands for the floppy disk controller chip. \*\*\* Note \*\*\* These routines assume that you have a front panel on your computer. If you do not have one, you will have to modify these programs to work with a system monitor, or whatever. ``` ORG 0000 ; define disk i/o ports. DISK COMMAND PORT DCOM EOU OF8H 00F8 = ;DISK STATUS PORT DSTAT EQU DCOM 00F8 = ;TRACK PORT TRACK DCOM+1 EQU 00F9 = ;SECTOR PORT DCOM+2 00FA = SECT EOU ;DATA PORT DCOM+3 DDATA EQU 00FB = :WAIT PORT WAIT EOU DCOM+4 00FC = ;The following routine will allow you to ; check for any internal shorts or opens ; with in the floppy interface. The routine ; reads the front panel switches, writes it ; to the floppy disk data port, then reads ; it back from the floppy disk data port, and ;writes it back out to the front panel lights. ; there should be a one to one match of the ; switches to the data lights. If more than ; one light comes on at a time, there is an ;internal short on the floppy data lines. If ; a light does not come on when a switch it turned on, then there is an open line on that ;data bit. TEST ROUTINE FOR CHECKING DISK INTERNAL DATA BUS. GET FRONT PANEL DATA 0000 DBFF BUSS: IN OFFH SEND IT TO CONTROLLER OUT DDATA 0002 D3FB GET DATA BACK AGAIN IN DDATA 0004 DBFB ; INVERT FOR FRONT PANEL CMA 0006 2F ; SHOW IT ON FRONT PANEL 0007 D3FF OUT OFFH ;LOOP AGAIN ``` BUSS JMP ``` ; The following routine allows testing the ; seek operation of the interface. You will ; need to put in blank disk into the drive ; and close the door. Do not put in a disk ; which contains any important data, as you ; may wipe it out. Do not set the front panel ; switches for anything higher than 3F hex, ; as this will cause the head to slam up past track 76, possibly causing damage. ; SEEK TEST ROUTINES ; DON'T SET FRONT PANEL ; SWITCHES FOR A HEX VALUE ; HIGHER THAN 3F OR YOU WILL ; SLAM THE HEAD BEYOND TRACK ; 76. 000C DBFF SEEK: IN OFFH ; READ FRONT PANEL 000E D3FB OUT DDATA ;SEND TRACK NUMBER 0010 3E13 MVI A,13H GET SEEK COMMAND 0012 D3F8 OUT DCOM ;SEND IT 0014 C30C00 JMP SEEK ;LOOP AGAIN ;The following routine test for step in ; and step out. You will need to mount a ; disk into the drive and shut the door. ;DO NOT PRESS RUN !!! for this test. Use ; single step operation. ; The program as listed will step in toward ;track 76. To step out toward track 0, you ; need to change the 43H to a 63H. ; STEP IN/OUT ROUTINE 0017 3E43 STEP: MVI A,43H ;STEP IN COMMAND 0019 D3F8 OUT DCOM ; ISSUE COMMAND 001B C31700 JMP STEP ;LOOP AGAIN ;The following routine checks for head ;load command. You will need to mount a ; disk and shut the door to run this test. ;DO NOT USE A VALUABLE DISK !!! for this ;test. TYPE 2 COMMAND ; HEAD LOAD ROUTINE 001E 3E8C HEAD: MVI A,8CH ;HEAD LOAD COMMAND 0020 D3F8 OUT DCOM ; ISSUE COMMAND 0022 C31E00 JMP HEAD ;LOOP AGAIN ``` ### DISK TEST ROUTINES ``` The following routine reads a sector from the disk and puts the data into ; a buffer call RAMADD. This buffer can ;be anywhere in memory you wish. ; The routine saves the status of the disk ; operation at the location called STAT. ; If you have problems, check the bits at this location against the status bits ; shown in the data sheet for the floppy ; controller chip, in Appendix A (1793). ; You will need to mount a blank disk into ; the drive and shut the door. ;DO NOT USE A VALUABLE DISK !!! for this ;test. READ A SECTOR ROUTINE ; CAN BE ANYWHERE 1000H 1000 = RAMADD EQU ; ISSUE FORCE INTERRUPT A, ODOH 0025 3ED0 READ: IVM ;SEND IT DCOM 0027 D3F8 OUT ;SOME XTHL 0029 E3 ; DELAY XTHL 002A E3 ; POINT TO MEMORY BUFFER H, RAMADD LXI 002B 210010 ;LOAD SECTOR NUMBER A,1 . MVI 002E 3E01 ; SEND IT TO SECTOR PORT OUT SECT 0030 D3FA GET READ COMMAND A,8CH 0032 3E8C IVM ; ISSUE READ COMMAND DCOM OUT 0034 D3F8 ;WAIT FOR DRQ OR INTRO WAIT RLOOP: IN 0036 DBFC SET FLAGS FOR OPERATION ORA Α 0038 B7 DONE IF INTRO RDONE 0039 F24300 JΡ ; ELSE, READ A BYTE FROM DISK IN DDATA 003C DBFB ; PUT IT INTO THE BUFFER VOM M,A 003E 77 BUMP BUFFER POINTER Η 003F 23 INX ; READ NEXT BYTE FROM DISK RLOOP JMP 0040 C33600 CHECK DISK STATUS DSTAT 0043 DBF8 RDONE: IN ; SAVE THE STATUS STAT STA 0045 324B00 ; HARD LOOP JMP HJMP 0048 C34800 HJMP: :SAVE STATUS HERE WHEN DONE 0 STAT: DB 004B 00 ``` ``` ; The following routine writes one ; sector of the disk. If you have ;a problem, check the status bits ; at location WSTAT against the bits ; in the data sheet for the 1793 in ; the appendix. ;This routine is similar in operation ; to the read a sector routine above. ; You must mount a blank disk into the ;drive and shut the door. ;DO NOT USE A VALUABLE DISK !!! as ; this routine does write on the disk, ; and you will lose any data on the ;sector you write to. ; WRITE A SECTOR ROUTINE 004C 3ED0 WRITE: MVI A, ODOH ; FORCE INTERRUPT COMMAND 004E D3F8 TUO DCOM ; ISSUE IT 0050 E3 XTHL ; SOME 0051 E3 XTHL ; DELAY 0052 3E01 IVM A,1 GET SECTOR NUMBER 0054 D3FA OUT SECT ;TELL SECTOR PORT 0056 3EAC MVI A, OACH GET WRITE COMMAND 0058 D3F8 OUT DCOM ; ISSUE IT 005A DBFC WLOOP: IN WAIT ;WAIT FOR DRQ OR INTRQ 005C B7 ORA ;SET FLAGS FOR OPERATION 005D F26700 JP WDONE ;JUMP WHEN INTRO 0060 7E MOV A, M GET DATA FROM BUFFER 0061 D3FB OUT DDATA ; PUT IT TO DISK 0063 23 INX Η ;BUMP BUFFER POINTER 0064 C35A00 JMP WLOOP ;LOOP FOR MORE DATA 0067 DBF8 WDONE: IN DSTAT ; CHECK DISK STATUS 0069 E6FD ANI 0FDH ; MASK OFF NON ERROR BITS 006B 327100 STA STATW ; SAVE STATUS BITS 006E C36E00 WJMP: JMP WJMP ; HARD LOOP WHEN DONE 0071 00 STATW: DB 0 ; SAVE STATUS BITS HERE ``` ### 2. Port and bit explanation The explanation for the disk controller ports are covered in the 1793 data sheet and will not be covered here. The extended ports FC and FD Hex will be explained. An input from port FC Hex is a combination hardware-software port which allows the disk controller to stall the CPU with a wait state to allow the disk controller chip time to access the data bus. This is generated by the gating of DRQ and INTRQ from the floppy chip onto either the XRDY or PRDY lines of the bus. Bit 7 of port FC is also used in the software during programmed data transfers to tell the software read/write and seek routines when an interrupt from the floppy chip has occurred. When this bit is a 'l' an interrupt has occurred, and the status port of the 1793 must be read to clear it back to a '0'. An output to port FC Hex is also the drive select, density select, and side select port. A break down of the port is as follows: | LSB | (bit 0) | x | not used | |----------|---------|----------|---------------------------------------------------| | | | | not used | | 1 | (bit 2) | x | not used | | 1 | (bit 3) | | <pre>0 = single density, 1 = double density</pre> | | | (bit 4) | 1/0 | binary value for drive select } 4 drives max | | | (bit 5) | 1/0 | binary value for drive select | | | (bit 6) | 1/0 | 0 = side 0, 1 = side 1 (side select) | | V<br>MSB | (bit 7) | <b>x</b> | not used | An input from port FD Hex is the software port for checking the INTRQ of the floppy chip while running under DMA operation. This port polls bit 7 of this port looking for a low (0), which tells the CPU that the DMA operation is complete. A one (1) means that the DMA is busy. All the rest of the bits in this port are not used. An output to port FD hex may be used to change the extended addressing bits on Al6 - A23 during a DMA read or write operation. This port is an latched 8 bit port and is enabled on to the S-100 bus only during DMA read or write operations. The bits which are placed into the latch, (U68), should be written only when the DMA controller is in-active, (not doing disk transfers). A typical example might be: MVI A,1 ;select bank # 1 OUT OFDH ;set extended port latch # DISK TEST ROUTINES ``` dma operation ;transfer to/from new bank now ;dma operation complete MVI A,0 ;select bank # 0 ;set extended port latch etc ``` ### TROUBLE-SHOOTING This section of the manual is to help you trouble-shoot the interface in case you are having problems. ### 1. Interface between computer cards. Compare the section on the IEEE S-100 pin functions (section 10), to the pin function list in your cpu manual, to find out if there are any conflicts with your computer and the new bus specification. If there are, you should make any necessary corrections for compatibility. ### 2. Compatible interfaces Review the section on S-100 compatible interfaces (section 11). The computer cards listed in section 11 only represents those products that we here at Tarbell Electronics have tested ourselves, and in no way defines any not in this list as not working with out interface. We would like to encourge our customers to send in any information with regard to other manufactures products that do or 'do not' work with our interface. If they don't work, maybe a reason as to why could be sent along also. Also, some Z80 cpu cards will not boot up correctly at 4Mhz with our board. We have found that in some cases cutting the phase 1 line (25) of the bus on the controller card may help. ### Jumper selections Review the section on jumper selection. If you are going to be running our software, then you must select the address jumper from the table in section 6 for the address range of E0 - FD hex. If you are going to use the on-board bootstrap prom, you "MUST" use the phantom line (pin 67) to disable your first memory card (addressed at 0000 hex). If you are going to use your own bootstrap program, then you must defeat our on-board bootstrap prom. If you have a revision B or below, you can turn off the on-board bootstrap by pulling out U35 pin 5 from it's socket, and then ground U33 pin 13 to U33 pin 7. For revision C and above, follow the instructions listed in the jumper options section. #### 4. XRDY or PRDY line If you are getting lost data errors, besure to check which line you are using for the processor wait line. This is important during a cold start load, as the on-board prom bootstrap uses this line during the booting of the system. If you are using the wrong line, you will more than likely get lost data errors. If you are not sure which line to use, review the section on jumper options (section 6). #### 5. Disk Problems Be sure that the disk you are trying to read has the correct format on it. It must be an IBM soft sector disk, 128 bytes/sector. Most disks shipped from the manufacturer that claim to be soft sector, are. But if you have reformatted the disk with the wrong format program, then you will have trouble reading it on this interface. If ### TROUBLE-SHOOTING you have any questions about this, review the documentation that supplied with the interface. I can not over stress this point. ### 6. Drives This interface is Shugart compatible only. That means drives which comply with the Shugart pin functions will more than likely work with no probblems. If you do have problems, consult the OEM drive manual or the factory for information. The drives that have been tested here at Tarbell Electronics are the Siemens, Shugart, and Persci drives. Also, be sure that the drive is set up for soft sector operation. We have recieved drives from the factory, set up for hard sector in the past. So look carefully at your drives for possibility. ### 7. Review Be sure and review section 2-3 in the front of this manual very carefully, as it can not be over stressed enough. ### 8. Symptoms vs Possible causes This table is a list of possible troubles with possible causes to look at. ### Possible cause 1. Won't boot..... Check pin 67. Must use Phantom line on first memory card. Make sure jump enables to system proms is defeated. Check for disk with correct format. Check C17, may have to change the value of this capacitor as outlined in section 2-3 of this manual. Check disk drive power supply lines for all voltage return lines tied to one commen place at power supply. Is there an operating system on the disk you are trying to boot from? 2. Won't run DMA ..... Check IEEE standard for compatibility with memory cards, cpu, and i/o cards in your system. If you are using a dynamic memory are there any problems with refreshing and control lines necessary to initiate the refreshing signals and our interface? Check for slow memory chips, e.g. old 2102's. Check our compatibility list. 3. Double density errors . Are you using a good certified double denstiy disk? Have you adjusted the pre-comp settings for your drive using the DFRAND.COM program? Is your drive rated for double denstiy operation? ### TROUBLE-SHOOTING 4. Won't run at all ..... Check voltage regulator on interface for correct voltage of +5 volts. Are any changes required to the board in the way of corrections to mistakes on the board? If not a factory assembled unit, are the changes on correctly? ### DISK DRIVE SETUP This interface is designed for Shugart compatible drives. This includes Siemens drives also. Jumpers and power requirements for both drives are listed below. Power requirements: ### Shugart and Siemens | DC Power | | AC power | | |-----------|-------------|----------|--------------| | Pin 3 - 5 | volt return | Pin 2 | 110 volts AC | | Pin 4 - 5 | volt return | | frame ground | | Pin 5 + 5 | volts DC | | 110 volts AC | \*\*\*\* Note \*\*\*\* Be sure all return lines are connected solidly together at the power supply end. If they are not, you may experience actual disk data errors. ### Shugart Drive Jumpers The following jumpers should be installed on each drive used: | 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 (no<br>DS1<br>T1<br>T3<br>T4<br>T5 | A<br>B<br>C<br>Y<br>T2<br>DS<br>ot 801) 800<br>DS2 | A<br>B<br>C<br>Y<br>T2<br>DS<br>800<br>DS3 | A<br>B<br>C<br>Y<br>T2<br>DS<br>800<br>DS4 | Note: Some drives may have a jumper installed at X. If so, remove it. DISK DRIVE SETUP Siemens ---- Drive select: Drive A Drive B Drive C Drive d Radial Sel 0 Radial Sel 1 Radial Sel 2 Radial Sel 3 Note: Some drives may come with Radial Sel 0 etched on the board. You will have to cut this etch if you wish to use it for a drive other than Drive A. If you are using more tan one drive, you must remove all the terminating resistor packs but the last one in the daisy chain. Be sure that the drive is jumpered for SOFT SECTOR options. If you have any doubts, consult the OEM manual for your drive. Siemens model FDD 100-8D drives may come from the manufacture with jumper G installed. You must change this jumper to location H for proper operation with our interface. # Persci drives Changes are required to the Persci drive to make it look like a Shugart compatible drive. These changes are listed in the Jumper section of this manual. # 54/7400 54H/74H00 54S/74S00 54LS/74LS00 **QUAD 2-INPUT NAND GATE** ## **ORDERING CODE:** See Section 9 | | PIN | COMMERCIAL GRADE | MILITARY GRADE | PKG | |--------------------|-----|-------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------|------| | PKGS | OUT | $V_{CC} = +5.0 \text{ V} \pm 5\%,$<br>$T_A = 0^{\circ} \text{C to} + 70^{\circ} \text{C}$ | $V_{CC} = +5.0 \text{ V} \pm 10\%,$<br>$T_A = -55^{\circ}\text{ C} \text{ to } +125^{\circ}\text{ C}$ | TYPE | | Plastic<br>DIP (P) | Α | 7400PC, 74H00PC<br>74LS00PC, 74S00PC | | 9A | | Ceramic<br>DIP (D) | Α | 7400DC, 74H00DC<br>74LS00DC, 74S00DC | 5400DM, 54H00DM<br>54LS00DM, 54S00DM | 6A | | Flatpak | Α | 74LS00FC, 74S00FC | 54LS00FM, 54S00FM | 31 | | ( <b>F</b> ) | В | 7400FC, 74H00FC | 5400FM, 54H00FM | | #### INPUT LOADING/FAN-OUT: See Section 3 for U.L. definitions | PINS | <b>54/74 (U.L.)</b> | <b>54/74H (U.L.)</b> | <b>54/74S (U.L.)</b> | 54/74LS (U.L.) | |-------------------|---------------------|------------------------|----------------------|-----------------------------| | | HIGH/LOW | HIGH/LOW | HIGH/LOW | HIGH/LOW | | Inputs<br>Outputs | 1.0/1.0<br>20/10 | 1.25/1.25<br>12.5/12.5 | 1.25/1.25<br>25/12.5 | 0.5/0.25<br>10/5.0<br>(2.5) | 54/7404 54H/74H04 54S/74S04 54S/74S04A 54LS/74LS04 **HEX INVERTER** ORDERING CODE: See Section 9 | | | E. See Section 9 | | | |--------------------|-----|------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------|------| | | PIN | COMMERCIAL GRADE | MILITARY GRADE | PKG | | PKGS | OUT | $V_{CC} = +5.0 \text{ V } \pm 5\%,$<br>$T_A = 0^{\circ}\text{C to } +70^{\circ}\text{C}$ | $V_{CC} = +5.0 \text{ V} \pm 10\%,$<br>$T_A = -55^{\circ} \text{ C} \text{ to } +125^{\circ} \text{ C}$ | TYPE | | Plastic<br>DIP (P) | A | 7404PC, 74H04PC<br>74S04PC, 74S04APC<br>74LS04PC | | 9A | | Ceramic<br>DIP (D) | · A | 7404DC, 74H04DC<br>74S04DC, 74S04ADC<br>74LS04DC | 5404DM, 54H04DM<br>54S04DM, 54S04ADM<br>54LS04DM | 6A | | Flatpak | Α | 74S04FC, 74S04AFC<br>74LS04FC | 54S04FM, 54S04AFM<br>54LS04FM | 31 | | (F) | В | 7404FC, 74H04FC | 5404FM, 54H04FM | | | INPUT LOADING/FAN-OUT: | See Section | 3 for | U.L. | definitions | |------------------------|-------------|-------|------|-------------| | | | | | | | | T | | ioi o.e. deminio | 113 | |-------------------|---------------------------------|----------------------------------|---------------------------|-----------------------------| | PINS | <b>54/74 (U.L.)</b><br>HIGH/LOW | <b>54/74H (U.L.)</b><br>HIGH/LOW | 54/74S (U.L.)<br>HIGH/LOW | 54/74LS (U.L.)<br>HIGH/LOW | | Inputs<br>Outputs | 1.0/1.0<br>20/10 | 1.25/1.25<br>12.5/12.5 | 1.25/1.25<br>25/12.5 | 0.5/0.25<br>10/5.0<br>(2.5) | # 54/7406 # HEX INVERTER BUFFER/DRIVER (With Open-Collector High-Voltage Output) ORDERING CODE: See Section 9 | PIN | | COMMERCIAL GRADE | MILITARY GRADE | PKG | |--------------------|-----|---------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------|------| | PKGS | OUT | $V_{CC} = +5.0 \text{ V } \pm 5\%,$ $T_A = 0^{\circ}\text{C to } +70^{\circ}\text{C}$ | $V_{CC} = +5.0 \text{ V} \pm 10\%,$<br>$T_A = -55^{\circ} \text{ C} \text{ to } +125^{\circ} \text{ C}$ | TYPE | | Plastic<br>DIP (P) | Α | 7406PC | | 9A | | Ceramic<br>DIP (D) | Α | 7406DC | 5406DM | 6A | | Flatpak<br>(F) | А | 7406FC | 5406FM | 31 | # INPUT LOADING/FAN-OUT: See Section 3 for U.L. definitions | PINS | <b>54/74 (U.L.)</b><br>HIGH/LOW | ` | | |-------------------|---------------------------------|---|--| | Inputs<br>Outputs | 1.0/1.0<br>OC**/10 | | | # CONNECTION DIAGRAM PINOUT A #### CONNECTION DIAGRAM PINOUT A 54/7407 HEX BUFFER/DRIVER (With Open-Collector High-Voltage Output) ORDERING CODE: See Section 9 14 Vcc COMMERCIAL GRADE MILITARY GRADE PIN 13 PKG **PKGS** $V_{CC} = +5.0 \text{ V } \pm 5\%$ , $V_{CC} = +5.0 \text{ V} \pm 10\%$ OUT 12 $T_A = 0$ °C to +70°C TYPE $T_A = -55^{\circ} C \text{ to } +125^{\circ} C$ Plastic 11 7407PC DIP (P) 10 9A Ceramic Α 7407DC 5407 DM DIP (D) 6A GND 7 Flatpak 7407FC (F) 5407FM 31 INPUT LOADING/FAN-OUT: See Section 3 for U.L. definitions 54/74 (U.L.) PINS HIGH/LOW Inputs 1.0/1.0 **Outputs** OC"/10 # 54/7408 54H/74H08 54S/74S08 54LS/74LS08 QUAD 2-INPUT AND GATE # CONNECTION DIAGRAMS PINOUT A **ORDERING CODE:** See Section 9 | | PIN | COMMERCIAL GRADE | MILITARY GRADE | PKG | |--------------------|-----|----------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------|----------| | PKGS | OUT | $V_{CC} = +5.0 \text{ V } \pm 5\%,$<br>$T_A = 0^{\circ} \text{ C to } +70^{\circ} \text{ C}$ | $V_{CC} = +5.0 \text{ V} \pm 10\%,$<br>$T_A = -55^{\circ} \text{ C} \text{ to } +125^{\circ} \text{ C}$ | TYPE | | Plastic<br>DIP (P) | Α | 7408PC, 74H08PC<br>74S08PC, 74LS08PC | | 9A | | Ceramic<br>DIP (D) | Α | 7408DC, 74H08DC<br>74S08DC, 74LS08DC | 5408DM, 54H08DM<br>54S08DM, 54LS08DM | .6A | | Flatpak | Α | 7408FC, 74S08FC<br>74LS08FC | 5408FM, 54S08FM<br>54LS08FM | 31 | | (F) | В | 74H08FC | 54H08FM | <u> </u> | #### INPUT LOADING/FAN-OUT: See Section 3 for U.L. definitions | PINS | <b>54/74 (U.L.)</b> | <b>54/74H (U.L.)</b> | <b>54/74S (U.L.)</b> | <b>54/74LS (U.L.)</b> | |-------------------|---------------------|------------------------|----------------------|-----------------------------| | | HIGH/LOW | HIGH/LOW | HIGH/LOW | HIGH/LOW | | Inputs<br>Outputs | 1.0/1.0<br>20/10 | 1.25/1.25<br>12.5/12.5 | 1.25/1.25<br>25/12.5 | 0.5/0.25<br>10/5.0<br>(2.5) | # 54/7411 54H/74H11 54S/74S11 54LS/74LS11 TRIPLE 3-INPUT AND GATE # ORDERING CODE: See Section 9 | 1 | | 0.00 | | | |--------------------|-----|----------------------------------------------------------------------------------------|----------------------------------------------------------------------|-----| | | PIN | COMMERCIAL GRADE | MILITARY GRADE | T | | PKGS | OUT | $V_{CC} = +5.0 \text{ V} \pm 5\%,$<br>$T_A = 0^{\circ}\text{C to} +70^{\circ}\text{C}$ | V <sub>CC</sub> = +5.0 V ±10%,<br>T <sub>A</sub> = -55° C to +125° C | PKG | | Plastic<br>DIP (P) | Α | 7411PC, 74H11PC<br>74S11PC, 74LS11PC | | 9A | | Ceramic<br>DIP (D) | Α | 7411DC, 74H11DC<br>74S11DC, 74LS11DC | 5411DM, 54H11DM<br>54S11DM, 54LS11DM | 6A | | Flatpak<br>(F) | Α | 7461150 7410 | 54S11FM, 54LS11FM | | | (F) | | 741150 74111 | 5411FM, 54H11FM | 31 | # INPUT LOADING/FAN-OUT: See Section 3 for U.L definitions | | | | for U.L definition | าร | |-------------------|---------------------------------|---------------------------|---------------------------|--------------------| | PINS | <b>54/74 (U.L.)</b><br>HIGH/LOW | 54/74H (U.L.)<br>HIGH/LOW | 54/74S (U.L.)<br>HIGH/LOW | 54/74LS (U.L.) | | Inputs<br>Outputs | 1.0/1.0<br>20/10 | 1.25/1.25<br>12.5/12.5 | 1.25/1.25<br>25/12.5 | 0.5/0.25<br>10/5.0 | | | | | | (2.5) | # 54/7421 54H/74H21 54LS/74LS21 **DUAL 4-INPUT POSITIVE AND GATE** **ORDERING CODE:** See Section 9 | | PIN | COMMERCIAL GRADE | MILITARY GRADE | PKG | |--------------------|-----|------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------|------| | PKGS | OUT | $V_{CC} = +5.0 \text{ V } \pm 5\%,$<br>$T_A = 0^{\circ}\text{C to } +70^{\circ}\text{C}$ | $V_{CC} = +5.0 \text{ V} \pm 10\%,$<br>$T_A = -55^{\circ}\text{ C to} + 125^{\circ}\text{ C}$ | TYPE | | Plastic<br>DIP (P) | Α | 7421PC, 74H21PC<br>74LS21PC | | 9A | | Ceramic<br>DIP (D) | Α | 7421DC, 74H21DC<br>74LS21DC | 5421DM, 54H21DM<br>54LS21DM | 6A | | Flatpak | Α | 7421FC, 74LS21FC | 5421FM, 54LS21FM | 31 | | (F) | В | 74H21FC | 54H21FM | Ŭ. | ## INPUT LOADING/FAN-OUT: See Section 3 for U.L. definitions | PINS | <b>54/74 (U.L.)</b> | <b>54/74H (U.L.)</b> | <b>54/74L\$ (U.L.)</b> | |-------------------|---------------------|------------------------|-----------------------------| | | HIGH/LOW | HIGH/LOW | HIGH/LOW | | Inputs<br>Outputs | 1.0/1.0<br>20/10 | 1.25/1.25<br>12.5/12.5 | 0.5/0.25<br>10/5.0<br>(2.5) | # 54/7432 54\$/74\$32 54LS/74LS32 QUAD 2-INPUT OR GATE ORDERING CODE: See Section 9 | | PIN | COMMERCIAL GRADE | MILITARY GRADE | | |--------------------|-----|-----------------------------|--------------------------------------------------------------------|-------------| | PKGS | OUT | V | V <sub>CC</sub> = +5.0 V ±10%,<br>T <sub>A</sub> = -55°C to +125°C | PKG<br>TYPE | | Plastic<br>DIP (P) | Α | 7432PC, 74S32PC<br>74LS32PC | 33 3 10 +125° C | 9A | | Ceramic<br>DIP (D) | Α | 7432DC, 74S32DC<br>74LS32DC | 5432DM, 54S32DM<br>54LS32DM | <br>6A | | Flatpak<br>(F) | Α | 7432FC, 74S32FC<br>74LS32FC | 5432FM, 54S32FM<br>54LS32FM | 31 | CONNECTION DIAGRAM PINOUT A | INPUT LO | DADING/FAN-OUT: See Section 3 for U.L. | | |----------|----------------------------------------|-------------| | | 3 for III | da4::+: | | | Transfer of Idi O.L. | definitions | | | | | | PINS | <b>54/74 (U.L.)</b><br>HIGH/LOW | <b>54/74S (U.L.)</b><br>HIGH/LOW | 54/74LS (U.L.) | |-------------------|---------------------------------|----------------------------------|--------------------| | Inputs<br>Outputs | 1.0/1.0<br>20/10 | 1.25/1.25<br>25/12.5 | 0.5/0.25<br>10/5.0 | | | | | (2.5) | # 54/7438 54LS/74LS38 # **QUAD 2-INPUT NAND BUFFER** (With Open-Collector Output) ## ORDERING CODE: See Section 9 | | PIN | COMMERCIAL GRADE | MILITARY GRADE | PKG | |--------------------|-----|----------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------|------| | PKGS OU | OUT | $V_{CC} = +5.0 \text{ V } \pm 5\%,$<br>$T_A = 0^{\circ} \text{ C to } +70^{\circ} \text{ C}$ | $V_{CC} = +5.0 \text{ V} \pm 10\%,$<br>$T_A = -55^{\circ} \text{ C} \text{ to } +125^{\circ} \text{ C}$ | TYPE | | Plastic<br>DIP (P) | Α | 7438PC, 74LS38PC | | 9A | | Ceramic<br>DIP (D) | Α | 7438DC, 74LS38DC | 5438DM, 54LS38DM | 6A | | Flatpak<br>(F) | Α | 7438FC, 74LS38FC | 5438FM, 54LS38FM | 31 | | | | | | | CONNECTION DIAGRAM PINOUT A # INPUT LOADING/FAN-OUT: See Section 3 for U.L. definitions | PINS | <b>54/74 (U.L.)</b><br>HIGH/LOW | 54/74LS (U.L.)<br>HIGH/LOW | |-------------------|---------------------------------|------------------------------| | Inputs<br>Outputs | 1.0/1.0<br>OC**/30 | 0.5/0.25<br>OC**/15<br>(7.5) | # 54/7474 54H/74H74 54S/74S74 54LS/74LS74 DUAL D-TYPE POSITIVE EDGE-TRIGGERED FLIP-FLOP **DESCRIPTION** — The '74 devices are dual D-type flip-flops with Direct Clear and Set inputs and complementary $(Q, \overline{Q})$ outputs. Information at the input is transferred to the outputs on the positive 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. After the Clock Pulse input threshold voltage has been passed, the Data input is locked out and information present will not be transferred to the outputs until the next rising edge of the Clock Pulse input. ## TRUTH TABLE (Each Half) | INPUT | OUT | PUTS | |-------|--------|-------| | @ tn | @ t | n + 1 | | D | Q | ā | | H | L<br>H | H | ## Asynchronous Inputs: LOW input to $\overline{S}_D$ sets Q to HIGH level LOW input to $\overline{C}_D$ sets Q to LOW level Clear and Set are independent of clock Simultaneous LOW on $\overline{C}_D$ and $\overline{S}_D$ makes both Q and $\overline{Q}$ HIGH H = HIGH Voltage Level L = LOW Voltage Level tn = Bit time before clock pulse. tn + 1 = Bit time after clock pulse ## **ORDERING CODE:** See Section 9 | | PIN | COMMERCIAL GRADE | MILITARY GRADE | T | |--------------------|-----|------------------------------------------------------------------------------------------|--------------------------------------------------------------------|-------------| | PKGS | OUT | $V_{CC} = +5.0 \text{ V} \pm 5\%,$<br>$T_A = 0^{\circ} \text{C to} +70^{\circ} \text{C}$ | V <sub>CC</sub> = +5.0 V ±10%,<br>T <sub>A</sub> = -55°C to +125°C | PKG<br>TYPE | | Plastic<br>DIP (P) | Α | 7474PC, 74H74PC<br>74S74PC, 74LS74PC | 0 10 1120 0 | 9A | | Ceramic<br>DIP (D) | А | 7474DC, 74H74DC<br>74S74DC, 74LS74DC | 5474DM, 54H74DM<br>54S74DM, 54LS74DM | 6A | | Flatpak | Α | 74S74FC, 74LS74FC | 54S74FM, 54LS74FM | | | (F) | В | 747450 | 5474FM, 54H74FM | 31 | # CONNECTION DIAGRAMS PINOUT A #### PINOUT B #### LOGIC SYMBOL Vcc = Pin 14 (4) GND = Pin 7 (11) # 54/7493A 54LS/74LS93 ## **DIVIDE-BY-SIXTEEN COUNTER** #### MODE SELECTION | | RESET<br>INPUTS | | out | ГРИТ | s | |-----------------|-----------------|----|----------------|----------------|----------------| | MR <sub>1</sub> | MR <sub>2</sub> | Qo | Q <sub>1</sub> | Q <sub>2</sub> | Q <sub>3</sub> | | Н | Н | L | L | L | L | | L | Н | | Co | unt | | | H | L. | | Co | unt | | | L | L | | Co | unt | | H = HIGH Voltage Level L = LOW Voltage Level **DESCRIPTION** — The '93 is a 4-stage ripple counter containing a high speed flip-flop acting as a divide-by-two and three flip-flops connected as a divide-by-eight. HIGH signals on the Master Reset (MR) inputs override the clocks #### **ORDERING CODE:** See Section 9 and force all outputs to the LOW state. | | PIN | COMMERCIAL GRADE | MILITARY GRADE | PKG | | |--------------------|-----|------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------|------------|--| | PKGS | OUT | $V_{CC} = +5.0 \text{ V } \pm 5\%,$<br>$T_A = 0^{\circ}\text{C to } +70^{\circ}\text{C}$ | $V_{CC} = +5.0 \text{ V} \pm 10\%,$<br>$T_A = -55^{\circ} \text{ C} \text{ to } +125^{\circ} \text{ C}$ | TYPE | | | Plastic<br>DIP (P) | Α | 7493APC, 74LS93PC | | 9A | | | Ceramic<br>DIP (D) | Α | 7493ADC, 74LS93DC | 5493ADM, 54LS93DM | 6 <b>A</b> | | | Flatpak<br>(F) | A | 7493AFC, 74LS93FC | 5493AFM, 54LS93FM | 31 | | # CONNECTION DIAGRAM PINOUT A #### LOGIC SYMBOL V<sub>CC</sub> = Pin 5 GND = Pin 10 NC = Pins 4, 6, 7, 13 #### TRUTH TABLE | COLINIT | ( | DUTI | PUTS | 3 | |---------|---|----------------|----------------|----------------| | COUNT | Q | Q <sub>1</sub> | Q <sub>2</sub> | Q <sub>3</sub> | | 0 | L | L | L | L | | 1 | Н | L | L | L | | 2 | L | Н | L | Ē | | 3 | Н | Н | L | L | | 4 | L | L | Н | L | | 5 | Н | L | Н | L<br>L<br>L | | 6 | L | Н | Н | | | 7 | н | Н | Н | L | | 8 | L | L | L | Н | | 9 | Н | L | L | Н | | 10 | L | Н | L | Н | | 11 | Н | Н | L | Н | | 12 | L | L | Н | Н | | 13 | Н | L | Н | н | | 14 | L | Н | Н | Н | | 15 | Н | Н | Н | Н | NOTE: Output Q0 connected to $\overline{CP}_1$ . # 54\$/74\$113 54LS/74LS113 # DUAL JK EDGE-TRIGGERED FLIP-FLOP DESCRIPTION — The '113 offers individual J, K, Set and Clock inputs. When the clock goes HIGH the inputs are enabled and data may be entered. The logic level of the J and K inputs may be changed when the clock pulse is HIGH and the bistable will perform according to the Truth Table as long as minimum setup and hold times are observed. Input data is transferred to the outputs on the falling edge of the clock pulse. #### TRUTH TABLE | INP | JTS | OUTPUT | |-----|-----|----------------------| | @ | tn | @ t <sub>n + 1</sub> | | J | K | a | | L | L | Qn | | L | Н | L | | Н | L | Н | | Н | Н | $\overline{Q}_n$ | #### Asynchronous Input: LOW input to \$\overline{S}\_D\$ sets Q to HIGH level Set is independent of clock $\begin{array}{l} t_n \, \mp \, \text{Bit time before clock pulse.} \\ t_n \, + \, t_n \, = \, \text{Bit time after clock pulse.} \\ H \, = \, HIGH \, \, \text{Voltage Level} \end{array}$ L = LOW Voltage Level ## **ORDERING CODE:** See Section 9 | | <del></del> | · · · · · · · · · · · · · · · · · · · | | | | |--------------------|-------------|------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------|------|--| | | PIN | COMMERCIAL GRADE | MILITARY GRADE | PKG | | | PKGS | OUT | $V_{CC} = +5.0 \text{ V } \pm 5\%,$<br>$T_A = 0^{\circ}\text{C to } +70^{\circ}\text{C}$ | $V_{CC} = +5.0 \text{ V} \pm 10\%,$<br>$T_A = -55^{\circ}\text{C to} +125^{\circ}\text{C}$ | TYPE | | | Plastic<br>DIP (P) | А | 74S113PC, 74LS113PC | | 9A | | | Ceramic<br>DIP (D) | А | 74S113DC, 74LS113DC | 54S113DM, 54LS113DM | 6A | | | Flatpak<br>(F) | A | 74S113FC, 74LS113FC | 54S113FM, 54LS113FM | 31 | | #### **CONNECTION DIAGRAM** PINOUT A #### LOGIC SYMBOL Vcc = Pin 14 GND = Pin 7 ## 54/74123 # DUAL RETRIGGERABLE RESETTABLE MULTIVIBRATOR **DESCRIPTION** — Each half of the '123 features retriggerable capability, complementary dc level triggering and overriding Direct Clear. When a circuit is in the quasi-stable (delay) state, another trigger applied to the inputs (per the Truth Table) will cause the delay period to start again, without disturbing the outputs. By repeating this process, the output pulse period (Q HIGH, $\overline{Q}$ LOW) can be made as long as desired. Alternatively, a delay period can be terminated at any time by a LOW signal on $\overline{C}_D$ , which also inhibits triggering. An internal connection from $\overline{C}_D$ to the input gate makes it possible to trigger the circuit by a positive-going signal on $\overline{C}_D$ , as shown in the Truth Table. For timing capacitor values greater than 1000 pF, the output pulse width is defined as follows. $t_{w}=0.28~R_{X}C_{X}~(1.0+0.7/R_{X})$ Where $t_{w}$ is in ns, $R_{X}$ is in $k\Omega$ and $C_{X}$ is in pF. #### **ORDERING CODE:** See Section 9 | | PIN | COMMERCIAL GRADE | MILITARY GRADE | PKG | |--------------------|-----|------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------|------| | PKGS OUT | | $V_{CC} = +5.0 \text{ V } \pm 5\%,$<br>$T_A = 0^{\circ}\text{C to } +70^{\circ}\text{C}$ | $V_{CC} = +5.0 \text{ V} \pm 10\%,$<br>$T_A = -55^{\circ} \text{ C to } +125^{\circ} \text{ C}$ | TYPE | | Plastic<br>DIP (P) | Α | 74123PC | | 9B | | Ceramic<br>DIP (D) | Α | 74123DC | 54123DM | 6B | | Flatpak<br>(F) | Α | 74123FC | 54123FM | 4L | # CONNECTION DIAGRAM PINOUT A #### LOGIC SYMBOL # 54/74125 54LS/74LS125A # QUAD BUS BUFFER GATE (With 3-State Outputs) **ORDERING CODE:** See Section 9 | - | | | | | | |--------------------|-----|----------------------------------------------------------------------------------------------|--------------------------------------------------------------------|------|--| | | PIN | COMMERCIAL GRADE | MILITARY GRADE | PKG | | | PKGS | оит | $V_{CC} = +5.0 \text{ V } \pm 5\%,$<br>$T_A = 0^{\circ} \text{ C to } +70^{\circ} \text{ C}$ | V <sub>CC</sub> = +5.0 V ±10%,<br>T <sub>A</sub> = -55°C to +125°C | TYPE | | | Plastic<br>DIP (P) | А | 74125PC, 74LS125APC | | 9A | | | Ceramic<br>DIP (D) | А | 74125DC, 74LS125ADC | 54125DM, 54LS125ADM | 6A | | | Flatpak<br>(F) | Α | 74125FC, 74LS125AFC | 54125FM, 54LS125AFM | 31 | | # INPUT LOADING/FAN-OUT: See Section 3 for U.L. definitions | PINS | <b>54/74 (U.L.)</b><br>HIGH/LOW | <b>54/74LS (U.L.)</b><br>HIGH/LOW | |-------------------|---------------------------------|-----------------------------------| | Inputs<br>Outputs | 1.0/1.0<br>130/10<br>(50) | 0.5/0.25<br>65/15<br>(25)/(7.5) | #### **CONNECTION DIAGRAM** PINOUT A #### TRUTH TABLE | IN | PUTS | ОИТРИТ | |----|------|--------| | Ē | D | 001101 | | L | L | L | | L | Н | н | | Н | X | Z | H = HIGH Voltage Level L = LOW Voltage Level X = Immaterial Z = High Impedance # 545/745138 54LS/74LS138 ## 1-OF-8 DECODER/DEMULTIPLEXER **DESCRIPTION** — The '138 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 '138 devices or to a 1-of-32 decoder using four '138 devices and one inverter. The '138 is fabricated with the Schottky barrier diode process for high speed. - SCHOTTKY PROCESS FOR HIGH SPEED - DEMULTIPLEXING CAPABILITY - MULTIPLE INPUT ENABLE FOR EASY EXPANSION - ACTIVE LOW MUTUALLY EXCLUSIVE OUTPUTS #### **ORDERING CODE:** See Section 9 | | PIN | COMMERCIAL GRADE | MILITARY GRADE | PKG | |--------------------|-----|------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------|------------| | PKGS | OUT | $V_{CC} = +5.0 \text{ V } \pm 5\%,$<br>$T_A = 0^{\circ}\text{C to } +70^{\circ}\text{C}$ | $V_{CC} = +5.0 \text{ V} \pm 10\%,$<br>$T_A = -55^{\circ}\text{ C} \text{ to } +125^{\circ}\text{ C}$ | TYPE | | Plastic<br>DIP (P) | A | 74S138PC, 74LS138PC | | 9B | | Ceramic<br>DIP (D) | Α | 74S138DC, 74LS138DC | 54S138DM, 54LS138DM | 6B | | Flatpak<br>(F) | A | 74S138FC, 74LS138FC | 54S138FM, 54LS138FM | <b>4</b> L | #### TRUTH TABLE | INPUTS | | | | | | | רטס | PUT | s | | | | | |--------|----|----------------|----|----------------|----------------|----|-----|-----|----|----|----------------|----------------|----| | Ē1 | Ē2 | E <sub>3</sub> | Αó | A <sub>1</sub> | A <sub>2</sub> | Ōο | Ō1 | Ō2 | Ō3 | Ō4 | Ō <sub>5</sub> | Ō <sub>6</sub> | Ō7 | | Н | Х | Х | Х | Х | Х | Н | Н | Н | Н | Н | Н | Н | Н | | x | Н | Х | Х | Χ | Χ | Н | Н | Н | Н | Н | Н | Н | Н | | x | Х | L | Х | X | Х | н | Н | Н | Н | Н | Н | Н | Н | | L | L | н | L | L | L | L | Н | Н | Н | н | Н | Н | Н | | L | L | н | Н | L | L | Н | L | Н | Н | Н | Н | Н | Н | | L | L | н | L | Н | L | Н | Н | L | Н | Н | Н | Н | Н | | L | L | Н | Н | Н | L | н | Н | Н | L | Н | Η, | Н | Н | | L | L | н | L | L | Н | н | Н | Н | Н | L | Н | Н | Н | | L | L | Н | Н | L | Н | н | Н | Н | Н | Н | L | Н | Н | | L | L | Н | L | Н | Н | Н | Н | Н | Н | Н | H | L | Н | | L | L | Н | Н | Н | Н | Н | Н | Н | Н | Н | Н | Н | L | H = HIGH Voltage Level L = LOW Voltage Level X = Immaterial #### CONNECTION DIAGRAM PINOUT A #### LOGIC SYMBOL $V_{CC} = Pin 16$ GND = Pin 8 ## 54/74145 ## 1-OF-10 DECODER/DRIVER (With Open-Collector Outputs) **DESCRIPTION**—The '145 decoder/drivers are designed to accept BCD inputs and provide appropriate outputs to drive 7-segment numerical displays. All outputs remain OFF for all invalid binary input conditions. These devices are designed for use as indicator/relay drivers or as open-collector logic circuit drivers. Each of the high breakdown (15 V) output transistors will sink up to 80 mA of current. - OPEN-COLLECTOR OUTPUTS - 80 mA CURRENT SINKING - 15 V GUARANTEED BREAKDOWN **ORDERING CODE:** See Section 9 | | T | T | | | |--------------------|-----|----------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------|------| | | PIN | COMMERCIAL GRADE | MILITARY GRADE | PKG | | PKGS | ОПТ | $V_{CC} = +5.0 \text{ V } \pm 5\%,$<br>$T_A = 0^{\circ} \text{ C to } +70^{\circ} \text{ C}$ | $V_{CC} = +5.0 \text{ V} \pm 10\%,$<br>$T_A = -55^{\circ} \text{ C to} + 125^{\circ} \text{ C}$ | TYPE | | Plastic<br>DIP (P) | Α | 74145PC | | 9B | | Ceramic<br>DIP (D) | Α | 74145DC | 54145DM | 7B | | Flatpak<br>(F) | Α | 74145FC | 54145FM | 4L | ## INPUT LOADING/FAN-OUT: See Section 3 for U.L. definitions | PIN NAMES | DESCRIPTION | <b>54/74 (U.L.)</b><br>HIGH/LOW | |-----------------------------------------------------|---------------------------------|---------------------------------| | $\frac{A_0 - A_3}{\overline{O}_0 - \overline{O}_9}$ | BCD Inputs Outputs (Active LOW) | 1.0/1.0<br>OC*/12.5 | OC - Open Collector #### TRUTH TABLE | | INPUTS | | | | | | | OU | TPU | rs | | *************************************** | | | |----|----------------|----------------|------------|----|----|----|----|----|----------------|------------|----|-----------------------------------------|----|---| | Ao | A <sub>1</sub> | A <sub>2</sub> | <b>A</b> 3 | Ō₀ | Ō1 | Ō₂ | Оз | Ō₄ | Ō <sub>5</sub> | <b>Ō</b> 6 | Ō7 | Ō <sub>8</sub> | Ō9 | | | L | L | L | L | L | Н | Н | Н | Н | Н | Н | Н | Н | Н | ۱ | | Н | L | L | L | Н | L | Н | Н | Н | Н | Н | н | Н | н | ı | | L | Н | L | L | Н | Н | L | Н | Н | Н | Н | Н | Н | н | П | | Н | Н | L | L | Н | Н | Н | L | Н | Н | Н | Н | Н | Н | I | | L | L | Н | L | н | Н | н | Н | L | Н | H. | н. | н | н | • | | Н | L | Н | L | Н | Н | Н | H | Н | Ļ | Н | Н | Н | н | | | L | Н | Н | L | Н | Н | Н | Н | Н | Н | L | Н | Н | н | | | Н | Н | Н | L | Н | Н | Н | Н | Н | Н | Н | L | Н | н | | | L | L | L | н | Н | Н | Н | н | н | н | н | Н | L | н | | | Н | L | L | н | Н | Н | Н | Н | Н | Н | Н | Н | Н | L | | | L | Н | L | н | Н | Н | Н | Н | Н | Н | Н | Н | Н | н | | | Н | Н | L | н | Н | H | Н | н | Н | Н | Н | Н | Н | н | | | L | L | н | н | Н | н | Н | Н | н | Н | н | н | н | н | | | Н | L | Н | н | Н | Н | Н | Н | Н | Н | Н | Н | Н | н | | | L | Н | Н | н | Н | Н | Н | Н | Н | Н | Н | н | Н | н | | | Н | Н | Н | н | Н | Н | Н | Н | Н | Н | Н | Н | Н | н | | LOGIC SYMBOL H = HIGh Voltage Leve # 54/74161 • 54LS/74LS161 54/74163 • 54LS/74LS163 # SYNCHRONOUS PRESETTABLE BINARY COUNTERS **DESCRIPTION** — The '161 and '163 are high speed synchronous modulo-16 binary counters. They are synchronously presettable for application in programmable dividers and have two types of Count Enable inputs plus a Terminal Count output for versatility in forming synchronous multistage counters. The '161 has an asynchronous Master Reset input that overrides all other inputs and forces the outputs LOW. The '163 has a Synchronous Reset input that overrides counting and parallel loading and allows the outputs to be simultaneously reset on the rising edge of the clock. For functional description and detail specifications please refer to the '160 data sheet. For S-TTL and LP-TTL versions please see the 9316 data sheet. - SYNCHRONOUS COUNTING AND LOADING - HIGH SPEED SYNCHRONOUS EXPANSION - LS VERSIONS FULLY EDGE TRIGGERED #### **ORDERING CODE:** See Section 9 | PIN | | COMMERCIAL GRADE | MILITARY GRADE | PKG | |--------------------|-----|--------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------|------| | PKGS | оит | $V_{CC} = +5.0 \text{ V } \pm 5\%,$<br>$T_A = 0^{\circ}\text{ C to } +70^{\circ}\text{ C}$ | $V_{CC} = +5.0 \text{ V} \pm 10\%,$<br>$T_A = -55^{\circ} \text{ C} \text{ to} + 125^{\circ} \text{ C}$ | TYPE | | Plastic<br>DIP (P) | Α | 74161PC, 74LS161PC<br>74163PC, 74LS163PC | | 9B | | Ceramic<br>DIP (D) | А | 74161DC, 74LS161DC<br>74163DC, 74LS163DC | 54161DM, 54LS161DM<br>54163DM, 54LS163DM | 7B | | Flatpak<br>(F) | Α | 74161FC, 74LS161FC<br>74163FC, 74LS163FC | 54161FM, 54LS161FM<br>54163FM, 54LS163FM | 4L | ## **CONNECTION DIAGRAM** PINOUT A 15 TC 14 0₀ 13 Q1 P1 4 P<sub>2</sub> 5 12 **Q**2 P3 6 11 Q. 10 CET 9 PË \*MR for '161 \*SR for '163 LOGIC SYMBOL \*MR for '161 V<sub>CC</sub> = Pin 16 \*SR for '163 Gnd = Pin 8 #### STATE DIAGRAM # 54/74174 54\$/74\$174 54LS/74LS174 HEX D FLIP-FLOP DESCRIPTION - The '174 is a high speed hex D flip-flop. The device is used primarily as a 6-bit edge-triggered storage register. The information on the D inputs is transferred to storage during the LOW-to-HIGH clock transition. The device has a Master Reset to simultaneously clear all flip-flops. - EDGE-TRIGGERED D-TYPE INPUTS - BUFFERED POSITIVE EDGE-TRIGGERED CLOCK - ASYNCHRONOUS COMMON RESET #### **ORDERING CODE:** See Section 9 | | PIN | COMMERCIAL GRADE | MILITARY GRADE | PKG | |--------------------|-----|------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------|------| | PKGS | OUT | $V_{CC} = +5.0 \text{ V } \pm 5\%,$<br>$T_A = 0^{\circ}\text{C to } +70^{\circ}\text{C}$ | $V_{CC} = +5.0 \text{ V} \pm 10\%,$<br>$T_A = -55^{\circ}\text{ C} \text{ to } +125^{\circ}\text{ C}$ | TYPE | | Plastic<br>DIP (P) | Α | 74174PC,<br>74S174PC, 74LS174PC | | 9B | | Ceramic<br>DIP (D) | Α | 74174DC,<br>74S174DC, 74LS174DC | 54174DM,<br>54S174DM, 54LS174DM | 6B | | Flatpak<br>(F) | Δ | 74174FC,<br>74S174FC, 74LS174FC | 54174FM,<br>54S174FM, 54LS174FM | 4L | #### CONNECTION DIAGRAM PINOUT A #### LOGIC SYMBOL Vcc = Pin 16 GND = Pin 8 ## TRUTH TABLE | INPUTS | OUTPUTS | |-------------------------------|----------------------| | @ $t_n$ , $\overline{MR} = H$ | @ t <sub>n + 1</sub> | | D <sub>n</sub> | Qn | | Н | Н | | L | L | $t_n=Bit\ time\ before\ positive-going\ clock\ transition$ $t_{n+1}=Bit\ time\ after\ positive-going\ clock\ transition$ H = HIGH Voltage Level # 54/74193 54LS/74LS193 ## **UP/DOWN BINARY COUNTER** (With Separate Up/down Clocks) **DESCRIPTION** — The '193 is an up/down modulo-16 binary counter. Separate Count Up and Count Down Clocks are used and in either counting mode the circuits operate synchronously. The outputs change state synchronous with the LOW-to-HIGH transitions on the clock inputs. Separate Terminal Count Up and Terminal Count Down outputs are provided which are used as the clocks for subsequent stages without extra logic, thus simplifying multistage counter designs. Individual preset inputs allow the circuits to be used as programmable counters. Both the Parallel Load (PL) and the Master Reset (MR) inputs asynchronously override the clocks. For functional description and detail specifications please refer to the '192 data sheet. #### **ORDERING CODE:** See Section 9 | | PIN | COMMERCIAL GRADE | MILITARY GRADE | PKG | |--------------------|-----|------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------|------| | PKGS | оит | $V_{CC} = +5.0 \text{ V } \pm 5\%,$<br>$T_A = 0^{\circ}\text{C to } +70^{\circ}\text{C}$ | $V_{CC} = +5.0 \text{ V} \pm 10\%,$<br>$T_A = -55^{\circ}\text{ C to } +125^{\circ}\text{ C}$ | TYPE | | Plastic<br>DIP (P) | Α | 74193PC, 74LS193PC | | 9B | | Ceramic<br>DIP (D) | Α | 74193DC, 74LS193DC | 54193DM, 54LS193DM | 6B | | Flatpak<br>(F) | A | 74193FC, 74LS193FC | 54193FM, 54LS193FM | 4L | #### CONNECTION DIAGRAM PINOUT A #### LOGIC SYMBOL V<sub>CC</sub> = Pin 16 GND = Pin 8 ## 54LS/74LS373 # OCTAL TRANSPARENT LATCH (With 3-State Outputs) **DESCRIPTION** — The '373 consists of eight latches with 3-state outputs for bus organized system applications. The flip-flops appear transparent to the data when Latch Enable ( $\stackrel{\frown}{LE}$ ) is HIGH. When LE is LOW, the data that meets the setup times is latched. Data appears on the bus when the Output Enable ( $\stackrel{\frown}{OE}$ ) is LOW. When $\stackrel{\frown}{OE}$ is HIGH the bus output is in the high impedance state. - EIGHT LATCHES IN A SINGLE PACKAGE - 3-STATE OUTPUTS FOR BUS INTERFACING #### **ORDERING CODE:** See Section 9 | | PIN | COMMERCIAL GRADE | MILITARY GRADE | PKG | |--------------------|-----|---------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------|------| | PKGS | OUT | $V_{CC} = +5.0 \text{ V } \pm 5\%,$ $T_A = 0^{\circ}\text{C to } +70^{\circ}\text{C}$ | $V_{CC} = +5.0 \text{ V} \pm 10\%,$<br>$T_A = -55^{\circ}\text{ C to } +125^{\circ}\text{ C}$ | TYPE | | Plastic<br>DIP (P) | Α | 74LS373PC | | 9Z | | Ceramic<br>DIP(D) | Α | 74LS373DC | 54LS373DM | 4E | | Flatpak<br>(F) | Α | 74LS373FC | 54LS373FM | 4F | # CONNECTION DIAGRAM PINOUT A #### LOGIC SYMBOL V<sub>CC</sub> = Pin 20 GND = Pin 10 #### LOGIC DIAGRAM ## 8T97 HEX TRI-STATE INVERTERS | INPU | T5 | OUTPUT | |------|----|------------| | DIS | 12 | OUT | | н | X | Hi-Z | | L | Н | <b>H</b> . | | L | L | L | # 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 # 8208 /8287 8-BIT PARALLEL BIDIRECTIONAL BUS DRIVERS - Data Bus Buffer Driver for MCS-86<sup>TM</sup>, MCS-80<sup>TM</sup>, MCS-85<sup>TM</sup>, and MCS-48<sup>TM</sup> - 3-State Outputs - High Output Drive Capability for Driving System Data Bus - 20-Pin Package with 0.3" Center - Fully Parallel 8-Bit Transceivers - No Output Low Noise when Entering or Leaving High Impedance State $8\,2\,0\,8$ The and 8287 are 8-bit bipolar transceivers with 3-state outputs. The 8287 inverts the input data at its outputs while the does not. Thus, a wide variety of applications for buffering in microcomputer systems can be met. $8\,2\,0\,8$ ## 8257/8257-5 PROGRAMMABLE DMA CONTROLLER - MCS-85<sup>TM</sup> Compatible 8257-5 - **4-Channel DMA Controller** - Priority DMA Request Logic - Channel Inhibit Logic - **Terminal Count and Modulo 128 Outputs** - s Single TTL Clock - Single + 5V Supply - m Auto Load Mode The Intel® 8257 is a 4-channel direct memory access (DMA) controller. It is specifically designed to simplify the transfer of data at high speeds for the Intel® microcomputer systems. Its primary function is to generate, upon a peripheral request, a sequential memory address which will allow the peripheral to read or write data directly to or from memory. Acquisition of the system bus in accomplished via the CPU's hold function. The 8257 has priority logic that resolves the peripherals requests and issues a composite hold request to the CPU. It maintains the DMA cycle count for each channel and outputs a control signal to notify the peripheral that the programmed number of DMA cycles is complete. Other output control signals simplify sectored data transfers. The 8257 represents a significant savings in component count for DMA-based microcomputer systems and greatly simplifies the transfer of data at high speed between peripherals and memories. 170 P 17/14 HLDA # MCS-80/85 #### **FUNCTIONAL DESCRIPTION** #### General The 8257 is a programmable, Direct Memory Access (DMA) device which, when coupled with a single Intel® 8212 I/O port device, provides a complete four-channel DMA controller for use in Intel® microcomputer systems. After being initialized by software, the 8257 can transfer a block of data, containing up to 16,384 bytes, between memory and a peripheral device directly, without further intervention required of the CPU. Upon receiving a DMA transfer request from an enabled peripheral, the 8257: - Acquires control of the system bus. - 2. Acknowledges that requesting peripheral which is connected to the highest priority channel. - Outputs the least significant eight bits of the memory address onto system address lines A<sub>0</sub>-A<sub>7</sub>, outputs the most significant eight bits of the memory address to the 8212 I/O port via the data bus (the 8212 places these address bits on lines A<sub>8</sub>-A<sub>15</sub>), and - Generates the appropriate memory and I/O read/ write control signals that cause the peripheral to receive or deposit a data byte directly from or to the addressed location in memory. The 8257 will retain control of the system bus and repeat the transfer sequence, as long as a peripheral maintains its DMA request. Thus, the 8257 can transfer a block of data to/from a high speed peripheral (e.g., a sector of data on a floppy disk) in a single "burst". When the specified number of data bytes have been transferred, the 8257 activates its Terminal Count (TC) output, informing the CPU that the operation is complete. The 8257 offers three different modes of operation: (1) DMA read, which causes data to be transferred from memory to a peripheral; (2) DMA write, which causes data to be transferred from a peripheral to memory; and (3) DMA verify, which does not actually involve the transfer of data. When an 8257 channel is in the DMA verify mode, it will respond the same as described for transfer operations, except that no memory or I/O read/write control signals will be generated, thus preventing the transfer of data. The 8257, however, will gain control of the system bus and will acknowledge the peripheral's DMA request for each DMA cycle. The peripheral can use these acknowledge signals to enable an internal access of each byte of a data block in order to execute some verification procedure, such as the accumulation of a CRC (Cyclic Redundancy Code) checkword. For example, a block of DMA verify cycles might follow a block of DMA read cycles (memory to peripheral) to allow the peripheral to verify its newly acquired data. #### **Block Diagram Description** #### 1. DMA Channels The 8257 provides four separate DMA channels (labeled CH-0 to CH-3). Each channel includes two sixteen-bit registers: (1) a DMA address register, and (2) a terminal count register. Both registers must be initialized before a channel is enabled. The DMA address register is loaded with the address of the first memory location to be accessed. The value loaded into the low-order 14-bits of the terminal count register specifies the number of DMA cycles minus one before the Terminal Count (TC) output is activated. For instance, a terminal count of 0 would cause the TC output to be active in the first DMA cycle for that channel. In general, if N = the number of desired DMA cycles, load the value N-1 into the low-order 14-bits of the terminal count register. The most significant two bits of the terminal count register specify the type of DMA operation for that channel. Figure 1. 8257 Block Diagram Showing DMA Channels These two bits are not modified during a DMA cycle, but can be changed between DMA blocks. Each channel accepts a DMA Request (DRQn) input and provides a DMA Acknowledge (DACKn) output. #### (DRQ 0-DRQ 3) DMA Request: These are individual asynchronous channel request inputs used by the peripherals to obtain a DMA cycle. If not in the rotating priority mode then DRQ 0 has the highest priority and DRQ 3 has the lowest can be generated by raising the request line and holding it high until DMA acknowledge. For multiple DMA cycles (Burst Mode) the request line is held high until the DMA acknowledge of the last cycle arrives. #### (DACK 0 - DACK 3) DMA Acknowledge: An active low level on the acknowledge output informs the peripheral connected to that channel that it has been selected for a DMA cycle. The DACK output acts as a "chip select" for the peripheral device requesting service. This line goes active (low) and inactive (high) once for each byte transferred even if a burst of data is being transferred. #### 2. Data Bus Buffer This three-state, bi-directional, eight bit buffer interfaces the 8257 to the system data bus. #### $(D_0 - D_7)$ Data Bus Lines: These are bi-directional three-state lines. When the 8257 is being programmed by the CPU, eight-bits of data for a DMA address register, a terminal count register or the Mode Set register are received on the data bus. When the CPU reads a DMA address register, a terminal count register or the Status register, the data is sent to the CPU over the data bus. During DMA cycles (when the 8257 is the bus master), the 8257 will output the most significant eight-bits of the memory address (from one of the DMA address registers) to the 8212 latch via the data bus. These address bits will be transferred at the beginning of the DMA cycle; the bus will then be released to handle the memory data transfer during the balance of the DMA cycle. | | T | |--------|-----------------------| | BIT 14 | TYPE OF DMA OPERATION | | 0 | Verify DMA Cycle | | 1 | Write DMA Cycle | | 0 | Read DMA Cycle | | 1 | (illegal) | | | 0 | Figure 2. 8257 Block Diagram Showing Data Bus Buffer #### 3. Read/Write Logic When the CPU is programming or reading one of the 8257's registers (i.e., when the 8257 is a "slave" device on the system bus), the Read/Write Logic accepts the I/O Read (I/OR) or I/O Write (I/OW) signal, decodes the least significant four address bits, $(A_0 \cdot A_3)$ , and either writes the contents of the data bus into the addressed register (if I/OW is true) or places the contents of the addressed register onto the data bus (if I/OR is true). During DMA cycles (i.e., when the 8257 is the bus "master"), the Read/Write Logic generates the I/O read and memory write (DMA write cycle) or I/O Write and memory read (DMA read cycle) signals which control the data link with the peripheral that has been granted the DMA cycle. Note that during DMA transfers Non-DMA I/O devices should be de-selected (disabled) using "AEN" signal to inhibit I/O device decoding of the memory address as an erroneous device address. #### (VOR) I/O Read: An active-low, bi-directional three-state line. In the "slave" mode, it is an input which allows the 8-bit status register or the upper/lower byte of a 16-bit DMA address register or terminal count register to be read. In the "master" mode, I/OR is a control output which is used to access data from a peripheral during the DMA write cycle. #### (I/OW) I/O Write: An active-low, bi-directional three-state line. In the "slave" mode, it is an input which allows the contents of the data bus to be loaded into the 8-bit mode set register or the upper/lower byte of a 16-bit DMA address register or terminal count register. In the "master" mode, I/OW is a control output which allows data to be output to a peripheral during a DMA read cycle. #### (CLK) Clock Input: Generally from an Intel® 8224 Clock Generator device. (¢2 TTL) or Intel® 8085A CLK output. #### (RESET) Reset: An asynchronous input (generally from an 8224 or 8085 device) which disables all DMA channels by clearing the mode register and 3-states all control lines. #### $(A_0 - A_3)$ Address Lines: These least significant four address lines are bi-directional. In the "slave" mode they are inputs which select one of the registers to be read or programmed. In the "master" mode, they are outputs which constitute the least significant four bits of the 16-bit memory address generated by the 8257. #### (CS) Chip Select: An active-low input which enables the I/O Read or I/O Write input when the 8257 is being read or programmed in the "slave" mode. In the "master" mode, CS is automatically disabled to prevent the chip from selecting itself while performing the DMA function. Figure 5. 8257 Block Diagram Showing Read/Write Logic Function #### 4. Control Logic This block controls the sequence of operations during all DMA cycles by generating the appropriate control signals and the 16-bit address that specifies the memory location to be accessed. #### $(A_4 - A_7)$ Address Lines: These four address lines are three-state outputs which constitute bits 4 through 7 of the 16-bit memory address generated by the 8257 during all DMA cycles. #### (READY) Ready: This asynchronous input is used to elongate the memory read and write cycles in the 8257 with wait states if the selected memory requires longer cycles. #### (HRQ) Hold Request: This output requests control of the system bus. In systems with only one 8257, HRQ will normally be applied to the HOLD input on the CPU. #### (HLDA) Hold Acknowledge: This input from the CPU indicates that the 8257 has acquired control of the system bus. #### (MEMR) Memory Read: This active-low three-state output is used to read data from the addressed memory location during DMA Read cycles. #### (MEMW) Memory Write: This active-low three-state output is used to write data into the addressed memory location during DMA Write cycles. #### (ADSTB) Address Strobe: This output strobes the most significant byte of the memory address into the 8212 device from the data bus. #### (AEN) Address Enable: This output is used to disable (float) the System Data Bus and the System Control Bus. It may also be used to disable (float) the System Address Bus by use of an enable on the Address Bus drivers in systems to inhibit non-DMA devices from responding during DMA cycles. It may be further used to isolate the 8257 data bus from the System Data Bus to facilitate the transfer of the 8 most significant DMA address bits over the 8257 data I/O pins without subjecting the System Data Bus to any timing constraints for the transfer. When the 8257 is used in an I/O device structure (as opposed to memory mapped), this AEN output should be used to disable the selection of an I/O device when the DMA address is on the address bus. The I/O device selection should be determined by the DMA acknowledge outputs for the 4 channels. #### (TC) Terminal Count: This output notifies the currently selected peripheral that the present DMA cycle should be the last cycle for this data block. If the TC STOP bit in the Mode Set register is set, the selected channel will be automatically disabled at the end of that DMA cycle. TC is activated when the 14-bit value in the selected channel's terminal count register equals zero. Recall that the low-order 14-bits of the terminal count register should be loaded with the values (n-1), where n = the desired number of the DMA cycles. #### (MARK) Modulo 128 Mark: This output notifies the selected peripheral that the current DMA cycle is the 128th cycle since the previous MARK output. MARK always occurs at 128 (and all multiples of 128) cycles from the end of the data block. Only if the total number of DMA cycles (n) is evenly divisable by 128 (and the terminal count register was loaded with n-1), will MARK occur at 128 (and each succeeding multiple of 128) cycles from the beginning of the data block. Figure 4. 8257 Block Diagram Showing Control Logic and Mode Set Register #### 5. Mode Set Register When set, the various bits in the Mode Set register enable each of the four DMA channels, and allow four different options for the 8257: The Mode Set register is normally programmed by the CPU after the DMA address register(s) and terminal count register(s) are initialized. The Mode Set Register is cleared by the RESET input, thus disabling all options, inhibiting all channels, and preventing bus conflicts on power-up. A channel should not be left enabled unless its DMA address and terminal count registers contain valid values; otherwise, an inadvertent DMA request (DRQn) from a peripheral could initiate a DMA cycle that would destroy memory data. The various options which can be enabled by bits in the Mode Set register are explained below: #### **Rotating Priority Bit 4** In the Rotating Priority Mode, the priority of the channels has a circular sequence. After each DMA cycle, the priority of each channel changes. The channel which had just been serviced will have the lowest priority. If the ROTATING PRIORITY bit is not set (set to a zero), each DMA channel has a fixed priority. In the fixed priority mode, Channel 0 has the highest priority and Channel 3 has the lowest priority. If the ROTATING PRIORITY bit is set to a one, the priority of each channel changes after each DMA cycle (not each DMA request). Each channel moves up to the next highest priority assignment, while the channel which has just been serviced moves to the lowest priority assignment: | | CHANNEL -> JUST SERVICED | CH-0 | CH-1 | CH-2 | CH-3 | |--------------------------|--------------------------|------------------------------|--------------|--------------|--------------| | Priority ——> Assignments | <b>‡</b> | CH-1<br>CH-2<br>CH-3<br>CH-0 | CH-3<br>CH-0 | CH-0<br>CH-1 | CH-1<br>CH-2 | Note that rotating priority will prevent any one channel from monopolizing the DMA mode; consecutive DMA cycles will service different channels if more than one channel is enabled and requesting service. There is no overhead penalty associated with this mode of operation. All DMA operations began with Channel 0 initially assigned to the highest priority for the first DMA cycle. #### **Extended Write Bit 5** If the EXTENDED WRITE bit is set, the duration of both the MEMW and I/OW signals is extended by activating them earlier in the DMA cycle. Data transfers within microcomputer systems proceed asynchronously to allow use of various types of memory and I/O devices with different access times. If a device cannot be accessed within a specific amount of time it returns a "not ready" indication to the 8257 that causes the 8257 to insert one or more wait states in its internal sequencing. Some devices are fast enough to be accessed without the use of wait states, but if they generate their READY response with the leading edge of the I/OW or MEMW signal (which generally occurs late in the transfer sequence), they would normally cause the 8257 to enter a wait state because it does not receive READY in time. For systems with these types of devices, the Extended Write option provides alternative timing for the I/O and memory write signals which allows the devices to return an early READY and prevents the unnecessary occurrence of wait states in the 8257, thus increasing system throughput. #### TC Stop Bit 6 If the TC STOP bit is set, a channel is disabled (i.e., its enable bit is reset) after the Terminal Count (TC) output goes true, thus automatically preventing further DMA operation on that channel. The enable bit for that channel must be re-programmed to continue or begin another DMA operation. If the TC STOP bit is not set, the occurrence of the TC output has no effect on the channel enable bits. In this case, it is generally the responsibility of the peripheral to cease DMA requests in order to terminate a DMA operation. #### Auto Load Bit 7 The Auto Load mode permits Channel 2 to be used for repeat block or block chaining operations, without immediate software intervention between blocks. Channel 2 registers are initialized as usual for the first data block; Channel 3 registers, however, are used to store the block re-initialization parameters (DMA starting address, terminal count and DMA transfer mode). After the first block of DMA cycles is executed by Channel 2 (i.e., after the TC output goes true), the parameters stored in the Channel 3 registers are transferred to Channel 2 during an "update" cycle. Note that the TC STOP feature, described above, has no effect on Channel 2 when the Auto Load bit is set. If the Auto Load bit is set, the initial parameters for Channel 2 are automatically duplicated in the Channel 3 registers when Channel 2 is programmed. This permits repeat block operations to be set up with the programming of a single channel. Repeat block operations can be used in applications such as CRT refreshing. Channels 2 and 3 can still be loaded with separate values if Channel 2 is loaded before loading Channel 3. Note that in the Auto Load mode, Channel 3 is still available to the user if the Channel 3 enable bit is set, but use of this channel will change the values to be auto loaded into Channel 2 at update time. All that is necessary to use the Auto Load registers at the conclusion of each update cycle with the new parameters for the next data block transfer. Each time that the 8257 enters an update cycle, the update flag in the status register is set and parameters in Channel 3 are transferred to Channel 2, non-destructively for Channel 3. The actual re-initialization of Channel 2 occurs at the beginning of the next channel 2 DMA cycle after the TC cycle. This will be the first DMA cycle of the new data block for Channel 2. The update flag is cleared at the conclusion of this DMA cycle. For chaning operations, the update flag in the status register can be monitored by the CPU to determine when the re-initialization process has been completed so that the next block parameters can be safely loaded into Channel 3. #### 6. Status Register The eight-bit status register indicates which channels have reached a terminal count condition and includes the update flag described previously. The TC status bits are set when the Terminal Count (TC) output is activated for that channel. These bits remain set until the status register is read or the 8257 is reset. The UPDATE FLAG, however, is not affected by a status register read operation. The UPDATE FLAG can be cleared by resetting the 8257, by changing to the non-auto load mode (i.e., by resetting the AUTO LOAD bit in the Mode Set register) or it can be left to clear itself at the completion of the update cycle. The purpose of the UPDATE FLAG is to prevent the CPU from inadvertently skipping a data block by overwriting a starting address or terminal count in the Channel 3 registers before those parameters are properly auto-loaded into Channel 2. The user is cautioned against reading the TC status register and using this information to reenable channels that have not completed operation. Unless the DMA channels are inhibited a channel could reach terminal count (TC) between the status read and the mode write. DMA can be inhibited by a hardware gate on the HRQ line or by disabling channels with a mode word before reading the TC status. Figure 5. Autoload Timing # MCS-80/85 #### **OPERATIONAL SUMMARY** ## Programming and Reading the 8257 Registers There are four pairs of "channel registers": each pair consisting of a 16-bit DMA address register and a 16-bit terminal count register (one pair for each channel). The 8257 also includes two "general registers": one 8-bit Mode Set register and one 8-bit Status register. The registers are loaded or read when the CPU executes a write or read instruction that addresses the 8257 device and the appropriate register within the 8257. The 8228 generates the appropriate read or write control signal (generally I/OR or I/OW while the CPU places a 16-bit address on the system address bus, and either outputs the data to be written onto the system data bus or accepts the data being read from the data bus. All or some of the most significant 12 address bits A<sub>4</sub>-A<sub>15</sub> (depending on the systems memory, I/O configuration) are usually decoded to produce the chip select (CS) input to the 8257. An I/O Write input (or Memory Write in memory mapped I/O configurations, described below) specifies that the addressed register is to be programmed, while an I/O Read input (or Memory Read) specifies that the addressed register is to be read. Address bit 3 specifies whether a "channel register" ( $A_3 = 0$ ) or the Mode Set (program only)/Status (read only) register ( $A_3 = 1$ ) is to be accessed. The least significant three address bits, $A_0$ – $A_2$ , indicate the specific register to be accessed. When accessing the Mode Set or Status register, $A_0$ – $A_2$ are all zero. When accessing a channel register bit $A_0$ differentiates between the DMA address register ( $A_0$ = 0) and the terminal count register ( $A_0$ = 1), while bits $A_1$ and $A_2$ specify one of the | CONTROL INPUT | CS | I/OW | I/OR | A3 | |---------------------------------------|----|------|------|----| | Program Half of a<br>Channel Register | 0 | 0 | 1 | 0 | | Read Half of a<br>Channel Register | 0 | 1 | 0 | 0 | | Program Mode Set<br>Register | 0 | 0 | 1 | 1 | | Read Status Register | 0 | 1 | 0 | 1 | four channels. Because the "channel registers" are 16bits, two program instruction cycles are required to load or read an entire register. The 8257 contains a first/last (F/L) flip flop which toggles at the completion of each channel program or read operation. The F/L flip flop determines whether the upper or lower byte of the register is to be accessed. The F/L flip flop is reset by the RESET input and whenever the Mode Set register is loaded. To maintain proper synchronization when accessing the "channel registers" all channel command instruction operations should occur in pairs, with the lower byte of a register always being accessed first. Do not allow CS to clock while either I/OR or I/OW is active, as this will cause an erroneous F/L flip flop state. In systems utilizing an interrupt structure, interrupts should be disabled prior to any paired programming operations to prevent an interrupt from splitting them. The result of such a split would leave the F/L F/F in the wrong state. This problem is particularly obvious when other DMA channels are programmed by an interrupt structure. #### 8257 Register Selection | | 1 | AD | DRES | S INPL | JT\$ | ] | BI-DIRECTIONAL DATA | | | | | | A BUS | | |-------------------------|-------|------------|-----------------------|--------|------|-----|---------------------|--------|-----------|-----------------|--------------------------------------------------|----------------|-------|-----| | REGISTER | BYTE | <b>A</b> 3 | <b>A</b> <sub>2</sub> | Aı | Ao | F/L | D, | D, | D, | D4 | D, | D <sub>2</sub> | Dı | D | | CH-0 DMA Address | LSB | 0 | | 0 | 0 | 0 | <b>A</b> 7 | A | 1. | † <del>.</del> | <del> </del> | +- | + | +- | | | MSB | Ö | o | 0 | 0 | 1 | A15 | Als | As<br>Ais | A4<br>A12 | A <sub>1</sub> | A <sub>2</sub> | A | Ao | | CH-0 Terminal Count | LSB | 0 | 0 | 0 | | | C <sub>2</sub> | 1 | 1 | | | <b>A</b> 10 | Ag | As | | | MSB | ō | 0 | o | 1 | 1 | Rd | C, | Ci | C <sub>12</sub> | C, | C | C | Co | | CH-1 DMA Address | LSB | 0 | ٥ | 1 | 0 | 1 | | | 011 | C12 | CII | C10 | C, | C. | | | MSB | Ö | 0 | | 0 | 0 | Same | as Ch | ennel ( | b | | | | 1 | | CH-1 Terminal Count | LSB | 0 | 0 | 1 | | | | | | | | | 1 | | | | MSB | ō | ō | 1 | i | 1 | | | | | | 1 | | | | CH-2 DMA Address | LSB | ٥ | 1 | 0 | 0 | ٥ | | | | | | | ļ | | | | MSB | 0 | 1 | ō | Ö | 1 | Same | as Chi | innel ( | į | | | 1 | | | CH-2 Terminal Count | LSB | 0 | 1 | ٥ | 1 | 0 | | | | | | | | | | | MSB | ō | 1 | ō | i | 1 1 | | | | | | | | l | | CH-3 DMA Address | LSB | | 1 | 1 | 0 | 0 | | | | | | | | | | | MSB . | 0 | 1 | 1 | ŏ | 1 1 | Same | es Cha | nnel ( | | | | | ļ | | CH-3 Terminal Count | LSB | | 1 | • | 1 | | | | | | | | | 1 | | | MSB | 0 | 1 | 1 | i | 1 | | | | | | | | | | MODE SET (Program only) | - | 1 | | ٥ | 0 | | AL | TCS | EW | RP | | | | | | STATUS (Read only) | _ | | | • | | 0 | 0 | .08 | E# | 75 | EN3 | EN2 | EN1 | ENO | <sup>\*</sup>A<sub>0</sub>-A<sub>15</sub>: DMA Starting Address, C<sub>0</sub>-C<sub>13</sub>: Terminal Count value (N-1), Rd and Wr: DMA Verify (00), Write (01) or Read (10) cycle selection, AL: Auto Load, TCS: TC STOP, EW: EXTENDED WRITE, RP: ROTATING PRIORITY, EN3-EN0: CHANNEL ENABLE MASK, UP: UPDATE FLAG, TC3-TC0: TERMINAL COUNT STATUS BITS. 1 DRQn refers to any DRQ line on an enabled DMA channel. Figure 6. DMA Operation State Diagram #### DMA OPERATION #### Single Byte Transfers A single byte transfer is initiated by the I/O device raising the DRQ line of one channel of the 8257. If the channel is enabled, the 8257 will output a HRQ to the CPU. The 8257 now waits until a HLDA is received insuring that the system bus is free for its use. Once HLDA is received the DACK line for the requesting channel is activated (LOW). The DACK line acts as a chip select for the requesting I/O device. The 8257 then generates the read and write commands and byte transfer occurs between the selected I/O device and memory. After the transfer is complete, the DACK line is set HIGH and the HRQ line is set LOW to indicate to the CPU that the bus is now free for use. DRQ must remain HIGH until DACK is issued to be recognized and must go LOW before S4 of the transfer sequence to prevent another transfer from occuring. (See timing diagram.) #### **Consecutive Transfers** If more than one channel requests service simultaneously, the transfer will occur in the same way a burst does. No overhead is incurred by switching from one channel to another. In each S4 the DRQ lines are sampled and the highest priority request is recognized during the next transfer. A burst mode transfer in a lower priority channel will be overridden by a higher priority request. Once the high priority transfer has completed control will return to the lower priority channel if its DRQ is still active. No extra cycles are needed to execute this sequence and the HRQ line remains active until all DRQ lines go LOW. #### **Control Override** The continuous DMA transfer mode described above can be interrupted by an external device by lowering the HLDA line. After each DMA transfer the 8257 samples the HLDA line to insure that it is still active. If it is not active, the 8257 completes the current transfer, releases the HRQ line (LOW) and returns to the idle state. If DRQ lines are still active the 8257 will raise the HRQ line in the third cycle and proceed normally. (See timing diagram.) #### **Not Ready** The 8257 has a Ready input similar to the 8080A and the 8085A. The Ready line is sampled in State 3. If Ready is LOW the 8257 enters a wait state. Ready is sampled during every wait state. When Ready returns HIGH the 8257 proceeds to State 4 to complete the transfer. Ready is used to interface memory or I/O devices that cannot meet the bus set up times required by the 8257. #### Speed The 8257 uses four clock cycles to transfer a byte of data. No cycles are lost in the master to master transfer maximizing bus efficiency. A 2MHz clock input will allow the 8257 to transfer at a rate of 500K bytes/second. #### **Memory Mapped I/O Configurations** The 8257 can be connected to the system bus as a memory device instead of as an I/O device for memory mapped I/O configurations by connecting the system memory control lines to the 8257's I/O control lines and the system I/O control lines to the 8257's memory control lines. This configuration permits use of the 8080's considerably larger repertoire of memory instructions when reading or loading the 8257's registers. Note that with this connection, the programming of the Read (bit 15) and Write (bit 14) bits in the terminal count register will have a different meaning: Figure 11. Detailed System Interface Schematic | | | | <br> | |---|------|--------|------------| | | | | | | 1 | | MEMAD | <br>1/0 RD | | | | MEMWR | <br>I/O WR | | ١ | 8257 | | <br>MEM RD | | | | (/O RD | <br>MEM WR | | | l | | | | BIT 15<br>READ | BIT 14<br>WRITE | | |----------------|------------------|------------------------------------------------------------------| | 0<br>0<br>1 | 0<br>1<br>0<br>1 | DMA Verify Cycle<br>DMA Read Cycle<br>DMA Write Cycle<br>Illegal | Figure 7. System Interface for Memory Mapped I/O Figure 8. TC Register for Memory Mapped I/O Only # SYSTEM APPLICATION EXAMPLES Figure 9. Floppy Disk Controller (4 Drives) Figure 10. High-Speed Communication Controller # **ABSOLUTE MAXIMUM RATINGS\*** | Ambient Temperature Under Bias. | 0°C to 70°C | |---------------------------------|-----------------| | Storage Temperature | -65°C to +150°C | | Voltage on Any Pin | | | With Respect to Ground | 0.5V to +7V | | Power Dissipation | 1 Watt | "COMMENT: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability. # D.C. CHARACTERISTICS $T_A = 0^{\circ}$ C to 70°C, $V_{CC} = +5V \pm 5\%$ , GND = 0V | SYMBOL | PARAMETER | MIN. | MAX. | UNIT | TEST CONDITIONS | |-----------------|-----------------------------|------|---------------------|--------------|-------------------------------------------------------| | VIL | Input Low Voltage | -0.5 | 0.8 | <del> </del> | TEST CONDITIONS | | VIH | Input High Voltage | | + | Volts | | | VOL. | | 2.0 | V <sub>CC</sub> +.5 | Volts | | | | Output Low Voltage | | 0.45 | Volts | loL = 1.6 mA | | <b>У</b> он | Output High Voltage | 2.4 | Vcc | Volts | OH=-150µA for AB,<br>DB and AEN<br>OH=-80µA for other | | V <sub>HH</sub> | HRQ Output High Voltage | 3.3 | Vcc | Volts | OH = -80μA | | loc | Vcc Current Drain | | 120 | | ουμΑ | | 46 | Input Leakage | | | mA | | | <b>OFL</b> | | | ±10 / | μΑ | VIN = VCC to OV | | OFL | Output Leakage During Float | | ±10 | μΑ | Vout = Vcc to 0V | ## CAPACITANCE T<sub>A</sub> = 25°C; V<sub>CC</sub> = GND = 0V | SYMBOL | PARAMETER | 84101 | T = 1.00 | T | Υ | T | |------------------|-------------------|-------|----------|------|-----------------|-----------------| | C . | | MIN. | TYP. | MAX. | UNIT | TEST CONDITIONS | | CIN | Input Capacitance | | | 10 | ρF | fc = 1MHz | | C <sub>1/O</sub> | I/O Capacitance | | | 1 | | 10 - 111112 | | | | | | 20 | pF | Unmeasured pins | | | | | 1 | | returned to GND | | ### A.C. CHARACTERISTICS: PERIPHERAL (SLAVE) MODE $T_A = 0^{\circ} C$ to $70^{\circ} C$ , $V_{CC} = 5.0 V \pm 5\%$ ; GND = 0V (Note 1). ### 8080 Bus Parameters ### Read Cycle: | | | 8257 | | 8257-5 | | | | |-----------------|--------------------------|------|------|--------|------|------|-----------------| | Symbol | Parameter | Min. | Max. | Min. | Max. | Unit | Test Conditions | | TAR | Adr or CS↓ Setup to RD↓ | 0 | | 0 | | ns | | | T <sub>RA</sub> | Adr or CSt Hold from RDt | 0 | | 0 | | ns | | | T <sub>RD</sub> | Data Access from RD↓ | 0 | 300 | 0 | 200 | ns | (Note 2) | | T <sub>DF</sub> | DB→Float Delay from RD↑ | 20 | 150 | 20 | 100 | ns | | | TRR | RD Width | 250 | | 250 | | ns | | ### Write Cycle: | | | 8257 | 8267-5 | | | |-----------------|-----------------------|-----------|-----------|------|-----------------| | Symbol | Para meter Para meter | Min. Mex. | Min. Max. | Unit | Test Conditions | | TAW | Adr Setup to WR↓ | 20 | 20 | ns | | | Twa | Adr Hold from WR1 | 0 | 0 | ns | | | T <sub>DW</sub> | Data Setup to WR↑ | 200 | 200 | ns | | | T <sub>WD</sub> | Data Hold from WR↑ | 0 | 0 | ns | | | T <sub>WW</sub> | WR Width | 200 | 200 | ns | | ### Other Timing: | | | | 8257 | | 8257-5 | | | | |-------------------|--------------------------------------------------|------|------|------|--------|------|-----------------|--| | Symbol | Parameter | Min. | Mex. | Min. | Mex. | Unit | Test Conditions | | | T <sub>RSTW</sub> | Reset Pulse Width | 300 | | 300 | | ns | | | | TRSTD | Power Supply↑ (V <sub>CC</sub> ) Setup to Reset↓ | 500 | | 500 | | μs | | | | T <sub>r</sub> | Signal Rise Time | | 20 | | 20 | ns | | | | Tf | Signal Fall Time | | 20 | | 20 | ns | | | | TRSTS | Reset to First I/OWR | 2 | | 2 | | tcy | | | Notes: 1. All timing measurements are made at the following reference voltages unless specified otherwise: Input "1" at 2.0V, "0" at 0.8V 2. 8257: CL = 100pF, 8257-5: CL = 150pF. Output "1" at 2.0V, "0" at 0.8V ### 8257 PERIPHERAL MODE TIMING DIAGRAMS ### **Read Timing:** Input Waveform for A.C. Tests: # MCS-80/85 ### A.C. CHARACTERISTICS: DMA (MASTER) MODE $T_A = 0^{\circ}C$ to $70^{\circ}C$ , $V_{CC} = +5V \pm 5\%$ , GND = 0V. ### **Timing Requirements** | | | 82! | 57 | 82 | | | |-----------------|-------------------------------------|-------|-------------------|-------|-------------------|------| | SYMBOL | PARAMETER | MIN. | MAX. | MIN. | MAX. | UNIT | | T <sub>CY</sub> | Cycle Time (Period) | 0.320 | 4 | 0.320 | 4 | μs | | $T_{\theta}$ | Clock Active (High) | 120 | .8T <sub>CY</sub> | 80 | .8T <sub>CY</sub> | ns | | Tas | DRQ↑ Setup to θ↓ (SI, S4) | 120 | | 30 | | ns | | Тан | DRQ↓ Hold from HLDA↑ <sup>[4]</sup> | 0 | | 0 | | ns | | THS | HLDA↑ or ↓Setup to θ↓(SI, S4) | 100 | | 100 | | ns | | T <sub>RS</sub> | READY Setup Time to θ↑ (S3, Sw) | 30 | | 30 | | ns | | TRH | READY Hold Time from θ↑ (S3, Sw) | 20 | | 20 | 1 | ns | Note: 4, Tracking Parameter. ### **Tracking Parameters** Signals labeled as Tracking Parameters (footnotes 4-7 under A.C. Specifications) are signals that follow similar paths through the silicon die. The propagation speed of these signals varies in the manufacturing process but the relationship between all these parameters is constant. The variation is less than or equal to 50 ns. Suppose the following timing equation is being evaluated, $T_{A(MIN)} + T_{B(MAX)} \le 150 \text{ ns}$ and only minimum specifications exist for $T_A$ and $T_B$ . If $T_{A(MIN)}$ is used, and if $T_A$ and $T_B$ are tracking parameters, $T_{B(MAX)}$ can be taken as $T_{B(MIN)}$ + 50 ns. $T_{A(MIN)} + (T_{B(MIN)}^* + 50 \text{ ns}) \le 150 \text{ ns}$ \*if $T_A$ and $T_B$ are tracking parameters # WCS-80,85 ### A.C. CHARACTERISTICS: DMA (MASTER) MODE $T_A = 0$ °C to 70 °C, $V_{CC} = +5V \pm 5\%$ , GND = 0V ### **Timing Responses** | | | 8257 | 7 | 8257 | -5 | I | |-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------|-----------------------------------------|---------------------------------------|----------------------------------------|------| | SYMBOL | PARAMETER | MIN. | MAX. | MIN. | MAX. | UNIT | | Τρα | HRQ↑ or ↓Delay from θ↑(SI,S4) (measured at 2.0V) <sup>[1]</sup> | | 160 | | 160 | ns | | T <sub>DQ1</sub> | HRQ↑ or ↓Delay from θ↑(SI,S4)<br>(measured at 3.3V) <sup>[3]</sup> | | 250 | | 250 | ns | | TAEL | AEN↑ Delay from θ ↓(S1) <sup>[1]</sup> | | 300 | | 300 | ns | | TAET | AEN↓ Delay from θ↑(SI)[1] | | 200 | | 200 | ns | | T <sub>AEA</sub> | Adr (AB) (Active) Delay from AEN1 (S1)[4] | 20 | | 20 | | ns | | T <sub>FAAB</sub> | Adr (AB) (Active) Delay from θ † (S1)[2] | | 250 | | 250 | ns | | TAFAB | Adr(AB)(Float) Delay from θ1(SI)[2] | · | 150 | | 150 | ns | | TASM | Adr(AB)(Stable) Delay from θ↑(S1)[2] | | 250 | | 250 | ns | | TAH | Adr (AB) (Stable) Hold from θ1(S1)[2] | T <sub>ASM</sub> -50 | | T <sub>ASM</sub> -50 | | ns | | TAHR | Adr(AB)(Valid) Hold from Rd†(S1,SI)[4] | 60 | | 60 | ************************************** | ns | | TAHW | Adr(AB)(Valid) Hold from Wrt(S1,SI)[4] | 300 | *************************************** | 300 | | ns | | TFADB | Adr(DB)(Active) Delay from θ↑(S1)[2] | | 300 | | 300 | ns | | TAFDB | Adr (DB) (Float) Delay from 0 † (S2)[2] | T <sub>STT</sub> +20 | 250 | T <sub>STT</sub> +20 | 170 | ns | | TASS | Adr (DB) Setup to AdrStb + (S1-S2)[4] | 100 | | 100 | | ns | | TAHS | Adr (DB) (Valid) Hold from AdrStb4(S2)[4] | 50 | | 50 | | ns | | TSTL | AdrStb† Delay from θ†(S1)[1] | | 200 | 1.1 | 200 | ns | | T <sub>STT</sub> | AdrStb↓ Delay from θ↑(S2)[1] | | 140 | | 140 | ns | | Tsw | AdrStb Width (S1-S2)[4] | T <sub>CY</sub> -100 | | T <sub>CY</sub> -100 | ····· | ns | | TASC | Rd+ or Wr(Ext)+ Delay from AdrStb+(S2)[4] | 70 | | 70 | | ns | | T <sub>DBC</sub> | Rd↓ or Wr(Ext)↓ Delay from Adr(DB)<br>(Float)(S2) <sup>[4]</sup> | 20 | | 20 | - | ns | | TAK | DACK† or ‡Delay from θ‡(S2,S1) and TC/Mark† Delay from θ†(S3) and TC/Mark‡ Delay from θ†(S4) <sup>[1,5]</sup> | · | 250 | | 250 | ns | | TDCL | $\overrightarrow{Rd}\downarrow$ or $\overrightarrow{Wr}(Ext)\downarrow$ Delay from $\theta\uparrow(S2)$ and $\overrightarrow{Wr}\downarrow$ Delay from $\theta\uparrow(S3)^{[2,6]}$ | | 200 | | 200 | ns | | Трст | $\overline{Rd}\uparrow$ Delay from $\theta\downarrow$ (S1,SI) and $\overline{Wr}\uparrow$ Delay from $\theta\uparrow$ (S4) $^{[2,7]}$ | | 200 | | 200 | ns | | TFAC | Rd or Wr (Active) from $\theta$ † (S1)[2] | | 300 | | 300 | ns | | TAFC | Rd or Wr (Float) from θ↑(SI)[2] | | 150 | | 150 | ns | | TRWM | Rd Width (S2-S1 or SI)[4] | 2TCY + Tθ-50 | | 2T <sub>CY</sub> + T <sub>θ</sub> -50 | | ns | | Twwm | Wr Width (\$3-\$4)[4] | T <sub>CY</sub> -50 | | T <sub>CY</sub> -50 | | ns | | Twwme | Wr(Ext) Width (S2-S4)[4] | 2T <sub>CY</sub> -50 | | 2T <sub>CY</sub> -50 | | ns | Notes: 1. Load = 1 TTL. 2. Load = 1 TTL + 50pF. 3. Load = 1 TTL + (R<sub>L</sub> = 3.3K), V<sub>OH</sub> = 3.3V. 4. Tracking Parameter. 5. ΔT<sub>AK</sub> < 50 ns. 6. ΔT<sub>DCL</sub> < 50 ns. 7. ΔT<sub>DCT</sub> < 50 ns. ### **DMA MODE WAVEFORMS** ### CONSECUTIVE CYCLES AND BURST MODE SEQUENCE Figure 13. Control Override Sequence Figure 14. Not Ready Sequence # FD 179X-01 Floppy Disk Formatter/Controller Family ### **FEATURES** - TWO VFO CONTROL SIGNALS - SOFT SECTOR FORMAT COMPATIBILITY - **AUTOMATIC TRACK SEEK WITH VERIFICATION** - ACCOMMODATES SINGLE AND DOUBLE **DENSITY FORMATS** IBM 3740 Single Density (FM) IBM System 34 Double Density (MFM) - READ MODE - Single/Multiple Sector Read with Automatic Search or Entire Track Read - Selectable 128 Byte or Variable length Sector - WRITE MODE - Single/Multiple Sector Write with Automatic Sector Search - Entire Track Write for Diskette Formatting - 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 - On-Chip Track and Sector Registers/Comprehensive Status Information - PROGRAMMABLE CONTROLS Selectable Track to Track Stepping Time Side Select Compare - WRITE PRECOMPENSATION (MFM AND FM) - WINDOW EXTENSION - INCORPORATES ENCODING/DECODING AND ADDRESS MARK CIRCUITRY - FD1792/4 IS SINGLE DENSITY ONLY - FD1793/4 HAS TRUE DAL LINES ### 179X-01 FAMILY CHARACTERISTICS | | CEAR ALL PROPERTY | CONTRACTOR SERVICES | CONTRACTOR SEC | | |------------------------|-------------------|---------------------------|----------------|----------| | FEATUR | ies ii | 191-01 1792-0 | 1 1793-01 | 1794-01 | | | | | + | | | | TAME 1 | X | 1 X | X | | Dotable Delete | S RAIS NA | X | Y | | | | | <del>- 1</del> | 1 0 | | | 17.4 | | | 1 1 | | | anvaceore area | 5US . | $\mathbf{X} + \mathbf{X}$ | | | | Write Precomo | | X X | Y | V | | Adjusted to the second | | <del>U U -</del> | +-0 | | | LASSE CONTRACTOR | SIUIT | <u>л</u> ј. Х | + X | <b>X</b> | ### **APPLICATIONS** FLOPPY DISK DRIVE INTERFACE SINGLE OR MULTIPLE DRIVE CONTROLLER/ **FORMATTER** NEW MINI-FLOPPY CONTROLLER FD179X SYSTEM BLOCK DIAGRAM ### **GENERAL DESCRIPTION** The FD179X are MOS LSI devices which perform the functions of a Floppy Disk Formatter/Controller in a single chip implementation. The FD179X, which can be considered the end result of both the FD1771 and FD1781 designs, is IBM 3740 compatible in single density mode (FM) and System 34 compatible in Double Density Mode (MFM). The FD179X contains all the features of its predecessor the FD1771, plus the added features necessary to read/write and format a double density diskette. These include address mark detection, FM and MFM encode and decode logic, window extension, and write precompensation. In order to maintain compatibility, the FD1771, FD1781, and FD179X designs were made as close as possible with the computer interface, instruction set, and I/O registers being identical. Also, head load control is identical. In each case, the actual pin assignments vary by only a few pins from any one to another. The processor interface consists of an 8-bit bidirectional bus for data, status, and control word transfers. The FD179X is set up to operate on a multiplexed bus with other bus-oriented devices. The FD179X is fabricated in N-channel Silicon Gate MOS technology and is TTL compatible on all inputs and outputs. The 1793 is identical to the 1791 except the DAL lines are TRUE for systems that utilize true data busses. ### **PIN OUTS** | PIN<br>NUMBER | PIN NAME | SYMBOL | FUNCTION | |---------------|--------------------------|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 1 | NO CONNECTION | NC | Pin 1 is internally connected to a back bias generator and must be left open by the user. | | 19 | MASTER RESET | MR | A logic low on this input resets the device and loads HEX 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. Also, HEX 01 is loaded into sector register. | | 20 | POWER SUPPLIES | Vss | Ground | | 21 | | <b>V</b> cc | +5V ±5% | | 40 | | <b>V</b> DD | +12V ±5% | | COMPUTER | INTERFACE: | | | | 2 | WRITE ENABLE | WE | A logic low on this input gates data on the DAL into the selected register when $\overline{CS}$ is low. | | 3 | CHIP SELECT | <del>CS</del> | A logic low on this input selects the chip and enables computer communication with the device. | | 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. | | 5,6 | REGISTER SELECT<br>LINES | A0, A1 | These inputs select the register to receive/ transfer data on the DAL lines under RE and WE control: A1 A0 RE WE 0 0 Status Reg Command Reg 0 1 Track Reg Track Reg 1 0 Sector Reg Sector Reg 1 1 Data Reg Data Reg | | 7-14 | DATA ACCESS LINES | DAL0-DAL7 | Eight bit inverted Bidirectional bus used for transfer of data, control, and status. This bus is receiver enabled by WE or transmitter enabled by RE. | | 24 | CLOCK | CLK | This input requires a free-running square wave clock for internal timing reference, 2 MHz for 8" drives, 1 MHz for mini-drives. | | PIN<br>NUMBEF | PIN NAME | SYMBOL | FUNCTION | |---------------|--------------------------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 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 operations, respectively. Use 10K pull-up resistor to +5. | | 39 | INTERRUPT<br>REQUEST | INTRQ | This open drain output is set at the completion of any command and is reset when the STATUS register is | | FLOPPY D | ISK INTERFACE: | | read or the command register is written to. Use 10K pull-up resistor to +5. | | 15 | STEP | STEP | The step output contains a pulse for each step. | | 16 | DIRECTION | DIRC | Direction Output is active high when stepping in, active low when stepping out. | | 17 | EARLY | EARLY | Indicates that the WRITE DATA pulse occurring while Early is active (high) should be shifted early for write precompensation. | | 18 | LATE | LATE | Indicates that the write data pulse occurring while Late is active (high) should be shifted late for write precompensation. | | 22 | TEST | TEST | This input is used for testing purposes only and should be tied to +5V or left open by the user unless interfacing to voice coil actuated motors. | | 23 | HEAD LOAD TIMING | HLT | When a logic high is found on the HLT input the head is assumed to be engaged. | | 25 | READ GATE | RG | A high level on this output indicates to the data separator circuitry that a field of zeros (or ones) has been encountered, and is used for synchronization. | | 26 | READ CLOCK | RCLK | A nominal square-wave clock signal derived from the data stream must be provided to this input. Phasing (i.e. RCLK transitions) relative to RAW READ is important but polarity (RCLK high or low) is not. | | 27 | RAW READ | RAW READ | The data input signal directly from the drive. This input shall be a negative pulse for each recorded flux transition. | | 28 | HEAD LOAD | HLD | The HLD output controls the loading of the Read-Write head against the media. | | 29 | TRACK GREATER<br>THAN 43 | TG43 | This output informs the drive that the Read/Write head is positioned between tracks 44-76. This output is valid only during Read and Write Commands. | | 30 | WRITE GATE | WG | This output is made valid before writing is to be performed on the diskette. | | 31 | WRITE DATA | WD | A 250 ns (MFM) or 500 ns (FM) pulse per flux transition. WD contains the unique Address marks as well as data and clock in both FM and MFM formats. | | | | | | | PIN<br>NUMBER | PIN NAME | SYMBOL | FUNCTION | |---------------|---------------------------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 32 | READY | READY | This input indicates disk readiness and is sampled for a logic high before Read or Write commands are performed. If Ready is low the Read or Write operation is not performed and an interrupt is generated. Type I operations are performed regardless of the state of Ready. The Ready input appears in inverted format as Status Register bit 7. | | 33 | WRITE FAULT<br>VFO ENABLE | WF/VFOE | This input detects writing fault indications from the drive. When WG = 1 and $\overline{\text{WF}}$ goes low the current Write command is terminated and the Write Fault status bit is set. The $\overline{\text{WF}}$ input should be made inactive (high) when WG becomes inactive. When WG = 0, this pin functions as a VFO enable output. $\overline{\text{VFOE}}$ is made active when the head is fully engaged and data is being inspected off of the diskette. | | 34 | TRACK 00 | TR00 | This input informs the FD179X that the Read/Write head is positioned over Track 00. | | 35 | INDEX PULSE | ĪΡ | This input informs the FD179X when the index hole is encountered on the diskette. | | 36 | WRITE PROTECT | WPRT | This input is sampled whenever a Write Command is received. A logic low terminates the command and sets the Write Protect Status bit. | | 37 | DOUBLE DENSITY | DDEN | This pin selects either single or double density operation. When $\overline{DDEN}=0$ , double density is selected. When $\overline{DDEN}=1$ , single density is selected. This line must be left open on the 1792/4 | #### **ORGANIZATION** The Floppy Disk Formatter block diagram is illustrated on page 5. 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 (RAW READ) 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 is 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) if the verify flag is on. 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 the 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 new command is a force interrupt. The command register can be loaded from the DAL, but not read onto the DAL. FD179X BLOCK DIAGRAM Status Register (STR)—This 8-bit register holds device Status information. The meaning of the Status bits is a function of the type of command previously executed. 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^{16} + x^{12} + x^5 + 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. Timing and Control—All computer and Floppy Disk Interface controls are generated through this logic. The internal device timing is generated from an external crystal clock. The FD1791/3 has two different modes of operation according to the state of $\overline{\text{DDEN}}$ . When $\overline{\text{DDEN}} = 0$ double density (MFM) is assumed. When $\overline{\text{DDEN}} = 1$ , single density (FM) is assumed. **AM Detector**—The address mark detector detects ID, data and index address marks during read and write operations. ### 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 FD179X. The DAL are three state buffers that are enabled as output drivers when Chip Select (CS) and Read Enable ( $\overline{\text{RE}}$ ) are active (low logic state) or act as input receivers when $\overline{\text{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 $\overline{CS}$ is made low. The address bits A1 and A0, combined with the signals $\overline{RE}$ during a Read operation or $\overline{WE}$ during a Write operation are interpreted as selecting the following registers: | A1- | ΔΛ | READ (RE) | WRITE (WE) | |-----|----|-----------------|------------------| | | | | Command Register | | 0 | 0 | Status Register | | | 0 | 1 | Track Register | Track Register | | 1 | 0 | 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 FD179X 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. At the completion of every command an INTRQ is generated. INTRQ is reset by either reading the status register or by loading the command register with a new command. In addition, INTRQ is generated if a Force Interrupt command condition is met. ### FLOPPY DISK INTERFACE The 1791 and 1793 have two modes of operation according to the state of DDEN (Pin 37). When DDEN = 1, single density is selected. In either case, the CLK input (Pin 24) is at 2 MHz. However, when interfacing with the mini-floppy, the CLK input is set at 1 MHz for both single density and double density. When the clock is at 2 MHz, the stepping rates of 3, 6, 10, and 15 ms are obtainable. When CLK equals 1 MHz these times are doubled. The 1792/4 operates in the single density mode only, with Pin 37 left open by the user. ### **HEAD POSITIONING** Five 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 0 of the command word. After the last directional step an additional 15 milliseconds of head settling time takes place if the Verify flag is set in Type I commands. Note that this time doubles to 30 ms for a 1 MHz clock. If $\overline{\text{TEST}} = 0$ , there is zero settling time. There is also a 15 ms head settling time if the E flag is set in any Type II or III command. The rates (shown in Table 1) can be applied to a Step-Direction Motor through the device interface. **Step**—A 2 $\mu$ s (MFM) or 4 $\mu$ s (FM) pulse is provided as an output to the drive. For every step pulse issued, the drive moves one track location in a direction determined by the direction output. **Direction (DIRC)**—The Direction signal is active high when stepping in and low when stepping out. The Direction signal is valid 12 $\mu$ s before the first stepping pulse is generated. When a Seek, Step or Restore command is executed an optional verification of Read-Write head position can be performed by setting bit 2 (V = 1) in the command word to a logic 1. The verification operation begins at the end of the 15 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 and an INTRQ is generated with no errors. The FD179X must find an ID field with correct track number and correct CRC within 5 revolutions of the media; otherwise the seek error is set and an INTRQ is generated. **Table 1. STEPPING RATES** | CL | _K | 2 MHz | 2 MHz | 1 MHz | 1 MHz | 2 MHz | 1 MHz | |----|----|--------|--------|--------|--------|--------|--------| | DD | EN | 0 | 1 | 0 | 1 | X | × | | R1 | R0 | TEST=1 | TEST=1 | TEST=1 | TEST=1 | TEST=0 | TEST=0 | | 0 | 0 | 3 ms | 3 ms | 6 ms | 6 ms | 200 μs | 400 μs | | 0 | 1 | 6 ms | 6 ms | 12 ms | 12 ms | 200 μs | 400 μs | | 1 | 0 | 10 ms | 10 ms | 20 ms | 20 ms | 200 μs | 400 μs | | 1 | 1 | 15 ms | 15 ms | 30 ms | 30 ms | 200 μs | 400 μs | | | | | | | | | | The Head Load (HLD) output controls the movement of the read/write head against the media. HLD is activated at the beginning of a Type I command if the h flag is set (h = 1), at the end of the Type I command if the verify flag (V = 1), or upon receipt of any Type II or III command. Once HLD is active it remains active until either a Type I command is received with (h = 0 and V = 0); or if the FD179X is in an idle state (non-busy) and 15 index pulses have occurred. Head Load Timing (HLT) is an input to the FD179X which is used for the head engage time. When HLT = 1, the FD179X assumes the head is completely engaged. The head engage time is typically 30 to 100 ms depending on drive. The low to high transition on HLD is typically used to fire a one shot. The output of the one shot is then used for HLT and supplied as an input to the FD179X. #### **HEAD LOAD TIMING** When both HLD and HLT are true, the FD179X will then read from or write to the media. The "and" of HLD and HLT appears as a status bit in Type I status. In summary for the Type I commands: if h=0 and V=0, HLD is reset. If h=1 and V=0, HLD is set at the beginning of the command and HLT is not sampled nor is there an internal 15 ms delay. If h=0 and V=1, HLD is set near the end of the command, an internal 15 ms occurs, and the FD179X waits for HLT to be true. If h=1 and V=1, HLD is set at the beginning of the command. Near the end of the command, after all the steps have been issued, an internal 15 ms delay occurs and the FD179X then waits for HLT to occur. For Type II and III commands with E flag off, HLD is made active and HLT is sampled until true. With E flag on, HLD is made active, an internal 15 ms delay occurs and then HLT is sampled until true. ### **DISK READ OPERATIONS** Sector lengths of 128, 256, 512 or 1024 are obtainable in either FM or MFM formats. For FM, DDEN should be placed to logical "1." For MFM formats, DDEN should be placed to a logical "0." Sector lengths are determined at format time by a special byte in the "ID" field. If this Sector length byte in the ID field is zero, then the sector length is 128 bytes. If 01 then 256 bytes. If 02, then 512 bytes. If 03, then the sector length is 1024 bytes. The number of sectors per track as far as the FD179X is concerned can be from 1 to 255 sectors. The number of tracks as far as the FD179X is concerned is from 0 to 255 tracks. For IBM 3740 compatibility, sector lengths are 128 bytes with 26 sectors per track. For System 34 compatibility (MFM), sector lengths are 256 bytes/sector with 26 sectors/track; or lengths of 1024 bytes/sector with 8 sectors/track. (See Sector Length Table.) For read operations, the FD179X requires RAW READ Data (Pin 27) signal which is a 250 ns pulse per flux transition and a Read clock (RCLK) signal to indicate flux transition spacings. The RCLK (Pin 26) signal is provided by some drives but if not it may be derived externally by Phase lock loops, one shots, or counter techniques. In addition, a Read Gate Signal is provided as an output (Pin 25) which can be used to inform phase lock loops when to acquire synchronization. When reading from the media in FM. RG is made true when 2 bytes of zeroes are detected. The FD179X must find an address mark within the next 10 bytes; otherwise RG is reset and the search for 2 bytes of zeroes begins all over again. If an address mark is found within 10 bytes, RG remains true as long as the FD179X is deriving any useful information from the data stream. Similarly for MFM, RG is made active when 4 bytes of "00" or "FF" are detected. The FD179X must find an address mark within the next 16 bytes, otherwise RG is reset and search resumes. During read operations (WG = 0), the $\overline{\text{VFOE}}$ (Pin 33) is provided for phase lock loop synchronization. $\overline{\text{VFOE}}$ will go active when: - a) Both HLT and HLD are True - b) Settling Time, if programmed, has expired - c) The 179X is inspecting data off the disk If $\overline{\text{WF/VFOE}}$ is not used, leave open or tie to a 10K resistor to +5. ### **DISK WRITE OPERATION** 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 FD179X 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 FD179X 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. For write operations, the FD179X provides Write Gate (Pin 30) and Write Data (Pin 31) outputs. Write data consists of a series of 500 ns pulses in FM $(\overline{DDEN}=1)$ and 250 ns pulses in MFM $(\overline{DDEN}=0)$ . Write Data provides the unique address marks in both formats. Also during write, two additional signals are provided for write precompensation. These are EARLY (Pin 17) and LATE (Pin 18). EARLY is active true when the WD pulse appearing on (Pin 30) is to be written early. LATE is active true when the WD pulse is to be written LATE. If both EARLY and LATE are low when the WD pulse is present, the WD pulse is to be written at nominal. Since write precompensation values vary from disk manufacturer to disk manufacturer, the actual value is determined by several one shots or delay lines which are located external to the FD179X. The write precompensation signals EARLY and LATE are valid for the duration of WD in both FM and MFM formats. Whenever a Read or Write command (Type II or III) is received the FD179X samples the Ready input. If this input is logic low the command is not executed and an interrupt is generated. All Type I commands are performed regardless of the state of the Ready input. Also, whenever a Type II or III command is received, the TG43 signal output is updated. #### **COMMAND DESCRIPTION** The FD179X will accept 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. **Table 2. COMMAND SUMMARY** | | | | | | ВІ | TS | | | | |------|------------------|-----|------|----|----|----|----|------|----------------| | TYP | E COMMAND | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | 1 | Restore | . 0 | 0 | 0 | 0 | h | ٧ | 'n | f. | | 1 | Seek | -0 | 0 | 0 | 4 | h | ٧ | , Ci | ro | | 1 | Step | 0 | 0 | 1 | u | h | ٧ | r, | fo | | 1 | Step In | 0 | ្វាំ | .0 | U | h | ٧ | n | To. | | | Step Out | 0 | -1 | 1 | u | h | ٧ | T, | To | | l II | Read Sector | * 1 | 0 | 0 | m | S | E | C | o | | 11 | Write Sector | | 0 | 1 | m | S | E | Ċ | a <sub>o</sub> | | 111 | Read Address | • | 1 | 0 | 0 | O | E | 0 | 0 | | 111 | Read Track | 1 | 1 | 1 | 0 | 0 | E | 0 | 0 | | 111 | Write Track | | 1 | 1 | 1 | 0 | E | 0 | 0 | | IV | Force Interrrupt | 1 | 1 | 0 | 1 | 13 | 12 | f, | f <sub>o</sub> | Note: Bits shown in TRUE form. **Table 3. FLAG SUMMARY** | | Table 5. I EAG SOMMATT | |---|------------------------------------------------------------------| | - | TYPEICOMMANDS | | | h = Head Load Flag (Bit 3) | | | h = 1, Load head at beginning<br>h = 0, Unload head at beginning | | | V = Verify flag (Bit 2) | | | V = 1, Verify on destination track<br>V = 0, No verify | | | r <sub>1</sub> r <sub>0</sub> = Stepping motor rate (Bits 1-0) | | | Refer to Table 1 for rate summary | | | u = Update flag (Bit 4) | | 1 | u = 1, Update Track register<br>u = 0, No update | | - | | **Table 4. FLAG SUMMARY** | T | TYPE II & III COMMANDS | | | | | | | |---------|------------------------|------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------|-------------------|-------------|------| | Į | n = Multi | ple Re | cord fl | ag (Bi | 4 | 77<br>38 44 | | | | m = 0, 1<br>m = 1, 1 | | | | | | | | | <sub>k</sub> = Date | Contract of the | 100 | 271 | 0) | | | | | a <sub>0</sub> = 0, | B (Da | te Mar | k) | | | | | | a <sub>0</sub> = 1.1 | | | | ark) | g) (L | | | | | | <u>elay</u> (2)<br>me de | | | | | | Ź | | | 5 ms c | 4.4 | | | | | | S = Side | | 100 | | | | V. 1 | | | S = 0, C | | | de 0 | | | | | | S = 1, C | ompare | for Si | de 1 | | | | | | C = Side | Comp | are Fla | g | | | | | | C = 0, d | ACCUPATION AND DESCRIPTION OF THE PARTY. | STATE OF THE PARTY | 100 mg | The second second | | | | Marie C | C = 1, eq | <b>TOBLE S</b> | ide sei | ect cor | npare . | N. W. | | Table 5. FLAG SUMMARY | TYPE IV COMMAND | | |----------------------------------------------------|-------| | li = Interrupt Condition flags (Bits 3-0) | | | 10 = 1, Not-Ready to Ready Transitio | n- of | | 11 = 1, Ready to Not-Ready Transitio | n | | 12 = 1, Index Pulse<br>13 = 1, Immediate Interrupt | | | 13 -In' = 0, Terminate with no Interru | bt | | o u mari | | #### TYPE I COMMANDS The Type I Commands include the Restore, Seek, Step, Step-In, and Step-Out commands. Each of the Type I Commands contains a rate field (ror1), which determines the stepping motor rate as defined in Table 1. The Type I 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 FD179X receives a command that specifically disengages the head. If the FD179X is idle (busy =0) for 15 revolutions of the disk, the head will be automatically disengaged (HLD made inactive). The Type I 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 15 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, and 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 four revolutions of the disk, the FD179X 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 TYPE I COMMAND FLOW Register is loaded with zeroes and an interrupt is generated. If TROO is not active low, stepping pulses (pins 15 to 16) at a rate specified by the r10 field are issued until the TROO input is activated. At this time the Track Register is loaded with zeroes and an interrupt is generated. If the TROO input does not go active low after 255 stepping pulses, the FD179X terminates operation, interrupts, and sets the Seek error status bit. 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. Note that the Restore command is executed when $\overline{\text{MR}}$ goes from an active to an inactive state. ### **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 FD179X 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 **TYPE I COMMAND FLOW** 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 FD179X 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 rare field, a verification takes place if the V flag is on. If the u flag is on, the Track Register 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 FD179X 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<sub>1</sub>r<sub>10</sub> field, a TYPE I COMMAND FLOW 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 FD179X issues one stepping pulse in the direction towards track 0. If the u flag is on, the Track Register is decremented by one. After a delay determined by the rro 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. ### TYPE II COMMANDS The Type II Commands are the Read Sector and Write Sector 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 15 msec delay. If the E flag is 0, the head is loaded and HLT sampled with no 15 msec delay. The ID field and Data Field format are shown on page 12. When an ID field is located on the disk, the FD179X compares the Track Number on 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 FD179X must find an ID field with a Track number, Sector number, side number, and CRC within four revolutions of the disk; otherwise, the Record not found status bit is set (Status bit 3) and the command is terminated with an interrupt. Each of the Type II Commands contains an (m) flag which determines if multiple records (sectors) are to be read or written, depending upon the command. If m=0, 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 FD179X will continue to read or write multiple records and update the sector register until the sector regis- ter exceeds the number of sectors on the track or until the Force Interrupt command is loaded into the Command Register, which terminates the command and generates an interrupt. If the Sector Register exceeds the number of sectors on the track, the Record-Not-Found status bit will be set. The Type II commands also contain side select compare flags. When C=0, no side comparison is made. When C=1, the LSB of the side number is read off the ID Field of the disk and compared with the contents of the (S) flag. If the S flag compares with the side number recorded in the ID field, the 179X continues with the ID search. If a comparison is not made within 5 index pulses, the interrupt line is made active and the Record-Not-Found status bit is set. #### **READ SECTOR** Upon receipt of the Read Sector 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, correct side number, and correct CRC, the data field is presented to the computer. The Data Address Mark of the data field must be found within 30 bytes in single density and 43 bytes in double density of the last ID field CRC byte; 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 **TYPE II COMMAND** **TYPE II COMMAND** | GAP | ID | TRACK<br>NUMBER | SIDE | SECTOR | SECTOR | CRC | CRC | GAP | DATA | DATA | FIELŐ | CRC<br>1 | CRC<br>2 | |-----|------|-----------------|------|--------|----------|-----|-----|-----|------|------|--------|----------|----------| | 111 | MIVI | | | FIELD | <u> </u> | | | | | DA | TA FIE | .D | | In MFM only, IDAM and DATA AM are preceded by three bytes of A1 with clock transition between bits 4 and 5 missing. TYPE II COMMAND 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 (Bit 5) as shown below: TYPE II COMMAND ### WRITE SECTOR Upon receipt of the Write Sector 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, correct side number, and correct CRC, a DRQ is generated. The FD179X counts off 11 bytes in single density and 22 bytes in double density 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 in single density and 12 bytes in double density are then written on the disk. At this time the Data Address Mark is then written on the disk as determined by the $a_0$ field of the command as shown below: ### TYPE III COMMAND WRITE TRACK The FD179X 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 of logic ones in FM or in MFM. 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 TYPE III COMMAND WRITE TRACK 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 | | SECTOR SECTOR CRC CRC<br>ADDRESS LENGTH 1 2 | |---------------|---|---------------------------------------------| | 1 | 2 | 3 4 5 6 | Although the CRC characters are transferred to the computer, the FD179X checks for validity and the CRC error status bit is set if there is a CRC error. The Track 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 pulse 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. The accumulation of bytes is synchronized to each Address Mark encountered. Upon completion of the command, the interrupt is activated. RG is not activated during the Read Track command. ### 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 receiving 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 in FM or by receipt of F5 in MFM. ### CONTROL BYTES FOR INITIALIZATION | DATA PATTERN<br>IN DR (HEX) | FD179X INTERPRETATION IN FM (DDEN = 1) | FD1791/3 INTERPRETATION<br>IN MFM (DDEN = 0) | |--------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 00 thru F4 F5 F6 F7 F8 thru FB FC FD FE FF | Write 00 thru F4 with CLK = FF Not Allowed Not Allowed Generate 2 CRC bytes Write F8 thru FB, Clk = C7, Preset CRC Write FC with Clk = D7 Write FD with Clk = FF Write FE, Clk = C7, Preset CRC Write FF with Clk = FF | Write 00 thru F4, in MFM Write A1* in MFM, Preset CRC Write C2** in MFM Generate 2 CRC bytes Write F8 thru FB, in MFM Write FC in MFM Write FD in MFM Write FE in MFM Write FF in MFM | <sup>\*</sup>Missing clock transition between bits 4 and 5 ### 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 lo through lo field is detected. The interrupt conditions are shown below: I<sub>0</sub> = Not-Ready-To-Ready Transition I<sub>1</sub> = Ready-To-Not-Ready Transition $I_2$ = Every Index Pulse I<sub>3</sub> = Immediate Interrupt (requires reset, see Note) **NOTE:** If $I_0 - I_3 = 0$ , there is no interrupt generated but the current command is terminated and busy is reset. This is the only command that will enable the immediate interrupt to clear on a subsequent Load Command Register or Read Status Register. ### 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) | |-------------------|-------------------| | 7 6 5 4 | 3 2 1 0 | | S7 S6 S5 S4 | S3 S2 S1 S0 | Status varies according to the type of command executed as shown in Table 6. <sup>\*\*</sup>Missing clock transition between bits 3 & 4 Table 6. STATUS REGISTER SUMMARY | ВІТ | ALL TYPE I<br>COMMANDS | READ<br>ADDRESS | READ<br>SECTOR | READ<br>TRACK | WRITE<br>SECTOR | WRITE | |----------|---------------------------|------------------------|------------------------|------------------------|-------------------------------|-----------------------------| | S7<br>S6 | NOT READY WRITE PROTECT | NOT READY<br>0 | NOT READY<br>0 | NOT READY | NOT READY<br>WRITE | TRACK<br>NOT READY<br>WRITE | | S5<br>S4 | HEAD LOADED<br>SEEK ERROR | O<br>RNE | RECORD TYPE<br>FINE | 0<br>0 | PROTECT<br>WRITE FAULT<br>RNF | PROTECT WRITE FAULT 0 | | S3<br>S2 | TRACK 0 | GRC ERROR<br>LOST DATA | CRC ERROR<br>LOST DATA | 0<br>L <b>OST</b> DATA | CRC ERROR | 0<br>LOST DATA | | S1<br>S0 | INDEX<br>BUSY | DRQ<br>BUSY | DRO<br>BUSY | DRQ<br>BUSY | DRO<br>BUSY | DRQ<br>BUSY | ### 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 fored with MR. | | S6 PROTECTED | When set, indicates Write Protect is activated. This bit is an inverted copy of 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 ORC ERROR | CRC encountered in ID field. | | S2 TRACK 00 | When set, indicates Read/Write head is positioned to Track 0. This bit is an inverted copy of the TROO input. | | S1 INDEX | When set, indicates index mark detected from drive. This bit is an inverted copy of the IP input. | | SO 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 it and III Commands will not execute unless the drive is ready. | | S6 WRITE PROTECT | On Read Record: Not Used, On Read Track: Not Used. On any Write: It indicates a Write Protect. This bit is reset when updated. | | S5 RECORD TYPE/<br>WRITE FAULT | On Read Record: It indicates the record-type code from data field address mark. 1 = Deleted Data Mark. 0 = Data Mark. On any Write: It indicates a Write Fault. This bit is reset when updated. | | S4 RECORD NOT<br>FOUND (RNF) | When set, it indicates that the desired track, sector, or side 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 DRO 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 up- | | | When set, command is under execution. When reset, no command is under execution. | #### 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/O 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 FD179X 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 normal clock pattern. However, if the FD179X detects a data pattern of F5 thru FE in the data register, this is interpreted as data address marks with missing clocks or CRC generation. For instance, in FM 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 in FM or MFM. As a consequence, the patterns F5 thru FE must not appear in the gaps, data fields, or ID fields. Also, CRC's must be generated by an F7 pattern. Disks may be formatted in IBM 3740 or System 34 formats with sector lengths of 128, 256, 512, or 1024 bytes. ### IBM 3740 FORMAT—128 BYTES/SECTOR Shown below is the IBM single-density format with 128 bytes/sector. In order to format a diskette, 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. - \*Write bracketed field 26 times - \*\*Continue writing until FD1791 interrupts out. Approx. 247 bytes. **IBM TRACK FORMAT** ### **IBM SYSTEM 34 FORMAT-**256 BYTES/SECTOR Shown below is the IBM dual-density format with 256 bytes/sector. In order to format a diskette 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. | 4.5 | | rigation are not | THE SALE LANGE TO | 1. 46 DEC 1900 PM | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------|-----------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | NUMBER | 1.2 | | | | | | 14 37 37 | · HEX \ | /ALUE O | F | | OF BYTES | | DVTE | MOUTE | S. E. | | | 100 | OT IE. | WRITTE | N . | | .80 | 4E | | | | | | 95 | Section 198 | | | | 12 | 00 | | | | | 그는 그는 전화를 하면 시장하는 그는 회사는 그리고 회원 살이 그리고 | TO THE REAL PROPERTY. | 30.00 | | | | . 3 | F6 | | | | | | Value of the Control | | | | | | - FC III | ndex Mar | k) | | | 50* × | | | | | | | 46 | X20 | | | | | 00 | | | | | | | | | e transcension | | <b>3</b> | FS. | | 86. | | | - 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | | | | | | | | ) Addres | Mark | | | 1 1 | | 41.44 | | | | The state of s | 11000 | Number | | | | 1 1° | 9112.1 | ilumber (i | 7 mg 44 | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | | | | | 4 CH 17 | | | | Serie | Number | 11 three | AX | | | | | | | | | 01 | er e | | | | | G7 10 | <b>CRCs</b> wr | Maria V | AAR AA | | Maria de la Companya | | mindo Mi | uvery | 44 C. 44 . 14 | | 22 | 4E : | Name of the second | | 200 | | 12 | 2 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | <b>14.</b> | (3.6) | California ( | | | 00 | | | No. | | | F5 | | | | | | | | | | | The second section | FR (D | ata Addre | es Mada | 31.30 | | OE0 | | ara como | os Mark | Transfer Court | | 256 | DATA | | | | | 1. Sec. 11. 11. 11. 11. 11. 11. 11. 11. 11. 1 | . F-7 /A | | | | | | 17/12/ | <b>CRCs wri</b> | tten) | | | 1 54 | 4E | | | (4) (4) | | | Maria Section 400 | THE STATE | | | | 598** | AF | 1985 E. S. | | Mary Strain | | PROBLEM STATE OF THE T | 2.5 | | | | | | alone or with a strangerships. | more and the second of the | · * / * * * * * * * * * * * * * * * * * | March Company of the | <sup>\*</sup> Write bracketed field 26 times ### **NON-IBM FORMATS** Variations in the IBM format are possible to a limited extent if the following requirements are met: sector size must be a choice of 128, 512 or 1024 bytes; gap size must be according to the following table. Note that the Index Mark is not required by the FD179X. All gap sizes shown are the minimum values required by the 179X. | | FM | MFM | |---------|-------------|-------------| | Gap I | 16 bytes FF | 16 bytes 4E | | Gap II | 11 bytes FF | 22 bytes 4E | | • | 6 bytes 00 | | | | | 12 bytes 00 | | Gap III | 10 bytes FF | 3 bytes A1 | | | TO DYNUS FF | 16 bytes 4E | | | 4 bytes 00 | 8 bytes 00 | | | | 3 bytes A1 | | Gap IV | 16 bytes FF | 16 bytes 4E | <sup>\*</sup>Byte counts must be exact. ### **ELECTRICAL CHARACTERISTICS** ### **MAXIMUM RATINGS** $V_{\text{DD}}$ With Respect to Vss (Ground) =15 to -0.3VMax. Voltage to Any Input With =15 to -0.3V Respect to Vss Operating Temperature 0°C to 70°C Storage Temperature -55°C to +125°C ### **OPERATING CHARACTERISTICS (DC)** $T_A = 0^{\circ}C$ to 70°C, $V_{DD} = +12.0V \pm .6V$ , $V_{SS} = OV, V_{CC} = +5V \pm .25V$ $V_{\text{DD}} = 10$ ma Nominal, $V_{\text{CC}} = 35$ ma Nominal | SYMBOL | CHARACTERISTIC | MIN. | TYPE. | MAX. | UNITS | CONDITIONS | |----------------------------------------------|----------------------------------------------------------------------------------------------------------------------------|------------|-------|--------------------------------|------------------------------|--------------------------------------------------------------| | lil<br>lot<br>VIH<br>VIL<br>Voh<br>Vol<br>Po | Input Leakage Output Leakage Input High Voltage Input Low Voltage Output High Voltage Output Low Voltage Power Dissipation | 2.6<br>2.8 | | 10<br>10<br>0.8<br>0.45<br>0.5 | μA<br>μA<br>V<br>V<br>V<br>V | CONDITIONS Vin = Vod Vout = Vod i lo = 100 µA lo = 1.6 mA | ### TIMING CHARACTERISTICS $T_A = 0^{0}C$ to $70^{0}C$ , $V_{DD} = + 12V \pm .6V$ , $V_{SS} = 0V$ , $V_{CC} = +5V \pm .25V$ ### **READ ENABLE TIMING** | SYMBOL | CHARACTERISTIC | MIN. | TYP. | MAX. | UNITS | CONDITIONS | |------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------|----------------|------------|---------------------------|------------------------------------------------------|------------------------------------------------------------------------------------------------| | TSET THLD TRE TDRR TIRR TDACC TDOH | Setup ADDR & CS to RE Hold ADDR & CS from RE RE Pulse Width DRQ Reset from RE INTRQ Reset from RE Data Access from RE Data Hold From RE | 0<br>10<br>400 | 400<br>500 | 500<br>3000<br>300<br>150 | nsec<br>nsec<br>nsec<br>nsec<br>nsec<br>nsec<br>nsec | CONDITIONS C <sub>L</sub> = 50 pf See Note 6 C <sub>L</sub> = 50 pf C <sub>L</sub> = 50 pf | <sup>\*\*</sup>Continue writing until FD179X interrupts out. Approx. 598 bytes. <sup>\*\*</sup>Byte counts are minimum, except exactly 3 bytes of A1 must be written. ### **READ ENABLE TIMING** ### WRITE ENABLE TIMING ### WRITE ENABLE TIMING | SYMBOL | CHARACTERISTIC | MIN. | TYP. | MAX. | UNITS | CONDITIONS | |--------------|---------------------------------------|-------------|------|------|--------------|-------------| | TSET<br>THLD | Setup ADDR & CS to WE | 50<br>10 | | | nsec<br>hsec | | | TWE | WE Pulse Width<br>DRQ Reset from WE | 350 | 400 | 500 | nsec<br>nsec | and service | | TIRR | INTRO Beset from WE | | 500 | 3000 | nsec | See Note 6 | | TDS<br>TDH | Data Setup to WE<br>Data Hold from WE | - 250<br>20 | | | nsec<br>nsec | | #### INPUT DATA TIMING: | SYMBOL | CHARACTERISTIC | MIN. | TYP. | MAX. | UNITS | CONDITIONS | |------------------------|-----------------------------------------------------------------------------|-------------------------|------|------|-------------------------------|---------------------------------------------| | Tew<br>the<br>Ta | Place Read Pulse Width<br>Rave Read Cycle Time<br>RCLK Duty (High) | 1800<br>1800<br>860 | 88 S | | ASSIC<br>TASSIC<br>TASSIC | See Note 1,2<br>See Note 3<br>See Note 4, 5 | | Tb<br>Tc<br>Tx:<br>Tx: | RCLK Duty (Low) RCLK Cycle Time RCLK hold to Raw Read Raw Read hold to RCLK | 800<br>1600<br>40<br>40 | | | neec<br>11980<br>ASAG<br>ASAG | See Note 1 | WRITE DATA TIMING ### WRITE DATA TIMING: (ALL TIMES DOUBLE WHEN CLK = 1 MHz) | SYMBOL | CHARACTERISTICS | MIN. | TYP. | MAX. | LINITO | CONDITIONS | |------------|----------------------------|-------|-------------|--------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | | 1411 | 111. | IVIAA. | UNITS | CONDITIONS | | 7340 | Wille Cate Pelse Width | Area. | enn. | | | A STATE OF THE STA | | | | | /500<br>200 | 550 | nsec | FW | | Twg | White Streets Write Date | | - | 250 | JABBC | - FORM | | | | | | | μSΘC<br>μSΘC | MEM | | . The | Miste data cycle Time: | 7 | 23,or4 | | usec | MENT<br>±CLK Error | | - <b>b</b> | Early (Late) to Write Date | 425 | | | nsec | MFM | | 4 | Barty (Late) From | 125 | | | nsec | MFM | | | Wife Data | | | | | | | | Write Gate off from WO | | 2 | | μsec 🖠 | FM: | | | Arrivation (1) | | | | wsec. | MFM | | | | | | | | Age Sales and | ### **MISCELLANEOUS TIMING:** | SYMBOL | CHARACTERISTIC | MIN. | TYP. | MAX. | UNITS | CONDITIONS | |--------------|---------------------------|------------|------------|-------|---------------|-------------| | TOD. | Clock Dury flow | | | | | | | TCD2 | Clock Dune (high) | 280<br>200 | 250<br>250 | 20000 | Dsec | | | TSTP | Step Pulse Outpet | 2014 | 230 | ZUUUU | nsec<br>Asec | | | TOIR | Dir Setup to Step | Ja 12 | | | µsec<br>µsec | See Note 6 | | TMA | Master Fleset Pulse Width | a 50 | | | μ <b>se</b> c | | | 7 <b>718</b> | Index Ruise Width | 10. | | | MSEC | | | TWF | Write Paul Puise Width | 30 | A | | μsec. | Site Note 6 | | | | | | | | | ### INPUT DATA TIMING ### NOTES: - 1. Pulse width on RAW READ (Pin 27) is normally 100-300 ns. However, pulse may be any width if pulse is entirely within window. If pulse occurs in both windows, then pulse width must be less than 300 ns for MFM at CLK = 2 MHz and 600 ns for FM at 2 MHz. Times double for 1 MHz. - 2. 100 ns. pulses are recommended for 8" MFM. ### MISCELLANEOUS TIMING - 3. tbc should be 2 $\mu$ s, nominal in MFM and 4 $\mu$ s nominal in FM. Times double when CLK = 1 MHz. - 4. RCLK may be high or low during RAW READ (Polarity is unimportant). - 5. RCLK should be forced low when VFOE = 1 and free-running when VFOE = 0. - 6. Times double when clock = 1 MHz. ## 179X-01 Application Notes ### INTRODUCTION The FD179X Floppy Disk Formatter/Controller performs all the functions necessary to read or write data to any type of floppy disk drive. Both 8" and 5" (mini-floppy) drives with single or double density storage capabilities are supported. These MOS/LSI devices will replace a large amount of discrete logic required for interfacing a host processor to a floppy disk. The FD179X is ideally suited for microprocessor interfacing, either in a stand-alone computer system, or as a slave processor for mini-computer applications. The chip has been designed to be compatible with the IBM 3740 (FM) data format, or IBM System 34 (MFM). Provisions for non-standard variable length sectors have been included to provide more data storage capability per track. Programmable stepping rates via a 2-bit setting in the Command Register allows for interfacing to disk drives with different track-to-track access times. Requiring standard +5V, +12V power supplies, the FD179X is available in a standard 40-pin dual-in-line package. When DDEN=1, the FD1791/3 reads and writes data in a frequency-modulated format. Both clock and data are recorded serially on each track of the disk. A data pulse or flux transition recorded between two clock pulses indicates a Logic "1"; the absence of a pulse between clocks indicates a Logic "0". Recorded on each track are unique combinations of data and clock bits called Address Marks. These address marks do not appear elsewhere on the disk and are used for synchronization. Four distinct address marks used are: | Description | Data | Clock | |------------------------------------------------------------------------------------|------------------------------------------------------------------|-------| | Index Address Mark<br>ID Address Mark<br>Data Address Mark<br>Deleted Address Mark | <b>€</b> C<br>( <b>F.D</b> )<br>( <b>F.D</b> )<br>( <b>F.D</b> ) | g yab | Figure 1A illustrates a typical recording in FM format. Note that a clock bit is always written before the data bit, regardless if the data written is a 1 or 0. The 1792 and 1794 have been designed for single density applications. Pin 37 must be left open by the user for proper operation. When the Double Density Enable (DDEN) pin of the 1791/3 is brought low, MFM recording is enabled. This modified-frequency-modulated technique uses a self-clocking feature to allow for recording at higher densities. Figure 1B illustrates this format. A clock pulse is written to the disk only if the preceding and present data bit written is zero. Without the use of this encoding scheme, recording densities at this higher speed would not be possible. ### PROCESSOR INTERFACE The FD179X contains five internal registers that can read or be written to. These registers are used to write commands, read status, and read and write data to and from the floppy disk. They are selected by a proper binary code on the A0, A1 lines in conjunction with the RE and WE lines when the device is selected. The registers and their addresses are: | CS | Αı | Ao | RE = 0 | WE = 0 | |----|----|----|------------------------------------|-------------| | Ö | 0 | 0 | are treasured to the second second | COMMAND REG | | 0 | 0 | | TOKOK SEG | THA SKIRES | | Ö | | | CATALOG . | DATA REG | | 1 | X | X | Desertation | Despected | X = don't care ### REGISTER ACCESS Because of internal clock synchronization, certain delays are required when accessing registers in read and write conditions. These time delays are: | OPERATION | NEXT OPERATION | TIME DELAY REQ'D | |---------------------------------------------------------------------------------------------------------------|-----------------------|------------------------| | Write to Commend | Floori.Train Stiffus | MFM = 4 us FM = 8 us | | Silver of | Mediate) | Getore Status is Valid | | e de la composition de la composition de la composition de la composition de la composition de la composition | States Register | #0 = 2 us | | Write to any | Read from a Cifferent | No Celay Rep d. | | Megister | reporter. | | Note: All time delays double for mini-floppy (CLK = 1MHz) operation. ### **MASTER RESET** The $\overline{MR}$ line of the FD179X is used during a power-up condition when processor initialization is to take place. During the trailing edge of $\overline{MR}$ , a RESTORE command (HEX 03) is jammed into the command register and executed at the slowest stepping rate. If a faster stepping rate is desired, this can be loaded into the command register during the RESTORE, in which case the remainder of the steps will occur at the new selected rate until Track 00 is sensed. The minimum pulse width of $\overline{\text{MR}}$ is 50 $\mu\text{s}$ . ### **DATA REQUEST** The Data Request line (pin 38) and the Data Request bit of the status register indicate valid data transfers. When performing any read command, it indicates that valid data is contained in the data register and the host processor may read this byte. In any write command, it indicates that the data register is empty and may be loaded by the host processor with a new data byte. If it is desired to have separate DRQ's to indicate "read" and "write" mode, the circuit of figure 2 may be used. Whenever RG is true, DRQ will be caused by a read operation. When false, DRQ must have been caused by a write operation. DRQ is always reset when the Data Register is read or written to. DRQ is also reset when the Command Register is loaded with a new command, providing the FD179X is IDLE (Busy = 0). ### **HEAD LOAD TIMING** The Head Load Output (HLD) controls the movement of the R/W head against the media. When HLD = 1, the head is to be loaded against the disk. An internal 15 ms. delay allows for the head to fully engage. If the drive used requires more head load time, an external circuit must be used to increase this time delay. Figure 3 illustrates the use of a oneshot to perform this function. When the E flag of any Type II or III command is reset (E = 0), the internal 15 ms. delay is disabled and the HLT line is sampled immediately. The duration of the one-shot pulse width set by the Resistor/Capacitor combination selected will prevent a Logic "1" from appearing on HLT until the preset time has expired. The "AND" function of HLT and HLD appears in the status register as BIT 5 and may be used to avoid another time delay by informing the host processor that the R/W head is already engaged. This will speed up access when doing 2 consecutive READ SECTOR commands, for example. Regardless of the head load configuration used, HLT is always sampled for a Logic "1" before the current command is continued. ### **TEST INPUT** The TEST input of the FD179X is used when interfacing to voice-coil activated motors. In most applications, it may be tied high or simply left open by the user. When TEST = 0, the internal stepping rates are decreased to about 400 microseconds, the HLT internal 15 ms. delay is disabled, and acts as if the E flag was reset. Figure 4 shows a typical implementation of TEST when used with a voice-coil activated drive. ### **DDEN INPUT (1791 and 1793 only)** The Double Density Enable ( $\overline{DDEN}$ ) pin is used to select single and double density operation. When $\overline{DDEN}$ = 1, single density is selected; when $\overline{DDEN}$ = 0, double density is selected. This line can be switched from 0 to 1 or from 1 to 0 at any time except when WRITE GATE (WG) is activated. IBM double density diskettes have TRACK 00 side 0 recorded in single density instead of double density. The "AND-ING" of the $\overline{TR00}$ and a side 0 signal can be used to force $\overline{DDEN}$ to a Logic "1" when on TRACK 00. The $\overline{DDEN}$ (pin 37) of the 1792 and 1794 must be left open for proper operation. ### **COMMAND USAGE** Whenever a command is successfully or unsuccessfully completed, the busy bit of the status register is reset and the INTRQ line is forced high. Command termination may be detected either way. The INTRQ can be tied to the host processor's interrupt line, causing a system interrupt with an appropriate service routine to terminate commands. The busy bit may be monitored with a user program and will achieve the same results through software. Performing both an INTRQ and a busy bit check is not recommended because a read of the status register to determine the condition of the busy bit will reset the INTRQ line. This can cause an INTRQ from not occurring. ### **RESTORE COMMAND** On some disk drives, it is possible to position the R/W head outward past Track 00 and prevent the TR00 line from going low unless a STEP IN is first performed. If this condition exists in the drive used, the RESTORE command will never detect a TR00. Issuing several STEP IN pulses before a RESTORE command will remedy this situation. The RESTORE and all other Type 1 commands will execute even though the READY bit indicates the drive in not ready (NOT READY = 1). ### READ TRACK COMMAND The READ TRACK command can be used to manually inspect data on a hard copy printout. Gaps, address marks, and all data are brought in to the data register during this command. The READ TRACK command may be used to inspect diskettes for valid formatting and data fields as well as address marks. Since the 179X does not synchronize clock and data until the Index Address Mark is detected, data previous to this ID mark will not be valid. READ GATE (RG) is not actuated during this command. ### **READ ADDRESS COMMAND** In systems that use either multiple drives or sides, the read address command can be used to tell the host processor which drive or side is selected. The current position of the R/W head is also denoted in the six bytes of data that are sent to the computer. The READ ADDRESS command as well as all other Type II and Type III commands will not execute if the READY line is inactive (READY = 0). Instead, an interrupt will be generated and the NOT READY status bit will be set to a 1. ### FORCED INTERRUPT COMMAND The Forced Interrupt command is generally used to terminate a multiple sector command or to insure Type I status in the status register. The lower four bits of the command determine the conditional interrupt as follows: - I = NOT-READY TO READY TRANSITION - 1, = READY TO NOT-READY TRANSITION - I<sub>2</sub> = EVERY INDEX PULSE - I<sub>3</sub> = IMMEDIATE INTERRUPT Regardless of the conditional interrupt set, any command that is currently being executed when the Forced Interrupt command is loaded will immediately be terminated and the busy bit will be reset indicating an idle condition. Then, when the condition for interrupt is met, the INTRQ line will go high signifying that the condition specified has occurred. The conditional interrupt is enabled when the corresponding bit positions of the command ( $I_3 - I_0$ ) are set to a 1. If $I_3 - I_0$ are all set to zero, no interrupt will occur, but any command presently under execution will be immediately terminated upon receipt of the Force Interrupt command (HEX D0). As usual, to clear the interrupt a read of the status register or a write to the command register is required. The exception is when using the immediate interrupt condition ( $I_3$ = 1). If this command is loaded into the command register, an interrupt will be immediately generated and the current command terminated. Reading the status or writing to the command register will not automatically clear the interrupt; another forced interrupt command with $I_3$ - $I_0$ = 0 must be loaded into the command register in order to reset the INTRQ from this condition. More than one condition may be set at a time. If for example, the READY TO NOT-READY condition ( $I_1$ = 1) and the Every Index Pulse ( $I_2$ = 1) are both set, the resultant command would be HEX "DA". The "OR" function is performed so that either a READY TO NOT-READY or the next Index Pulse will cause an interrupt condition. # FLOPPY DISK INTERFACE READ GATE The Read Gate output from the FD179X is used to inform the external data separator circuitry that a field of ones or zeros has been read off the disk. In FM mode, the RG signal will go high only after the following conditions are met: - 1. The Head is loaded - 2. HLT is at a Logic "1" - 3. Settling time, if programmed, has elapsed - 4. A field of zeros has been read off the disk RG will be reset back to a zero upon a Master Reset (MR) or upon receipt of any command including the Force Interrupt command when BUSY = 0, or upon a Force Interrupt command when terminating a multiple sector Read/Write command. For double density operation (MFM), the RG characteristics are as follows: Assume the FD1791/3 is searching for an ID field. When 4 consecutive bytes of zeros are detected, RG will be made active. RG will be reset upon any one of the following conditions: - 1. 3 A1's with missing clocks not found within 16 bytes - 2. HEX "FE" not found within the next byte - 3. One byte after CRC - 4. Invalid TRACK/SECTOR Address (only during a READ/WRITE sector command) If the ID search was unsuccessful, the FD1791/3 will then continue the search for the specified ID field. When the correct ID field is encountered and if the current command was a WRITE SECTOR, RG will remain at a Logic "0". If the current command was a READ SECTOR, the FD1791/3 will then look for 4 consecutive bytes of zeros. If 4 bytes of zeros were not found, the FD1791/3 will do an internal retry. If 4 bytes are found within the next 33 bytes, RG will then be set to a Logic "1". RG is now deactivated (RG = 0) upon one of the following conditions: - 3 A1's with missing clocks found within 16 bytes - 2. HEX "FB" or "F8" not found within the next byte - 3. After the CRC is read (successful completion) Items 1 and 2 will result in an internal retry. RG is not activated during the Read Track command. ### VFOE/WF The 179X provides an additional signal that can be used to control the external data separator, VFOE/WF (pin 33) is an input/output pin that functions as a VFO enable and a write fault signal. When Write Gate (WG) = 1, pin 33 functions as an input to detect write fault conditions at the drive. If pin 33 is brought low when WG = 1, the current Write command is terminated and the INTRQ is activated. The write fault status bit is then set indicating a failure in drive electronics. When WG = 0, pin 33 functions as an output, pin 33 will go active (Logic "0") when the following conditions are met: - 1. Head is loaded - 2. Settling time, if programmed, has elapsed - 3. Data is being inspected off the disk The VFOE signal can be used to control RCLK. When VFOE = 0, RCLK should be allowed to free run; when VFOE = 1, RCLK should be forced low. The following circuits can be used to separate VFOE/WF signals. ### **RAW READ** The RAW READ input should be supplied a negative going pulse for every clock or data bit recorded on the media. The normal pulse width is 100 to 200 ns. but may be any pulse width providing the pulse occurs entirely in the read clock window. When flux reversals are totally non-existant (i.e., head is disengaged), the external separator should ensure that the RAW READ is held at a Logic "1". ### RCLK The READ CLOCK signal must be supplied from an external data separator and is used to "frame" each RAW READ transition. The FD179X will determine whether the RAW READ pulse is clock or data, so the active state of RCLK is unimportant (i.e., high or low during RAW READ). RCLK transitions must be phased with RAW READ either by a counter/separator, or phase lock loop configuration. For proper operation, RCLK must be a minimum of 800 ns. high and 800 ns. low. For 8" MFM, this requires a 50-50 RCLK window. VFO's that operate in the 8-16 MHz range are recommended. When switching RCLK from one source to another, great care must be exercised to ensure this 800 ns. margin. Figure 5 shows the $\overline{RAW}$ READ and RCLK timing relationships. When $\overline{VFOE}$ = 1 RCLK should be forced low, and free-running when $\overline{VFOE}$ = 0. ### WRITE PRECOMPENSATION Write precompensation is a technique where the WRITE DATA (both clock and data) is written in a direction opposite of the anticipated bit shift. It is generally required for 8" MFM recording and is usually not used for FM single density. Write precompensation may be obtained by the use of external circuitry in conjunction with WD, EARLY and LATE. The algorithm for write precompensation is shown in figure 6. The external logic required is in the form of delay circuits or one shots. As a general rule, write precompensation is done only on Tracks 44-77, but may be required on all tracks if specified by the drive manufacturer. Figure 8 illustrates a precomp circuit using the Western Digital 2143 4-phase clock generator. The timing relationships are shown in figure 9. The early, late or nominal condition is latched into the 74LS175 on the rising edge of WD. This fires the 2143 via its OSC in (pin 11) line and starts the 4-phase generation. Depending upon the condition, the resultant WD is generated by Ø2 on nominal, Ø1 on early, or Ø3 on late. The Ø4 output resets the latch in anticipation of the next WD pulse. The 7438 is an open collector device and requires a pull-up resistor if not supplied at the drive. A 5K potentiometer is used to adjust the desired pulse width. ### DATA SEPARATION The FD179X requires an external data separator. Data separators range from the counter/one-shot technique to phase lock loops. The choice of separator design is dependent upon data reliability and system cost. The FD179X requires a RAW READ signal which is a negative going pulse for every flux reversal, and a Read Clock (RCLK) signal to indicate flux reversal spacing. RAW READ must be a minimum of 100 ns. and RCLK (high or low) at 800 ns. Because of high flux reversal rates, Write Precompensation with a Phase Lock Loop separator is recommended for 8" MFM applications. Figure 10 illustrates a counter separator. This circuit uses a crystal clock and Read Gate (RG) is not used. Figure 11 shows the timing of the circuit. Any negative RAW READ transition loads the counter with a "5". When the counter counts down to zero, the RCLK flip-flop (74LS74) toggles, producing a RCLK. If the next data bit is zero (no RAW READ pulse), the counter continually counts down until another RAW READ pulse occurs. Then it is loaded again and the process repeats. Many users are using this circuit and are achieving error rates better than 10-8, even for 8" MFM with write precompensation. This circuit may also be used for the 5" mini-floppy. Figure 12 illustrates a phase lock loop method of data separation. The advantage of this scheme over counter/separators is its excellent data recovery and high reliability. The RCLK "tracks" the RAW READ transitions, allowing for greater flexibility in bit shifts and overall system margins. Although the PPL arrangement is preferred, its added component count generally limits its use to 8" MFM and FM applications. ### **DATA RECOVERY** Occasionally, the R/W head of the disk drive may get "off track", and dust or dirt may get trapped on the media. Both of these conditions will cause a RECORD NOT FOUND and/or a CRC error to occur. This "soft error" can usually be recovered by the following procedure: - 1. Issue the command again - 2. Unload and load the head and repeat step - 3. Issue a restore, seek the track, and repeat step 1 If RNF or CRC errors are still occurring after trying these methods, a "hard error" may exist. This is usually caused by improper disk handling, exposure to high magnetic fields, etc. and generally results in destroying portions or tracks of the diskette. FIGURE 1A. FM RECORDING FIGURE 1B. MFM RECORDING FIGURE 2. FORMING SEPARATE READ AND WRITE MODE SIGNALS FROM DRQ FIGURE 3. CONTROLLING HEAD LOAD TIMING FIGURE 4. INTERFACING TO VOICE-COIL ACTIVATED DRIVES FIGURE 5. READ DATA TIMING | | eady<br>ent | Sending | To Be<br>Sent | MFM | FM | |---|-------------|---------|---------------|--------------------------------------------------------|----------------------------| | X | 1 . | 1 | 0 | Precomp Early | Precomp Early <sup>1</sup> | | X | 0 | 1 | 1 | Precomp Late | Precomp Late <sup>1</sup> | | 0 | 0 | 0 | 1 | Precomp Early<br>(Inhibit During A1 & C2) <sup>2</sup> | N/A | | 1 | 0 | 0 | 0 | Precomp Late (Inhibit During A1 & C2) 2 | N/A | X = Don't Care N/A = Not Applicable 1 = Inhibited during missing clocks 2 = With missing clock transitions (Address marks) ## FIGURE 6A. INTERNAL WRITE PRE-COMP ALGORITHM | Early | Late | Precomp Required | |-------|------|------------------| | 1 | 0 | Do not Delay WD | | 0 | 0 | Delay WD By ∆ | | 0 | 1 | Delay WD by 2 △ | Notes All other Early/Late conditions are illegal. $\Delta$ = 100 — 150 ns. depending upon drive manufacturer. See figure 7 for timing with Early/Late. FIGURE 7. WRITE PRE-COMP TIMING FIGURE 8. 179X WRITE PRE-COMP A-66 FIGURE 9. WRITE PRE-COMP TIMING FIGURE 10. COUNTER/SEPARATOR FIGURE 11. COUNTER/SEPARATOR TIMING (8" FM SHOWN)