1984 Storage Management Products Handbook

ii

.

### Making The Leading Edge Work For You.

This handbook is designed for you, the engineer. It's intended to be a useful tool, enabling you to make a preliminary evaluation of our products and later, with samples in hand, design our products into your own systems.

The data in these pages have been reviewed by our Marketing, Engineering, Manufacturing, and Quality groups. Now we would like you to review the information we've provided and tell us how we can improve it. Please feel free to suggest any changes, additions, or clarifications that occur to you. And don't hesitate to call to our attention any sins of omission or commission we may have made.

We're eager to help upgrade the quality of information our industry provides to its customers. So, please, help us. Direct your comments to:

Marketing Communications Manager WESTERN DIGITAL CORPORATION 2445 McCabe Way Irvine, CA 92714 (714) 863-0102

# WESTERN DIGITAL

**Regional and District Sales Offices** 

#### Northeastern United States/Eastern Canada

70 Atlantic Avenue Marblehead, MA 01945 (617) 631-6466

72 Sumit Avenue Montvale, NJ 07645

#### North Central United States

3600 West 80th Street Suite 620 Bloomington, MN 55431 (312) 655-8781 (Temporary)

1301 West 22nd Street Suite 217 Oak Brook, IL 60521 (312) 655-8781

#### Southern United States

1015 Semoran Blvd. Summit Plaza II, Suite D Casselberry, FL 32707 (305) 331-4434

4950 Westgrove Dr., Suite 115 Dallas, TX 75248 (214) 248-6785

Wrightsville Blvd. #209 2300 W. Meadowview Road Greensboro, NC 27407 (919) 299-6733

4931 SW 201st Street Fort Lauderdale, FL 33332 (305) 421-1355

#### Western United States/Western Canada

1151 Dove Street Suite 170 Newport Beach, CA 92660 (714) 851-1221

5677 Oberlin Drive San Diego, CA 92121 (619) 457-1777

201 San Antonio Circle Building E, Suite 172 Mountain View, CA 94040 (415) 941-0216

#### Europe

28/30 Upper High Street Epsom, Surrey KT17 #4QJ United Kingdom 44-3727-42178



2445 McCABE WAY IRVINE, CALIFORNIA 92714

(714) 863-0102, TWX 910-595-1139

### **Table of Contents**

| Functional Indexv                                    | /ii |
|------------------------------------------------------|-----|
| Numerical Indexi                                     | x   |
| System Product Quality/Reliability                   | 1   |
| Quality/Reliability to Leading Edge Technology       | 5   |
| Announcing Burn-In Program Availability/Warranties 1 | 1   |
| Hi-Rel "K" Testing Program                           |     |
| Floppy Disk Controller Devices                       | 5   |
| Floppy Disk Support Devices                          | 7   |
| Winchester Disk Controller Devices                   | 5   |
| Winchester Disk Support Devices                      | 7   |
| Winchester Board Products                            | 3   |
| Main Memory Devices                                  |     |
| Ordering Information                                 | 1   |
| Package Diagrams                                     | 2   |
| Pin Compatibility Chart                              |     |
| Terms and Conditions                                 |     |
|                                                      |     |

Advance Information: This product has not been produced in volume and is subject to functional and timing revisions. Prior to designing with the product, it is necessary to contact Western Digital Corporation for current information.

**Preliminary:** This product is in limited production and may be subject to change after device characterization has been completed. Prior to designing with the product, it is necessary to contact Western Digital Corporation for current information.

Data sheets without one of the above headings are in full production and intended for normal commercial applications. For military, extended temperature, burn-in, or hi-rel applications, contact Western Digital Corporation for information regarding further processing.

## **Functional Index**

#### STORAGE MANAGEMENT PRODUCTS

#### Page

#### FLOPPY DISK CONTROLLER DEVICES

| WD1771-01<br>WD1771-01 | Floppy Disk Formatter/Controller        | 15<br>35 |
|------------------------|-----------------------------------------|----------|
| WD1770/1772            | 5-1/4" Floppy Disk Controller/Formatter | 43       |
| WD1773                 | 5-1/4" Floppy Disk Controller/Formatter | 67       |
| WD1770/72/73           | Application Notes                       | 71       |
| FD179X-02              | Floppy Disk Formatter/Controller Family | 73       |
| FD179X                 | Application Notes                       | 95       |
| WD279X-02              | Floppy Disk Formatter/Controller Family | 111      |
| WD279X                 | Application Notes                       | 133      |

#### FLOPPY DISK SUPPORT DEVICES

| WD1691       | Floppy Support Logic                |     |
|--------------|-------------------------------------|-----|
| DM1883A/B    | Direct Memory Access Controller 145 | i - |
| WD2143-03    | Four Phase Clock Generator 157      |     |
| WD9216-00/01 | Floppy Disk Data Separator 161      |     |

#### WINCHESTER DISK CONTROLLER DEVICES

| WD1100        | Series Winchester Controller Chips | 165 |
|---------------|------------------------------------|-----|
| WD1100-01     | Serial/Parallel Converter          | 167 |
| WD1100-02     | MFM Generator                      |     |
| WD1100-12     | Improved MFM Generator             | 177 |
| WD1100-03     | AM Detector                        | 183 |
| WD1100-04     | CRC Generator/Checker              | 187 |
| WD1100-05     | Parallel/Serial Converter          |     |
| WD1100-06     | ECC/CRC Logic                      |     |
| WD1100-07     | Host Interface Logic               | 201 |
| WD1100-09     | Data Separator Support Logic       | 205 |
| WD1010-00, 01 | Winchester Disk Controllers        | 209 |
| WD1010-05, 08 | Winchester Disk Controllers        |     |
| WD1010        | Application Notes                  | 257 |
| WD2010        | Winchester Disk Controller         |     |
| WD1050        | SMD Controller/Formatter           | 267 |

#### WINCHESTER DISK SUPPORT DEVICES

| Winchester Data Separator Device          | 297                              |
|-------------------------------------------|----------------------------------|
| Write Precompensation Device              | 299                              |
| Error Detection/Support Logic Device      | 301                              |
| Buffer Manager Control Processor          | 309                              |
| Write Precomp/Data Separator Support Chip | 313                              |
| Buffer Manager Support Chip               | 317                              |
| ECC Logic Device                          | 319                              |
| Programmable Polynomial Generator         | 321                              |
|                                           | Winchester Data Separator Device |

#### WINCHESTER BOARD PRODUCTS

| WD1000-05<br>WD1001-05/55/85<br>WD1002-05<br>WD1002-SHD<br>WD1002-MTB<br>WD1055-SCS<br>WD1055-MTB | Winchester Disk Controller         Winchester Disk Controller         Winchester/Floppy Disk Controller         Winchester Disk Controller         Winchester/Floppy Disk Controller         Winchester/Floppy Disk Controller         SMD Controller Board         Multibus SMD Disk Drive Controller Board | 343<br>353<br>361<br>379<br>399 |
|---------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------|
|                                                                                                   | ICES                                                                                                                                                                                                                                                                                                         |                                 |
| WD8206<br>WD8207<br>WD99650                                                                       | Error Detection and Correction Unit                                                                                                                                                                                                                                                                          | 423                             |

## **Numerical Index**

#### Part Number

#### Page

|                 | -   |
|-----------------|-----|
| WD1000-05       | 323 |
| WD1001-05/55/85 | 343 |
| WD1002-05       | 353 |
| WD1002-SHD      | 361 |
| WD1002-MTB      | 379 |
| WD1010-00, 01   | 209 |
| WD1010-05, 08   | 233 |
| WD1011          | 297 |
| WD1012          | 299 |
| WD1014          | 301 |
| WD1015-00       | 309 |
| WD1050          | 267 |
| WD1055-SCS      | 399 |
| WD1055-MTB      | 401 |
| WD1100          | 165 |
| WD1100-01       | 167 |
| WD1100-02       | 171 |
| WD1100-03       | 183 |
| WD1100-04       | 187 |
| WD1100-05       | 191 |
| WD1100-06       | 195 |
| WD1100-07       | 201 |
| WD1100-09       | 205 |
|                 | 313 |
|                 | 317 |
| WD1100-12       | 177 |
|                 | 319 |
|                 | 321 |
|                 | 137 |
| WD1770/72       | 43  |
| WD1771          | 15  |
| WD1773          | 67  |
| FD179X-02       | 73  |
|                 | 145 |
|                 | 263 |
|                 | 157 |
|                 | 111 |
|                 | 403 |
|                 | 423 |
|                 | 161 |
| WD99650         | 463 |
|                 |     |

х

#### Western digital 0 1 R Ρ Т

0

## System Product Quality/Reliability

#### QUALITY PROGRAM DESCRIPTION

The Quality Organization shown on the attached organization chart (Figure 2) reports directly to the President of Western Digital. It assures compliance to design control, quality and reliability specifications pursuant to corporate policy. Quality assurance provisions are derived in part from MIL-Q-9858, as applied to high grade commercial products.

#### CORPORATE QUALITY POLICY

It is the policy of Western Digital Corporation that every employee be committed to quality excellence in producing products/processes which conform to acceptable requirements. The total quality program is managed and monitored by the quality assurance organization. Quality assurance is chartered to review marketing product requirements, qualify hardware and software designs, certify manufacturing operations and monitor performance/control conformance to product specifications.

Primary responsibility for execution of the quality program rests with functional organizations to design, produce, and market high quality and high reliability products specified to our customers.

#### **DESIGNING FOR RELIABILITY**

0

The premise upon which board and system manufacturing operations are based is that quality is planned and designed-in, not screened-in or selected. A welltested, high-quality design is far more reliable than a marginal design with any amount of burn-in or fixes. To assure top quality design, Western Digital maintains one of the most experienced board/system design staffs in the industry. A tightly controlled design review team comprising members from Quality Assurance, Marketing, Manufacturing and several experienced design engineers, provides review of each new design several times during its development to ensure widest possible performance margins. The production release procedure assures a checklist for.

- Test Method/Program Qualifications
- Characterization Report
- Field Test (Beta Test) Report
- Product Qualification Audit
- C Documentation Package Release for Document Control
- Software/Diagnostics Qualification

#### MAINTAINING QUALITY/RELIABILITY IN PRODUCTION

The Quality Control Testing Flow Chart shown on Figure 1 defines the exact stages contained in the production process. Internally manufactured LSI components undergo 100% testing at maximum specified operating temperatures as well as strict quality controls defined to assure high quality and reliability. Components not designed and manufactured by Western Digital are also 100% screened as shown in photos during incoming inspection at 70°C. The tests performed include selective active component burn-in performed at 125°C for 160 hours to insure guaranteed levels of reliability. This 125°C accelerated testing eliminates defects that cannot effectively be accelerated by burning-in boards and systems which have temperature limitations. Key quality control procedures include:

- Incoming Inspection Procedure
- In-Process Travel Card Traceability
- Workmanship Standards
- Quality Corrective Action Notice/MRB Procedure
- Cuality Audit Procedure

#### PRODUCT FINAL TEST/CORRECTIVE ACTION

All boards are 100% in-circuit tested and 100% functional tested for acceptable performance according to applicable test specifications on testers qualified by QA. Products are tested at maximum specified temperature and voltage margins using diagnostic software to ensure greater performance margins. Failures are logged on a travel card specifically designed to insure traceability to manufacturing steps and to maintain failure records for QA corrective action.

If the board is designed to perform in a host system, further diagnostics are performed in an environment configured to actual customer requirements.

#### PRODUCT ACCEPTANCE

Upon completing the final test, the board/system undergoes QC final workmanship standards inspection and selective samples are audited to the functional product specification to guarantee quality at specified operating margins to the customer.



Bare board test



Incoming IC 100% screening



In-circuit test



#### Figure 1. QUALITY CONTROL TESTING FLOW CHART





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

# WESTERN DIGITAL

## Quality/Reliability To Leading Edge Technology

#### QUALITY PROGRAM DESCRIPTION

The Quality Organization shown in Figure 2 assures compliance to design control, quality and reliability specifications, pursuant to corporate policy.

#### CORPORATE QUALITY POLICY

It is the policy of Western Digital Corporation that every employee be committed to quality excellence in producing products/processes which conform to acceptable requirements. The total quality program is managed and monitored by the quality assurance organization. Quality assurance is chartered to review marketing product requirements, qualify hardware and software designs, certify manufacturing operations and monitor performance/control conformance to product specifications.

Primary responsibility for execution for the quality program rests with functional organizations to design, produce and market high quality and high reliability products specified to our customers.

#### LSI QUALITY ASSURANCE PROGRAM HIGHLIGHTS

- LSI manufacturing assurance provisions are derived in part from MIL-M-38510 and MIL-STD-883B as applied to high grade commercial components.
- All process raw materials used in the Mask/Wafer fabrication and assembly operations are monitored by Material Assurance.
- Material Assurance maintains a thorough control of incoming material and has developed unique "use/stress tests" (look ahead sample build acceptance) which critical material must pass before acceptance.
- The Product Assurance Department continuously monitors the internal and external manufacturing flow (shown in Figure 1) and issues process control reports displaying detailed data and trends for the associated areas.
  - Document control is an integral part of Product Assurance. All specifications are issued and controlled by this activity.
  - The Western Digital Malaysian assembly operation uses specifications and quality control provisions controlled by Document Control. Indicators of Malaysia quality are reviewed weekly.

- Purchased FAB and assembly operations are individually qualified and are certified against standard specifications during vendor qualification and monitored against reliability criteria.
- Defect control within the process assures the highest levels of built-in reliability.
- Quality audits and gates are located throughout the manufacturing process in order to assure a stable process and thus, a quality product to our customers. Figure 1 illustrates the manufacturing/ screening/inspection flow diagram and identifies the steps as they relate to the production of LSI devices.
- Testing assures quality margins through 100% testing by manufacturing and, in addition, all products must pass a specified AQL sample test performed by QA at maximum operating temperature as follows:

#### **Outgoing Quality Levels**

| SUBGROUPS INSPECTIO                                                       | ON LEVEL |
|---------------------------------------------------------------------------|----------|
| Subgroup 1 — Final 100% Electrical<br>Audit @ Max °C                      | 0.5 AQL* |
| Subgroup 2 — Visual (Marking, Lead<br>Integrity, Package, Verify customer |          |
| shipper)                                                                  | 1.0 AQL  |
| Subgroup 3 — Shipping Visual Audit                                        | 1.0 AQL  |

\*The double sampling techniques used allow considerably better AQL's in most all cases.

 LSI devices are 100% tested on industry standard test systems like that shown below. Quality outgoing testing (auditing) is done on the Fairchild Sentry Series 20 where possible to allow better correlation with customers.





### **Reliability Means Lasting Value**

#### DESIGNING FOR RELIABILITY

The production release procedure for an LSI device is designed to assure maximum reliability with a Quality checklist for:

- Test program qualifications
- Characterization report
- Field test (Beta Test) report
- Reliability Lifetest Qualifications
- Infrared Thermal Analysis
- Static Protection

All new devices and major process changes must pass reliability qualification before incorporation into production using the criteria defined in Tables 2-4. The infrared microscope shown on the right assures optimum burn-in temperatures and margins of safety. The dynamic burn-in system shown on the right is one of two custom designed systems which assure protective device isolation during burn-in.

#### • MAINTAINING RELIABILITY IN PRODUCTION

Process defects control are defined to continually measure built-in reliability, as measured by the following criteria:



TABLE 1

| PROCESS RELIABILITY CONTROL            | METHOD                                               | CONDITION                                             | SAMPLE*                                             |
|----------------------------------------|------------------------------------------------------|-------------------------------------------------------|-----------------------------------------------------|
| Subgroup 1 — Defects Control           |                                                      |                                                       |                                                     |
| a. Oxide Integrity                     | Non-destructive<br>bubble test                       | Pinhole defect density                                | 5 wafers                                            |
| b. Polysilicon Integrity               | SEM Analysis                                         | Visual                                                | 5 wafers                                            |
| Subgroup 2 — Electro-Migration Control |                                                      |                                                       |                                                     |
| Metal Step Coverage                    | MIL-STD-883<br>Method 2018                           | SEM Analysis                                          | 5 wafers                                            |
| Subgroup 3 — Defect Density            | Critical layers<br>Field<br>Gate<br>Contact<br>Metal | Visual of Photo defects<br>(Defects/in <sup>2</sup> ) | 8 wafers<br>each layer                              |
| Subgroup 4 — Passivation/Insulation    |                                                      |                                                       |                                                     |
| Integrity                              | MIL-STD-883 Method<br>2021                           | Visual of Pinhole<br>defect density                   | Final Silox<br>5 wafers<br>Intermediate<br>5 wafers |

\*Inspection intervals are defined by the in-line process control data reviewed on a lot-by-lot basis.

#### PROGRAMS TO ASSURE OPTIMUM RELIABILITY

Improved levels of reliability are available under custom reliability programs using static and dynamic burn-in to further improve reliability. These programs focus on MOS failure mechanisms as follows:

| FAILURE<br>MECHANISM | EFFECT ON<br>DEVICE | ESTIMATED<br>ACTIVATION ENERGY | SCREENING<br>METHOD                 |
|----------------------|---------------------|--------------------------------|-------------------------------------|
| Slow Trapping        | Wearout             | 1.0 eV                         | Static Burn-In                      |
| Contamination        | Wearout/<br>Infant  | 1.4 eV                         | Static Burn-In                      |
| Surface Charge       | Wearout             | 0.5-1.0 eV                     | Static Burn-In                      |
| Polarization         | Wearout             | 1.0 eV                         | Static Burn-In                      |
| Electromigration     | Wearout             | 1.0 eV                         | Dynamic Burn-In                     |
| Microcracks          | Random              | _                              | 100% Temp. Cycling                  |
| Contacts             | Wearout/<br>Infant  | <u> </u>                       | Dynamic Burn-In                     |
| Oxide Defects        | Infant/<br>Random   | 0.3 eV                         | Dynamic Burn-In<br>at max. voltage  |
| Electron Injection   | Wearout             |                                | Low Temp. Voltage<br>Operating Life |

#### FAILURE MECHANISMS IN MOS

#### Temperature Acceleration of Failure

The Arrhenius Plot defines a failure rate proportional to exp(-Ea/kt) where Ea is the activation energy for the failure mechanism. The figure on the right indicates that lower activation energy failures are **not** effectively accelerated by temperature alone; hense, maximum voltage operation is selectively applied to optimize the burn-in process.

#### Static Burn-In (125°C - 48 hours or 160 hours)

Provided on a sample basis for process monitor/control of 0.5 eV — 1.0 eV failure mechanisms. 100% static burn-in may be specified at an additional cost. However, static burn-in is considered only partially effective for internal LSI gates at logic "O" levels.

## Dynamic Burn-In (Pattern test/125°C — 8 hours to 160 hours)

Accelerated functional dynamic operating life effectively controls internal MOS gate defects buried from external pin access. The input pattern is optionally pseudo-random or fixed pattern programmable to simulate 1000-3000 hours of field operation at maximum operating voltage(s).

#### High-Rel "K" Testing Program

General conformance to MIL-STD-883B method 5004.4, Class B with static Burn-In (Dynamic Burn-In may be specified as an option).



#### LSI RELIABILITY STANDARDS

#### TABLE 2 STANDARD RELIABILITY LEVELS

|    | TEST                         | METHOD               | CONDITION         | FAILURE                                     |
|----|------------------------------|----------------------|-------------------|---------------------------------------------|
| Mo | fant<br>ortality<br>ee note) | Static<br>Burn-In    | 125°C — 160 hrs.  | <0.5%                                       |
|    | ong Term<br>illure Rate      | Dynamic<br>Life Test | 125°C — 1000 hrs. | <.05%/1000 hrs.<br>@ 55°C<br>60% Confidence |

\*NOTE: Devices failing the infant mortality target remain on burn-in until acceptable failure rates are obtained.

#### TABLE 3 GROUP A DEVICE RELIABILITY MONITORS

| TEST                               | METHOD | CONDITIONS                                                      | LTPD |
|------------------------------------|--------|-----------------------------------------------------------------|------|
| Subgroup 1                         |        |                                                                 |      |
| a. Internal Visual                 |        |                                                                 | 15   |
| b. Thermal Shock                   | 1011   | Test Failure Used (cond. B or C)                                |      |
| c. Bond Strength                   | 2011   | Test Failures (cond. B)                                         |      |
| d. Die Shear Strength              | 2019   | Test Failures                                                   |      |
| Subgroup 2                         |        |                                                                 |      |
| a. Seal — Gross Leak               |        | Fluorocarbon detection 10 - 3<br>atm/cc/sec                     | 15   |
| b. Seal — Fine Leak                | 1014   | Test Condition A                                                |      |
| Subgroup 3                         |        |                                                                 |      |
| a. Rotating Steady State Life Test | 1005   | Static 160 hr. Burn-In 125°C<br>plus 125°C Lifetest — 1000 hrs. | 5    |
| b. Electrical Parameters           | -      | Final electrical @ 25°C (with data @ 70°C)                      |      |

#### TABLE 4 GROUP B PACKAGE RELIABILITY MONITORS

| TEST                                                                | METHOD | CONDITIONS                                | LTPD |
|---------------------------------------------------------------------|--------|-------------------------------------------|------|
| Subgroup 1                                                          |        |                                           |      |
| a. Thermal Shock                                                    | 1011   | Test Condition B or C                     | 15   |
| b. Temperature Cycling                                              | 1010   | Test Condition B or C                     |      |
| c. Seal — Gross Leak                                                | -      | Fluorocarbon detection 10-3<br>atm/cc/sec |      |
| d. Seal — Fine Leak (ceramic)                                       | 1014   | Test Condition A                          |      |
| e. Electrical Parameters                                            |        | Electrical at max -C                      |      |
| <ul> <li>f. 85/85 Moisture Resistance<br/>(plastic only)</li> </ul> | _      | 85% RH/85°C for 1000 hours<br>PDA = 10%   |      |
| g. Electrical Parameters                                            | _      | Final electrical @ 25°C                   |      |
| Subgroup 2                                                          |        |                                           |      |
| a. High Temp. Storage                                               | 1008   | Test Condition B or C                     |      |
| b. Mechanical Shock                                                 | 2002   | Test Condition B                          | 15   |
| c. Seal — Gross Leak                                                | -      | Fluorocarbon detection 10-3<br>atm/cc/sec |      |
| d. Seal — Fine Leak<br>(ceramic)                                    | 1014   | Test Condition A                          |      |
| e. Electrical Parameters                                            | —      | Final electrical @ 25°C/max. C            |      |
| Subgroup 3                                                          |        |                                           |      |
| a. Lead Integrity                                                   | 2004   | Test Condition B2<br>(Lead Fatigue)       | 15   |
| b. Seal — Gross Leak                                                |        | Fluorocarbon detection 10-3<br>atm/cc/sec |      |
| c. Seal — Fine Leak<br>(ceramic)                                    | 1014   | Test Condition A                          |      |



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

## WESTERN DIGITAL

CORPORATION

## Announcing Burn-In Program Availability/Warranties

Western Digital now supports customer burn-in requirements for both static and dynamic burn-in under the strict control of the QA-Reliability organization.

This burn-in provides high performance 125°C static and dynamic burn-in for 8-160 hours to eliminate infant mortality and improve reliability. This process is executed using custom modified 32Bit AEHR test commercial burn-in equipment which provide monitored fixed pattern or pseudorandom burn-in with power supply and resistor device pin isolation.

LSI dynamic burn-in is verified in all cases by the design engineer for proper functioning. LSI Chip sets are also individually burned-in with dynamic equivalency to assure high performance bundled reliability.

The warranty on the program will optionally provide certificate of compliance to standard or custom designed burn-in programs and guarantee <.05%/Khrs failure rate.

#### CAUTION

Using outside burn-in methods not certified as acceptable by Western Digital may result in voided warranty, due to mishandling, junction temperature stress, or electrical damage. Further, since most burn-in houses do not support testing, catastrophic system condition can result in substantial damage before a problem is identified.

One consistent problem experienced with outside LSI burn-in houses can cause reliability problems; namely, parallelling totem pole MOS outputs, where the output states are not predictable, can cause a single (or a few) device(s) to sink all the current from the other devices on the burn-in tray — electromigration or current zaps are both possible.

Western Digital burn-in diagrams, dated after 1/1/82, must be used exactly as shown and will be provided upon request.

SEE YOUR LOCAL REPRESENTATIVE FOR COSTS AND ORDERING INFORMATION ON THIS NEW PROGRAM.

.. ...

.....

# WESTERN DIGITAL

Hi-Rel "K" Testing Program

#### FEATURES

GENERAL CONFORMANCE TO MIL-STD-883B, METHOD 5004.4, CLASS B (SEE COMPARISON ON FOLLOWING PAGES)

 INCLUDES: PRECAP VISUALS SEAL INTEGRITY POWER CONDITIONING ENHANCEMENT OPTIONS

#### **GENERAL DESCRIPTION**

Western Digital's Hi-Rel "K" program is designed to provide high reliability devices for extended temperature environments. Individual enhancements may be specified to meet a customer's requirements.



## COMPARISON OF MIL-STD-883 AND HI-REL "K" TEST PROGRAM

| MIL-STD-883B, METHOD 5004.4, CLASS B                                                                                                                                                                                  | HI-REL "K" TEST                                                                                                                                                                        |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>3.1.1 Internal Visual</b><br>Method 2010.3<br>Test condition B                                                                                                                                                     | All Hi-Rel "K" devices receive 100% inspections<br>prior to lid seal. These inspections together com-<br>prise criteria comparable to Mil-Std-883, method<br>2010.3, test condition B. |
| <b>3.1.2 Stabilization Bake</b><br>Method 1008.1<br>Test condition C<br>24 hours at 150°C                                                                                                                             | Same                                                                                                                                                                                   |
| <b>3.1.3 Temperature Cycling</b><br>Method 1010.2, Test condition C<br>$-65^{\circ}$ C to 150°C for 10 cycles, with 10 minutes<br>dwell and 5 minutes maximum transfer time                                           | Same                                                                                                                                                                                   |
| 3.1.4 Constant Acceleration<br>Method 2001.2, Test condition E. 30,000 G stress<br>level                                                                                                                              | Not Done Unless Specified                                                                                                                                                              |
| 3.1.5 Visual Inspection<br>Visual inspection for catastrophic failures after<br>screens                                                                                                                               | Same                                                                                                                                                                                   |
| <ul> <li>3.1.6 Seal Method 1014.2</li> <li>(a) Helium fine leak — Test condition A<sub>1</sub>. Bomb condition 2 hours at 60 psig. Reject limit 5 x 10<sup>-8</sup> torr</li> </ul>                                   | Same                                                                                                                                                                                   |
| (b) Flourocarbon gross leak — Test condition C                                                                                                                                                                        | Same                                                                                                                                                                                   |
| <b>3.1.9 Interim (pre-burn-in) Electricals</b><br>Per applicable device specification                                                                                                                                 | Preburn-in test at 25°C. Must meet requirements of device data sheets.                                                                                                                 |
| 3.1.10 Burn-in Test<br>Method 1015.2 160 hours @ 125°C                                                                                                                                                                | Same                                                                                                                                                                                   |
| 3.1.13 Interim (Post burn-in) electricals<br>Per applicable device specification                                                                                                                                      | Burn-in equipment isolate failures automatically to<br>assure no harmful interaction.                                                                                                  |
| <ul> <li>3.1.15 Final Electrical Test <ul> <li>(a) Static Tests</li> <li>(1) 25°C</li> <li>(2) Minimum and Maximum Operating<br/>Temperatures</li> </ul> </li> <li>(b) Dynamic and Switching Tests at 25°C</li> </ul> | Same                                                                                                                                                                                   |
| (c) Functional Tests at 25°C                                                                                                                                                                                          |                                                                                                                                                                                        |
| 3.1.17 Qualification or Quality Conformance<br>Inspection and Test Sample Selection                                                                                                                                   | Not done unless defined using method 5005 as a guide.                                                                                                                                  |
| 3.1.18 External Visual<br>Method 2009.2                                                                                                                                                                               | Same                                                                                                                                                                                   |
| VESTERN DIGITAL RELIABILITY ENHANCEMENT<br>OPTIONS                                                                                                                                                                    |                                                                                                                                                                                        |
| 00% Temperature Testing                                                                                                                                                                                               | Extended High Temperature Storage                                                                                                                                                      |
| Level                                                                                                                                                                                                                 | + 150°C for 24 hours standard, other time/tempera ture storage requirements available as required.                                                                                     |
| Thermal, Shock (Liquid to Liquid)                                                                                                                                                                                     | Dynamic Bum-In                                                                                                                                                                         |

Dynamic Bum-In Per note previously supplied.

## WESTERN DIGITAL

CORPORATION

## FD1771-01 Floppy Disk Formatter/Controller

#### FEATURES

- SOFT SECTOR FORMAT COMPATIBILITY
- AUTOMATIC TRACK SEEK WITH VERIFICATION
- READ MODE
   Single/Multiple Sector Write with Automatic
   Sector 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
- PROGRAMMABLE CONTROLS Selectable Track-to-Track Stepping Time Selectable Head Settling and Head Engage Times

Selectable Three Phase or Step and Direction and Head Positioning Motor Controls

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

#### APPLICATIONS

FLOPPY DISK DRIVE INTERFACE

SINGLE OR MULTIPLE DRIVE CONTROLLER/FORMATTER

NEW MINI-FLOPPY CONTROLLER

#### **GENERAL DESCRIPTION**

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

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

The FD1771 is fabricated in N-channel Silicon Gate MOS technology and is TTL compatible on all inputs and outputs. The A and B suffixes are for ceramic and plastic packages, respectively.



FD1771 SYSTEM BLOCK DIAGRAM

#### PIN OUTS

| Pin No.        | Pin Name                       | Symbol                                                | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|----------------|--------------------------------|-------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1<br>19        | Power Supplies<br>MASTER RESET | V <sub>BB</sub> /NC<br>MR                             | -5V<br>A logic low on this input resets the device and loads<br>"03" into the command register. The Not Ready<br>(Status bit 7) is reset during MR ACTIVE. When MR<br>is brought to a logic high, a Restore Command is<br>executed, regardless of the state of the Ready signal<br>from the drive.                                                                                                                                                                                                                  |
| 20<br>21<br>40 |                                | V <sub>SS</sub><br>V <sub>CC</sub><br>V <sub>DD</sub> | Ground<br>+5V<br>+12V                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| Computer I     | nterface                       |                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 2              | WRITE ENABLE                   | WE                                                    | A logic low on this input gates data on the DAL into the selected register when $\overline{\text{CS}}$ is low.                                                                                                                                                                                                                                                                                                                                                                                                      |
| 3              | CHIP SELECT                    | CS                                                    | 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{CS}$ is low.                                                                                                                                                                                                                                                                                                                                                                                           |
| 5, 6           | REGISTER SELECT<br>LINES       | A <sub>0</sub> , A <sub>1</sub>                       | These inputs select the register to receive/transferdata on the DAL lines under RE and WE control:A1A0REWE000Status Register01Track RegisterTrack Register10Sector RegisterSector Register111Data RegisterData RegisterData Register                                                                                                                                                                                                                                                                                |
| 7-14           | DATA ACCESS LINES              | DAL0-DAL7                                             | Eight bit inverted bidirectional bus used for transfer<br>of data, control, and status. This bus is a receiver<br>enabled by WE or a transmitter enabled by RE.                                                                                                                                                                                                                                                                                                                                                     |
| 24             | CLOCK                          | CLK                                                   | This input requires a free-running 2 MHz ± 1% square wave clock for internal timing reference.                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 38<br>39       | DATA REQUEST                   | DRQ                                                   | This open drain output indicates that the DR con-<br>tains assembled data in Read operations, or the DR<br>is empty in Write operations. This signal is reset<br>when serviced by the computer through reading or<br>loading the DR in Read or Write operation, respec-<br>tively. Use 10K pull-up resistor to +5.<br>This open drain output is set at the completion or<br>termination of any operation and is reset when a<br>new command is loaded into the command register.<br>Use 10K pull-up resistor to +5. |
| Floppy Disl    | k Interface:                   |                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 15             | Phase 1/Step                   | PH1/STEP                                              | If the <u>3PM</u> input is a logic low the three-phase motor control is selected and PH1, PH2, and PH3 outputs                                                                                                                                                                                                                                                                                                                                                                                                      |
| 16             | Phase 2/Direction              | PH2/DIRC                                              | form a one active low signal out of three. PH1 is active<br>low after MR. If the 3PM input is a logic high the step                                                                                                                                                                                                                                                                                                                                                                                                 |
| 17             | Phase 3                        | РНЗ                                                   | and direction motor control is selected. The step<br>output contains a 4 usec high signal for each step                                                                                                                                                                                                                                                                                                                                                                                                             |
| 18             | 3-Phase Motor Select           | 3PM                                                   | and the direction output is active high when stepping<br>in; active low when stepping out.                                                                                                                                                                                                                                                                                                                                                                                                                          |

FD1771-01

| r       | Г                                          |         |                                                                                                                                                                                                                                                                                                                                                                        |
|---------|--------------------------------------------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Pin No. | Pin Name                                   | Symbol  | Function                                                                                                                                                                                                                                                                                                                                                               |
| 22      | TEST                                       | TEST    | This input is used for testing purposes only and should be tied to +5V or left open by the user.                                                                                                                                                                                                                                                                       |
| 23      | HEAD LOAD TIMING                           | HLT     | The HLT input is sampled after 10 ms. When a logic high is sampled on the HLT input the head is assumed to be engaged.                                                                                                                                                                                                                                                 |
| 25      | EXTERNAL DATA<br>SEPARATION                | XTDS    | A logic low on this input selects external data separation. A logic high or open selects the internal data separator.                                                                                                                                                                                                                                                  |
| 26      | FLOPPY DISK CLOCK<br>(External Separation) | FDCLOCK | This input receives the externally separated clock when $\overline{\text{XTDS}} = 0$ . If $\overline{\text{XTDS}} = 1$ , this input should be tied to a logic high.                                                                                                                                                                                                    |
| 27      | FLOPPY DISK DATA                           | FDDATA  | This input receives the raw read disk data if XTDS=1, or the externally separated data if XTDS=0.                                                                                                                                                                                                                                                                      |
| 28      | HEAD LOAD                                  | HLD     | The HLD output controls the loading of the Read-<br>Write head against the media.                                                                                                                                                                                                                                                                                      |
| 29      | Track Greater than 43                      | TG43    | This output informs the drive that the Read-Write head is positioned between tracks44-76. This output is valid only during Read and Write commands.                                                                                                                                                                                                                    |
| 30      | WRITE GATE                                 | WG      | This output is made valid when writing is to be per-<br>formed on the diskette.                                                                                                                                                                                                                                                                                        |
| 31      | WRITE DATA                                 | WD      | This output contains both clock and data bits of 500 ns duration.                                                                                                                                                                                                                                                                                                      |
| 32      | Ready                                      | READY   | This input indicates disk readiness and is sampled<br>for a logic high before Read or Write commands are<br>performed. If Ready is low, the Read or Write oper-<br>ation is not performed and an interrupt is generated.<br>A Seek operation is performed regardless of the state<br>of Ready. The Ready input appears in inverted format<br>as Status Register bit 7. |
| 33      | WRITE FAULT                                | WF      | This input detects wiring faults indications from the drive. When WG=1 and $\overline{WF}$ goes low, the current Write command is terminated and the Write Fault status bit is set. The $\overline{WF}$ input should be made inactive (high) when WG becomes inactive.                                                                                                 |
| 34      | TRACK 00                                   | TR00    | This input informs the FD1771 that the Read-Write head is positioned over Track 00 when a logic low.                                                                                                                                                                                                                                                                   |
| 35      | INDEX PULSE                                | ĪP      | Input, when low for a minimum of 10 usec, informs<br>the FD1771 when an index mark is encountered on<br>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      | DISK INITIALIZATION                        | DINT    | The iput is sampled whenever a Write Track com-<br>mand is received. If DINT=0, the operation is termin-<br>ated and the Write Protect status bit is set.                                                                                                                                                                                                              |

#### ORGANIZATION

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

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

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

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

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

loaded from or transferred to the DAL. This Register should not be loaded when this device is busy.

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

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

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

