#### CROMEMCO 4FDC DISK CONTROLLER CROMEMCO INCORPORATED 2400 Charleston Road, Mountain View, California #### TABLE OF CONTENTS | | | Page | |------------|---------------------------|------| | 1. | INTRODUCTION | 1 | | 2. | RDOS | 2 | | <b>3</b> . | REGISTER DESCRIPTION | 1,1 | | 4. | INTERFACE CHARACTERISTICS | 31 | | 5. | PARTS PLACEMENT DIAGRAM | 35 | | 6. | INITIAL SETUP PROCEDURE | 36 | | 7. | THEORY OF OPERATION | 40 | | 8. | PARTS LIST | 44 | | 9. | WARRANTY | 46 | Cromemco 4FDC MANUAL copyright 1977 by Cromemco, Inc. #### CHAPTER 1: INTRODUCTION The Cromemco Disk Controller (model 4FDC) is designed to interface both 5-inch ("mini") and 8-inch floppy disk drives to the S-100 computer bus used in Cromemco computers. In addition the 4FDC contains a serial I/O channel with software-selectable baud rates from 110 baud to 76,800 baud. The 4FDC controller also has a 1K resident 2708 ROM pre-programmed with Cromemco's RDOS ROM-resident Disk Operating System. RDOS is designed to allow a operator to perform all essential disk operations from the console keyboard. RDOS also contains a bootstrap program that can be used to load the powerful Cromemco CDOS disk operating system into RAM memory from a diskette. Four switches on the 4FDC interface card are used to set the operation of the card. Switch 1 is the RDOS DISABLE switch. When this switch is ON the 1K ROM containing RDOS cannot be accessed by the computer. When this switch is OFF the RDOS program resides in the computer memory space from address COOO to C3FF. Switch 2 is the RDOS DISABLE AFTER BOOT switch. If this switch is ON the 1K ROM containing RDOS will automatically be disabled after CDOS is bootstrapped in from a disk thus clearing memory space from COOO to C3FF for system use. (In this mode the ROM is actually disabled by an output to port 40H which is done automatically by CDOS). If switch 2 is OFF, RDOS remains in memory space even after CDOS is loaded. RDOS contains two programs; 1) the CDOS bootstrap program and 2) the console monitor program. Switch 3 is the BOOT ENABLE switch. When this switch is ON the bootstrap program will execute (thus loading CDOS) without first entering the monitor program. If this switch is off, RDOS begins in the console monitor mode permitting the bootstrap operation or other operations to be performed under console control. Switch 4 is the INITIALIZATION INHIBIT switch. When this switch is ON, diskettes cannot be initialized under software control thus preventing a "runaway" program from unintentionally altering the diskette initialization. This switch must be OFF when initializing diskettes. Both RDOS and CDOS are written to take full advantage of the Z-80 microprocessor instruction set. Complete details on RDOS are given in Chapter 2 of this manual. CDOS is described in a separate manual that is provided with Cromemco's disk software. #### CHAPTER 2: #### RDOS: Copyright 1977, Cromemco, Inc. The ROM-resident Disk Operating System has two modes of operation. If the 4FDC board is connected to one or more disk drives equipped with the CROMEMCO CDOS operating system and DIP switch 3 is on, the monitor will boot in the operating system from the disk whenever the computer is reset. If switch 3 is off, the monitor's command mode is accessed by resetting the computer. This mode provides control of the computer from the terminal keyboard attached to the 4FDC's serial port. Transfer of control to a program anywhere in memory can be made from the keyboard. Commands are also included to display the contents of memory, change memory values, move and compare blocks of memory, examine input ports, write data to output ports, and change the baud rate of the serial port on the 4FDC. These commands make the 4FDC useful even without disk drives for running the computer or for debugging hardware. There are also commands to select any of the four drives which can be attached to the 4FDC, to set its head seek rate, to seek tracks, to read or write blocks of memory to the diskette starting at any track and sector, to boot in CDOS from drive A and to change the location of the monitor's stack. #### Command Format The normal prompt of the monitor is a semi-colon, ';'. However, if a disk drive is selected the prompt changes in order to remind the user which drive is current. (See Select Disk Drive for details.) The monitor is controlled by one and two-character commands from the terminal keyboard. The format is free-form with respect to spaces. All data is entered and printed in hexadecimal format. In the following, DM is the Display Memory command and S is the Swath operator (See below). The four examples are equivalent commands. They display the contents of 100 hex bytes of memory beginning with location 1000 hex. ('(CR)' indicates carriage return). ;DM1000 10FF (CR) ;DM1000S100 (CR) ; D M 1000 10FF (CR) ; D M 1000 S 100 (CR) When entering an address as an operand, only the last four digits typed in are retained. For example, '321000' is read as '1000'. Therefore, if a wrong digit is entered, continue typing until the last four digits are correct. Only the last two digits typed are retained when a two-digit number such as a data byte is entered. # Swath Operator There are two ways to specify the address range of many commands. The first is to simply list the beginning and ending addresses (and, where appropriate, the destination address). For example, the first command below displays the contents of memory between addresses E400 and E402. The second command moves (or copies) the first 1400 hex bytes of memory to memory starting at 2000 hex. DM E400 E402 M 0 13FF 2000 Another way to do the same thing is to use the Swath operator, S, to specify the width of the address range rather than state the ending address explicitly. DM E400S3 M 0 S1400 2000 #### Errors and Escapes When the monitor detects an error condition, the command is aborted and a '?' is printed followed by the prompt ';' for the next command. Any command may be aborted from the keyboard either when the monitor is requesting further input, or during print-out, by depressing either the ESCAPE or the ALT MODE key. CONTROL-SEMI-COLON, CONTROL-SHIFT-'K', and '}' may also work. #### Baud Rates and UART Selection When the monitor is entered, push carriage-return until the monitor responds with: CROMEMCO RDOS The monitor is capable of selecting 19200, 9600, 4800, 2400, 1200, 300, 150, or 110 baud. The maximum number of carriage-returns required to select any of these baud rates is four. The baud rate can also be changed by using Initialize command. (See below.) Some peripheral devices such as paper tape readers or punches may have no keyboards. The baud rate can also be set by outputting a data byte from the following table to port 0. | Baud Rates | <u>Data Byte</u> | |------------|------------------| | 110 | 01 | | 150 | 82 | | 300 | 84 | | 1200 | 88 | | 2400 | 90 | | 4800 | AO | | 9600 | C0 | The baud rate can be octupled by outputting 10 hex to port 2. Outputting 0 to this port brings the baud rate back to normal. #### System Stack The monitor's stack normally resides in low memory between 40 and 80 hex. However, if it is in the way, it can be moved using the Kick Stack command. (see below) #### Using the Monitor Set the power-on jump switch on the ZPU card to C (1100 binary) and turn off DIP switch 3 on the 4FDC. Depress carriage-return two to four times in order to set the UART on the 4FDC to baud rate of the terminal being used. The monitor will then respond: #### CROMEMCO RDOS followed by a prompt ';'. The monitor is then ready to accept commands from the keyboard. In order to boot in CDOS from drive-A simply type: B (CR) #### COMMANDS #### Boot (1) B (CR) Boots CDOS from the diskette on drive-A. CDOS will then respond with its prompt 'A.'. Display Memory DM beginning-addr ending-addr (CR) (2a) or (2b) DM beginning-addr S swath-width The contents of memory are displayed in hexadecimal form. Each line of the display is preceded by the address of its first byte. For example: ;DM100 S3; #### Examine Input Port (3) E port-number (CR) Displays the current contents of the input port identified by port-number (in hex). Go (4) G starting-addr (CR) Execution begins at starting-address. ## Initialize Baud Rate (5) I (CR) After the carriage-return is typed, change the baud rate of the terminal to the desired value and then push carriagereturn until the monitor responds with its prompt. March 1986 A State of the The monitor is capable of selecting 19200, 9600, 4800, 2400, 1200, 300, 150, or 110 band. The maximum number of carriage returns required to select any of these baud rates is four. #### Kick Stack (6) K new-stack-location (CR) Moves the monitor's stack from normal location at 7C hex to any convenient location in RAM memory. Remember to leave 64 (40 hex) bytes for the system stack above its new location (including 4 bytes for temporary storage above the stack proper). in a superior of the control of the control of the control of the control of the control of the control of the Interpretation of the control of the control of the control of the control of the control of the control of the #### Move M source-addr source-end destination-addr (CR) (7a) or (7b) M source-addr S swath-width destination-addr (CR) Move (or copy) the contents of memory beginning with sourceaddress and ending with source-end to destination-address. After the move, the monitor verifies that source and destination are the same. This will result in a print-out of discrepancies which are not really errors after certain types of overlapping moves. However, this print-out can be terminated by depressing ESCAPE ar ALT Mode. The move command can be used to fill a block of memory with a constant. For example, to enter zeros between locations 100 and 108, use the Substitute Memory command to enter 0 at location 100, and then move 100 through 107 to 101: M 100 107 101 or #### M 100 S 8 101 Care should be taken not to overwrite the monitor's stack which resides in low memory between 40 and 80 hex unless changed with the Kick Stack command. #### Output (8) O data-byte port-number (CR) Writes data to the output port identified by port-number (in hex). #### Read Disk (9a)RD destination-addr destination-end sector-number (CR) or (9b) RD destination-addr S swath-width sector-number (CR) Before this command will be accepted the disk drive and track number must have been specified. (See the Select Disk Drive and Seek commands below.) Reads enough sectors from the current drive to fill the specified memory area, starting with the specified sector of the current track. Prints the first track and sector and the last track and sector read. However, if the last sector of the last track on the diskette is read before the memory area is filled then a question mark is printed and the command is terminated. The command is also terminated if an error is read in reading a sector. In this case, a message of the following type is printed: # R-ERR nn Where nn is a hex number which indicates the status: State of the State of | <u>Bit</u> | Indication | |------------|------------------| | 7 | Not Ready | | 6 | Record Type | | 5 | Record Type | | 4 | Record Not Found | | 3 | CRC Error | | 2 | Lost Data | | 1 | Data Request | | 0 | Busy | The number of the last track accessed can be obtained from input port 31 hex and the number of the last sector accessed from input port 32 hex. (See the Examine Input Port command.) | | Large Floppy | Mini Floppy | |---------|--------------|-------------| | Tracks | 0 - 4C hex | 0 - 27 hex | | Sectors | 1 - 1A hex | 1 - 12 hex | Care should be taken not to overwrite the monitor's stack which normally resides in lower RAM between 40 and 80 hex. If it is desirable to load this region of memory from the disk, first move the stack using the Kick Stack command. The test of the contract th #### Seek Track #### (10) S track-number (CR) Before this command will be accepted the disk drive must have been specified. (See the Select Disk Drive command below.) Seeks the specified track of the current drive. If an error is made, a message of the following type is printed: #### S-ERR nn where nn is a hex number which indicates the status: | Bit | Indication | |-------|---------------| | 7 | Not Ready | | 6 | Write Protect | | 5 | Head Engaged | | 4 . | Seek Error | | 3 | CRC Error | | 2 | Track 0 | | . 1 . | Index | | 0 | Busy | #### Substitute Memory #### (11) SM address (CR) Substitute Memory displays the contents of address and outputs a dot, '.', as a prompt for the substituted value. If no change is desired, type a space or another dot. Otherwise, enter the new value. The monitor accepts hex digits until it gets a delimiter, such as a space, dot, or carriage-return, retaining the last two digits entered as the value. Unless the delimiter is a carriage-return, the monitor then outputs the contents of the next sequential memory location with a dot prompt. A carriage-return terminates the command. #### Verify (12a) V source-addr source-end destination-addr (CR) or ((12b) V source-addr S swath-width destination-addr (CR) Verify that the block of memory between source-address and source-end contains the same values as the block beginning at destination-address. The addresses and contents are printed for each discrepancy found (unless the print-out is terminated by ESCAPE or ALT MODE) This command works by reading bytes from the source and destination and comparing them. If a discrepancy is found, the memory is read again for print-out. Thus it can happen that a discrepancy is printed-out with the source and destination contents indicated to be the same. This is caused by a defective memory element. #### Write Disk (13a) WD source -addr source -end sector-number (CR) $\mathbf{or}$ (13b) WD source S swath-width sector-number (CR) Before this command will be accepted the disk drive and track number must have been specified. (See the Select Disk Drive and Seek commands on previous page.) Writes the contents of the specified memory area to the current drive, starting with the specified sector of the current track. Prints the first track and sector and the last track and sector written. However, if part of the memory area remains after the last sector of the last track is written, a question mark is printed and the command is terminated. The command is also terminated if an error is made in writing a sector. In this case, a message of the following type is made: #### W-ERR nn where nn is a hex number indicating the status: | <u>Bit</u> | Indication | |------------|------------------| | 7 | Not Ready | | 6 | Write Protect | | 5 | Write Fault | | 4 | Record Not Found | | 3 | CRC Error | | 2 | Lost Data | | 1 | Data Request | | 0 | Busy | The last track accessed can be obtained from port 31 hex. The last sector accessed from port 32 hex. (See Examine Input command.) | | Large Floppy | Mini Floppy | | | |---------|--------------|-------------|--|--| | Tracks | 0 - 4C hex | 0 - 27 hex | | | | Sectors | 1 - 1A hex | 1 - 12 hex | | | #### Select Disk Drive The 4FDC will control up to four disk drives, labelled "A", "B", "C", and "D". It can handle seek speeds from the slow seek appropriate to the mini floppy to the fast seek of Cromemco's large floppy. It can also handle the medium seek of some other large floppies. To select a drive and a seek speed, type the drive label followed by one semi-colon for the fast seek, and two semi-colons for medium seek, or three semi-colons for slow seek. For example, to select drive C with slow seek, type: To select drive A with fast seek, type: #### A; (CR) Until the drive selection is changed the normal monitor prompt, ';', will be replaced by the disk label and speed indicator as typed, 'C;;' in the first example. All disk commands (Seek, Read Disk, and Write Disk) refer to the drive most recently selected. Disk selection also restores the disk drive head to home, track 0. If an error is made in doing this a message of the following type is printed: #### H-ERR nn where nn is a hex number indicating the status: | Bit | Indication | |-----|---------------| | 7 | Not Ready | | 6 | Write Protest | | 5 | Head Engaged | | 4 | Seek Error | | 3 | CRC Error | | 2 | Track 0 | | 1 | Index | | 0 | Busy | # CHAPTER 3: REGISTER DESCRIPTION The registers of the 4FDC will be discussed in numerical order according to their I/O address assignment shown below: | I/O Address (hex) | INPUT | <u>OUTPÚT</u> | |--------------------------------------------------|----------------------------------------|-------------------------------------| | etta amaga a <b>Qu</b> | UART status | UART baud rate | | 1917 1917 19 19 19 19 19 19 19 19 19 19 19 19 19 | UART data | UART data | | | not assigned | UART command | | which has the $0.3$ H $^{\circ}$ | interrupt address | interrupt mask | | 04 | parallel input | parallel out/auxiliary disk command | | 0.5 | not assigned | timer 1 | | 06 | 11 11 | timer 2 | | 07 | n et vicente de la Alexander | timer 3 | | 08 | н т | timer 4 | | 09 | 11 · · · · · · · · · · · · · · · · · · | timer 5 | | 30 | DISK status | DISK command | | | DISK track | DISK track | | 31<br>32 | | DISK sector | | 33 | | DISK data | | 34 | | DISK control | | 40 | not assigned | bank select | #### IN Status Register: Bit assignment by PC board traces. 00 | <u>D7</u> | <u>D6</u> | <u>D5</u> | <u>D4</u> | <u>D3</u> | <u>D2</u> | <u>D1</u> | $\overline{\mathbf{D0}}$ | |-----------------------------|-----------|-----------|-----------|-----------|-----------|-----------|--------------------------| | Transmit<br>Buffer<br>Empty | Data | Pend- | Bit | Bit | ial | | | The functions of these flags are indicated in the following sections. ## D7 Transmitter Buffer Empty (TBE): A high in bit 7 indicates that the transmitter data buffer is ready to accept a new byte. TBE goes high as soon as the serial transmitter begins to send the byte currently in the buffer. Since the transmitter is "double-buffered", the user may respond to the TBE signal and load the buffer even before the previous byte has been totally transmitted. TBE also activates interrupt request 5. TBE is cleared when the buffer is loaded and is set by the RESET command. #### D6 Receiver Data Available (RDA): A high in bit 6 indicates that a byte of data is available from the receiver buffer. This flag remains high until the buffer is read. A RESET command clears the flag. If the buffer is not read by the time the next byte from the receiver is ready, the new byte will write over the old byte and the overrun error flag will be set. RDA also activates interrupt request 4. #### D5 Interrupt Pending (IPG): A high in bit 5 indicates that one or more of the eight interrupt request sources has become active. This flag goes high at the same time as the interrupt request pin of the TMS 5501 UART. #### D4 Start Bit Detect (SBD): A high in bit 4 indicates that the serial receiver has detected a start bit. This bit remains high until the full character has been received. SBD is cleared by RESET command. This bit is provided for test purposes. #### D3 Full Bit Detect (FBD): The FBD flag in bit 3 goes high one full bit time after the start bit has been detected. This bit remains high until the full character has been received. FBD is cleared by a RESET command. This bit is provided for test purposes. # D2 Serial Receive (SRV): A high in bit 2 indicates high level on the serial data input line. A low in bit 2 indicates a low level on the serial data input line. SRV is high when no data is being received. This bit is provided for break detection and for test purposes. ## D1 Overrun Error (ORE): A high in bit 1 indicates that the receiver has loaded the receiver data buffer before the previous contents were read. ORE is cleared after the status port is read or by the RESET command. #### DO Frame Error (FME): A high in bit 0 indicates an error in one or both of the stop bits which "framed" the last received data byte. FME remains high until a valid character is received. OUT Baud Rate Register: Loading this register sets the baud rate and stop bits for serial receive and trans-00mit data. Bit assignment is as follows: > D7 D5 D4 <u>D3</u> <u>D2</u> D6 STOP 9600 4800 2400 1200 300 150 110 BITS A STOP TO A high in bit 7 selects one stop bit for serial receive and transmit data. A low in bit 7 selects two stop bits. # SC (AVIDOS IN ACT) AND TO DO BAUD RATE A high in one of the lower seven bits selects the corresponding baud rate. If more than one bit is high, the highest rate selected will result. If none of the bits are high, the serial transmitter and receiver will be disabled. (For special purposes, these baud rates can be octupled -- see the description of HBD in the command register). Receiver Data: This register contains an assembled 01 IN byte of data from the serial receiver. and the second of o - Transmitter Data: This register is loaded with data 01 OUT for the serial transmitter. - Not Assigned: Reading this port causes no response from the 4FDC. This address is available for other 02 IN parts of the computer system. a Carrier and the Carrier and the second and the second 02 OUT Command Register: The format for the command register is shown as follows: ----- latched ----- $\underline{D7}$ $\underline{D6}$ $\underline{D5}$ $\underline{D4}$ $\underline{D3}$ $\underline{D2}$ $\underline{D1}$ $\underline{D0}$ Not Not Test HIGH INTA RST7 Break Reset Used Used BAUD Enable Sel. #### D5 Test Bit (TB5): A high in bit 5 disables the internal interrupt priority logic and then enables the internal clock. Thus, the signal on the INT pin of the 5501 becomes a TTL level clock of 1562.5 Hz (12.5 kHz if HBD is high -- see D4 High Baud below). TB5 should be low for normal operation. #### D4 High Baud (HBD): A high in bit 4 octuples the rate of the internal clock. This causes the interval timers to count eight times faster and the serial data rates to increase eight-fold. When bit 4 is high, baud rates up to 76.8k are available for high speed data transfers. #### D3 INTA Enable (INE): A high in bit 3 allows the 5501 to respond to an Interrupt Acknowledge by gating a Restart instruction into the data bus at the correct time and resetting its internal interrupt request latch. A low in bit 3 prevents the 5501 from detecting an INTA cycle. Bit 3 should be high for normal operation. #### D2 RST7 Select (RS7): A high in bit 2 connects the MSB of the parallel input port to the interrupt request latch for the lowest priority interrupt (interrupt 7). A low-to-high transition on the MSB of the parallel input port (PI7) will activate the interrupt request latch. The 4FDC provides an optional jumper to connect DRQ from the disk to PI7. This jumper is labelled "INTER 7". When the jumper is inserted and RS7 is high, DRQ's from the disk will generate interrupts. A low in bit 2 connects the output of Timer 5 to the interrupt request latch for the lowest priority interrupt (interrupt 7). When the timer count reaches zero, the interrupt request latch will be activated. #### D1 Break (BRK): A high in bit 1 holds the serial transmitter output in the low state (spacing). RES will override (see DO Reset below). Cyrolina Record Edition A low in bit 1 allows normal operation. BRK should be 1ow for normal operation. DO Reset (RES): English Francis A high in bit 0 causes the following actions: - a) The Serial Receiver goes into search mode; RDA, SBD, FBD, and ORE are set to zero. The contents of the receiver buffer are not affected. - b) The Serial Transmitter output is set high (marking). If DO and D1 are both high, the RES function will override. RES sets TBE high. - c) The interrupt register is cleared except for the TBE interrupt request which is set high. - d) The interval timers are cleared. RES is not latched. - Interrupt Address: This register contains the en-03 IN coded address of the highest priority interrupt currently requesting service. This address is identical to the "Restart" instruction op-code for the interrupt acknowledge. Thus, the register contents may be (in order of service priority): - HEX SOURCE C7 --- Timer 1 CF --- Timer 2 D7 --- End of job (From disk) DF --- Timer 3 E7 --- Receiver Data Available EF --- Transmitter Buffer Empty E7 --- Timer 4 - F7 --- Timer 4 - FF --- Timer 5 or (DRQ From Disk) This register is provided for servicing interrupts via polling. After the register is read, the corresponding bit in the interrupt request register is reset. If the register is read when no interrupt is pending, it will read OFFH. OUT Interrupt Mask: The contents of this register are logically "And"-ed with output from the interrupt request register on the 5501. A high bit in the interrupt mask allows the corresponding request to pass on into the priority encoder. A low bit in the interrupt mask inhibits the corresponding interrupt from passing any further. Since the interrupt requests are latched independently of the state of the mask, an interrupt may be requested while the mask bit is low. The request will be retained until the mask is changed and the request allowed to pass on (assuming no RES command in the interim). The mask bit assignments are: $\underline{D7}$ $\underline{D6}$ $\underline{D5}$ $\underline{D4}$ $\underline{D3}$ $\underline{D2}$ $\underline{D1}$ $\underline{D0}$ Timer 5 Timer 4 TBE RDA Timer 3 EOJ Timer 2 Timer 1 DRO O4 IN Parallel Input: This register contains the data presented at J4. Two bits are reserved for the 4FDC. D7 D6 D5 D4 D3 D2 D1 D0 DRQ SEEK X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X D7-DRQ (jumper option) A high in bit seven indicates the DISK data register, PORT 33H, is requesting service. This signal is also available at ports 30H and 34H. DRQ is provided at bit seven of port 04 so that the RS7 mode of the UART may be selected (see description of RS7; bit 2 of port 2) if interrupt driven disk routines are required. When shipped, the 4FDC does not have the enabling jumper inserted. In order to use D7 as described here, insert jumper "INTER 7" just below J4. #### D6 - SEEK IN PROGRESS A high in bit six indicates the voice coil motor in the currently selected drive is in motion. A low in bit six indicates the voice coil motor has stopped moving in the currently selected drive. This signal is only meaningful when the currently selected drive has a voice-coil head stepper motor (e.g. PERSCI 277). In all other cases, it will float high through the 150 ohm pullup to +5 volts. #### D5-D0 unassigned The bottom six input bits are free for system use. The input data must stabilize within 75 ns after Input Strobe/ goes low and remain stable until Input Strobe/ goes high again. 04 OUT Parallel Output/Auxiliary Disk Command: This register contains the data which drives the parallel output buffers. Data is stable after Output Strobe/rises. <u>D7 D6 D5 D4 D3 D2 D1 D0</u> X -EJ. -EJ. -FAST -RESTORE -CONTROL X X LEFT RIGHT SEEK OUT ← PERSCI 277 OPTIONS → D7 -Not assigned #### D6 -EJECT LEFT A one in bit six causes no action. A zero in bit six activates the eject left line of J2. This bit only affects PerSci 277 drives with remote eject option. This bit is normally high. #### D5 -EJECT RIGHT A one in bit five causes no action. A zero in bit five activates the eject right line of J2. This bit only affects PerSci 277 drives with remote eject option. This bit is normally high. #### D4 - FAST SEEK A one in bit four causes no action. A zero in bit four puts the FD 1771 into fast step mode as needed by voice coil drives. D4 should be returned to logic 1 after the drive has signalled seek complete. This bit is normally high. #### D3 - RESTORE A one in bit four causes no action. A zero in bit four causes the currently selected drive to return to Track 00. This bit is normally high. #### D2 - CONTROL OUT A high in bit 2 causes no action. A low in bit 2 pulls down pin 1 of J1 the priority Daisy-Chain. This bit is normally high. D1,D0-Not assigned - 05 IN Not Connected: Addressing this port causes no response from the 4FDC. This address is available for use by other parts of the computer system. - Timer 1: This register contains the count used to TUO 05 start Timer 1. This count is decremented by 1 every 64 useconds after initial loading. When the count reaches zero, bit 0 of the interrupt request register is set and the timer disabled. Since the maximum count is 255, the longest interval is 255x64 useconds = 16.32 mseconds. Accuracy is plus 0 and minus 64 µseconds. Loading a count of zero causes an immediate interrupt request to the interrupt request register. Loading a new count while the timer is counting reinitializes the timer without an interrupt request. If HBD is high in the command register, the timers will count eight times as fast. - 06 IN Not Connected: Same as Input 05. - 06 OUT Timer 2: Operates in the same fashion as timer 1. - 07 IN Not Connected: Same as Input 05. - 07 OUT Timer 3: Operates in the same fashion as timer 1. - 08 IN Not Connected: Same as Input 05. - 08 OUT Timer 4: Operates in the same fashion as timer 1. - 09 IN Not Connected: Same as Input 05. - 09 OUT Timer 5: Operates in the same fashion as timer 1 - 30 IN <u>Disk Status</u>: This register's bit assignment varies according to the last command loaded into the disk command port. There are six possible assignments: | Last<br>Command | <u>D7</u> | <u>D6</u> | <u>D5</u> | <u>D4</u> | <u>D3</u> | <u>D2</u> | <u>D1</u> | <u>D0</u> | |------------------------------|--------------|------------------|--------------|--------------|--------------|--------------|-----------|-----------| | SEEK,<br>STEP, or<br>RESTORE | Not<br>Ready | Write<br>Protect | Head<br>Down | Not<br>Found | CRC<br>Error | | Index | Busy | | | | Record<br>Type | | | | | | Busy | | WRITE<br>RECORD(S) | | Write<br>Protect | | | | | | Busy | | READ<br>ADDRESS | Not<br>Ready | 0 | | | CRC<br>Error | | • | Busy | | READ<br>TRACK | Not<br>Ready | | <b>0</b> | 0 | s | Lost<br>Data | | Busy | | | | Protect | | 0 | | | DRQ | Busy | # D7 -NOT READY A one in bit 7 indicates the drive is unable to execute the command (e.g., the door is open). This bit is an inverted copy of the signal from the currently selected drive. #### D6 -WRITE PROTECT OR RECORD TYPE During READ RECORD(S) this bit represents bit 1, inverted, of the DATA ADDRESS MARK data byte. During WRITE or head moving operations, this bit is set to one if the diskette in the currently selected drive has been write protected. the form of the start #### D5 - HEAD DOWN OR RECORD TYPE OR WRITE FAULT During head movement commands, this bit is set to one when the head is down and the setting time has elapsed. During READ RECORD(S), this bit represents bit O, inverted, of the DATA ADDRESS MARK data byte. During WRITE operations, this bit is a copy of the WRITE FAULT signal from the currently selected drive. The second of the second of the This bit is reset after being read. #### D4 - NOT FOUND . . A high in bit 4 indicates the desired track/ and or sector were not verified. During READ ADDRESS, a high in bit 4 indicates no sector address field was encountered. This bit is cleared after the status register is read. and the property of the second #### D3 - CRC ERROR A high in bit 3 indicates the internal CRC check did not agree with the diskette's CRC bytes. If bit 4 is set, the CRC error ocurred in an address field; otherwise, it indicates an error in a data field. #### D2 - TRACK 00 OR LOST DATA During head movement commands, a one in bit 2 indicates the head is positioned over TRACK 00 (farthest from the center). This signal is a copy of TK00 from the currently selected drive. During data transfer commands, a one in bit 2 indicates that the computer did not respond to DRQ within one byte time (i.e., 32 useconds or 64 useconds for 8" or 5" drives respectively). LOST DATA is cleared after being read. # D1 - INDEX OR DRQ During head movement commands, a one in bit 1 indicates that the diskette in the currently selected drive is passing the INDEX or beginning of the track. This bit is a copy of IP from the drive. During READ commands, a high in bit 2 indicates the 4FDC has a data byte from the disk ready to be read at port 33H. This bit is reset after being read. During WRITE commands, a high in bit 2 indicates the 4FDC needs a data byte from the computer at port 33H. This bit is reset after it is read. #### DO - BUSY A high in bit 0 indicates the 4FDC is executing a disk command and cannot accept a new disk command yet (except a FORCE INTERRUPT command; see description of FORCE INTERRUPT). 30 OUT <u>Disk Command Register</u>: The bit assignment varies with each command, therefore, each command will be discussed separately. # - SUMMARY - | Command | | <u>D7</u> | <u>D6</u> | <u>D5</u> | <u>D4</u> | <u>D3</u> | <u>D2</u> | <u>D1</u> | $\overline{\mathbf{D0}}$ | |-----------------|------|-----------|-----------|-----------|-----------|-----------|----------------------|-----------|--------------------------| | RESTORE | • | 0 | 0 | 0 | 0 | 1 | ν | r, | $\mathbf{r}_{0}$ | | SEEK | | 0 | 0 | 0 | 1 | 1 | ν | $r_1$ | r <sub>o</sub> | | STEP | | 0 | 0 | 1 | u | 1. | v | rı | r <sub>o</sub> | | STEP IN | | 0 | 1 | 0 | u | 1 | ν | r, | $\mathbf{r}_{0}$ | | STEP OUT | | 0 | 1 . | 1 | u | 1 . | $\mathbf{V}_{\cdot}$ | $r_1$ | $\mathbf{r}_{0}$ | | READ RECORD(S) | . 7. | 1 | 0 : | 0 . | m | Ъ | <b>E</b> . | 0 | 0 | | WRITE RECORD(S) | | 1 | 0 | 1. | m | Ъ. | E | $a_1$ | $a_{\sigma}$ | | READ ADDRESS | | 1 | 1 | - 0 | 0 | 0. | 1 | - 0 | 0 | | READ TRACK | | 1 | 1 | 1 | 0 | 0 | 1 | 0 | s | | WRITE TRACK | | 1 | 1 | 1 | 1 | 0 . | 1 | 0 | 0 | | FORCE INTERRUPT | | 1 | 1 | 0 | 1. | $I_3$ | $\mathbf{I}_{2}$ | $I_1$ | $I_0$ | | | | | | | | | | | | | <u>F1ags</u> <u>=1</u> | este<br><del>Tri t</del> erre e e | e o egyét<br>Szazászásá | - (1)<br>- (1) | <u>=0</u> | | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------|---------------------------------------|----------------|---------------------------|------------------------------------| | v Verify on la u Update track m Multiple rec b IBM block E Enable head \$\bar{s}\$ No synchroni | register<br>ords | No u<br>Sing<br>Othe<br>v Assu | r<br>me head | is down | n<br>ress Mark | | i de la proposición de la composición del composición de la compos | Fields | = 0 | =1 | = 2 | =3 | | (8" Stepping Rate)<br>(5" Stepping Rate) | $r_1r_0$ | 6 ms<br>12 ms | 6 ms<br>12 ms | 10 ms<br>20 ms | 20 ms<br>40 ms | | | | FB (DATA<br>MARK) | FA | F9 | F8 (DELETED DATA) | | | ĪĒN | I <sub>2</sub> =1<br>WHEN<br>NOT READ | . I | I <sub>1</sub> =1<br>NDEX | $\frac{10 = 1}{1 \text{MMEDIATE}}$ | #### COMMAND DESCRIPTION #### RESTORE Upon receipt of this command, the Track 00 (TR00) input is sampled. If TR00 is active low indicating the Read-Write head is positioned over track 0, the Track Register is loaded with zeroes and EOJ is set. If TR00 is not active low, stepping pulses are issued until the TR00 input is activated. At this time, the Track Register is loaded with zeroes and EOJ is set. and the said If the TR00 input does not go active low after 255 stepping pulses, the 4FDC terminates operation, sets EOJ, and sets the Seek error status bit. Note that the RESTORE command is executed after a RESET. A verification operation takes place if the V flag is set. 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 4FDC will update the Track Register and issue stepping pulses in the appropriate direction until the contents of the Track Register are equal to the contents of the Data Register (the desired track location). A verification operation takes place if the V flag is on. EOJ is set at the completion of the command. STEP Upon receipt of this command, the 4FDC 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 r<sub>1</sub>r<sub>0</sub> field, a verification takes place if the V flag is on. If the u flag is on, the Track Register is updated. EOJ is set at the completion of the command. STEP IN Upon receipt of this command, the 4FDC issues one stepping pulse in the direction towards the center of the diskette. If the u flag is on, the Track Register is incremented by one. After a delay determined by the $r_1r_0$ field, a verification takes place if the V flag is on. EOJ is set at the completion of the command. STEP OUT Upon receipt of this command, the 4FDC 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 $r_1r_0$ field, a verification takes place if the V flag is on. EOJ is set at the completion of the command. These five commands have an optional verification flag. During verification, 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, EOJ is set, and the BUSY status bit is reset. If there is not a match but there is valid ID CRC, EOJ is set, the Seek Error status bit (Status bit 4) is set, and the BUSY status bit is reset. If there is a match but not a valid CRC, the CRC error status bit is set (Status bit 3), and the next encountered ID field is read from the disk for the verification operation. If an ID field with a valid CRC cannot be found after two revolutions of the disk, the 4FDC terminates the operation, sets EOJ, and sets record not found in the status register. 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. READ RECORD(S) Upon receipt of the Read command, the head is loaded, the BUSY status bit is set; and when an ID field is encountered that has the correct track number, correct sector number, and correct CRC, the data field is presented to the computer. The Data Address Mark of the data field must be found within 28 bytes of the correct field; if not, the Record Not Found status bit is set and the operation is terminated. When the first character or byte of the data field has been shifted, DRQ is generated. When the next byte is accumulated, another DRQ is generated. When the next byte is accumulated, another DRQ is generated. computer has not read the previous contents of the Data Register before a new character is transferred, that character is lost and the Lost Data Status bit is set. sequence continues until the complete data field has been inputted to the computer. If there is a CRC error at the end of the data field, the CRC error status bit is set and the command is terminated (even if it is a multiple record command). At the end of the Read operation, the type of Data Address Mark encountered in the data field is recorded in the Status Register (Bits 5 and 6) as shown below: | Status<br>Bit 5 | Status<br>Bit 6 | Data AM<br>(HEX) | |-----------------|-----------------|------------------| | 0 | 0 | FB | | 0 | 1 | FA | | 1 | 0 | F9 | | 1 | $1 \cdots$ | F8 | WRITE RECORD(S) Upon receipt of the Write command, the head is loaded and the BUSY status bit is set. When an ID field is encountered that has the correct track number, correct sector number, and correct CRC, a DRQ is generated. The 4FDC counts off 11 bytes from the CRC field and the Write Gate (WG) output is made active if the DRQ is serviced (i.e., the Data Register 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, six bytes of zeroes are written on the disk. At this time, the Data Address Mark is then written on the disk as determined by the alao field of the command as shown below: | en e | <u>a</u> 1 | <u>a o</u> | DATA MARK (HEX) | CLOCK MARK (HEX) | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------|------------|-----------------|------------------| | And the second s | 0 | 0 | FB | . C7<br>C7 | | | n englige kolon <b>I</b> - | U | F9 | C7<br>C7 | The 4FDC 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 zeroes 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 internally and written on the disk followed by one byte gap of logic ones. The two commands READ RECORD(S) and WRITE RECORD(S) contain a (b) flag which in conjunction with the sector length field contents of the ID determines the length (number of characters) of the Data field. For IBM 3740 compatibility, the b flag should equal 1. The numbers of bytes in the data field (sector) is then 128 x $2^{n}$ where n=0,1,2,3. For b = 1 | Sector Length<br>Field (hex) | Number of bytes in sector (decimal) | |------------------------------|-------------------------------------| | 00 | 128 | | 01 | 256 | | 02 | 512 | | 03 | 1024 | | | | graduate the state When the b flag equals zero, the sector length field (n) multiplied by 16 determines the number of bytes in the sector or data field as shown below: | For b | | | |-------|------------------------------|-------------------------------------| | | Sector Length<br>Field (hex) | Number of bytes in sector (decimal) | | | 01<br>02<br>03<br>04 | 16<br>32<br>48<br>64 | | | FF<br>00 | 4080<br>4096 | These two commands also contain a (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 EOJ is set 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 4FDC will continue to read or write multiple records and update the sector register until the sector register exceeds the number of sectors on the track. At this point, the NOT FOUND and CRC error bits are set, and EOJ is set. READ ADDRESS Upon receipt of the Read Address command, the head is loaded and the BUSY status bit is set. The next encountered ID field is then read in from the disk and the six data bytes of the ID field are assembled. DRQ is generated for each byte. The six bytes of the ID field are shown below: | TRACK | ZEROES | SECTOR | SECTOR | CRC | CRC | |-------|--------|--------|--------|-----|-----| | ADDR | | ADDR | LENGTH | 1 | 2 | | 1 | 2 | 3 | 4 | 5 | 6 | Although the CRC characters are transferred to the computer, the 4FDC checks for validity and the CRC error status bit is set if there is a CRC error. The Sector Address of the ID field is written into the sector register. At the end of the operation, EOJ is set and the BUSY status bit is reset. #### READ TRACK Upon receipt of the Read Track command, the head is loaded and the BUSY status bit is set. Reading starts with the leading edge of the first encountered index mark and continues until the next index pulse. As each byte is assembled, it is transferred to the Data Register and the Data Request is generated for each byte. No CRC checking is performed. Gaps are included in the input data stream. If bit 0 (\$\overline{S}\$) of the command is a 0, the accumulation of bytes is synchronized to each Address Mark encountered. Upon completion of the command, EOJ is set. #### 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 Data Register 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 EOJ If a byte is not present in the is set. Data Register when needed, a byte of zeroes 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 written. ## CONTROL BYTES FOR INITIALIZATION | | INTERPRETATION | CLOCK MARK<br>(HEX) | |------------|-------------------|---------------------| | <b>F</b> 7 | Write CRC Char. | FF | | · F8 | Data Addres Mark | C7 | | F9 | Data Address Mark | C7 | | FA | Data Address Mark | C7 | | DATA PATTERN (HEX) | INTERPRETATION | CLOCK MARK<br>(HEX) | |--------------------|--------------------|---------------------| | FB | Data Address Mark | <b>C</b> 7 | | FC | Index Address Mark | D7 | | FD | Spare | | | F <b>E</b> | ID Address Mark | C7 | The Write Track command will not excecute if SW4 is ON. Note that one F7 pattern generates 2 CRC characters. #### FORCE INTERRUPT 64 8 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 EOJ will be set when the condition specified in the $I_0$ through $I_3$ 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_1$ = Ready-10-Not-Ready ITansi $I_2$ = Every Index Pulse I<sub>3</sub> = Immediate Interrupt If $I_0 - I_0 = 0$ , the command will be terminated but EOJ will not be set. The FORCE INTERRUPT commands above must be cleared in this manner before the 4FDC is given its next command. #### 31 IN/OUT Track Register: This register holds the track number of the current Read/Write head position. It is incremented by one every time the head is stepped in (towards track 76) and decremented by one when the head is stepped out (towards track 00). The contents of the register are compared with the recorded track number in the ID field during disk Read, Write, and Verify operations. This register should not be loaded when the 4FDC is busy. #### 32 IN/OUT Sector Register: This 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. This register should not be loaded when the device is busy. - In Data Register: This 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. - 34 IN Disk Flags: This port provides four signals. D7 - DRQ gradual and section of A high in bit 7 indicates the 4FDC has a byte from the disk or needs a byte for the disk according to the current operation. D6 - BOOT A low in bit 6 indicates that SW3 is set to ${\tt BOOT}$ . A high in bit 6 indicates SW3 is set to MON. D5 -HEADLOAD A one in bit 5 indicates the head of the currently selected drive is loaded. A zero in bit 5 indicates the head has unloaded. D4-D1 -Unassigned DO -EOJ A one in bit 0 indicates the command has finished. (End of job) #### 34 OUT Disk Control: D7 D6 D5 D4 D3 D2 D1 D0 AUTO X MOTOR MAXI DS4 DS3 DS2 DS1 WAIT ON #### D7 ~AUTO WAIT A one in bit seven puts the 4FDC into Auto Wait mode which means that subsequent reading of Input port 34H will hold the CPU in a WAIT state until one of three things happen: - a) The 4FDC issues a DRQ (this is the normal use of AUTO WAIT). - b) The 4FDC issues EOJ this terminates the AUTO WAIT condition (the normal method of termination). - c) There is a hardware RESET. D6 -Unassigned D5 -Motor On A one in bit 5 activates the motor-on signal to all disk drives. A zero in bit 5 deactivates the motor-on signal to all disk drives. This bit is set by RESET. D4 -MAXI A one in bit 4 conditions the 4FDC for an 8" disk drive. A zero in bit 4 conditions the 4FDC for a 5" disk drive (Mini). This bit is set by RESET. D3-D0 -DRIVE SELECT A high in bits 3 through 0 selects the corresponding disk drive for all further operations. Only one drive should be selected at a given time. RESET deselects all drives. 40 OUT Bank Select: Outputting any byte to port 40H will disable the 1K ROM on the 4FDC if SW2 is on. The ROM may be re-enabled by RESET. #### CHAPTER 4: INTERFACE CHARACTERISTICS - S-100 The 4FDC appears on the S-100 bus as a 1K memory card and 15 I/O ports. The 4FDC is capable of generating interrupts and responding on a prioritized basis to the interrupt acknowledge cycle. (N.B. CDOS does not use the interrupt capability of the board.) Data exchange for the disk and serial I/O is programmed, not via direct memory access (DMA). This requires a minimum CPU speed of 2 mHz and no memory wait states (at 2mHz) in the buffer memory. The Bootstrap/Monitor ROM is addressed at C000-C3FFH. This address may be changed by cutting traces and inserting jumpers at IC44. Hold acknowledge will temporarily disable the ROM. At 4mHz, the 4FDC inserts one wait state on M1 (instruction fetch) cycles for 280 compatibility. There are no wait states at 2mHz. When switch one is on, the ROM is defeated and the 4FDC occupies no address space in memory. When switch 2 is on, the ROM is disabled as soon as a byte (any byte) is written to output port 40H, the bank select port. The ROM is re-enabled by a hardware RESET. The serial I/O channel requires 10 I/O addresses. CDOS requires these to start at I/O address 00, the way the 4FDC is shipped. The starting address may change at 10, 20, 50, 60, or 70 H by cutting the trace at the "0" output of IC 7 and moving it to another output pin. The serial I/O channel is asynchronous because it uses the on-board clock. When one of the serial I/O channel's ports is addressed by the CPU, the 4FDC pulls down PRDY and holds it down until the 4FDC synchronizes with the CPU (up to 1 usec.) The disk I/O ports are synchronous. CDOS assumes a base address of 30H, although this may be changed by cutting the trace at the "3" output of IC7 as explained above. There are two cases in which the 4FDC will create wait states for the disk I/O ports: 1) if the ports 30-33H are read at 4 mHz there will be one wait state added for the FD1771 data to stabilize, and 2) if the Auto-Wait mode has been selected an indefinite number of waits will be added to read or write operations on port 34H. The CPU will stay in a WAIT state until the 4FDC issues a Data Request or an End of Job signal (or there is a hardware RESET). This mode is used when reading or writing 8" diskettes with a 2mHz CPU. Interface Characteristics - Serial Channel The 4FDC provides both RS-232 and 20 mA current loop interface. For RS-232 connect three wires from your terminal as follows: RS-232 terminal 4FDC (i.e. CRT) J4 ...... Signal ground (not chassis) pin [7] Receiver data (for display) pin 3 Transmitter data (keyboard) pin 2 Some terminals may require additional modem control signals such as Clear to Send, Data Set Ready, Data Carrier Detect, etc. These may be wired to J4 pin 23 of the 4FDC. For 20 ma teletype interface, make the following connections: | 4FDC ASR33 (rear terminal block) | |---------------------------------------------------| | pin 25 (terminal 6 (printer current out) | | pin 24 terminal 3( keyboard current out) | | pin 23 terminal7(printer current in) | | pin 17 terminal 4 (keyboard current in) | | Interface Characteristics - 8" and 5" Disk Drives | The 4FDC drives J2 and J3, the Disk Drive Signal Cable Connectors, in parallel through separate sets of TTL bus drivers. The Signal cables should be terminated (150 ohm resistors to +5 volts) at the end of the cable only. If more than one driver per cable is used, only the last drive on the cable should use pullups. Signals from the drives back to the controller are terminated on the 4FDC with 150 ohm pullups. The second second Outputs from the 4FDC: (all active low 0.6 volts) | DS1 | These are the four drive select signals. When a drive | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------| | DS2 | select signal is active the selected drive should en- | | | Select Signal is active the believed attro | | DS3 | able its data and status drivers and load the read/ | | DS4 | write head. All other drives should ignore signals | | | And the transfer of the control of first agented | | 2 - 4 - 4 to 4 to 1 | until selected. When DRIVE SELECT is first asserted, | | 100 | the 4FDC waits a fixed amount of time for the head to | | | LOAD before reading or writing the diskette. This time | | | | | | delay is 48 ms for 8" drives and 72 ms for 5" drives. | | | The delay may be changed by rewiring IC53. The delay | | | The deray may be changed by rewriting resisting deray | | ranka kilonin katu | is 8 milliseconds times (16 - delay jumper value) as | | The second second second | shown on the following page. | | and the state of t | Shown on the lottowing page. | | | | | | | STEP This line goes active low for 16 microseconds to move the head of the selected drive in the direction specified by output DIRC. For multiple steps, the stepping rate is determined by the format of the command given to the 4FDC and will be 6, 10 or 20 milliseconds per step for large floppies (except voice coil types like the PerSci 277, in which case it is about 400 microseconds per step) or 12, 20 or 40 milliseconds per step for small floppies. The 4FDC will wait one stepping period after the last step for the Head to settle before attempting to read or write the diskette. DIRC When this line is asserted (low) pulses on the STEP line should cause the head of the selected drive to advance one track per step towards the center of the diskette. If DIRC is high, pulses on the STEP line should cause the head of the selected drive to retreat on track per step towards the outer edge of the diskette (towards Track 00.) Motor On This signal turns on the motors of all drives when low. When high it turns off the motors off all drives (so equipped). WRITE GATE This signal goes low to enable diskette write operations. WRITE DATA This signal contains the intermingled clock and data pulses to be written on the diskette. Pulse width is 500 nanoseconds for 8" drives, 1 microsecond for 5" drives. RESTORE This signal requests the head of the selected drive to return to TRACK 00. This signal is not used by the CDOS drivers. EJECT This signal requests the currently selected PerSci 277 LEFT to eject its left hand diskette. EJECT This signal requests the currently selected PerSci 277 RIGHT to eject its right hand diskette. Inputs to the 4FDC (all active low 0.6 volts) INDEX This line should go low for at least 10 useconds once per revolution of the diskette. TRACK This signal should go low and stay low while the selected drive is on track 00, the outermost track. READY This signal should be low when the disk drive is operable (i.e. door is closed, motor speed up, etc.) The 4FDC will always initiate a command regardless of the state of ready; the purpose of the signal is for detecting disk change operations using the Force Interrupt command. WRITE This signal goes low if a write-protected diskette is PROTECT in the currently selected drive. READ This signal is composite clock and data pulses from the DATA 5" drive. The line should go low for 1 microsecond for each flux reversal on the surface of the diskette. DATA pulses) from the currently selected 8" drive. The pulse should be low for 250 nanoseconds. This signal contains the clock stream (separated from the data pulses) from the currently selected 8" drive. The pulses should be active low for 250 nanoseconds. SEEK COMPLETE This signal should go low when the voice coil drive has positioned the read/write head over the desired track. This signal is gated with drive select and applies only to voice coil drives like the PerSci 277. CHAPTER 5: PARTS PLACEMENT DIAGRAM #### CHAPTER 6: INITIAL SET-UP 4FDC Switches - For initial check-out operation set switches 1, 2, and 3 OFF and switch 4 ON. For operation after initial check-out set switches 1 OFF, and switches 2, 3, and 4 ON. The function of these switches is as follows: | | | FUNCTION WHEN<br>OFF | FUNCTION WHEN<br>ON | SETTING FOR<br>INITIAL<br>CHECK-OUT | "NORMAL"<br>SETTING | |-----|----------|-----------------------------------------------------------------------------------|-------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------| | OFF | SWITCH 1 | Permits monitor/<br>boot ROM to be<br>read. | Totally dis-<br>ables monitor<br>boot ROM. | OFF | OFF | | CNO | SWITCH 2 | Keeps the mon-<br>itor/boot ROM<br>Resident (by<br>disabling the<br>bank select). | Disables the monitor/boot ROM after the first output to I/O port 40H (bank select). | OFF | ON | | OFF | SWITCH 3 | Signals the monitor/boot program to stay in mon-itor mode. | Signals the monitor/boot program to go to the boot mode. | OFF | ON | | CNO | SWITCH 4 | Permits the<br>4FDC to in-<br>itialize<br>diskettes. | Inhibits in-<br>itialization<br>of diskettes. | ON State of the st | ON | 4FDC Cables - Place the 4FDC in front of you with component side up and J1-J4 away from you. Plug in disk and terminal cables as follows: | Connector | Function | Cable Size | |------------|-------------------------------------------|--------------| | <b>J2</b> | 8" disk daisy chain<br>PerSci 277 | 50 Conductor | | <b>J</b> 3 | 5" disk daisy chain (for WANGCO 82 drive) | 34 Conductor | | J4 | Serial Interface (CRT, TTY, etc.) | 26 Conductor | Be certain that the cable stripe is on the left when the cables are plugged in. ### PerSci Model 277 Set-Up Connect DC power to J3 on the PerSci drive. Connect the 50 pin cable from J2 on the 4FDC to Pl on the PerSci. Assign drive numbers to the PerSci by wiring the 14 pin jumper inserted in Ull on the PerSci as follows: If your system uses two Model 277s, remove termination pack Ul from the drive electrically closer to the 4FDC. ### WANGCO Model 82 Set-Up Cut the jumper wire on the PC board of the Wangco Model 82 labelled "MUX" (just above J4, the big blade connector in back). Locate the package of jumper straps just above the PC board edge connector. The first 3 jumper positions, labelled "DS1", "DS2", "DS3", select DRIVE A, DRIVE B, or DRIVE C respectively. Cut the 2 jumpers that don't apply to your configuration (or simply bend out the pins on the jumper pack so they don't contact the socket). The 5 remaining jumpers connect line terminating resistors. For single drive set-ups, these jumpers are left intact. For 2 or more drives, the jumpers are left intact on the drive at the end of the control cable only; the other drives have these jumpers cut (or bent) out. Fig. 6-1. When using the Wangco model 82 disk drive with the Cromemco model 4FDC controller the "MUX" strap and "Frame Ground" strap must be disconnected as shown in this figure. The jumper plug shown in the figure must be configured as described in the text. Finally, locate the spade lug ground on the rear chassis with a white wire under it. Remove the spade lug, disconnect the white wire, and replace the spade lug. Tape the white wire (or cut it off); it is no longer needed. This isolates chassis ground from logic ground. (See Figure 6-1 for details). ### Initial Check-Out Set the MON switch 3, to the MON position (off); the RESident switch, switch 2, to RES position (off); and the ROM enable switch to ROM position (off). Verify that your computer has a processor and at least 1K of read/write memory addressed anywhere but C000 (the Monitor/Boot coldstart entry point). Since the MON switch is selected. the Monitor program will be excuted instead of the Bootstrap loader. Press "Carriage Return" on your terminal until the monitor signon message appears, indicating that the monitor has successfully determined the terminals baud rate. Legal Baud rates are 110, 150, 300, 1200, 2400, 4800, 9600, and 19,200. Insert a diskette in your Drive A and verify the drive performance by calibrating the drive, seeking out 2 tracks, and reading the first sector as detailed below: ;A; This restores the head if 8"; type A;;; for 5"drive A;S2 Seek track 2 A;RD 80 S 80 1 Reads into 80H the last sector To bring up the Cromemco Disk Operating System, set up your computer with 32 kilobytes of read/write memory addressed from 0000-7FFFH. This memory must be full speed (450 ns acess time maximum) if you are running an 8" disk drive and have a 2mHz processor. We recommend either the 4KZ static memory or 16KZ dynamic memory cards for reliable operation at both 2 and 4 mHz. If you have a Cromemco ZPU, set it for 2 or 4 mHz operation as desired (CPU speed does not affect disk performance) and set the power-on-jump address to "C000" (i.e. Al5=Al4=1). On the 4FDC set the MON switch, switch 3, to the BOOT position (on) and the RESident switch, switch 2, to the BANK position (on). Power up the system and execute C000 H. The head will load on drive A as the Bootstrap program in the ROM reads in sector 1 of track 00, and transfers program control to CDOS, and "deboots" (the ROM disables itself, leaving address C000-C3FFH free for the system if necessary). Press "Carriage Return" on your terminal until the CDOS signon message appears, indicating that CDOS has successfully determined the terminal's baud rate. The head will load again as more of the CDOS program is read into memory. The command DIR will list the names of the files on the disk. ### CHAPTER 7: THEORY OF OPERATION ### Power Supplies The unregulated bus power lines are converted to regulated supplies of +5, -5, and +12 volts by ICs 40, 15, and 39 respectively. The 4FDC requires 1.0 A at +8 unregulated, 0.100 A at +18 unregulated, and 0.100 A at -18 unregulated. ### Address Decode The 4FDC decodes address and status signals on the bus to find the following conditions: 1) Memory read cycles in the address range COOO-C3FFH, 2) Input/Output references in the address range 30-34H, and 4) Output references to port 40H. In case 1, IC30P9 will go low, enabling the 1K prom IC31. In case 2, the address decoding is done in two stages. First, the base address is decoded by IC7, then the offset is determined by IC23. Pin 15 of IC7 goes low for addresses in the range of 00-0FH. In case 3, 1C7P12 goes low when the address base 30-3FH is detected. Further decoding is performed by IC11's address inputs and by the gating in the read/write circuits of IC36. Input or output references to port 34H are signalled by a high level at IC22P5. In case 4, IC7P11 goes low for address base 40-4FH. IC8P11 goes low for outputs with an offset of 0, thus clocking IC29 on output references to port 40H. $(1+\alpha)^{\frac{1}{2}} \delta (1+\alpha)^{\frac{1}{2}} (1+\alpha)^{\frac{1$ ### Data Bus The 4FDC has a three state, bidirectional internal data bus. It is coupled to the Data In and Data Out buses on the S-100 bus through latch ICs 33 and 50. There are four cases of operation determined by the particular 4FDC function being addressed. Case 1, Memory Read: When IC30P9 goes low selecting the 2708, data appears at the inputs of exclusive-or gates ICs 34 and 35. The common input to these gates is held low by a signal from IC7, so data passes through the ex-ors without being inverted. Next, four bits are presented to multiplexer IC49. The select pin IC49Pl is held high by a signal from IC23, so data passes straight through the multiplexer. Eight bits of data now are presented to the latch IC50. The gate of the latch, IC50Pl1, is held high by IC20P8 as long as the ROM is enabled, so data passes through the latch. The three-state output drivers of the latch are enabled during PDBIN by a low at IC19P6. Case 2. Input/Output references in the range 00-09H: When the TMS5501 IC12 is addressed, the 4FDC emulates an 8080 I/O cycle (M3). This is necessary to generate strobed status bits and to insure the correct read/write timing. The cycle begins when IC23P5 goes low presenting a high to the JK inputs of the first section of IC3. This section of IC3 is clocked by the falling edge of internal 02 and shifts a high level to IC3P2. This high level generates an internal SYNC The internal SYNC pulse enables status pulse at IC17P13. strobe drivers IC43P8 and IC43P11 (Write Output and Interrupt Acknowledge respectively), disables the incoming bus drivers on IC33 and triggers the SYNC pin of the TMS5501. SYNC is terminated by the rising edge of 02 which clocks the next section of IC3 and presents a high level at IC3P12. this period, the TMS5501 internally arranges data paths while the 4FDC idles. When 02 falls again, IC20P6 goes low which opens the gate of the output latch IC50 admitting the data present at the inputs of IC30. This data has come from the TMS5501 via exclusive-or gates IC34 and IC35 and multiplexer IC49. The exclusive-ors have a common input held low by an output from IC7, so they pass the data through without Multiplixer IC49 passes the data straight through inversion. except when the 4FDC is in the process of reading the serial status port (Input port 00). In this case, IC23P5 goes low causing the multiplexer to switch D7 and D6 with D4 and D3 (producing the status bit assignment detailed in Chapter 3). The cycle finally terminates when 02 rises again shifting a high level to IC3P16. Case 3, Input/Output references to ports 30-34H: When IC7P12 goes low signifying disk reference operations, the common pins of exclusive-or gates ICs 34, 35, 47, and 48 go high. This causes the internal data bus of the 4FDC to be complemented with respect to the S-100 bus, as required by the FD1771-1. During output cycles, data from the processor is latched into IC33 by PWR/. During input cycles, latch IC50 is read during PDBIN. Case 4, Output reference to port 40H: Although the data bus is not examined by the 4FDC during bank select, the data on the S-100 DO bus is latched into IC33 anyway. ### Wait State Generator The wait state generator, IC42P11, passes on wait requests when enabled by IC18. There are four enabling conditions: 1) 4MHz Inputs from ports 30-33H, 2) 4MHz M1 fetches from the ROM at COOO-C3FFH, 3) Disk references with Auto Wait mode selected, and 4) Any reference to the TMS5501 (ports 00-09). There are three sources of wait request: 1) PSYNC, 2) Ready from wait IC25P8, and 3) Ready from TMS5501 (IC25P12). The coincidence of an enabling condition and a wait request stops the processor in mid cycle. # Clocks The 4FDC has an 8.000 MHz on board crystal clock which controls all internal board timing. IC2 conditions the clock for the TMS5501 and FD1771. 2MHz 01 and 02 signals are generated at IC4P3 and IC1P10 respectively. A 1MHz timing signal is generated at IC2P15 and a switchable 2 or 1MHz clock is generated at IC2P16 (controlled by the maxi/mini signal at IC4P13). ## Bank Select The 1K ROM on board the 4FDC may be disabled through output port 40H if switch 2 (RES) is on. In this case, the ROM is deselected permanently after the first output to port 40H clocks flip-flop IC29P11 and forces IC29P9 low. This forces the memory address decoder IC30P9 high, deselecting the ROM. The ROM may be re-enabled by a hardware RESET signal which sets IC29P9 high again. TMS5501 Interfaces IC12 requires 12 volt clock levels at the 01 and 02 inputs. These are supplied by active pullups Q1 and Q2 which when triggered by a falling edge at the input of open collector inverter package IC25 switch on briefly to pull the inverter outputs up to 12 volts. The serial output IC12P40 is inverted and shifted from TTL levels to +12 and -5 levels by Q3 and Q4. IC25P2 provides an open collector current sink for current loops. The serial input IC12P5 is controlled by discrete NAND gate made up of Q5 and Q6 which shifts and inverts -5/+12 levels to +5/0 volt levels. The parallel inputs and outputs are buffered by octal bus buffers ICs 13 and 14. ### FD1771-1 Interfaces All signals from the drives are TTL buffered and have 150 ohm pullups. Maxi and mini signals are wired and at the pullup side of the buffers. Signals which do not apply to the mini (i.e., READY and SEP CLOCK), are disabled and pulled high when the mini is selected. Signals to the drives from the 1771 are TTL buffered with separate buffers for mini and maxi connectors. The STEP output is stretched by IC37 to about 16 microseconds before going to the drives. The HLD (head load) output does not go directly to the drives but rather enables the drive select lines through IC10P1. Thus, the actual drive select signal to the drive is the coincidence of a latched drive selection (done at port 34H) and HLD from the 1771. Head loading time is determined by counters IC36 and 27. Timeout is controlled by the count loaded into IC38 by IC53. Signals DRQ, HLD, and INTRQ (or EOJ) are available at input port 34H (IC9). Various control signals are assigned to output port 34H and are latched by ICs 24 and 41. ### Priority Chain The 4FDC includes a ripple priority circuit which will defeat the interrupt acknowledge cycle of Priority IN/ is held low. If the 4FDC is allowed to perform the interrupt acknowledge, it will pull down its Priority Out/ line to signal others in the chain not to respond. This chain is compatible with the Cromemco TU-ART. ### CHAPTER 8: PARTS LIST ### 4FDC Revision B ### PARTS LIST | | | • | | | | | |----------------------|-----------------------|---------------------------------------------|-----|-------------------------------------------|--------------------------------|-------| | IC<br>IC<br>IC<br>IC | 1<br>2<br>3<br>4<br>5 | 74LS04<br>74276<br>74276<br>74LS00<br>74367 | | IC 49<br>IC 50<br>IC 51<br>IC 52<br>IC 53 | 74LS373<br>L 74LS32<br>2 74L04 | | | IC<br>IC<br>IC | 6<br>7<br>8 | 74368<br>74LS138<br>74LS00 | | Transistors | | | | IC | 9 | 74368 | | Ql | 2N3906 | | | IC | 10 | 74368 | · | Q2 | 2N3906 | | | IC | 11 | FD 1771-1 | | Q3 | 2N3906 | | | IC | 12 | TMS 5501 | | Q4 | 2N3904 | | | TC | | 74LS241 | | Q5 | 2N3904 | | | IC | 14 | 74LS240 | | Q6 | 2N3904 | | | IC | 15 | 7905/LM320-5 | • | | • | | | IC | | 74LS04 | | Diad | | | | IC | 17<br>18 | 74LS02<br>74S64 | | Diodes Dl | LED, TIL-211 | Green | | ĬĊ | 19 | 7425 | | D2 | 1N914 | Green | | IC | 20 | 74LS10 | | D3 | 1N914 | | | IC | 21 | 74LS04 | | | | | | ΙC | 22 | 74S260 | | | | | | IC | 23 | 74903 | | Resistors | • | | | IC | 24 | 74LS174 | | <b>.</b> | 7.14 1 | | | IC<br>IC | 25<br>26 | 7406<br>74LS04 | | | 1K ¼ w | • | | IC | 27 | CD4020AE | | R 2 -<br>R 3 | 1K ¼ w<br>150 ¼ w | | | IC | 28 | 74LS08 | *** | · R 4 | 10K ¼ w | | | | 29 | 74LS74 | | R 5 | | •• | | IC | 30 | 74S133 | | R 6 | | | | | 31 | 2708 | | R 7 | 680 ¼ w | | | IC | 32 | 74LS04 | | R 8 | 1K ¼ w | | | IC | 33 | 745373 | | R 9 | | • | | IC | 34<br>35 | 74LS86<br>74LS86 | | R10 | 270 ¼ w | | | IC | 36 | 7420 | | R <b>11</b><br>R12 | 470 ¼ w<br>4.7K ¼ w | | | IC | 37 | 74164 | | R13 | 10K % w | | | | 38 | 74161 | | R14 | 10K ¼ w | | | | 39 | 7812/LM340-12 | | R15 | 5.6K ¼ w | | | | 40 | 7805/LM340-5 | • | R16 | 4.7K 4 w | | | | 41 | 74LS74 | | R17 | 5.6K ¼ w | | | IC | 42<br>43 | 74367<br>74LS03 | | R18 | 390 ¼ W | | | IC | 43<br>44 | 74L04 | | R19 | 180 ¼ ₩ | | | IC | 45 | 74367 | | R20<br>R21 | 4.7K ¼ w<br>330 ¼ w | | | | 46 | 74367 | | R22 | 5.6K ¼ w | | | IC | 47 | 74LS86 | | R23 | 330 ¼ w | | | IC | 48 | 74LS86 | | R24 | 39 ¼ W | | | | | | - | | | | | | | | • | . 45 | |-------------------|------------|-----------------------|--------------|---------------------------| | Resistors (con't) | | | Capacitors ( | con't) | | | | | ^ | | | | R25 | 39 ¼ w | C43 | .l uF ceramic disc | | | R26 | 330 ¼ ₩ | C#4 | .l uF ceramic disc | | | R27 | 5.6K ¼ w | C45 | .l uf ceramic disc | | | | | C46 | .l uF ceramic disc | | | | | C47 | .l uF ceramîc disc | | Resistor | Networ | ks | C48 | .1 uF ceramic disc | | | D113 | OTB OB: SB : | | | | | RN1 | SIP, 8Pin, 7Resistors | | | | | | 150 ohm | Miscellaneou | is : | | | RN2 | SIP, 8Pin, 7Resistors | | | | | | 1K ohm | | | | | | | | , | | | | | J2 | Connector, 50Pin, Circuit | | Capacito | rs | | | Assembly, CA-D50RSP100- | | | | • | | 230-090 | | | C 1 | 30 pF ceramic disc | Ј3 | Connector, 34Pin, Circuit | | | C 2 | 10 uF tantalum | | Assembly, CA-D34RSP100- | | | C 3 | .1 uF ceramic disc | | 230-090 | | | | .l uF ceramic disc | <b>J</b> 4 | Connector, 26Pin, Circuit | | | C 4<br>C 5 | .1 uF ceramic disc | 0 1 | Assembly, CA-D26RSP100- | | | C 6 | .1 uF ceramic disc | | 230-090 | | | C 7 | | 0 | | | | | 10 uF tantalum | 2 | 4-40 Screws and Hex Nuts | | | C 8 | 10 uF tantalum | 1 | Heat Sink | | | C 9 | l uF ceramic disc | _ | | | | C10 | .1 uF ceramic disc | 1 | 8 MHz Crystal | | | C11 | .l uF ceramic disc | 1 | 4 Pole Dipswitch | | | C12 | .l uF ceramic disc | 5 | 6-32x3/8 pan head screws | | • | C13 | .l uF ceramic disc | 5 | 6-32 small pattern hex n | | | Cl4 | .l uF ceramic disc | 1 | PC Board | | | C15 | .l uF ceramic disc | 1 | Serial I/O Cable Assembly | | | C16 | .05 uF ceramîc disc | | \$ | | | C17 | .l uF ceramic disc | Sockets | | | | C18 | .l uF ceramic disc | 0.0 | · · | | | C19 | .1 uF ceramic disc | 26 | 14 pin | | | C20 | .l uf ceramic disc | 15 | 16 pin | | | C21 | .05 uF ceramic disc | 6 | 20 pin | | | C22 | .l uF ceramic disc | 1 | 24 pin | | | C23 | 75 pF ceramic disc | 2 | 40 pin | | | C24 | 75 pF ceramic disc | • | | | | C25 | .l uF ceramic disc | | | | | C26 | .1 uF ceramic disc | | | | | C27 | .1 uF ceramic disc | | | | | C28 | .1 uF ceramic disc | | | | | | | | | | | C29 | .l uF ceramic disc | | • | | | C30 | .l uF ceramic disc | | | | | C31 | .05 uF ceramic disc | | | | | C32 | .1 uF ceramic disc | | | | | C33 | .l uf ceramic disc | | | | | C34 | .1 uf ceramic disc | | • | | | C35 | .l uF ceramic disc | | | | | C36 | 10 uF tantalum | ** | | | | C37 | 10 uF tantalum | | · · | | | C38 | 10 uF tantalum | • | | | | C39 | .l uF ceramic disc | | | | | C40 | .l uF ceramic disc | | | | | C41 | .l uF ceramic disc | | | | | C42 | .1 uF ceramic disc | | | | | ÷ • • | | | | ### CHAPTER 9: WARRANTY Your factory-built 4FDC disk controller card is warranted against defects in materials and workmanship for a period of 90 days from the date of delivery. We will repair or replace products that prove to be defective during the warranty period provided that they are returned to Cromemco. No other warranty is expressed or implied. We are not liable for consequential damages. Your assembled 4FDC kit or your factory-built 4FDC after the warranty period will be repaired, provided that it is returned to Cromemco, for a set service fee. We reserve the right to refuse to repair any kit that was not assembled in a workmanlike manner or any product that in our opinion has been subject to abnormal electrical or mechanical abuse. Payment of the service fee must accompany the returned merchandise. The service fee is currently \$70 and is subject to change.