**CRC Logic:** This logic is used to check or to generate the 16-bit Cyclic Redundancy Check (CRC). The polynomial is:  $G(x) = x^{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.



FD1771 BLOCK DIAGRAM

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

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

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

#### **PROCESSOR INTERFACE**

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

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

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

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

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

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

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

#### FLOPPY DISK INTERFACE

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

#### **HEAD POSITIONING**

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

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

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

When a Seek, Step or Restore command is executed, an optional verification of Read-Write head position can be performed by setting bit 2 in the command word to a logic 1. The verification operation begins at the end of the 10 millisecond settling time after the head is loaded against the media. The track number from the first encountered ID Field is compared against the contents of the Track Register. If the track numbers compare and the ID Field Cyclic Redundancy Check (CRC) is correct, the verify operation is complete. If track comparison is not made but the CRC checks, an interrupt is generated, the Seek Error status (Bit 4) is set and the Busy status bit is reset.

| Γ  |        | 1771-X1<br>CLK = 2 MHz |              | 1771 or – X1<br>CLK = 2 MHz |                   |
|----|--------|------------------------|--------------|-----------------------------|-------------------|
| r1 | ro     | TEST = 1               | TEST = 1     | TEST = 0                    | TEST = 0          |
| 0  | 0      | 6ms<br>6ms             | 12ms<br>12ms | Approx.<br>400μs*           | Approx.<br>800µs* |
| 1  | 0<br>1 | 10ms<br>20ms           | 20ms<br>40ms |                             |                   |

#### Table 1. STEPPING RATES

\*For exact times consult WDC.

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

#### **DISK READ OPERATION**

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

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

The chip can also operate on externally separated

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

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

#### **DISK WRITE OPERATION**

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

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

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

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

#### **COMMAND DESCRIPTION**

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

#### **TYPE 1 COMMANDS**

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

The Type 1 Commands contain a head load flag (h) which determines if the head is to be loaded at the beginning of the command. If h=1, the head is loaded at the beginning of the command (HLD output is made active). If h=0, HLD is deactivated.

Table 2. COMMAND SUMMARY

|      |                 | BITS |   |   |   |    |    |    |    |
|------|-----------------|------|---|---|---|----|----|----|----|
| TYPE | COMMAND         | 7    | 6 | 5 | 4 | 3  | 2  | 1  | 0  |
| 1    | Restore         | 0    | 0 | 0 | 0 | h  | ٧  | r1 | ro |
| 1    | Seek            | 0    | 0 | 0 | 1 | h  | ۷  | ri | ro |
|      | Step            | 0    | 0 | 1 | u | h  | ۷  | ri | ro |
|      | Step In         | 0    | 1 | 0 | u | h  | ۷  | ri | ro |
|      | Step Out        | 0    | 1 | 1 | u | h  | ۷  | ri | ro |
|      | Read Command    | 1    | 0 | 0 | m | b  | Е  | Ó  | ŏ  |
|      | Write Command   | 1    | 0 | 1 | m | b  | Е  | aı | a0 |
|      | Read Address    | 1    | 1 | 0 | 0 | 0  | Е  | 0  | ŏ  |
|      | Read Track      | 1    | 1 | 1 | 0 | 0  | 1  | 0  | s  |
|      | Write Track     | 1    | 1 | 1 | 1 | 0  | 1  | 0  | 0  |
| IV   | Force Interrupt | 1    | 1 | 0 | 1 | lз | 12 | 11 | 14 |

Note: Bits shown in TRUE form.

#### Table 3. FLAG SUMMARY

| TYPEI                                                                 |
|-----------------------------------------------------------------------|
| h = Head Load flag (Bit 3)                                            |
| h = 1, Load head at beginning<br>h = 0, Do not load head at beginning |
| V = Verify flag (Bit 2)                                               |
| V = 1, Verify on last track<br>V = 0, No verify                       |
| r1r0 = Stepping motor rate (Bits 1-0)                                 |
| Refer to Table 1 for rate summary                                     |
| u = Update flag (Bit 4)                                               |
| u = 1, Update Track register<br>u = 0, No update                      |

#### Table 4. FLAG SUMMARY

| ΤΥΡΕΙΙ                                                                                                                         |
|--------------------------------------------------------------------------------------------------------------------------------|
| m = Multiple Record flag (Bit 4)                                                                                               |
| m = 0, Single Record<br>m = 1, Multiple Records                                                                                |
| b = Block length flag (Bit 3)                                                                                                  |
| b = 1, IBM format (128 to 1024 bytes)<br>b = 0, Non-IBM format<br>(16 to 4096 bytes)                                           |
| a1a0 = Data Address Mark (Bits 1-0)                                                                                            |
| a1a0 = 00, FB (Data Mark)<br>a1a0 = 01, FA (User defined)<br>a1a0 = 10, F9 (User defined)<br>a1a0 = 11, F8 (Deleted Data Mark) |

#### Table 5. FLAG SUMMARY

| TYPE III                                                                                                                                             |
|------------------------------------------------------------------------------------------------------------------------------------------------------|
| s = Synchronize flag (Bit 0)                                                                                                                         |
| $\overline{s} = 0$ , Synchronize to AM<br>$\overline{s} = 1$ , Do Not Synchronize to AM                                                              |
| ΤΥΡΕΙν                                                                                                                                               |
| li = Interrupt Condition flags (Bits 3-0)                                                                                                            |
| $I_0 = 1$ , Not Ready to Ready Transition<br>$I_1 = 1$ , Ready to Not Ready Transition<br>$I_2 = 1$ , Index Pulse<br>$I_3 = 1$ , Immediate interrupt |
| E = Enable HLD and 10 msec Delay                                                                                                                     |
| E = 1, Enable HLD, HLT and 10 msec<br>Delay                                                                                                          |
| E = 0, Head is assumed Engaged and<br>there is no 10 msec Delay                                                                                      |

Once the head is loaded, the head will remain engaged until the FD1771 receives a command that specifically disengages the head. If the FD1771 does not receive any commands after two revolutions of the disk, the head will be automatically disengaged (HLD made inactive). The Head Load Timing Input is sampled after a 10 ms delay, when reading or writing on the disk is to occur.

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

During verification, the head is loaded and after an internal 10 ms delay, the HLT input is sampled. When HLT is active (logic true), the first encountered ID field is read off the disk. The track address of the ID Field is then compared to the Track Register; if there is a match and a valid ID CRC, the verification is complete, an interrupt is generated and the BUSY status bit is reset. If there is not a match but there is

valid ID CRC, an interrupt is generated, the Seek Error status bit (Status Bit 4) is set and the BUSY status bit is reset. If there is a match but not a valid CRC, the CRC error status bit is set (Status Bit 3), and the next encountered ID Field is read from the disk for the verification operation. If an ID Field with a valid CRC cannot be found after two revolutions of the disk, the FD1771 terminates the operation and sents 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. Whe U=0, the track register is not updated.

#### **RESTORE (SEEK TRACK 0)**

Upon receipt of this command the Track 00 ( $\overline{TR00}$ ) input is sampled. If  $\overline{TR00}$  is active low indicating the Read-Write head is positioned over track 0, the Track

Register is loaded with zeroes and an interrupt is generated. If TR00 is not active low, stepping pulses (pins 15 to 17) at a rate specified by the  $r_1r_0$  field are issued until the TR00 input is activated. At this time the TR is loaded with zeroes and an interrupt is generated. If the TR00 input does not go active low after 255 stepping pulses, the FD1771 terminates operation, interrupts, and sets the Seek error status bit. Note that the RESTORE command is executed when MR goes from an active to an inactive state. A verification operation takes place if the V flag is set. The h bit allows the head to be loaded at the start of command.

#### SEEK

This command assumes that the Track Register contains the track number of the current position of the Read-Write head and the Data Register contains the desired track number. The FD1771 will update the



Track register and issue stepping pulses in the appropriate direction until the contents of the Track register are equal to the contents of the data register (the desired track location). A verification operation takes place if the V flag is on. The h bit allows the head to be loaded at the start of the command. An interrupt is generated at the completion of the command.

#### STEP

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



**TYPE I COMMAND FLOW** 

interrupt is generated at the completion of the command.

#### STEP-IN

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

#### STEP-OUT

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

#### TYPE II COMMANDS

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

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

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

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

FD1771-0

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

IDAM = ID Address Mark - DATA = (FE)<sub>16</sub> CLK = (C7)<sub>16</sub>

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

| For | b | Ξ | 1 |  |
|-----|---|---|---|--|
|-----|---|---|---|--|

| Sector Length<br>Field (Hex) | Number of Bytes<br>in Sector (Decimal) |  |
|------------------------------|----------------------------------------|--|
| 00                           | 128                                    |  |
| 01                           | 256                                    |  |
| 02                           | 512                                    |  |
| 03                           | 1024                                   |  |

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

For b = 0

| Sector Length<br>Field (Hex) | Number of Bytes<br>in Sector (Decimal) |  |
|------------------------------|----------------------------------------|--|
| 01                           | 16                                     |  |
| 02                           | 32                                     |  |
| 03                           | 48                                     |  |
| 04                           | 64                                     |  |
| •                            | •                                      |  |
| •                            | •                                      |  |
| •                            | •                                      |  |
| FF                           | 4080                                   |  |
| 00                           | 4096                                   |  |

Each of the Type II commands also contain a (m) flag which determines if the 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 FD1771 will continue to read or write multiple records and update the sector register until the sector register exceeds the number of sectors on the track or until the Force Interrupt command is loaded into the command register, which terminated the command and generates an interrupt.

#### READ COMMAND

Upon receipt of the Read command, the head is loaded, the BUSY status bit set, and when an ID field is encountered that has the correct track number, correct sector number, and correct CRC, the data field is presented to the computer. The Data Address Mark of the data field must be found within 28 bytes of the correct field; if not, the Record Not Found status bit is set and the operation is terminated. When the first character or byte of the data field has been



TYPE II COMMAND FLOW

shifted through the DSR, it is transferred to the DR, and DRQ is generated. When the next byte is accumulated in the DSR, it is transferred to the DR and another DRQ is generated. If the computer has not read the previous contents of the DR before a new character is transferred that character is lost and the

FD1771-01



i

**TYPE II COMMAND FLOW** 

Lost Data status bit is set. This sequence continues until the complete data field has been input 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 mulltiple 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 6 | Status<br>Bit 5 | Data AM<br>(Hex) |
|-----------------|-----------------|------------------|
| 0               | 0               | FB               |
| 0               | 1               | FA               |
| 1               | 0               | F9               |
| 1               | 1               | F8               |



**TYPE II COMMAND FLOW** 

#### WRITE COMMAND

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

The FD1771 then writes the data field and generates DRQs to the computer. If the DRQ is not serviced in

| a <sub>1</sub> a <sub>0</sub> |   | Data Mark<br>(Hex) | Clock Mark<br>(Hex) |  |
|-------------------------------|---|--------------------|---------------------|--|
| 0                             | 0 | FB                 | C7                  |  |
| Ō                             | 1 | FA                 | C7                  |  |
| 1                             | 0 | F9                 | C7                  |  |
| 1                             | 1 | F8                 | C7                  |  |

time for continuous writing the Lost Data status bit is set and a byte of zeros is written on the disk. The command is not terminated. After the last data byte has been written on the disk, the two-byte CRC is computed internally and written on the disk followed by one byte gap of logic ones. The WG output is then deactivated.



TYPE II COMMAND FLOW

#### TYPE III COMMANDS

#### **READ Address**

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

| TRACK | SIDE   | SECTOR  | SECTOR | CRC | CRC |
|-------|--------|---------|--------|-----|-----|
| ADDR  | NUMBER | ADDRESS | LENGTH | 1   | 2   |
| 1     | 2      | 3       | 4      | 5   |     |

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

#### READ TRACK

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

#### WRITE TRACK

Upon receipt of the Write Track command, the head is loaded and the BUSY status bit is set. Writing starts with the leading edge of the first encountered index pulse and continues until the next index pulse, at which time the interrupt is activated. The Data Request is activated immediately upon 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.
FD1771-01



#### TYPE III COMMAND WRITE TRACK

#### **CONTROL BYTES FOR INITIALIZATION**

| DATA<br>PATTERN<br>(HEX) | PATTERN             |    |
|--------------------------|---------------------|----|
| F7                       | Write CRC Character | FF |
| F8                       | Data Address Mark   | C7 |
| F9                       | Data Address Mark   | C7 |
| FA                       | Data Address Mark   | C7 |
| FB                       | Data Address Mark   | C7 |
| FC                       | Index Address Mark  | D7 |
| FD                       | Spare               |    |
| FE                       | ID Address Mark     | C7 |



#### **TYPE III COMMAND WRITE TRACK**

The Write Track Command will not execute if the  $\overrightarrow{\text{DINT}}$  input is grounded; instead, the Write Protect status bit is set and the interrupt is activated. Note that one F7 pattern generates two CRC characters.

#### TYPE IV COMMAND

#### Force Interrupt

This command can be loaded into the command register at any time. If there is a current command under execution (BUSY status bit set), the command will be terminated and an interrupt will be generated when the condition specified in the I<sub>0</sub> through I<sub>3</sub> 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<sub>2</sub> = 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 clear the immediate interrupt.

#### 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 | <b>S</b> 5 | S4 | S3 | S2 | S1 | S0 |  |  |

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

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

#### Table 6. STATUS REGISTER SUMMARY

#### STATUS FOR TYPE I COMMANDS

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

FD1771-0-

#### STATUS BITS FOR TYPE II AND III COMMANDS

| BIT | NAME                          | MEANING                                                                                                                                                                                                                                            |
|-----|-------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| S7  | NOT READY                     | This bit when set indicates the drive is not ready. When reset, it indicates that the drive is ready. This bit is an inverted copy of the READY input and "ored" with MR. The TYPE II and III Commands will not execute unless the drive is ready. |
| S6  | RECORD TYPE/<br>WRITE PROTECT | On Read Record: It indicates the MSB of record-type code from<br>data field address mark. On Read Track: Not Used. On any<br>Write Track: It indicates a Write Protect. This bit is reset when<br>updated.                                         |
| S5  | RECORD TYPE/WRITE FAULT       | On Read Record: It indicates the LSB of record-type code from<br>data field address mark. On Read Track: Not Used. On any<br>Write Track: It indicates a Write Fault. This bit is reset when<br>updated.                                           |
| S4  | RECORD NOT FOUND              | When set, it indicates that the desired track and sector were not found. This bit is reset when updated.                                                                                                                                           |
| S3  | CRC ERROR                     | If S4 is set, an error is found in one or more ID fields; otherwise it indicates error in data field. This bit is reset when updated.                                                                                                              |
| S2  | LOST DATA                     | When set, it indicates the computer did not respond to DRQ in one byte time. This bit is reset to zero when updated.                                                                                                                               |
| S1  | DATA REQUEST                  | This bit is a copy of the DRQ output. When set, it indicates the DR is full on a Ready operation or the DR is empty on a Write operation. This bit is reset to zero when updated.                                                                  |
| S0  | BUSY                          | When set, command is under execution. When reset, no command is under 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 FD1771 raises the Data Request signal. At this point in time, the user loads the Data Register with desired data to be written on the disk. For every byte of information to be written on the disk, a Data Request is generated. This sequence continues from one index mark to the next index mark. Normally, whatever data pattern appears in the Data Register is written on the disk with a clock mark of (FF)<sub>16</sub>. However, if the FD1771 detects a data pattern on F7 through FE in the Data Register, this is interpreted as data address marks with missing clocks or CRC generation. For instance, an FE pattern will be interpreted as an ID address mark (DATA-FE, CLK-C7) and the CRC will be initialized. An F7 pattern will generate two CRC characters. As a consequence, the patterns F7 through FE must not appear in the gaps, data fields, or ID fields. Also, CRCs must be generated by an F7 pattern.

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

#### IBM 3740 Formats — 128 Bytes/Sector

The IBM format with 128 bytes/sector is depicted in the Track Format figure on the following page. In order to create this format, the user must issue the Write Track command, and load the data register with the following values. For every byte to be written, there is one data request.

| Number<br>of Bytes | Hex Value of<br>Byte Written |
|--------------------|------------------------------|
| 40                 | 00 or FF                     |
| 6                  | 00                           |
| 1                  | FC (Index Mark)              |
| <b>*</b> 26        | 00 or FF                     |
| 6                  | 00                           |
| 1                  | FE (ID Address Mark)         |
| 1                  | Track Number (0 through 4C)  |
| 1                  | 00                           |
| 1                  | Sector Number (1 through 1A) |
| 1                  | 00                           |
| 1                  | F7 (two CRCs written)        |
| 11                 | 00 or FF                     |
| 6                  | 00                           |
| 1                  | FB (Data Address Mark)       |
| 128                | Data (IBM uses E5)           |
| 1                  | F7 (two CRCs written)        |
| 27                 | 00 or FF                     |
| 247 **             | 00 or FF                     |

\*Write bracketed field 26 times.

\*\*Continue writing until FD1771 interrupts out. Approximately 247 bytes.

#### **Non-IBM Formats**

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

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

#### **References:**

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



TRACK FORMAT

#### ELECTRICAL CHARACTERISTICS

#### Maxium Ratings

| VDD with respect to VBB (Groun | d) +20 to -0.3V |
|--------------------------------|-----------------|
| Max Voltage to any input with  | +20 to -0.3V    |
| respect to VBB                 |                 |
| Operating Temperature          | 0° C to 70° C   |
| Storage Temperature            | -55°C to +125°C |

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

 $\begin{array}{l} T_{A} = 0^{\circ}C \ to \ 70^{\circ}C, \ V_{DD} = \pm 12.0V \pm .6V, \\ V_{BB} = \pm 5.0 \pm .5V, \ V_{SS} = 0V, \ V_{CC} = \pm 5V \pm .25V \\ I_{DD} = 10 \ ma \ Nominal, \ I_{CC} = 30 \ ma \ Nominal, \\ I_{BB} = \pm 0.4 \ \mu a \ Nominal \end{array}$ 

| Symbol | Characteristic                 | Min. | Тур. | Max. | Units | Conditions   |
|--------|--------------------------------|------|------|------|-------|--------------|
| ΙLΙ    | Input Leakage                  |      |      | 10   | μA    | VIN = VDD    |
| ILO    | Output Leakage                 |      |      | 10   | μA    | VOUT = VDD   |
| ⊻н     | Input High Voltage             | 2.6  |      |      | v     |              |
| VIL    | Input Low Voltage (All Inputs) |      |      | 0.8  | V     |              |
| Voн    | Output High Voltage            | 2.8  |      |      | V     | IO = -100 uA |
| VOL    | Output Low Voltage             |      |      | 0.45 | V     | IO = 1.0 mA  |

#### TIMING CHARACTERISTICS

TA = 0°C to 70°C.  $V_{DD}$  = +12V ± .6V,  $V_{BB}$  = -5V + .25V.  $V_{SS}$  = 0V.  $V_{CC}$  = +5V + .25V. NOTE: Timings are given for 2 MHz Clock. For those timings noted, values will double when chip is operated at 1 MHz. Use 1 MHz when using mini-floppy.

#### **Read Operations**

| Symbol | Characteristic           | Min. | Тур. | Max. | Units | Conditions                                       |
|--------|--------------------------|------|------|------|-------|--------------------------------------------------|
| TSET   | Setup ADDR and CS to RE  | 100  |      |      | nsec  |                                                  |
| THLD   | Hold ADDR and CS from RE | 10   |      |      | nsec  |                                                  |
| TRE    | RE Pulse Width           | 450  |      |      | nsec  | C <sub>L</sub> = 25 pf                           |
| TDRR   | DRQ Reset from RE        |      |      | 750  | nsec  |                                                  |
| TIRR   | INTRQ Reset from RE      |      |      | 3000 | nsec  |                                                  |
| TDACC  | Data Access from RE      |      |      | 450  | nsec  | C <sub>L</sub> = 25 pf<br>C <sub>L</sub> = 25 pf |
| TDOH   | Data Hold from RE        | 50   |      | 150  | nsec  | C <sub>L</sub> = 25 pf                           |

#### Write Operations

| Symbol | Characteristic           | Min. | Тур. | Max. | Units | Conditions |
|--------|--------------------------|------|------|------|-------|------------|
| TSET   | Setup ADDR and CS to WE  | 100  |      |      | nsec  |            |
| THLD   | Hold ADDR and CS from WE | 10   |      |      | nsec  |            |
| TWE    | WE Pulse Width           | 450  | 300  |      | nsec  |            |
| TDRR   | DRQ Reset from WE        |      |      | 750  | nsec  |            |
| TIRR   | INTRQ Reset from WE      |      |      | 3000 | nsec  | See Note   |
| TDS    | Data Setup to WE         | 350  |      |      | nsec  |            |
| TDH    | Data Hold from WE        | 150  |      |      | nsec  |            |

#### External Data Separation (XTDS = 0)

| Symbol | Characteristic                     | Min. | Тур. | Max. | Units | Conditions |
|--------|------------------------------------|------|------|------|-------|------------|
| TPWX   | Pulse Width Read Data & Read Clock | 150  |      | 350  | nsec  |            |
| тсх    | Clock Cycle External               | 2500 |      |      | nsec  |            |
| TDEX   | Data to Clock                      | 500  |      | 1    | nsec  |            |
| TDDX   | Data to Data Cycle                 | 2500 |      |      | nsec  |            |

FD1771-01



#### **READ ENABLE TIMING**

# XTOS + 0 EYTERNAL DATA SEFARATION Image: sefaration

WRITE ENABLE TIMING

#### READ TIMING (XTDS = 0)

#### Internal Data Separation ( $\overline{XTDS} = 1$ )

| Symbol | Characteristic             | Min. | Тур. | Max. | Units | Conditions |
|--------|----------------------------|------|------|------|-------|------------|
| TPWI   | Pulse Width Data and Clock | 150  |      | 1000 | nsec  |            |
| TCI    | Clock Cycle Internal       | 3500 |      | 5000 | nsec  |            |

#### Write Data Timing

| Symbol | Characteristic          | Min. | Тур. | Max. | Units | Conditions               |
|--------|-------------------------|------|------|------|-------|--------------------------|
| TWGD   | Write Gate to Data      |      | 1200 |      | nsec  | 300 nsec ± CLK tolerance |
| TPWW   | Pulse Width Write Data  | 500  |      | 600  | nsec  |                          |
| TCDW   | Clock to Data           |      | 2000 |      | nsec  | ± CLK tolerance          |
| TCW    | Clock Cycle Write       |      | 4000 |      | nsec  | ± CLK tolerance          |
| TWGH   | Write Gate Hold to Data | 0    |      | 100  | nsec  |                          |

#### **Miscellaneous Timing**

| Symbol           | Characteristic           | Min. | Тур. | Max. | Units | Conditions           |
|------------------|--------------------------|------|------|------|-------|----------------------|
| TCD1             | Clock Duty               | 175  |      |      | nsec  | 2 MHz ± 1% See Note  |
| TCD <sub>2</sub> | Clock Duty               | 210  |      |      | nsec  |                      |
| TSTP             | Step Pulse Output        | 3800 |      | 4200 | nsec  | )                    |
| TDIR             | Direct Setup to Step     | 24   |      |      | nsec  |                      |
| TMR              | Master Reset Pulse Width | 10   |      |      | nsec  | >These times doubled |
| TIP              | Index Pulse Width        | 10   |      |      | nsec  | when CLK = 1 MHz     |
| TWF              | Write Fault Pulse Width  | 10   |      |      | nsec  | )                    |



READ TIMING (XTDS = 1)

XTDS 1 INTERNAL DATA SEPARATION FDCLOCK MUST BE TIED HIGH

FDDATA

C

**MISCELLANEOUS TIMING** 



WRITE DATA TIMING

See page 481 for ordering information.

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

## WESTERN DIGITAL

**1771-01 Application Notes** 

#### INTRODUCTION

The FD1771-01 Floppy Disk Formatter/Controller is a MOS/LSI device designed to ease the task of interfacing the 8" or 5¼ (mini-floppy) disk drive to a host processor. It is ideally suited for a wide range of microprocessors, providing an 8-bit bi-directional interface to the CPU for all control and data transfers. Requiring standard + 12,  $\pm$ 5V power supplies, the 1771 is available in ceramic or plastic 40 pin dual-in-line packages.

The 1771 has been designed to be compatible with the IBM 3740 standard. This single-density Frequency Modulated (FM) recording technique, records a clock bit between a data bit serially on each track. Figure 1 illustrates how a HEX "D2" is recorded. Note that when the data bit to be written is zero, no pulse or flux transition is recorded. For the 8" drive. there are 77 tracks, with 26 sectors on each track. Each sector contains 128 bytes of data. Although there is no "standard" format for the mini-floppy, most manufacturers utilize either 35 or 40 tracks per side, with 16 sectors of 128 bytes each per track. Both the 8" and 5¼" formats must be soft-sectored, i.e., there are no physical holes to denote sector locations. The hard-sectored disk has been losing popularity, mainly due to the fact that the sector lengths cannot be increased.

Being soft-sector compatible, the 1771 must know where each sector begins on the track. This is performed by using Address Marks. These bytes are recorded on the disk with certain clock pulses missing, and are unique from all other data and gap bytes recorded on the track. Six distinct Address Marks can be used:

| Description                                                                                                        | Data                             | Clock<br>Pattern                       |
|--------------------------------------------------------------------------------------------------------------------|----------------------------------|----------------------------------------|
| Index Address Mark<br>ID Address Mark<br>Data Address Mark<br>User defined<br>User Defined<br>Deleted Address Mark | FC<br>FE<br>FB<br>FA<br>F9<br>F8 | D7<br>C7<br>C7<br>C7<br>C7<br>C7<br>C7 |

The two "User Defined" Address Marks are unique to the 1771, and do not appear in the IBM 3740 standard. These Address Marks can be used to define the type of data i.e., "object" or "text" data, alternate sector data, or any other purpose the user chooses.

#### PROCESSOR INTERFACE

The 1771 contains five internal registers that can be accessed via the 8-bit DAL lines by the CPU. These registers are used to control the movement of the head, read and write sectors, and perform all other functions at the drive. Regardless of the operation performed, it must be initiated through one or more of these registers. 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 | Α1 | A <sub>0</sub> | RE = 0     | <b>WE</b> = 0 |
|----|----|----------------|------------|---------------|
| 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      |
| 1  | х  | х              | Deselected | Deselected    |

**Command Register.** This is a write-only register used to send all commands to the 1771.

**Status Register:** This is a read-only register that must be read at the completion of every command to determine whether execution was successful. It may also be used to monitor command execution, and to sense when data is required by the drive for read or write operations.

**Track Register:** This R/W register holds the current position of the R/W head.

Sector Register: This R/W register holds the desired sector number for read and write commands.

**Data Register:** This R/W register contains the data to be read or written to a particular sector.

#### INTERRUPTS

There are two INTERRUPT lines for CPU use. These are the DRQ (Data Request) and INTRQ (Interrupt Request). These are active high, open drain outputs and require a pull-up resistor of 10K or greater to +5V. Both of these signals also appear in the status register as the Busy (INTRQ) and the data request (DRQ) bits. The user has the option of utilizing these hardware lines for system interrupts, or through software by polling the status register. The choice is dependent upon the particular microprocessor and support hardware of the system.

**INTRQ:** This line is used to signify the completion of any command. It is reset low when a new command is loaded into the command register, or when the status register is read.

**DRQ:** This line is active high whenever the data register requires servicing. During a read command, it signifies that the data register contains a byte of data from the disk and may be read by the CPU. During a write command, it signifies that the data register is empty and may be loaded with the next byte to be written on the disk. The DRQ line is reset whenever the data register is read or written to. It is also reset when a new command is loaded into the command register, providing the new command is not a Forced Interrupt, and the 1771 is not busy (Busy Bit=0).

#### WRITE SECTOR

With the use of the WRITE SECTOR command, the CPU can access any desired sector(s) in a track. Prior to loading this command, the R/W head of the drive must be positioned over the specific track. This can be first accomplished with the use of any of the Type I commands. Once positioned, the CPU must load the desired sector number into the sector register, then issue the command. The head will load, and the 1771 will begin searching for the correct ID field. If the correct sector and track is not found within 2 revolutions of the disk, the RECORD-NOT-FOUND bit will be set in the status register, and the command will be terminated. Once found, the 1771 will issue a DRQ in request of the first data byte to be written. Once the data register is loaded, the 1771 will issue a DRQ for each byte to be recorded, until the entire sector is written. For the 8" drive, the user must load the data register 24 microseconds after a DRQ is generated. Failure to meet this time will cause the lost data bit to be set, and a byte of zeros substituted and written on the disk.

#### READ SECTOR

The READ SECTOR command functions in much the same way as the WRITE SECTOR command. The sector register must again be loaded with the desired sector number, before the read command can be loaded. After the ID field has been found, the 1771 will begin generating DRQ's, with the data register being loaded with each byte of the sector field. For the 8" drive, the user must read the data register at least 26 microseconds after the DRQ is generated. Failure to meet this time will cause the lost data bit to be set in the status register, while the next assembled byte will overwrite the contents of the data register.

Both the Read and Write sector commands also

contain an "m" flag for accessing multiple sectors. The sector register is incremented internally after each sector is read or written to. Eventually the sector register will exceed the physical number of sectors on the track. The user can either issue the Forced Interrupt command after the last sector, or wait for the 1771 to interrupt out. In the latter case, the RECORD-NOT-FOUND status bit will be set.

#### FLOPPY DISK INTERFACE

For the most part, the actual Floppy Disk Interface will consist mainly of Buffer/Drivers. Most drives manufactured today require an open collector TTL interface, with appropriate resistor terminal networks. Figure 2 shows the interface of the 1771 to a Shugart SA400 Drive. Aside from the data seperator, the interface consists mainly of 7438's and 7414 TTL gates. A 9602 one-shot is used for the desired head load delay. In this illustration, the 6800 microprocessor is used via a 6820 Peripheral Interface Adapter to control all functions of the 1771. Similarly, other parallel port devices (such as the 8255 for 8080 systems) can be used for the interface, or the 1771 may simply be tied directly to the systems data bus and control lines, providing TTL loading factors are observed.

#### DATA SEPERATION

The internal DAT<u>A SEP</u>ERATOR of the 1771 can be used by tying the XTDS line high, and supplying the combined clock and data pulses on the FD data line. In order to maintain an error rate better than 1 in  $10^8$ , and external data seperator is recommended.

Since the 1771 system clock is at 2 MHz, this allows for a 500 ns resolution. The internal data window will move 500 ns with respect to the incoming data bit. On the inner tracks of the drive, the bit shift is more severe and may occasionally cause a data or clock bit to fall outside of this data window. Since the 1771 will perform up to 5 retries, this error rate may be acceptable for some applications.

When the  $\overline{XTDS}$  line is forced low, the 1771 will accept seperated clock and data on the FDCLOCK and FDDATA lines. Figure 3 illustrates the timing of these signals. The actual FDCLOCK and FDDATA lines may be reversed; the 1771 will determine which line is clock and which is data when an Address Mark is detected. This feature greatly simplifies the design of the data seperator.

Figure 4 illustrates the Phase-Lock Loop method for data seperation. The circuit operates at 8 MHz, or 32 times the frequency of a received bit cell. The MC4024 VCO is used to supply the nominal clock frequency. The first 74LS161 counter provides a divide by 16 frequency and a carry to one side of the MC4044 phase detector. The other input of the MC4044 is tied to another 74LS161 counter which is affected by the incoming data stream. The output of the phase detector is a signal proportional to the differences of the incoming pulses. This is then fed through a low pass filter, and to the input of the MC4024 to adjust the output frequency. Figures 5 thru 8 illustrate other types of data seperators. These employ the "Counter Seperator" techniques and are quite different from the Phase-Lock-Loop method. With the addition of "One-Shot" delay element or an input clock, most of the complexity of the PPL circuit can be eliminated.



FIGURE 1. FM RECORDING.



FIGURE 2. 1771 TO SHUGART SA400 DRIVE



1771-01





FIGURE 4. CIRCUIT PROVIDED COURTESY OF MOTOROLA AND ICOM CORPS.

1771-01



FIGURE 5. CIRCUIT PROVIDED COURTESY OF PROCESSOR APPLICATIONS LTD.



FIGURE 6.

1771-01







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

## WESTERN DIGITAL

Α

τ /

0

N



WD1770/1772 51/4" Floppy Disk Controller/Formatter

n R

#### FEATURES

- 28 PIN DIP
- SINGLE 5V SUPPLY
- BUILT-IN DATA SEPARATOR
- BUILT-IN WRITE PRECOMPENSATION
- 5<sup>1</sup>/<sub>4</sub>" SINGLE AND DOUBLE DENSITY
- MOTOR CONTROL
- 128, 256, 512 OR 1024 SECTOR LENGTHS

Ω

RP

- TTL COMPATIBLE
- 8 BIT BIDIRECTIONAL DATA BUS
- TWO VERSIONS AVAILABLE WD1770 = STANDARD 179X STEP RATES WD1772 = FASTER STEP RATES

#### DESCRIPTION

The WD1770 is a MOS/LSI device which performs the functions of a 51⁄4" Floppy Disk Controller/Formatter. It is similar to its predecessor, the WD179X, but also contains a digital data separator and write precompensation circuitry. The drive side of the interface needs no additional logic except for buffers/ receivers. Designed for 51⁄4" single or double density operation, the device contains a programmable Motor On signal.

The WD1770 is implemented in NMOS silicon gate technology and is available in a 28 pin dual-in-line.

The WD1770 is a low cost version of the FD179X Floppy Disk Controller/Formatter. It is compatible with the 179X, but has a built-in digital data separator and write precompensation circuits. A single read line (RD, Pin 19) is the only input required to recover





serial FM or MFM data from the disk drive. The device has been specifically designed for control of 51/4" floppy disk drives with data rates of 125 KBits/Sec (single density) and 250 KBits/Sec (double density). In addition, write precompensation of 125 Nsec from nominal can be enabled at any point through simple software commands. Another programmable feature, Motor On, has been incorporated to enable the spindle motor automatically prior to operating a selected drive.

Two versions of the WD1770 are available. The standard version is compatible with the 179X stepping rates, while the WD1772 offers stepping rates of 2, 3, 5 and 6 msec.

The processor interface consists of an 8-bit bidirectional bus for transfer of status, data, and commands. All host communication with the drive occurs through these data lines. They are capable of driving one standard TTL load or three "LS" loads.

| PIN<br>NUMBER | PIN NAME                         | SYMBOL    | FUNCTION                                                                                                                                                                           |  |  |  |  |
|---------------|----------------------------------|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| 1             | CHIP SELECT                      | CS        | A logic low on this input selects the chip and enable Host communication with the device.                                                                                          |  |  |  |  |
| 2             | READ/WRITE                       | R/W       | A logic high on this input controls the<br>placement of data on the D0-D7 lines from a<br>selected register, while a logic low causes a<br>write operation to a selected register. |  |  |  |  |
| 3,4           | ADDRESS 0,1                      | A0, A1    | These two inputs select a register to Read/Write data:<br>$\overrightarrow{CS}$ A1 A0 $\overrightarrow{R/W} = 1$ $\overrightarrow{R/W} = 0$                                        |  |  |  |  |
|               |                                  |           | 000Status RegCommand Reg001Track RegTrack Reg010Sector RegSector Reg011Data RegData Reg                                                                                            |  |  |  |  |
| 5-12          | DATA ACCESS LINES<br>0 THROUGH 7 | DAL0-DAL7 | Eight bit bidirectional bus used for transfer of<br>data, control, or status. This bus is enabled by<br>CS and R/W. Each line will drive one TTL load.                             |  |  |  |  |
| 13            | MASTER RESET                     | MR        | A logic low pulse on this line resets the device<br>and initializes the status register (internal pull-u                                                                           |  |  |  |  |
| 14            | GROUND                           | GND       | Ground.                                                                                                                                                                            |  |  |  |  |
| 15            | POWER SUPPLY                     | Vcc       | $+5V \pm 5\%$ power supply input.                                                                                                                                                  |  |  |  |  |
| 16            | STEP                             | STEP      | The Step output contains a pulse for each step<br>of the drive's R/W head. The WD1770 and<br>WD1772 offer different step rates.                                                    |  |  |  |  |
| 17            | DIRECTION                        | DIRC      | The Direction output is high when stepping in towards the center of the diskette, and low when stepping out.                                                                       |  |  |  |  |
| 18            | CLOCK                            | CLK       | This input requires a free-running 50% duty cycle clock (for internal timing) at 8 MHZ $\pm$ 1%.                                                                                   |  |  |  |  |
| 19            | READ DATA                        | RD        | This active low input is the raw data line containing both clock and data pulses from the drive.                                                                                   |  |  |  |  |
| 20            | MOTOR ON                         | мо        | Active high output used to enable the spindle<br>motor prior to read, write or stepping opera-<br>tions.                                                                           |  |  |  |  |
| 21            | WRITE GATE                       | WG        | This output is made valid prior to writing on the diskette.                                                                                                                        |  |  |  |  |
| 22            | WRITE DATA                       | WD        | FM or MFM clock and data pulses are placed on this line to be written on the diskette.                                                                                             |  |  |  |  |
| 23            | TRACK 00                         | TROO      | This active low input informs the WD1770 that<br>the drive's RW heads are positioned over Track<br>zero (internal pull-up).                                                        |  |  |  |  |
| 24            | INDEX PULSE                      | 9<br>I    | This active low input informs the WD1770 when<br>the physical index hole has been encountered<br>on the diskette (internal pull-up).                                               |  |  |  |  |
| 25            | WRITE PROTECT                    | WPRT      | This input is sampled whenever a Write<br>Command is received. A logic low on this<br>line will prevent any Write Command from<br>executing (internal pull-up).                    |  |  |  |  |
| 26            | DOUBLE DENSITY<br>ENABLE         | DDEN      | This input pin selects either single (FM) or<br>double (MFM) density. When DDEN = 0, double<br>density is selected (internal pull-up).                                             |  |  |  |  |

WD1770/1772

| PIN<br>NUMBER | PIN NAME          | SYMBOL | FUNCTION                                                                                                            |
|---------------|-------------------|--------|---------------------------------------------------------------------------------------------------------------------|
| 27            | DATA REQUEST      | DRQ    | This active high output indicates that the Data<br>Register is full (on a Read) or empty (on a Write<br>operation). |
| 28            | INTERRUPT REQUEST | INTRQ  | This active high output is set at the completion<br>of any command or reset a read of the Status<br>Register.       |



#### WD1770 SYSTEM BLOCK DIAGRAM

#### ARCHITECTURE

The Floppy Disk Formatter block diagram is illustrated on page 4. 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 (RD) 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 and decremented by one when the head is stepped out (towards track 00). The contents of the register are compared with the recorded track number in the ID field during disk Read, Write, and Verify operations. The Track Register can be loaded from or transferred to the DAL. This Register should not be loaded when 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.

**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 FD1770 has two different modes of operation according to the state of  $\overline{\text{DDEN}}$ . When  $\overline{\text{DDEN}} = 0$ , double density (MFM) is enabled. When  $\overline{\text{DDEN}} = 1$ , single density is enabled.

**AM Detector** — The address mark detector detects ID, data and index address marks during read and write operations.

**Data Separator** — A digital data separator consisting of a ring shift register and data window detection logic provides read data and a recovery clock to the AM detector.

#### 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 WD1770. The DAL are three state buffers that are enabled as output drivers when Chip Select ( $\overline{CS}$ ) and  $\overline{RW} = 1$  are active or act as input receivers when  $\overline{CS}$  and  $\overline{RW} = 0$  are active.

When transfer of data with the Floppy Disk Controller is required by the host processor, the device address is decoded and CS is made low. The address bits A1 and A0, combined with the signal R/W during a Read operation or Write operation are interpreted as selecting the following registers:

| A1 | - A0 | READ ( $R/\overline{W} = 1$ ) | WRITE ( $R/\overline{W} = 0$ ) |
|----|------|-------------------------------|--------------------------------|
| 0  | 0    | Status Register               | Command 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 WD1770 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 operations 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 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.

The WD1770 has two modes of operation according to the state  $\overline{\text{DDEN}}$  (Pin 26). When  $\overline{\text{DDEN}} = 1$ , single density is selected. In either case, the CLK input (Pin 18) is at 8 MHZ.

#### GENERAL 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 the fourth byte in the "ID" field.

| SECTOR LENGTH TABLE                                             |      |  |  |  |  |
|-----------------------------------------------------------------|------|--|--|--|--|
| SECTOR LENGTH NUMBER OF BYTES<br>FIELD (HEX) IN SECTOR (DECIMAL |      |  |  |  |  |
| 00                                                              | 128  |  |  |  |  |
| 01                                                              | 256  |  |  |  |  |
| 02                                                              | 512  |  |  |  |  |
| 03                                                              | 1024 |  |  |  |  |

The number of sectors per tract as far as the WD1770 is concerned can be from 1 to 255 sectors. The

number of tracks as far as the WD1770 is concerned is from 0 to 255 tracks.

#### **GENERAL 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 device 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.

For Write operations, the WD1770 provides Write Gate (Pin 21) to enable a Write condition, and Write Data (Pin 22) which consists of a series of active high pulses. These pulses contain both Clock and Data information in FM and MFM. Write Data provides the unique missing clock patterns for recording Address Marks.

The Precomp Enable bit in Write commands allow automatic Write precompensation to take place. The outgoing Write Data stream is delayed or advanced from nominal by 125 nanoseconds according to the following table:

|                                                            | PATTERN |   |   | MFM   | FM  |  |  |
|------------------------------------------------------------|---------|---|---|-------|-----|--|--|
| Х                                                          | 1       | 1 | 0 | Early | N/A |  |  |
| Х                                                          | 0       | 1 | 1 | Late  | N/A |  |  |
| 0                                                          | 0       | 0 | 1 | Early | N/A |  |  |
| 1                                                          | 0       | 0 | 0 | Late  | N/A |  |  |
| Next Bit to be sent Current Bit sending Previous Bits sent |         |   |   |       |     |  |  |

Precompensation is typically enabled on the innermost tracks where bit shifts usually occur and bit density is at its maximun.

#### COMMAND DESCRIPTION

The WD1770 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 1.

#### **COMMAND SUMMARY**

|     |              |   |   |   | Bľ  | TS |    |    |    |
|-----|--------------|---|---|---|-----|----|----|----|----|
| TYP | E COMMAND    | 7 | 6 | 5 | 4   | 3  | 2  | 1  | 0  |
| 1   | Restore      | 0 | 0 | 0 | 0   | h  | ۷  | ۲1 | ro |
| 1   | Seek         | 0 | 0 | 0 | 1   | h  | ۷  | r1 | ro |
| 1   | Step         | 0 | 0 | 1 | u   | h  | ۷  | r1 | ro |
| 1   | Step-in      | 0 | 1 | 0 | u   | h  | ۷  | r٩ | ro |
| 1   | Step-out     | 0 | 1 | 1 | u · | h  | ۷  | r۱ | ro |
| H   | Read Sector  | 1 | 0 | 0 | m   | h  | Е  | 0  | 0  |
| 11  | Write Sector | 1 | 0 | 1 | m   | h  | Е  | Ρ  | a0 |
| 111 | Read         |   |   |   |     |    |    |    |    |
|     | Address      | 1 | 1 | 0 | 0   | h  | Е  | 0  | 0  |
|     | Read Track   | 1 | 1 | 1 | 0   | h  | Е  | 0  | 0  |
| 111 | Write Track  | 1 | 1 | 1 | 1   | h  | Е  | Ρ  | 0  |
| IV  | Force        |   |   |   |     |    |    |    |    |
|     | Interrupt    | 1 | 1 | 0 | 1   | 13 | 12 | 11 | IO |

#### FLAG SUMMARY

| TYPE | L | CON | IMA | NDS |
|------|---|-----|-----|-----|

| h — | Motor | On | Flan | (Rit 3) |
|-----|-------|----|------|---------|

- h = 0, Enable Spin-Up Sequence
- h = 1, Disable Spin-Up Sequence

#### V = Verify Flag (Bit 2)

- V = 0. No Verify
- V = 1, Verify on Destination Track

| ۲١, | r0 | WD1770 | WD1772 |
|-----|----|--------|--------|
| 0   | 0  | 6 ms   | 2 ms   |
| 0   | 1  | 12 ms  | 3 ms   |
| 1   | 0  | 20 ms  | 5 ms   |
| 1   | 1  | 30 ms  | 6 ms   |

u = Update Flag (Bit 4)u = 0, No Update

u = 1, Update Track Register

#### TYPE II & III COMMANDS

- m = Multiple Sector Flag (Bit 4)
- m = 0, Single Sector
- m = 1, Multiple Sector

#### a0 = Data Address Mark (Bit 0)

 $a_0 = 0$ , Write Normal Data Mark

a0 = 1, Write Deleted Data Mark

#### E = 30ms Settling Delay (Bit 2)

- E = 0, No Delay
- E = 1, Add 30ms Delay

#### P = Write Precompensation (Bit 1)

- P = 0, Enable Write Precomp
- P = 1, Disable Write Precomp

#### **TYPE IV COMMANDS**

#### I<sub>3</sub>-I<sub>0</sub> Interrupt Condition (Bits 3-0)

- $l_0 = 1$ , Don't Care
- $I_1 = 1$ , Don't Care
- $l_2 = 1$ , Interrupt on Index Pulse
- I3 = 1, Immediate Interrupt
- $I_3-I_0 = 0$ , Terminate without Interrupt

#### **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 ( $r_0,r_1$ ), which determines the stepping motor rate.

A  $4\mu$ s (MFM) or 8  $\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. The chip will step the drive in the same direction it last stepped unless the command changes the direction.

The Direction signal is active high when stepping in and low when stepping out. The Direction signal is valid  $24\mu s$  before the first stepping pulse is generated.

After the last directional step an additional 30 milliseconds of head settling time takes place if the Verify flag is set in Type I commands. There is also a 30 ms head settling time if the E flag is set in any Type II or III command.

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 30 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. 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.

The WD1770 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. If V = 0, no verification is performed.

All commands, except the Force Interrupt command, may be programmed via the h Flag to delay for spindle motor start up time. If the h Flag is set and the Motor On line (Pin 20) is low when a command is received, the WD1770 will force Motor On to a logic 1 and wait 6 revolutions before executing the command. At 300 RPM, this guarantees a one second spindle start up time. If after finishing the command, the device remains idle for 10 revolutions, the Motor On line will go back to a logic 0. If a command is issued while Motor On is high, the command will execute immediately, defeating the 6 revolution start up. This feature allows consecutive Read or Write commands without waiting for motor start up each time; the WD1770 assumes the spindle motor is up to speed.

#### **RESTORE (SEEK TRACK 0)**

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 an interrupt is generated. If TR00 is not active low, stepping pulses (Pin 16) at a rate specified by the  $r_1,r_0$  field are issued until the TR00 input is activated.



49

WD1770/1772

At this time, the Track Register is loaded with zeroes and an interrupt is generated. If the TR00 input does not go active low after 255 stepping pulses, the WD1770 terminates operation, interrupts, and sets the Seek error status bit, providing the V flag is set. A verification operation also takes place if the V flag is set. The h bit allows the Motor On option at the start of command.

#### SEEK

This command assumes that the Track Register contains the track number of the current position of the Read/Write head and the Data Register contains the desired track number. The WD1770 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



TYPE I COMMAND FLOW

operation takes place if the V flag is on. The h bit allows the Motor On option at the start of the command. An interrupt is generated at the completion of the command. Note: When using multiple drives, the track register must be updated for the drive selected before seeks are issued.

#### STEP

Upon receipt of this command, the WD1770 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 r1,r0 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 Motor On option at the start of the command. An interrupt is generated at the completion of the command.

#### STEP-IN

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

#### STEP-OUT

Upon receipt of this command, the WD1770 issues one stepping pulse in the direction towards track 0. If the U flag is on, the Track Register is decremented by one. After delay determined by the  $r_1,r_0$  field, a verification takes place if the V flag is on. The h bit allows the Motor On option 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 the command will execute after a 30 msec delay.

When an ID field is located on the disk, the WD1770 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 WD1770 must find an ID field with a Track number, Sector number, and CRC within four revolutions of the disk, other-



#### **TYPE II COMMAND**

wise, the Record not found status bit is set (Status Bit 4) and the command is terminated with an interrupt (INTRQ).

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 WD1770 will continue to read or write multiple records and update the sector register in numerical ascending sequence until the sector register exceeds the number of sectors on the track or until the Force Interrupt command is loaded into the Command Register, which terminates the command and generates an interrupt.

For example: If the WD1770 is instructed to read sector 27 and there are only 26 on the track, the sector register exceeds the number available. The WD1770 will search for 5 disk revolutions, interrupt out, reset busy, and set the record not found status bit.

#### **READ SECTOR**

Upon receipt of the Read Sector command, the Busy status bit is set, and when a 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 30 bytes in single density and 43 bytes in double density of the last ID field CRC byte; if not, the ID field is searched for and verified again followed by the Data Address Mark search. If after 5 revolutions the DAM cannot be found, the Record Not Found status bit is set and the operation is terminated. When the first character or byte of the data field has been shifted through the DSR, it is transferred to the DR, and DRQ is generated. When the next byte is accumulated in the DSR, it is transferred to the DR and another DRQ is generated. If the computer has not read the previous contents of the DR before a new character is transferred that character is lost and the Lost Data Status bit is set. This sequence continues until the complete data field has been inputted to the computer. If there is a CRC error at the end of the data field, the CRC error status bit is set, and the command is terminated (even if it is a multiple record command).

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

| STATUS BIT 5 |                   | 7 |
|--------------|-------------------|---|
| 1            | Deleted Data Mark |   |
| 0            | Data Mark         |   |

#### WRITE SECTOR

Upon receipt of the Write Sector command, 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 WD1770 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



**TYPE II COMMAND** 

and the Lost Data status bit is set. If the DRQ has been serviced, the WG is made active and six bytes of zeroes 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 ao field of the command as shown below:

| a <sub>0</sub> | DATA ADDRESS MARK (BIT 0) |
|----------------|---------------------------|
| 1              | Deleted Data Mark         |
| 0              | Data Mark                 |

The WD1770 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



**TYPE II COMMAND** 



**TYPE II COMMAND** 

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 by one byte of logic ones in FM or in MFM. The WG output is then deactivated. INTRQ will set  $24\mu$ sec (MFM) after the last CRC byte is written. For partial sector writing, the proper method is to write data and fill the balance with zeroes.

#### **TYPE III COMMANDS**

#### **Read Address**

Upon receipt of the Read Address command, the Busy Status Bit is set. The next encountered ID field is then read in from the disk, and 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 | SIDE<br>NUMBER | SECTOR<br>ADDRESS |   |   | CRC<br>2 |
|---------------|----------------|-------------------|---|---|----------|
| 1             | 2              | 3                 | 4 | 5 | 6        |

Although the CRC characters are transferred to the computer, the WD1770 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 so that a comparison can be made by the user. 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. All Gap, Header, and data bytes are assembled and transferred to the data register and DRQ's are generated for each byte. The accumulation of bytes is synchronized to each address mark encountered. An interrupt is generated at the completion of the command. This command has several characteristics which make it suitable for diagnostic purposes. They are: no CRC checking is performed; gap information is included in the data stream; and the address mark detector is on for the duration of the command. Because the AM detector is always on, write splices or noise may cause the chip to look for an AM.

The ID AM, ID field, ID CRC bytes, DAM, Data, and Data CRC Bytes for each sector will be correct. The Gap Bytes may be read incorrectly during write-splice time because of synchronization.

#### WRITE TRACK 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 with a large amount of memory. Data and gap information 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 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 within 3 byte times, 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 zeroes is substituted.

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 WD1770 detects a data pattern of F5 through FE in the data register, this is interpreted as data address marks with missing clocks or CRC generation.

| DATA PATTERN<br>IN DR (HEX) | IN FM (DDEN = 1)                       | IN MFM (DDEN = 0)             |
|-----------------------------|----------------------------------------|-------------------------------|
| 00 thru F4                  | Write 00 thru F4 with CLK = FF         | Write 00 thru F4, in MFM      |
| F5                          | Not Allowed                            | Write A1* in MFM, Present CRC |
| F6                          | Not Allowed                            | Write C2** in MFM             |
| F7                          | Generate 2 CRC bytes                   | Generate 2 CRC bytes          |
| F8 thru FB                  | Write F8 thru FB, CLK = C7, Preset CRC | Write F8 thru FB, in MFM      |
| FC                          | Write FC with CLK = D7                 | Write FC in MFM               |
| FD                          | Write FD with CLK = FF                 | Write FD in MFM               |
| FE                          | Write FE, CLK = C7, Preset CRC         | Write FE in MFM               |
| FF                          | Write FF with CLK = FF                 | Write FF in MFM               |

\*Missing clock transition between bits 4 and 5.

\*\*Missing clock transition between bits 3 and 4.

WD1770/1772



TYPE III COMMAND WRITE TRACK



#### **TYPE III COMMAND WRITE TRACK**

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. An F7 pattern will generate two CRC characters in FM or MFM. As a consequence, the patterns F5 through 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.

#### TYPE IV COMMANDS

The Forced Interrupt command is generally used to terminate a multiple sector read or write command or to insure Type I status in the status register. 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 the busy status bit reset.

The lower four bits of the command determine the conditional interrupt as follows:

- 10 = Don't Care
- I<sub>1</sub> = Don't Care
- I<sub>2</sub> = Every Index Pulse
- I<sub>3</sub> = Immediate Interrupt

The conditional interrupt is enabled when the corresponding bit positions of the command (13-10) are set to a 1. Then, when the condition for interrupt is met, the INTRQ line will go high signifying that the condition specified has occurred. If I3-I0 are all set to zero (HEX D0), no interrupt will occur but any command presently under execution will be immediately terminated. When using the immediate interrupt condition  $(I_3 = 1)$  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. The HEX D0 is the only command that will enable the immediate interrupt (HEX D8) to clear on a subsequent load command register or read status register operation. Follow a HEX D8 with D0 command.

Wait 16 micro sec (double density) or 32 micro sec (single density) before issuing a new command after issuing a forced interrupt. Loading a new command sooner than this will nullify the forced interrupt.

Forced interrupt stops any command at the end of an internal micro-instruction and generates INTRQ when the specified condition is met. Forced interrupt will wait until ALU operations in progress are complete (CRC calculations, compares, etc.).

#### **Status Register**

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 user has the option of reading the status register through program control or using the DRQ line with DMA or interrupt methods. When the Data register is read the DRQ bit in the status register and the DRQ line are automatically reset. A write to the Data register also causes both DRQ's to reset.

The busy bit in the status may be monitored with a user program to determine when a command is complete, in lieu of using the INTRQ line. When using the INTRQ, a busy status check is not recommended because a read of the status register to determine the condition of busy will reset the INTRQ line.

The format of the Status Register is shown below:

| (BITS) |                 |    |    |    |    |    |    |  |
|--------|-----------------|----|----|----|----|----|----|--|
| 7      | 7 6 5 4 3 2 1 0 |    |    |    |    |    |    |  |
| S7     | S6              | S5 | S4 | S3 | S2 | S1 | S0 |  |

#### **RECOMMENDED — 128 BYTES/SECTOR**

Shown below is the recommended 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.

| NUMBER<br>OF BYTES | HEX VALUE OF BYTE WRITTEN |
|--------------------|---------------------------|
| 40                 | FF (or 00)                |
| 6                  | 00 `                      |
| 1                  | FE (ID Address Mark)      |
| 1                  | Track Number              |
| 1                  | Side Number (00 or 01)    |
| 1                  | Sector Number (1 thru 1A) |
| 1                  | 00 (Sector Length)        |
| 1                  | F7 (2 CRC's written)      |
| 11                 | FF (or 00)                |
| 6                  | 00                        |
| 1                  | FB (Data Address Mark)    |
| 128                | Data (IBM uses E5)        |
| 1                  | F7 (2 CRC's written)      |
| 10                 | FF (or 00)                |
| 369**              | FF (or 00)                |

\*Write bracketed field 16 times.

\*\*Continue writing until WD1770 interrupts out. Approx. 369 bytes.

#### 256 BYTES/SECTOR

Shown below is the recommended 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.



WD1770/1772

| NUMBER   |                           |
|----------|---------------------------|
| OF BYTES | HEX VALUE OF BYTE WRITTEN |
| 60       | 4E                        |
| 12       | 00                        |
| 3        | F5 (Writes A1)            |
| 1        | FE (ID Address Mark)      |
| 1        | Track Number (0 thru 4C)  |
| 1        | Side Number (0 or 1)      |
| 1        | Sector Number (1 thru 1A) |
| 1        | 01 (Sector Length)        |
| 1        | F7 (2 CRC's written)      |
| 22       | 4E                        |
| 12       | 00                        |
| 3        | F5 (Writes A1)            |
| 1        | FB (Data Address Mark)    |
| 256      | DATA                      |
| 1        | F7 (2 CRC's written)      |
| 24       | 4E                        |
| 668**    | 4E                        |

\*Write bracketed field 16 times.

\*\*Continue writing until WD1770 interrupts out. Approx. 668 bytes.

#### 1. Non-Standard Formats

Variations in the recommended formats are possible to a limited extent if the following requirements are met:

- 1) Sector size must be 128, 256, 512 of 1024 bytes.
- 2) Gap 2 cannot be varied from the recommended format.
- 3) 3 bytes of A1 must be used in MFM.

In addition, the Index Address Mark is not required for operation by the WD1770 Gap 1, 3, and 4 lengths can be as short as 2 bytes for WD1770 operation, however PLL lock up time, motor speed variation, write-splice area, etc. will add more bytes to each gap to achieve proper operation. It is recommended that the recommended format be used for highest system reliability.

|           | FM                        | MFM                                     |
|-----------|---------------------------|-----------------------------------------|
| Gap I     | 16 bytes FF               | 32 bytes 4E                             |
| Gap II    | 11 bytes FF               | 22 bytes 4E                             |
| *         | 6 bytes 00                | 12 bytes 00<br>3 bytes A1               |
| Gap III** | 10 bytes FF<br>4 bytes 00 | 24 bytes 4E<br>8 bytes 00<br>3 bytes A1 |
| Gap IV    | 16 bytes FF               | 16 bytes 4E                             |

\*Byte counts must be exact.

\*\*Byte counts are minimum, except exactly 3 bytes of A1 must be written.

| BIT NAME                     | MEANING                                                                                                                                                                                                                                              |
|------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| S7 MOTOR ON                  | This bit reflects the status of the Motor On output.                                                                                                                                                                                                 |
| 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<br>TYPE/SPIN-UP    | When set, this bit indicates that the Motor Spin-Up sequence has completed (6 revolutions) on Type I commands. Type 2 & 3 commands, this bit indicates record Type. 0 = Data Mark. 1 = Deleted Data Mark.                                            |
| 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/<br>TRACK 00    | When set, it indicates the computer did not respond to DRQ in one byte time. This bit is reset to zero when update. On Type I commands, this bit reflects the status of the TRACK 00 Pin.                                                            |
| S1 DATA REQUEST/<br>INDEX    | This bit is a copy of the DRQ output. When set, it indicates the DR is full on a Read Operation or the DR is empty on a Write operation. This bit is reset to zero when updated. On Type I commands, this bit indicates the status of the Index Pin. |
| S0 BUSY                      | When set, command is under execution. When reset, no command is under execution.                                                                                                                                                                     |

#### DC ELECTRICAL CHARACTERISTICS

MAXIMUM RATINGS

| Storage Temperature   | 55°C to + 125°C     |
|-----------------------|---------------------|
| Operating Temperature | 0°C to 70°C Ambient |

Maximum Voltage to Any Input with Respect to VSS  $\dots \dots \dots \dots \dots (-15 \text{ to } -0.3 \text{V})$ 

#### STATUS REGISTER DESCRIPTION

#### DC OPERATING CHARACTERISTICS

| SYMBOL | CHARACTERISTIC      | MIN.     | MAX. | UNITS | CONDITIONS         |
|--------|---------------------|----------|------|-------|--------------------|
| ηL     | Input Leakage       |          | 10   | μA    | VIN = VCC          |
| IOL    | Output Leakage      |          | 10   | μA    | VOUT = VCC         |
| VIH    | Input High Voltage  | 2.0      |      | v     |                    |
| VIL    | Input Low Voltage   |          | 0.8  | v     |                    |
| Vон    | Output High Voltage | 2.4      |      | V V   | $I_0 = -100 \mu A$ |
| VOL    | Output Low Voltage  |          | 0.40 | v     | $l_0 = 1.6  mA$    |
| PD     | Power Dissipation   |          | .75  | w     |                    |
| RPU    | Internal Pull-Up    | 100      | 1700 | μA    | $V_{IN} = 0V$      |
| ICC    | Supply Current      | 75 (Typ) | 150  | mA    |                    |

#### TA = 0°C to 70°C, VSS = 0V, VCC = $+5V \pm .25V$

#### AC TIMING CHARACTERISTICS

 $TA = 0^{\circ}C$  to 70°C,  $V_{SS} = 0V$ ,  $V_{CC} = +5V \pm .25V$ 

#### **READ ENABLE TIMING** — $\overline{\text{RE}}$ such that : $\overline{\text{RW}} = 1, \overline{\text{CS}} = 0.$

| SYMBOL | CHARACTERISTIC       | MIN. | TYP. | MAX. | UNITS | CONDITIONS     |
|--------|----------------------|------|------|------|-------|----------------|
| TRE    | RE Pulse Width of CS | 150  |      |      | nsec  | $C_L = 50  pf$ |
| TDRR   | DRQ Reset from RE    |      | 25   | 100  | nsec  |                |
| TIRR   | INTRQ Reset from RE  |      |      | 8000 | nsec  |                |
| TDV    | Data Valid from RE   |      | 100  | 200  | nsec  | $C_L = 50  pf$ |
| TDOH   | Data Hold from RE    | 50   |      | 150  | nsec  | $C_L = 50  pf$ |

Note: DRQ and INTRQ reset are from rising edge (lagging) of RE, whereas resets are from falling edge (leading) of WE.

#### WRITE ENABLE TIMING — $\overline{WE}$ such that : $R/\overline{W} = 0$ , $\overline{CS} = 0$ .

| SYMBOL | CHARACTERISTIC                             | MIN. | TYP. | MAX. | UNITS | CONDITIONS |
|--------|--------------------------------------------|------|------|------|-------|------------|
| TAS    | Setup ADDR to CS                           | 50   |      |      | nsec  |            |
| TSET   | Setup R/ $\overline{W}$ to $\overline{CS}$ | 0    |      |      | nsec  |            |
| ТАН    | Hold ADDR from CS                          | 20   |      |      | nsec  |            |
| THLD   | Hold R/W from CS                           | 0    |      |      | nsec  |            |
| TWE    | WE Pulse Width                             | 150  |      |      | nsec  |            |
| TDRW   | DRQ Reset from WE                          |      | 100  | 200  | nsec  |            |
| TIRW   | INTRQ Reset from WE                        |      |      | 8000 | nsec  |            |
| TDS    | Data Setup to WE                           | 150  |      |      | nsec  |            |
| TDH    | Data Hold from WE                          | 0    |      |      | nsec  |            |

# WD1770/1772



**REGISTER TIMINGS**


WD1770/1772

WRITE DATA TIMING

# WRITE DATA TIMING:

| SYMBOL | CHARACTERISTIC           | MIN. | TYP.                      | MAX. | UNITS                        | CONDITIONS                                 |
|--------|--------------------------|------|---------------------------|------|------------------------------|--------------------------------------------|
| Twg    | Write Gate to Write Data |      | 4<br>2                    |      | μsec<br>μsec                 | FM<br>MFM                                  |
| Tbc    | Write Data Cycle Time    |      | 4,6,8                     |      | μsec                         |                                            |
| Twf    | Write Gate off from WD   |      | 4<br>2                    |      | μsec<br>μsec                 | FM<br>MFM                                  |
| Тwp    | Write Data Pulse Width   |      | 820<br>690<br>570<br>1380 |      | nsec<br>nsec<br>nsec<br>nsec | Early MFM<br>Nominal MFM<br>Late MFM<br>FM |

# INPUT DATA TIMING:

| SYMBOL | CHARACTERISTIC       | MIN. | TYP. | MAX. | UNITS | CONDITIONS |
|--------|----------------------|------|------|------|-------|------------|
| TPW    | Raw Read Pulse Width | 200  |      |      | nsec  |            |
| TBC    | Raw Read Cycle Time  | 3000 |      |      | nsec  |            |

# MISCELLANEOUS TIMING:

| SYMBOL           | CHARACTERISTIC           | MIN. | TYP.     | MAX. | UNITS | CONDITIONS |
|------------------|--------------------------|------|----------|------|-------|------------|
| TCD1             | Clock Duty (low)         | 50   | 67       |      | nsec  |            |
| TCD <sub>2</sub> | Clock Duty (high)        | 50   | 67       |      | nsec  |            |
| TSTP             | Step Pulse Output        |      | 4<br>8   |      | µsec  | MFM<br>FM  |
| TDIR             | Dir Setup to Step        |      | 24<br>48 |      | μsec  | MFM<br>FM  |
| TMR              | Master Reset Pulse Width | 50   |          |      | μsec  |            |
| TIP              | Index Pulse Width        | 20   |          |      | µsec  |            |



**MISCELLANEOUS TIMING** 

See page 481 for ordering information.

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

# Western digital R



# WD1773 5<sup>1</sup>/<sub>4</sub>" Floppy Disk Controller/Formatter

#### **FEATURES**

100% SOFTWARE COMPATIBILITY WITH WD1793

C

0

Ρ

Ω

- BUILT-IN DATA SEPARATOR
- BUILT-IN WRITE PRECOMPENSATION
- SINGLE (FM) AND DOUBLE (MFM) DENSITY
- 28 PIN DIP, SINGLE + 5V SUPPLY
- TTL COMPATIBLE INPUTS/OUTPUTS
- 128, 256, 512 OR 1024 SECTOR LENGTHS
- 8-BIT BI-DIRECTIONAL HOST INTERFACE



#### PIN DESIGNATION

#### DESCRIPTION

The WD1773 is an MOS/LSI device which performs the functions of a 51/4" Floppy Disk Controller/ Formatter. It is fully software compatible with the Western Digital WD1793-02, allowing the designer to reduce parts count and board size on an existing WD1793 based design without software modifications.

With the exception of the enable Precomp/Ready line, the WD1773 is identical to the WD1770 controller. This line serves as both a READY input from the drive during READ/STEP operations, and as a Write Precompensation enable during Write operations. A built-in digital data separator virtually eliminates all external components associated with data recovery in previous designs.

The WD1773 is implemented in NMOS silicon gate technology and is available in a 28 pin, dual-in-line package.

#### PIN DESCRIPTION

| 5        |
|----------|
| <        |
| D        |
| <u> </u> |
| N        |
| Z        |
| ω        |

| PIN<br>NUMBER | PIN NAME                         | SYMBOL    | FUNCTION                                                                                                                                                                           |
|---------------|----------------------------------|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1             | CHIPSELECT                       | CS        | A logic low on this input selects the chip and enable Host communication with the device.                                                                                          |
| 2             | READ/WRITE                       | R/W       | A logic high on this input controls the<br>placement of data on the D0-D7 lines from a<br>selected register, while a logic low causes a<br>write operation to a selected register. |
| 3,4           | ADDRESS 0,1                      | A0, A1    | These two inputs select a register to Read/Write data:<br>$\overrightarrow{CS}$ A1 A0 $\overrightarrow{RW}$ = 1 $\overrightarrow{R/W}$ = 0                                         |
|               |                                  |           | CSA1A0R/W = 1R/W = 0000Status RegCommand Reg001Track RegTrack Reg010Sector RegSector Reg010Sector RegData Reg                                                                      |
| 5-12          | DATA ACCESS LINES<br>0 THROUGH 7 | DAL0-DAL7 | Eight bit bidirectional bus used for transfer of<br>data, control, or status. This bus is enabled by<br>CS and R/W. Each line will drive one TTL load.                             |
| 13            | MASTER RESET                     | MR        | A logic low pulse on this line resets the device and initializes the status register.                                                                                              |
| 14            | GROUND                           | GND       | Ground.                                                                                                                                                                            |
| 15            | POWER SUPPLY                     | VCC       | + 5V $\pm$ 5% power supply input.                                                                                                                                                  |
| 16            | STEP                             | STEP      | The Step output contains a pulse for each step<br>of the drive's R/W head. The WD1770 and<br>WD1772 offer different step rates.                                                    |
| 17            | DIRECTION                        | DIRC      | The Direction output is high when stepping in towards the center of the diskette, and low when stepping out.                                                                       |
| 18            | CLOCK                            | CLK       | This input requires a free-running 50% duty cycle clock (for internal timing) at 8 MHZ $\pm$ 1%.                                                                                   |
| 19            | READ DATA                        | RD        | This active low input is the raw data line<br>containing both clock and data pulses from the<br>drive.                                                                             |
| 20            | ENABLE PRECOMP/<br>READY LINE    | ENP/RDY   | Serves as a READY input from the drive during<br>READ/STEP operations and as a Write Precomp<br>enable during write operations.                                                    |
| 21            | WRITE GATE                       | WG        | This output is made valid prior to writing on the diskette.                                                                                                                        |
| 22            | WRITE DATA                       | WD        | FM or MFM clock and data pulses are placed on this line to be written on the diskette.                                                                                             |
| 23            | TRACK 00                         | TROO      | This active low input informs the WD1770 that the drive's R/W heads are positioned over Track zero.                                                                                |
| 24            | INDEX PULSE                      | ĪP        | This active low input informs the WD1770 when<br>the physical index hole has been encountered<br>on the diskette.                                                                  |
| 25            | WRITE PROTECT                    | WPRT      | This input is sampled whenever a Write<br>Command is received. A logic low on this<br>line will prevent any Write Command from<br>executing.                                       |
| 26            | DOUBLE DENSITY<br>ENABLE         | DDEN      | This input pin selects either single (FM) or<br>double (MFM) density. When DDEN = 0, double<br>density is selected.                                                                |

# PIN DESCRIPTION (CONTINUED)

| PIN<br>NUMBER | PIN NAME          | SYMBOL | FUNCTION                                                                                                            |
|---------------|-------------------|--------|---------------------------------------------------------------------------------------------------------------------|
| 27            | DATA REQUEST      | DRQ    | This active high output indicates that the Data<br>Register is full (on a Read) or empty (on a Write<br>operation). |
| 28            | INTERRUPT REQUEST | INTRQ  | This active high output is set at the completion of any command or reset a read of the Status Register.             |

WD1773

See page 481 for ordering information.

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

# WESTERN DIGITAL

WD1770/72/73 5<sup>1</sup>/<sub>4</sub>" Floppy Disk Controller/Formatter Family Application Notes

#### INTRODUCTION

To meet the demand for a low cost compact LSI Floppy Disk Controller device, Western Digital has developed the WD1770. The WD1770 is a NMOS floppy disk controller device for 51/4 " drives that incorporates the FD179X, a digital data separator and write precompensation circuitry all in a single chip. The device offers soft sector formatting, selectable stepping rates, automatic track seek with verify, and variable sector lengths. The FD1770 comes in a 28-pin dual-in-line package and operates from a single 5 volt only power supply.

#### APPLICATIONS

The mini-floppy controller is targeted for the low cost sector of the disk drive market, where digital data separation is preferred over analog phase lock loop. Included in this market are Personal Computers, Portable Computers and Small Business Computers.

#### FOLLOW ON DEVICES

#### WD1772

The device will be the same as the WD1770 except for increased stepping rates of 2, 3, 5 and 6ms.

#### WD1773

The device will be the same as the WD1770 except that it will be totally software compatible with the FD179X (No motor on feature).

#### HOST INTERFACING

Interfacing to a host processor is accomplished through the eight bit bidirectional Data Access Lines (DAL) and associated control lines. The DAL is used to transfer data, status and control words out of or into WD1770. The DAL having three states enabled as an output when Chip Select ( $\overline{CS}$ ) is active low and Read/Write (R/W) is high or as input receiver when  $\overline{CS}$  and R/W is low. When transfer of data with the device

is required by the host  $\overline{CS}$  is made low. The address bits A0 and A1 combined with the R/W line select the register and direction of data.

During Direct Memory Access (DMA) data transfers between the WD1770 and Host Memory, the Data Request (DRQ) line is used in Data Transfer Control. This signal also appears as status bit 1 during Read/ Write operations. On Disk Read operations the DRQ is active when an assembled byte is present in the Data Register, then reset when read by the Host. If the Host fails to read the Data register before the following byte is assembled in the data register the lost data bit is set in Status Register.

At the completion of every command INTRQ is generated. INTRQ is reset by either reading the status or by loading the command register. (After any register is written to the same register cannot be read from until 16µsec in MFM or 32µsec in FM have elasped.)

# DISKETTE DRIVE INTERFACING

The WD1770 has two modes of operation depending on the state of DDEN, regardless of the state DDEN the CLK input remains at 8 MHz. Disk Reads with sector lengths of 128, 256, 512 and 1024 byte sector in both FM or MFM from 51/4" diskettes is accomplished via the internal digital data separator. Disk Write operation in MFM on inner tracks may require write precompensation. Write precompensation is enabled when bit 1 = 0, in the write command and a precompensation value of 125 ns will be produced.

The diskettes spindle motor is controlled by bit 3 of any Type I, II or III command, upon receiving a command with bit 3 = 0, the spin up sequence is enabled.

#### **GENERAL INFORMATION**

A +5 volt supply  $\pm$ 5% should be used as V<sub>CC</sub>, and the clock input requires a free running 50% duty cycle at 8 MHz  $\pm$  1%.

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

#### WESTERN DIGITAL 0 ſ. 0 R P O N

# FD179X-02 Floppy Disk Formatter/Controller Family

#### FEATURES

- TWO VFO CONTROL SIGNALS RG & VFOE
- 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) Non IBM Format for Increased Capacity
- READ MODE
  - Single/Multiple Sector Read with Automatic Search or Entire Track Read

Selectable 128, 256, 512 or 1024 Byte Sector Lengths 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
- INTERFACES TO WD1691 DATA SEPARATOR
- WINDOW EXTENSION

Τ

- INCORPORATES ENCODING/DECODING AND ADDRESS MARK CIRCUITRY
- FD1792/4 IS SINGLE DENSITY ONLY
- FD1795/7 HAS A SIDE SELECT OUTPUT

#### 179X-02 FAMILY CHARACTERISTICS

| FEATURES              | 1791 | 1792 | 1793 | 1794 | 1795 | 1797 |
|-----------------------|------|------|------|------|------|------|
| Single Density (FM)   | Х    | Х    | X    | Х    | Х    | Х    |
| Double Density (MFM)  | Х    |      | Х    |      | Х    | Х    |
| True Data Bus         |      |      | X    | Х    |      | Х    |
| Inverted Data Bus     | Х    | X    |      |      | Х    |      |
| Write Precomp         | Х    | X    | Х    | Х    | Х    | Х    |
| Side Selection Output |      |      |      |      | Х    | Х    |

#### APPLICATIONS

8" FLOPPY AND 51/4" MINI FLOPPY CONTROLLER SINGLE OR DOUBLE DENSITY CONTROLLER/FORMATTER



#### FD179X SYSTEM BLOCK DIAGRAM

| Т        |
|----------|
|          |
| <u> </u> |
| N        |
| Q        |
| ×        |
| ò        |
| 5        |

| 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 (50 microseconds min.) on this input resets the device and loads HEX 03 into the command register. The Not Ready (Status Bit 7) is reset during $\overline{MR}$ ACTIVE. When $\overline{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            |                       | Vcc       | $+5V \pm 5\%$                                                                                                                                                                                                                                                                                                                                                               |
| 40            |                       | Vdd       | + 12V ±5%                                                                                                                                                                                                                                                                                                                                                                   |
| COMPUTE       | R INTERFACE:          |           |                                                                                                                                                                                                                                                                                                                                                                             |
| 2             | WRITE ENABLE          | WE        | A logic low on this input gates data on the DAL into the selected register when $\overline{\text{CS}}$ is low.                                                                                                                                                                                                                                                              |
| 3             | CHIP SELECT           | ĈŜ        | 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{CS}$ is low.                                                                                                                                                                                                                                                   |
| 5,6           | REGISTER SELECT LINES | A0, A1    | These inputs select the register to receive/transfer data on the DAL lines under $\overline{\text{RE}}$ and $\overline{\text{WE}}$ control:                                                                                                                                                                                                                                 |
|               |                       |           | CS A1 A0 RE WE                                                                                                                                                                                                                                                                                                                                                              |
|               |                       |           | 000Status RegCommand Reg001Track RegTrack Reg010Sector RegSector Reg011Data RegData Reg                                                                                                                                                                                                                                                                                     |
| 7-14          | DATA ACCESS LINES     | DALO-DAL7 | Eight bit Bidirectional bus used for transfer of data, control,<br>and status. This bus is receiver enabled by $\overline{WE}$ or transmitter<br>enabled by $\overline{RE}$ . Each line will drive 1 standard TTL load.                                                                                                                                                     |
| 24            | CLOCK                 | CLK       | This input requires a free-running 50% duty cycle square wave clock for internal timing reference, 2 MHz $\pm$ 1% for 8" drives, 1 MHz $\pm$ 1% for mini-floppies.                                                                                                                                                                                                          |
| 38            | DATA REQUEST          | DRQ       | This open drain output indicates that the DR contains<br>assembled data in Read operations, or the DR is empty in<br>Write operations. This signal is reset when serviced by the<br>computer through reading or loading the DR in Read or Write<br>operations, respectively. Use 10K pull-up resistor to +5.                                                                |
| 39            | INTERRUPT REQUEST     | INTRQ     | This open drain output is set at the completion of any com-<br>mand and is reset when the STATUS register is read or the<br>command register is written to. Use 10K pull-up resistor to<br>+5.                                                                                                                                                                              |
| FLOPPY D      | ISK INTERFACE:        |           |                                                                                                                                                                                                                                                                                                                                                                             |
| 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 occuring while Early is<br>active (high) should be shifted early for write precom-<br>pensation.                                                                                                                                                                                                                                        |
| 18            | LATE                  | LATE      | Indicates that the write data pulse occurring while Late is active (high) should be shifted late for write precompensation.                                                                                                                                                                                                                                                 |

| PIN<br>NUMBER | PIN NAME                              | SYMBOL   | FUNCTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|---------------|---------------------------------------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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 steppers.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 23            | HEAD LOAD TIMING                      | HLT      | When a logic high is found on the HLT input the head is<br>assumed to be engaged. It is typically derived from a 1 shot<br>triggered by HLD.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 25            | READ GATE<br>(1791, 1792, 1793, 1794) | RG       | This output is used for synchronization of external data<br>separators. The output goes high after two Bytes of zeros in<br>single density, or 4 Bytes of either zeros or ones in double<br>density operation.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 25            | SIDE SELECT OUTPUT<br>(1795, 1797)    | SSO      | The logic level of the Side Select Output is directly controlled<br>by the 'S' flag in Type II or III commands. When $U = 1$ , SSO is<br>set to a logic 1. When $U = 0$ , SSO is set to a logic 0. The SSO<br>is compared with the side information in the Sector I.D. Field.<br>If they do not compare Status Bit 4 (RNF) is set. The Side<br>Select Output is only updated at the beginning of a Type II or<br>III command. It is forced to a logic 0 upon a MASTER RESET<br>condition.                                                                                                                                                                                                                                                                                     |
| 26            | READ CLOCK                            | RCLK     | A nominal square-wave clock signal derived from the data<br>stream must be provided to this input. Phasing (i.e. RCLK<br>transitions) relative to RAW READ is important but polarity<br>(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<br>against the media.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 29            | TRACK GREATER THAN 43                 | TG43     | This output informs the drive that the Read/Write head is<br>positioned between tracks 44-76. This output is valid only<br>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 200 ns (MFM) or 500 ns (FM) output pulse per flux transition.<br>WD contains the unique Address marks as well as data and<br>clock in both FM and MFM formats.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 32            | READY                                 | READY    | This input indicates disk readiness and is sampled for a logic<br>high before Read or Write commands are performed. If Ready<br>is low the Read or Write operation is not performed and an<br>interrupt is generated. Type I operations are performed<br>regardless of the state of Ready. The Ready input appears in<br>inverted format as Status Register bit 7.                                                                                                                                                                                                                                                                                                                                                                                                            |
| 33            | WRITE FAULT<br>VFO ENABLE             | WF/VFOE  | This is a bi-directional signal used to signify writing faults at the drive, and to enable the external PLO data separator. When WG = 1, Pin 33 functions as a WF input. If WF = 0, any write command will immediately be terminated. When WG = 0, Pin 33 functions as a VFOE output. VFOE will go low during a read operation after the head has loaded and settled (HLT = 1). On the 1795/7, it will remain low until the last bit of the second CRC byte in the ID field. VFOE will then go high until 8 bytes (MFM) or 4 bytes (FM) before the Address Mark. It will then go active until the last bit of the second CRC byte of the Data Field. On the 1791/3, VFOE will remain low until the end of the Data Field. This pin has an internal 100K Ohm pull-up resistor. |
| 34            | TRACK 00                              | TR00     | This input informs the FD179X that the Read/Write head is positioned over Track 00.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |

| PIN NUMBER | PIN NAME       | SYMBOL | FUNCTION                                                                                                                                                                                                                                     |
|------------|----------------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 35         | INDEX PULSE    | ĪP     | 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.<br>A logic low terminates the command and sets the Write<br>Protect Status bit.                                                                                                  |
| 37         | DOUBLE DENSITY | DDEN   | This input pin selects either single or double density operation. When $\overline{\text{DDEN}} = 0$ , double density is selected. When $\overline{\text{DDEN}} = 1$ , single density is selected. This line must be left open on the 1792/4. |

#### **GENERAL DESCRIPTION**

The FD179X are N-Channel Silicon Gate 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 bi-directional 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 TTL compatible on all inputs and outputs. The outputs will drive ONE TTL load or three LS loads. The 1793 is identical to the 1791 except the DAL lines are TRUE for systems that utilize true data busses.

The 1795/7 has a side select output for controlling double sided drives, and the 1792 and 1794 are "Single Density Only" versions of the 1791 and 1793 respectively. On these devices, DDEN must be left open.

#### 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). 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.

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 FD179X 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



#### FD179X BLOCK DIAGRAM

density (FM) is assumed. 1792 & 1794 are single density only.

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 (RE) are active (low logic state) or act as input receivers when CS and Write Enable (WE) are active.

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

| <b>A</b> 1 | - A0 | READ (RE)       | WRITE (WE)       |
|------------|------|-----------------|------------------|
| 0          | 0    | Status Register | Command 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.

The 179X has two modes of operation according to the state of  $\overline{\text{DDEN}}$  (Pin 37). When  $\overline{\text{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.

#### **GENERAL 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 the fourth byte in the "ID" field.

| Sector L      | ength Table*        |
|---------------|---------------------|
| Sector Length | Number of Bytes     |
| Field (hex)   | in Sector (decimal) |
| 00            | 128                 |
| 01            | 256                 |
| 02            | 512                 |
| 03            | 1024                |

\*1795/97 may vary --- see command summary.

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 in 8" double density the FD179X requires RAW READ Data (Pin 27) signal which is a 200 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) on 1791/92/93/94 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{VFOE}$  (Pin 33) is provided for phase lock loop synchronization.  $\overline{VFOE}$  will go active low 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 WF/VFOE is not used, leave open or tie to a 10K resistor to +5.

#### **GENERAL 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{\text{DDEN}} = 1$ ) and 200 ns pulses in MFM ( $\overline{\text{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.

#### READY

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 1. TABLE 1. COMMAND SUMMARY.

FD179X-02

| <u>A.</u> C | ommands for Mode | els: 1791, 17 | 92, 17 | 93, 17 | 94 |    |    |    |      | B. Co | omma | nds fo | r Mod | els: 17 | '95, 17 | 97 |    |
|-------------|------------------|---------------|--------|--------|----|----|----|----|------|-------|------|--------|-------|---------|---------|----|----|
|             | Bits             |               |        |        |    |    |    |    | Bits |       |      |        |       |         |         |    |    |
| Туре        | Command          | 7             | 6      | 5      | 4  | 3  | 2  | 1  | 0    | 7     | 6    | 5      | 4     | 3       | 2       | 1  | 0  |
| 1           | Restore          | 0             | 0      | 0      | 0  | h  | ٧  | r1 | ro   | 0     | 0    | 0      | 0     | h       | v       | r1 | ro |
| T           | Seek             | 0             | 0      | 0      | 1  | h  | V  | r1 | ro   | 0     | Ō    | Ō      | 1     | h       | v       | ri | ro |
| 1           | Step             | 0             | 0      | 1      | Т  | h  | V  | r1 | ro   | 0     | 0    | 1      | T     | h       | v       | rj | ro |
| I           | Step-in          | 0             | 1      | 0      | Т  | h  | v  | r1 | ro   | 0     | 1    | 0      | т     | h       | v       | r1 | ro |
| 1           | Step-out         | 0             | 1      | 1      | Т  | h  | V  | r٩ | ro   | 0     | 1    | 1      | Т     | h       | v       | rj | ro |
| 11          | Read Sector      | 1             | 0      | 0      | m  | S  | Е  | С  | 0    | 1     | 0    | 0      | m     | L       | E       | U  | Ō  |
| 11          | Write Sector     | 1             | 0      | 1      | m  | S  | Е  | С  | a0   | 1     | 0    | 1      | m     | Ē       | Е       | Ū  | ao |
| 111         | Read Address     | 1             | 1      | 0      | 0  | 0  | Е  | 0  | 0    | 1     | 1    | 0      | 0     | 0       | Е       | U  | 0  |
| 111         | Read Track       | 1             | 1      | 1      | 0  | 0  | Е  | 0  | 0    | 1     | 1    | 1      | 0     | 0       | Е       | U  | 0  |
| 111         | Write Track      | 1             | 1      | 1      | 1  | 0  | Е  | 0  | 0    | 1     | 1    | 1      | 1     | 0       | Е       | U  | Ó  |
| IV          | Force Interrupt  | 1             | 1      | 0      | 1  | lз | 12 | 11 | l0   | 1     | 1    | 0      | 1     | lз      | I2      | l1 | 10 |

#### FLAG SUMMARY

#### TABLE 2. FLAG SUMMARY

| Command<br>Type | Bit<br>No(s) |                                                                                                                                                                                                                                                                                                    | Description                                                                                |  |
|-----------------|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------|--|
| 1               | 0, 1         | <sup>r</sup> 1 <sup>r</sup> 0 = Stepping Motor Rate<br>See Table 3 for Rate Summary                                                                                                                                                                                                                |                                                                                            |  |
| I               | 2            | V = Track Number Verify Flag                                                                                                                                                                                                                                                                       | V = 0, No verify<br>V = 1, Verify on destination track                                     |  |
| I               | 3            | h = Head Load Flag                                                                                                                                                                                                                                                                                 | <ul> <li>h = 1, Load head at beginning</li> <li>h = 0, Unload head at beginning</li> </ul> |  |
| I               | 4            | T = Track Update Flag                                                                                                                                                                                                                                                                              | T = 0, No update<br>T = 1, Update track register                                           |  |
| Н               | 0            | <sup>a</sup> 0 = Data Address Mark                                                                                                                                                                                                                                                                 | <sup>a</sup> 0 = 0, FB (DAM)<br><sup>a</sup> 0 = 1, F8 (deleted DAM)                       |  |
| 11              | 1            | C = Side Compare Flag                                                                                                                                                                                                                                                                              | C = 0, Disable side compare<br>C = 1, Enable side compare                                  |  |
| 11 & 111        | 1            | U = Update SSO                                                                                                                                                                                                                                                                                     | U = 0, Update SSO to 0<br>U = 1, Update SSO to 1                                           |  |
| &               | 2            | E = 15 MS Delay                                                                                                                                                                                                                                                                                    | E  =  0, No 15 MS delay<br>E  =  1, 15 MS delay                                            |  |
| II              | 3            | S = Side Compare Flag                                                                                                                                                                                                                                                                              | S = 0, Compare for side 0<br>S = 1, Compare for side 1                                     |  |
| II              | 3            | L = Sector Length Flag                                                                                                                                                                                                                                                                             | LSB's Sector Length in ID Field<br>00 01 10 11                                             |  |
|                 |              |                                                                                                                                                                                                                                                                                                    | L = 0  256  512  1024  128                                                                 |  |
| 11              | 4            | m = Multiple Record Flag                                                                                                                                                                                                                                                                           | $\begin{array}{ c c c c c c c c c c c c c c c c c c c$                                     |  |
| IV              | 0-3          | Ix       = Interrupt Condition Flags         I0       = 1 Not Ready To Ready Transition         I1       = 1 Ready To Not Ready Transition         I2       = 1 Index Pulse         I3       = 1 Immediate Interrupt, Requires A Reset         I3·I0       = 0 Terminate With No Interrupt (INTRQ) |                                                                                            |  |

\*NOTE: See Type IV Command Description for further information.

.

### 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 (r0 r1), which determines the stepping motor rate as defined in Table 3.

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. The chip will step the drive in the same direction it last stepped unless the command changes the direction.

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.

The rates (shown in Table 3) can be applied to a Step-Direction Motor through the device interface.

| С      | _K | 2 MHz  | 2 MHz  | 1 MHz  | 1 MHz  | 2 MHz  | 1 MHz  |
|--------|----|--------|--------|--------|--------|--------|--------|
| DD     | EN | 0      | 1      | 0      | 1      | ×      | x      |
| <br>R1 | RO | TEST=1 | TEST=1 | TEST=1 | TEST=1 | TEST=0 | TEST=0 |
| 0      | 0  | 3 ms   | 3 ms   | 6 ms   | 6 ms   | 184µs  | 368µs  |
| 0      | 1  | 6 ms   | 6 ms   | 12 ms  | 12 ms  | 190µs  | 380µs  |
| . 1    | 0  | 10 ms  | 10 ms- | 20 ms  | 20 ms  | 198µs  | 396µs  |
| 1      | 1  | 15 ms  | 15 ms  | 30 ms  | 30 ms  | 208µs  | 416µs  |
|        |    |        |        |        |        |        |        |

TABLE 3. STEPPING RATES

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.

When a Seek, Step or Restore command is executed an optional verification of Read-Write head position can be performed by settling 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. 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.

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. If V = 0, no verification is performed.

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 status Bit 5 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.

#### **RESTORE (SEEK TRACK 0)**

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 an interrupt is generated. If TR00 is not active low, stepping pulses (pins 15 to 16) at a rate specified by the 1 r0 field are issued until the TR00 input is activated. At this time the Track Register is loaded with zeroes and an interrupt is generated. If the TR00 is not go active low after 255 stepping pulses, the FD179X terminates operation, interrupts, and sets the Seek error status bit, providing the V flag is set. A verification operation also 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 MR goes from an active to an inactive state and that the DRQ pin stays low.

#### 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



#### TYPE I COMMAND FLOW

the Data Register (the desired track location). A verification operation takes place if the V flag is on. The h bit allows the head to be loaded at the start of the command. An interrupt is generated at the completion of the command. Note: When using multiple drives, the track register must be updated for the drive selected before seeks are issued.

#### 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 <sup>r</sup>1<sup>r</sup>0 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



#### TYPE I COMMAND FLOW

flag is on, the Track Register is incremented by one. After a delay determined by the <sup>r</sup>1<sup>r</sup>0 field, a verification takes place if the V flag is on. The h bit allows the head to be loaded at the start of the command. An interrupt is generated at the completion of the command.

#### STEP-OUT

Upon receipt of this command, the 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 <sup>r</sup>1<sup>r</sup>0 field, a verification takes place if the V flag is on. The h bit allows the head to be loaded at the start of the command. An interrupt is generated at the completion of the command.

#### EXCEPTIONS

On the 1795/7 devices, the SSO output is not affected during Type 1 commands, and an internal side compare does not take place when the (V) Verify Flag is on.



TYPE I COMMAND FLOW

#### **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 13.

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.



#### TYPE II COMMAND

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 in numerical ascending sequence until the sector register exceeds the number of sectors on the track or until the Force Interrupt command is loaded into the Command Register, which terminates the command and generates an interrupt.

For example: If the FD179X is instructed to read sector 27 and there are only 26 on the track, the sector register exceeds the number available. The FD179X will search for 5 disk revolutions, interrupt out, reset busy, and set the record not found status bit.

The Type II commands for 1791-94 also contain side select compare flags. When C = 0 (Bit 1) 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 (Bit 3). If the S flag compares with the side number recorded in the ID field, the FD179X 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.

HAVE INDEX HOLE PASSED

DAM

BEEN

DOES TRACI

ìг

NC

NC

SET CRC STATUS ERROF NO

INTRO, RESET BUSY

The Type II and III commands for the 1795-97 contain a side select flag (Bit 1). When U = 0, SSO is updated to 0. Similarly, U = 1 updates SSO to 1. The chip compares the SSO to the ID field. If they do not compare within 5 revolutions the interrupt line is made active and the RNF status bit is set.

The 1795/7 READ SECTOR and WRITE SECTOR commands include a 'L' flag. The 'L' flag, in conjunction with the sector length byte of the ID Field, allows different byte lengths to be implemented in each sector. For IBM compatability, the 'L' flag should be set to a one.

#### 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







#### TYPE II COMMAND

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 ID field is searched for and verified again followed by the Data Address Mark search. If after 5 revolutions the DAM cannot be found, the Record Not Found status bit is set and the operation is terminated. When the first character or byte of the data field has been shifted through the DSR, it is transferred to the DR, and DRQ is generated. When the next byte is accumulated in the DSR, it is transferred to the DR and another DRQ is generated. If the Computer has not read the previous contents of the DR before a new character is transferred that character is lost and the Lost Data Status bit is set. This sequence continues until the complete data field has been inputted to the computer. If there is a CRC error at the end of the data field, the CRC error status bit is set, and the command is terminated (even if it is a multiple record command).

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

# STATUS

BIT5

Deleted Data Mark Data Mark

0 Data Mark

#### 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 zeroes 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 <sup>2</sup>0 field of the command as shown below:

| ao | Data Address Mark (Bit 0) |  | _ |
|----|---------------------------|--|---|
| 1  | Deleted Data Mark         |  |   |
| 0  | Data Mark                 |  |   |
|    |                           |  |   |

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 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 by one byte of logic ones in FM or in MFM. The WG output is then deactivated. For a 2 MHz clock the INTRQ will set 8 to 12  $\mu$ sec after the last CRC byte is written. For partial sector writing, the proper method is to write the data and fill the balance with zeroes. By letting the chip fill the zeroes, errors may be masked by the lost data status and improper CRC Bytes.

#### TYPE III COMMANDS

#### READ ADDRESS

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

| TRACK |   | SECTOR<br>ADDRESS | SECTOR | CRC | CRC |
|-------|---|-------------------|--------|-----|-----|
| 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 so that a comparison can be made by the user. 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. All Gap, Header, and data bytes are assembled and transferred to the data register and DRQ's are generated for each byte. The accumulation of bytes is synchronized to each address mark encountered. An interrupt is generated at the completion of the command.

This command has several characteristics which make it suitable for diagnostic purposes. They are: the Read Gate



is not activated during the command; no CRC checking is performed; gap information is included in the data stream; the internal side compare is not performed; and the address mark detector is on for the duration of the command. Because the A.M. detector is always on, write splices or noise may cause the chip to look for an A.M. If an address mark does not appear on schedule the Lost Data status flag is set.

The ID A.M., ID field, ID CRC bytes, DAM, Data, and Data CRC Bytes for each sector will be correct. The Gap Bytes may be read incorrectly during write-splice time because of synchronization.



#### CONTROL BYTES FOR INITIALIZATION

| DATA PATTERN                                                       | FD179X INTERPRETATION                                                                                                                                                                                                           | FD1791/3 INTERPRETATION                                                                                                                                                                                       |
|--------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| IN DR (HEX)                                                        | IN FM (DDEN = 1)                                                                                                                                                                                                                | IN MFM (DDEN = 0)                                                                                                                                                                                             |
| 00 thru F4<br>F5<br>F6<br>F7<br>F8 thru FB<br>FC<br>FD<br>FE<br>FF | Write 00 thru F4 with CLK = FF<br>Not Allowed<br>Generate 2 CRC bytes<br>Write F8 thru FB, Clk = C7, Preset CRC<br>Write FC with Clk = D7<br>Write FD with Clk = FF<br>Write FE, Clk = C7, Preset CRC<br>Write FF with Clk = FF | Write 00 thru F4, in MFM<br>Write A1* in MFM, Preset CRC<br>Write C2** in MFM<br>Generate 2 CRC bytes<br>Write F8 thru FB, in MFM<br>Write FC in MFM<br>Write FD in MFM<br>Write FE in MFM<br>Write FF in MFM |

\*Missing clock transition between bits 4 and 5

#### WRITE TRACK 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 with a large amount of memory. Data and gap information 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 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 zeroes is substituted.

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.

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. 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.

#### TYPE IV COMMANDS

The Forced Interrupt command is generally used to terminate a multiple sector read or write command or to in\*\*Missing clock transition between bits 3 & 4

sure Type I status in the status register. 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 the busy status bit reset.

The lower four bits of the command determine the conditional interrupt as follows:

- I0 = Not-Ready to Ready Transition
- 1 = Ready to Not-Ready Transition
- I2 = Every Index Pulse
- <sup>1</sup>3 = Immediate Interrupt

The conditional interrupt is enabled when the corresponding bit positions of the command  $(^{1}3 \cdot ^{1}0)$  are set to a 1. Then, when the condition for interrupt is met, the IN-TRQ line will go high signifying that the condition specified has occurred. If  $^{1}3 \cdot ^{1}0$  are all set to zero (HEX D0), no interrupt will occur but any command presently under execution will be immediately terminated. When using the immediately generated and the current command terminated. Reading the status or writing to the command register will not automatically clear the interrupt. The HEX D0 is the only command that will enable the immediate interrupt (HEX D8) to clear on a subsequent load command register or read status register operation. Follow a HEX D8 with D0 command.

Wait 8 micro sec (double density) or 16 micro sec (single density before issuing a new command after issuing a forced interrupt (times double when clock = 1 MHz). Loading a new command sooner than this will nullify the forced interrupt.

Forced interrupt stops any command at the end of an internal micro-instruction and generates INTRQ when the specified condition is met. Forced interrupt will wait until ALU operations in progress are complete (CRC calculations, compares, etc.).

More than one condition may be set at a time. If for example, the READY TO NOT-READY condition  $(^{1}1 = 1)$  and the Every Index Pulse  $(^{1}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.

READ TRACK SEQUENCE ENTER A FD179X-02 SET BUSY RESET STATUS BITS 2, 4, 5 INDEX PULSE ? NO NO INTRQ RESET BUSY YES READY ? YES SHIFT ONE BIT COPY'S FLAG TO SSO LINE (1795/7 ONLY) YES SET INTRO RESET BUSY INDEX PULSE SET HLD NO ADDRESS MARK DETECTED YES NO E=1 ? NO YES HAVE 8 BITS BEEN ASSEMBLED NO DELAY 15MS\* YES NO HLT=1 ? IS DR EMPTY NO SET LOST DATA BIT YES YES TG43 UPDATE TRANSFER DSR TO DR NO RÉAD TRACK SET 2 DRQ READ ADDRESS YES в **TYPE III COMMAND** "If TEST = 0, NO DELAY

Read Track/Address

If TEST=1 and CLK=1 MHZ, 30 MS DELAY



FD179X-02

#### STATUS REGISTER

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 user has the option of reading the status register through program control or using the DRQ line with DMA or interrupt methods. When the Data register is read the DRQ bit in the status register and the DRQ line are automatically reset. A write to the Data register also causes both DRQ's to reset.

The busy bit in the status may be monitored with a user program to determine when a command is complete, in lieu of using the INTRQ line. When using the INTRQ, a busy status check is not recommended because a read of the status register to determine the condition of busy will reset the INTRQ line.

The format of the Status Register is shown below:

|    |    |    | (Bl | TS) |    |            |    |
|----|----|----|-----|-----|----|------------|----|
| 7  | 6  | 5  | 4   | 3   | 2  | 1          | 0  |
| S7 | S6 | S5 | S4  | S3  | S2 | <b>S</b> 1 | S0 |

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

Because of internal sync cycles, certain time delays must be observed when operating under programmed I/O. They are: (times double when clock = 1 MHz)

|                          |                                 | Delay Req'd. |      |  |
|--------------------------|---------------------------------|--------------|------|--|
| Operation                | Next Operation                  | FM           | MFM  |  |
| Write to<br>Command Reg. | Read Busy Bit<br>(Status Bit 0) | 12 µs        | 6µs  |  |
| Write to<br>Command Reg. | Read Status<br>Bits 1-7         | 28 µS        | 14μs |  |
| Write Any<br>Register    | Read From Diff.<br>Register     | 0            | 0    |  |

# 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.

#### 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.

| NUMBER<br>OF BYTES | HEX VALUE OF<br>BYTE WRITTEN |
|--------------------|------------------------------|
| 40                 | FF (or 00)1                  |
| 6                  | 00                           |
| 1                  | FC (Index Mark)              |
| * 26               | FF (or 00)1                  |
| 6                  | 00                           |
| 1                  | FE (ID Address Mark)         |
| 1                  | Track Number                 |
| 1                  | Side Number (00 or 01)       |
| 1                  | Sector Number (1 thru 1A)    |
| 1                  | 00 (Sector Length)           |
| 1                  | F7 (2 CRC's written)         |
| 11                 | FF (or 00) <sup>1</sup>      |
| 6                  | 00                           |
| 1                  | FB (Data Address Mark)       |
| 128                | Data (IBM uses E5)           |
| 1                  | F7 (2 CRC's written)         |
| 27                 | FF (or 00)1                  |
| 247**              | FF (or 00)1                  |

\*Write bracketed field 26 times

\*\*Continue writing until FD179X interrupts out. Approx. 247 bytes.

1-Optional '00' on 1795/7 only.

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.

| NUMBER<br>OF BYTES | HEX VALUE OF<br>BYTE WRITTEN |
|--------------------|------------------------------|
| 80                 | 4E                           |
| 12                 | 00                           |
| 3                  | F6 (Writes C2)               |
| 1                  | FC (Index Mark)              |
| * 50               | 4E                           |
| 12                 | 00                           |
| 3                  | F5 (Writes A1)               |
| 1                  | FE (ID Address Mark)         |
| 1                  | Track Number (0 thru 4C)     |
| 1                  | Side Number (0 or 1)         |
| 1                  | Sector Number (1 thru 1A)    |
| 1                  | 01 (Sector Length)           |
| 1                  | F7 (2 CRCs written)          |
| 22                 | 4E                           |
| 12                 | 00                           |
| 3                  | F5 (Writes A1)               |
| 1                  | FB (Data Address Mark)       |
| 256                | DATA                         |
| 1                  | F7 (2 CRCs written)          |
| 54                 | 4E                           |
| 598**              | 4E                           |

\*Write bracketed field 26 times

\*\*Continue writing until FD179X interrupts out. Approx. 598 bytes.



IBM TRACK FORMAT

#### 1. NON-IBM FORMATS

Variations in the IBM formats are possible to a limited extent if the following requirements are met:

- 1) Sector size must be 128, 256, 512 or 1024 bytes.
- 2) Gap 2 cannot be varied from the IBM format.
- 3) 3 bytes of A1 must be used in MFM.

In addition, the Index Address Mark is not required for operation by the FD179X. Gap 1, 3, and 4 lengths can be as short as 2 bytes for FD179X operation, however PLL lock up time, motor speed variation, write-splice area, etc. will add more bytes to each gap to achieve proper operation. It is recommended that the IBM format be used for highest system reliability.

|           | FM                        | MFM                                     |
|-----------|---------------------------|-----------------------------------------|
| Gap I     | 16 bytes FF               | 32 bytes 4E                             |
| Gap II    | 11 bytes FF               | 22 bytes 4E                             |
| *         | 6 bytes 00                | 12 bytes 00<br>3 bytes A1               |
| Gap III** | 10 bytes FF<br>4 bytes 00 | 24 bytes 4E<br>8 bytes 00<br>3 bytes A1 |
| Gap IV    | 16 bytes FF               | 16 bytes 4E                             |

\*Byte counts must be exact.

\*\*Byte counts are minimum, except exactly 3 bytes of A1 must be written.



**READ ENABLE TIMING** 

### TIMING CHARACTERISTICS

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

READ ENABLE TIMING (See Note 6, Page 21)

| SYMBOL | CHARACTERISTIC         | MIN. | TYP. | MAX. | UNITS | CONDITIONS            |
|--------|------------------------|------|------|------|-------|-----------------------|
| TSET   | Setup ADDR & CS to RE  | 50   |      |      | nsec  |                       |
| THLD   | Hold ADDR & CS from RE | 10   |      |      | nsec  |                       |
| TRE    | RE Pulse Width         | 400  |      |      | nsec  | $C_L = 50 \text{ pf}$ |
| TDRR   | DRQ Reset from RE      |      | 400  | 500  | nsec  | ·                     |
| TIRR   | INTRQ Reset from RE    |      | 500  | 3000 | nsec  | See Note 5            |
| TDACC  | Data Access from RE    |      |      | 350  | nsec  | C⊾ = 50 pf            |
| TDOH   | Data Hold From RE      | 50   |      | 150  | nsec  | C∟ = 50 pf            |

#### WRITE ENABLE TIMING (See Note 6, Page 21)

| SYMBOL                              | CHARACTERISTIC                                                                                                | MIN.            | TYP.       | MAX.        | UNITS                                  | CONDITIONS |
|-------------------------------------|---------------------------------------------------------------------------------------------------------------|-----------------|------------|-------------|----------------------------------------|------------|
| TSET<br>THLD<br>TWE<br>TDRR<br>TIBB | Setup ADDR & CS to WE<br>Hold ADDR & CS from WE<br>WE Pulse Width<br>DRQ Reset from WE<br>INTRQ Reset from WE | 50<br>10<br>350 | 400<br>500 | 500<br>3000 | , nsec<br>nsec<br>nsec<br>nsec<br>nsec | See Note 5 |
| TDS<br>TDH                          | Data Setup to WE<br>Data Hold from WE                                                                         | 250<br>70       |            | 0000        | nsec<br>nsec                           |            |





|          | 1    | NOMINA | AL.   |      |      |      |
|----------|------|--------|-------|------|------|------|
| DISKETTE | MODE | DDEN   | CLK   | Т,   | Ть   | T,   |
| 8"       | MFM  | 0      | 2 MHz | 1 μs | 1 μs | 2 μs |
| 8″       | FM   | 1      | 2 MHz | 2 μs | 2μs  | 4 μs |
| 5″       | MFM  | 0      | 1 MHz | 2 μs | 2μs  | 4 μs |
| 5″       | FM   | 1      | 1 MHz | 4 μs | 4 μs | 8 µs |

INPUT DATA TIMING

| WRITE ENABLE TI |
|-----------------|
|-----------------|

#### INPUT DATA TIMING:

| SYMBOL | CHARACTERISTIC        | MIN. | TYP. | MAX. | UNITS | CONDITIONS     |
|--------|-----------------------|------|------|------|-------|----------------|
| Трw    | Raw Read Pulse Width  | 100  | 200  |      | nsec  | See Note 1     |
| tbc    | Raw Read Cycle Time   | 1500 | 2000 |      | nsec  | 1800 ns @ 70°C |
| Тс     | RCLK Cycle Time       | 1500 | 2000 |      | nsec  | 1800 ns @ 70°C |
| Tx1    | RCLK hold to Raw Read | 40   |      |      | nsec  | See Note 1     |
| Tx₂    | Raw Read hold to RCLK | 40   |      |      | nsec  | See Note 1     |

#### WRITE DATA TIMING: (ALL TIMES DOUBLE WHEN CLK = 1 MHz) (See Note 6, Page 21)

| SYMBOL | CHARACTERISTICS            | MIN. | TYP.      | MAX. | UNITS | CONDITIONS |
|--------|----------------------------|------|-----------|------|-------|------------|
|        |                            |      |           |      |       |            |
| Twp    | Write Data Pulse Width     |      | 500       | 650  | nsec  | FM         |
|        |                            |      | 200       | 350  | nsec  | MFM        |
| Twg    | Write Gate to Write Data   |      | 2         |      | μsec  | FM         |
|        |                            |      | 1         |      | μsec  | MFM        |
| Tbc    | Write data cycle Time      |      | 2,3, or 4 |      | μsec  | ±CLK Error |
| Ts     | Early (Late) to Write Data | 125  |           |      | nsec  | MFM        |
| Th     | Early (Late) From          | 125  |           |      | nsec  | MFM        |
|        | Write Data                 |      |           |      |       |            |
| Twf    | Write Gate off from WD     |      | 2         |      | μsec  | FM         |
|        |                            |      | 1         |      | μsec  | MFM        |
| Twdl   | WD Valid to Clk            | 100  |           |      | nsec  | CLK=1 MHZ  |
|        |                            | 50   |           |      | nsec  | CLK=2 MHZ  |
| Twd2   | WD Valid after CLK         | 100  |           |      | nsec  | CLK=1 MHZ  |
|        |                            | 30   |           |      | nsec  | CLK=2 MHZ  |
|        |                            |      |           |      |       |            |
|        |                            |      |           |      |       |            |



WRITE DATA TIMING

| MISCELLANEOUS TIMING | : (Times | Double | When C | lock = | 1 MHz) | (See Note 6, Page 21) |
|----------------------|----------|--------|--------|--------|--------|-----------------------|
|----------------------|----------|--------|--------|--------|--------|-----------------------|

|                                               | MIN.                                                                                    | TYP.                                                                                                                        | MAX.                                                                                                           | UNITS                                                                                                                 | CONDITIONS                                                                                                                                                      |
|-----------------------------------------------|-----------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Clock Duty (low)                              | 230                                                                                     | 250<br>250                                                                                                                  | 20000                                                                                                          | nsec                                                                                                                  |                                                                                                                                                                 |
| Step Pulse Output                             | 2 or 4                                                                                  |                                                                                                                             | 20000                                                                                                          | μsec                                                                                                                  | See Note 5                                                                                                                                                      |
| Dir Setup to Step<br>Master Reset Pulse Width | 50                                                                                      | 12                                                                                                                          |                                                                                                                | μsec<br>μsec                                                                                                          | ± CLK ERROR                                                                                                                                                     |
| Index Pulse Width                             | 10                                                                                      |                                                                                                                             |                                                                                                                | μsec<br>usec                                                                                                          | See Note 5                                                                                                                                                      |
|                                               | Clock Duty (high)<br>Step Pulse Output<br>Dir Setup to Step<br>Master Reset Pulse Width | Clock Duty (high)200Step Pulse Output2 or 4Dir Setup to StepMaster Reset Pulse WidthMaster Rulse Width50Index Pulse Width10 | Clock Duty (high)200250Step Pulse Output2 or 4Dir Setup to Step12Master Reset Pulse Width50Index Pulse Width10 | Clock Duty (high)20025020000Step Pulse Output2 or 412Dir Setup to Step12Master Reset Pulse Width50Index Pulse Width10 | Clock Duty (high)20025020000nsecStep Pulse Output2 or 4 $\mu$ secDir Setup to Step12 $\mu$ secMaster Reset Pulse Width50 $\mu$ secIndex Pulse Width10 $\mu$ sec |



MISCELLANEOUS TIMING

#### \*FROM STEP RATE TABLE

#### NOTES:

- 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. A PPL Data Separator is recommended for 8" MFM.
- 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. Times double when clock = 1 MHz.
- 6. Output timing readings are at  $V_{\text{OL}}$  = 0.8v and  $V_{\text{OH}}$  = 2.0v.

| Table 4   | STATUS | REGISTER        | SUMMARY |
|-----------|--------|-----------------|---------|
| 1 4010 4. | SIAIUS | <b>NEGIOTEN</b> | JUMMANT |

| віт | ALL TYPE I<br>COMMANDS | READ<br>ADDRESS | READ<br>SECTOR | READ<br>TRACK | WRITE<br>SECTOR  | WRITE<br>TRACK   |
|-----|------------------------|-----------------|----------------|---------------|------------------|------------------|
| S7  | NOT READY              | NOT READY       | NOT READY      | NOT READY     | NOT READY        | NOT READY        |
| S6  | WRITE<br>PROTECT       | 0               | 0              | 0             | WRITE<br>PROTECT | WRITE<br>PROTECT |
| S5  | HEAD LOADED            | 0               | RECORD TYPE    | 0             | WRITE FAULT      | WRITE FAULT      |
| S4  | SEEK ERROR             | RNF             | RNF            | 0             | RNF              | 0                |
| S3  | CRC ERROR              | CRC ERROR       | CRC ERROR      | 0             | CRC ERROR        | 0                |
| S2  | TRACK 0                | LOST DATA       | LOST DATA      | LOST DATA     | LOST DATA        | LOST DATA        |
| S1  | INDEX PULSE            | DRQ             | DRQ            | DRQ           | DRQ              | DRQ              |
| S0  | BUSY                   | BUSY            | BUSY           | BUSY          | BUSY             | 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 'ored' 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 CRC 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 $\overline{\text{IP}}$ input.                                                              |
| S0 BUSY        | When set command is in progress. When reset no command is in progress.                                                                                                             |

#### STATUS FOR TYPE II AND III COMMANDS

| BIT NAME                       | MEANING                                                                                                                                                                                                                                            |  |  |
|--------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| S7 NOT READY                   | This bit when set indicates the drive is not ready. When reset, it indicates that the drive is ready. This bit is an inverted copy of the Ready input and 'ored' with MR. The Type II and III Commands will not execute unless the drive is ready. |  |  |
| S6 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.<br>1 = Deleted Data Mark. 0 = Data Mark. On any Write: It indicates a Write Fault. This bit<br>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 DRQ output. When set, it indicates the DR is full on a Read<br>Operation or the DR is empty on a Write operation. This bit is reset to zero when up-<br>dated.                                                           |  |  |
| S0 BUSY                        | When set, command is under execution. When reset, no command is under execution.                                                                                                                                                                   |  |  |

#### ELECTRICAL CHARACTERISTICS

Absolute Maximum Ratings

 $\begin{array}{l} V_{DD} \mbox{ with repect to } V_{SS} \mbox{ (ground): } + 15 \mbox{ to } - 0.3V \\ Voltage to any input with respect to } V_{SS} = \mbox{ + 15 to } - 0.3V \\ Icc = 60 \mbox{ MA (35 MA nominal)} \\ IbD = \mbox{ 15 MA (10 MA nominal)} \end{array}$ 

 $\label{eq:constraint} \begin{array}{l} C_{IN} \& \ C_{OUT} = 15 \ pF \ max \ with all pins grounded except \\ one under test. \\ Operating temperature = 0°C \ to \ 70°C \\ Storage temperature = -55°C \ to \ +125°C \end{array}$ 

OPERATING CHARACTERISTICS (DC)

 $TA = 0^{\circ}C \text{ to } 70^{\circ}C, V_{DD} = + 12V \pm .6V, V_{SS} = 0V, V_{CC} = + 5V \pm .25V$ 

| SYMBOL          | CHARACTERISTIC      | MIN. | MAX. | UNITS | CONDITIONS             |
|-----------------|---------------------|------|------|-------|------------------------|
| l <sub>iL</sub> | Input Leakage       |      | 10   | μΑ    | $V_{IN} = V_{DD}^{**}$ |
| lol             | Output Leakage      |      | 10   | μΑ    | $V_{OUT} = V_{DD}$     |
| Vін             | Input High Voltage  | 2.6  |      | V     |                        |
| VIL             | Input Low Voltage   |      | 0.8  | V     |                        |
| Vон             | Output High Voltage | 2.8  |      | V     | $lo = -100 \mu A$      |
| Vol             | Output Low Voltage  |      | 0.45 | V     | $lo = 1.6  mA^*$       |
| Po              | Power Dissipation   |      | 0.6  | w     |                        |

\*1792 and 1794  $I_0 = 1.0 \text{ mA}$ 

\*\*Leakage conditions are for input pins without internal pull-up resistors. Pins 22, 23, 33, 36, and 37 have pull-up resistors. See Tech Memo #115 for testing procedures.

See page 481 for ordering information.

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

# WESTERN DIGITAL

FD179X Application Notes

#### INTRODUCTION

Over the past several years, the Floppy Disk Drive has become the most popular on-line storage device for mini and microcomputer systems. Its fast access time, reliability and low cost-per-bit ratio enables the Floppy Disk Drive to be *the* solution in mass storage for microprocessor systems. The drive interface to the Host system is standardized, allowing the OEM to substitute one drive for another with minimum hardware/ software modifications.

Since Floppy Disk Data is stored and retrieved as a self-clocking serial data stream, some means of separating the clock from the data and assembling this data in parallel form must be accomplished. Data is stored on individual Tracks of the media, requiring control of a stepper motor to move the Read/Write head to a predetermined Track. Byte sychronization must also be accomplished to insure that the parallel data is properly assembled. After all the design considerations are met, the final controller can consist of 40 or more TTL packages.

To alleviate the burden of Floppy Disk Controller design, Western Digital has developed a Family of LSI Floppy Disk controller devices. Through its own set of macro commands, the FD179X Controller Family will perform all the functions necessary to read and write data to the drive. Both the 8" standard and 5¼" minifloppy are supported with single or double density recording techniques. The FD179X is compatible with the IBM 3740 (FM) data format, or the System 34 (MFM) standards. Provisions for non-standard formats and variable sector lengths have been included to provide more storage capability per track. Requiring standard +5, +12 power supplies the FD179X is available in a standard 40 pin dual-in-line package.

The FD179X Family consists of 6 devices. The differences between these devices is summarized in Figure 1. The 1792 and 1794 are "single density only" devices, with the Double Density Enable pin (DDEN) left open by the user. Both True and inverted Data bus devices are available. Since the 179X can only drive one TTL Load, a true data bus system may use the 1791 with external inverting buffers to arrive at a true bus scheme. The 1795 and 1797 are identical to the 1791 and 1793, except a side select output has been added that is controlled through the command Register.

#### SYSTEM DESIGN

The first consideration in Floppy Disk Design is to determine which type of drive to use. The choice ranges from single-density single sided mini-floppy to the 8" double-density double-sided drive. Figure 2 illustrates the various drive and data capacities associated with each type. Although the 8" double-density drive offers twice as much storage, a more complex data separator and the addition of Write Precompensation circuits are mandatory for reliable data transfers. Whether to go with 8" double-density or not is dependent upon PC board space and the additional circuitry needed to accurately recover data with extreme bit shifts. The byte transfer time defines the nominal time required to transfer one byte of data from the drive. If the CPU used cannot service a byte in this time, then a DMA scheme will probably be required. The 179X also needs a few microseconds for overhead, which is subtracted from the transfer time. Figure 3 shows the actual service times that the CPU must provide on a byte-by-byte basis. If these times are not met, bytes of data will be lost during a read or write operation. For each byte transferred, the 179X generates a DRQ (Data Request) signal on Pin 38. A bit is provided in the status register which is also set upon receipt of a byte from the Disk. The user has the option of reading the status register through program control or using the DRQ Line with DMA or interrupt schemes. When the data register is read, both the status register DRQ bit and the DRQ Line are automatically reset. The next full byte will again set the DRQ and the process continues until the sector(s) are read. The Write operation works exactly the same way, except a WRITE to the Data Register causes a reset of both DRQ's.

#### **RECORDING FORMATS**

The FD179X accepts data from the disk in a Frequency-Modulated (FM) or Modified-Frequency-Modulated (MFM) Format. Shown in Figures 4A and 4B are both these Formats when writing a Hexidecimal byte of 'D2'. In the FM mode, the 8 bits of data are broken up into "bit cells." Each bit cell begins with a clock pulse and the center of the bit cell defines the data. If the data bit = 0, no pulse is written; if the data = 1, a pulse is written in the center of the cell. For the 8" drive, each clock is written 4 microseconds apart. In the MFM mode, clocks are decoded into the data stream. The byte is again broken up into bit cells, with the data bit written in the center of the bit cell if data = 1. Clocks are only written if both surrounding data bits are zero. Figure 4B shows that this occurs only once between Bit cell 4 and 5. Using this encoding scheme, pulses can occur 2, 3 or 4 microseconds; twice as much data can be recorded without increasing the Frequency rate due to this encoding scheme.

The 179X was designed to be compatible with the IBM 3740 (FM) and System 34 (MFM) Formats. Although most users do not have a need for data exchange with IBM mainframes, taking advantage of these well studied formats will insure a high degree of system performance. The 179X will allow a change in gap fields and sector lengths to increase usable storage capacity, but variations away from these standards is not recommended. Both IBM standards are soft-sector format. Because of the wide variation in address marks, the 179X can only support soft-sectored media. Hard sectored diskettes have continued to lose popularity, mainly due to the unavailability of a standard and the limitation of sector lengths imposed by the physical sector holes in the diskette.

#### PROCESSOR INTERFACE

The Interface of the 179X to the CPU consists of an 8-bit Bi-directional bus, read/write controls and optional interrupt lines. By selecting the device via the CHIP SELECT Line, each of the five internal registers can be accessed.

Shown below are the registers and their addresses:

| PIN 3<br>CS | PIN 6<br>A <sub>1</sub> | PIN 5<br>A₀ | PIN 4<br>RE <i>=</i> ∕0∕ | PIN 2<br>₩E <i>≕</i> Ø |
|-------------|-------------------------|-------------|--------------------------|------------------------|
| 0           | 0                       | 0           | STATUS REG               | COMMAND<br>REG         |
| 0           | 1                       | o           | SECTOR REG               | TRACK REG              |
| 0           | 1<br>X                  | 1<br>X      | DATA REG<br>H1-Z         | SECTOR REG             |
|             |                         |             | =                        | H1-Z                   |

Each time a command is issued to the 179X, the Busy bit is set and the INTRQ (Interrupt Request) Line is reset. The user has the option of checking the busy bit or use the INTRQ Line to denote command completion. The Busy bit will be reset whenever the 179X is idle and awaiting a new command. The INTRQ Line, once set, can only be reset by a READ of the status register or issuing a new command. The MR (Master Reset) Line does not affect INTRQ. The  $A_0$ ,  $A_1$ , Lines used for register selections can be configured at the CPU in a variety of ways. These lines may actually tie to CPU address lines, in which case the 179X will be memory-mapped and addressed like RAM. They may also be used under Program Control by tying to a port device such as the 8255, 6820, etc. As a diagnostic tool when checking out the CPU interface, the Track and Sector registers should respond like "RAM" when the 179X is idle (Busy = INTRQ = 0).

Because of internal synchronization cycles, certain time delays must be introduced when operating under Programmed I/O. The worst case delays are:

| OPERATION                | NEXT<br>OPERATION            | DELAY REQ'D                                                                    |
|--------------------------|------------------------------|--------------------------------------------------------------------------------|
| WRITE TO<br>COMMAND REG  | READ STATUS<br>REGISTER      | $\begin{array}{l} MFM = \ 14\mus^{\star} \\ FM = \ 28\mus_{\star} \end{array}$ |
| WRITE TO<br>ANY REGISTER | READ FROM A<br>DIFFERENT REG | NO DELAY                                                                       |

| *NOTE: Times Double | when CLK = | 1MHz (5¼" drive) |
|---------------------|------------|------------------|
|---------------------|------------|------------------|

Other CPU interface lines are CLK, MR and DDEN. The CLK line should be 2MHz (8" drive) or 1MHz (5<sup>1</sup>/<sub>4</sub>" drive) with a 50% duty cycle. Accuracy should be  $\pm 1\%$  (crystal source) since all internal timing, including stepping rates, are based upon this clock.

The  $\overline{\text{MR}}$  or Master Reset Line should be strobed a minimum of 50 microseconds upon each power-on condition. This line clears and initializes all internal registers and issues a restore command (Hex '03') on the rising edge. A quicker stepping rate can be written to the command register after a  $\overline{\text{MR}}$ , in which case the remaining steps will occur at the faster programmed rate. The 179X will issue a maximum of 255 stepping pulses in an attempt to expect the  $\overline{\text{TROO}}$  line to go active low. This line should be connected to the drive's TROO sensor.

The  $\overline{\text{DDEN}}$  line causes selection of either single density ( $\overline{\text{DDEN}} = 1$ ) or double density operation.  $\overline{\text{DDEN}}$ should not be switched during a read or write operation.

#### FLOPPY DISK INTERFACE

The Floppy Disk Interface can be divided into three sections: Motor Control, Write Signals and Read Signals. All of these lines are capable of driving one TTL load and not compatible for direct connection to the drive. Most drives require an open-collector TTL interface with high current drive capability. This must be done on all outputs from the 179X. Inputs to the 179X may be buffered or tied to the Drives outputs, providing the appropriate resistor termination networks are used. Undershoot should not exceed -0.3 volts, while integrity of  $V_{\rm H}$  and  $V_{\rm OH}$  levels should be kept within spec.

#### MOTOR CONTROL

Motor Control is accomplished by the STEP and DIRC Lines. The STEP Line issues stepping pulses with a period defined by the rate field in all Type I commands. The DIRC Line defines the direction of steps (DIRC = 1 STEP IN/DIRC = 0 STEP OUT).

Other Control Lines include the IP or Index Pulse. This Line is tied to the drives' Index L.E.D. sensor and makes an active transition for each revolution of the diskette. The TROO Line is another L.E.D. sensor that informs the 179X that the stepper motor is at its furthest position, over Track 00. The READY Line can be used for a number of functions, such as sensing "door open", Drive motor on, etc. Most drives provide a programmable READY Signal selected by option jumpers on the drive. The 179X will look at the ready signal prior to executing READ/WRITE commands. READY is *not* inspected during any Type I commands. All Type I commands will execute regardless of the Logic Level on this Line.

#### WRITE SIGNALS

Writing of data is accomplished by the use of the WD, WG, WF, TG43, EARLY and LATE Lines. The WG or Write Gate Line is used to enable write current at the drive's R/W head. It is made active prior to writing data on the disk. The WF or WRITE FAULT Line is used to inform the 179X of a failure in drive electronics. This signal is multiplexed with the VFOE Line and must be logically separated if required. Figure 5 illustrates three methods of demultiplexing.

The TG43 or "TRACK GREATER than 43" Line is used to decrease the Write current on the inner tracks, where bit densities are the highest. If not required on the drive, TG43 may be left open.

#### WRITE PRECOMPENSATION

The 179X provides three signals for double density Write Precompensation use. These signals are WRITE DATA, EARLY and LATE. When using single density drives (eighter 8" or 5¼"), Write Precompensation is not necessary and the WRITE DATA line is generally TTL Buffered and sent directly to the drive. In this mode, EARLY and LATE are left open.

For double density use, Write Precompensation is a function of the drive. Some manufacturers recommend Precompensating the 5<sup>1</sup>/<sub>4</sub>" drive, while others do not.

With the 8" drive, Precompensation may be specified from TRACK 43 on, or in most cases, all TRACKS. If the recommended Precompensation is not specified, check with the manufacturer for the proper configuration required.

The amount of Precompensation time also varies. A typical value will usually be specified from 100-300ns. Regardless of the parameters used, Write Precompensation must be done external to the 179X. When DDEN is tied low, EARLY or LATE will be activated at least 125ns. before and after the Write Data pulse. An Algorithm internal the 179X decides whether to raise EARLY or LATE, depending upon the previous bit pattern sent. As an example, suppose the recommended Precomp value has been specified at 150ns. The following action should be taken:

| EARLY | LATE | ACTION TAKEN                 |
|-------|------|------------------------------|
| 0     | 0    | delay WD by 150ns (nominal)  |
| 0     | 1    | delay WD by 300ns (2X value) |
| 1     | 0    | do not delay WD              |

There are two methods of performing Write Precompensation:

1) External Delay elements

2) Digitally

Shown in Figure 6 is a Precomp circuit using the Western Digital 2143 clock generator as the delay element. The WD pulse from the 179X creates a strobe to the 2143, causing subsequent output pulses on the £1. £2 and Ø3 signals. The 5K Precomp adjust sets the desired Precomp value. Depending upon the condition of EARLY and LATE, Ø1 will be used for EARLY, Ø2 for nominal (EARLY = LATE = 0), and  $\emptyset$ 3 for LATE. The use of "one-shots" or delay line in a Write Precompensation scheme offers the user the ability to vary the Precomp value. The Ø4 output resets the 74LS175 Latch in anticipation of the next WD pulse. Figure 7 shows the WD-EARLY/LATE relationship, while Figure 8 shows the timing of this write Precomp scheme. Another method of Precomp is to perform the function digitally. Figure 9 illustrates a relationship between the WD pulse and the CLK pin, allowing a digital Precomp scheme. Figure 10 shows such a scheme with a preset Write Precompensation value of 250ns. The synchronous counter is used to generate 2MHz and 4MHz clock signals. The 2MHz clock is sent to the CLK input of the 179X and the 4MHz is used by the 4-bit shift register. When a WD pulse is not present, the 4MHz clock is shifting "ones" through the shift register and maintaining Q<sub>D</sub> at a zero level. When a WD pulse is present, a zero is loaded at either A, B, or C depending upon the states of LATE, EN PRECOMP and EARLY. The zero is then shifted by the 4MHz clock until it reaches the Q<sub>p</sub> output. The number of shift operations determines whether the WRITE DATA pulse is written early, nominal or late. If both FM and MFM operations is a system requirement, the output of this circuit should be disabled and the WD pulse should be sent directly to the drive.

#### DATA SEPARATION

The 179X has two inputs (RAW READ & RCLK) and one output (VFOE) for use by an external data separator. The RAW READ input must present clock and data pulses to the 179X, while the RCLK input provides a "window" or strobe signal to clock each RAW READ pulse into the device. An ideal Data Separator would have the leading edge of the RAW READ pulse occur in the exact center of the RCLK strobe.

Motor Speed Variation, Bit shifts and read amplifier recovery circuits all cause the RAW READ pulses to drift away from their nominal positions. As this occurs, the RAW READ pulses will shift left or right with respect to RCLK. Eventually, a pulse will make its transition outside of its RCLK window, causing either a CRC error or a Record-not-Found error at the 179X.

A Phase-Lock-Loop circuit is one method of achieving synchronization between the RCLK and RAW READ signals. As RAW READ pulses are fed to the PLL, minor adjustments of the free-running RCLK frequency can be made. If pulses are occurring too far apart, the RCLK frequency is *decreased* to keep synchronization. If pulses begin to occur closer together, RCLK is *increased* until this new higher frequency is achieved. In normal read operations, RCLK will be constantly adjusted in an attempt to match the incoming RAW READ frequency.

Another method of Data Separation is the Counter-Separator technique. The RCLK signal is again freerunning at a nominal rate, until a RAW READ pulse occurs. The Separator then denotes the position of the pulse with respect to RCLK (by the counter value), and counts down to increase or decrease the current RCLK window. The next RCLK window will occur at a nominal rate and will continue to run at this frequency until another RAW READ pulse adjusts RCLK, but only the present window is adjusted.

Both PPL and Counter/Separator are acceptable methods of Data Separation. The PPL has the highest reliability because of its "tracking" capability and is recommended for 8" double density designs.

As a final note, the term "Data Separator" may be misleading, since the physical separation of clock and data bits are not actually performed. This term is used throughout the industry, and can better be described as a "Data Recovery Circuit" rather than a Data Separator.

The VFOE signal is an output from the 179X that signifies the head has been loaded and valid data pulses are appearing on the RAW READ line. It can be used to enable the Data Separator and to insure clean RCLK transitions to the 179X. Since some drives will output random pulses when the head is disengaged, VFOE can prevent an erratic RCLK signal during this time. If the Data Separator requires synchronization during a known pattern of one's or zero's, then RG (READ GATE) can be used. The RG signal will go active when the 179X is currently over a field of zeros or ones. RG is not available on the 1795/1797 devices, since this signal was replaced with the SSO (Side Select Output) Line. Shown in Figure 11 is a 2½ IC Counter/Separator. The 74LS193 free runs at a frequency determined by the CRYCLK input. When a RAW READ pulse occurs, the counter is loaded with a starting count of '5'. When the RAW READ Line returns to a Logic 1, the counter counts down to zero and again free runs. The 74LS74 insures a 50% duty cycle to the 179X and performs a divide-by-two of the  $Q_p$  output.

Figure 12 illustrates another Counter/Separator utilizing a PROM as the count generator. Depending upon the RAW READ phase relationship to RCLK, the PROM is addressed and its data output is used as the counter value. A 16MHz clock is required for 8" double density, while an 8MHz clock can be used for single density.

Figure 13 shows a Phase-Lock-Loop data recovery circuit. The phase detector (U2, Figure 2) compares the phase of the SHAPED DATA pulse to the phase of VFO CLK  $\div$  2. If VFO CLK  $\div$  2 is lagging the SHAPED DATA pulse an output pulse on #9, U2 is generated. The filter/amplifier converts this pulse into a DC signal which increases the frequency of the VCO.

If, correspondingly, CLK  $\div$  2 is leading the SHAPED DATA pulse, an output pulse on #5, U2 is generated. This pulse is converted into a DC signal which decreases the frequency of the VCO. These two actions cause the VCO to track the frequency of the incoming READ DATA pulses. This correction process to keep the two signals in phase is constantly occurring because of spindle speed variation and circuit parameter variations.

The operating specifications for this circuit are as follows:

| Free Running Frequency<br>Capture Range<br>Lock Up Time | 2MHz<br>± 15%<br>50 microsec. "1111" or<br>"0000" Pattern<br>100 Microsec "1010" Pat-<br>tern |
|---------------------------------------------------------|-----------------------------------------------------------------------------------------------|
|---------------------------------------------------------|-----------------------------------------------------------------------------------------------|

The RAW READ pulses are generated from the falling edge of the SHAPED DATA pulses. The pulses are also reshaped to meet the 179X requirements. VFO CLK  $\div$  2 OR 4 is divided by 2 once again to obtain VFO CLK OUT whose frequency is that required by the 179X RCLK input. RCLK must be controlled by VFOE so VFOE is sampled on each rising edge of VFO CLK OUT. When VFOE goes active EN RCLK goes active in synchronization with VFO CLK OUT RCLK goes inactive in synchronization with VFO CLK OUT, again preventing any glitches on the RCLK output.

Figure 14 illustrates a PPL data recovery circuit using the Western Digital 1691 Floppy Support device. Both data recovery and Write Precomp Logic is contained within the 1691, allowing low chip count and PLL reliability. The 74S124 supplies the free-running VCO output. The PUMP UP and PUMP DOWN signals from the 1691 are used to control the 74S124's frequency.
#### 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 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 TROO 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 TROO. Issuing several STEP IN pulses before a RESTORE command will remedy this situation. The RESTORE and all other Type I commands will execute even though the READY bit indicates the drive is 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.

| TRACK SIDE SECTOR | CRS<br>LENGTH | CRC<br>1 | CRC<br>2 |  |
|-------------------|---------------|----------|----------|--|
|-------------------|---------------|----------|----------|--|

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:

| $1_0 = NOT-READY TO READY TRANSITION$ | NC |
|---------------------------------------|----|
| $1_1 = READY TO NOT-READY TRANSITION$ | NC |
| 1 <sub>2</sub> = EVERY INDEX PULSE    |    |
| $1_3 = 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 DO).

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.

#### 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 1. DEVICE CHARACTERISTICS

| DEVICE                                       | SNGL DENSITY               | DBLE DENSITY     | INVERTED BUS | TRUE BUS    | DOUBLE-SIDED |
|----------------------------------------------|----------------------------|------------------|--------------|-------------|--------------|
| 1791<br>1792<br>1793<br>1794<br>1795<br>1797 | X<br>X<br>X<br>X<br>X<br>X | x<br>x<br>x<br>x | x<br>x<br>x  | X<br>X<br>X | X<br>X       |

## FIGURE 2. STORAGE CAPACITIES

|                                                                            |                                                                              |                                 | UNFORMATTED<br>CAPACITY (NOMINAL)                                |                                                                                         | BYTE<br>TRANSFER                                             | FORMA<br>CAPA                                                     |                                                                            |
|----------------------------------------------------------------------------|------------------------------------------------------------------------------|---------------------------------|------------------------------------------------------------------|-----------------------------------------------------------------------------------------|--------------------------------------------------------------|-------------------------------------------------------------------|----------------------------------------------------------------------------|
| SIZE                                                                       | DENSITY                                                                      | SIDES                           | PER TRACK                                                        | PER DISK                                                                                | TIME                                                         | PER TRACK                                                         | PER DISK                                                                   |
| 51⁄4"<br>51⁄4"<br>51⁄4"<br>51⁄4"<br>8"<br>8"<br>8"<br>8"<br>8"<br>8"<br>8" | SINGLE<br>DOUBLE<br>SINGLE<br>DOUBLE<br>SINGLE<br>DOUBLE<br>SINGLE<br>DOUBLE | 1<br>2<br>2<br>1<br>1<br>2<br>2 | 3125<br>6250<br>3125<br>6250<br>5208<br>10,416<br>5208<br>10,416 | 109,375*<br>218,750<br>218,750<br>437,500<br>401,016<br>802,032<br>802,032<br>1,604,064 | 64μs<br>32μs<br>64μs<br>32μs<br>32μs<br>16μs<br>32μs<br>16μs | 2304**<br>4608***<br>2304<br>4608<br>3328<br>6656<br>3328<br>6656 | 80,640<br>161,280<br>322,560<br>256,256<br>512,512<br>512,512<br>1,025,024 |

\*Based on 35 Tracks/Side \*\*Based on 18 Sectors/Track (128 byte/sec) \*\*\*Based on 18 Sectors/Track (256 bytes/sec)

## FIGURE 3. NOMINAL VS. WORSE CASE SERVICE TIME

|                        |                                      | NOMINAL TRANSFER             | WORST-CASE 179X SERVICE TIME         |                                      |  |
|------------------------|--------------------------------------|------------------------------|--------------------------------------|--------------------------------------|--|
| SIZE                   | DENSITY                              | TIME                         | READ                                 | WRITE                                |  |
| 5¼"<br>5¼"<br>8"<br>8" | SINGLE<br>DOUBLE<br>SINGLE<br>DOUBLE | 64μs<br>32μs<br>32μs<br>16μs | 55.0μs<br>27.5μs<br>27.5μs<br>13.5μs | 47.0μs<br>23.5μs<br>23.5μs<br>11.5μs |  |

## FIGURE 4A. FM RECORDING



#### FIGURE 4B. MFM RECORDING



## FIGURE 5. WF/VFOE DEMULTIPLEXING CIRCUITRY



PIN 33 USED AS A VFOE SIGNAL ONLY











FIGURE 7. WRITE PRE-COMP TIMING



FIGURE 8. PRECOMP TIMING FOR CIRCUIT IN FIGURE 6









FIGURE 11. COUNTER/SEPARATOR

745288 PROGRAMMING TABLE

| ADDRESS | DATA | ACTION TAKEN        |
|---------|------|---------------------|
| 00      | 01   | NONE                |
| 01      | 01   | RETARD BY 1 COUNT   |
| 02      | 02   |                     |
| 03      | 03   |                     |
| 04      | 03   | RETARD BY 2 COUNTS  |
| 05      | 04   |                     |
| 06      | 05   |                     |
| 07      | 06   |                     |
| 08      | 0B   | ADVANCE BY 2 COUNTS |
| 09      | 0D   |                     |
| 0A      | 0C   |                     |
| 0B      | 0E   |                     |
| 0C      | 0F   |                     |
| 0D      | OF   | ADVANCE BY 1 COUNT  |
| 0E      | 00   |                     |
| 0F      | 01   |                     |
| 10      | 01   | FREE RUN            |
| 11      | 02   |                     |
| 12      | 03   |                     |
| 13      | 04   |                     |
| 14      | 05   |                     |
| 15      | 06   |                     |
| 16      | 07   |                     |
| 17      | 08   |                     |
| 18      | 09   |                     |
| 19      | 0A   |                     |
| 1A      | 0B   |                     |
| 1B      | 0C   |                     |
| 1C      | 0D   |                     |
| 1D      | 0E   |                     |
| 1E      | 0F   |                     |
| 1F      | 00   |                     |



106



X67103



108

Refer to 179X-02 Floppy Disk Formatter/Controller Family Data Sheet for Command, Timing and Status Information.

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

#### WESTERN DIGITAL Ρ Ο

п

WD279X-02 Floppy Disk Formatter/Controller Family

#### FEATURES

- ON-CHIP PLL DATA SEPARATOR
- ON-CHIP WRITE PRECOMPENSATION LOGIC
- SINGLE + 5V SUPPLY
- ACCOMMODATES SINGLE AND DOUBLE DENSITY FORMATS
  - IBM 3740 (FM) IBM 34 (MFM)
- AUTOMATIC SEEK WITH VERIFY
- MULTIPLE SECTOR READ/WRITE
- TTL COMPATIBLE
- PROGRAMMABLE CONTROL SELECTABLE TRACK-TO-TRACK ACCESS HEAD LOAD TIMING
- SOFTWARE COMPATIBLE WITH THE FD179X SERIES
- SOFT SECTOR FORMAT COMPATIBILITY

| ENP   | 1  | $\bigcirc$ | 40 | HLT      |
|-------|----|------------|----|----------|
| WE    | 2  |            | 39 | INTRQ    |
| cs 🗖  | 3  |            | 38 | DRQ      |
| RE    | 4  |            | 37 | DDEN     |
| A0 🗌  | 5  |            | 36 | WPRT     |
| A1    | 6  |            | 35 | ĪP       |
| DALO  | 7  |            | 34 | TR00     |
| DAL1  | 8  |            | 33 | WPW      |
| DAL2  | 9  |            | 32 | READY    |
| DAL3  | 10 |            | 31 | WD       |
| DAL4  | 11 |            | 30 | WG       |
| DAL5  | 12 |            | 29 | TG43     |
| DAL6  | 13 |            | 28 | HLD      |
| DAL7  | 14 |            | 27 | RAW RD   |
| STEP  | 15 |            | 26 | VCO      |
| DIRC  | 16 |            | 25 | SSO/ENMF |
| 5/8   | 17 |            | 24 | CLK      |
| RPW   | 18 |            | 23 | PUMP     |
| MR    | 19 |            | 22 | TEST     |
| GND 🗔 | 20 |            | 21 | Vcc      |

#### PIN DESIGNATION

#### DESCRIPTION

The WD279X are N-Channel Silicon Gate MOS LSI devices which perform the functions of a Floppy Disk Formatter/Controller in a single chip implementation. The WD279X, which can be considered the end result of both the FD1771 and FD179X designs, is IBM 3740 compatible in single density mode (FM) and System 34 compatible in Double Density Mode (MFM). The WD279X contains all the features of its predecessor the FD179X plus a high performance Phase-Lock-Loop Data Separator as well as Write Precompensation Logic. In Double Density mode. Write Precompensation is automatically engaged to a value programmed via an external potentiometer. In order to maintain compatibility, the FD1771, FD179X and WD279X 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 bi-directional bus for data, status, and control word transfers. The WD279X is set up to operate on a multiplexed bus with other bus-oriented devices.

The WD279X is TTL compatible on all inputs and outputs. The outputs will drive one TTL load or three LS loads. The 2793 is identical to the 2791 except the DAL lines are TRUE for systems that utilize true data busses.

The 2795/7 has a side select output for controlling double sided drives.

| PIN DESCRIPTION | N                     |                 |                                                                                                                                                                                                                                                                                                                                                                       |  |  |
|-----------------|-----------------------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| PIN NUMBER      | PIN NAME              | SYMBOL          | FUNCTION                                                                                                                                                                                                                                                                                                                                                              |  |  |
| 1               | ENABLE PRECOMP        | ENP             | A Logic high on this input enables write precompen-<br>sation to be performed on double density Write Data<br>output only.                                                                                                                                                                                                                                            |  |  |
| 19              | MASTER RESET          | MR              | A logic low (50 microseconds min.) on this input<br>resets the device and loads HEX 03 into the com-<br>mand register. The Not Ready (Status Bit 7) is reset<br>during MR ACTIVE. When MR is brought to a logic<br>high a RESTORE Command is executed, regardless<br>of the state of the Ready signal from the drive. Also,<br>HEX 01 is loaded into sector register. |  |  |
| 20              | POWER SUPPLIES        | V <sub>SS</sub> | Ground                                                                                                                                                                                                                                                                                                                                                                |  |  |
| 21              |                       | Vcc             | $+5V \pm 5\%$                                                                                                                                                                                                                                                                                                                                                         |  |  |
| COMPUTER IN     | TERFACE:              |                 |                                                                                                                                                                                                                                                                                                                                                                       |  |  |
| 2               | WRITE ENABLE          | WE              | A logic low on this input gates data on the DAL into the selected register when CS is low.                                                                                                                                                                                                                                                                            |  |  |
| 3               | CHIP SELECT           | ĊŚ              | A logic low on this input selects the chip and enables<br>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 LINES | A0, A1          | These inputs select the register to receive/transfer data on the DAL lines under RE and WE control:                                                                                                                                                                                                                                                                   |  |  |
|                 |                       |                 | CS A1 A0 RE WE                                                                                                                                                                                                                                                                                                                                                        |  |  |
|                 |                       |                 | 0 0 0 Status Reg Command Reg<br>0 0 1 Track Reg Track Reg<br>0 1 0 Sector Reg Sector Reg<br>0 1 1 Data Reg Data Reg                                                                                                                                                                                                                                                   |  |  |
| 7-14            | DATA ACCESS LINES     | DALO-DAL7       | Eight bit bi-directional bus used for transfer of com-<br>mands, status, and data. These lines are inverted<br>(active low) on WD2791 and WD2795.                                                                                                                                                                                                                     |  |  |
| 24              | CLOCK                 | CLK             | This input requires a free-running 50% duty cycle square wave clock for internal timing reference, 2 MHz $\pm$ 1% for 8" drives, 1 MHz $\pm$ 1% for mini-floppies.                                                                                                                                                                                                    |  |  |
| 38              | DATA REQUEST          | DRQ             | This output indicates that the Data Register contains<br>assembled data in Read operations, or the DR is<br>empty in Write operations. This signal is reset when<br>serviced by the computer through reading or loading<br>the DR.                                                                                                                                    |  |  |
| 39              | INTERRUPT REQUEST     | INTRQ           | This output is set at the completion of any command<br>and is reset when the Status register is read or the                                                                                                                                                                                                                                                           |  |  |
| FLOPPY DISK     | 1                     |                 | Command register is written to.                                                                                                                                                                                                                                                                                                                                       |  |  |
| 15              | STEP                  | STEP            | The step output contains a pulse for each step.                                                                                                                                                                                                                                                                                                                       |  |  |
| 16              | DIRECTION             | DIRC            | Direction Output is active high when stepping in,<br>active low when stepping out.                                                                                                                                                                                                                                                                                    |  |  |
| 17              | 51⁄4," 8" SELECT      | 5/8             | This input selects the internal VCO frequency for use with 51/4 " drives or 8" drives.                                                                                                                                                                                                                                                                                |  |  |
| 18              | READ PULSE WIDTH      | RPW             | An external potentiometer tied to this input controls the phase comparator within the data separator.                                                                                                                                                                                                                                                                 |  |  |
| 22              | TEST                  | TEST            | A logic low on this input allows adjustment of exter-<br>nal resistors by enabling internal signals to appear on<br>selected pins.                                                                                                                                                                                                                                    |  |  |

WD279X-02

## PIN DESCRIPTION (Continued)

| PIN NUMBER | PIN NAME                           | SYMBOL   | FUNCTION                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|------------|------------------------------------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 23         | PUMP                               | PUMP     | High-Impedance output signal which is forced high<br>or low to increase/decrease the VCO frequency.                                                                                                                                                                                                                                                                                                                                                                  |
| 25         | ENABLE MINI-FLOPPY<br>(2791, 2793) | ENMF     | A logic low on this input enables an internal +2 of<br>the Master Clock. This allows both 5¼" and 8" drive<br>operation with a single 2 MHz clock. For a 1 MHz<br>clock on Pin 24, this line must be left open or tied to a<br>Logic 1.                                                                                                                                                                                                                              |
| 25         | SIDE SELECT OUTPUT<br>(2795, 2797) | SSO      | The logic level of the Side Select Output is directly controlled by the 'S' flag in Type II or III commands. When $U = 1$ , SSO is set to a logic 1. When $U = 0$ , SSO is set to a logic 0. The SSO is compared with the side information in the Sector I.D. Field. If they do not compare Status Bit 4 (RNF) is set. The Side Select Output is only updated at the beginning of a Type II or III command. It is forced to a logic 0 upon a MASTER RESET condition. |
| 26         | VOLTAGE-CONTROLLED<br>OSCILLATOR   | VCO      | An external capacitor tied to this pin adjusts the VCO center frequency.                                                                                                                                                                                                                                                                                                                                                                                             |
| 27         | RAW READ                           | RAW READ | The data input signal directly from the drive. This<br>input shall be a negative pulse for each recorded flux<br>transition.                                                                                                                                                                                                                                                                                                                                         |
| 28         | HEAD LOAD                          | HLD      | The HLD output controls the loading of the Read-<br>Write head against the media.                                                                                                                                                                                                                                                                                                                                                                                    |
| 29         | TRACK GREATER<br>THAN 43           | TG43     | This output informs the drive that the Read/Write<br>head is positioned between tracks 44-76. This output<br>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       | MFM or FM output pulse per flux transition. WD contains the unique Address marks as well as data and clock in both FM and MFM formats.                                                                                                                                                                                                                                                                                                                               |
| 32         | READY                              | READY    | This input indicates disk readiness and is sampled<br>for a logic high before Read or Write commands are<br>performed. If Ready is low the Read or Write<br>operation is not performed and an interrupt is<br>generated. Type I operations are performed regard-<br>less of the state of Ready. The Ready input appears in<br>inverted format as Status Register bit 7.                                                                                              |
| 33         | WRITE PRECOMP<br>WIDTH             | WPW      | An external potentiometer tied to this input controls the amount of delay in Write precompensation mode.                                                                                                                                                                                                                                                                                                                                                             |
| 34         | TRACK 00                           | TR00     | This input informs the WD279X that the Read/Write head is positioned over Track 00.                                                                                                                                                                                                                                                                                                                                                                                  |
| 35         | INDEX PULSE                        | ĪP       | This input informs the WD279X 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 input pin selects either single or double density operation. When $\overrightarrow{\text{DDEN}} = 0$ , double density is selected. When $\overrightarrow{\text{DDEN}} = 1$ , single density is selected.                                                                                                                                                                                                                                                        |
| 40         | HEAD LOAD TIMING                   | HLT      | When a logic high is found on the HLT input the head<br>is assumed to be engaged. It is typically derived from<br>a 1 shot triggered by HLD.                                                                                                                                                                                                                                                                                                                         |







#### APPLICATIONS

#### 8" FLOPPY AND 51/4" MINI FLOPPY CONTROLLER SINGLE OR DOUBLE DENSITY CONTROLLER/FORMATTER

The WD279X Family are MOS/LSI devices which perform the functions of a Floppy Disk Controller/Formatter. Software compatible with its predecessor, the FD179X, the device also contains a high performance Phase-Lock-Loop Data Separator as well as Write Precompensation Logic.

When operating in Double Density mode, Write Precompensation may be enabled, its value predetermined by an external potentiometer. An on-chip VCO and phase comparator allows adjustable frequency range for 5<sup>1</sup>/<sub>4</sub>" or 8" Floppy Disk interfacing.

The WD279X is fabricated in NMOS silicon gate technology and available in a 40 pin dual-in-line package.

| FEATURES             | 2791 | 2793 | 2795 | 2797 |
|----------------------|------|------|------|------|
| Single Density (FM)  | x    | x    | x    | х    |
| Double Density (MFM) | X    | X    | X    | X    |
| True Data Bus        |      | X    |      | X    |
| Inverted Data Bus    | X    |      | X    |      |
| Side Select Out      |      |      | X    | X    |
| Internal CLK Divide  | X    | х    |      |      |

#### 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). 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 registerare 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.

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.

AM Detector — The address mark detector detects ID, data and index address marks during read and write operations.

Write Precompensation — enables write precompensation to be performed on the Write Data output.

WD279X-02



#### WD279X BLOCK DIAGRAM

**Data Separator** — a high performance Phase-Lock-Loop Data Separator with on-chip VCO and phase comparator allows adjustable frequency range for 5<sup>1</sup>/<sub>4</sub>" or 8" Floppy Disk interfacing.

#### 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 WD279X. The DAL are three state buffers that are enabled as output drivers when Chip Select ( $\overline{CS}$ ) and Read Enable ( $\overline{RE}$ ) are active (low logic state) or act as input receivers when  $\overline{CS}$  and Write Enable ( $\overline{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 | - A0 | READ (RE)       | WRITE (WE)       |
|----|------|-----------------|------------------|
| 0  | 0    | Status Register | Command 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 WD279X 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.

The 279X has two modes of operation according to the state of  $\overline{\text{DDEN}}$  (Pin 37). When  $\overline{\text{DDEN}} = 1$ , Single Density (FM) is selected. When  $\overline{\text{DDEN}} = 0$ , Double Density (MFM) is selected. In either case, the CLK input (Pin 24) is set at 2 MHz for 8" drives or 1 MHz for 514" drives.

On the 2791/2793, the ENMF input (Pin 25) can be used for controlling both 51/4" and 8" drives with a single 2 MHz clock. When  $\overline{\text{ENMF}} = 0$ , an internal  $\div$  2 of the CLK is performed. When  $\overline{\text{ENMF}} = 1$ , no divide takes place. This allows the use of a 2 MHz clock for both 51/4" and 8" configurations.

The internal VCO frequency must also be set to the proper value. The 5/8 input (Pin 17) is used to select data separator operation by internally dividing the Read Clock. When 5/8 = 0, 51/4 " data separation is selected; when 5/8 = 1, 8" drive data separation is selected.

| CLOCK (24) | ENMF (25) | 5/8 (17) | DRIVE |
|------------|-----------|----------|-------|
| 2 MHz      | 1         | 1        | 8″    |
| 2 MHz      | 0         | 0        | 51⁄4″ |
| 1 MHz      | 1         | 0        | 51⁄4″ |

#### FUNCTIONAL DESCRIPTION

The WD279X-02 is software compatible with the FD179X-02 series of Floppy Disk Controllers. Commands, status, and data transfers are performed in the same way. Software generated for the 179X can be transferred to a 279X system without modification.

In addition to the 179X, the 279X contains an internal Data Separator and Write precompensation circuit. The TEST (Pin 22) line is used to adjust both data separator and precompensation. When TEST = 0, the WD (Pin 31) line is internally connected to the output of the write precompone-shot. Adjustment of the WPW (Pin 33) line can then be accomplished. A second one-shot tracks the precomp setting at approximately 3:1 to insure adequate Write Data pulse widths to meet drive specifications.

Similarly, Data separation is also adjusted with  $\overline{\text{TEST}} = 0$ . The TG43 (Pin 29) line is internally connected to the output of the read data one-shot, which is adjusted via the RPW (Pin 18) line. The DIRC (Pin 16) line contains the Read Clock output (.5 MHz for 8" drives). The VCO Trimming capacitor (Pin 26) is adjusted for center frequency.

Internal timing signals are used to generate pulses during the adjustment mode so that these adjustments can be made while the device is in-circuit. The TEST line also contains a pull-up resistor, so adjustments can be performed simply by grounding the TEST pin, overriding the pull-up. The TEST pin cannot be used to disable stepping rates during operation as its function is quite different from the 179X.

Other pins on the device also include pull-up resistors and may be left open to satisfy a Logic 1 condition. These are: ENP. 5/8, ENMF, WPRT, DDEN, HLT, TEST, and MR.

#### GENERAL 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

| Sector L                     | ength Table*                           |
|------------------------------|----------------------------------------|
| Sector Length<br>Field (hex) | Number of Bytes<br>in Sector (decimal) |
| 00                           | 128                                    |
| 01                           | 256                                    |
| 02                           | 512                                    |
| 03                           | 1024                                   |

\* 2795/97 may vary - see command summary.

placed to a logical "0." Sector lengths are determined at format time by the fourth byte in the "ID" field.

The WD279X recognizes tracks and sectors numbered 00-FFX. However, due to programming restrictions, only tracks and sectors 00 thru F4 can be formatted.

## GENERAL 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 279X 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.

For write operations, the 279X provides Write Gate (Pin 30) and Write Data (Pin 31) outputs. Write data consists of a series of pulses set to a width approximately three times greater than the precomp adjustment. Write Data provides the unique address marks in both formats.

#### READY

Whenever a Read or Write command (Type II or III) is received the 279X 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. TG43 may be tied to ENP to enable write precompensation on tracks 44-76.

#### COMMAND DESCRIPTION

The WD279X 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 1.

## A. Commands for Models: 2791, 2793

TABLE 1. COMMAND SUMMARY B. Commands for Models: 2795, 2797

| A. Commands for Models. 2791, 2790 |                 |      |   |   |   | <u>ы</u> . О | Jiiiiia | nuaro | i wou | CI3. 21 | 33, 21 | 31 |   |    |    |    |    |
|------------------------------------|-----------------|------|---|---|---|--------------|---------|-------|-------|---------|--------|----|---|----|----|----|----|
|                                    |                 | Bits |   |   |   |              |         |       | Bits  |         |        |    |   |    |    |    |    |
| Туре                               | Command         | 7    | 6 | 5 | 4 | 3            | 2       | 1     | 0     | 7       | 6      | 5  | 4 | 3  | 2  | 1  | 0  |
| I                                  | Restore         | 0    | 0 | 0 | 0 | h            | V       | r1    | ro    | 0       | 0      | 0  | 0 | h  | V  | r1 | ro |
| 1                                  | Seek            | 0    | 0 | 0 | 1 | h            | ۷       | r1    | ro    | 0       | 0      | 0  | 1 | h  | V  | r1 | ro |
| 1                                  | Step            | 0    | 0 | 1 | Т | h            | ۷       | r۱    | ro    | 0       | 0      | 1  | Т | h  | V  | r1 | ro |
| 1                                  | Step-in         | 0    | 1 | 0 | Т | h            | V       | r۱    | ro    | 0       | 1      | 0  | Т | h  | V  | r1 | ro |
| 1                                  | Step-out        | 0    | 1 | 1 | T | h            | ٧       | r1    | r0    | 0       | 1      | 1  | Т | h  | V  | r1 | ro |
| 11                                 | Read Sector     | 1    | 0 | 0 | m | S            | Е       | С     | 0     | 1       | 0      | 0  | m | L  | Е  | U  | 0  |
| 11                                 | Write Sector    | 1    | 0 | 1 | m | S            | Е       | С     | ao    | 1       | 0      | 1  | m | L  | Е  | U  | a0 |
| III                                | Read Address    | 1    | 1 | 0 | 0 | 0            | Е       | 0     | 0     | 1       | 1      | 0  | 0 | 0  | Ε  | U  | 0  |
| III                                | Read Track      | 1    | 1 | 1 | 0 | 0            | Е       | 0     | 0     | 1       | 1      | 1  | 0 | 0  | Ε  | U  | 0  |
| 111                                | Write Track     | 1    | 1 | 1 | 1 | 0            | Е       | 0     | 0     | 1       | 1      | 1  | 1 | 0  | Ε  | U  | 0  |
| IV                                 | Force Interrupt | 1    | 1 | 0 | 1 | Iз           | l2      | 11    | l0    | 1       | 1      | 0  | 1 | lз | l2 | 4  | l0 |

#### FLAG SUMMARY

#### TABLE 2. FLAG SUMMARY

| Command<br>Type | Bit<br>No(s) |                                                                                                                                                                                                    | Description                                                          |
|-----------------|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------|
| 1               | 0, 1         | <sup>r</sup> 1 <sup>r</sup> 0 = Stepping Motor Rate<br>See Table 3 for Rate Summary                                                                                                                |                                                                      |
| I               | 2            | V = Track Number Verify Flag                                                                                                                                                                       | V = 0, No verify<br>V = 1, Verify on destination track               |
| I               | 3            | h = Head Load Flag                                                                                                                                                                                 | h = 0, Unload head at beginning<br>h = 1, Load head at beginning     |
| I               | 4            | T = Track Update Flag                                                                                                                                                                              | T = 0, No update<br>T = 1, Update track register                     |
| II & III        | 0            | <sup>a</sup> 0 = Data Address Mark                                                                                                                                                                 | <sup>a</sup> 0 = 0, FB (DAM)<br><sup>a</sup> 0 = 1, F8 (deleted DAM) |
| 11              | 1            | C = Side Compare Flag                                                                                                                                                                              | C = 0, Disable side compare<br>C = 1, Enable side compare            |
| &               | 1            | U = Update SSO                                                                                                                                                                                     | U = 0, Update SSO to 0<br>U = 1, Update SSO to 1                     |
| &               | 2            | E = 15 MS Delay                                                                                                                                                                                    | E = 0, No. 15 MS delay<br>E = 1, 15 MS delay (30 MS for 1 MHz)       |
| II              | 3            | S = Side Compare Flag                                                                                                                                                                              | S = 0, Compare for side 0<br>S = 1, Compare for side 1               |
| II              | 3            | L = Sector Length Flag                                                                                                                                                                             | LSB's Sector Length in ID Field<br>00 01 10 11                       |
|                 |              |                                                                                                                                                                                                    | L = 0 256 512 1024 128                                               |
|                 |              |                                                                                                                                                                                                    | L = 1 128 256 512 1024                                               |
| II              | 4            | m = Multiple Record Flag                                                                                                                                                                           | m = 0, Single record<br>m = 1, Multiple records                      |
| IV              | 0-3          | $      I_x = Interrupt Condition F       I_0 = 1 Not Ready To Read       I_1 = 1 Ready To Not Read       I_2 = 1 Index Pulse       I_3 = 1 Immediate Interrup       I_3-I_C = 0 Terminate With No$ | ly Transition<br>ly Transition<br>t, Requires A Reset*               |

\*NOTE: See Type IV Command Description for further information.

#### Write Precompensation

When operating in Double Density mode ( $\overline{DDEN} = 0$ ), the 279X has the capability of providing a user-defined precompensation value for Write Data. An external potentiometer (10K) tied to the WPW signal (Pin 33) allows a setting of 100 to 300 ns from nominal.

Setting the Write precomp value is accomplished by forcing the TEST line (Pin 22) to a Logic 0. A stream of pulses can then be seen on the Write Data (Pin 31) line. Adjust the WPW Potentiometer for the desired pulse width. This adjustment may be performed in-circuit since Write Gate (Pin 30) is inactive while TEST = 0.

#### **Data Separation**

The 279X can operate with either an external data separator or its own internal recovery circuits. The condition of the TEST line (Pin 22) in conjunction with  $\overline{\text{MR}}$  (Pin 19) will select internal or external mode.

To program the 279X for external VCO, a  $\overline{\text{MR}}$  pulse must be applied while  $\overline{\text{TEST}} = 0$ . A clock equivalent to eight times the data rate (e.g., 4.0 MHz for 8" Double Density) is applied to the VCO input (Pin 26). The feedback reference voltage is available on the Pump output (Pin 23) for external integration to control the VCO. TEST is returned to a Logic 1 for normal operation. Note: To maintain-this mode, TESTmust be held low whenever MR is applied.

For internal VCO operation, the  $\overline{\text{TEST}}$  line must be high during the  $\overline{\text{MR}}$  pulse, then set to a Logic 0 for the adjustment procedure.

A 50K Potentiometer tied to the RPW input (Pin 18) is used to set the internal Read Data pulse for proper phasing. With a scope on Pin 29 (TG43), adjust the RPW pulse for 1/8 of the data rate (250 ns for 8" Double Density). An external variable capacitor of 560 pf is tied to the VCO input (Pin 26) for adjusting center frequency. With a frequency counter on Pin 16 (DIRC) adjust the trimmer cap to yield the appropriate Data Rate (500 KHz for 8" Double Density). The DDEN line must be low while the 5/8 line is held high or the adjustment times above will be doubled.

After adjustments have been made, the TEST pin is returned to a Logic 1 and the device is ready for operation. Adjustments may be made in-circuit since the DIRC and TG43 lines may toggle without affecting the drive.

The PUMP output (Pin 23) consists of positive and negative pulses, which their duration is equivalent to the phase difference of incoming Data vs. VCO frequency. This signal is internally connected to the VCO input, but a Filter is needed to connect these pulses to a slow moving DC voltage.

The internal phase-detector is unsymmetrical for a random distribution of data pulses by a factor of two, in favor of a PUMP UP condition. Therefore, it is desirable to have a PUMP DOWN twice as responsive to prevent run-away during a lock attempt.

A first order lag-lead filter can be used at the PUMP output (Pin 23). This filter controls the instantaneous response of the VCO to bit-shifted data (jitter) as well as the response to normal frequency shift, i.e., the lock-up time. A balance must be accomplished between the two conditions to inhibit over-responsiveness to jitter and to prevent an extremely wide lock-up response, leading to PUMP runaway. The filter affects these two reactions in mutually opposite directions.

The following Filter Circuit is recommended for 8" FM/MFM:



Since 51/4 " Drives operate at exactly one-half the data rate (250 Kb/sec) the above capacitor should be doubled to .2 or .22 $\mu$ f.

#### **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 (r<sub>0</sub> r<sub>1</sub>), which determines the stepping motor rate as defined in Table 3.

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. The chip will step the drive in the same direction it last stepped unless the command changes the direction.

The Direction signal is active high when stepping in and low when stepping out. The Direction signal is valid before the first stepping pulse is generated.

The rates (shown in Table 3) can be applied to a Step-Direction Motor through the device interface.

| C  | LK | 2 MHz                        | 1 MHz                        |
|----|----|------------------------------|------------------------------|
| R1 | R0 | $\overline{\text{TEST}} = 1$ | $\overline{\text{TEST}} = 1$ |
| 0  | 0  | 3 ms                         | 6 ms                         |
| 0  | 1  | 6 ms                         | 12 ms                        |
| 1  | 0  | 10 ms                        | 20 ms                        |
| 1  | 1  | 15 ms                        | 30 ms                        |

TABLE 3. STEPPING RATES

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. There is also a 15 ms head settling time if the E flag is set in any Type II or III command.

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. 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.

The WD279X 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. If V = 0, no verification is performed.

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 279X is in an idle state (non-busy) and 15 index pulses have occurred.

Head Load timing (HLT) is an input to the 279X which is used for the head engage time. When HLT = 1, the 279X 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 279X.



#### HEAD LOAD TIMING

When both HLD and HLT are true, the 279X will then read from or write to the media. The "and" of HLD and HLT appears as status Bit 5 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 279X 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 279X 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.

#### **RESTORE (SEEK TRACK 0)**

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 an interrupt is generated. If TR00 is not

active low, stepping pulses at a rate specified by the <sup>r</sup>1<sup>r</sup>0 field are issued until the TR00 input is activated. At this time the Track Register is loaded with zeroes and an interrupt is generated. If the TR00 input does not go active low after 255 stepping pulses, the 279X 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{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 WD279X will update the Track register and issue stepping pulses in the appropriate direction until the



#### TYPE I COMMAND FLOW



#### TYPE I COMMAND FLOW

contents of the Track register are equal to the contents of the Data Register (the desired track location). A verification operation takes place if the V flag is on. The h bit allows the head to be loaded at the start of the command. An interrupt is generated at the completion of the command. Note: When using multiple drives, the track register must be updated for the drive selected before seeks are issued.

#### STEP

Upon receipt of this command, the 279X 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 <sup>r</sup>1<sup>r</sup>0 field, a verification takes place if the V flag is on. If the T 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 279X issues one stepping pulse in the direction towards track 76. If the T flag is on, the Track Register is incremented by one. After a



#### TYPE I COMMAND FLOW

delay determined by the <sup>r</sup>1<sup>r</sup>0 field, a verification takes place if the V flag is on. The h bit allows the head to be loaded at the start of the command. An interrupt is generated at the completion of the command.

#### STEP-OUT

Upon receipt of this command, the 279X issues one stepping pulse in the direction towards track 0. If the T flag is on, the Track Register is decremented by one. After a delay determined by the  $^{T_1O}$  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.

#### EXCEPTIONS

On the 2795/7 devices, the SSO output is not affected during Type I commands, and an internal side compare does not take place when the (V) Verify Flag is on.

#### **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

WD279X-02

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.

When an ID field is located on the disk, the 279X 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







TYPE II COMMAND

depending upon the command. The 279X must find an ID field with a Track number, Sector number, side number, and CRC within 5 revolutions of the disk; otherwise, the Record not found status bit is set (Status bit 4) 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 279X will continue to read or write multiple records and update the sector register in numerical ascending sequence until the sector register exceeds the number of sectors on the track or until the Force Interrupt command is loaded into the Command Register, which terminates the command and generates an interrupt.

For example: If the 279X is instructed to read sector 27 and there are only 26 on the track, the sector register exceeds



#### TYPE II COMMAND

the number available. The 279X will search for 5 disk revolutions, interrupt out, reset busy, and set the record not found status bit.

The Type II commands for 2791-93 also contain side select compare flags. When C = 0 (Bit 1) 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 (Bit 3). If the S flag compares with the side number recorded in the ID field, the 279X 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.

The Type II and III commands for the 2795-97 contain a side select flag (Bit 1). When U = 0, SSO is updated to 0. Similarly, U = 1 updates SSO to 1. The chip compares the SSO to the ID field. If they do not compare within 5 revolutions the interrupt line is made active and the RNF status bit is set.

The 2795/7 READ SECTOR and WRITE SECTOR com-



#### TYPE II COMMAND

mands include a 'L' flag. The 'L' flag, in conjunction with the sector length byte of the ID Field, allows different byte lengths to be implemented in each sector. For IBM compatibility, the 'L' flag should be set to a one.

#### 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 ID field search is repeated.

When the first character or byte of the data field has been shifted through the DSR, it is transferred to the DR, and DRQ is generated. When the next byte is accumulated in the DSR, it is transferred to the DR and another DRQ is generated. If the Computer has not read the previous contents of the DR before a new character is transferred that character is lost and the Lost Data Status bit is set. This sequence continues until the complete data field has been inputted to the computer. If there is a CRC error at the end of the data field, the CRC error status bit is set, and the command is terminated (even if it is a multiple sector 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:

| STATUS<br>BIT 5 |                   |
|-----------------|-------------------|
| 1               | Deleted Data Mark |
| 0               | Data Mark         |
|                 |                   |

#### 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 279X 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 zeroes 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 <sup>2</sup>0 field of the command as shown below:

| a0 | Data Address Mark (Bit 0) |
|----|---------------------------|
| 1  | Deleted Data Mark         |
| 0  | Data Mark                 |

The 279X 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 by one bye of FE in FM or in MFM. The WG output is then deactivated. For a 2 MHz clock the INTRQ will set 8 to 12  $\mu$ sec after the last CRC byte is written. For partial sector writing, the proper method is to write the data and fill the balance with zeroes. By letting the chip fill the zeroes, errors may be masked by the lost data status and improper CRC Bytes.

#### TYPES III COMMANDS READ ADDRESS

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

| TRACK | SIDE   | SECTOR  | SECTOR | CRC | CRC |
|-------|--------|---------|--------|-----|-----|
| ADDR  | NUMBER | ADDRESS | LENGTH | 1   | 2   |
| 1     | 2      | 3       | 4      | 5   | 6   |

Although the CRC characters are transferred to the



WD279X-02

#### TYPE III COMMAND WRITE TRACK

computer, the 279X 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 so that a comparison can be made by the host. At the end of the operation an interrupt is generated and the Busy Status is reset.

#### READ TRACK

123

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. All Gap, Header, and data bytes are assembled and transferred to the data register and DRQ's are generated for each byte. The ac-



**TYPE III COMMAND WRITE TRACK** 

cumulation of bytes is synchronized to each address mark encountered. An interrupt is generated at the completion of the command.

This command has several characteristics which make it suitable for diagnostic purposes. They are: no CRC checking is performed; gap information is included in the data stream; the internal side compare is not performed; and the address mark detector is on for the duration of the command. Because the A.M. detector is always on, write splices or noise may cause the chip to look for an A.M. If an address mark does not appear on schedule with the Lost Data status flag being set.

The ID A.M., ID field, ID CRC bytes, DAM, Data and Data CRC Bytes for each sector will be correct. The Gap Bytes may be read incorrectly during write-splice time because of synchronization.

#### WRITE TRACK 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 with a large amount of memory. Data and gap information 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 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 zeroes is substituted.

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 279X 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.

The CRC generator is initialized when any data byte from F8 to FE is about to be transferred from the DR to the DSR

| DATA PATTERN<br>IN DR (HEX) | WD279X INTERPRETATION<br>IN FM (DDEN = 1) | WD279X INTERPRETATION<br>IN MFM (DDEN = 0) |
|-----------------------------|-------------------------------------------|--------------------------------------------|
| 00 thru F4                  | Write 00 thru F4 with CLK = FF            | Write 00 thru F4, in MFM                   |
| F5                          | Not Allowed                               | Write A1* in MFM, Preset CRC               |
| F6                          | Not Allowed                               | Write C2** in MFM                          |
| F7                          | Generate 2 CRC bytes                      | Generate 2 CRC bytes                       |
| F8 thru FB                  | Write F8 thru FB, Clk = C7, Preset CRC    | Write F8 thru FB, in MFM                   |
| FC                          | Write FC with Clk = D7                    | Write FC in MFM                            |
| FD                          | Write FD with Clk = FF                    | Write FD in MFM                            |
| FE                          | Write FE, Clk = C7, Preset CRC            | Write FE in MFM                            |
| FF                          | Write FF with Clk = FF                    | Write FF in MFM                            |

CONTROL BYTES FOR INITIALIZATION

\* Missing clock transition between bits 4 and 5

\*\* Missing clock transition between bits 3 and 4

or by receipt of F5 in MFM. 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.

#### **TYPE IV COMMANDS**

The Forced Interrupt command is generally used to terminate a multiple sector read or write command or to insure Type I status in the status register. 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 the busy status bit reset.

The lower four bits of the command determine the conditional interrupt as follows:

- I0 = Not-Ready to Ready Transition
- I1 = Ready to Not-Ready Transition
- 2 = Every Index Pulse
- I3 = Immediate Interrupt

The conditional interrupt is enabled when the corresponding bit positions of the command ( $^{1}3 \cdot ^{1}0$ ) are set to a 1. Then, when the condition for interrupt is met, the INTRQ line will go high signifying that the condition specified has occurred. If  $^{1}3 \cdot ^{1}0$  are all set to zero (HEX D0), no interrupt will occur but any command presently under execution will be immediately terminated. When using the immediate



interrupt condition  $^{I_3} = 1$ ), 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. The HEX D0 is the only command that will enable the immediate interrupt (HEX D8) to clear on a subsequent load command register or read status register operation. Follow a HEX D8 with D0 command.

Wait 8 micro sec (double density) or 16 micro sec (single density) before issuing a new command after issuing a forced interrupt (times double when clock = 1 MHz). Loading a new command sooner than this will nullify the forced interrupt.

Forced interrupt stops any command at the end of an internal micro-instruction and generates INTRQ when the specified condition is met. Forced interrupt will wait until ALU operations in progress are complete (CRC calculations, compares, etc.)

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.



#### STATUS REGISTER

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 user has the option of reading the status register through program control or using the DRQ line with DMA or interrupt methods. When the Data register is read the DRQ bit in the status register and the DRQ line are automatically reset. A write to the Data register also causes both DRQ's to reset.

The busy bit in the status may be monitored with a user program to determine when a command is complete, in lieu of using the INTRQ line. When using the INTRQ, a busy status check is not recommended because a read of the status register to determine the condition of busy will reset the INTRQ line.

The format of the Status Register is shown below:

|    |    |    | (Bľ | TS) |    |    |    |
|----|----|----|-----|-----|----|----|----|
| 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 4.

Because of internal sync cycles, certain time delays must be observed when operating under programmed I/O. They are: (times double when clock = 1 MHz)

|                          |                                 | Delay | Req'd. |
|--------------------------|---------------------------------|-------|--------|
| Operation                | Next Operation                  | FM    | MFM    |
| Write to<br>Command Reg. | Read Busy Bit<br>(Status Bit 0) | 12µS  | 6µs    |
| Write to<br>Command Reg. | Read Status<br>Bits 1-7         | 28µs  | 14µs   |
| Write Any<br>Register    | Read From Diff.<br>Register     | 0     | 0      |

#### 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.

| NUMBER<br>OF BYTES | HEX VALUE OF<br>BYTE WRITTEN |
|--------------------|------------------------------|
| 40                 | FF (or 00) <sup>3</sup>      |
| 6                  | 00                           |
| 1                  | FC (Index Mark)              |
| 1 26               | FF (or 00)                   |
| 6                  | 00                           |
|                    | FE (ID Address Mark)         |
| 1                  | Track Number                 |
| 1                  | Side Number (00 or 01)       |
| 1                  | Sector Number (1 thru 1A)    |
| 1                  | 00 (Sector Length)           |
|                    | F7 (2 CRC's written)         |
| 11                 | FF (or 00)                   |
| 6                  | 00                           |
| 1                  | FB (Data Address Mark)       |
| 128                | Data (IBM uses E5)           |
| 1                  | F7 (2 CRC's written)         |
| 27                 | FF (or 00)                   |
| 2472               | FF (or 00)                   |

- 1. Write bracketed field 26 times
- Continue writing until 279X interrupts out. Approx. 247 bytes.

3. A '00' option is allowed.

#### IBM SYSTEM 34 FORMAT-256 BYTES/SECTOR

Shown below is the IBM dual-density format with 256 bytes/sector. In order for 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.

| NUMBER   | HEX VALUE OF              |
|----------|---------------------------|
| OF BYTES | BYTE WRITTEN              |
| 80       | 4E                        |
| 12       | 00                        |
| 3        | F6 (Writes C2)            |
| 1        | FC (Index Mark)           |
| * 50     | 4E                        |
| 12       | 00                        |
| 3        | F5 (Writes A1)            |
| 1        | FE (ID Address Mark)      |
| 1        | Track Number (0 thru 4C)  |
| 1        | Side Number (0 or 1)      |
| 1        | Sector Number (1 thru 1A) |
| 1        | 01 (Sector Length)        |
| 1        | F7 (2 CRCs written)       |
| 22       | 4E                        |
| 12       | 00                        |
| 3        | F5 (Writes A1)            |
| 1        | FB (Data Address Mark)    |
| 256      | DATA                      |
| 1        | F7 (2 CRCs written)       |
| 54       | 4E                        |
| 598**    | 4E                        |

\* Write bracketed field 26 times

\*\* Continue writing until 279X interrupts out. Approx. 598 bytes.



**IBM TRACK FORMAT** 

#### 1. NON-IBM FORMATS

Variations in the IBM formats are possible to a limited extent if the following requirements are met:

- 1) Sector size must be 128, 256, 512 of 1024 bytes.
- 2) Gap 2 cannot be varied from the IBM format.
- 3) 3 bytes of A1 must be used in MFM.

In addition, the Index Address Mark is not required for operation by the 279X. Gap 1, 3, and 4 lengths can be as short as 2 bytes for 279X operation, however PLL lock up time, motor speed variation, write splice area, etc. will add more bytes to each gap to achieve proper operation. It is recommended that the IBM format be used for highest system reliability.

#### MFM FM 16 bytes FF 32 bytes 4E Gap I Gap II 11 bytes FF 22 bytes 4E \* 6 bytes 00 12 bytes 00 . 3 bytes A1 Gap III\*\* 10 bytes FF 24 bytes 4E 4 bytes 00 8 bytes 00 3 bytes A1 16 bytes 4E Gap IV 16 bytes FF

\* Byte counts must be exact.

\*\* Byte counts are minimum, except exactly 3 bytes of A1 must be written.

NOTE: Maximum limits indicate where permanent device damage occurs. Continuous operation at these limits is not intended and should be limited to those conditions specified in the DC Electrical characteristics.

## ELECTRICAL CHARACTERISTICS

#### Absolute Maximum Ratings

Voltage to any input with respect to  $V_{SS} = +7$  to -0.5V

Operating temperature =  $0^{\circ}$ C to  $70^{\circ}$ C Storage temperature =  $-55^{\circ}$ C to  $+125^{\circ}$ C

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

 $T_A = 0^{\circ}C$  to 70°C,  $V_{SS} = 0V$ ,  $V_{CC} = +5V \pm .25V$ 

| SYMBOL | CHARACTERISTIC      | MIN. | TYP. | MAX. | UNITS | CONDITIONS           |
|--------|---------------------|------|------|------|-------|----------------------|
| կլ     | Input Leakage       |      |      | 10   | μA    | VIN = VCC            |
| IOL    | Output Leakage      |      |      | 10   | μA    | VOUT = VCC           |
| VĨH    | Input High Voltage  | 2.0  |      |      | v     |                      |
| VIL    | Input Low Voltage   |      |      | 0.8  | v     |                      |
| VoH    | Output High Voltage | 2.4  |      |      | V     | $I_{O} = -100 \mu A$ |
| VOL    | Output Low Voltage  |      |      | 0.45 | v     | $l_0 = 1.6  mA$      |
| VOHP   | Output High PUMP    | 2.2  |      |      | V     | lop = -1.0 mA        |
| VOLP   | Output Low PUMP     |      |      | 0.2  | V     | IOP = +1.0  mA       |
| PD     | Power Dissipation   |      |      | .75  | w     | All Outputs Open     |
| RPU    | Internal Pull-up*   | 100  |      | 1700 | μA    | $V_{IN} = 0V$        |
| ICC    | Supply Current      |      | 70   | 150  | mA    | All Outputs Open     |

\* Internal Pull-up resistors on PINS 1, 17, 19, 22, 36, 37 and 40. Also pin 25 on 2791 and 3.

#### TIMING CHARACTERISTICS

## $T_{\mbox{\scriptsize A}}$ = 0°C to 70°C, $V_{\mbox{\scriptsize SS}}$ = 0V, $V_{\mbox{\scriptsize CC}}$ = +5V $\pm$ .25V

## READ ENABLE TIMING

| SYMBOL | CHARACTERISTIC         | MIN. | TYP. | MAX. | UNITS | CONDITIONS             |
|--------|------------------------|------|------|------|-------|------------------------|
| TSET   | Setup ADDR & CS to RE  | 50   |      |      | nsec  |                        |
| THLD   | Hold ADDR & CS from RE | 10   |      |      | nsec  |                        |
| TRE    | RE Pulse Width         | 200  |      |      | nsec  | CL = 50 pf             |
| TDRR   | DRQ Reset from RE      |      | 100  | 200  | nsec  |                        |
| TIBB   | INTRQ Reset from RE    |      | 500  | 3000 | nsec  | See Note               |
| TDACC  | Data Valid from RE     |      | 100  | 200  | nsec  | C <sub>L</sub> = 50 pf |
| Трон   | Data Hold From RE      | 20   |      | 150  | nsec  | $C_L = 50  pf$         |

#### WRITE ENABLE TIMING

| SYMBOL | CHARACTERISTIC         | MIN. | TYP. | MAX. | UNITS | CONDITIONS |
|--------|------------------------|------|------|------|-------|------------|
| TSET   | Setup ADDR & CS to WE  | 50   |      |      | nsec  |            |
| THLD   | Hold ADDR & CS from WE | 10   |      |      | nsec  |            |
| TWE    | WE Pulse Width         | 200  |      | 1    | nsec  |            |
| TDBB   | DRQ Reset from WE      |      | 100  | 200  | nsec  |            |
| TIRR   | INTRQ Reset from WE    |      | 500  | 3000 | nsec  | See Note   |
| TDS    | Data Setup to WE       | 150  |      | 1    | nsec  |            |
| TDH    | Data Hold from WE      | 50   |      |      | nsec  |            |



## INPUT DATA TIMING

| SYMBOL                             | CHARACTERISTIC                              | MIN.        | TYP.        | MAX. | UNITS        | CONDITIONS |
|------------------------------------|---------------------------------------------|-------------|-------------|------|--------------|------------|
| T <sub>PW</sub><br>T <sub>BC</sub> | Raw Read Pulse Width<br>Raw Read Cycle Time | 100<br>1500 | 200<br>2000 |      | nsec<br>nsec |            |

## WRITE DATA TIMING: (ALL TIMES DOUBLE WHEN CLK = 1 MHz) (NO WRITE PRECOMPENSATION)

| SYMBOL | CHARACTERISTIC           | MIN.       | TYP.       | MAX.       | UNITS        | CONDITIONS |
|--------|--------------------------|------------|------------|------------|--------------|------------|
| TWP    | Write Data Pulse Width   | 400<br>200 | 500<br>250 | 600<br>300 | nsec<br>nsec | FM<br>MFM  |
| TWG    | Write Gate to Write Data | 200        | 2          | 500        | μsec         | FM         |
| TWF    | Write Gate off from WD   |            | 2          |            | μsec<br>μsec | MFM<br>FM  |
|        |                          |            | 1          |            | μsec         | MFM        |

#### **MISCELLANEOUS TIMING:**

| SYMBOL           | CHARACTERISTIC                 | MIN.   | TYP. | MAX.       | UNITS | CONDITIONS                    |
|------------------|--------------------------------|--------|------|------------|-------|-------------------------------|
| TCD1             | Clock Duty (low)               | 230    | 250  | 20000      | nsec  |                               |
| TCD <sub>2</sub> | Clock Duty (high)              | 230    | 250  | 20000      | nsec  |                               |
| TSTP             | Step Pulse Output              | 2 or 4 |      |            | μsec  | See Note                      |
| TDIR             | Dir Setup to Step              |        | 12   |            | μsec  | ± CLK ERROR                   |
| TMR              | Master Reset Pulse Width       | 50     |      |            | μsec  |                               |
| TIP              | Index Pulse Width              | 10     |      |            | μsec  | See Note                      |
| RPW              | Read Window Pulse Width        |        | -    |            |       | Input 0-5V                    |
|                  |                                | 120    |      | 700        | nsec  | MFM                           |
|                  |                                | 240    |      | 1400       | nsec  | FM ± 15%                      |
|                  | Precomp Adjust.                | 100    |      | 300        | nsec  | MFM                           |
| WPW              | Write Data Pulse Width         |        |      |            |       | Precomp = 100 nsec            |
|                  |                                | 200    | 300  | 400        | nsec  | MFM                           |
| WPW              | Write Data Pulse Width         |        |      |            |       | Precomp = 300 nsec            |
|                  |                                | 600    | 900  | 1200       | nsec  | MFM                           |
| VCO              | Free Run Voltage Controlled    | 6.0    |      |            | MHz   | Cext = 0                      |
|                  | Oscillator. Adjustable by ext. |        | 4.0  |            | MHz   | Cext = 35 pf                  |
|                  | capacitor on Pin 26            |        |      |            |       |                               |
|                  | Pump Up + 25%                  | 5.0    |      |            | MHz   | PU = 2.2V                     |
|                  |                                |        |      |            |       | Cext = 35 pf                  |
| VCO              | Pump Down – 25%                |        |      | 3.0        | MHz   | $\overline{PD} = 0.2V$        |
|                  |                                |        |      | 0.0        |       | Cext = 35 pf                  |
|                  | 5% Change VCC                  | 3.8    |      | 4.2        | MHz   | Cext = 35 pf                  |
| vco              | $T_{\Delta} = 75^{\circ}C$     | 3.5    |      |            | MHz   | Cext = 35 pf                  |
| Cext             | Adjustable external capacitor  | 20     | 45   | 100        | pf    | VCO = 4.0MHz                  |
|                  |                                | 20     | -0   | 100        |       | nom                           |
| RCLK             | Derived read clock             |        |      |            |       | VCO = 4.0MHz                  |
|                  | $=$ VCO $\div$ 8, 16, 32       |        |      |            |       | V00 = 4.0M112                 |
|                  |                                |        | 500  |            | KHz   | $\overline{\text{DDEN}} = 0$  |
|                  |                                |        | 000  |            | 13/12 | 5/8 = 1                       |
|                  |                                |        | 250  |            | KHz   | $\overline{\text{DDEN}} = 0$  |
|                  |                                |        | 200  |            | 13112 | 5/8 = 0                       |
|                  |                                |        | 250  |            | KHz   | $\overline{\text{DDEN}} = 1$  |
|                  |                                |        | 230  |            | 1012  | $\overline{5}/8 = 1$          |
|                  |                                |        | 125  |            | KHz   | $\frac{5/6}{\text{DDEN}} = 1$ |
|                  |                                |        | 120  |            | NHZ   | 5/8 = 0                       |
| PU/DON           | PU/PD time on                  |        |      | 250        |       | 5/8 = 0<br>MFM                |
| 10,001           | (pulse width)                  |        |      | 250<br>500 | ns    |                               |
|                  | (paide width)                  |        |      | 500        | ns    | FM                            |



NOTES:

- 1. Times double when clock = 1 MHz.
- 2. Output timing readings are at V\_OL = 0.8v and V\_OH = 2.0v.



#### WRITE DATA TIMING



MISCELLANEOUS TIMING

\* FROM STEP RATE TABLE

## Table 4. STATUS REGISTER SUMMARY

| віт                              | ALL TYPE I<br>COMMANDS                                                   | READ<br>ADDRESS                                   | READ<br>SECTOR                                              | READ<br>TRACK                      | WRITE<br>SECTOR                                   | WRITE<br>TRACK                     |
|----------------------------------|--------------------------------------------------------------------------|---------------------------------------------------|-------------------------------------------------------------|------------------------------------|---------------------------------------------------|------------------------------------|
| S7<br>S6                         | NOT READY<br>WRITE<br>PROTECT                                            | NOT READY<br>0                                    | NOT READY<br>0                                              | NOT READY<br>0                     | NOT READY<br>WRITE<br>PROTECT                     | NOT READY<br>WRITE<br>PROTECT      |
| S5<br>S4<br>S3<br>S2<br>S1<br>S0 | HEAD LOADED<br>SEEK ERROR<br>CRC ERROR<br>TRACK 0<br>INDEX PULSE<br>BUSY | 0<br>RNF<br>CRC ERROR<br>LOST DATA<br>DRQ<br>BUSY | RECORD TYPE<br>RNF<br>CRC ERROR<br>LOST DATA<br>DRQ<br>BUSY | 0<br>0<br>LOST DATA<br>DRQ<br>BUSY | 0<br>RNF<br>CRC ERROR<br>LOST DATA<br>DRQ<br>BUSY | 0<br>0<br>LOST DATA<br>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.<br>This bit is an inverted copy of the Ready input and logically 'ored' with MR. |
| S6 PROTECTED   | When set, indicates Write Protect is activated. This bit is an inverted copy of 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<br>signals.                                                                         |
| S4 SEEK ERROR  | When set, the desired track was not verified. This bit is reset to 0 when updated.                                                                                                    |
| S3 CRC 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.                                                                                     |
| S0 BUSY        | When set command is in progress. When reset no command is in progress.                                                                                                                |

#### STATUS FOR TYPE II AND III COMMANDS

| BIT NAME                     | MEANING                                                                                                                                                                                                                                            |
|------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| S7 NOT READY                 | This bit when set indicates the drive is not ready. When reset, it indicates that the drive is ready. This bit is an inverted copy of the Ready input and 'ored' with MR. The Type II and III Commands will not execute unless the drive is ready. |
| S6 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               | On Read Record: It indicates the record-type code from data field address mark. 1 = Deleted Data Mark. 0 = Data Mark. On any Write: Forced to a Zero.                                                                                              |
| 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 DRQ output. When set, it indicates the DR is full on a Read Operation or the DR is empty on a Write operation. This bit is reset to zero when updated.                                                                   |
| S0 BUSY                      | When set, command is under execution. When reset, no command is under execution.                                                                                                                                                                   |

#### SUMMARY OF ADJUSTMENT PROCEDURE

#### WRITE PRECOMPENSATION

- 1) Set TEST (Pin 22) to a logic high.
- 2) Strobe MR (Pin 19).
- 3) Set TEST (Pin 22) to a logic low.
- 4) Observe pulse width on WD (Pin 31).
- 5) Adjust WPW (Pin 33) for desired pulse width (Precomp Value).
- 6) Set TEST (Pin 22) to a logic high.

#### DATA SEPARATOR

- 1) Set TEST (Pin 22) to a logic high.
- 2) Strobe MR (Pin 19). Insure that 5/8, and DDEN are set properly.
- 3) Set TEST (Pin 22) to a logic low.
- 4 Observe Pulse Width on TG43 (Pin 29).
- 5) Adjust RPW (Pin 18) for 1/8 of the read clock (250ns for 8" DD, 500ns for 51/4" DD, etc.).
- 6) Observe Frequency on DIRC (Pin 16).
- 7) Adjust variable capacitor on VCO pin for Data Rate (500 KHz for 8" DD, 250 KHz for 51/4" DD, etc.).
- 8) Set TEST (Pin 22) to a logic high.

NOTE: To maintain internal VCO operation, insure that TEST = 1 whenever a master reset pulse is applied.

## WESTERN DIGITAL

WD279X-02 Floppy Disk Formatter/Controller Family Application Notes

#### INTRODUCTION

In an effort to simplify Floppy Diskette interfacing, Western Digital has been constantly improving the LSI Controller/Formatter, the most recent of which is the WD279X Family of LSI controller devices, incorporating advanced technology to include controller, Write Precompensation and Analog Phase Lock Loop in a single 40 pin dual-in-line package. With this package we can now offer the designer the simplest ever interfacing option.

The family consists of four members, WD2791, WD2793, WD2795 and WD2797. WD2791 and WD2793 offer internal clock divide in true and inverted data bus. The WD2795 and WD2797 offer internal side select. The family supports both 51⁄4" and 8" Diskette Drives and both single and double density.

#### HOST INTERFACING

The LSI Diskette Controller has been developed to ease the interfacing of Processor to Disk Device. The Host interfacing with WD279X Family is accomplished with minimum external devices via an 8 bit Bidirectional bus, read/write controls, register select lines and optional control line for chip select, 51⁄4 " or 8" select, enable mini floppy, double density enable. The basic operation at the controller is accomplished by selecting the device via (CS) chip select line, enabling selection of one of the five internal registers (Figure 1).

| A1 | · A0 | READ (RE)       | WRITE (WE)       |
|----|------|-----------------|------------------|
| 0  | 0    | Status Register | Command Register |
| 0  | 1    | Track Register  | Track Register   |
| 1  | 0    | Sector Register | Sector Register  |
| 1  | 1    | Data Register   | Data Register    |

#### Figure 1.

Each time a command is issued to the WD279X, the busy bit is set and INTRQ (Interrupt Request) line is reset. The user has the option of testing for the busy bit or polling INTRQ to determine if command has been completed.

The busy bit will be reset whenever the WD279X is idle and awaiting a new command. The INTRQ line once set, can only be reset by reading of the status register or issuing a new command.

The A<sub>0</sub>, A<sub>1</sub> Lines used for register selections can be configured at the CPU in a variety of ways. These

lines may actually tie to CPU addressed like RAM. They may also be used under Program Control by tying to a port device such as the 8255, 6250, etc. As a diagnostic tool when checking out the CPU interface, the Track and Sector registers should respond like "RAM" when the WD279X is idle (Busy = INTRQ = 0).

Because of internal synchronization cycles, certain time delays must be introduced when operating under Programmed I/O. The worst case delays are:

| OPERATION                | NEXT<br>OPERATION               |      | REQ'D.<br>MFM |
|--------------------------|---------------------------------|------|---------------|
| Write to<br>Command Reg. | Read Busy Bit<br>(Status Bit 0) | 12µs | 6µs           |
| Write to<br>Command Reg. | Read Status<br>Bits 1-7         | 28µs | 14µs          |
| Write Any<br>Register    | Read From Diff.<br>Register     | 0    | 0             |

Other CPU interface lines are CLK, MR and DDEN. The CLK line should be 2 MHz (8" drive) or 1 MHz (514" drive) with 50% duty cycle. Accuracy should be + 1% (crystal source) since all internal timing, including stepping rates, are based upon this clock, or a single 2 MHz CLK on WD2791 and WD2793 since ENMF line will internally divide CLK.

The MR or Master Reset Line should be strobed a minimum of 50 microseconds upon each power-on condition. This line clears and initializes all internal registers and issues a restore command (Hex '03') on the rising edge. A quicker stepping rate can be written to the command register after a MR, in which case the remaining steps will occur at the faster programmed rate. The WD179X will issue a maximum of 255 stepping pulses in an attempt to expect the TR00 line to go active low. This line should be connected to the drive's TR00 sensor.

The DDEN line causes selection of either single density (DDEN = 1) or double density operation. DDEN should not be switched during a read or write operation.

The 5/8 Line selects interal VCO frequency to be used with 51/4 " or 8" drives.

#### FLOPPY DISK INTERFACE

The Floppy Disk Interface can be divided into three sections: Motor Control, Write Signals and Read Signals. All of these lines are capable of driving one TTL load and not compatible for direct connection to the

WD279X-02

drive. Most drives require an open-collector TTL interface with high current drive capability. This must be done on all outputs from the WD279X. Inputs to the WD279X may be buffered or tied to the Drives outputs, providing the appropriate resistor termination networks are used. Undershoot should not exceed -0.3 volts, while integrity of V<sub>IH</sub> and V<sub>OH</sub> levels should be kept within spec.

#### MOTOR CONTROL

Motor Control is accomplished by the STEP and DIRC Lines. The STEP Line issues stepping pulses with period defined by the rate field in all Type I commands. The DIRC Line defines the direction of steps (DIRC = 1 STEP IN/DIRC = 0 STEP OUT).

Other Control Lines include the IP or Index Pulse. This Line is tied to the drives' Index L.E.D. sensor that informs the WD279X that the stepper motor is at its furthest position, over Track 00. The READY Line can be used for a number of functions, such as sensing "door open," Drive motor on, etc. Most drives provide a programmable READY Signal selected by option jumpers on the drive. The WD279X will look at the ready signal prior to executing READ/WRITE commands. READY is not inspected during any Type 1 commands. All type 1 commands will execute regardless of the Logic Level on this Line.

#### **GENERAL 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 WD279X 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.

#### **RESTORE (SEEK TRACK 0)**

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 an interrupt is generated. If TROO is not active low, stepping pulses (pins 15 to 16) at a rate specified by the r1m 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 TR00 input does not go active low after 255 stepping pulses, the WD279X terminated operations, 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 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 WD279X will update the Track register and issue stepping pulses in the appropriate direction until the contents of the Track register are equal to the contents of the Data Register (the desired track location). A verification operation takes place if the V flag is on. The h bit allows the head to be loaded at the start of the command. An interrupt is generated at the completion of the command. Note: When using multiple drives, the track register must be updated for the drive selected before seeks are issued.

#### STEP

Upon receipt of this command, the WD279X 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_1r_0$  field, a verification takes place if the V flag is on. If the T 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 WD279X issues one stepping pulse in the direction towards track 0. If the T flag is on, the Track Register is decremented by one. After a delay determined by the r1r0 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.

#### EXCEPTIONS

On the WD2795/7 devices, the SSO output is not affected during Type I commands, and an internal side compare does not take place when the (V) Verify Flag is on.

For write operations, the WD279X provides Write Gate (Pin 30) and Write Data (Pin 31) outputs. Write data consists of a series of pulses set to a width approximately three times greater than the precomp adjustment. Write Data provides the unique address marks in both formats.

#### READY

Whenever a Read or Write command (Type II or III) is received the WD279X 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. TG43 may be tied to ENP to enable write precompensation on tracks 44-76.
#### COMMAND DESCRIPTION

The WD279X 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, and 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. Command types are summarized in Table 1 and Table 2.

#### Table 1. COMMAND SUMMARY

A. Commands for Models: 2791, 2793

B. Commands for Models: 2795, 2797

|       | Bits            |   |   |     |   |    |    | Bits |    |   |   |   |   |    |    |    |    |
|-------|-----------------|---|---|-----|---|----|----|------|----|---|---|---|---|----|----|----|----|
| Туре  | Command         | 7 | 6 | 5   | 4 | 3  | 2  | 1    | 0  | 7 | 6 | 5 | 4 | 3  | 2  | 1  | 0  |
| 1     | Restore         | 0 | 0 | 0   | 0 | h  | V  | r1   | ro | 0 | 0 | 0 | 0 | h  | V  | r1 | ro |
| i     | Seek            | Ō | Ō | 0   | 1 | h  | ٧  | r۱   | ro | 0 | 0 | 0 | 1 | h  | ۷  | ۲ţ | r0 |
| i     | Step            | 0 | 0 | . 1 | т | h  | ٧  | r1   | ro | 0 | 0 | 1 | Т | h  | ۷  | r1 | r0 |
| ÷.    | Step-in         | Ō | 1 | 0   | Т | h  | V  | ٢١   | ro | 0 | 1 | 0 | Т | h  | ۷  | r۱ | r0 |
| i     | Step-out        | 0 | 1 | 1   | Т | h  | V  | r1   | ro | 0 | 1 | 1 | Т | h  | ۷  | r۱ | ro |
| - ii  | Read Sector     | 1 | 0 | 0   | m | S  | Е  | С    | 0  | 1 | 0 | 0 | m | L  | Е  | U  | 0  |
| ü     | Write Sector    | 1 | 0 | 1   | m | S  | Е  | С    | a0 | 1 | 0 | 1 | m | L  | Е  | U  | a0 |
| - iii | Read Address    | 1 | 1 | 0   | 0 | 0  | Е  | 0    | 0  | 1 | 1 | 0 | 0 | 0  | E  | U  | 0  |
|       | Read Track      | 1 | 1 | 1   | 0 | 0  | Е  | 0    | 0  | 1 | 1 | 1 | 0 | 0  | E  | U  | 0  |
| 111   | Write Track     | 1 | 1 | 1   | 1 | 0  | Е  | 0    | 0  | 1 | 1 | 1 | 1 | 0  | E  | U  | 0  |
| iv    | Force Interrupt | 1 | 1 | 0   | 4 | 13 | 12 | 11   | ю  | 1 | 1 | 0 | 1 | I3 | 12 | 11 | 10 |

#### Table 2. FLAG SUMMARY

| Command<br>Type | Bit<br>No(s) |                                                                                     | Description                                                                                |
|-----------------|--------------|-------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------|
| I               | 0, 1         | <sup>r</sup> 1 <sup>r</sup> 0 = Stepping Motor Rate<br>See Table 3 for Rate Summary |                                                                                            |
| I               | 2            | V = Track Number Verify Flag                                                        | V = 0, No verify<br>V = 1, Verify on destination track                                     |
| 1               | 3            | h = Head Load Flag                                                                  | <ul> <li>h = 0, Load head at beginning</li> <li>h = 2, Unload head at beginning</li> </ul> |
| ł               | 4            | T = Track Update Flag                                                               | T = 0, No update<br>T = 1, Update track register                                           |
| 11              | 0            | a0 = Data Address Mark                                                              | <sup>a</sup> 0 = 0, FB (DAM)<br><sup>a</sup> 0 = 1, F8 (deleted DAM)                       |
| II & III        | 1            | C = Side Compare Flag                                                               | C = 0, Disable side compare<br>C = 1, Enable side compare                                  |
| II & III        | 1            | U = Update SSO                                                                      | U = 0, Update SSO to 0<br>U = 1, Update SSO to 1                                           |
| II & III        | 2            | E = 15 MS Delay                                                                     | E = 0, No 15 MS delay<br>E = 1, 15 MS delay (30 MS for 1 MHz)                              |
| Н               | 3            | S = Side Compare Flag                                                               | S = 0, Compare for side 0<br>S = 1, Compare for side 1                                     |
| II              | 3            | L = Sector Length Flag                                                              |                                                                                            |
|                 |              |                                                                                     | LSB's Sector Length in ID Field<br>00 01 10 11                                             |
|                 |              |                                                                                     | L = 0  256  512  1024  128                                                                 |
|                 |              |                                                                                     | L = 1 128 256 512 1024                                                                     |
| II              | 4            |                                                                                     | m = 0, Single record<br>m = 1, Multiple records                                            |
| IV              | 0-3          |                                                                                     | y Transition<br>y Transition<br>, Requires A Reset*                                        |

\*NOTE: See Type IV Command Description for further information.

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

WD279X-02

# WESTERN DIGITAL

O R P O R A T I O N

# WD1691 Floppy Support Logic (F.S.L.)

#### FEATURES

DIRECT INTERFACE TO THE FD179X

ſ.

- ELIMINATES EXTERNAL FDC LOGIC
- DATA SEPARATION/RCLK GENERATION
- WRITE PRECOMPENSATION SIGNALS
- VFOE/WF DEMULTIPLEXING
- PROGRAMMABLE DENSITY
- 8" OR 5.25" DRIVE COMPATIBLE
- ALL INPUTS AND OUTPUTS TTL COMPATIBLE
- SINGLE + 5V SUPPLY

#### **GENERAL DESCRIPTION**

The WD1691 F.S.L. has been designed to minimize the external logic required to interface the 179X Family of Floppy Disk Controllers to a drive. With the use of an external VCO, the WD 1691 will generate the RCLK signal for the WD179X, while providing <u>an adjustment</u> pulse (PUMP) to control the VCO frequency. VFOE/WF de-multiplexing is also accomplished and Write Precompensation signals have been included to interface directly with the WD2143 Clock Generator.

The WD1691 is implemented in N-MOS silicon gate technology and is available in a plastic or ceramic 20 pin dual-in-line package.



| PIN         | NAME                                | SYMBOL          | FUNCTION                                                                                                                                             |
|-------------|-------------------------------------|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1           | WRITE DATA<br>INPUT                 | WDIN            | Ties directly to the FD179X WD pin.                                                                                                                  |
| 2, 3, 4, 19 | PHASE<br>2, 3, 1, 4                 | 02 03 01 04     | 4 Phase inputs to generate a desired Write Precompensation delay. These signals tie directly to the WD2143 Clock Generator.                          |
| 5           | STROBE                              | STB             | Strobe output from the 1691. Strobe will latch at a high level<br>on the leading edge of WDIN and reset to a low level on the<br>leading edge of 04. |
| 6           | WRITE DATA<br>OUTPUT                | WDOUT           | Serial, pre-compensated Write data stream to be sent to the disk drive's WD line.                                                                    |
| 7           | WRITE GATE                          | WG              | Ties directly to the FD179X WG pin.                                                                                                                  |
| 8           | VFO ENABLE/<br>WRITE FAULT          | VFOE/WF         | Ties directly to the FD179X VFOE/WF pin.                                                                                                             |
| 9           | TRACK 43                            | TG43            | Ties directly to the FD179X TG43 pin, If Write Precompen-<br>sation is required on TRACKS 44-76.                                                     |
| 10          | v <sub>SS</sub>                     | v <sub>SS</sub> | Ground                                                                                                                                               |
| 11          | READ DATA                           | RDD             | Composite clock and data stream input from the drive.                                                                                                |
| 12          | READ CLOCK                          | RCLK            | RCLK signal generated by the WD1691, to be tied to the FD179X RCLK pin.                                                                              |
| 13          | PUMP UP                             | PU              | Tri-state output that will be forced high when the WD1691 requires an increase in VCO frequency.                                                     |
| 14          | PUMP DOWN                           | PD              | Tri-state output that will be forced low when the WD1691 re-<br>quired a decrease in VCO frequency.                                                  |
| 15          | Double Density<br>Enable            | DDEN            | Double Density Select input. When Inactive (High), the VCO frequency is internally divided by two.                                                   |
| 16          | Voltage<br>Controlled<br>Oscillator | vco             | A nominal 4.0MHz (8" drive) or 2.0MHz (5.25" drive) master clock input.                                                                              |
| 17, 18      | EARLY<br>LATE                       | EARLY<br>LATE   | EARLY and LATE signals from the FD179X, used to deter-<br>mine Write Precompensation.                                                                |
| 20          | v <sub>cc</sub>                     | v <sub>cc</sub> | + 5V $\pm$ 10% power supply                                                                                                                          |

WD1691

Table 1 PIN DEFINITIONS



| WG          | VFOE/WF          | RDD              | PU+PD                          |
|-------------|------------------|------------------|--------------------------------|
| 1<br>0<br>0 | X<br>1<br>0<br>0 | X<br>X<br>1<br>0 | HI-Z<br>HI-Z<br>HI-Z<br>Enable |

Figure 4 DATA RECOVERY LOGIC

DEVICE DESCRIPTION

The WD1691 is divided into two sections:

- 1) Data Recovery Circuit
- 2) Write precompensation Circuit

The Data Separator or Recovery Circuit has four inputs:  $\overline{DDEN}$ , VCO, RDD, and VFOE/WF; and three outputs: PU,  $\overline{PD}$  and RCLK. The VFOE/WF input is used in conjunction with the Write Gate signal to enable the Data recovery circuit. When Write Gate is high, a write operation is taking place, and the data recovery circuits are disabled, regardless of the state on any other inputs.

The Write Precompensation circuit has been designed to be used with the WD2143-03 clock generator. When the WD1691 is operated in a "single density only" mode, write precompensation as well as the WD2143-03 is not needed. In this case,  $\overline{\phi 1}$ ,  $\overline{\phi 2}$ ,  $\overline{\phi 3}$ ,  $\overline{\phi 4}$ , and STB should be tied together, DDEN left open, and TG43, WDIN, Early, and Late tied to ground.

In the double-density mode  $\overline{(DDEN=0)}$ , the signals Early and Late are used to select a phase input  $(\overline{\phi 1} - \overline{\phi 4})$  on the leading edge of WDIN. The STB line is latched high when this occurs, causing the WD2143-03 to start its pulse generation.  $\overline{\phi 2}$  is used as the write data pulse on nominal (Early=Late= $\phi$ ),  $\overline{\phi 1}$  is used for early, and  $\overline{\phi 3}$  is used for late. The leading edge of  $\overline{\phi 4}$  resets the STB line in anticipation of the next write data pulse. When TG43=0 or  $\overline{DDEN=1}$ , Precompensation is disabled and any transitions on the WDIN line will appear on the WDout line. If write precompensation is desired on all tracks, leave TG43 open (an internal pull-up will force a Logic I) while  $\overline{DDEN=0}$ .

The signals, DDEN, TG43, and RDD have internal pull-up resistors and may be left open if a logic I is desired on any of these lines.

When VFOE/WF and WRITE GATE are low, the data recovery circuit is enabled. When the RDD line goes Active Low, the PU or PD signals will become active. See Figure 4. If the RDD line has made its transition in the beginning of the RCLK window, PU will go from a HI-Z state to a Logic I, requesting an *increase* in VCO frequency. If the RDD line has made its transition at the end of the RCLK window, PU will remain in a HI-Z state while PD will go to a logic zero, requesting a *decrease* in VCO frequency. When the leading edge of RDD occurs in the center of the RCLK window, both PU and PD will remain tri-stated, indicating that no adjustment of the VCO frequency is needed. See Figure 3. The RCLK signal is a divide-by-16 (DDEN=1) or a divide-by-8 (DDEN=0) of the VCO frequency.

The minimum Voh level on PU is specified at 2.4V, sourcing 200ua. During PUMP UP time, this output will go from a tri-state to .4V minimum. By tying PU and  $\overrightarrow{PD}$  together, a PUMP signal is created that will be forced low for a decrease in VCO frequency and forced high for an increase in VCO frequency. To speed up rise times and stabilize the output voltage, a resistor divider can be used to set the tristate level to approximately 1.4V. This yields a worst case swing of  $\pm$  1V; acceptable for most VCO chips with a linear voltage-to-frequency characteristic.

Both PU and  $\overline{PD}$  signals are affected by the width of the RAW READ ( $\overline{RDD}$ ) pulse. The wider the RAW READ pulse, the longer the PU or  $\overline{PD}$  signal (depending upon the phase relationship to RCLK) will remain active. If the RAW READ pulse exceeds 250ns, (VCO = 4MHz,  $\overline{DDEN} = 0$ ) or 500ns. (VCO = 2MHz,  $\overline{DDEN} = 1$ ), then both a PU and  $\overline{PD}$  will occur in the same window. This is undesirable and reduces the accuracy of the external integrator or low-pass filter to convert the PUMP signals into a slow moving D.C. correction voltage.

Eventually, the PUMP signals will have corrected the VCO input to exactly the same frequency multiple as the RAW READ signal. The leading edge of the RAW READ pulse will then occur in the exact center of the RCLK window, an ideal condition for the FD179X internal recovery circuits.

#### SPECIFICATIONS

#### ABSOLUTE MAXIMUM RATINGS

| Ambient Temperature under Bias  | -25° to 70°C |
|---------------------------------|--------------|
| Voltage on any pin with respect |              |
| to Ground (vss)                 | -0.2 to +7V  |
|                                 |              |

#### DC ELECTRICAL CHARACTERISTICS

 $T_A = 0$  to 70°C;  $V_{CC} = 5.0V \pm 10\%$ ;  $V_{SS} = OV$ 

Storage Temp.—Ceramic—65°C to +150°C Plastic—55°C to +125°C

NOTE: Maximum limits indicate where permanent device damage occurs. Continuous operation at these limits is not intended and should be limited to those conditions specified in the DC Electrical characteristics.

| SYMBOL          | PARAMETER                 | MIN  | ТҮР | MAX   | UNIT | TEST CONDITIONS         |
|-----------------|---------------------------|------|-----|-------|------|-------------------------|
| VIL             | Input Low Voltage         | -0.2 |     | +0.8  | v    |                         |
| VIH             | Input High Voltage        | 2.0  |     |       | v    |                         |
| V <sub>OL</sub> | Output Low Voltage        |      |     | +0.45 | v    | I <sub>OL</sub> =3.2MA  |
| V <sub>OH</sub> | High Level Output Voltage | 2.4  |     |       | v    | I <sub>OH</sub> =-200µа |
| Vcc             | Supply Voltage            | 4.5  | 5.0 | 5.5   | v    |                         |
| lcc             | Supply Current            |      | 40  | 100   | MA   | All outputs open        |

NOTE: For AC and functional testing purposes, a Logic '0' is measured at 0.8V, and a Logic '1' at 2.0V.

#### AC ELECTRICAL CHARACTERISTICS

 $T_A = 0^{\circ}$  to 70°C;  $V_{CC} = 5V \pm 10\%$ ;  $V_{SS} = OV$ 

SYMBOL PARAMETER MIN TYP MAX UNIT TEST CONDITIONS MHz DDEN=0 FIN VCO Input Frequency .5 4 6 DDEN=1 MHz .5 2 6 RDD Pulse Width 100 200 Rpw ns. EARLY (LATE) to WDIN 100 Wel ns. Pon PUMP UP/DN Time 0 250 ns. DDEN=1 WDIN to WDOUT 80 Wpi ns. 6.5 10 KΩ Internal Pull-up Resistor 4.0 Inr



Figure 5 INTERNAL PULL-UP RESISTOR



#### Figure 6 RDD AND RCLK PULSE DIAGRAMS

WD1691



Figure 7 WRITE DATA TIMING (MFM)



Figure 8 WRITE DATA TIMING (FM)

WD1691



Figure 9 WD1691 to FD1771-01 INTERFACE

#### TYPICAL APPLICATIONS

Figure 9 illustrates the 1691 to FD1771-01 floppy disk controller. The RCLK signal is used to gate the RAW data pulses which are inverted by the 74LS04 inverter. Since RCLK will be high during data and low during clock a 74LS08 is used to switch the proper clock or data pulse to the FD1771.

Shown in Figure 10 is a Phase-Lock Loop data separator and the support logic for a single and double-density 8" drive. The raw data (Both clock and data bits) are fed to the WD1691 and FD179X. The WD1691 outputs its PU or PD signal, which is integrated by the .33uf capacitor and 33ohm resistor to form a control voltage for the 74S124 VCO device. The 4.0MHZ nominal output of the VCO then feeds back to the WD1691 completing the loop. The WD2143-03 is also used, providing write precompensation when in double-density, from tracks 44-77. The DDEN line can either be controlled by a toggle switch or a logic level from the host system.

#### ALIGNMENT

To adjust write precompensation, issue a command to the FD179X so that write data pulses are present. This can be done with a 'WRITE TRACK' command and the IP line open, or a continuous 'WRITE SECTOR' operation. With a scope on pin 4 of the WD1691, adjust the precomp pot for the desired value. This will range from 100 to 300 ns typically.

The pulse width set on pin  $\overline{4}$  ( $\overline{\emptyset}1$ ) will be the desired precomp delay from nominal.

The data separator must be adjusted with the RDD or VFOE/WF line at a Logic I. Adjust the bias voltage poten-

tiometer for 1.4V on pin 2 of the 74S124. Then adjust the range control to yield 4.0MHZ on pin 7 of the 74S124.

#### SUBSTITUTING VCO's

There are other VCO circuits available that may be substituted for the 74S124. The specifications required are:

- The VCO must free run at 4.0MHz with a 1.4V control signal. The WD1691 will force this voltage 1 Volt in either direction (i.e., .4V = decrease frequency, 2.4V = increase frequency). If a ± 15% capture range is desired, then a 1 Volt change on the VCO input should change the frequency by 15%. Capture range should be limited to about ± 25%, to prevent the VCO from breaking into oscillation and/or losing lock because of noise spikes (causing abnormally quick adjustments of the VCO frequency). Jitter in the VCO output frequency may further be reduced by increasing the integration capacitor/resistor, but this will also decrease the final capture range and lock-up time.
- 2) The sink output current of the WD1691 is 3.2ma minimum. The source output current is -200ua. Therefore, source current is the limiting factor. Insure that the input circuitry of the VCO does not require source current in excess of -200ua.

Another alternative is to use a voltage follower/level shifter circuit to match the input requirements of the VCO chosen. A more complex filter can be used to convert the PUMP UP/PUMP DOWN pulses to the varying DC voltage signal required by the VCO, achieving an optimum condition between lock-up time and high frequency rejection.



See page 481 for ordering information.

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

# WESTERN DIGITAL

CORPORATION

## DM1883A/B Direct Memory Access Controller

#### FEATURES

- AUTOMATIC DAISY CHAINING OF BUS AND INTERRUPT ACKNOWLEDGE SIGNALS
- AUTO LOAD OPTION
- SINGLE +5 VDC POWER SUPPLY
- 8 BIT BI-DIRECTIONAL DATA BUS
- TRUE OR COMPLEMENT DATA BUS
- 8 CPU ADDRESSABLE DMAC REGISTERS
- 8 CPU ADDRESSABLE DEVICE REGISTERS
- AUTOMATIC GENERATION OF DEVICE CS DURING DMA AND CPU DEVICE ACCESSES
- 256K MEMORY ADDRESSING
- 64K PROGRAMMABLE PAGE PROTECTION
- BYTE OR WORD DMA TRANSFERS
- INTERRUPT AND BUS REQUEST CAPABILITIES
- END-OF-BLOCK SHUT OFF BY DMAC
- TIME-OUT INTERRUPT CAPABILITY
- SINGLE CLOCK INPUT
- CS, RE, WE, A0-A3 ADDRESSING
- STOP REQUEST INPUT TO DELAY INTER-RUPT OR BUS REQUESTS
- COMPATIBLE WITH OUR FLOPPY DISC CONTROLLERS
- 8 BIT PROGRAMMABLE INTERRUPT ID CODE

#### **GENERAL DESCRIPTION**

The DM1883 Direct Memory Access Controller (DMAC) is packaged in a 40 pin standard dual inline package. The chip requires a single +5 power supply input and a single clock input. The device contains 8 CPU addressable registers, and allows for up to 8 CPU addressable device registers if the automatic device chip select feature is used. Byte or word transfers can be programmed, and all memory DMA operations are handshaked for compatibility with a variety of bus structures. Up to 256K bytes of memory can be accessed directly with 64K page protection and nonexistent memory interrupt as options. Bus and Interrupt Acknowledge signals are internally daisy chained, and a STOP REQUEST input prevents new requests while a current request is active. Device accesses are not handshaked, and a BUS HOLD feature is present for high speed devices. Device interrupt input, end-of-block output, and I/O read/write output pins simplify hardware interfacing to the device and the CPU bus. The AUTO LOAD feature allows automatic bootloading of up to 64K bytes or words into memory starting at location zero. An 8 bit interrupt ID code is also provided.



DM1883 BLOCK DIAGRAM

### INTERFACE SIGNALS DESCRIPTIONS

| PIN<br>NUMBER | SIGNAL NAME      | SYMBOL        | FUNCTION                                                                                                                                                                                                                                                                                                                                                                   |
|---------------|------------------|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1             | GROUND           | VSS           | Ground                                                                                                                                                                                                                                                                                                                                                                     |
| 2             | DATA REQUEST     | DRQ           | Data service request input from the peripheral device. A DMA transfer is initiated when this signal goes high.                                                                                                                                                                                                                                                             |
| 3             | REPLY            | REPLY         | Active low bi-directional handshake signal for both CPU and DMA transfers.                                                                                                                                                                                                                                                                                                 |
| 4             | BACK IN          | BACKI         | Bus acknowledge in. An active low input signal from the<br>CPU or a previous device in the BACK daisy chain. When<br>low this signal will initiate a DMA transfer if the DMAC was<br>requesting a DMA cycle.                                                                                                                                                               |
| 5, 23, 24, 25 | REGISTER SELECTS | A0-A3         | These inputs select one of eight DMAC registers or one of eight device registers. When A3 is high the DMAC is selected. When A3 is low the DMAC is deselected and $\overline{\text{DCS}}$ is made low by the DMAC to activate device transfers. $\overline{\text{CS}}$ input to the DMAC must be made low before either the DMAC or the device may be selected by the CPU. |
| 6             | BUS REQUEST      | BUSR          | Active low output signal to initiate a CPU bus request and<br>to latch A8-A15, A17 of the 18 bit DMA transfer address<br>from DAL0-DAL7, AE8 into an external register.                                                                                                                                                                                                    |
| 7             | CHIP SELECT      | <del>CS</del> | Active low chip select input signal for CPU controlled operations.                                                                                                                                                                                                                                                                                                         |
| 8             | BACK OUT         | BACKO         | Bus acknowledge out. An active low output signal used to<br>pass BACKI along the daisy chain when the DMAC is not<br>requesting a DMA cycle. This output is not affected by<br>STOPR.                                                                                                                                                                                      |
| 9             | DEVICE SELECT    | DCS           | Active low device chip select output signal for CPU and DMAC controlled operations.                                                                                                                                                                                                                                                                                        |
| 10            | READ ENABLE      | RE            | Active low bi-directional read enable for the DMAC and the device.                                                                                                                                                                                                                                                                                                         |
| 11            | WRITE ENABLE     | WE            | Active low bi-directional write enable for the DMAC and<br>the device. RE and WE are inputs during CPU controlled<br>operations, and outputs to the device during DMAC con-<br>trolled operations.                                                                                                                                                                         |
| 12            | MEMORY READ      | MEMR          | Active low output to initiate a memory read during DMA transfers to the peripheral device.                                                                                                                                                                                                                                                                                 |
| 13            | MEMORY WRITE     | MEMW          | Active low output to initiate a memory write during DMA transfers from the peripheral device.                                                                                                                                                                                                                                                                              |
| 14            | MASTER RESET     | MR            | Active low master reset signal to initialize the DMAC.                                                                                                                                                                                                                                                                                                                     |
| 15            | CLOCK            | CLK           | Clock input                                                                                                                                                                                                                                                                                                                                                                |
| 16            | MEMORY SYNC      | MSYNC         | Active low memory sync output to initiate a memory access during DMA transfers.                                                                                                                                                                                                                                                                                            |
| 17            | READ/WRITE       | R∕₩           | This output indicates the direction of transfer for the peripheral device. High for device-to-memory transfers (READ), and low for memory to device transfers (WRITE). Tied directly to Control Register bit 4.                                                                                                                                                            |
| 18            | LOAD ADDRESS LOW | LAL           | Active low output signal to latch A0-A7, A16 of the 18-bit<br>DMA transfer address from DAL0-DAL7, AE8 into an ex-<br>ternal register. BUSR and LAL are compatible with INTEL<br>8212 devices.                                                                                                                                                                             |

| PIN    |                   |           |                                                                                                                                                                                                                                                                                                                                                                             |
|--------|-------------------|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| NUMBER | SIGNAL NAME       | SYMBOL    | FUNCTION                                                                                                                                                                                                                                                                                                                                                                    |
| 19     | STOP REQUEST      | STOPR     | Active low input that prevents INTR and BUSR from going<br>low even if a request becomes active. An active INTR or<br>BUSR request will not be affected by this input going low.<br>This signal is used to speed up daisy chaining of bus and<br>interrupt acknowledge inputs, and to prevent new requests<br>while some other request is in the process of being serviced. |
| 20     | IACK IN           | IACKI     | Interrupt acknowledge in. An active low input signal from<br>the CPU or a previous device in the IACK daisy chain. The<br>DMAC is selected when INTR is low and this signal goes<br>low. If RE also goes low while the DMAC is selected via this<br>signal then the interrupt ID code is gated onto DAL0-DAL7.                                                              |
| 21     | POWER SUPPLY      | Vcc       | +5 VDC power supply input                                                                                                                                                                                                                                                                                                                                                   |
| 22     | IACK OUT          | IACKŌ     | Interrupt acknowledge out. An active low output signal used to pass IACKI along the daisy chain when the DMAC is not requesting an interrupt. This output is not affected by STOPR.                                                                                                                                                                                         |
| 26     | TRUE DATA BUS     | TDB       | This input selects a true data bus on the DAL lines when<br>high or open, and a complemented data bus on the DAL<br>lines when low.                                                                                                                                                                                                                                         |
| 27     | ADDRESS EXTENSION | AE8       | Address extension bit output. Used during DMA opera-<br>tions to extend the address to 18 bits. This bit is true if TDB is high and complemented if TDB is low.                                                                                                                                                                                                             |
| 28-35  | DATA ACCESS LINES | DAL0-DAL7 | An 8-bit bi-directional three-state bus for CPU and DMAC controlled transfers to and from the DMAC. These signals remain in a three-state mode if the peripheral device is selected via A3 instead of the DMAC.                                                                                                                                                             |
| 36     | BYTE OR WORD      | BOW       | Byte or word DMA transfer mode input. When high mem-<br>ory addresses are incremented by one after every DMA<br>transfer. When low memory addresses are incremented<br>by two after every DMA transfer and the LSB of the memory<br>address is forced to zero.                                                                                                              |
| 37     | AUTO LOAD         | AUTLD     | Active high input to initiate a non-programmed 64K device to memory data transfer.                                                                                                                                                                                                                                                                                          |
| 38     | END OF BLOCK      | EOB       | Active high output to shut off the peripheral device when the transfer count goes to zero.                                                                                                                                                                                                                                                                                  |
| 39     | DEVICE INTERRUPT  | DINTR     | Interrupt service request input from the peripheral device.<br>An interrupt request is generated by the DMAC if this in-<br>put is high and the device interrupt enable bit in the com-<br>mand register is also set.                                                                                                                                                       |
| 40     | INTERRUPT REQUEST | INTR      | Active low interrupt service request output. This output<br>goes low if: 1) Any one of the three interrupt conditions is<br>active, and 2) The STOPR input is high, and 3) The corres-<br>ponding interrupt enable bit for the interrupting condition<br>is set.                                                                                                            |

NOTE: The following pins float when not active low and require an external pull-up resistor of 10 KΩ (or greater) to +5 VDC:

INTR, REPLY, RE, WE, MEMR, MEMW, MSYNC

The following pins have internal 10 KΩ pull-up resistors to +5 VDC:

TBD, DRQ, DINTR

#### WIRE-ORABLE SIGNALS

The following output signals can be wired together with a single common pull-up resistor if multiple DMAC chips exist on the same board:

MSYNC, MEMR, MEMW, INTR

#### **REGISTER SELECTION**

A 4-bit address input (A0, A1, A2, A3) is used to select one of 8 internal DMAC registers or to generate a device chip select ( $\overline{DCS}$ ) output signal for selection of up to 8 peripheral device registers. The following table details the selection process.

|    |    | INP | UTS |    | OUTPUT | SELECTED                                |
|----|----|-----|-----|----|--------|-----------------------------------------|
| cs | A3 | A2  | A1  | A0 | DCS    | REGISTER                                |
| L  | L  | x   | х   | x  | L      | One of 8 peripheral<br>device registers |
| L  | н  | L   | L   | L  | н      | DMAC control regis-<br>ter (0)          |
| L  | н  | L   | L   | н  | н      | DMAC status register (1)                |
| L  | н  | L   | н   | L  | н      | DMAC TC low register (2)                |
| L  | н  | L   | н   | н  | н      | DMAC TC high regis-<br>ter (3)          |
| L  | н  | н   | L   | L  | н      | DMAC MA low regis-<br>ter (4)           |
| ι  | н  | н   | L   | н  | н      | DMAC MA high regis-<br>ter (5)          |
| L  | н  | н   | н   | L  | н      | DMAC MA ext. regis-<br>ter (6)          |
| L  | н  | н   | н   | н  | н      | DMAC ID code regis-<br>ter (7)          |

NOTE: L = Low voltage level, H = High voltage level, X = don't care.

#### REGISTER DEFINITIONS

#### TRANSFER COUNT REGISTER (TCR)

A 16-bit counter register that holds the two's complement of the transfer count (words or bytes) for DMA transfer operations. The low order 8 bits are in TC low, and the high order 8 bits are in TC high. The count is incremented by one after every DMA transfer. When the count reaches zero bit 3 of the Status Register is set to a one. If bit 3 in the Command Register is also a one then INTR will go low (providing STOPR is also high). TCR is set to a one on a MASTER RESET to allow a 64K transfer count during auto load.

#### **MEMORY ADDRESS REGISTER (MAR)**

An 18-bit counter register that occupies 3 DMA registers. Bits 0-7 are in MA low, bits 8-15 are in MA high, and bits 16-17 are in MA ext. The carry from bit 15 to 16 is enabled if and only if bit 6 of the Command Register is set to a one. If the BOW input pin is high then the MAR is incremented by one after every DMA transfer. If the BOW input pin is low then the MAR is incremented by two after every transfer and bit 0 is forced to a zero. This register is cleared to all zeros on a MASTER RESET.

During a DMA operation the DMA address is gated onto the DAL lines in two 9-bit bytes. The first byte out contains MAR 8-15 on DAL 0-7 and MAR 17 or AE8. The second byte out contains MAR 0-7 on DAL 0-7 and MAR 16 on AE8. The first byte is valid on the trailing edge of BUSR, and the second byte is valid on the trailing edge of LAL. Note that the address can easily be extended to 24 bits by decoding the address of the 2-bit extension register externally and gating the 6 unused bits into an external latch. This would give the system 16 Mbytes of addressing with either 65K or 256K bytes of paging.

#### DMAC CONTROL REGISTER (CR)

|     | 7    | 6         | 5                                                                                                                                                                                                                   | 4              | 3                               | 2                | 1.            | 0           |  |  |  |
|-----|------|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|---------------------------------|------------------|---------------|-------------|--|--|--|
| N   | /A   | AECE      | HBUS                                                                                                                                                                                                                | ЮМ             | TCIE                            | TOIE             | DIE           | RUN         |  |  |  |
| віт | SYMB | OL        |                                                                                                                                                                                                                     |                | FUNCTION                        |                  |               |             |  |  |  |
| 0   | RUN  | N Run/sto | p bit. A 1 plac                                                                                                                                                                                                     | ces the DMA    | C in the run m                  | ode. A 0 termir  | nates DMAC    | operation.  |  |  |  |
| 1   | DIE  | Device    | interrupt enab                                                                                                                                                                                                      | ole. A 1 allow | s a high input                  | on DINTR to s    | et the INTR o | output low. |  |  |  |
| 2   | TOI  | The tim   | Time-out interrupt enable. A 1 allows the time-out one-shot to set the INTR output low<br>The time- <u>out interrupt is set during a DMA transfer if REPLY</u> does not go low within<br>5 usec of MSYNC going low. |                |                                 |                  |               |             |  |  |  |
| 3   | тси  | 1         | r count zero ii<br>INTR output                                                                                                                                                                                      |                | ole. A 1 allows                 | a zero in the tr | ansfer count  | register to |  |  |  |
| 4   | юм   | and a 0   | Input or output mode. A 1 sets READ mode (from the peripheral device to men and a 0 sets WRITE mode (from memory to the peripheral device). This bit also ap as an ungated output on the $R/W$ pin.                 |                |                                 |                  |               |             |  |  |  |
| 5   | НВС  |           |                                                                                                                                                                                                                     |                | to hold onto t<br>or word trans |                  | entire block  | instead of  |  |  |  |

| віт | SYMBOL | FUNCTION                                                                                                  |
|-----|--------|-----------------------------------------------------------------------------------------------------------|
| 6   | AECE   | Address extension carry enable. A 1 allows a carry from DMA address bit 15 to propo-<br>gate into bit 16. |
| 7   | N/A    | Not used.                                                                                                 |

NOTE: Bits 1, 2, 3 set INTR low on an active condition if and only if the STOPR input is high.

|     | DMAC STATUS REGISTER (SR) |                                          |                                                                                                                                                                                                                                                                                                                                             |                  |                   |                  |                 |              |  |  |  |  |
|-----|---------------------------|------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|-------------------|------------------|-----------------|--------------|--|--|--|--|
|     | 7                         | 6                                        | 5                                                                                                                                                                                                                                                                                                                                           | 4                | 3                 | 2                | 1               | 0            |  |  |  |  |
| BL  | JSY                       | AECE                                     | HBUS                                                                                                                                                                                                                                                                                                                                        | IOM              | TCZI              | τοι              | DINT            | BOW          |  |  |  |  |
| віт | SYMBOL                    |                                          |                                                                                                                                                                                                                                                                                                                                             |                  | FUNCTION          |                  |                 |              |  |  |  |  |
| 0   | BOW                       | pin. A 1 b<br>after eac                  | Byte or word data channel. A read only bit that indicates the status of the BOW input<br>pin. A 1 bit indicates byte mode, and the DMA memory address is incremented by one<br>after each DMA transfer. A 0 bit indicates word mode, and the DMA memory address is<br>incremented by two (bit 0 is forced to a 0) after every DMA transfer. |                  |                   |                  |                 |              |  |  |  |  |
| 1   | DINT                      |                                          | If set a device interrupt has occurred. This is a read/write bit. Resetting this bit to a zero will reset INTR.                                                                                                                                                                                                                             |                  |                   |                  |                 |              |  |  |  |  |
| 2   | τοι                       | 1                                        | me-out interr<br>reset INTR.                                                                                                                                                                                                                                                                                                                | upt has occu     | rred. This is a   | read/write bi    | t. Resetting th | his bit to a |  |  |  |  |
| 3   | TCZI                      | \$ · · · · · · · · · · · · · · · · · · · | ransfer count<br>/hen set.                                                                                                                                                                                                                                                                                                                  | equals zero      | interrupt has     | occurred. A r    | ead only bit.   | Sets EOB     |  |  |  |  |
| 4   | IOM                       | Input-ou<br>only bit.                    | •                                                                                                                                                                                                                                                                                                                                           | nis bit reflects | the status of b   | oit 4 in the Con | nmand Regist    | er. A read   |  |  |  |  |
| 5   | HBUS                      | Hold bus                                 | s. This bit refle                                                                                                                                                                                                                                                                                                                           | ects the statu   | s of bit 5 in the | e Command R      | legister. A rea | d only bit.  |  |  |  |  |
| 6   | AECE                      |                                          | Address extension carry enable. This bit reflects the status of bit 6 in the Comma Register. A read only bit.                                                                                                                                                                                                                               |                  |                   |                  |                 |              |  |  |  |  |
| 7   | BUSY                      |                                          | ata transfer no<br>ommand Reg                                                                                                                                                                                                                                                                                                               |                  | . A read only bi  | t that reflects  | the status of b | it 0 (RUN)   |  |  |  |  |

NOTE: Bits 1, 2, 3 are set if the corresponding condition occurs. The enable bits in the CR affect only the INTR output, and not the Status Register.

#### ID CODE REGISTER (IDR)

An 8-bit programmable interrupt ID code register that gives the system an efficient way to establish a jump or vector address during a DMAC interrupt. The register is cleared to all zeros during a MASTER RESET, and must be loaded by the program during system initialization. If INTR is low, and IACKI and RE go low then the <u>contents</u> of <u>this</u> register are gated onto DAL 0-7. IACKI and CS must not be allowed to be low at the same time.

#### MASTER RESET

All register bits are reset to a zero during a MASTER RESET except the following which are set to ones: TCR bit 0, CR4, CR5, CR6, SR4, SR5, and SR6. This sets up the DMAC for a 64K transfer from the peripheral device to memory starting at address 0. The hold bus mode is also enabled. Execution of an Auto Load will begin DMA transfers under the above conditions.

#### AUTO LOAD

If the AUTLD input is made active after a MASTER RESET then bits CR3, CR1, and CR0 are also set. This places the DMAC in run mode, and enables two of the interrupt conditions. The DMAC will initiate data transfers, and will continue until either the transfer count reaches zero or a device interrupt occurs. Either event will terminate transfers and generate an interrupt.

#### WRITE PROTECT FEATURE

During CPU controlled transfers to the DMAC, if the RUN bit is set then any attempt to write into any of the Memory Address or Transfer Count registers will result in a NOP. REPLY will be made low in any case.

#### **CPU CONTROLLED DATA TRANSFERS**

During a CPU controlled transfer the CPU must have control of the system bus. When a CPU cycle is

initiated the system decodes the address on the bus. If the DMAC or its associated peripheral device is selected then CS to the DMAC is made low. The DMAC looks at the A3 input. If A3 is low the peripheral device is selected, and DCS is made low. The DMAC will not respond to an active RE or WE if A3 is low, and the DAL bus will stay in a high impedance state. This allows the DMAC DAL bus and the device DAL bus to be tied together if the device DAL bus is also in a high impedence state when the device is not selected.

If A3 is high when  $\overline{CS}$  is low then the DMAC is selected and will respond to an active low  $\overline{RE}$  or  $\overline{WE}$ . A0-A2 selects the DMAC as described under the REGISTER SELECTION section. If  $\overline{RE}$  goes low the DMAC places the contents of the selected register on the DAL bus and activates  $\overline{REPLY}$  to inform the CPU that valid data is on the bus. If  $\overline{WE}$  goes low the DMAC gates the contents of the DAL bus into the selected register and activates  $\overline{REPLY}$  to inform the CPU that data has been accepted.

If the peripheral device has more than 8 registers, or the device has fewer than 8 registers and there are one or more auxiliary registers external to the device, then it may be easier for the user to separate DMAC and device chip selects. In this mode  $\overline{CS}$  to the DMAC is activated if and only if the DMAC is selected and A3 is tied to +5 VDC. The chip select to the device from a CPU controlled data transfer is ORed with DCS out of the DMAC. In this mode  $\overline{DCS}$ will go low if and only if a DMA transfer is in effect and can be used by the controller as a "DMA ACTIVE" signal. Note that in any case actual data transfers to and from the CPU and the peripheral device are done by way of the device's DAL bus, not the DMAC's DAL bus.

#### DMAC CONTROLLED DATA TRANSFERS

When the DMAC is in RUN mode (CR0=1) it waits for a Data Request (DRQ) input from the peripheral device. When DRQ becomes active the DMAC requests the bus from the CPU by activating BUSR. If STOPR was active when DRQ went active then the DMAC would wait until STOPR went high before activating BUSR. When BACKI goes low in response to an active BUSR the request has been granted and the DMAC controls data transfers between the peripheral device and memory. The direction of the transfer is determined by the status of the READ/WRITE (R/W) output pin. Note that R/W is tied directly to CR4.

#### 1.) DEVICE-TO-MEMORY DMA TRANSFERS (CR4=1)

Once the DMAC has been granted the bus the following occurs:

- A.) The DMAC places the high byte of the memory address on the DAL lines, activates DCS, and then raises BUSR. The trailing edge of BUSR can be used to latch the address into an external buffer.
- B.) The DMAC places the low byte of the memory address on the DAL lines while activating LAL, and then activates MSYNC. The trailing edge of LAL can be used to latch the address into an external buffer
- C.) The DAL lines are placed into a high impedence state in anticipation of a data transfer across the bus.
- D.) <u>The DMAC</u> activates RE and then activates MEMW.
- E.) <u>The DMAC</u> waits for <u>REPLY</u> to go low. When <u>REPLY</u> is active the DMAC deactivates <u>MEMW</u> and then deactivates <u>RE</u>.
- F.) If the DMAC is *not* in hold bus mode (CR5=1) then the DMAC deactivates DCS and gives up control of the bus. If the DMAC is in hold bus mode then DCS remains low until after the completion of the final data transfer. Note that BUSR still cycles for every transfer.
- G.) After the completion of every data transfer the memory address register is incremented by one in byte mode or two in word mode.
- H.) After the completion of every data transfer the transfer count is incremented by one. Transfers are considered to be completed when the transfer count equals zero.

#### 2.) MEMORY-TO-DEVICE DMA TRANSFERS (CR4=0)

Once the DMAC has been granted the bus it goes through the same steps as in the DEVICE-TO-MEMORY mode with the exception of steps "D" and "E" which are as follows:

- D.) The DMAC activates MEMR and then activates WE.
- E.) The DMAC waits for REPLY to go low. When REPLY is active the DMAC deactivates WE and then deactivates MEMR.

In either mode BACKI will be gated out to BACKO as soon as the DMAC deactivates DCS. This allows other devices in the chain to gain access to the bus immediately.

#### INTERRUPTS

There are three individually enabled interrupt conditions. If any of the conditions occurs it will set its corresponding bit in the Status Register. If the appropriate enable bit in the Command Register is set then INTR is also activated. Note that these are independent functions. When INTR is active then the

DMAC can be selected by an active IACKI instead of an active CS. CS and IACKI must not both be active at the same time.



TYPICAL DMAC TO FDC APPLICATION

Once an interrupt condition sets its corresponding bit in the status register the bit stays set until a CPU write to the status register occurs with a zero in the bit position.\* If any one (or more) of the three interrupt condition bits in the Status Register is set then IACKI will not be gated out to IACKO even if the interrupt is *not* enabled.

The three interrupt conditions are as follows:

#### 1.) DEVICE INTERRUPT (DINT)

A device interrupt condition occurs when the DINTR input is made high. This sets SR1 and, if CR1 is set, it activates INTR. The RUN bit is also reset thus terminating all subsequent DMA transfers. A device interrupt could be generated by a number of causes, and the program will have to test the device's Status Register to determine the cause of the interrupt. The DINT status bit in the DMAC Status Register must be cleared by the program as a part of the interrupt service routine.

#### 2.) TRANSFER COUNT EQUALS ZERO INTERRUPT (TCZI)

When the TCR is incremented to zero after a DMA transfer the TCZI status bit (SR3) is set and the RUN bit (CR0) is reset. This terminates all DMA operations and, if CR3 is set, activates INTR. SR3 can be cleared only by loading a non-zero value into the TCR. The EOB output pin is high whenever SR3 is set.

#### 3.) TIME-OUT INTERRUPT (TOI)

During any DMA transfer the leading edge of MSYNC triggers an internal time delay of approximately 5 microseconds. If the DMAC does not receive an active low REPLY input within that time delay then the DMA operation is terminated, the RUN bit is reset, and the TOI status bit (SR2) is set. If CR2 is set then INTR is activated. SR2 can only be cleared by writing a zero into that position of the Status Register.

#### INTERRUPT OPERATION

When the DMAC activates INTR the CPU responds by activating IACKI. This signal can be daisy chained through all devices. The first device in the chain that has any bit in SR1-SR3 set will block the gating of IACKI out to IACKO. In addition, if INTR is active an IACKI will select the DMAC. An active RE after an IACKI select will gate the contents of the interrupt ID code register onto the DAL lines. The ID code stays active on the DAL lines as long as IACKI and RE are active. This code, which is cleared to zero by a MASTER RESET and loaded by the program during system initialization, can be used by the system to create a JUMP or VECTOR address for the device interrupt routine. Note that an active  $\overline{CS}$ during a DMAC select via an active IACKI will cause unspecified results. Note also that no condition can activate INTR unless its corresponding enable bit is set and STOPR is high. If STOPR is active when the interrupt condition occurs then the DMAC will hold INTR inactive until STOPR goes inactive. At that time the DMAC will activate INTR automatically.

#### DMA PRIORITY SYSTEMS Fixed Priority

A fixed priority can be established in two ways: through a parallel request-grant system or through a CPU controlled daisy chain system. A typical asynchronous parallel DMA priority system is shown. In this system any request generates an active STOPR, which is gated to all devices, and an active DMA request to the CPU. The CPU DMA grant generates a grant to the requesting device with the highest priority. If more than one request is received at the same time then the grants are honored from the highest to the lowest priority. In most cases, however, grants are not received simultaneously. The highest priority devices, therefore, will receive most of the immediate grants with the others being delayed by an active STOPR.



#### ASYNCHRONOUS PARALLEL DMA PRIORITY SYSTEM

Establishing a fixed priority system through a daisy chain approach requires the CPU monitor a "DMA IN PROGRESS" signal on the bus. This signal can be generated from DCS during a DMA transfer (i.e., DCS·CS). In this mode the CPU activates BACKI and STOPR in response to some bus request. STOPR is tied to all DMA controllers to prevent new bus requests while BACKI is propagating through all non-requesting DMAC devices. When the requesting DMAC gains control over the bus and activates DCS the CPU drops BACKI.". When DCS is deactivated the CPU deactivates STOPR to allow new requests. In this manner the device physically

NOTE: For a transfer-count-equals-zero interrupt condition to be cleared the Transfer Count Register must be loaded with a non-zero count.

DM1883A/B

closest to the CPU on the daisy chain has highest priority for all request cycles.

NOTE: BACKI and STOPR can be dropped at the same time with no effect on the priority scheme, but the CPU may have to capture new requests until DCS goes high.

#### **Rotating Priority**

This is a daisy chain approach that prevents one device from getting most of the bus grants if multiple devices are active at the same time. In this mode any device requesting the bus causes the CPU to activate BACKI. This signal is tied to the BACKI and STOPR inputs of the first DMAC. The BACKI and STOPR inputs of the second DMAC, and so on. The BACKO output of

the last DMAC in the chain goes back to the CPU to reset its BACKI output. In this mode the first device cannot request again until all other requesting devices in the chain have also been serviced.

In any case, if the CPU has to have the DMA request held active throughout the DMA cycle then the user will have to create this signal on the controller thusly: DMAREQ = BUSR + (DCS $\cdot$ CS). If the device and DMAC chip selects are generated on the controller separately then the CS can be eliminated from the equation. It is needed only to distinguish a CPU chip select from a DMA cycle chip select. Note that in either case the second term in the equation is equivalent to "DMA CYCLE IN PROGRESS" (DMAIP).

NOTE: Maximum ratings indicate limits beyond which permanent damage may occur. Continuous operation at these limits is not intended and should be limited to those conditions specified under dc electrical characteristics.

#### SPECIFICATIONS ·

#### Absolute Maximum Ratings

| Ambient Temperature Under Bias0°C to +70°C |
|--------------------------------------------|
| Voltage on Any Pin with Respect            |
| to Ground                                  |
| Power Dissipation 0.6 Watt                 |

#### **DC Electrical Characteristics**

 $T_A = 0^{\circ}C$  to +70°C;  $V_{CC} = 5.0V \pm 5\%$ ; GND =0V

SYMBOL PARAMETER MIN. TYP. MAX. UNIT TEST CONDITIONS VIL Input Low Voltage -0.5 0.8 V ViH Input High Voltage 2.4 v VCC  $I_{OL} = 1.6 \text{ mA}$ Output Low Voltage 0.45 Vol v **Output High Voltage** ۷он 2.4 V Aىر 100 = HOL Data Bus Leakage -50 μA  $V_{IN} = 0.45V$ DL 10  $V_{IN} = V_{CC}$ μA Input Leakage 10  $V_{IN} = V_{CC}$ 41 μA Power Supply Current 90 45 mΑ <sup>I</sup>CC

NOTE: VOL ≤0.4V when interfacing with low power Schottky parts (I<sub>OL</sub> <1 mA).

#### Capacitance

 $T_{A} = 25^{\circ}C; V_{CC} = GND = 0V$ 

| SYMBOL           |                                    | PARAMETER           | MIN. | TYP. | MAX. | UNIT | TEST CONDITIONS                  |
|------------------|------------------------------------|---------------------|------|------|------|------|----------------------------------|
| CIN              | Input Capaci                       | tance               |      |      | 10   | pF   | f <sub>C</sub> = 1 MHz           |
| C <sub>I/O</sub> | I/O Capacita                       | nce                 |      |      | 20   | pF   | Unmeasured pins returned to GND. |
| System Cl        | System Clock (CLK) Characteristics |                     |      |      |      |      |                                  |
| Maximum          | Frequency                          | = 2.0 MHz           |      |      |      |      |                                  |
| Minimum          | Pulse Width                        | = 250 ns            |      |      |      |      |                                  |
| Maximum          | Pulse Width                        | = 50% of duty cycle |      |      |      |      |                                  |
|                  |                                    |                     |      |      |      |      |                                  |

DM1883A/B



**CPU CONTROLLED TRANSFER** 



#### DMA CONTROLLED TRANSFER TIMING

AC Electrical Characteristics  $T_A = 0^{\circ}C$  to +70°C;  $V_{CC} = 5.0V \pm 5\%$ ; GND = 0V

| SYMBOL                                                                  | DESCRIPTION                                  | MIN      | M   | AX. I             | JNIT | COND       |
|-------------------------------------------------------------------------|----------------------------------------------|----------|-----|-------------------|------|------------|
| CPU CO                                                                  | NTROLLED TRANSFER TIMING - READ              |          |     | ······            |      |            |
| TAR                                                                     | Address Valid to RE ¥                        | 80       |     |                   | ns   |            |
| TCR                                                                     | CS <b>↓</b> to RE <b>↓</b>                   | 0        |     |                   | ns   |            |
| TRE                                                                     | RE Pulse Width                               | 300      |     |                   | ns   |            |
| TRDV                                                                    | RE ∳ to Data Valid                           |          | 3   | 75                | ns   | CL = 50 pF |
| TRR                                                                     | RE + (A) to REPLY + (A)                      | 50       | 3   | 50                | ns   | CL = 50 pF |
| TRA                                                                     | Address Hold from RE                         | 30       |     |                   | ns   |            |
| TRC                                                                     | CS Hold from RE <b>↓</b>                     | 0        |     |                   | ns   |            |
| TRDF                                                                    | Data Float from RE↓                          |          | 2   | 00                | ns   |            |
| CPU CO                                                                  | NTROLLED TRANSFER TIMING - WRITE             |          |     |                   |      | L          |
| TAW                                                                     | Address Valid to WE ¥                        | 80       |     |                   | ns   |            |
| TCW                                                                     | CS ★ to WE ★                                 | 0        |     |                   | ns   |            |
| TDW                                                                     | Data Valid to WE 🖡                           | 300      |     |                   | ns   | CL = 50 pF |
| TWE                                                                     | WE Pulse Width                               | 300      |     |                   | ns   |            |
| TWR                                                                     | WE + (A) to REPLY + (A)                      | 50       | 35  | 50                | ns   | CL = 50 pF |
| TWA                                                                     | Address Hold from ₩E ↓                       | 30       |     |                   | ns   |            |
| тус                                                                     | CS Hold from ₩E ↓                            | 0        |     |                   | ns   |            |
| TWD                                                                     | Data Hold from ₩E I                          | 30       |     |                   | ns   |            |
| SYMBOL                                                                  | DESCRIPTION                                  | MIN      | TYP | MAX.              | UNIT | COND       |
| DMA CO                                                                  | NTROLLED TRANSFER TIMING                     |          |     |                   |      |            |
| TCSV1                                                                   | Indicated CLK Edge to Indicate Signal Valid  |          | 150 | 250               | ns   | CL = 50 pF |
| TCSV2                                                                   | Indicated CLK Edge to Indicated Signal Valid |          | 250 | 400               | ns   | CL = 50 pF |
| TAS                                                                     | DAL Set Up to BUSR ↓ or LAL ♥(4)             | 80       |     |                   | ns   | CL = 50 pF |
| ТАН                                                                     | DAL Hold from BUSR ↓ or LAL ♥ (₦)            | 50       |     |                   | ns   | CL = 50 pF |
| TLDF                                                                    | LAL ↓ to DAL Float                           |          |     | 250               | ns   | CL = 50 pF |
| TSET                                                                    | Indicated Signal Setup to Indicated CLK Edge | 80       |     |                   | ns   |            |
| MISCELL                                                                 | ANEOUS TIMING ( T 1 CLOCK PERIOD)            |          |     | J                 | ·    | I          |
| CS (4) To                                                               | DCS 🕇 (#)Propogation Delay                   |          |     |                   | [    |            |
| (for A3 lo                                                              | ow)                                          |          | 150 | 250               | ns   | CL = 50 pF |
|                                                                         | ) to IACKO 🕇 () Propogation Delay            |          |     |                   |      |            |
|                                                                         | t Requesting Interrupt                       |          | 150 | 250               | ns   | CL = 50 pF |
| BACKI I (I) to BACKO I (I) Propogation Delay<br>when Not Requesting Bus |                                              |          | 150 | 250               | ns   | CL = 50 pF |
| MR Pulse Width                                                          |                                              | 2τ       | 100 | 1 200             |      |            |
|                                                                         | AUTLD, DRQ, REPLY Pulse Width                | 2τ<br>1τ |     |                   |      |            |
|                                                                         | or TDB¥ (4) Set Up                           | 500      |     |                   | ns   |            |
|                                                                         | NTR V or BUSR V from STOPR V                 | 300      |     | 1τ - 400          | ns   | CL = 50 pF |
| 0                                                                       | rom DINTR                                    |          |     | 1.5 <b>t</b> +400 |      | CL - 50 pF |
| anna it fit                                                             |                                              |          |     | 1.0. 400          | 1 10 |            |

NOTE: A 1 TTL load is assumed on all output signals

DM1883A/B

See page 481 for ordering information.

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

## Western Digital п

 $\overline{n}$ 

# WD2143-03 Four Phase Clock Generator

#### FEATURES

IMPROVED VERSION OF WD2143-01

п

- TRUE AND INVERTED OUTPUTS
- SINGLE 5 VOLT SUPPLY
- TTL COMPATABLE .
- ON CHIP OSCILLATOR
- TTL CLOCK INPUT
- TTL CLOCK OUTPUTS
- PROGRAMMABLE PULSE WIDTHS
- PROGRAMMABLE PHASE WIDTHS
- NO EXTERNAL CAPACITOR

#### GENERAL DESCRIPTION

The WD2143-03 Four-Phase Clock Generator is a MOS/ LSI device capable of generating four phase clocks. The output pulse widths are controlled by tying an external resistor to the proper control inputs. All pulse widths may be set to the same width by tying the  $\phi$ PW line through an external resistor. Each pulse width can also be individually programmed by tying a resistor through the appropriate  $\phi$  1PWφ4PW control inputs.

N





#### DEVICE OPERATION

Each of the phase outputs can be controlled individually by typing an external resistor from  $\phi$ 1PW- $\phi$ 4PW to a +5V supply. When it is desired to have  $\phi 1$  through  $\phi 4$  outputs the same width, the  $\phi$ 1PW- $\phi$ 4PW inputs should be left open and an external resistor tied from the  $\phi$ PW (Pin 17) input to +12V.

STROBE IN (pin 11) is driven by a TTL square wave. Each of the four phase outputs provide both true and inverted signals, capable of driving 1 TTL load each.

| PIN NUMBER | SYMBOL                              | DESCRIPTION                                                                                                                       |
|------------|-------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 1, 3, 5, 7 | $\overline{\phi}1-\overline{\phi}4$ | Four phase clock outputs. These outputs are inverted (active low).                                                                |
| 2, 4, 6, 8 | φ1-φ4                               | Four Phase clock outputs. These outputs are true (active high).                                                                   |
| 9          | GND                                 | Ground                                                                                                                            |
| 10         | NC                                  | No connection                                                                                                                     |
| 11         | STB IN                              | Input signal to initiate four-phase clock outputs.                                                                                |
| 12         | NC                                  | No connection                                                                                                                     |
| 13-16      | φ1 <b>PW-</b> φ4 <b>PW</b>          | External resistor inputs to control the individual pulse widths of each output. These pins can be left open if $\phi$ PW is used. |
| 17         | φPW                                 | External resistor input to control all phase outputs to the same pulse widths.                                                    |
| 18         | V <sub>cc</sub>                     | +5V $\pm$ 5% power supply input                                                                                                   |

Table 1 PIN DESCRIPTIONS

### TYPICAL APPLICATIONS

WD2143-03



Figure 2 WRITE PRECOMP OPERATION WITH F.S.L. WD1691



Figure 4 EQUAL PULSE WIDTH OUTPUTS



Figure 3 TTL SQUARE WAVE OPERATION



Figure 5 INDIVIDUAL PULSE WIDTH OUTPUTS





Figure 7 WD2143-03 TIMING DIAGRAM

#### SPECIFICATIONS

 Absolute Maximum Ratings

 Operating Temperature
 0° to +70° C

 Voltage on any pin with respect to Ground\*
 -0.5 to +7V

 Power Dissipation
 1 Watt

 Storage Temperature
 plastic
 -55° to +125° C ceramic -65° to +150°C

Note: Maximum ratings indicate limits beyond which permanent damage may occur. Continuous operation at these limits is not intended and should be limited to the DC electrical characteristics specified.

\* Pin 17 = -0.5V to +12V. Increasing voltage on Pin 17 will decrease  $T_{DW}.$ 

#### DC ELECTRICAL CHARACTERISTICS

 $V_{CC} = 5V \pm 5\%$ , GND = OV,  $T_A = 0^{\circ}$  to 70°C.

| SYMBOL | PARAMETER             | MIN. | MAX. | UNITS | CONDITIONS            |
|--------|-----------------------|------|------|-------|-----------------------|
| VOL    | TTL low level output  |      | 0.4  | v     | ioL = 1.6 mA          |
| Voh    | TTL high level output | 2.0  |      | v     | $i_{OH} = -100 \mu A$ |
| VIL    | STB in low voltage    |      | 0.8  | v     |                       |
| VIH    | STB in high voltage   | 2.4  |      | v     |                       |
| icc    | Supply Current        |      | 80   | mA    | All outputs open      |
|        |                       |      |      |       |                       |

Table 2 DC ELECTRICAL CHARACTERISTICS

#### SWITCHING CHARACTERISTICS

 $V_{CC} = 5V \pm 5\%$ , GND = 0V T<sub>A</sub> = 0° to 70° C

| SYMBOL           | PARAMETER                | MIN. | MAX. | UNITS | CONDITIONS                            |
|------------------|--------------------------|------|------|-------|---------------------------------------|
| tPD              | STB IN to Ø1             | r    | 140  | ns    | · · · · · · · · · · · · · · · · · · · |
| <sup>t</sup> pw  | Pulse Width (any output) | 100  | 300  | ns    | CL = 30pf                             |
| tPR              | Rise Time (any output)   |      | 30   | ns    | CL = 30pf                             |
| tPF              | Fall Time (any output)   |      | 25   | ns    | CL = 30pf                             |
| fs               | STROBE PULSE WIDTH       |      | 1.0  | μs    | combined t <sub>pw</sub> = 400 ns     |
| <sup>t</sup> DPW | Pulse Width Differential |      | ± 10 | %     | Referenced to Ø1, 100-300 ns.         |

Table 3 SWITCHING CHARACTERISTICS

NOTE: TPW measured at 50% VOH Point; VOL = 0.8V, VOH = 2.0V.

See page 481 for ordering information.

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

*C O R P O R A T J O N* **WD9216-00/WD9216-01** 

WESTERN DIGITAL

Floppy Disk Data Separator — FDDS

#### FEATURES

- PERFORMS COMPLETE DATA SEPARATION FUNCTION FOR FLOPPY DISK DRIVES
- SEPARATES FM OR MFM ENCODED DATA FROM ANY MAGNETIC MEDIA
- ELIMINATES SEVERAL SSI AND MSI DEVICES NORMALLY USED FOR DATA SEPARATION
- NO CRITICAL ADJUSTMENTS REQUIRED
- COMPATIBLE WITH WESTERN DIGITAL 179X, 176X AND OTHER FLOPPY DISK CONTROLLERS
- SMALL 8-PIN DUAL-IN-LINE PACKAGE
- +5 VOLT ONLY POWER SUPPLY
- TTL COMPATIBLE INPUTS AND OUTPUTS

#### **GENERAL DESCRIPTION**

The Floppy Disk Data Separator provides a low cost solution to the problem of converting a single stream of pulses from a floppy disk drive into separate Clock and Data inputs for a Floppy Disk Controller.

The FDDS consists primarily of a clock divider, a long-term timing corrector, a short-term timing corrector, and reclocking circuitry. Supplied in an 8-pin Dual-In-Line package to save board real estate, the FDDS operates on + 5 volts only and is TTL compatible on all inputs and outputs.

The WD9216 is available in two versions; the WD9216-00, which is intended for  $5\frac{1}{4}$  disks and the WD9216-01 for  $5\frac{1}{4}$  and 8" disks.



#### **PIN CONFIGURATION**



#### FLOPPY DISK DATA SEPARATOR BLOCK DIAGRAM

#### **ELECTRICAL CHARACTERISTICS**

#### MAXIMUM RATINGS\*

| Operating Temperature Range  | 0°C to + 70°C  |
|------------------------------|----------------|
| Storage Temperature Range    | -55°C to 125°C |
| Positive Voltage on any Pin, |                |
| with respect to ground       | + 8.0V         |
| Negative Voltage on any Pin, |                |
| with respect to ground       | – 0.3V         |

\* Stresses above those listed may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or at any other condition above those indicated in the operational sections of this specification is not implied. **NOTE:** When powering this device from laboratory or system power supplies, it is important that the Absolute Maximum Ratings not be exceeded or device failure can result. Some power supplies exhibit voltage spikes or "glitches" on their outputs when the AC power is switched on and off. In addition, voltage transients on the AC power line may appear on the DC output. If this possibility exists it is suggested that a clamp circuit be used.

| <b>OPERATING CHARACTERISTICS</b> (T <sub>A</sub> = | = 0°C to 70°C, V <sub>CC</sub> = +5V ± 5% | , unless otherwise noted) |
|----------------------------------------------------|-------------------------------------------|---------------------------|
|----------------------------------------------------|-------------------------------------------|---------------------------|

|                                              | PARAMETER                                                    | MIN.       | TYP.       | MAX.       | UNITS      | COMMENTS          |
|----------------------------------------------|--------------------------------------------------------------|------------|------------|------------|------------|-------------------|
| D.C. CHARACTERISTICS<br>INPUT VOLTAGE LEVELS |                                                              |            |            |            |            |                   |
| Low Lev                                      |                                                              |            |            | 0.8        | v          |                   |
|                                              | evel VIH<br>/OLTAGE LEVELS                                   | 2.0        |            |            | v          |                   |
| Low Lev                                      |                                                              |            |            | 0.4        | v          | IOL = 1.6mA       |
|                                              | vel VOH                                                      | 2.4        |            | -          | v          | $IOH = -100\mu A$ |
| INPUT CU<br>Leakage                          |                                                              |            |            | 10         |            | 0 ≤ VIN ≤ VDD     |
|                                              | PACITANCE                                                    |            |            |            | μΑ         |                   |
| All Inpu                                     |                                                              |            |            | 10         | pF         |                   |
|                                              | UPPLY CURRENT                                                |            |            | 50         | mA         |                   |
| A.C. CHARA                                   | CTERISTICS                                                   |            |            |            |            |                   |
| Symbol                                       |                                                              |            |            |            |            |                   |
|                                              | EFCLK Frequency<br>EFCLK Frequency                           | 0.2<br>0.2 |            | 4.3<br>8.3 | MHz<br>MHz | WD 9216-00        |
|                                              | EFCLK High Time                                              | 50         |            | 2500       | ns         | WD 9216-01        |
| TCKL RE                                      | EFCLK Lo <u>w Tim</u> e                                      | 50         |            | 2500       | ns         |                   |
|                                              | EFCLK to <u>SEPD</u> "ON" Delay<br>EFCLK to SEPD "OFF" Delay |            | 100<br>100 |            | ns<br>ns   |                   |
|                                              | EFCLK to SEPCLK Delay                                        | 100        | 100        |            | ns         |                   |
| tDLL DS                                      | SKD Active Low Time                                          | 0.1        |            | 100        | μS         |                   |
| tDLH DS                                      | SKD Active High Time                                         | 0.2        |            | 100        | μS         |                   |



WD9216-00/WD9216-01

#### DESCRIPTION OF PIN FUNCTIONS

| PIN<br>NUMBER | PIN NAME        | SYMBOL   | FUNCTION                                                                                                                                                          |  |  |  |  |
|---------------|-----------------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| 1             | Disk Data       | DSKD     | Data input signal direct from disk drive. Con-<br>tains combined clock and data waveform.                                                                         |  |  |  |  |
| 2             | Separated Clock | SEPCLK   | Clock signal output from the FDDS derived from floppy disk drive serial bit stream.                                                                               |  |  |  |  |
| 3             | Reference Clock | REFCLK   | Reference clock input.                                                                                                                                            |  |  |  |  |
| 4             | Ground          | GND      | Ground.                                                                                                                                                           |  |  |  |  |
| 5,6           | Clock Divisor   | CD0, CD1 | CD0 and CD1 control the internal clock dividercircuit. The internal clock is a submultiple of theREFCLK according to the following table:CD1CD0Divisor00012104111 |  |  |  |  |
| 7             | Separated Data  | SEPD     | SEPD is the data output of the FDDS                                                                                                                               |  |  |  |  |
| 8             | Power Supply    | Vcc      | + 5 volt power supply                                                                                                                                             |  |  |  |  |



TYPICAL SYSTEM CONFIGURATION (51/4 " Drive, Double Density)

#### OPERATION

A reference clock (REFCLK) of between 2 and 8 MHz is divided by the FDDS to provide an internal clock. The division ratio is selected by inputs CD0 and CD1. The reference clock and division ratio should be chosen per table 1.

The FDDS detects the leading edges of the disk data pulses and adjusts the phase of the internal clock to provide the SEPARATED CLOCK output.

Separate short and long term timing correctors assure accurate clock separation.

The internal clock frequency is nominally 16 times the SEPCLK frequency. Depending on the internal timing correction, the internal clock may be a minimum of 12 times to a maximum of 22 times the SEPCLK frequency.

The reference clock (REFCLK) is divided to provide the internal clock according to pins CD0 and CD1.

| _            |
|--------------|
| -            |
|              |
|              |
| 0            |
|              |
| œ            |
| Ñ            |
| _            |
| _            |
| 0            |
| <b>.</b>     |
| ÷            |
| 0            |
| ~            |
| $\mathbf{C}$ |
| -            |
|              |
| ~            |
|              |
|              |
| 0            |
|              |
| 9            |
| Ň            |
| IV.          |
| -            |
| _            |
| <b>o</b>     |
| <b>~</b> ″   |
|              |

2

|                       | TABLE 1:<br>CLOCK DIVIDER SELECTION TABLE |               |             |             |   |                   |  |  |
|-----------------------|-------------------------------------------|---------------|-------------|-------------|---|-------------------|--|--|
| DRIVE<br>(8″ or 5¼ ″) | DENSITY<br>(DD or SD)                     | REFCLK<br>MHz | CD1         | CD0         |   | REMARKS           |  |  |
| 8<br>8<br>8           | DD<br>SD<br>SD                            | 8<br>8<br>4   | 0<br>0<br>0 | 0<br>1<br>0 | } | Select either one |  |  |
| 5¼<br>5¼              | DD<br>DD                                  | 8<br>4        | 0<br>0      | 1<br>0      | } | Select either one |  |  |
| 51⁄4<br>51⁄4<br>51⁄4  | SD<br>SD<br>SD                            | 8<br>4<br>2   | 1<br>0<br>0 | 0<br>1<br>0 | } | Select any one    |  |  |





See page 481 for ordering information.

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