Apple /// Computer Information • Doc # 78 • ProFile Hard Disk Repair Info # Apple /// Computer Information APPLE /// PROFILE HARD DISK REPAIR DOCUMENTS 78 Ex Libris David T. Craig SCANNED BY JOE D VOGEL -- 7/2006 Source: David T. Craig Page 0001 of 0580 Apple Computer, Inc. Service Engineering Department # Apple /// Computer Repair Documents DAVID T. CRAIG 736 EDGEWATER, WICHITA, KANSAS 67230 [USA] 71533.606@ COMPUSERVE. COM Source: David T. Craig Page 0002 of 0580 Page lof1 ## APPLE /// COMPUTER ## REPAIR INFORMATION: PROFILEHARD DISK [ DAVID T. CRAIG - 736 EDGEWATER, WICHITA, KANSAS 67230 U.S.A. ] ## TABLE OF CONTENTS ``` PGS TITLE 31 8 PROFILE SALES KIT: PROFILE TECHNICAL REVIEW 12-2 6 APPLE /// PROFILE LIMITED DATA RECOVERY 203 11 PROFILE EXCHANGE PROCEDURES 32 4 238 PROFILE LEVEL 2 PHASE 1 SERVICE MANUAL (PRELIMINARY) 27/5 101 PROFILE LEVEL 2 PHASE 1 SERVICE MANUAL (VERY PRELIMINARY) 26 DSKDBG - BLOCK DEVICE DEBUGGER (VERSION E00.17) SERVICE MANUAL 372 6 PAGES: 399 7 1 HOW TO USE THE REV 18 DEBUGGER TO COPY PROFILES 4018 6 PROFILE PRODUCTION FORMAT TEST PROCEDURE WITH APPLE /// 408 9 4 CONVERTING A 5M BYTE PROFILE TO 10M BYTE 413 10 2 PROFILE CERTIFICATION AND FAILURE CRITERIA 416 11 3 PROFILE DEBUG DATA STATUS BYTE DEFINITIONS 420 12 7 PROFILE POWER SUPPLY (CLASS B) SPECIFICATION 428 13 9 PROFILE POWER SUPPLY (CLASS A2 - INTERNATIONAL) SPECIFICATION 438 14 12 HEAD DISK ASSEMBLY SPECIFICATION (FROM SEAGATE TECHNOLOGY) 451 15 9 INTERFACE CARD SET-UP AND TEST PROCEDURE - PROFILE/APPLE /// 6 PROFILE ANALOG BOARD FUNCTIONAL TEST (05 JAN 1984) 461 16 3 PROFILE ANALOG BOARD DEBUG TEST (08 DEC 1983) 468 17 442-18 1 PROFILE ANALOG BOARD DEBUG TEST REPAIR NOTES (08 DEC 1983) 474 19 2 PROFILE ANALOG BOARD UPGRADE 477 20 8 PROFILE INTERFACE BOARD TESTER OPERATION AND MAINTENANCE MANUAL 486 21 21 DISK DEBUG TEST USER'S MANUAL - PROFILE 5M BYTE 8 FORMATTING THE PROFILE HDA 508 22 517 23 7 PROFILE POWER SUPPLY (CLASS A) SPECIFICATION J25 24 2 PROFILE SECTOR INTERLEAVE CHARTS 528 25 2 PROFILE STATUS INFORMATION 531 26 5 MISC. PROFILE OSCILLOSCOPE CHARTS 537 27 1 PROFILE CONTROLLER ROM MISC. FACTS 539 28 4 MISC. PROFILE FACTS (HANDWRITTEN) THE 29 1 APPLE /// - PROFILE INTERFACE CARD SCHEMATIC 546 <sup>30</sup> 6 PROFILE FORMAT AND DIAGNOSTIC PROGRAM (VERSION 0.11) (PRELIMINARY) 553 31 5 SOS SOFTWARE DRIVER INFORMATION 559 32 3 PROFILE CONTROLLER BOARD PHOTOS 563 33 16 FUNCTIONAL DESCRIPTION OF THE PROFILE ANALOG BOARD (ROUGH DRAFT) ``` Source: David T. Craig Page 0003 of 0580 Apple Computer, Inc. Service Engineering Department # Apple /// Computer Repair Document COMPONENT NAME Profile Hard Disk DOCUMENT TITLE Profile Sales Kit: Profile Technical Review Author: Apple DAVID T. CRAIG 736 EDGEWATER, WICHITA, KANSAS 67230 [USA] Source: David T. Craig Page 0004 of 0580 Apple III ## ProFile Sales Kit ## ProFile Technical Review This section of the ProFile Sales Kit will give you an overview of the technical details of the ProFile Personal Mass Storage System for the Apple ///. It is intended to be a summary only, and is not a detailed explanation of the engineering aspects of the ProFile. This information is presented to give you a better understanding of the quality, reliability, and performance that Apple has built into ProFile, and to prepare you to answer technical questions raised by your customers. Additional information regarding the ProFile can be found in "Section D" of this Sales Kit. ## What is ProFile? Profile is a Winchester technology hard disk drive designed to operate with the Apple /// personal computer. It has a formatted storage capacity of 5 Megabytes, which is essentially the same as 35 floppy disks (the Apple /// disk drive uses floppies that have a capacity of 140K Bytes). The Profile will, as you can see, enable you to store large amounts of data on a single device. You are also able to store files that are larger than the 140K floppies that you usually use. In addition, you are able to access your data much faster with the Profile than with the Disk ///. The ProFile physically consists of three main assemblies. They are the ProFile drive, the Apple /// interface card, and the interconnect cable. The ProFile has its own power supply, and as such does not rely on the Apple /// for operating power. Functionally, the ProFile consists of five major modules: - 1. The Controller Card - 2. The Power Supply - 3. The Analog Card - 4. The Head Disk Assembly (HDA) with motor control board - 5. The Interface Card The following sections describe the function of these modules in detail. ## The Contoller Card Functionally, the controller provides communications with the Apple ///, provides signals to read and write serial data on the disk, moves the heads to the proper track, and monitors error conditions. The controller consists of a Z8 microprocessor, 2K bytes of RAM, error detection logic, and read/write control logic. 1-8 Source: David T. Craig Page 0005 of 0580 The Z8 provides an intelligent interface to the Apple ///. High level commands, such as read, write, and status, are passed to the Z8 through the RAM. The Z8 executes the command and passes the result of the operation back to the Apple /// through the RAM. The controller also interfaces to the analog card to pass head control information to it. In this way the controller determines when read/write operations will take place. The Z8 controls the stepper motor to move the heads from track to track (called "seeking"), selects one of four read/write heads, and writes sector marks on the disk during formatting. Read /Write functions are performed by the read/write logic on command from the Z8. This logic in turn controls the parallel to serial data conversion when writing, and the serial to parallel data conversion when reading. To ensure the proper transfer of data, the controller does a CRC (cyclic redundancy check) of the serial data. If an error occurs, the Z8 will automatically perform an error recovery routine and try to relocate the data onto a different section of the disk. The sector causing problems will be removed from use to prevent future errors. To prevent heat build-up in the drive, the Z8 removes power from the stepper motor if no commands have been received for 0.75 seconds. After 3 seconds, the head is moved to a non data area of the disk to prevent accidental damage to data if a failure (such as power loss) occurs. The READY light on the front of the ProFile is lit whenever the controller is idle (not busy). ## Power Supply The power supply provides the +5VDC, +12VDC, and -12VDC needed by the ProFile for operation. The supply also contains monitoring circuitry to detect a power failure. Once a failure is detected, the head current is shut off to prevent the accidental writing of false data that would otherwise occur if a write operation were in process when the power failed. The power supply is completely shielded to eliminate the effects of electro magnetic radiation. ## Analog Card The analog card serves as the interface between the controller and the Head Disk Assembly (HDA). It consists of a data encoder, a data decoder, write driver, head select logic, automatic gain control (AGC) preamplifier, read detector, phase lock loop (PLL), and sector detector. The head select matrix selects one of the four heads for a read or write operation. The ProFile has two fixed disks in its HDA, and there are two heads for each disk (one for each side, since the disks are double sided). Thus you have a choice of four heads, depending on which section of the disk you are trying to access. It is not necessary for you to know which section of the disk you are trying to access; the controller 2-8 Source: David T. Craig Page 0006 of 0580 and the analog board take care of that for you. During a write operation, the serial data is encoded using a technique known as MFM. It is not important that you know what this is, just that it allows the maximum data storage with low formatting overhead. In otherwords, it lets you get a lot of data in a small amount of space. During a read operation, the AGC circuit amplifies the low level head signal (.6 to 2.0 mv) to a fixed signal level (1.0 volt). The read detector simply shapes the signal so that it appears in a standard fashion. The PLL and data decoder then convert this signal back into serial data, which is passed to the controller, which in turn converts it to parallel data and passes it to the Apple ///. When the disk is initially formatted, the sector boundaries are written to the disk (this is done by removing all read signals from certain sections of the media). During the read operation, the sector detector looks for these areas of no read signal, and signals the controller that a sector boundary has been found. ## Head Disk Assembly (HDA) The ProFile HDA is a random access storage device with two non-removable 5 1/4 inch discs as storage media. Each disk surface employs one movable head to service 153 data tracks. The total formatted capacity of the four heads and surfaces is 5 Megabytes (16 sectors per track, 532 bytes per sector, 612 tracks). High reliability is achieved through the use of a band actuator and open loop stepper head positioning mechanism. The read/write heads are mounted on a ball bearing supported carriage which is positioned by the band actuator connected to the stepper motor shaft. The inherent simplicity of the mechanical design and electronic control allows maintenance free operation for the life of the drive (designed for over 10,000 hours MTBF). All PCB's are mounted outside the HDA for easy serviceability. Mechanical and contamination protection for the heads, actuator, and discs are provided by an impact resistant aluminum enclosure. A self contained recirculating system supplies clean air through a 0.3 micron filter. a special spindle pump assures adequate air flow and uniform temperature distribution throughout the head and disk area. Thermal isolation of the stepper and spindle motor assemblies from the disc enclosure provides significantly greater "off track" margin (temperature changes are less likely to cause read errors). Additionally, read and write operations can be performed immediately after power on without waiting for thermal stabilization. A brushless DC drive motor rotates the spindle at 3600 RPM. The spindle is driven directly with no belt or pulley. The motor and spindle are dynamically balanced to insure a low vibration level. A brake is used to provide a fast stop to the spindle motor when power is removed. Source: David T. Craig Page 0007 of 0580 ## Apple /// Computer Information • Doc # 78 • ProFile Hard Disk Repair Info 7 The recording media consists of a lubricated thin magnetic oxide coating on a 130 mm diameter aluminum substrate. This coating formulation, together with the low load force, low mass Winchester type "flying heads", permits reliable contact start/stop operation. ## Interface Card The Apple /// interface card serves primarily to buffer the data and decoded control lines of the Apple /// for transmission to the ProFile controller card. The interface card may be plugged into any of the four Apple /// expansion slots. Eight bi-directional data lines and five control lines are connected to the ProFile controller card with a 25-conductor cable. Each signal is buffered by an RC network fo EMI/RFI suppression. Bytes may be transferred either one at a time or by DMA at 1 Megabyte per second. 4-8 Source: David T. Craig Page 0008 of 0580 Apple III ## ProFile - The Reliability Story With thousands of ProFiles already installed, we have been asked to explain what Apple has done to make the ProFile so reliable. This is how we do it: Design Simplicity: Experience shows that the fewer parts there are, the less that can go wrong. Profile was designed to work in harmony with the personal computer, resulting in fewer electronic and mechanical parts than any comparable Winchester design. There are fewer things that can go wrong with Profile. ProFile is designed to prevent problems: Throughout the design process, the question was asked: "What can go wrong?" The answers were taken into account as the design proceeded. For instance, ProFile moves the heads to a "parking position" off the data zone after three seconds of no activity. This prevents the loss of data if, for instance, the ProFile is dropped or jarred. ProFile constantly checks for errors during operation. After any change in tracks, ProFile verifies that the operation has been performed correctly. ProFile also checks that the heads are positioned accurately on a track before any read or write operation is performed. Unless the system requests that the ProFile do otherwise, data is always verified after a write operation. In all these cases, ProFile will correct the problem so that no errors occur. Many types of systems are prone to failures when the power is turned on or off. The ProFile power supply is designed to sense a power failure well before the internal DC voltages drop. This allows the intelligent controller in ProFile to prevent any data loss if the power fails or is turned off accidentally. The system will not begin any operation until the power is on for at least one second. Superior System Margins: For the user, a system with greater operating margins results in superior reliability. Profile will operate correctly and handle data correctly under adverse environmental and mechanical conditions. For example, the packaging of Profile enables it to withstand a one inch (2.5 cm) drop while operating, or a three inch (7.6 cm) angled drop while not operating. The HDA (head disk assembly) can be operated from 10°C to 60°C. This wide operating range, combined with a 75% efficient switching power supply allows Profile to operate from 10 to 40°C in still air without a fan! High speed, low noise ECL (emitter coupled logic) provides wide margins for the analog electronics section of ProFile. Motor speed is kept accurate within 4%. Automatic gain control combined with a unique "gated detector" can compensate for off track operation up to 20%. Data can be read correctly with up to 50% signal degradation. 5-8 Source: David T. Craig Page 0009 of 0580 ProFile can Detect and Even Correct Problems: The intelligent controller which is built into ProFile is continually checking the operation of the disk. In addition to the "problem prevention" functions already described, ProFile performs additional operations to assure that the user will never see a problem. These operations start the moment ProFile is turned on. After power-up, ProFile does a scan of the entire disk surface, and checks for any errors. Upon any data error, an extensive analysis of the error is performed to determine whether a media error exists. If that is the case, the data will be moved to a spare sector of the disk. That part of the disk with a media error will no longer be used. In most cases, the data recovery routines in ProFile will be able to extract the data even from a bad sector. The recovery operation includes more than 300 retries under various conditions. Maps of the bad sectors are redundantly recorded on ProFile so that an error in the map will not cause a problem in operation. ProFile is Designed for Performance: Data can be transferred from the ProFile to the system at up to one Mbyte per second DMA rate. Data is interleaved at a 5:1 ratio, which allows three 512 byte sectors to be transferred on each rotation. MFM encoding allows the maximum data storage capacity with low formatting overhead. Profile has been Exhaustively Tested in Design and Manufacturing. During product development, over 200,000 hours of testing were logged. Over forty systems were customer tested for three months before volume production began. Each ProFile is tested for 184 hours prior to shipment, 60 of which are at $60^{\circ}$ C. This commitment to quality ensures a 10,000 hour MTBF with typical performance of over 24000 hours MTBF. ProFile is truly the most reliable product of its type. 6 - 8 Source: David T. Craig Page 0010 of 0580 ## PROFILE: ## APPLE'S 5 MEGABYTE PERSONAL MASS STORAGE SYSTEM for the APPLE /// #### FEATURES: ## 1. ProFile has 5 Megabytes of storage capacity - 2. Less than 44 cents per 1000 bytes - 3. ProFile accesses data 10 times faster than the conventional floppy disk drive. - 4. ProFile's intelligent controller automatically scans for error conditions and relocates marginal data blocks elsewhere on the disk, if necessary. - 5. ProFile has a flexible backup scheme using the Backup /// Utility. - 6. ProFile is fully supported by Apple ///s Sophisticated Operating System. - 7. Many different application programs can be stored on ProFile. Using Catalyst software from Quark Engineering, various software programs stored on ProFile, can be selected and then loaded from the hard disk without re-booting floppy diskettes when you want to go from one program to another. - 8. Profile is compact, lightweight, 8. Profile is usable in any work styled like the Apple /// and Monitor ///, simple to install, and extremely quiet. ## BENEFITS: - 1. Simplifies large data processing and programming tasks. - 2. Provides cost-effective data storage. - 3. Increases productivity. - 4. Assures data integrity. - 5. Assures data security. - 6. Apple /// software utilizes ProFile without requiring any changes. Different types of programs can often use the same data base. - 7. Saves time normally lost when booting up numerous floppies. Reduces media wear because programs are booted directly from the ProFile. - environment. 7-8 Source: David T. Craig Page 0011 of 0580 ## MARKETS AND APPLICATIONS ProFile is an ideal tool for.... - \* Financial Planners: who can make better decisions, because ProFile lets them draw on a greater data base in generating answers to questions about pricing, market share, profits, etc. In addition, all financial modeling files created with programs such as VisiCalc can be stored in one place allowing the planner to switch quickly from one file to another. - \* <u>Software Developers:</u> Profile lets developers keep all successive versions of programs on the same disk, thus making development time less tedious and time-consuming. - \* <u>Graphics Designers:</u> Thanks to ProFile's fast access time, plots, charts, and finished graphics can be displayed many times faster than with conventional diskettes. ProFile also makes it possible to create highly sophisticated graphics programs that require large amounts of storage space. - \* Professionals: ProFile lets doctors, dentists, lawyers, consultants, and other professionals store large client record files all in one place. - \* Managers in small to medium size businesses: Profile has the storage capacity to hold many letters, memos, reports, and other documents in a single place. 8-8 Source: David T. Craig Page 0012 of 0580 Apple Computer, Inc. Service Engineering Department # Apple /// Computer Repair Document Pro File Hard Disk DOCUMENT TITLE ProFile Limited Data Recovery Author: Apple DAVID T. CRAIG 736 EDGEWATER, WICHITA, KANSAS 67230 [USA] Source: David T. Craig Page 0013 of 0580 # apple computer inc. 6 pages 13 Source: David T. Craig ProFile Technical Procedures Section 1 Apple /// ProFile Limited Data Recovery ## Contents: | Introduction | . 3 | |----------------------------|-----| | What You Should Do First | | | Software Overview | | | Equipment Required1. | | | Configuring the Software | , 4 | | Setting Up the System | 4 | | Running the Program1. | . 5 | | Interpreting the Results1. | . 7 | ProFile Data Recovery rev. 4/20/83 Page 0014 of 0580 page 1.1 # **K**apple computer inc. 14 ProFile Technical Procedures Apple /// ProFile Limited Data Recovery and Exchange ## Contents: ## Section 1 | Introduction | |--------------------------| | What You Should Do First | | Software Overview | | Equipment Required1.4 | | Configuring the Software | | Setting Up the System | | Running the Program | | Interpreting the Results | ## Section 2 | Introduction | | |------------------------------------------------------------|-------| | Materials Required | .2.3 | | Removing the Cover | .2.5 | | Removing the LED Assembly | 2 7 | | Installing the New LED Assembly | .2.9 | | Replacing the Cover and Rear Plates Packaging for Shipment | .2.1 | | Summary of Procedures | .2.13 | | Builliary of Frocedures. | | ProFile Technical Procedures rev. 4/20/83 page 0.1 Source: David T. Craig Page 0015 of 0580 ## apple computer inc. #### A. INTRODUCTION This ProFile Limited Data Recovery Program is used with Apple /// ProFiles. It attempts to copy customer's files from a damaged ProFile to the exchange unit. Although there is no guarantee that data can be transferred, in most cases data recovery is possible if the ProFile passes the self test after being turned on. If the ProFile READY light does not come on to a steady state, data cannot be recovered using this program. Special arrangements must be made with Level 2 for data recovery. The importance of regular backups should be emphasized to the customer. The customer should have a copy of the Backup /// diskette (part number 681 0032). The documentation for this is "Apple /// Backup User's Manual" (part number 030 0381). CAUTION: Before continuing with this procedure use the "Apple /// Confidence Program" (part number 681 0031) to ensure that the Apple /// is functioning properly. Failure to do this could possibly damage the ProFile! ## B. WHAT YOU SHOULD DO FIRST First run the confidence program and make sure that the Apple /// is functioning properly. Then $\underline{\text{make a back-up copy of the Recovery Program diskette!}}$ You will be using a system with known bad hardware attached to it, so don't take a chance of destroying the software accidentally. Put the original in a safe place. ## C. SOFTWARE OVERVIEW The diskette accompanying this document contains software designed to recover a large portion of data found on a damaged ProFile. In order to use this program the customer's ProFile must complete the power-up cycle, which includes a testing sequence. That is, the red "READY" indicator must be on and steady. If this does not occur, data recovery is not possible. The program copies data from the customer's ProFile to the exchange unit. If the program has difficulty writing to the Exchange ProFile, it should stop. Something could be wrong with the Exchange unit, so try another Exchange unit. As data is copied, those blocks which the program had problems reading are identified. After the blocks are copied, all further operations are performed on the exchange unit. ProFile Data Recovery rev. 4/20/83 page 1.3 Source: David T. Craig Page 0016 of 0580 IΨ ## apple computer inc. The program examines each file to see if any of its blocks were among those which couldn't be copied. A printed record indicates the files that couldn't be copied as being suspect and, most probably, unusable. While this is going on, the master allocation map for the entire ProFile is also being rebuilt. The allocation map tells which blocks are used and which are free for use. Our testing has shown that of the ProFiles that become "READY", the program is able to recover most all of the customer's data. ## D. EQUIPMENT REQUIRED Recovery Program Diskette Apple /// System (256k) Monitor Compatible Printer Printer Interface Card (if not using the Silentype printer) ProFile Interface Card (2 required) ProFile Interface Cable (2 required) ## E. CONFIGURING THE SOFTWARE The Recovery Program software is configured for two ProFile drivers and the Silentype printer. If you use the Silentype printer no configuration is necessary. If you wish to use a printer which uses the built-in serial port or an interface card, use the System Configuration Program to add the appropriate driver. (Refer to the Standard Device Drivers Manual.) Delete the .PRINTER driver already configured. Whatever printer driver you use must be named .PRINTER as the program looks for this name for its output. Do <u>not</u> under any circumstances, make any changes to either of the two ProFile drivers. These are named **.GOOD** and **.BAD**, and $\underline{\text{must}}$ remain that way for the program to run correctly. When you have the software properly configured, make another copy and use it as your working diskette. There is really no point in taking the chance of destroying the one you just configured. ProFile Data Recovery rev. 4/20/83 page 1.4 Source: David T. Craig Page 0017 of 0580 ## apple computer inc. ## F. SEITING UP THE SYSTEM - 1. Turn the power off on the Apple /// and remove the cover. - If necessary, install an interface card for the printer in the slot for which you configured its driver. - 3. Configure the Apple /// with two ProFiles as follows: Install the ProFile interface cards in slots three (3) and four (4). These are the two right-most slots as you look at the Apple from the keyboard side. Seat the cards firmly in the slots. - 4. The ProFile Electronic Module contains two circular markers, one red and one green. Place the <u>red</u> marker on the cable connected to the ProFile card in <u>slot 4</u>. Place the <u>green</u> marker on the cable connected to the card in <u>slot 3</u>. (Addition markers are included in the software package.) NOTE: You can leave this set-up and whenever you want to use the data recovery procedures all that is necessary it to connect the ProFiles (see next section). 5. Connect the printer and monitor. ## G. RUNNING THE PROGRAM NOTE: Before you running the Limited Data Recovery Program, attach the LED to the Exchange ProFile. (See Section 2 for directions.) - 1. Turn on the monitor. - 2. Turn on the printer and make sure it is on-line. - 3. Connect the (good) Exchange ProFile to the cable marked with the green marker. - 4. Connect the customer's ProFile to the cable marked with the <u>red</u> CAUTION: Check that the cables are connected correctly or you will copy files from the Exchange ProFile to the customer's, eliminating any chance of saving any files. 5. Connect the power cables to both ProFiles and turn them on. ProFile Data Recovery rev. 4/20/83 page 1.5 Source: David T. Craig ## apple computer inc. - Wait until the "READY" lights on both ProFiles show steady red. This will take a minute or so. - Place the Recovery Program Diskette in the Apple /// built-in drive. - 8. Turn on the Apple /// and the program will start. - 9. When the program starts you will see the message: Watch the ready light on the EXCHANGE ProFile. Please press the RETURN key when you're ready. When you press RETURN, the READY light on the Exchange ProFile should flash once, indicating that the cables are connected correctly. If the light does <u>not</u> flash, you may have connected the cables <u>incorrectly</u>. Press the ESCAPE key (to prevent the recovery <u>process</u>), check the cables and try again. 10. As a final check, you will see the following displayed: Are you sure you want to overwrite PROFILE? (PROFILE is the name of the Exchange ProFile.) Enter "Y" if the ready light flashed, or ESCAPE if the ready light did not flash: Answer yes by entering a Y to begin the recovery process. - 11. An asterisk (\*) in the upper right hand corner of the screen will blink to indicate that the recovery operation is working correctly. During the operation, different messages will appear on the screen to let you know what is happening within the program. The operation can take anywhere from 15 to 30 minutes, depending upon how much data can be recovered. - 12. As sections of the program are completed, messages will be listed to the printer. - 13. When the program is done, the Apple bell will beep about every five seconds. Press the ESCAPE key to stop the bell and the program. - 14. Power down both ProFiles. The exchange unit goes to the customer, and the other unit goes to Level 2. - 15. Turn the equipment off, remove the program diskette and put it away. ProFile Data Recovery rev. 4/20/83 page 1.6 Source: David T. Craig Page 0019 of 0580 ## ( Capple computer inc. #### H. INTERPRETING THE RESULTS Give your customer the printed results of the data recovery procedures and a copy of how to interpret these results. In the following explanation, examples of the printout are shown in bold face printing. These statements are interpreted as follows: ## Apple /// Limited Disk Recovery Program Results: Trouble accessing # All accessible directories are listed below. Individual files which contain problem blocks are also listed. The resolution of the individual files on the ProFile is shown as a running status, displaying the directory names as they appear on the ProFile. If a file contains one or more "suspect" blocks, its name will appear. These files are not deleted as they may, in fact, still be partially usable. An example of this would be as ASCII file, such as one created by AppleWriter. An attempt should be made by the customer to access these files. If the attempt results in "unusual" things happening, then delete them. ## Block Conflict Report This message appears if two or more files claim use of the same block .Another pass through the ProFile directories is made to resolve it. Along with this message the directory names are listed on the print-out. Those files which conflict with each other will be listed. An attempt is made to repair the problem. If the conflict is resolved, no further mention is made of the files, otherwise the following message appears: Unable to repair all block conflict errors. Try your files. ## Summary of Allocation Map Changes This summarizes the changes made to the master allocation map. This will include the total number of blocks available on the ProFile (blocks on volume), the number of blocks in use (blocks used), and the number still available (blocks available). ## Block(s) released from allocation map A statement will also appear regarding the number of blocks, if any, released from the allocation map. If blocks were released, the original allocation map "thought" that more blocks were in use than really were. The ProFile returned to your customer contains the updated, correct allocation map. (The End) ProFile Data Recovery rev. 4/20/83 page 1.7 Source: David T. Craig Page 0020 of 0580 3 Apple Computer, Inc. Service Engineering Department # Apple /// Computer Repair Document Profile Hard Disk DOCUMENT TITLE ProFile Exchange Procedures Author: Apple DAVID T. CRAIG 736 EDGEWATER, WICHITA, KANSAS 67230 [USA] Source: David T. Craig Page 0021 of 0580 Il pages ## ProFile Technical Procedures ## Section 2 ## ProFile Exchange Procedures ## Contents: | Introduction | 2.3 | |-------------------------------------|------| | Materials Required | 2.3 | | Removing the Cover | 2.5 | | Removing the LED Assembly | 2.7 | | Installing the New LED Assembly | 2.7 | | Replacing the Cover and Rear Plates | 2.9 | | Packaging for Shipment | 2.11 | | Summary of Procedures | 2.13 | ProFile Exchange rev. 4/20/83 page 2.1 Source: David T. Craig Page 0022 of 0580 # apple computer inc. ## A. INTRODUCTION When a customer returns a ProFile for servicing, the unit will be exchanged for a spares kit ProFile. Before you exchange the customer's ProFile, run the Limited Data Recovery program (described in Section 1) if there is data the customer wishes to try to recover. Exchanging the ProFile consists of removing the cover, the L.E.D. Cable Assembly and rear plates from the customer's ProFile, then replacing the LED assembly and placing the rear plates and the customer's cover on the Service Spares Kit (Exchange ProFile) unit. The shipping cover marked "SHIPPING FIXTURE" is attached to the ProFile to be serviced and the entire unit is placed in the same packaging as was the spares kit, and sent back for servicing. ## B. MATERIALS REQUIRED Diagonal cutters ("dikes") Tie Wraps Medium Phillips Screwdriver Protective Pad Small Flatblade Screwdriver CAUTION: The ProFile is a mechanical device with motors and moving parts. Rough handling such as dropping the drive, sharply jarring it or allowing heavy objects to fall on it can cause a malfunction. Whenever it is necessary to turn the ProFile over, be sure to rest it on a protective pad. ProFile Exchange rev. 4/20/83 page 2.3 Source: David T. Craig Page 0023 of 0580 ## 24 **Capple computer inc.** #### C. REMOVING THE COVER - Make sure the customer's ProFile is turned off. Disconnect the power cord and interface cable (ribbon cable) from the back of the ProFile. - 2. Turn the ProFile over, lay it on the protective pad, and remove the three Phillips-head screws from beneath the front panel (Figure 1, #1). - 3. Turn the ProFile right side up; loosen and remove the four screws on the back of the unit and the two rear plates (Figure 2, #1). - 4. Lift the cover off carefully and rest it on the far side of the case, taking care not to pull on the LED cable. - 5. Unplug the LED cable from its socket on the controller board (Figure 3, #1). - 6. Remove the cover marked "SHIPPING FIXTURE" from the Service Spare parts module. Note the LED assembly is not attached. ProFile Exchange rev. 4/20/83 page 2.5 Source: David T. Craig Page 0025 of 0580 Downloaded from www.Apple2Online.com 24/ Capple computer inc. #### D. REMOVING THE LED ASSEMBLY - The ProFile cover is removed and the LED cable is disconnected from the controller card. - 2. With the customer's cover laying flat, as in Figure 5, cut off the white plastic tie (Figure 6, #3) that holds the LED cable to the white holder in the cover (Figure 6, #2). - 3. Remove the other end of the LED cable from the other holder in the cover. (On some ProFiles, this holder will be a clamp like the one shown in Figure 5, #1; on others, it will be like the one shown in Figure 6.) - 4. With a flathead screwdriver, pry the cable clamp off the back of the LED (Figure 7, #1) and slide it down the cable, out of the way. - 5. Firmly push a few inches of the cable out through the slot in the cover (behind the "Ready" label) as shown in Figure 8. You will have to remove the "Ready" label around the LED opening on the cover to free the LED. - 6. Around the red LED is a small black plastic mount. Remove the mount (Figure 8, #1) by pushing out its side flaps and sliding it off the LED. - 7. Pull the cable back through the hole in the case. ## E. INSTALLING THE NEW LED ASSEMBLY - 8. Take the LED from the Service Spares Kit and thread it through the front opening in the cover. Place the small black plastic mount on the LED (see Figure 8, #1), then pull the cable back through the opening until the LED fits in its slot. Replace the "ready" label with the new label found in the spares kit.. - Push the cable clamp (Figure 6, #1) up to the cover until it holds the cable steady. - 10. Place the LED cable against the white plastic holder and fasten it with a tie wrap, contained in the spares kit, (Figure 6, #2 and 3). Cut off excess tie wrap. - 11. Place the cable in the other holder (Figure 5, #1), using a tie wrap if necessary. Cut off excess tie wrap. - 12. Connect LED cable to controller card (Figure 9). Place Customer's LED Cable Assembly and old "Ready" label in the bag, from which you got the new assembly, to be returned with the ProFile to be serviced. Put the customer's cover on the Spares Kit ProFile. ProFile Exchange rev. 4/20/83 page 2.7 Source: David T. Craig Page 0027 of 0580 ## capple computer inc. ## F. REPLACING THE COVER AND REAR PLATES - 1. Attach the LED cable to its connector on the controller card (Figure 10). Make sure the LED cable exits down and away from the card (Figure 10, #1). - 2. Replace the two rear plates and the four screws. Do not tighten the screws at this time (Figure 11). **NOTE:** The serial number is stamped on one of the rear plates and must be transferred to the ProFile which the customer will keep. - 3. Replace the customer's ProFile cover on to the spares module. (Hint: The four slots on the back of the cover fit between the inner and outer rear plates. Line up the back first; then pull the cover gently forward and down. Check around the cover to make sure the LED cable isn't caught between the cover and the base.) - 4. Tighten the four rear-plate screws. - 5. Turn the ProFile over and replace the three screws on the front edge (Figure 12). - Turn the ProFile right side up. Reinstall the power cord and the interface cable. NOTE: Before replacing the cover on the unit to be serviced, lay the used LED Cable Assembly from the customer's ProFile on top. 7. Replace the cover marked "SHIPPING FIXTURE" on the unit to be returned for servicing. ProFile Exchange rev. 4/20/83 page 2.9 Source: David T. Craig Page 0029 of 0580 36 **É**apple computer inc. ## G. PACKAGING FOR SHIPMENT The following instructions refer to Figure 13 unless otherwise stated. - 1. Set Packing Box on the floor with all flaps facing outside the box. - 2. Bend the two End Pads and slide them into the box with the foam against the sides of the box. - Slide Bottom Pad, with the foam side toward the bottom of the box, into position between the end pads. - 4. Place End Caps snuggly onto the ends of the ProFile (Figure 14). - 5. Place the boxed ProFile on top of the Bottom Pad. - 6. Lay the Top Pad with the foam padding facing away from the ProFile, on top of the ProFile. - Place the Accessory Box, which contains the used LED Assembly, on top of the ProFile. - 8. Close the end (short) flaps; then the side flaps. - 9. Secure the flaps using shipping tape. - 10. Secure shipping documentation to the top of the box. FIGURE 14 ProFile Exchange Source: David T. Craig Page 0031 of 0580 | <b>J</b> al: | pke ( | computer inc. | | |--------------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------| | н. | SUMM | ARY OF PROCEDURES CHECKLIST | | | | | Remove the spares kit from its packaging. Keep materials to package the unit to be sent in for | | | | | Remove cover marked "SHIPPING FIXTURE" from the verify that all modules are present, all connect and that there are no loose or broken wires or f | ions are proper, | | | | Turn on monitor. | | | | | Turn on printer and make sure it is on-line. (Talready configured for the Silentype printer.) | The driver is | | | | Connect LED on Exchange ProFile. | | | | | Connect Exchange Profile (use slot 3 for the Int | cerface card). | | | | Connect customer's ProFile (use slot 4 for the I | Interface card). | | | | Turn on Apple /// and run the Limited Data Recov | very program. | | | | Power down and disconnect both ProFiles. | | | | | Remove both rear plates from the customer's Prob | File. | | | | Remove the cover from the customer's ProFile. | | | | | Remove and replace the LED assembly on the cover<br>ProFile, using the new LED front panel label. | r of the customer's | | | | Attach the two rear plates from the customer's Exchange (spares kit) ProFile). Note that the sone of these plates. | ProFile onto the<br>serial number is on | | | | Replace the customer's cover onto the Exchange I into place over the two rear plates. | ProFile fitting it | | | | Place the used LED assembly along with the old in the assembly box. | front panel label | | | | Attach the cover marked "SHIPPING FIXTURE" onto serviced. | the unit to be | | | | Pack the unit to be repaired and the box contain assembly in the spares kit packaging. | ning the used LED | | | | Complete all shipping documentation. | | | | | | (The End) | Source: David T. Craig Page 0032 of 0580 # Apple /// Computer Repair Document ProFile Hard Disk Pro-File Level II. Phase 1 Service Manual (Preliminary) Author: Apple DAVID T. CRAIG 736 EDGEWATER, WICHITA, KANSAS 67230 [USA] Source: David T. Craig Page 0033 of 0580 Source: David T. Craig Page 0034 of 0580 # PROFILE EQUIPMENT LIST | 13 | DEBUGGER: FIRMWARE889-9007 28338-8603 | |----|---------------------------------------| | 2) | SOFTWARE DUPLICATION: FST | | 3) | UPGRADE KIT: MASKED Z8 MICROPROSSOR | | | MISCELLANEOUS TOOLS: TEST LED | Source: David T. Craig Page 0035 of 0580 # PRO-FILE PHASE 1 SERVICE MANUAL TABLE OF CONTENTS | Manual Introduction i | |----------------------------------------------------------------------------------------------------------------------------------------------| | Section 1 Troubleshooting | | Section 1 Introduction | | Section 2 Service Procedures | | How To Use This Section 2.1 | | Pro-File Module Removal/Replacement Procedures Introduction | | PCB Upgrades Controller PCB Upgrade | | Checks and Adjustments HDA Speed 2.23 HDA Index 2.24 HDA Brake 2.26 HDA Track 0 2.30 | | Software Operation Procedures Format Program | | Pro-File Phase 1 Service Manual Table of Contents rev 11-28-83 | Source: David T. Craig Page 0036 of 0580 # PRO-FILE PHASE 1 SERVICE MANUAL TABLE OF CONTENTS #### Section 3 Appendices | Hov | to Use This Section | 2 | |-----------------------|----------------------------------------|-----------| | Ger<br>1.<br>2.<br>3. | rview of the Pro-File eral Information | 5<br>6 | | Pro | -File HDA Description | | | 2. | Physical Description | | | Fir | mware Routines | | | 1.<br>2.<br>3. | Scan Operation | 23 | | Cir | cuit Descriptions | | | 1. | Controller PCB | 27<br>9 2 | | 1. ( | ematic Diagrams Controller PCB | | | 2. | Analog PCB | 24 | Pro-File Phase 1 Service Manual Table of Contents rev 11-28-83 Source: David T. Craig Page 0037 of 0580 #### HOW TO USE THIS MANUAL The Pro-File Phase 1 Service Manual is divided into 3 sections: #### SECTION 1 TROUBLESHOOTING: This section contains a flowchart procedure and corresponding explanation for troubleshooting a problem Pro-File to the faulty module. #### SECTION 2 SERVICE PROCEDURES: This section contains the various procedures needed to test, adjust, and remove or replace the modules on the Pro-File. #### SECTION 3 APPENDICES: This section contains various descriptions referred to by the other sections for the purpose of providing general and specific information on Pro-File operation. Service Manual Introduction Page i rev 9-21-83 Source: David T. Craig Page 0038 of 0580 ### Apple /// Computer Information • Doc # 78 • ProFile Hard Disk Repair Info # 39 SECTION 1 TABLE OF CONTENTS | Section 1 Introduction 1. | |---------------------------------------| | Main Troubleshooting Flowchart 1. | | No Scan Troubleshooting Flowchart 1.1 | | Diagnostic Procedure Flowchart | Pro-File Phase 1 Service Manual Page 1.1 rev 9-21-83 Source: David T. Craig Page 0040 of 0580 #### IMPORTANT READ THIS #### HOW TO USE THIS SECTION The procedure in this Troubleshooting Section is concerned with isolating a problem in the Pro-File to a malfunctioning module (i.e. Controller PCB, Analog PCB, Hard Disk Assembly (HDA), or Power Supply). CAUTION: The Hard Disk Assembly (HDA) is a very expensive and fragile device, handle it gently to avoid damage. To troubleshoot the Pro-File use the flowcharts in this section beginning with the main flowchart on the next page. If you find a problem, go to the opposite page and read the explanation for the check that failed. This explanation will provide you with valuable information on the reasoning behind the flowchart, and will also provide you with references to sections 2 and 3 for needed procedures and additional information. After reading the flowchart explanation, you may if you wish take the action indicated at the NO branch of the total section indicated at the NO branch of \* If you are not familiar with Pro-File operation you may wish to read the Pro-File HDA description and/or the Pro-File Overview in the Appendices Section. Pro-File Phase 1 Service Manual Page 1.3 rev 9-21-83 Source: David T. Craig Page 0041 of 0580 1.1 When the Pro-File first came out the firmware program used for the Z8 microprocessor on the Controller PCB was contained on a ROM chip located piggyback on the Z8. After this version had been out in the field awhile, it was found that due to the heat expansion that occurred when the machine was turned on, the leads from the ROM's piggyback socket were intermittently separating from the Z8. Since the 28 would be looking for program instructions when this happened, the temporarily open input would be interpreted as a bit in an instruction code and cause the 28 to do strange things including putting the Pro-File into Write mode as the heads were doing a seek to a target track. This of course destroyed any sector header and/or data block fields that happened to be passing under the heads as they were on their way to the target track. Later when a read of the damaged sectors was tried, either as a result of the next power up Scan operation, or a read command from the host computer system, the Z8 would detect the problem and ultimately spare the sector which of course made the malfunction look like a media problem. The logical solution for the imagined media problem (the Z8 problem was not known at the time) was to replace the now badly formatted (though undamaged) HDA with a new HDA. This action would cause the Pro-File to work fine until the piggyback ROM again separated from the Z8. The HDA would be replaced again, ... etc. Needless to say this process was not very effective. The masked ROM Z8 has been developed to be an effective solution to this problem. All piggyback Z8s are to be replaced with this version. It is projected that most of the current Profile problems will be remedied by this upgrade. (Now return to the point in the flowchart which referred you to this discussion.) All functions performed by the Controller and Analog PCBs and the HDA are ultimately controlled by the firmware program in the 28 microprocessor on the Controller PCB. During power up on the Pro-File the 28 will have the Pro-File go through a Scan operation in which certain specific things are checked for. A detailed explanation of the Scan operation may be found in Section 3 of this manual. (Now proceed to the NoScan flowchart.) Pro-File Phase 1 Service Manual Page 1.5 rev 9-21-83 Source: David T. Craig Page 0043 of 0580 - 2.1 The Quick Debugger program reads the Spares table on the Profile and prints the original sector location of every spared sector listed in that table. Additional information on sparing sectors may be found in the Special Function Tracks explanation in the HDA format description in the Appendices Section of this manual. At this point in the flowchart you know that Scan worked OK, but that the HDA has spared too many sectors. Spared sectors can be caused by either: - 1. Electronic problems causing a sector to be unreadable or somehow alter its data bit pattern at the original sector location on the disk. For example the 28 may have malfunctioned as it was performing a Seek, and instructed the electronics to write as the heads were moving across the media to a target track. This of course would destroy the parts of all the sectors that the head passed over on its way to the target track. - 2. Media problems making it impossible to record magnetic information on a sector where it occurs. This could be a manufacturing defect in the media (the magnetic coating on the disk), or a ding in the media caused by head contact. One way to determine whether a spared sector was caused by a media problem or an electronic problem is to continuously read the questionable sector and examine its analog signal with an oscilloscope. The Quick Debugger printout gives you a list of spared sectors that you might want to look at. The DP (Diagnostic Procedure) flowchart that you are being referred to, will explain how you can continuously read a spared sector and interpret its analog signal. (Now proceed to the DP Flowchart.) 2.2 A missing or out of tolerance voltage can be caused by any of the modules in the Pro-File. The method used in this flowchart to isolate the problem module is to disconnect the power supply from all the modules, plug in a known good Controller PCB and monitor the voltages at P3 (the power supply connection to the Controller PCB). If the power supply is at fault then the voltage/s will still be missing or out of tolerance. WARNING: At least one module must be connected to the Power Supply at all times to provide it with a load. If the voltages are OK with the known good Controller PCB installed, then the problem must be with a module other than the power supply. To determine which of these modules is causing the power problem, each module is reconnected one at a time and P3 is checked after each reconnection. (Now return to the flowchart.) Pro-File Phase 1 Service Manual Page 1.7 rev 9-21-83 Source: David T. Craig Page 0045 of 0580 3.1 The Index signal is never actually used by the Pro-File electronics after the HDA has been formatted. During the format process, Index is used to provide a reference for the sectoring scheme to be put on the disk. (For an explanation of the Format used on the Pro-File refer to the Pro-File HDA Description in the Appendices section of this manual.) But the Index does provide the technician with an indication of actual disk speed. It should occur once per revolution just before sector 0 on disk surface 0. Since the disk speed is supposed to be 3600 RPM this means that the frequency counter should measure a 16.666 ms period between each Index pulse. If the Index signal is present at TPl of the Controller PCB, but will not adjust as per directions in the Index Check and Adjustment procedure in the Service Procedures Section of this manual, then the problem could be with the electronics on the Motor Controller PCB on the HDA, or with the disk motor on the HDA. If the signal is absent at TPl on the Controller PCB, then flow should be traced back to the Index sensor on the bottom of the HDA. (Now return to the point in the flowchart which referred you to this discussion.) 3.2 During the Format process all sector headers and marks are erased and the spares tracks (track 77 on all disk surfaces) are erased. An inability to format could be caused by an electronic problem in the Pro-File, or by the HDA. If the HDA formats OK after putting it into a known good Pro-File, then the problem is probably with one of the electronics modules in the Pro-File. (Now return to the point in the flowchart which referred you to this discussion.) Pro-File Phase 1 Service Manual Page 1.9 rev 9-21-83 Source: David T. Craig Page 0047 of 0580 4.1) The FST (Final System Test) is an exersizer/tester program used to determine whether or not the Pro-File is operating within acceptable limits. For approximately the first 10 minutes of the FST, the data block field of every sector is written to and read to detect any CRC read errors. The system Z8 is used during this test, so the same firmware routines (i.e. Scan, Seek, Read, Retry, Diagnostic, etc.) will be used. After the initial 10 minute write/verify has been performed, the FST exercises the Profile by doing random Seeks, Reads, etc. until its operation is terminated when the operator presses the <ESCAPE> key. The reason the flowchart has you check for problems after the first 15 minutes of FST is because most hard failures will probably produce errors within 5 minutes after the FST begins to exercise the Pro-File. At this point in the flowchart errors can be caused by 2 types of problems: 1. An Electronic problem which has caused a sector to be unreadable by altering the data bit pattern at its original sector location on the disk. For example the Z8 may malfunction as it performs a Seek, and instruct the electronics to write as the heads move across the media to a target track. This of course would destroy the parts of all the sectors that the head passes over on its way to the target track (the head should never write during a seek). 2. A Media problem which has made it impossible to record magnetic information on the sector where it occurs. This could be a manufacturing defect in the media (the magnetic coating on the disk), or a ding in the media caused by head contact during rough handling. The big question at this point is which of the 2 types of problems described above is the real culprit. If the error was caused by an itermittent electronic problem producing a bad format on the HDA, then this looks like an HDA (media) problem. However, if the HDA is replaced the problem will probably reoccur in time. (This discussion is continued on the next page.) Pro-File Phase 1 Service Manual Page 1.11 rev 9-21-83 Source: David T. Craig Page 0049 of 0580 4.1 (continued) The method this flowchart uses to determine which type of problem caused the error is to compare the sector locations of sectors that had errors before formatting (a list of these sectors was printed out when you ran the Quick Debugger program on the problem Pro-File), with those produced after formatting (these will be shown by the FST). If they are the same, then the problem which caused the errors, is probably bad media because bad media locations don't change, so the HDA should be replaced. If they are different, then the problem is probably electronic. This is because it is highly unlikely that an intermittent electronics problem would occur on the same sector twice. (If you would like further information on spared sectors, firmware routines, the Pro-File's HDA format, etc., you may refer to the descriptions in the Appendices Section of this manual.) If the faulty sectors were the same, and the number of errors exceeds those specified by the FST service criteria sheet (found in the Service Procedures Section), then replace the HDA and return to the point in the flowchart which referred you to this discussion. If they are different, then the problem is probably electronic and you need to look at some of the different faulty sectors to determine what is bad about them and so determine which module is faulty. The DP (Diagnostic Procedure) flowchart that you are being referred to, will explain how you can continuously read a spared sector and interpret its analog signal. (If there were different sectors, then proceed to the DP Flowchart.) Pro-File Phase 1 Service Manual Page 1.12 rev 9-21-83 Source: David T. Craig Page 0050 of 0580 NS1.1 Upon power up on the Pro-File the Z8 will wait for the POK (Power OK) signal to occur. This signal is generated by the power supply when it determines that the proper voltage levels for each voltage have been reached and stabilized. When it happens the Z8 will cause the Ready lamp to extinguish. This should happen within 1/2 to 3 seconds of power up. A missing or out of tolerance voltage can be caused by any of the modules in the Pro-File. The method used in this flowchart to isolate the problem module is to disconnect the power supply from all the modules, plug in a known good Controller PCB and monitor the voltages at P3 (the power supply connection to the Controller PCB). If the power supply is at fault then the voltage/s will still be missing or out of tolerance. If the voltages are OK with the known good Controller PCB installed, then the problem must be with a module other than the power supply. To determine which of these modules is causing the power problem each module is reconnected one at a time and P3 is checked after each reconnection. (Now return to the point in the flowchart which referred you to this discussion.) NS1.2 Approximately 20 seconds after the Ready lamp goes out indicating that the power has stabilized, the disk motor should be rotating at 3600 RPM (its operating speed). If the HDA isn't spinning the Pro-File can't read data and that's probably why the Scan operation was unsuccessful. (Now return to the point in the flowchart which referred you to this discussion.) Pro-File Phase 1 Service Manual Page 1.15 rev 9-21-83 Source: David T. Craig Page 0053 of 0580 NS2.1 The firmware program in the system Z8 waits approximately 20 seconds after a successful powerup (a successful powerup is indicated by the Power OK signal becoming active and causing the Ready lamp to extinguish) before it initiates the Scan operation. During Scan operation the Z8 will cause the following things to occur. Note: Turn off the Pro-File and gently position the interruptor arm to the Park position (if it is not already there). Then turn on the Pro-File while you observe the following. The interruptor arm will move to approximately the center of its travel and pause there briefly while the spares table is read from track 77 on disk surfaces 2 or 3. If there is a problem which disables the Pro-File from being able to read anything, then this is the first place that it would be evident. If the 28 is unable to read sector headers on track 77, then the interrupter arm may go to track 0 and back to 77 to try again. If it still can't read sector headers it may go to track 155 (Park position) and back to track 77 to try again to attempt read the spares table. If it still can't read the spares table the 28 will abandon the Scan operation and move the interruptor arm to Park position. (If you would like a detailed description of the Scan operation, or further information on the spares table, error recovery routines, the Pro-File's HDA format, etc. refer to the descriptions in the Appendices Section of this manual.) (Now return to the point in the flowchart which referred you to this discussion.) NS2.2 If the Seek to track 77 was successful (as described above in NS2.1), then the read circuitry must be at least marginally OK, so the 28 will go to track 0 to begin to read each sector in sequence beginning with sector 0. During this time the Ready lamp will blink. If there is a problem in this procedure the Pro-File firmware may go to an error recovery routine. (If you would like a detailed description of the Scan operation, or further information on the spares table, error recovery routines, the Pro-File's HDA format, etc. refer to the descriptions in the Appendices Section of this manual.) (Now return to the point in the flowchart which referred you to this discussion.) Pro-File Phase 1 Service Manual Page 1.17 rev 9-21-83 Source: David T. Craig Page 0055 of 0580 ### DP - DIAGNOSTIC PROCEDURE NOTE: The Diagnostic Procedure (DP) flowchart begins on page 1.22. However if this is your first time through this procedure, it is strongly recomended that you read the following introduction. #### Introduction: The main objective of this procedure is to familiarize the technician with some common failure modes within the Pro-File electronics. Each of these modes usually shows up as an alteration, of the analog waveform of the sector being read from the HDA. The modified patterns usually do not reflect actual physical damage to the disc surface, but rather a problem in the Pro-File electronics. The technician's job will be to examine the faulty sector's analog signal as it is being read to determine which module within the Pro-File caused or is causing the failure. The faulty sector's analog signal waveform can be monitored directly by placing oscilloscope probe(s) on either Test Points 1 & 2 (TP1 & TP2 are the same signal differentiated) on the Analog PCB and externally triggering the scope with the Index signal at TP9. An easy way to access these test points is to remove the metal plate located underneath the Pro-File, and tilt the Pro-File up on its side to expose the Analog PCB (refer to page 2.22 for the location of the Test Points). This way the Pro-File can be checked quickly with a minimum of disassembly. Following this introduction are examples of analog signals PCB taken on TP1 & TP2 along with the VCO charge pump data locking error voltage at TP8. The signal read at either TP1 or TP2 is the analog data read directly from the head after passing the data through a preamplifier, lo-pass filter, and automatic gain control circuit. The signals at TP1 and TP2 are really just head signals amplified by the circuitry on the Analog PCB. A loss of signal at these test points may indicate that there is a problem with the connection between the HDA and Analog PCB, or the Analog PCB circuitry. (continued on the next page) Pro-File Troubleshooting rev. 10-12-83 page 1.18 Source: David T. Craig Page 0056 of 0580 #### Introduction: (continued) The signal obtained from TP8 is the feedback voltage that a Phase Locked Loop (PLL) control circuit uses to lock to the analog data signal on the HDA. The feedback either increases or decreases the voltage to a **Voltage Controlled Oscillator** (VCO) causing it to increment or decrement its output frequency thereby syncing that frequency to that of the data being read. When the Pro-File is idle, the VCO locks to about 20 Mhz, or twice the Controller PCB clock frequency (there is very little signal at TP8). When reading, the frequency varies in proportion to the data frequency written to the disc. So, whenever the Pro-File is reading the data from the HDA, the signal will change in amplitude to reflect data on the disc. (refer to page 1.26, Example of Normal VCO charge pump Signal {TP8 voltage}) #### Possible Problems: #### A. Z8 microprocessor Of the problems existing in the Pro-File, most of them can be attributed to the system Z8 microprocessor on the Controller PCB. (Refer to page 1.5, part 1.1). The older system Z8 was a "piggyback" type chip, and the new version is the masked system Z8. The masked version is a much improved version less likely to fail over a normal Pro-File lifetime, yet, there is small percentage of fallout within these chips too. One malfunction that commonly occurs is when the Z8 turns on the write circuitry while seeking to a different track. (Refer to the following pages on Damaged or Cleared Data Areas) (continued on the next page) Pro-File Troubleshooting rev. 10-12-83 page 1.19 Source: David T. Craig Page 0057 of 0580 #### Introduction: (continued) #### Possible Problems: (continued) ### B. Controller and Analog PCB Upgrades In the past some lines on the Controller and Analog PCBs were being spuriously activated. Sometimes this would cause the Z8 to go into its write routine when it was supposed to be seeking or idle. The Controller and Analog PCB upgrade procedures (described in the Service Procedures Section), were designed to be a solution to these problems. #### C. Controller PCB The Pro-File Controller PCB functionally provides control signals to the Analog PCB and HDA to move the heads to the proper track, select the proper sector, channel data, and monitor error conditions during a read or write. If a malfunction occurs in any of these functions, the Controller PCB can be suspected as the bad module. However, do not forget to verify the Z8 microprocessor first. #### D. Analog PCB There are 2 main Analog PCB problems: - 1. PLL (Phase Lock Loop) problems may show up as an abnormal VCO (Voltage Controlled Oscillator) charge pump signal at TP8 when the analog data signal at TP2 and TP2 appears normal. In this case, the PLL circuitry would not be able to lock to the analog data signal coming from the HDA. (Refer to page 1.40, Example of Abnormal VCO charge pump). - 2. AGC (Automatic Gain Control) circuitry problems may the analog data signal to be low or non-existant at TPl and TP2. (Refer to page 1.42, Example of Abnormal AGC signal) #### E. Hard Disk Assembly (HDA) Of the many possible problems which can occur on the HDA, there are four major ones. (continued on the next page) Pro-File Troubleshooting rev. 10-12-83 page 1.20 Source: David T. Craig Page 0058 of 0580 #### Introduction: (continued) #### Possible Problems: - E. Hard Disk Assembly (HDA) (continued) - 1. Media damage (Refer to page 1.38, Example of Bad Media) can be found by finding an area on the media with a loss of signal (not a sector mark), where repeated attempts at rewriting data does not return the area to normal. (Rewriting the sector can be accomplished with the Big Debugger program, using the <W> command, refer to page 2.40 for instructions) There also can be damage to the media where one of the disc heads has struck the surface of the disc. Remember that there is a space for 32 bad sectors in the Spares Table, so a few bad sectors existing due to a media problem is acceptable and a normal part of Pro-File operation. - 2. Motor Speed problems usually occur because of a defective Motor Control PCB on the HDA. A widely oscillating speed might adversely affect the operation of the Pro-File. The analog signals will be present at the Test Points, but the analog to digital circuitry will probably not be able to lock to the data on the HDA. And the Pro-File probably will not pass reformatting without errors occurring. - Disc Head problems are usually limited to a complete loss of signal at one or more of the heads. It is because of damage to the heads or a bad connection to the heads. Either way, the HDA needs replacement, as there is no way to repair a problem internal to the HDA in the field. - Stepper Motor problems may be caused by a bad connection between the Controller or Analog PCB's, or a bad stepper motor winding. Either way, the stepper will not move smoothly or have accuracy at any track step. To confirm the problem use the Read command from the Big Debugger program in the Service Procedures Section to perform a read on some track other than where the heads are now. If the interrupter arm rotates in the direction opposite of the target track, or shakes back and forth there may be a problem with the stepper motor. Another problem that can occur is stepper motor hysteresis. Hysteresis is where a magnetic field is built up inside the stepper motor coils causing the motor to settle with the head positioned at a slightly off track position. In this case the HDA should be replaced since this is a track alignment problem internal to the HDA and not repairable by the technician. Pro-File Troubleshooting rev. 10-12-83 page 1.21 Source: David T. Craig Page 0059 of 0580 (DP1.1) If you do not have a list of faulty sectors, then the interrupter arm must have spent 1 minute or more over a track during Scan. This probably means that the Pro-File had difficulty reading a sector or sectors on that track. By entering the commands specified at this step in the flowchart into the Big Debugger program, you will cause the Big Debugger program to read every sector in sequence and stop in the event of an error. When the program stops the test operation, the heads will be positioned over the problem track, and the head for the disk surface containing the problem track will be enabled. This means that the analog signal from that track should continuously be sent to TPl and 2 on the Analog PCB. Perform the steps in the DPL.3 procedure to view the signal from this track and determine if its display can provide you with a clue as to what the problem is. If you don't feel that the display of this track is providing you with the syptoms you need to diagnose the problem, you can press the <SPACE> bar to cause the Big Debugger program to test the rest of the sectors until it finds another error. View that tracks signal for symptoms in the same way .... etc. (DP1.2) By entering the commands specified at this branch in the flowchart into the Big Debugger program you will cause the Big Debugger program to read one of the sectors that you determined earlier in the flowchart might contain clues to electronic problems in the Pro-File. While the program continuously reads the specified sector, the heads will be positioned over the problem sector's track, and the head for the disk surface containing the problem sector will be enabled. In DP1.3 you will find a procedure to view the signal from this track. If you position your timebase delay hilight over the analog data read signal for this period and enter timebase delay mode on your oscilloscope you will see an expanded display of the questionable sector. Compare the display of the faulty sector by itself with the faulty sector examples later in this procedure to help you find the problem. If you don't feel that the display of this sector is providing you with any of the symptoms described in DP1.3, you can enter the commands necessary to have the Big Debugger program continuously read the next faulty sector on your list. View that sectors signal for symptoms in the same way .... etc. Pro-File Troubleshooting rev. 10-12-83 page 1.23 Source: David T. Craig Page 0061 of 0580 #### TO VIEW THE TRACK BEING READ: - 1. TURN ON THE OSCILLOSCOPE AND ALLOW IT TO WARM UP FOR 15 HINUTES - 2. INITIALLY SET CHANNEL A (OR 1) ON THE OSCILLOSCOPE TO THE FOLLOWING: - A. VOLTS PER DIVISION CONTROL SETTING TO 1 VOLTS/DIV - B. AC COUPLING - C. CONNECT TO HOA ANALOG DATA TP1 OR 2 ON ANALOG PC8 (GROUND THE PROBE) - 3. SET CHANNEL B (OR 2) TO: - A. 0.5 VOLTS/DIV - B. AC COUPLING - C. CONNECT TO HDA VCO SIGNAL TP8 ON ANALOG PC8 (DO NOT GROUND THE PROBE) - 4. USE EXTERNAL TRIGGER AND SET TIMEBASE TO: - A. 2 RSEC/DIV - B. CONNECT EXTERNAL TRIGGER TO INDEX PULSE TP1 ON CONTROLLER PCB - C. AUTO TRIGGERING ADJUST TRIGGER LEVEL TO LOCK SIGNAL ON SCOPE MOTE: IF THERE IS NO INDEX PULSE ON TP1 (CONTROLLER PCB), TRY USING TP9 (ON ANALOG PCB). IT IS ACTUALLY THE INDEX SIGNAL FROM THE HOA, IF IS NOT PRESENT, CHECK THE INDEX SENSOR ADJUSTMENT DESCRIBED IN SECTION 2 <u>OBSERVE:</u> THE SIGNAL YOU ARE VIEWING SHOULD BE SIMILAR TO THAT SHOWN IN THE PHOTOGRAPH ON THE OPPOSITE PAGE. #### TO VIEW THE SECTOR BEING READ: - 5. WHILE IN THE NAIN TIMEBASE, POSITION AND ADJUST THE DELAYED TIMEBASE HIGHLIGHT OVER THE PERIOD OF THE VCD CHARGE PUMP SIGNAL THAT IS ACTIVE (PROBABLY LOW AND OSCILLATING, SIMILAR TO THE LOWER SIGNAL IN THE PHOTOGRAPH ON THE OPPOSITE PAGE). - 6. ENTER THE DELAYED TIME BASE TO VIEW THE QUESTIONABLE SECTOR **DESERVE:** THE SIGNAL YOU ARE VIEWING HAY BE COMPARED WITH THE MORNAL SIGNAL ILLUSTRATION SHOUN ON PAGE 1.28. 7. VIEW THE EXAMPLE SIGNALS IN THE FOLLOWING PAGES TO DETERMINE A PROBLEM WITHIN THE PROFILE > CONTINUE WITH DIAGNOSTIC PROCEDURE SIGNAL EXAMPLES Pro-File Troubleshooting rev. 10-12-83 page 1.24 Source: David T. Craig Page 0062 of 0580 OP1.3 At this point in the flowchart a head should be enabled over a track containing a faulty sector. On your oscilloscope display you should see a signal similar to that in the figure shown below. If you had a list of faulty sectors, then the Big Debugger program should be continuously reading a faulty sector. Notice the period in the VCO charge pump signal where it is low and oscillating. The sector where the VCO charge pump signal goes low is the sector that is being read. If you position your delay trigger hilight over the analog data read signal for this peri,od and enter delay trigger mode on your oscilloscope you will see an expanded display of the questionable sector. Compare the display of the faulty sector by itself with the faulty sector examples later in this procedure. If you find one that is similar, read the corresponding explanation and if you wish perform the recommended module replacement. If you are viewing a questionable track and you don't know which sector is bad, then use the delay trigger function on your oscilloscope to view the sectors individually to determine why the Pro-File had a problem with this track. Note: A sector mark (sometimes called sector gap) separates each sector as shown below. If you would like information on the format used for the Pro-File refer to the Pro-File HDA description in section 3. Pro-File Troubleshooting rev. 10-12-83 page 1.25 Source: David T. Craig Page 0063 of 0580 ### Diagnostic Procedure #### Example of a Normal Track TP1 displays a view of a track of data. An entire track is shown between the arrows. Amplitude is 2 v peak to peak. TP8 (VCO) is shown locking in to read a sector by the lower arrow. #### Scope Settings: TP1 - 1 volt/div TP8 - .5 volt/div Timebase: 2 msec/div TP1 displays another look at a normal track with a higher amplitude of 2.4 v. Note that there are 16 areas of no signal corresponding to the sector marks. TP8 (VCO) is not used here. #### Scope Settings: TP1 - 1 volt/div TP8 - .5 volt/div Timebase: 2 msec/div Pro-File Troubleshooting rev. 10-12-83 page 1.26 Page 0064 of 0580 Source: David T. Craig #### Examples of a Normal Track The amplitude voltage of an analog data signal from a normal track can vary depending on the physical location of the track, the Analog PCB, and what actual data has been written to the HDA. The photos shown at the left are two characteristic normal tracks which show a possible variation in amplitude voltage. The upper photo displays an amplitude of about 2 volts peak to peak, the lower amplitude 2.4 volts. Each track contains 16 sectors separated by a sector mark, but at this timebase the photo actually shows more than the 16 sectors. This is because the period of signal displayed at this timebase is longer than the period of time that it takes to read one complete track, so the beginning of the same track is displayed as the disk begins its next rotation. One complete track is shown between the arrows. Note: Careful examination of the upper photo shows the VCO charge pump circuitry locking in on the sector indicated by the lower arrow. Pro-File Troubleshooting rev. 10-12-83 page 1.27 Source: David T. Craig Page 0065 of 0580 # EXPANDED VIEW OF ONE SECTOR (TP 1 or 2) ## EXPANDED VIEW OF VCO CHARGE PUMP SIGNAL (TP8) THE OSCILLATIONS SHOULD OCCUR ONLY FOR THE SECTOR BEING READ. THE VOLTAGE LEVEL THEY OCCUR AT DEPENDS ON THE SPEED ADJUSTMENT ON THE HOA HUTUR CONTROL POB (THE ILLUSTRATION DEPICTS A SIGNAL RIDING ON A NEGATIVE LEVEL, AS HOST WILL) Pro-File Troubleshooting rev. 10-12-83 page 1.28 Source: David T. Craig Page 0066 of 0580 #### Examples of a Normal Sector As explained in the previous example of a normal track, the amplitude voltage of an analog data signal from a normal track can vary depending on the physical location of the track, the Analog PCB, and what actual data has been written to the HDA. The illustration at the left shows a typical view of a normal sector's analog signal. The amplitude of a sector can vary from about 1.1 volts to over 2 volts. The flared "bell" shape at the beginning of each sector, is a normal characteristic caused by the AGC (Automatic Gain Control) circuitry as it adjusts for the gain of the analog read signal from the head. If the bell shape is missing, the technician might suspect a faulty Analog PCB. The Sync bytes and Sector Header field at the beginning of the sector are written during formatting, and should never be written over after formatting. The Write Splice is the point at which the Pro-File will normally begin to write a data block into the sector. When the Pro-File reads a data block from a sector the data block field may not be in exact sync with the Sector Header field, so additional sync bytes are needed after the Write Splice, for the Pro-File to sync to the data field. Notice that the VCO charge pump signal at TP8 goes low only for the sector being read. The oscillations that occur while the charge pump signal is low reflect the changes the VCO (Voltage Controlled Oscillator) makes to sync with the clock in the analog data signal read from the HDA (TP 1 or 2). Pro-File Troubleshooting rev. 10-12-83 page 1.29 Source: David T. Craig Page 0067 of 0580 # 67 Diagnostic Procedure Example of a Normal VCO Signal TP1 displays a partial view of a track of data. The Profile has been told to read the sector of data shown by arrow. TP8 (VCO) shows a signal corresponding to the sector read. This signal "locks" to the data. #### Scope Settings: TP1 - 1 volt/div TP8 - .2 volt/div Timebase: 1 msec/div TP1 displays a larger view of the sector being read. TP8 (VCO) shows a more detailed look at the signal produced at TP8. Each increase and decrease in signal amplitude corresponds to the data signal at TP1 #### Scope Settings: TP1 - 1 volt/div TP8 - .2 volt/div Timebase: .2 msec/div Pro-File Troubleshooting rev. 10-12-83 page 1.30 Source: David T. Craig Page 0068 of 0580 #### Example of a Normal VCO charge pump Signal As explained in this flowchart's introduction, the VCO charge pump signal at TP8 enables the VCO (Voltage Controlled Oscillator) on the Analog PCB to synchronize to the data written on the disk. The voltage level at TP8 causes the VCO to increase or decrease its output frequency. When the Z8 wishes to read a sector on a track this signal will go low and then oscillate. This means it is now controlling the correction of the VCO as needed during the reading of the sector. After the sector is read, the 28 will direct the signal to go high again since there is no longer any data to be synced to. The upper photo shown at the left shows a view of about half of a normal track. The Pro-File was told (using the Big Debugger Program) to read the sector continuously. No read errors occurred despite the large amplitude signal seen on TP8. The lower photo displays an enlarged view of the sector being read above. Note that the changes in peaks in the data signal at TPl correspond to the peaks in the VCO charge pump signal in TP8. An even larger view of the signals would show this more clearly. Pro-File Troubleshooting rev. 10-12-83 page 1.31 Source: David T. Craig Page 0069 of 0580 # 69 Diagnostic Procedure Example of a Damaged Track TP1 displays a view of a track of data. There appears to be extra sectors if you count the extra peaks. TP8 (VCO) attempted to lock to the data present on the track, but was unable to confirm any good sectors. #### Scope Settings: TP1 - 1 volt/div TP8 - .5 volt/div Timebase: 2 msec/div TP1 displays a closer view of some of the sectors of the track. Several sectors appear to be normal, but have actually been damaged. TP8 (VCO) could not lock to the damaged the sectors. #### Scope Settings: TP1 - 1 volt/div TP8 - .5 volt/div Timebase: .5 msec/div Suspect: 1. System Z8 2. Controller Board 3. HDA Pro-File Troubleshooting rev. 10-12-83 page 1.32 Source: David T. Craig Page 0070 of 0580 #### Example of Damaged Track As described in the Pro-File HDA Format description in section 3, sector marks divide each track into 16 separate sectors. The Controller PCB expects the sectors to be in a certain location with respect to the sector marks. The upper photo shown at the left shows an entire track of data with uneven length sectors (they should all be the same length), and extra pulses (TPI). A normal sector would occur where the VCO charge pump (at TP8) shows the amplitude in the negative direction (down). The Pro-File was instructed to read all the sectors of the track with the Big Debugger program, what is shown is every other sector being read. The lower photo shows an enlarged view of the track analog signal displaying areas which appear to be similar to a normal sector, but are actually damaged. There are extra areas of no signal similar to a normal sector mark at the end of some of the sectors, and areas with multiple sector marks at the beginning of the sector (refer to lower arrow). At this point, the technician would normally suspect the system Z8 as the cause of the damaged tracks. This is because the 28 has historically been the most common failed component in the Pro-File. Yet, this Pro-File already had a masked version of the system 28 installed on the Controller PCB. So it is a possibility that the Controller PCB is really at fault, not the 28. Since the 28 had already been replaced during the upgrade procedures, it was decided to reformat the HDA (correcting the track damage in the format), and run FST for 15 minutes to see if the track damage would reoccur. A replacement system 28 was installed, the system upgraded, and the HDA reformatted. After running FST for 10 minutes, the Pro-File began to produce errors: (Refer to page 2.37 for a list of errors and criteria for failure) > 04 00 00 00 05 00 00 00 15 80 00 00 The Pro-File was stopped and the Controller PCB replaced. (The original 28 was reinstalled into the new Controller PCB) and the 15 minute FST rerun. No additional errors occurred even after 48 hours, so it was assumed that the Controller PCB somehow produced the damaged tracks. Pro-File Troubleshooting rev. 10-12-83 page 1.33 Source: David T. Craig Page 0071 of 0580 ### 41 Diagnostic Procedure Example of Damaged Data Areas on Track TP1 displays a view of a track of data. There are missing sector marks and other strange areas on the track. TP8 (VCO) is not used here. #### Scope Settings: TP1 - 1 volt/div TP8 - .5 volt/div Timebase: 2 msec/div TP1 displays a closer look at one of the areas of the damaged track. The arrow points to where a sector mark is missing. TP8 (VCO) is not used here. #### Scope Settings: TP1 - 1 volt/div TP8 - .5 volt/div Timebase: .5 msec/div Suspect: - 1. System Z8 - 2. Controller PCB - 3. HDA Pro-File Troubleshooting rev. 10-12-83 page 1.34 Page 0072 of 0580 Source: David T. Craig ### Example of Damaged Areas within a Track As described in the Pro-File HDA Format, page 3.11, sector marks divide each track into 16 separate sectors. The Controller PCB expects the sectors to be in a certain location with respect to the sector marks. The upper photo shown at the left shows an entire track of data between the two arrows with missing sector marks and other abnormal areas (TP1). The damaged track was quickly found by using the Big Debugger program to scan from track 0 to park position, (type the command <R +T PE X>, refer to the Big Debugger description in section 2 if more instruction is needed). The Debugger program stopped the heads at this track when it detected a read error. By looking at the signal at TPL, some abnormalities were seen. The lower photo shows a enlarged view of a portion of the track in the upper photo. The arrow points to where a sector mark has been written over. This kind of signal pattern is another probable characteristic of a system 28 failure. The sector mark was written over and the data put down in such a way so that it could not be read again. Once the sector mark information is damaged in this way, there is no possible way for the Pro-File to rewrite the sector mark without reformatting. The diagnostics internal to the Pro-File would probably spare this area under normal circumstances. The HDA must be reformatted to establish the normal sector information (however, this will destroy any data). During a scan after powering on, the interrupter stopped momentarily at this track location while the 28 made attempts to read the damaged sectors. The sectors on this track were not present in the spares table bad sector list after running the Quick Debugger program. In a case such as this the only way to continuously find and read the faulty track is to run the Big Debugger program and have it pause on any error. At that point, look at the signal and try to determine the problem. Pro-File Troubleshooting rev. 10-12-83 page 1.35 Source: David T. Craig Page 0073 of 0580 # 73 Diagnostic Procedure Example of a Damaged Track and Sectors TP1 displays a partial view of a track of data. There is one normal sector of data shown by the arrow. The other sectors have been overwritten with an abnormal pulse in various places. TP8 (VCO) could not lock to the abnormal sectors. # Scope Settings: TP1 - 1 volt/div TP8 - .5 volt/div Timebase: .5 msec/div TP1 displays a larger view of the damaged sector. TP8 (VCO) is not used here. #### Scope Settings: TP1 - 1 volt/div TP8 - .5 volt/div Timebase: .2 msec/div Suspect: 1. System Z8 2. Controller PCB Pro-File Troubleshooting rev. 10-12-83 page 1.36 Source: David T. Craig Page 0074 of 0580 ### Example of Damaged Track and Sectors The upper photo shown at the left shows a partial track of data with one normal sector occurring in the center of the photo. The other sectors have what appears to be an extra sector mark written in the middle. Not only is the extra sector mark in the wrong position, the width of the sector mark is about three times normal. The 28 became confused when reading this sector because of the extra sector marks. The lower photo shows another track on the HDA with a similar problem (an extra apparent sector mark). At this point, one should normally suspect the system 28 as the cause of the damaged sectors. The problem Pro-File originally had a piggyback system Z8 installed, so there was a very good chance that the Z8 would be the problem. The Pro-File PCBs were upgraded and the HDA reformatted normally. A 15 minute FST run produced no errors, so the test was continued for 48 hours. No errors occurred. (except an occasional read error - 08 00 00 00; refer to page 2.37 for a list of errors and how many of a type are acceptable) Pro-File Troubleshooting rev. 10-12-83 page 1.37 Source: David T. Craig Page 0075 of 0580 # Diagnostic Procedure Example of Cleared Data Areas on Track TP1 displays a view of a track of data. About a 1/4 of the track has been wiped to a constant AC signal. There are no signs of data in this area. TP8 (VCO) is not used here. ### Scope Settings: TP1 - 1 volt/div TP8 - .5 volt/div Timebase: 2 msec/div TP1 displays another track which has been completely cleared of any data accept for one small disturbance. An normal track would be between the arrows. TP8 (VCO) is not used here. #### Scope Settings: TP1 - 1 volt/div TP8 - .5 volt/div Timebase: 2 msec/div # Suspect: 1. System Z8 3. Analog PCB 2. Controller PCB 4. HDA Pro-File Troubleshooting rev. 10-12-83 page 1.38 Source: David T. Craig Page 0076 of 0580 # Example of Cleared Data Areas on Track The upper photo shown at the left shows an entire track of data between the two arrows with about 1/4 of the track damaged. The sectors in the damaged area have been cleared to a continuous level AC signal by some unknown source, probably the system 28. Both the sector marks and data areas are missing. The lower photo shows another track on the same HDA which has been cleared completely of any data and sector marks. Each signal displays a condition where the HDA wrote a continuous AC signal without using the sector marks as an indicator of where to write. There is no way for the Pro-File to repair the damaged areas without the technician reformatting the HDA. Chances are very good that the system 28 functioned abnormally and caused the Pro-File to write over the data signal; so this would be a good choice for the bad module. It is also possible that the Controller or Analog PCB could be the cause of the problem because there could have been a short which may have caused the write circuit to malfunction. For example, a DC voltage shorted to one of the disc heads on the HDA, while the heads were positioned over a track might cause the head to perform a DC erase of the entire track. This kind of erase would only take about 17 milliseconds to happen (one disc revolution). But if this happened, the signal would be a low amplitude signal, much like a continuous sector mark, etc. Pro-File Troubleshooting rev. 10-12-83 page 1.39 Source: David T. Craig Page 0077 of 0580 # 77 Diagnostic Procedure ### Example of Offtrack Signal TP1 displays a view of a track of data. There are 3 sectors which have been damaged. TP8 (YCO) was not able to lock on to this kind of abnormal data signal at TP1 # Scope Settings: TP1 - 1 volt/div TP8 - .5 volt/div Timebase: 2 msec/div TP1 displays a closer view of some of the sectors of the track, including the bad area. The signal shows that two sectors have actually been damaged. TP8 (VCO) is not used here. #### Scope Settings: TP1 - 1 volt/div TP8 - .5 volt/div Timebase: .5 msec/div Suspect: - 1. System Z8 - 2. Controller PCB - 3. HDA Pro-File Troubleshooting rev. 10-12-83 page 1.40 Source: David T. Craig Page 0078 of 0580 #### Example of Offtrack Signal As described in the physical description of the Pro-File HDA format in section 3 of this manual, the data areas are written on the disc surfaces in tracks, and the Z8 performs the Seek routine to cause the stepper motor to move the heads over the target track to access data. The number of step pulses the 28 sends to the stepper motor determines how far . the head will move and so which track it will be over. (For an explanation of the Seek routine refer to the Firmware Routines description in section 3.) Because the control system is of open loop nature, (i.e. there is little feedback telling the Controller PCB where the disc heads are physically located) both mechanical and electronic offtrack problems can occur. A mechanical offtrack problem within the HDA can be caused by several things. The stepper motor controlling the position of the heads can become inaccurate placing the heads slightly offtrack either way. The metal band which pulls the heads back and forth can become torn or damaged resulting in poor placement of the heads. The mechanical assembly holding the bearings for the movement of the heads can become distorted causing every track to be shifted one way. Or the HDA stepper motor could have a hysteresis problem. Any of these problems can only be corrected by replacing the HDA. An electronic problem can resemble that of a mechanical one, except that there is generally no permanent damage done to the HDA. After reformatting, the HDA can be returned to normal service, as long as the problem has been eliminated from the system. If the system 28 was an older revision piggyback type, then it is probably the bad component. This is because the Z8 has historically been the most common failed component in the Pro-File. Another electronic failure that can cause an offtrack problem is the Controller PCB. The upper photo shows three sectors which have been damaged by the system 28 microprocessor by writing the data in an offtrack position. The lower photo shows a closeup of the analog signal where two sectors have actually been damaged. By telling the system to attempt to read the sector continuously, and carefully and gently moving the interrupter arm towards the target track, the signal became normal. This confirmed the fact that the sectors were written offtrack. By replacing the piggyback system 28 with a masked ROM version, reformatting the HDA the problem disappeared. This was confirmed by running the Pro-File on FST for 48 hours. Pro-File Troubleshooting rev. 10-12-83 page 1.41 Source: David T. Craig Page 0079 of 0580 # 79 Diagnostic Procedure ### Example of Bad Media TP1 displays a closer view of a suspected bad area of a track. In about the middle of the sector there appears to be a section missing some magnetic material. TP8 TP1 TP8 (YCO) does not show any perticular abnormality. ### Scope Settings: TP1 - 1 volt/div TP8 - 5 volt/div Timebase: .1 msec/div TP1 TP1 -displays a larger view of the sector shown above. On closer examination, the dead area appears as a sector mark, except much smaller in width. TP8 TP8 (VCO) displays as flat signal, as it would between normal sector marks #### Scope Settings: TP1 - 1 volt/div TP8 - 5 volt/div Timebase: .01 msec/div 1. Media Problem Suspect: Pro-File Troubleshooting rev. 10-12-83 page 1.42 Source: David T. Craig Page 0080 of 0580 #### Example of Bad Media Bad Media is an example of where the HDA disk surface coating has been damaged by either a defect in the magnetic coating or a scratch due to head contact with the media. There are a limited number of allowable defects per disk surface. These defects (hard errors) are defined as $\leq$ 2 bytes in length. The total number of defects is: > Per Drive Per Surface Track 0 32 errors total 8 errors total No errors allowed The HDA disk drive uses two double sided 5-1/4 inch discs coated with an iron oxide base material as the recording media. The disc dimensions are 40mm inside diameter and 130 mm outside diameter. The thickness of the magnetic coating increases linearly from 20 microinches to 40 microinches at the outside diameter. The disk surface is coated with a Teflon lubricant 40 to 60 angstroms in thickness. (an angstrom = 0.0000000004 inches) The media defect shown at left was detected by looking at the spares list of supposedly bad sectors, created by the Quick Debugger program and then telling the Big Debugger program to continuously read the suspect sector. An initial view of the track looked completely normal, except for the fact that one of the sectors produced an error when reading. By displaying the whole sector, there appeared to be a small area of no signal present (Refer to upper photo). Closer examination (by using the delay trigger function of the oscilloscope) of the suspect area of the sector, shows a total loss of signal in this area (lower photo). If bad media is suspected an attempt should be made to write data to the sector(s) in question before the conclusion can be made that the suspect area is actually a media problem. The Big Debugger allows the technician to read a sector into the computer buffer and write the sector back out to the 'bad' sector on the Pro-File. (Refer to page 2.40, for instructions on the Big Debugger program. Use the command <W> to write.) If the number of total errors incurred by reading the media is greater than or equal to the total number of errors shown above, then the HDA should be rejected as defective. Pro-File Troubleshooting rev. 10-12-83 page 1.43 Source: David T. Craig Page 0081 of 0580 # Diagnostic Procedure Example of Abnormal VCO Signal at TP8 <u>TP1</u> displays a view of a track of data. (The entire track appears between the two arrows) TP1 TP8 (VCO) displays a very high amplitude signal (2v). This abnormal voltage is due to the errors occurring when reading. TP8 Scope Settings: TP1 - 1 volt/div TP8 - 5 volt/div Timebase: 2 msec/div TP1 displays a closer view of one of the sectors of a track. This sector (and all others of the track) has been written offtrack. TP8 (VCO) tries to correct for the offtrack condition by boosting its amplitude voltage. This effect is seen at the left. Scope Settings: TP8 TP1 - 1 volt/div TP8 - .5 volt/div Timebase: .2 msec/div 1. Analog PCB 2. HDA Suspect: Pro-File Troubleshooting rev. 10-12-83 page 1.44 Source: David T. Craig Page 0082 of 0580 ### Example of Abnormal VCO charge pump Signal During a normal read operation, the Pro-File locks to the analog data signal by comparing the phase of the clock in the analog read signal with the phase of the VCO. If the VCO leads or lags the analog data clock a positive or negative correction voltage is stored in the charge pump capacitor. The charge on this capacitor is the voltage controlling the VCO, and can be seen at TP8 on the Analog PCB (usually + 1 volt Peak to Peak). To change the frequency, the Pro-File changes an input voltage to the VCO. If the VCO charge pump signal (TP8) is observed along with the data signal (TP1) and a large deviation in VCO charge pump voltage appears (similar to the spikes in the upper photo), the VCO circuitry on the Analog PCB could be causing the abnormal VCO charge pump voltage to occur- By changing the timebase to read a single sector (the lower photo), notice that both the analog data signal at TPI and the VCO charge pump voltage at TP8 appear abnormal. TPl displays an offtrack condition (noted by the pinching of the signal following the sector mark), where the head is not positioned directly over the written data signal. This offtrack condition can be either caused by an electronic or HDA related failure. (There are more examples of an offtrack data signal earlier in this procedure.) As it turned out, every track on the particular HDA which produced this picture showed an analog data signal similar to TPl (in the lower photo). Because every sector of every track on the HDA was offtrack, it might be concluded that the HDA is bad because of the consistency in head misalignment. The problem could be remedied by reformatting, but this would not be a good thing to do as the reason why the Pro-File went offtrack is not known. (Unknown damage internal to the HDA itself) Pro-File Troubleshooting rev. 10-12-83 page 1.45 Source: David T. Craig Page 0083 of 0580 # Diagnostic Procedure HORZ SUP = 2 MS/DIV Example of Abnormal AGC (Automatic Gain Control) TP1 displays a view of a track of data. The track amplitude is about half the expected value of 2 mv p-p. TP8 (VCO) is not used here ### Scope Settings: TP1 - 1 volt/div TP8 - .5 volt/div Timebase: 2 msec/div TP1 displays a closer view of some of the sectors of the track. Note that the sectors don't have the bell shape near the sector mark. TP8 (VCO) is not used here. #### Scope Settings: TP1 - 1 volt/div TP8 - .5 volt/div Timebase: Variable Suspect: - 1. Analog Card - 2. HDA Pro-File Troubleshooting rev. 10-12-83 page 1.46 Source: David T. Craig Page 0084 of 0580 ### Example of Abnormal AGC A normal data signal read at Test Points 1 & 2 on the Analog PCB have an average amplitude voltage of about 2 volts peak to peak. If there is a malfunction in the amplifier circuits between the disc heads and TP1 & 2, the signal amplitude can be much less. For example, the analog to digital conversion circuits may be able to operate with voltages as low as 1.1 volt Peak to Peak. Below 1.1 volt the analog circuitry just does not get a large enough amplitude signal to function. The AGC circuitry was added to overcome normal changes in signal as the head seeks back and forth between the inner and outer tracks. Decreases in the thickness of media coating or head flying height tend to cancel a loss in signal. Inner tracks will usually have the lowest amplitude signals. In the upper photo at the left, the AGC circuitry was not functioning correctly as the amplitude was about 1 volt peak to peak. After power up, the interrupter began to scan normally until about track 100, when the scan stopped. Several hours later the interrupter was still stopped on the same track, unable to read the data present there. The lower photo shows an expanded view of one entire sector from another track. Note that the normal flared shape present immediately after the sector mark is missing. This missing "bell" shape is a characteristic of a faulty AGC circuit on the Analog PCB. The Analog PCB was replaced and the Pro-File functioned normally. Pro-File Troubleshooting rev. 10-12-83 page 1.47 Source: David T. Craig Page 0085 of 0580 #### SECTION 2 TABLE OF CONTENTS | How To Use This Section | 2.1 | | | | | | | | | |------------------------------------------------|----------------------|--|--|--|--|--|--|--|--| | Pro-File Module Removal/Replacement Procedures | | | | | | | | | | | Introduction | 2.9<br>2.11<br>2.13 | | | | | | | | | | PCB Upgrades | | | | | | | | | | | | | | | | | | | | | | Controller PCB Upgrade | 2.19<br>2.21 | | | | | | | | | | • | | | | | | | | | | | Checks and Adjustments | | | | | | | | | | | HDA Speed | 2.24<br>2.26 | | | | | | | | | | Software Operation Procedures | | | | | | | | | | | Format Program | 2.36<br>2.37<br>2.38 | | | | | | | | | | | | | | | | | | | | Source: David T. Craig Page 0087 of 0580 Service Procedures Page 2.1 rev 10-12-83 # HOW TO USE THIS SECTION: This section contains the removal/replacement, theck and adipatment, and software operation procedures you will need to repair the pro-File. If you are unsure which procedure to perform, so to the troubleshooting procedure in the Frollieshooting section and follow the directions. Service Procedures Source: David T. Craig Page 0088 of 0580 # PROFILE MODULE REMOVAL AND REPLACEMENT PROCEDURES #### INTRODUCTION The following equipment will be needed in these procedures: | Diagonal cutters ("dikes") | Protective Pad | |-----------------------------|-----------------------------| | Tie Wraps | Medium Phillips Screwdriver | | Small Flatblade Screwdriver | Needlenose pliers | CAUTION: The ProFile is a mechanical device with motors and moving parts. Rough handling such as dropping the drive, sharply jarring it or allowing heavy objects to fall on it can cause a malfunction. Whenever it is necessary to turn the ProFile over, be sure to rest it on a protective pad. UNDER NO CIRCUMSTANCES SHOULD THE HDA BE ENTERED! Service Procedures Page 2.3 rev 10-12-83 Source: David T. Craig Page 0089 of 0580 #### THE PRO-FILE COVER #### Removing the Cover: - 1. Make sure the ProFile is turned off. Disconnect the power cord and interface cable (ribbon cable) from the back of the ProFile. - Turn the ProFile over, lay it on the protective pad, and remove the three Phillips-head screws from beneath the front panel (Figure 2, #1). - Turn the ProFile right side up; loosen but do not remove the four screws on the back of the unit (Figure 3, #1). - 4. Carefully pull out the lip on the bottom of the cover to disconnect it from the frame. - Take care not to pull on the LED cable as you carefully lift the cover off and rest it on the far side of the case, . - 6. Unplug the LED cable from its socket on the controller PCB (Figure 4, #1). #### Reinstalling the Cover: - 1. Attach the LED cable to its connector on the controller PCB (Figure 5). Make sure the LED cable exits down and away from the PCB (Figure 5, #1). - .2. Replace the ProFile cover. (Hints: The four slots on the back of the cover fit between the inner and outer rear plates, over the four loosened screws. Line up the back first; then pull the cover gently forward and down. Check around the cover to make sure the LED cable isn't caught between the cover and the base; then tighten the four rear-plate screws.) - 3. Turn the Profile over and replace the three screws on the front edge (Fig. 2). - 4. Turn the ProFile right side up. Reinstall the power cord and the interface cable. Service Procedures Page 2.5 rev 10-12-83 Source: David T. Craig Page 0091 of 0580 #### B. THE READY L.E.D. #### Removing Ready LED: - Remove the ProFile cover and disconnect the LED cable from the controller PCB. Lay the cover flat, as in Figure 6. - Cut off the white plastic tie (Figure 7, #3) that holds the LED cable to the white holder in the cover (Figure 7, #2). - 3. Remove the other end of the LED cable from the other holder in the cover. (On some ProFiles, this holder will be a clamp like the one shown in Figure 6, \$1; on others, it will be like the one shown in Figure 7.) - 4. With a flathead screwdriver, pry the cable clamp off the back of the LED (Figure 8, #1) and slide it down the cable, out of the way. - Gently push a few inches of the cable out through the slot in the cover, as shown in Figure 9. - NOTE: You may have to remove the "ready" label around the LED opening on the cover to free the LED. - 6. Around the red LED is a small black plastic mount. Remove the mount (Figure 9, #1) by pushing out its side flaps and sliding it off the LED. - 7. Pull the cable back through the hole in the case. #### Installing the Ready LED: - 8. Thread the LED cable through the opening in the cover, and place the small black plastic mount on the LED (see Figure 9, #1). Then pull the cable back through the opening until the LED fits in its slot. Replace the "ready" label. - Push the cable clamp (Figure 7, \*1) up to the cover until it holds the cable steady. - Place the LED cable against the white plastic holder and fasten it with a tie wrap (Figure 7, #2 and 3). - Place the cable in the other holder (Figure 6, #1), using a tie wrap if necessary. Cut off excess tie wrap. - Connect the LED cable to the controller PCB (Fig. 10) and reinstall the cover. Service Procedures Page 2.7 rev 10-12-83 Source: David T. Craig Page 0093 of 0580 Service Procedures Page 2:8 Fev 9-27-83 Source: David T. Craig Page 0094 of 0580 #### C. THE CONTROLLER PCB . Replacing the Old PCB: - Remove the cover and disconnect the LED from the controller PCB. - Disconnect the ribbon cable (Figure 11, #1) and (as far as you can) the orange Mylar motor control cable (Figure 11, #2) from the controller PCB. (You can finish disconnecting the motor control cable more easily after taking the PCB out.) NOTE: Do not pull on the ribbon cable (analog-to-controller cable). Push and wiggle the grey plastic connector until it comes free of the PCB. - 3. Remove the long screw at the middle rear of the controller PCB (Figure 11, #3). - 4. Use the needlenose pliers to push in the flanges of each of the five plastic stand-offs (Figure 11, #4), to release the PCB. NOTE: Some PCBs will have two additional stand-offs, or two screws to remove, as shown in Figure 11, #5. - 5. Lift the controller PCB forward and up off the power supply - you may have to push out on the rear plate to free the interface cable connector (Figure 11, #6), and finish disconnecting the motor control cable. Set the PCB aside. NOTE: When you lift off the controller PCB, you will see a loose metal spacer under the spot where you removed the long screw. Save this spacer for use with the new PCB. #### Installing the New PCB: - 6. Holding the controller PCB over the power supply, position the interface cable connector (Fig. 10, #6) in its slot in the rear plate. - Position the controller PCB over the five plastic stand-offs, but don't push it down yet. - 8. Connect a) the orange Mylar motor control cable and b) the analog-to-controller ribbon cable. - 9. Slide the metal spacer under the PCB so that it is underneath the rear, middle screw hole. Insert the long screw through the hole and the spacer without tightening it. - Gently push the PCB down until the stand-offs hold it firmly in place; then tighten the long screw. - 11. Connect the LED cable and replace the cover. Service Procedures Page 2.9 rev 10-12-83 Source: David T. Craig Page 0095 of 0580 FIGURE 13 FIGURE 14 Service Procedures Page 2:10 FeV 9=27=83 Source: David T. Craig Page 0096 of 0580 #### THE POWER SUPPLY Removing the Old Power Supply - Remove the cover, disconnect the LED cable and remove the controller PCB. - 2. Disconnect the small white power supply plug (between the power supply and the HDA) from its mate (Figure - Turn the ProFile over and rest it on a foam pad. Remove the four screws that hold the power supply onto the bottom of the ProFile case (Figure 13, #1). - Hold the power supply in place as you turn the ProFile right side up. Position it with its rear plates facing you. Find the longer of the two rear plates, remove the two screws that hold it on (Figure 14, #1), and remove the plate (Figure 14, #2). - 5. Remove the four screws that hold the power supply to the inner rear plate (Figure 15, #1), and lift out the power supply. #### Installing the New Power Supply - Position the power supply unit in the ProFile frame so that the two cables come out toward the HDA. Line up the four screw holes in the back of the power supply with the four lower holes in the inner rear plate; install the four screws. - 2. Replace the outer rear plate. Insert the two mounting screws that hold this plate to the inner rear plate, but don't tighten them all the way. - Connect the two-pronged power supply cable to its mate from the HDA (Figure 12, #1); reconnect them behind the orange Mylar cable (i.e., closer to the HDA). - 4. Holding the power supply in place, turn the ProFile over onto the workpad. Replace the four screws that hold the power supply to the bottom of the case. Turn the ProFile right side up. - Reinstall the controller PCB. - 6. Connect the LED cable to the controller PCB and put the ProFile cover back on. Service Procedures Page 2.11 rev 10-12-83 Source: David T. Craig Page 0097 of 0580 ### THE HARD DISK ASSEMBLY (HDA), AND ANALOG PCB #### Removing the Old HDA and Analog PCB: - Remove the cover, disconnect the LED cable, and disconnect the cables that connect the HDA to the power supply and controller PCB. - Turn the ProFile over and rest it on the protective pad. Remove the four screws that mount the HDA to the ProFile housing (Figure 15, #1). - Carefully lift the housing up and off. Keep the HDA on the protective pad. #### Removing Old the Analog PCB: - Turn the HDA so that the ribbon cable comes out to your right. - If there is a metal bar across the front of the analog PCB as shown in Figure 16, #1, or over the top of the analog PCB, remove the screws that hold the bar in place and set the bar aside. NOTE: This bar does not exist on later models. - Three small cables (Figure 17, #2, 3, 4) connect to one side of the PCB. The plug and socket of each cable should bear a corresponding number, so that you can tell which plug goes in which socket. If such numbers are not present, write them in with a marker. - 4. Carefully disconnect all five cables from the analog - Index cable (Figure 17, #2) - Stepper motor cable (Figure 17, #3) - 3. Track 0 cable (Figure 17, #4) - Head cable (Figure 17, #5) - Analog-to-controller cable (Figure 17, #6) - Turn the HDA so that the rounded side is facing you, and remove the ground strap (Figure 18, #1) by grasping its plug firmly with the needlenose pliers and pulling. CAUTION: This is a short wire and its connection is tight. Use minimum force to prevent ripping it off the analog PCB. - Remove the four Phillips-head mounting screws from the analog PCB (Figure 17, #1). - Gently squeeze outward on the rails (Figure 17, #7) and lift the analog PCB from the HDA. Service Procedures Page 2.13 rev 10-12-83 Source: David T. Craig FIGURE 21 Service Procedures Page 2.14 rev 9-27-83 Source: David T. Craig Page 0100 of 0580 #### Installing the New Analog PCB: - Slide the analog PCB back under the rails. Line up the holes in the PCB with the screw holes on the rail. - 9. Reconnect the analog-to-controller (ribbon) cable. (Do not use the arrow on the ribbon cable connector as a guide to connecting it. The ribbon cable should exit down and away from the analog PCB, and the side of the connector where the ribbon cable curls over a bar should be on top.) - Reconnect the other four cables. Check to make sure they are connected to the right plugs. - Replace the four Phillips-head mounting screws in the analog PCB. - 12. Reconnect the ground strap. - If there was a metal bar over the rail, replace it and reinstall its screws. - 14. Reinstall the HDA, reconnect all cables, and replace the cover. #### Reinstalling the HDA: - Turn the HDA so that the ribbon cable comes out to your right. - 2. Place the ProFile case over the analog PCB (see Figure 19: the rear plates of the case should be on the far side of the HDA). Line up the screw holes in the case with the screw holes in the railings over the analog PCB (Figure 19, #1). - 3. Reinstall the screws. - 4. Turn the ProFile right-side up, with the rear plate facing you. (The ribbon cable should now extend out from the bottom of the HDA.) Service Procedures Page 2.15 rev 10-12-83 Source: David T. Craig Page 0101 of 0580 Source: David T. Craig Page 0102 of 0580 Service Procedures Page 2:16 rev 9-27-83 #### F. THE MOTOR CONTROL PCB - 1. Remove the HDA and the Analog PCB as described in the HDA and Analog PCB Removal/Replacement procedure found in this section. - Refer to the illustrations on the opposite page to identify whether you have an old or new Motor control PCB. Your replacement motor control PCB should always be a new revision. - \*\*\* If you have an old motor control PCB, then you must remove the brake on the HDA in addition to removing the motor control PCB. - \*\*\* If you have a new motor control PCB then P1 may be a 7 pin Molex plug fitting on Jl a 6 pin jack. In this case pin 1 on the plug will be the extra pin with pins 2 through 7 of the plug fitting onto pins 1 through 6 of the jack. - 3. Remove the motor control PCB by disconnecting all plugs, and removing the 2 screws fastening it to the HDA main assembly. - 4. Reinstall the motor control PCB by reconnecting the plugs, and reinstalling the 2 screws to fasten the PCB to the HDA main assembly. Service Procedures Page 2.17 rev 10-12-83 Page 0103 of 0580 Source: David T. Craig Downloaded from www.Apple2Online.com Page 0104 of 0580 Source: David T. Craig #### CONTROLLER BOARD UPGRADE PROCEDURE The following equipment may be needed for this procedure: | PART | APPLE PART NUMBER | |-------------------------------|-------------------| | 5.1K ohm Resistor (1) | 101-4512 | | 0.1 microfarad Capacitors (2) | 130-0007 | | 1K ohm Resistor +5% (1) | 101-4102 | | 6.36 X 5/16 Standoff (1) | 860-0213 | | Masked 28 Microprocessor (1) | 341-0171-A | | 330 ohm DIP Packs (2) | 112-0105 | Identify the Rev level etched on both sides of the PCB. Refer to the illustration on the opposite page for the location of the items mentioned in the following discussion. If the Rev is 820-0055 Rev A, B, C, or D then perform the following checks and upgrades. (There are a few controller PCBs in the field that do not have the 820-0055 number etched on the PCB. These PCBs should be replaced with an 820-0055 rev PCB.) - Solder a 5.1K ohm resister (PN 101-4512) between pins 1 and 3 of connector P3 on the controller bd. - Solder a 0.1 uf capacitor (PN 130-0007) between pins 3 and 5 of connector P3 on the controller. - C. Solder a 0.1 uf capacitor (PN 130-0007) between the upper lead of R14 (U40 pin 2) and the bottom lead of C36 (ground). - Check that RIS is present on the PCB. If RIS is missing or one lead is cut then replace it with a 1K ohm 5% resister (PN 101-4102). - Check that the metal standoff between the controller PCB and the power supply assembly is 5/16" in length. If it is not, replace it with a 6-36 X 5/16" standoff (PN 860-0213). - Check that U1 and U2 on the controller PCB are between 330 and 332 ohm DIP packages. If they are any other value, then replace them with 330 ohm DIP packages. (You may wish to verify the resistance of the current DIP packages with an ohm meter.) - Check the 28. If it is the piggyback version then replace it with the latest mask version (no piggyback) (PN 341-0171-A). Service Procedures Page 2.19 rev 10-12-83 Source: David T. Craig Page 0105 of 0580 Page 2.20 rev 9-27-83 Source: David T. Craig Page 0106 of 0580 #### ANALOG BOARD UPGRADE PROCEDURE The following equipment may be needed to perform this procedure: | PART | | ·········· | | | | | <u> </u> | | APPLE P/N | |-------|----------|------------|-----|-----|----|-------|-----------|------|-----------| | 20 mm | section | οf | 26 | to | 30 | gauge | insulated | wire | N/A | | 12mm | section | ο£ | 26 | to | 30 | gauge | insulated | wire | N/A | | 3.9K | ohm Resi | isto | )rs | (2) | ) | | | | 101-4392 | - 1. Identify the rev level of the PCB. The PCB part number is etched at the bottom left on both sides of the PCB. The number will be either 820-0054-A (rev A) or 820-0054-D (rev D). (No rev "B" or rev "C" PCBs were ever made for production) There are a few older analog PCBs in the field that do not have the 820-0054 number and alphabetic (i.e A, or D) identifier etched on the PCB. These should be replaced with rev "A" or "D" PCBs. - 2. Locate device U2 and turn the PCB over. - If the PCB is rev "D", this will be the final step (skip step 4). If the PCB is rev "A" perform both this step and step 4. - A. Solder an insulated wire approximately 3/4 (15mm) long from pin 1 of U2 to pin 10 of U2. - B. Solder a 3.9K ohm resistor (Apple PN 101-4392) between pin 10 of U2 and +5V. This will be designated R118 on updated schematics. - C. Solder a second 3.9K ohm resistor from pin 4 of U2 to +5V. Ths will be designated Rll9 on updated schematics. - Solder an insulated wire approximately 1/2" (9.5mm) long from pin 4 of U2 to pin 13 of U2. # Underside of Analog PCB Location U2 Service Procedures Page 2.21 rev 9-27-83 Source: David T. Craig Page 0107 of 0580 Service Procedures Page 2:22 rev 9-27-83 Source: David T. Craig Page 0108 of 0580 ### HDA SPEED CHECK AND ADJUSTMENT PROCEDURE The following equipment will be needed to perform this procedure: > Frequency Counter and probes Anti-sabotage Sealant (e.g. glyptol) Tweaker (1) for adjusting potentiometers Note: If you need instructions for any removal/replacement, you can find them in the Module Removal/Replacement. Procedures part of this section. ### To CHECK: - (1) Remove the cover from the Profile. - Connect the black lead from the frequency counter to a ground point on the analog PCB. Connect the red lead to TP-1 on the Controller PCB. - (3) Set the frequency counter to read Per. A @ 10 hz. - (4) Turn on the Profile and allow 30 seconds for the HDA motor to get up to speed. The frequency counter should be showing the motor speed to be within 1% of 16667 ms. (16500 to 16832 ms.) If the motor speed is not within this range then perform the adjustment procedure below. If the motor speed is within the proper range reinstall the HDA assembly and cover on the Profile. ## To ADJUST: - Remove the HDA assembly from the Profile. Once removed, reconnect the ribbon cable from the HDA to P2 on the Controller PCB, and power connector P4 from the Power Supply to the HDA. - (2) Locate the trimmer potentiometer positioned near the ground strap on the Analog PCB by P4. - (3) Adjust the trimmer potentiometer until the HDA motor speed is within range (after each turn of the potentiometer allow time for the motor speed to settle). - (4) Once the motor is within the specified limits, lock the adjusting screw on the trimmer pot with antisabotage sealant. - (5) Reinstall the HDA assembly and cover. Service Procedures Page 2.23 rev 10-12-83 Source: David T. Craig Page 0109 of 0580 # INDEX CHECK AND ADJUSTMENT PROCEDURE ing equipment will be needed to perform this # To CHECK: - Remove the Cover; and then the HDA assembly; from the Profile: **{**}} - (2) Remove the Analog PCB from the HDA: - (3) Turn the HDA upside down in front of you. Locate the index mechanism as shown in figure I below: - te the spindle motor until the silver index table spindle motor is aligned with the index {4} - (3) # INDEX MECHANISM (Fig: 1) (This procedure is continued on the next page:) Service Procedures Page 2:24 Fev 18=12=83 Source: David T. Craig Page 0110 of 0580 # INDEX CHECK AND ADJUSTMENT PROCEDURE (continued) #### To ADJUST: - Loosen the two mounting screws so that the index sensor moves freely. - (2) Align the silver index tab and the index sensor. - (3) Place the 30 mil. flat gauge between the index tab and the index sensor. - (4) Push the index sensor forward (towards spindle motor) until it makes light contact with flat gauge. - (5) Tighten the mounting screws. - The flat gauge should be held firmly but should not be so snug that it cannot be easily removed. - (7) Remove the flat gauge and check the operation of the index sensor. - (8) Reinstall the Analog PCB into the HDA assembly, and the HDA assembly into the Profile. Service Procedures Page 2.25 rev 10-12-83 Source: David T. Craig Page 0111 of 0580 III # BRAKE CHECK AND ADJUSTMENT BROCEDURE The following equipment will be needed to perform this procedure: 5/64 Allen (Nex) Griver .010 inch flat gauge Locktite thread sealer There are 2 main revisions of motor control PCBs for the Pro-File HDA. The older rev uses a brake to slow the HDA disk motor after power is removed. It is for this rev of motor contol PCB that this procedure was developed. The newer rev reverse biases the disk motor to slow the disk after power is removed. You can identify which PCB you have by referring to the illustration on page 2.16. Note: If you need instructions for any removal/replacement, you can find them in the Module Removal/Replacement Procedures part of this section: #### TO CHECK! - (1) Remove the Cover and then the HBA assembly from the Profile: - (2) Remove the Analog PCB from the HDA: - (3) Turn the HDA upside down in front of you. Locate the brake mechanism as shown in figure 1: Insert the flat gauge between the Solenoid Body and the Plunger Plate as shown in figure 1: The gauge should fit snugly but slide easily: If the elearance is too tight or too loose, perform the procedure below. If the elearance is OK reinstall the HDA assembly, and then reinstall the Cover. (The adjustment procedure is continued on the next page.) Service Procedures Page 2.26 rev 10=12=83 Source: David T. Craig Page 0112 of 0580 # BRAKE CHECK AND ADJUSTMENT PROCEDURE (continued) #### BRAKE MECHANISM ### (Fig.1) #### To ADJUST: - (1) Remove the mounting screw and coat the end threads with locktite. - (2) Carefully replace the mounting screw; avoid getting any locktite on the sides of the screw hole in the solenoid body. - (3) Run in the mounting screw until snug, then back out 1/4 turn. - (4) Place the flat gauge between solenoid body and plunger plate. - (5) Push the solenoid body forward (toward spindle motor) until the brake pad makes light contact with the braking surface of spindle motor. (Hint: an Allen driver or similar object placed through the screw hole in the side bracket behind the sclenoid body provides a convenient method of positioning the solenoid). (The adjustment procedure is continued on the next page.) Service Procedures Page 2.27 rev 10-12-83 Source: David T. Craig Page 0113 of 0580 # BRAKE CHECK AND ADJUSTMENT PROCEDURE (continued) - (6) Tighten the mounting screw. - (7) The flat gauge should be held firmly by the solenoid but should not be so snug that it can not be removed easily. - (8) Remove flat gauge and check operation of the brake by performing the following steps: - a. Carefully position the HDA on a level surface, with the brake on top. - b. Reconnect P4 (no other HDA connections are necessary) from the HDA to the Power Supply. - c. Plug the Power cord into the Profile and turn it on. Observe: That when the spindle motor begins to spin, the brake solenoid energizes and pulls the brake pad away from the braking surface of the spindle motor. d. Turn the Profile off. Observe: That the brake solenoid deenergizes and the brake pad is released to contact the braking surface of the spindle motor. WARNING: Disconnect Power from the Profile before going any further. - (9) If the brake "chatters", a possible remedy is canting or tilting the solenoid body left or right. - (10) Reinstall the Analog PCB on the HDA assembly, and the HDA assembly in the Profile. Service Procedures Page 2.28 rev 10-12-83 Source: David T. Craig Page 0114 of 0580 FIDELINE 11 Service Procedures Page 2.30 rev 9-27-83 Source: David T. Craig Page 0116 of 0580 # TRACK O CHECK AND ADJUSTMENT PROCEDURE The following equipment will be needed to perform this procedure: Profile Debug 28 .010 inch wire gauge .070 inch wire gauge A/// with internal disk drive .050 inch Allen (hex) driver Note: If you need instructions for any removal/replacement you can find them in the Module Removal Replacement Procedures in this section. #### To CHECK: - (1) Remove the cover from the Profile. - Position the Profile so that the interruptor arm on the HDA is in front of you. - (3) On the Controller PCB remove the system 28 with masked ROM, and install a piggyback Debug Z-8 into its socket. - (4) Turn on the Profile Observe: That after approximately 20 seconds the HDA interrupter arm will move from Park position to track 0 position as shown in figures 1 and 2. (5) Use the .010 inch and the .070 inch wire gauges to insure that the clearance between the top of interrupter arm and optic mounting bracket (See Fig. 3) is between .010 and .070 inches. If it is not then perform the adjustment procedure on the next page. NOTE: If the following adjustment does not work, try adjusting the position of the interrupter arm on its shaft to obtain the proper clearance. (The adjustment procedure is located on the next page.) Service Procedures Page 2.31 rev 10-12-83 Source: David T. Craig # TRACK ON CHECK AND ADJUSTMENT PROCEDURE (continued) #### TO ADDIEST: - ((1)) 4000000 the mounting screws on the optic bracket. - (2)) Shirts the bracket/optic assembly towards the top of HIBA to open the gap between the interrupter arm and the optic mounting bracket. - (3) Shide the 50 mil. wire gauge into the gap, being careful not to disturb interrupter arm: - (4) Stide the bracket assembly down until the top of the bracket and the interrupter arm close lightly on the gauge. - (5) Carefully tighten mounting screws so as not to disturb the adjustment: - (6) Turn off the Profile and replace the Debugger 28 with the System 28: - (7) Turn on the Profile and wait approximately 2 minutes as it performs its Scan seguence: At the and of the Scan seguence the interrupter arm should be returned to the Park position: - (8) Turn off the Profile: - (9) On the Controller PCB remove the System Z=8; and install the piggyback Bebug Z=8 in its socket: - (10) Turn on the Profile and rachack the clearance between the optic bracket and the interrupter arm as described above: Reperform the adjustment until the elearance is ok: - (11) Turn off the Profile and replace the Bebug 28 with the System 28: - (12) Reinstall the Cover on the Profile: Service Procedures Page 2.32 Fev 10-12-83 Source: David T. Craig Page 0118 of 0580 ## HDA FORMATTING PROCEDURE The following equipment will be needed for this procedure Apple /// Profile Interface PCB for the Apple /// Profile Interface Cable Jumper (a 2 inch length of 22 ga. wire with small alligator clips at both ends will do) Debugger Z8 Format software (Profile format diskette #889-0013) - 1. Install the Profile Interface PCB in slot 1 of the Apple /// and connect the Profile Interface Cable from it to the Profile. - 2. Remove the cover from the Profile. If instructions are needed refer to the Module Removal and Replacement Procedures in this section. - 3. Remove the system program 28 from the Controller PCB and insert a Debugger 28. If at all possible do not remove the prom from the piggyback socket as this can cause intermittent failures because of damage to the piggyback socket. - 4. Turn on the Profile and wait 30 seconds for the HDA motor to come up to speed. - Note: When the Profile is turned on, its firmware will flash the Ready LED as the power comes up. After that function is performed the firmware program in the Debugger Z8 will not turn the Ready LED on again until the program in the Apple /// initiates communications with the Profile. - 5. Boot the Format program. Observe: the Ready LED comes on steadily. If it does not, check all connections between the Apple /// and the Profile. Note: the program may prompt you that the Profile has incorrect FD.ROM version 03.11. This is normal the Format program will work OK. Service Procedures Page 2.33 rev 10-12-83 Source: David T. Craig Page 0119 of 0580 - 66. Press (NETURN), then as prompted by the display, install the jumper to short the two pints of \$7 on the Controller PUB together (refer to the illustration of the Controller PROB on page 2.18 to help you frind P7)). - works: the statement "press any key", as now displayed, is imported, it should read "press Return" with the THE ROR THE REST OF THE PORMAN PROCEDURE - 77. Press (RETURN) and watch the interrupter arm on the Hard Disk Assembly (HDA), it should step from track 0 to the park position as shown below in approximately 180 seconds. - Mother: If the arm did not complete the scan swap the HPA to a known good Profile and retry. If Format still does not occur the MDA is probably faulty, replace iit. - 8. After completion of the scan the screen display will tell you if the formatting was successful or not. (if there was an error in formatting the screen will display an error code, recheck all connections on the Pro-File and between the Pro-File and the host computer.) Observe: If the formatting was successful the Ready LED will come on steadily and the screen will display. "Formatting completed. Pass Remove jumper. Press any key to continue" Service Procedures Page 2.34 rev 10=12=83 Source: David T. Craig Page 0120 of 0580 Caution: At this time remove the jumper from P7 to prevent damage to the unit. 9. Press <RETURN> as prompted . The following should occur within the next 2 and 1/2 minutes: Observe: The profile will now automatically: - \* Scan all sectors, heads and tracks - \* Compare buffers on track 77 - \* Certify all sectors on track 77 \* Initialize spare tables on track 77 At the end of each process listed above the screen display should indicate "pass". Note: the last line on the screen display "press <RETURN> when profile is ready" only indicates that if you have more than one profile to format, the diskette does not have to be rebooted each time. Service Procedures Page 2.35 rev 10-12-83 Source: David T. Craig Page 0121 of 0580 ## PFANALS SESEMMTESOT ( PEGT ) PROCEDURE The foolowing equipment will be needed for this sprocedure ADBRE //// FEST SEELWARE (AARN##888208939) A#///PPoffleeIAnsefaceePBBB pPagfile IAnterface Cabble - 11. Install the Profile Interface PEBB in salet11 off the Apple 1. Install-the Prolite Interiace PEBDian sact logithe Apphe //// and connect the Profile Interiace Cabbe from ittoothe PF6file. 2. Engly to that there is a system ROOM 288 installed on the Controller PEBD. 3. Then on the PF6file and west 22 manuages for the Profile to complete its cases requests. - 33. Thirm on the Profile and wast 22 minutes for 100 minutes the complete its seam sequence. 44. BBOOL the FET program. Observe that for 100 minutes the profile will write and verify each track in sequence from track 00 to track 1522 (the Ready Led) will blink as each - operation occurs. The specified period (15 minutes, or 408 hours). If an error line occurs (described below) determine if it is feetal by checking the Max exerces ALLOWED COLLINA FOR the error code on the Criteria Sheet con - the opposite page. 6. To terminate the test press (4800138). - This number of blocks transferred during the test. This number will be continued the continued of contin - TATAL ATTORS that have accurred throughout the test. This number should fine the fish screen. - These parts telets to the 1/0 status duties the promise seroes to the most - . These bytes relate to the particular status code/s that were sant from the another the the host (for test program). - indicates the time elapsed for the ourrent blook transfer. - : The Louical block sent by the host (for test program). - Indicates the Cylinder (frack), wead, and sector being pead from or written too. AN ERROR OCCUPS. THE STATUS LINE FOR THAT ERROR WILL BE PERMANENALLY CAYED AT THE BOTTOM OF THE FOT SOREEN. THE ERROR CODE IS TAKEN FROM A AS DESCRIBED ABOVE. YOU MAY INTERPRET THIS ERROR BY COMPARING RITERIA SHEET ON THE OPPOSITE PASE. A MORE DETAILED ENFLAMATION OF THE SECTOR THE ERROR HAY BE FOUND IN THE "O" FIELD OF THE ERROR LINE. # 805000 Ec 66 66 66 66 66 0000 ffff Service Procedures Page 2.36 rev 10-12-83 Source: David T. Craig Page 0122 of 0580 # PINAL SYSTEM TEST (FST) CRITERIA SHEET | SEEK TO MINOR THORS WITTER MICK SHEW TO USE OF SHEW THE SHEW THE SHEW SHEW SHEW SHEW SHEW SHEW SHEW SH | | | 4 | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------|---------------------------------------|-----------------| | MOTES: 10 MOTE THAN 10 MOTES: 11 MOTES: 12 MOTES: 13 MOTES: 14 MOTES: 15 MOTES: 16 MOTES: 16 MOTES: 17 MOTES: 18 | FINAL SYSTEM TEST (FST) ERROR STATUS CODES | | 10/20/83 | | THAT CAN OCI SEE TO MORE THANK THAN | | | NOTES. | | BUFFER CORP FAILED* IS A SEEK TO MININK THOCK SEEK TO MININK THOCK SEEK TO MININK THOCK SEEK TO MININK THOCK SEEK TO MININK THOCK SEEK TO MININK THOCK MARKER THI 9 MEV9 OF ALL DUE TO SEEK TO MININK THOCK MARKER THI 9 MEV9 OF ALL DUE TO SEEK TO MININK THOCK MARKER THI 9 MEV9 OF ALL DUE TO MININK THOCK MARKER THI 9 MEVS SEEK TO MININK THOCK MARKER THI 9 MEVS SEEK TO MININK THOCK MARKER THI 9 MEVS SEEK TO MININK THOCK THOCK THOCK THE THICK THE THOCK THI 9 MEVS SEEK OF THE THOCK MARKER THICK MARKER THI 9 MEVS SEEK OF THE THICK MARKER THI 9 MEVS SEEK OF THE THICK MARKER THIS THICK THI | WEEK TO WHOSE TIMES | | | | BUFFER CORP FAILED* IS A SEEK TO MININK THOCK SEEK TO MININK THOCK SEEK TO MININK THOCK SEEK TO MININK THOCK SEEK TO MININK THOCK SEEK TO MININK THOCK MARKER THI 9 MEV9 OF ALL DUE TO SEEK TO MININK THOCK MARKER THI 9 MEV9 OF ALL DUE TO SEEK TO MININK THOCK MARKER THI 9 MEV9 OF ALL DUE TO MININK THOCK MARKER THI 9 MEVS SEEK TO MININK THOCK MARKER THI 9 MEVS SEEK TO MININK THOCK MARKER THI 9 MEVS SEEK TO MININK THOCK THOCK THOCK THE THICK THE THOCK THI 9 MEVS SEEK OF THE THOCK MARKER THICK MARKER THI 9 MEVS SEEK OF THE THICK MARKER THI 9 MEVS SEEK OF THE THICK MARKER THIS THICK THI | 1 ·· A · - | 0 | MISHATCH OR | | SEEK TO MOUNT WARK ALLOWED STORE STO | | | *BUFFER COMPA | | DAN'T MAN 3 MICHOLS WITER MINE AN HOUR DE DE SON'T FINE TARGET MEMBER IN 9 MEVS SON DE DE SON'T FINE TARGET MEMBER IN 9 MEVS A RANGE OF SET THAT CAM DE SON DE DE SON'T FINE TARGET MEMBER IN 9 MEVS BETWEETER SPENSYUM FAILER SON DE DE S | B ** # * * * | D | | | ONN'! FINE TYRKET MAKET IN 9 NEVS OF PERRORS ET ING 99 TIDTAL SYNCHIC COCCURED ON '! FIND INGEST MAKED IN 9 NEVS OF CARROST IN MAKET IN MAKET IN MAKET IN 9 NEVS ON '! FIND INGEST MAKET IN MAKET IN 9 NEVS ON '! FIND INGEST MAKET IN MAKET IN 9 NEVS SE 60 00 100 ON'! FIND INGEST MAKET IN MAKET IN 9 NEVS ON O | | <u> </u> | MELUTED | | OU DISTOR THE STATES HARDE SE SEYS OF DISTOR THE STATES HARDE SE SEYS OF DISTOR THE STATES HARDE SE SEYS SE OF SE SE SE SE SE SE SE SE SE SEYS SE S | | | 2. ANY COMBINAT | | NOT ALLOWED A | | • | | | BRACKETS IN A RANGE OF STANDE DISCUSS SECTORS ON 15 FOR TANDET MARKET MARKET DISCUSS SO 60 60 10 ON 15 FOR TANDET MARKET DISCUSS SECTORS ON 15 FOR TANDET MARKET DISCUSS SECTORS SO 60 60 10 ON 15 FOR TANDET MARKET DISCUSS SECTORS ON 15 FOR THE SO 3 SECTORS SECTORS SECTORS SO 60 60 10 ON 15 FOR THE SO 3 SECTORS SECTORS SECTORS SO 60 60 10 ON 15 FOR THE SO 5 SECTORS SECTORS SECTORS SO 60 60 10 ON 15 FOR THE SO 5 SECTORS SECTORS SECTORS SO 60 60 10 ON 15 FOR THE SO 5 SECTORS SEC | 일 및 및 Tare | 2 | NOT ALLOWED | | A RAMGE OF S OWN'T FIND TANGET HEADER IN 9 NEVS ES 00 00 00 OWN'T FIND TANGET HEADER IN 9 NEVS SE 00 00 00 OWN'T FIND TANGET HEADER IN 9 NEVS SE 00 00 00 OWN'T FIND TANGET HEADER IN 9 NEVS SE 00 00 00 OWN'T FIND TANGET HEADER IN 9 NEVS SE 00 00 00 OWN'T HEAD 3 SECTIONS AFTER SEEX SE 00 00 00 OWN'T HEAD 3 SECTIONS AFTER SEEX 2 PREMISESS IS SEED AS OUR OWN'T HEAD 3 SECTIONS AFTER 2 PREMISESS S | | - | X BOACYFTS THE | | SOURCE TO MAKE STANCE MAKES IN 9 MAYS SO 00 00 CAN'T FIND TANCET MAKES IN 9 MAYS SECURISTIES OPERATION FAILES SO 00 00 CON'T MAKE I SECURIS AFTER MESS CON'T MAKE I MAKES IN SECURIS SO 00 00 CON'T MAKE I MAKES IN SECURIS CON'T MAKE I MAKES IN SECURIS CON'T MAKE I MAKES IN SECURIS CON'T MAKE I MAKES IN SECURIS CON'T MAKE I MAKES IN SECURIS CON'T MAKE I MAKES IN SECURIS AFTER MESS IN MAKES IN SECURIS AFTER MESS CON'T MAKE I MAKES IN SECURIS AFTER MESS CON'T MAKE IN MAKES IN SECURIS AFTER MESS CON'T MAKE IN MAKES IN SECURIS AFTER MESS CON'T MAKES IN MAKES IN SECURIS AFTER MESS CON'T MAKES IN MAKES IN SECURIS AFTER MESS CON'T MAKES IN MAKES IN SECURIS AFTER MESS CON'T MAKES IN MAKES IN SECURIS AFTER MESS CON'T MAKES IN | | · | A RANGE OF N | | Service from Target Header In 9 Neve In 9 Neve In Neurette Greating From Target Header Service from Target In 9 Neve In Neurette Greating Greating From Target In 9 Neve In Neurette In 9 Neve In Neurette Greating Greating From Target In 9 Neve In Neurette In 9 Neve In Neurette Greating Greati | A A | Q | THAT CAM OCC | | SOUNT FIND TANKET MEMBER IN 6 NEVS REQUESTED OPERATURE FAILED SO 00 00 TO ONE'T READ 3 SECTIONS AFTER SEEX OD SET MEMB ENDER SO 00 00 TO SET MEMB ENDER SO 00 00 TO MANY MEMB ENDER SO 00 00 TO MANY MEMB 3 SECTIONS AFTER SEEX SOUNT 4 SEEX TO MEMB 5 SECTIONS AFTER SEEX SOUNT MEMB 4 SEEX TO MEMB 5 SECTIONS AFTER SEEX SOUNT MEMB 4 SEEX TO MEMB 5 SECTIONS AFTER SEE | | | | | SOURCE PART THE THESE WENT AND S DESCRIPTION OF FAULTS SO SO SO TO CORPT PERO 3 SECTIONS WITCH PERS SO SO SO TO CORPT PERO 3 SECTIONS WITCH PERS SO SO SO TO SOURCE PROTECTS SO S | 6 | | | | SO SO SO SO CORP'T READ 3 SECTIONS AFTER SEEK DO SO SO SO SO SO SOCIOUS AFTER SEEK SO SO SO SO SO SOCIOUS AFTER SEEK SO SOCIOUS AFTER SEEK SO SO SO SO SOCIOUS SEEK SEEK SEEK SEEK SEEK SEEK SE | - CHI'T FING TARGET HEARTH IN & NEVS | Đ | · · | | ONE TO READ 3 SECTIONS AFTER SEEK DOING HEAD SHOULD SEE MATE 3) SEE MAY BE SHOULD SEE MATE 3) SEE MAY BE SHOULD SEE MATE 3) SEE MAY BE SHOULD SEE MATE 3) SEE MAY BE SHOULD SEE MATE 3) SEE MAY BE SHOULD SEE MATE 3) SEE MAY SHOULD SEE MATE 3 SECTIONS AFTER SEEK SEE MAY SHOULD SECTIONS AFTER SEEK SEET SEE MAY SECTIONS AFTER SEEK SEET SEE MAY SECTIONS AFTER SEEK SEET SEE SEEMS SEET OF SECTIONS AFTER SEEK SEET SEE TO SECTIONS AFTER SEEK SEET SEET TO SECTIONS AFTER SEEK SEET SEET TO SECTIONS AFTER SEEK SEET TO SECTIONS AFTER SEEKS 15 NO SEE TO SECTIONS AFTER SEEKS SEET SEET TO SECTIONS AFTER SEEKS SEED SECTIONS AFTER SEEKS SEET SEET TO SECTIONS AFTER SEEKS SEET SEET SEET SECTIONS AFTER SEEKS SEET SEET SEET SEED SECTIONS AFTER SEEKS SEET SEET SEET SEED SECTIONS AFTER SEEKS SEET SEET SEED SECTIONS AFTER SEEKS SEET SEED SECTION SEET SEED SECTION SEET SEEKS SEET SEET SEET SEED SECTION SEED SEED SEED SEED SEED SEED SEED SEE | REQUESTED OFENATION FAILER | | | | SOUTH THE STREET REPORT DIES DIES D | | | | | SAN THE SECOND STATE STA | | | | | MAND HEAD SHOCK 10 St 40 60 MAND HEAD SHOCK 10 St 40 60 60 MAND HEAD SHOCK 10 ST 40 60 60 MAND SHOCK OR HOUSESTED GRENNTION FAILED MAND SHOCK OR HOUSESTED GRENNTION FAILED 11 30 60 60 60 MAND SHOCK OR HOUSESTED GRENNTION FAILED ONE'! MEAN 3 MECTORS AFTER 2 MERCES 15 00 60 60 ONE'! FIND THEM 3 MECTORS AFTER MEX. ONE'! FIND THEM 3 MECTORS AFTER 2 MERCES 15 17 00 60 60 MAND MECK TO MOUNT THEM 2 MECTORS AFTER MEX. ONE'! MEAN 3 MEXICS FOR 40 40 40 J SYTE MEROWARDS MECTORS AFTER MEXICS ONE'! MEAN 3 SHOCK MEAN SHOW | ON NA DE COLL TO MAY (MEE MOTE 5) | | | | MAN DE MAN CAN DE MILIERED (SEE MITTE 3) MAN DE MAN DE SENICIE MAN DE MAN DE MICHAELE MICHAELE MITTER SEELE MAN DE MAN DE MICHAELE MICHAELE MITTER SEELE MAN DE MAN DE MICHAELE MICHAELE MITTER SEELE MAN DE MAN DE MICHAELE MITTER SEELE MITTER SEELE MAN DE MAN DE MICHAELE MITTER SEELE MITTER SEELE MAN DE MAN DE MICHAELE MITTER SEELE MITTER SEELE MITTER SEELE MIN DE MICHAELE MITTER SEELE MIN DE MITTER SEELE MIN DE MITTER SEELE MIN DE MI | SET E-S FROM | 99 | ļ | | BOOK NOW NEWS SHORE WE GO 40 00 WHITE RATE SHORE OR REQUESTED GPENNYION FAULES IF ON 10 00 00 00 IF ON 1 DEAD 3 SECTIONS AFTER SEEX OF ON 1 DEAD 3 SECTIONS AFTER 2 SERIESS 15 00 00 00 IF ON 1 DEAD 3 SECTIONS AFTER 2 SERIESS 15 07 00 00 AND 1 DEAD 3 SECTIONS AFTER 2 SERIESS 15 07 00 00 AND 1 DEAD 3 SECTIONS AFTER 2 SERIESS 15 07 00 00 AND 1 DEAD 3 SECTIONS AFTER 2 SERIESS 15 07 00 00 AND 1 DEAD 3 SECTIONS AFTER 2 SERIESS 15 07 00 00 AND 1 DEAD 3 SECTIONS AFTER 2 SERIESS 15 07 00 00 AND 1 DEAD 3 SECTIONS AFTER 2 SERIESS 15 07 00 00 AND 1 DEAD 3 SECTIONS AFTER 2 SERIESS 15 07 00 00 AND 1 DEAD 3 SECTIONS AFTER 2 SERIESS 15 07 00 00 AND 1 DEAD 3 SECTIONS AFTER 2 SERIESS 15 07 00 00 AND 1 DEAD 3 SECTIONS AFTER 2 SERIESS 15 07 00 00 15 07 00 00 15 07 00 00 15 07 00 00 15 07 00 00 15 07 00 00 15 07 00 00 15 07 00 00 15 07 00 00 15 07 00 00 15 07 00 00 15 07 00 00 15 07 00 00 15 07 00 00 15 07 00 00 15 07 00 00 15 07 00 00 15 07 00 00 15 07 00 00 15 07 00 00 15 07 00 00 15 07 00 00 15 07 00 00 15 07 00 00 15 07 00 00 15 07 00 00 15 07 00 00 15 07 00 00 15 07 00 00 15 07 00 00 15 07 00 00 15 07 00 00 15 07 00 00 15 07 00 00 15 07 00 00 15 07 00 00 15 07 00 00 15 07 00 00 15 07 00 00 15 07 00 00 15 07 00 00 15 07 00 00 15 07 00 00 15 07 00 00 15 07 00 00 15 07 00 00 15 07 00 00 15 07 00 00 15 07 00 00 15 07 00 00 15 07 00 00 15 07 00 00 15 07 00 00 15 07 00 00 15 07 00 00 15 07 00 00 15 07 00 00 15 07 00 00 15 07 00 00 15 07 00 00 15 07 00 00 15 07 00 00 15 07 00 00 15 07 00 00 15 07 00 00 15 07 00 00 15 07 00 00 15 07 00 00 15 07 00 00 15 07 00 00 15 07 00 00 15 07 00 00 15 07 00 00 15 07 00 00 15 07 00 00 15 07 00 00 15 07 00 00 15 07 00 00 15 07 00 00 15 07 00 00 15 07 00 00 15 07 00 00 15 07 00 00 15 07 00 00 15 07 00 00 15 07 00 00 15 07 00 00 15 07 00 00 15 07 00 00 15 07 00 00 15 07 00 00 15 07 00 00 15 07 00 00 15 07 00 00 15 07 00 00 15 07 00 00 15 07 00 00 15 07 00 00 15 07 00 00 15 07 0 | | · · · · · · · · · · · · · · · · · · · | | | DO SO SO SO WHAT SENDER OR REQUESTED OPERATION FAILED DISTRICT NEAD 3 SECTIONS AFTER SEEX ONE'T NEAD 3 SECTIONS AFTER SEEX ONE'T NEAD 3 SECTIONS AFTER SEEX ONE'T FIND TRACET UP 9 NEWS OR REQUESTED OPERATION FAILED SON'T NEAD 3 SECTIONS AFTER SEEX ONE'T PIND TRACET UP 9 NEWS OR REQUESTED OPERATION FAILED ONE'T NEAD 3 SECTIONS AFTER SEEX ONE'T NEAD 3 SECTIONS AFTER SEEX ONE'T NEAD 3 SECTIONS AFTER SEEX ONE'T NEAD 3 SECTIONS AFTER SEEX ONE'T NEAD 3 SECTIONS AFTER SEEX ONE'T PIND TRACET THE 2 SEETINGS AFTER SEEX ONE'T NEAD 3 SECTIONS AFTER SEEX ONE'T PIND TRACET THE 2 SECTIONS AFTER SEEX ONE'T PIND TRACET THE 3 SECTIONS AFTER SEEX ONE'T PIND TRACET THE 3 SECTIONS AFTER SEEX ONE'T NEAD 3 SECTIONS AFTER SEEX ONE'T PIND TRACET THE 3 SECTIONS AFTER SEEX ONE'T PIND TRACET THE 3 SECTIONS AFTER SEEX ONE'T PIND TRACET THE 3 SECTIONS AFTER SEEX ONE'T PIND TRACET THE 3 SECTIONS AFTER SEEX ONE'T PIND TRACET THE 3 SECTIONS AFTER SEEX ONE'T PIND TRACET THE 3 SECTIONS AFTER SEEX ONE'T SEED AFT | <b>↑</b> | 8 | | | ### CONT NEAD 3 SECTIONS AFTER 2 SECRETS 15 00 00 00 CONT NEAD 3 SECTIONS AFTER 5 SEEX CONT NEAD 3 SECTIONS AFTER 2 SECRETS 15 00 00 00 CONT NEAD 3 SECTIONS AFTER 2 SECRETS 15 00 00 00 CONT NEAD 3 SECTIONS AFTER 2 SECRETS 15 00 00 00 CONT NEAD 3 SECTIONS AFTER 2 SECRETS 15 10 00 00 CONT NEAD 3 SECTIONS AFTER 2 SECRETS 15 17 00 00 CONT NEAD 3 SECTIONS AFTER 2 SECRETS 15 17 00 00 CONT NEAD 3 SECTIONS AFTER 2 SECRETS | | | l | | DE CONTENTION DE LE CON | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | 10 | | | MEAD SENCE OR REQUESTED GRENATION FADLES 13 30 40 100 CONCT READ 3 SECTIONS AFTER SEEX CONCT READ 3 SECTIONS AFTER 2 SERBERS 15 00 100 AC DON'T READ 3 SECTIONS AFTER 2 SERBERS 15 07 100 100 CONCT READ 3 SECTIONS AFTER 2 SERIESS 15 07 100 100 AN ACC CONCT READ 3 SECTIONS AFTER 2 SERIESS 15 07 100 100 AN ACC CONCT READ 3 SECTIONS AFTER 2 SERIESS 15 07 100 100 AN ACC CONCT READ 3 SECTIONS AFTER 2 SERIESS 0 ONL'T FIND TANGET TH 4 NEWS OR REQUESTED DESMITTEM FABLED ONL'T FIND TANGET THE 2 TREATERS 1 SYTE REPOWNITUR RETUGES WITH 2 TREATERS 1 SYTE REPOWNITUR RETUGES WITH SUFFER WAS STATUS TABLES OR SA-3 SET. | | | | | DATE SEPTION OF REQUESTED SPENDING PAILER 12 30 00 00 DIRECT READ 3 SECTIONS AFTER SEEX GRICLINES SECTIONS AFTER 2 SECTIONS SOUTH READ 3 SECTIONS AFTER 2 SECTIONS OWNERS AFTER 2 SECTIONS AFTER 2 SECTIONS OWNERS AFTER 2 SECTIONS AFTER 2 SECTIONS OWNERS AFTER 2 SECTIONS AFTER 2 SECTIONS OWNERS TO MIXING TRACK | 3 a a c | | ŀ | | DOME'T MEAN 3 SECTIONS AFTER SEEK OWN'T MEAN 3 SECTIONS AFTER SEEK OWN'T MEAN 3 SECTIONS AFTER 2 SESSERS SHOULD TRANSFE IN 9 MEAN SECTIONS AFTER SEEK SHOULD TRANSFE IN 9 MEAN SECTIONS AFTER SEEK SHOULD TRANSFE IN SECTIONS AFTER SEEK OWN'T MEAN 3 SECTIONS AFTER SEEK OWN'T MEAN 3 SECTIONS AFTER SEEK OWN'T PEND TRANSFE IN 9 MEAN SE REGISSIONS AND | A CHARLEST OF MILETIN CONTACTOR CAT AT | 10 | | | OWE'T READ 3 SECTIONS AFTER 2 SESSECTS 15 DO NO AD CONST READ 3 SECTIONS AFTER 2 SESSECTS 15 DO NO AD CONST READ 3 SECTIONS AFTER 2 SESSECTS CONST READ 3 SECTIONS AFTER SERVICES SON'T READ 3 SECTIONS AFTER SERVICES 15 TZ DO NO AD AD AD SECTIONS AFTER SERVICES OWE'T READ 3 SECTIONS AFTER SERVICES OWE'T FIND TANGET THACK CONST READ 3 SECTIONS AFTER SERVICES OWE'T FIND TANGET THE 2 SERVICES AP DO NO DO J SYTE REPORTURE RETURNS AFTER Z RESERVES TO DO NOT READ 3 SECTIONS AFTER Z RESERVES OF DO NO DO J SYTE REPORTURE RETURNS RETURN BUTTE BUFFER AND STATUS TABLES OR S2-3 SET. | | | | | GMITT MEAD 3 METIONS AFTER 2 SEMENTS 15 NO NO AD CHIEFT MEAD 3 SECTIONS AFTER 3 SEEDEST CHIEFT MEAD 3 SECTIONS AFTER 3 MESTERS CHIEFT MEAD 3 SECTIONS AFTER 2 MESTERS 15 NZ NO ND ADAM SECTION AFTER 2 MESTERS CONCT MEAD 3 SECTIONS AFTER 2 MESTERS CONCT MEAD 3 SECTIONS AFTER 2 MESTERS CONCT MEAD 3 SECTIONS AFTER 2 MESTERS OPEN 1 MEAD 3 SECTIONS AFTER 2 MESTERS FOR NO NO NO J SYTE NETWORN THE STREET NO STATUS TABLES OR S2-3 SET. | <b>E ↑ </b> | a | | | 15 to 40 40 | | | | | BOY'T FIND TORGET IN 9 NEWS OR REQUESTED OPERATION FAGLED 15 TZ 80 III AN A A III CON'T MEAN 3 SECTIONS AFTER 2 MESSESS ON'T MEAN 3 SECTIONS AFTER MESS ON'T FIND TAKES THE SETS OR REQUESTED OPERATION FAGLED CON'T FIND 3 SECTIONS AFTER 2 MESSESS AP 40 00 00 00 J SYTE REPORTURE METALES MUSTE MUFFER WAS STATUS TABLES OR S2-3 SET. | | | | | SHIPT FAMO THREET OF 9 METS OF REQUESTED OPERATION FACLES ONLY SEAL S SECTIONS AFTER 2 MEXICOS 3.5 EZ BO BD AN 44 SEEK TO HEAD S SECTIONS AFTER METS CONLY SEAD 3 SECTIONS AFTER METS ONLY SEAD 3 SECTIONS AFTER METS ONLY SEAD 3 SECTIONS AFTER METS ONLY SEAD 3 SECTIONS AFTER 2 MEMBERS AP 40 BO BO SO BOTTOM SECTION AFTER 2 MEMBERS AP 40 BO BO SO BOTTOM SECTION AFTER 2 MEMBERS D J SYTE MEMBERS WILLIAM BETWEEN WILLIAM STATUS TABLES OR SA-3 SET. | | 0 | | | 15 EZ 80 BD A MA SEX TO MICHIG TRACK CONCT BEAR 3 SECTIONS AFTER SIZEK CONCT BEAR 3 SECTIONS AFTER SIZEK CONCT FROM 3 SECTIONS AFTER 2 BENEFITS GAN'T FROM 3 SECTIONS AFTER 2 BENEFITS SP 60 80 80 80 J SYTE REPORTUR BETWEEN BUFFER WAS STATUS TABLES OR S2-3 SET. | | | | | O CONCT MEAN 3 SECTIONS AFTER SHEEK ONLY FIND TANGET THE 9 REPORTED DEBATTION FAMILED CAN'T MEAN 3 MESTICAS AFTER 2 MESTICAS AFTER 2 MESTICAS AFTER 2 MESTICAS 19 00 00 00 J SYTE REPORTED MESTICES MUSTE MUFFER WAS STATUS TABLES OR 52-3 SET. | 15 17 00 ED | | | | ONE'S FIND SMORT IN 4 NEVS OR RECHESTED DEBUTION FAILED ONE'S FIND 3 MINISTERS IN REMISSES OF OR ON ON J SYTE REPORTUR RETURES MINISTER BUFFER WAS STATUS TABLES OR 52-3 SET. | | , | | | SP 60 60 60 J SYTE REPUBLITUR BETWEEN WILLTE BUFFER WAS STATUS TABLES OR 52-3 SET. | OMI'S FIND SANCES IN 4 NEVS OR REQUESTED OPERATION FAILED | | | | 3 STILE SEPTIMENT SETTE SUPPLY AND SIGNAL INSULA OK 25-3 SET. | | | | | | S BYTE REPROSTUR METWEEN WITTE BUFFER WAS STATUS TABLES OR 52-3 SET. | · D | | | The same of the same and the same of s | SPARE TABLE MPOATE COOKINED, INFFER MATA 25 CHANGED. | | | - TION KCEED L IS - IDICATE NUMBER: Service Procedures Page 2.37 rev 9-27-83 Source: David T. Craig Page 0123 of 0580 # OUICK PERIOGER TEST PROCEDURE The following equipment will be needed for this procedure Apple /// Prefile interfere PCB for the Apple /// Prefile interfere Cable Ovick Pebygger Software Version Fob. 97 (APN# 889-9004) Silentage Printer The Quick Penager program reads the spares table from the pro-file and prints the Wiginal sector location of every spared sector histed in that table. - 4. Install the Profile Interface PCB in slot 1 of the Apple //// and connect the Profile Interface Cable from it to the Profile. - 2. Ensure that there is a 28 with standard system ROM installed on the controller PCB. - 3. Turn on the Profile and wait 2 minutes for the Pro-File to complete its scan sequence. - 4. Connect the Sitentype to Port A on the back of the Apple - 5. Book the Quick Debugger program: Observe: The Quick Debugger command prompt line is displayed as shown below: €⊗₩₩₳₩Ð(₿¸₣¸₽¸₿¸℞¸Ѕ¸Ŧ¸Ѷ¸₩¸३⟩≣३ 6. Type (5) to select the Get Status command: Observe: a. The line shown below is displayed next to the command prompt line: STATUS-CET STATUS BLOCK 80 80 80 80 88 88 99 - b. The Ready LEB goes out as the interrupter arm on the HBA goes to track 77 to read the spares table: - e: A new command prompt line is displayed: (continued on the next page) Service Procedures Source: David T. Craig Page 0124 of 0580 7. Type <P> to select the Print Status command. Observe: The line shown below is displayed on the CRT. PRINT STATUS TO SCREEN OR PRINTER (S/P) 8. Type <P> to select the printer. Observe: The Silentype prints out as shown below. CONTROLLER VERSION - 03.98 SPARED SECTOR TOTAL 00 LIST CYL HD SECT BAD BLOCKS TOTAL 00 LIST : CYL HO SECT (End of this procedure.) Service Procedures Page 2.39 rev 10-12-83 Page 0125 of 0580 Source: David T. Craig # DSKDBG - BLOCK DEVICE DEBUGGER VERSION E00.17 # TABLE OF CONTENTS | PA | RT | | PAGE | |----|----------------|----------------------------------------------------|---------| | 1. | Intr | oduction | 2.4 | | | 1.1 | How to Use This Program | 2.4 | | | 1.2 | Typical Command Examples | 2.4 | | 2. | Comm | mand Structure | 2.4 | | | ,2.1 | Command Prompt | 2.4 | | | 2.2 | Detailed Command Descriptions | 2.4 | | | | 2.2.1 Buffer Fill | 2.4 | | | | 2.2.2 Create Spare | 2.4 | | | | 2.2.3 Display | 2.4 | | | | 2.2.4 Format | 2.4 | | | | 2.2.5 Get Status | 2.5 | | | | 2.2.6 Initialize Spare Table | 2.5 | | 3. | Comm | mand Summary | 2.5 | | 4. | New | Features | 2.5 | | 5. | Typi | ical Problems and How To Avoid Them | 2.5 | | 6. | Know | on BUGS in VERSIONS E00.17 AND E00.16 | 2.5 | | 7. | Stat | cus Byte Descriptions | 2.5 | | | 7.1 | Status Bytes with System ROM 28 Installed | 1 2.5 | | | 7.2 | Status Bytes with Formatter/Debugger ROM Installed | | | g. | <b>*</b> 04.64 | Procedures Page 2.40 ve | 0_27_02 | Source: David T. Craig Page 0126 of 0580 #### PART 1 INTRODUCTION The Formatter/Debugger program is provided as a service aid for troubleshooting block I/O devices such as the ProFile disk drive. It is a program that allows you to directly communicate with a block I/O device and exercise it through a series of unique commands or build simple test sequences that will assist in debugging the device. It is a particularly helpful tool for servicing devices that have been returned because of a malfunction, etc. For example, the program can be used to detect an error and then by using the loop on error function, you can use an oscilloscope to analyse the circuit that caused the error. You can use the program to service a drive containing either the Format/Debugger ROM Z8 or the Standard System ROM Z8. (The Standard System ROM Z8 is the operational ROM in the Z8 that is shipped in the disk drive.) The command summary, part 3, specifies which type of ROM must be in the drive to use a given command. ### PART 1.1 HOW TO USE THIS PROGRAM To use this debugger properly, you should be aware of some of the design concepts. In designing the user interface (command structure) it was decided to use single character commands (explained later). This permits you to type in the command very rapidly and use options (which are not always required) to modify certain test variables. The most used test variables are the three byte logical block that is treated as either a 24-bit number or as three 8-bit numbers. As a 24-bit number, the variable represents a standard logical block with a decimal range of 0-16 million blocks (Hex 000000- FFFFFF). As three 8-bit numbers, each variable has a range of 0-255 (Hex 00-FF). The program makes no assumptions about the use of the test variable; it just gives you two ways to talk to it. You can consider it as a large (24 bit) number or as three smaller (8 bit) numbers. This variable is sent to the disk exactly as a 24-bit number which the firmware decides how to interpret. You, the user, must know how the firmware will react to understand what the firmware is doing with the block number. Service Procedures Page 2.41 rev 9-27-83 Source: David T. Craig Page 0127 of 0580 # PARATI 12- 2TYPRIGIAICOOMMONIE XEMMERSES NOTE: DARISHMENT IN IN IN IN IN INCIDENT STREET STR To help la make the conner to bithis sprengammant eclesi, has ease escare escar <KF> (KB&&#) THis communed requests add tate to observe define the unit to be readed from the unit to be requests the communed and the BBOOK veriable to the unit taked the communed the unit to other in the unit to other in the communed to be readed RRbyYitssetfddessnoetchangethheBBDOKKvariabbee; ittussesites carffattvxitue. HBowever, ypoucaanchangethhebbookkvariabbee byy addfiggaammedifeertoothbecommandiinthheformoffaannmeser. This number is normally treated such that leading zeeps are assimed, thus 0,000,000, etc. all produce the 24-bit value 000000. For example: The above example is applicable conly when using the Stendard System ROM 208. Notice that the HIDDE variable sent is either 000000 or 0000013. The multiper 133 is the same as 01133 on 00000133 and produces the value 00000133 in the BLOOK variable. NOTE: The number 13 in the example is a HAX number, not a decimal number. 113 Heex = 119 Descrimal Remember that the firmware in the disk drive being tested determines how the block variable will be treated. Normally it is treated as a logical block. In the example on the following page, let's change the command to show how it would be used with the Format/Debugger ROM 28: Service Procedures Page 2.42 rev 9=27=83 Source: David T. Craig Page 0128 of 0580 For example: <RT1H2S3> or <RT01H02S03>, etc. (read block 010203) Notice that the command now has 3 modifiers in the form of T and a number, H and a number, and S and a number. The modifier T (Track) references the first 8-bits of the BLOCK variable, the H (Head) references the second 8-bits, and the S (Sector) references the third 8-bits. Note that they are separate modifiers and can be used independently. For example: If BLOCK = 000000, then the command <RT5><RETURN> will set BLOCK = 050000 If BLOCK = 050000, then the command <RH3><RETURN> will set BLOCK = 050300 If BLOCK = 050300, then the command <RT16S9><RETURN> will set BLOCK = 160309 Note that the last command in the example happened to affect the first and third bytes. Had the last command been RS9 then the BLOCK would have been 050309. When all three modifiers are used, they must be in the T, H, S sequence. REMEMBER! The numbers used are always Hexidecimal numbers. **<W>** (write) This command requests data to to be written to the unit being tested. It passes the command and the BLOCK variable to the unit and transfers the data to the unit from the output buffer (see the buffer fill command, part 2.2.1, and the display command, part 2.2.3). W by itself does not change the BLOCK variable; it uses its current value. However, as was the case with a read command, the BLOCK variable can be changed by adding a modifier. Service Procedures Page 2.43 rev 9-27-83 Source: David T. Craig Page 0129 of 0580 For example, the commands WO, WITHIELD, WHED, etc. have the same effect on the BIOCK wariable that they did in the Read command. <+> ((plus)) This command increments the BLOCK wariable. + by introduction increments the variable by 1. For example, iff the BLOCK variable was 00001f, then after + iit will be 000020 (Note the bex numbers). +3 will increment the BLOCK by 3 each time. +3T will increment the first 8-bit wariable by 3 each time. For example, if the BLOCK was 050311, then +3T will change ift to 080311. H and 5 work the same way to modify the second and third groups of 8-bit wariables. To provide wrapsround and carry, the + commend will wrap a 24-bit number at FFFFFF. It will wrap T at 97 ((97 increments to 0) and will set H an S to 0 to provide full wrap. H will wrap at 3 (3 goes to 0) creating a carry to T and S will wrap at F (F goes to 0) creating a carry to H. Future enhancements will be to find out what the maximum block count for a device is and then wrap the 24-bit number at that count. <D> (Display) This command displays the comtemts of the imput or output buffers. D by itself will display the input buffer. DI is the same as D. DO will display the output buffer. DS will decode the contents of the input buffer as extended status information. The form of the display is the same as that for an APPLE monitor memory dump. It will display the first 256 bytes of the buffer and pause so that you can study the values. At the bottom of the screen it asks for < ESCAPE> to terminate, < RETURN> to quit, ANY other key to continue. <ESCAPE> stops further display and cancels the rest of the command line effectively stopping processing and returning control to the user. <RETURN> quits the display command and causes the program to go on to the next command. Service Procedures Page 2.44 rev 9-27-83 Source: David T. Craig Page 0130 of 0580 Pressing any of the other keys, except the space bar, will allow the program to display the next 256 bytes of the buffer. Pressing the space bar will allow you to display the buffer line by line. CAUTION: If you just keep hitting a key to see the next 256 bytes you will see first the buffer you requested and then memory above it. There are areas of ram above the buffers that will, when displayed cause your screen to get VERY sick and you will have to either re-boot the program or be very familiar with APPLE III hardware and monitor. Just in case you are not familiar with the monitor memory display, here is an example. (The monitor doesn't display the descriptive information above the dashed line.) | Hex<br>Address | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | A | В | c | D | E | F | |------------------------|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---| | 8000:<br>8010:<br>etc. | | | | | | | | | | | | | | | | | Service Procedures Page 2.45 rev 9-27-83 Source: David T. Craig Page 0131 of 0580 # PRART 22. COMMAND STRUGTURE E<sup>2</sup>371 COMMINIO CONSISTS STS OF ONE OF MORE CHARACTERS and modificers ihn command offours. Each aroup is separated by one or more spaces. The command like is one or more command proxipe. There is enough space in the command buffer for 255 characters. Multiple command lines are possible by use of the Macro Add # BART 2-1 COMMAND BROWS The program prompt consists of the following two lines: SIBI COMMAND (B,C,B,F,G,H,F,IL,M,N,D,P,Q,R,S,F,N,M,X,F+,--,//,, ?)) => The first line contains two flags, sl pl, that tell which slot and drive the program is set to test. The second line of the prompt consists of the first letter of each valid command. A list of the commands is always available by typing if or ? and pressing < Refund. NOTE: After typing a command and pressing (Return) to execute it; you can press (ESCAPE) to terminate the command. However, if you wish to review the command that you just executed for the purpose of changing it, etc., you can simultaneously type (CONTROL) (A) instead of (ESCAPE). Service Precedures Page 2:46 Fev 9=27=83 Source: David T. Craig Page 0132 of 0580 # PART 2.2 DETAILED COMMAND DESCRIPTIONS Following are descriptions of some of the commands that require more detailed explanations than others. In depth examples of some of the more commonly used commands such as Read, Write, Increment, and Display were provided in part 1.2. For an overall summary of all commands, refer to part 3. #### PART 2.2.1 BUFFER FILL <B>[num] <RETURN> - where num is an optional 16 bit hex number (eg.,B0123) The buffer fill command is used to fill the output buffer with a specific data pattern. It can be used with either the Format/Debugger ROM Z8 or the Standard System ROM Z8 installed in the drive. To use the command, type B followed by a number which will be treated as a 16 bit (2 byte) pattern. For example, the command $\langle R0 \rangle \langle sp \rangle \langle B1234 \rangle \langle sp \rangle \langle W0 \rangle \langle sp \rangle \langle B45 \langle sp \rangle \langle W1 \rangle \langle RETURN \rangle$ would read logical block-0, fill the output buffer with 12341234..., write block-0, fill the output buffer with 00450045..., and finally write this data to block-1. # PART 2.2.2 CREATE SPARE <C><RETURN> ---- the C-command must be the only command on the line. The create spare command is used to force a peripheral device to transfer a logical block to a new (spare) physical location on the device. The command will then request the block number to be spared and will then request confirmation from the user. If confirmed, the logical block will be spared by the device controller. This command should only be used when the Standard System ROM 28 is installed in the drive. Using this command will allow you to fix flaky blocks found during testing. The user will be asked for confirmation of this command. Respond with Y (Yes) or N (no). NOTE: Do not attempt to use the create spare command when the Format/Debugger ROM 28, version D3.11 or earlier, is installed in your drive. Service Procedures Page 2.47 rev 9-27-83 Source: David T. Craig Page 0133 of 0580 ### PART 2.2.3 DISPLAY <D>[I,0,8] <RETURN> - where I is input buffer, O is output buffer, and S is the extended status information in the input buffer. The display command can be used with either the Format/Debugger ROM 28 or the Standard System ROM 28 installed in the drive. It is used to display the contents of the input or output buffers. These buffers occupy the following Hex locations in the computer's memory: input buffer ----8000H - 8213H output buffer ---8300H - 8523H The display will show 256 bytes at a time, scrolling to the next 'page' after each key press. To end the display and continue executing the command line, press <RETURN>. To abort the command line press (ESCAPE). With the display on the screen, you can press the spacebar to cause a scroll to the first line of the next 'page'. Then, each time you press the space bar, the display will scroll one line forward. The Display Status command works only slightly differently in that it decodes the input buffer into Extended status info about the spares and bad blocks and it will not stop until it is finished or until the space bar, <RETURN> key, or the <ESCAPE> key are pressed. REMEMBER! The Display Status command will decode anything found in the input buffer so be sure to use the Get Status command first to make sure that the information is valid. Before using the Display Status command with the Format/Debugger ROM 28 installed, you must initialize the spare tables (see part 2.2.6) and then use the Get Status command, otherwise the display will contain garbage. With the Standard System ROM 28 installed, you only have to issue the Get Status command before displaying the extended status of the input buffer. Service Procedures Page 2.48 rev 9-27-83 Source: David T. Craig Here are some additional tips about using the Display Status command. - After typing D[S] and pressing <RETURN>, press the space bar to stop the listing. Press the space bar again each time you wish to step through another line of the listing. Pressing any other key will cause a fast scan of the listing. - Pressing <ESCAPE> will cancel the rest of the display function. - Pressing <RETURN> will terminate the spare sector listing and start the bad block listing. # PART 2.2.4 FORMAT $\langle F \rangle \langle RETURN \rangle$ ---- this command must be the only command in the command line. The Format command is used with the Format/Debugger ROM Z8 installed in the drive. It is used to erase all old data from memory and lay down a new pattern of address and data. After formatting a drive with the Format/Debugger ROM 28 installed, you can type D[I] to get a list of the defective blocks. The list will end with FF FF FF. Refer to the documentation provided for the F/D ROM for further details. WARNING: This command is very dangerous and should only be used if damage to the address headers has occurred and only after every reasonable attempt has been made to recover other data from the device. The user will be asked to confirm this command. Respond with <Y> (Yes) or <N> (No). Remember! This command will erase all previously recorded data. Following is an example of the error message that will be displayed if you attempt to format a drive with a Standard System ROM Z8 installed. I/O ProFile Block R1 R2 R3 R4 S1 S2 S3 S4 S5 S6 FORMAT S1 D1 00 03 5F 00 00 00 00 55 55 55 55 00 00 The 55's in this example are the error indicators. Service Procedures Page 2.49 rev 9-27-83 Source: David T. Craig Page 0135 of 0580 # PART 3-3-5 GET STATUS #### **(6)**(**927**(**9)**) The Get Status command works only with the Standard System Rom 78: It is used to obtain extended status information from the drive and place it in the input buffer: (You will need to execute the Display command to view the contents.) The Get Status command makes sure that the status you are going to view is valid: When using a Profile you can also get the status by reading block ffffff. # PART 3.3.6 INITIALIZE SPARE TABLE <!><RETURN> ==== this command must be the first command in the command line: The Initialize command is used by the Brofile Format/Debugger ROM 28 to setup the spare tables in the Brofile drive: After the Debugger ROM has formatted the disk; the entire disk is available to read from or write on so that certification of the entire disk is possible: After the spare table sectors have been certified; the tables need to be initialized to allow the controller ROM to work properly: The Initialize command is not used when the Standard System ROM 28 is installed in the drive: WARNING: This command is potentially dangerous as it effectively erases any old spared table data and if used incorrectly will cause the loss of valuable data on the profile: The user will be asked to confirm this command: In response; type $\{Y\}$ (Yes) or $\{N\}$ (NO): Service Procedures Page 2:58 Fe∀ 9=<del>2</del>7=83 Source: David T. Craig Page 0136 of 0580 ### PART 3 COMMAND SUMMARY Following is a summary of all the commands that can be used with this program: #### BUFFER FILL B[<RETURN>] or B[num]<RETURN> Fill the output buffer. where num is a 16 bit hex fill number used with both Formatter/Debugger and Standard System ROM Z8s #### CREATE SPARE C<RETURN> Force the drive to spare the specified block. must be the only command on the command line used only with Standard System ROM 28 #### DISPLAY <D><RETURN> or <D>[I]<RETURN> or <D>[O] <RETURN> or <D>[S] <RETURN> Display the I/O buffers. used with both Formatter/Debugger and Standard System ROM 28s #### FORMAT <F><RETURN> Format the device. This is a dangerous command used only with Format/Debugger ROM 28 #### GET STATUS <G><RETURN> Get extended status information. Remember! When using the ProFile, RFFFFFF (read block FFFFFF) also returns status information used only with the Standard System ROM Z8 Service Procedures Page 2.51 rev 9-27-83 Source: David T. Craig Page 0137 of 0580 HELB where E2 is to display errors when the Standard where E2 is to display errors when the Standard where E2 is to display errors when the Standard where E2 is to display errors when the Standard where E2 is to display errors when the Standard where E2 is to display errors when the where E2 is to display errors when the where E2 is to display errors when the where charts to design the command shown in this command shown in this summary. #### INITIALIZE SPARE TABLE **{I}**\$**{RETURN**} Clear the spare block to the clear the spare angerous this spare angerous this spare to the clear this spare to the clear this spare and a present the clear <EBF>{S:H:B}<RETURN> £88\$8N Loop on Format commands to the firmware. Where s = sector marks Where s = address headers D = data field LPF can be followed by any combination of <M>[A{8=3}:E:E:8=3] < RETURN> MACR8 Use macro functions (alternate command lines): where A = add activity macro table where A = add activity macros used with either acrosmatter/Debugger or used with either ystem acrosmatter/Debugger or not effectively implemented at this time Service Procedures Page 2:52 rev 9-27-83 rev 9-27-83 Source: David T. Craig Page 0138 of 0580 ``` 138 N,O Not implemented yet PAUSE <P>[<RETURN>] or <P>[A(num),C,(num),E(num),N(num)]<RETURN> Pause and wait for user. Where A = any error/nonerror C = clear any error/nonerror E = on error N = on no error (num) is a 16-bit mask of S1 S2 Note: All four digits of the 16-bit mask must be turned on used with either Formatter/Debugger or Standard System ROM 28 QUIT <Q>[<RETURN>] Return to calling routine (This module is a subroutine). READ <R> [(num),T(num),H(num),S(num)]<RETURN> Read a block where (num) = 24 bit number (8 bit if T,H,S) T = first (Hi) byte of block H = second (Mid) byte of block S = third (Lo) byte of block Remember! The firmware of the device tested determines how the number is treated. See the following example: S - Formatter/ Debugger ROM ProFile 00 00 00 Hi Mid Lo - Standard System ROM 28 >O means read to the output buffer ( Eg., R23>O ) used with either Formatter/Debugger or Standard System ROM 28 ``` Service Procedures Page 2.53 rev 9-27-83 Source: David T. Craig Page 0139 of 0580 #### SCAN **KSYKRETURNY** Order the firmware to scan the entire disk (read only). Requires confirmation (Y or N) after scanning, use D[I] to get list of any bad blocks found during scan used only with Format/Debugger ROM 28 #### TURN OFF STEPPER Turn off the power to the stepper motor. Used with format/bebugger ROM 28 but not normally used with Standard System ROM 28 Not implemented yet WHITE ⟨₩⟩ [(num), T(num), H(num), S(num)] ⟨RETURN⟩ Write to a block (same format as read): where (num) = 24 bit number (8 bit if T,H,S) T = first (Hi) byte of block H = second (Mid) byte of block S = third (Lo) byte of block The firmware of the device tested determines now the number is treated: See the following example: Remember! T H S = Formatter/ Bebugger ROM Profile 00 00 00 Hi Mid Lo = Standard System ROM E8 $\xi I$ means write from the input buffer ( eg., W23 $\xi I$ ) used with either Formatter/Debugger or Standard System ROM 28 Service Precedures Page 2:54 FeV 9=27=83 Source: David T. Craig Page 0140 of 0580 ``` 140 XECUTE <X><RETURN> or X[E(num)]<RETURN> Execute the current command line again. where E = execute the line to this point on error num = 16 bit error mask of S1 S2 X[E] will execute a function over and over again, if an error has occurred, up to the point where the error occurred <+>[(num),T(num),H(num),S(num)]<RETURN> Increment the block number. where (num) = 24 bit number (8 bit if T,H,S) T = first (Hi) byte of block H = second (Mid) byte of block S = third (Lo) byte of block <-> [(num), T(num), H(num), S(num)] < RETURN> Decrement the block number. where (num) = 24 bit number (8 bit if T,H,S) T = first (Hi) byte of block H = second (Mid) byte of block S = third (Lo) byte of block the - command does not decrement properly for H and S modifiers </>[S(num),T]<RETURN> Choose options (/H for help). where S = slot set T = translate current block to cylinder/head/sector Help. ``` Service Procedures Page 2.55 rev 9-27-83 Source: David T. Craig Page 0141 of 0580 ## PART 4 NEW FEATURES The following new features have been developed since the release of DSKDBG V-E00.16 and are included in DSKDBG V-£00.17. - \* The Help effors command has been slightly modified. OF <#E1> provides help for the Standard System ROM 28 and (HE2) returns help for the format/Debugger ROM 28. - \* The Help command lists the form of the extended help commands. - \* Display now has a sommand to allow the decoding of the status table into the version, spare list, and bad block DS = display status info. - \* Use (BSCAPE) of (RETURN) to terminate a long list of spares of bad blocks. - \* An additional modifier is available for read/write commands that allows you to specify which buffer you are reading to or writing from. For example, a read command followed by >0 means read to the output buffer. A write command followed by (I means write from the input buffer. ### PART 5 TYPICAL PROBLEMS AND HOW TO AVOID THEM. \* The + (Instement) command doesn't work. This is to date the most common problem. Usually the command line will look something like RO PE + X What you were trying to do is sequentially read thru the disk starting at block 0. What you said was Read block 0 (block = 0), Pause on error, Increment block (block = 1), Repeat line, Read block 0 (block again = 0) ...... To fix this problem just do one line to set block 0 and then go on to the next line to do the Read, Pause on effef ete: Service Precedures Page 2.56 rev 9-27-83 Source: David T. Craig Page 0142 of 0580 For example: <R0><RETURN> <R><sp><PE><+><X><RETURN> \* Display Status Won'T Work Or Won't Stop The display status command allows you to display the input buffer and make assumptions about what the data means. For it to work, the Get status command must successfully read the status informtion from the drive. If the input buffer has garbage in it, the Display Status command may go round and round trying to display all the spared sectors and bad blocks. To stop the command when it is caught in a loop or is listing a bunch of bad blocks, simply press the $\langle {\tt RETURN} \rangle$ key or the <ESCAPE> key. The functions of the other keys are the same as for all other display commands. # PART 6 KNOWN BUGS IN VERSIONS E00.17 AND E00.16 The Macro command has 3 known bugs. The first occurs when a macro is added to the list and there is already one there of that number. The effect is to make both of them disappear. The secondbug occurs when the macro is invoked on a line with the X command (eg., Ml X). This disables the <ESCAPE> key so the program can only be halted by re-booting. The third bug also involves the X command. When a macro is added (eg., R MAl X), it will keep asking to delete the old macro. The - command doesn't decrement properly for H and S modifiers Service Procedures Page 2.57 rev 9-27-83 Source: David T. Craig #### PART 77 STRATUS HATE DESKURDEDONS This part provides a hitt-by-bit description of the four stratus bytes availlabile wiith the Standard System ROM 28 or the Frommett/Dethummer ROOM ZES. # 17.11 SEPATUS HATTHE WITH STANDARD ROW W-3.98 INSTALLIBID #### SECRECIUS 11 - 77 = 11 iiff Prooffile diid mott recoeiwe 555 too iits last response - 6 = 11 iiff writtee our writtee/werriffly wass abboutted because >>55322 bbyytteess - iiff dhattan weense smerntt. - iif Profile couldin't read iits spare table - 5 = 1 iif knoest"s dheta iis mo langer iin bakk because Profile updated iits spare table - 4 = 1 iif SHEK ERROR umathle iin 3 turies to read 3 consecutiive headers on a track - 3 = 1 if CRC error (comby seet during actual read or verify of write/werlify, mot while trying to read headers affter sæking) - 2 = 1 if TOMEOUT EXPROR (couldn't find beader in 9 revolutions - not set while trying to read beaders after seeking) - 1 = 0/2 - 0 = 1 if operation wasuccessful (continued on the next page.) Service Procedures Page 2.58 rev 9-27-83 Page 0144 of 0580 Source: David T. Craig #### STATUS 2 - 7 = 1 if SEEK ERROR unable in 1 try to read 3 consecutive headers on a track - 6 = 1 if spared sector table overflow ( > 32 sectors spared) - 5 = N/A - 4 = 1 if bad block table overflow ( > 100 bad blocks in table) - 3 = 1 if ProFile unable to read its status sector - 2 = 1 if sparing occurred - 1 = 1 if seek to wrong track occurred - 0 = N/A #### STATUS 3 - 7 = 1 if ProFile has been reset - 6 = 1 if block number invalid - \* 5 = 1 if block I.D. at end of sector mismatch - 4 = N/A - 3 = N/A - \* 2 = 1 if ProFile was reset - \* 1 = 1 if ProFile gave a bad response - \* 0 = 1 if parity error - \* These bits are set by the SOS ProFile driver and are not used by the Dskdbg ProFile.IO. # STATUS 4 7 - 0 = the number of errors encountered when rereading a block after any read error Service Procedures Page 2.59 rev 9-27-83 Source: David T. Craig Page 0145 of 0580 # PART 7:2 STATUS BYTES WITH FORMATTER/DEBUSSER ROM FD3:98 REV 11 THETALLER # STATUS 1 - 7 = 1 if Profile did not receive 55 to its last response - 6 = 1 if no index found during formatting - 5 = 1 if no sector mark found during formatting - 4 = 1 if SEEK ERROR = unable to read 3 consecutive headers on a track (one try only) - 3 = 1 if CRC effor (only set during actual read or verify of write/verify, not while trying to read headers after seeking - 2 = 1 if TIMEOUT ERROR (couldn't find header in 9 revolutions = not set while trying to read headers after seeking) - 1 = N/A - 0 = 1 compare error on a write compare # STATUS 2 - 7 = 1 if Profile has been reset - 6 = 1 if track number invalid while reading or writing a sector - 5 **≡** N/A - 4 = N/A - 3 ≡ N/A - 2 = N/A - 1 = 1 if seek to wrong track occurred - 0 = N/A (continued on the next page) Service Procedures Page 2:60 ¥e¥ 9=27=83 Source: David T. Craig Page 0146 of 0580 # STATUS 3 D7, D6, and D5, along with D4 and D3 from STATUS 1, tell why a write compare operation failed. | -4 | D7 | D6 | D5 | |---------------|----|----|-----| | write timeout | 0 | 0 | 0 | | read timeout | 1 | 0 | 0 | | read CRC | 1 | 1 | . 0 | | data compare | 1 | 1 | 1 | # STATUS 4 7 - 0 = the number of errors encountered when formatting data fields or scanning the disk. Service Procedures Page 2.61 rev 9-27-83 Source: David T. Craig Page 0147 of 0580 | 148 | SECTION 3 TABLE OF CONTENTS | | |-----------------------------------------------------|-----------------------------|------------| | How to Use Thi | is Section 3. | . 2 | | Overview of th | ne Pro-File | | | General Inform | mation 3. | . 3 | | <ol> <li>Analog PCB</li> <li>Switcher Po</li> </ol> | PCB | .6<br>.7 | | Pro-File HDA D | Description | | | 2. Pro-File HD | escription | .11 | | Firmware Routi | ines | | | <ol> <li>Retry (Erro</li> <li>Diagnostic</li> </ol> | tion | .23<br>.25 | | Circuit Descri | iptions | | | | PCB | | | Schematic Diag | grams | | | <ol> <li>Controller</li> <li>Analog PCB</li> </ol> | PCB 3. | .12 | Appendices Page 3.1 rev 11-28-83 Source: David T. Craig Page 0149 of 0580 # HOW TO USE THIS SECTION This section contains general information on the functional operation of the 4 modules in the Pro-File, and its firmware operation. It is designed to be referred to from the other sections in this manual, but you may wish to use it to help you better understand Pro-File operation. If you are unfamiliar with Winchester disk drives, then a good place to start would be with the Pro-File HDA description in this section. Then if you would like general information on each of the 4 Pro-File modules read the "Overview of the Pro-File". Appendices Page 3.2 rev 11-28-83 Source: David T. Craig Page 0150 of 0580 #### OVERVIEW OF THE PRO-FILE The following description will give you an overview of the technical details of the ProFile. It is intended to be a summary only, and is not a detailed explanation of the engineering aspects of the ProFile. # General Information on the Pro-File The intelligent Controller (Controller PCB), which is built into ProFile is continually checking the operation of the disk. Profile performs many operations to assure that the user will never see a problem. These operations start the moment ProFile is turned on. After power-up, ProFile does a Scan operation of the entire disk surface, and checks for any errors. Upon any data read error, an extensive analysis of the error is performed to determine whether a media error exists. If that is the case, the data will be moved to a spare sector of the disk. That part of the disk with a media error will no longer be used, it is "spared". In most cases, the error recovery routines in ProFile will be able to extract the data even from a bad sector. The recovery operation includes more than 300 retries under various conditions. Maps of the bad sectors are redundantly recorded on ProFile (these maps are called spares tables), so that an error in the map will not cause a problem in operation. The ProFile moves the heads to a "parking position" off the data zone after three seconds of no activity. This prevents the loss of data if, for instance, the ProFile is dropped or jarred. ProFile constantly checks for errors during operation. After any change in tracks, ProFile verifies that the operation has been performed correctly. Profile also checks that the heads are positioned accurately on a track before any read or write operation is performed. Unless the system requests that the ProFile do otherwise, data is always verified after a write operation. In all these cases, Profile will correct the problem so that no errors occur. Appendices Page 3.3 rev 10-12-83 Source: David T. Craig Page 0151 of 0580 Data can be transferred from the ProFile to the system at up to one Mbyte per second DMA rate. Data is interleaved at a 5:1 ratio, which allows three 512 byte sectors to be transferred on each rotation. MFM encoding allows the maximum data storage capacity with low formatting overhead. - Note: 1. For more detailed information on Scan operation, and error recovery routines refer to the firmware routine's functional description in this section. - 2. For more information on the format (including spares tables), used for the Pro-File HDA refer to the Pro-File HDA description in this section.) #### What is ProFile? ProFile is a Winchester technology hard disk drive designed to operate with a host computer. It has a formatted storage capacity of 5 Megabytes, which is essentially the same as 35 floppy disks (the Apple III disk drive uses floppies that have a capacity of 140K Bytes). Functionally, the ProFile consists of four major modules: - The Controller PCB - The Analog PCB 2. - 3. The Power Supply - 4. The Hard Disk Assembly (HDA) with motor control PCB The discussions on the following pages describe the general function of these modules. Appendices Page 3.4 rev 10-12-83 #### 1. The Controller PCB Functionally, the Controller provides communications with the host computer, provides signals to read and write serial data on the disk, moves the heads to the proper track, and monitors error conditions. The Controller consists of a Z8 microprocessor, 2K bytes of RAM, error detection logic, and read/write control logic. The Z8 provides an intelligent interface to the host computer. High level commands, such as read, write, and status, are generated by the host computer to through the Pro-File interface cable to the Z8. The Z8 uses the buffer area in RAM to temporarily store any data being read from or written to the disk. The Controller also interfaces to the Analog card to pass head control information to it. In this way the Controller determines when read/write operations will take place. The Z8 controls disk operations in the HDA. Basically it sends the stepper motor in the HDA step pulses to move the heads from track to track (such moves are called "seeks"), selects one of four read/write heads, and enables the different functions (i.e. sync, clock data, etc.) on the Analog PCB to perform the read or write operation called for by the host. Read/Write functions are performed by the read/write logic on command from the 28. This logic in turn controls the parallel to serial data conversion when writing, and the serial to parallel data conversion when reading. To ensure the proper transfer of data, the Controller does a CRC (cyclic redundancy check) of the serial data. If an error occurs, the Z8 will automatically perform an error recovery routine and try to relocate the data onto a different section of the disk. The sector causing problems will be removed from use to prevent future errors. After 3 seconds of no communication with the host, the Z8 on the Controller PCB will move the head to a Park position on the disk (track 155 a non data track), to prevent accidental damage to the disk surface in the event of a hardware failure (such as power loss). Once in Park position for 0.75 seconds, the Z8 removes power from the stepper motor to prevent heat build-up in the drive. The READY light on the front of the ProFile is lit whenever the Controller is idle (not busy). Appendices Page 3.5 rev 10-12-83 Source: David T. Craig #### 2. Analog PCB The Analog PCB serves as the interface between the Controller and the Head Disk Assembly (HDA). The Analog PCB consists of a data encoder, a data decoder, write driver, head select logic, automatic gain control (AGC) preamplifier, read detector, phase lock loop (PLL), and sector detector. The head select matrix selects one of the four heads for a read or write operation in response to control signals from the Z8 on the Controller PCB. The ProFile has two fixed disks in its HDA, and there are two heads for each disk (one for each side, since the disks are double sided). Thus you have a choice of four heads, depending on which section of the disk you are trying to access. It is not necessary for the host computer to know which section of the disk it is trying to access; the Controller and the Analog PCB take care of that. During a write operation, the serial data is encoded using a technique known as Modified Frequency Modulation (MFM). During a read operation, the AGC circuit amplifies the low level head signal (.6 to 2.0 mv) to a fixed signal level (1.0 volt). The read detector simply shapes the signal so that it appears in a standard fashion. The PLL and data decoder then convert this signal back into serial data, which is passed to the Controller, which in turn converts it to parallel data and passes it to the host computer. High speed, low noise ECL (emitter coupled logic) provides wide margins for the Analog electronics PCB of the ProFile. When the disk is initially formatted, the sector boundaries are written to the disk (this is done by removing all read signals from certain sections of the media). During the read operation, the sector detector looks for these areas of no read signal, and signals the Controller that a sector boundary has been found. Appendices Page 3.6 rev 10-12-83 Source: David T. Craig Page 0154 of 0580 # 3. Switcher Power Supply The power supply provides the +5VDC, and $\pm 12$ VDC needed by the ProFile for operation. The supply also contains monitoring circuitry to detect a power failure. This monitoring circuitry senses a power failure before the internal DC voltages drop. If a power failure should occur the monitoring circuitry uses a signal called Power OK (POK) to reset the Z8 on the Controller PCB. This allows the intelligent Controller in ProFile to prevent any data loss if the power fails or is turned off accidentally. The system will not begin any operation until the power is on for at least one second. Once a failure is detected, the head current is shut off to prevent the accidental writing of false data that would otherwise occur if a write operation were in process when the power failed. The power supply is completely shielded to eliminate the effects of electro magnetic radiation. Appendices Page 3.7 rev 10-12-83 Source: David T. Craig Page 0155 of 0580 ## 4. Head Disk Assembly (HDA) The Profile HDA is a random access storage device with two non-removable 5 1/4 inch discs as storage media. Each disk surface employs one movable head to service 153 data tracks. The total formatted capacity of the four heads and surfaces is approximately 5 Megabytes (16 sectors per track, 512 bytes <A/// format> or 532 bytes <Lisa format> per sector, and 612 tracks). High reliability is achieved through the use of a band actuator and open loop stepper head positioning mechanism. The read/write heads are mounted on a ball bearing supported carriage which is positioned by the band actuator connected to the stepper motor shaft. Mechanical and contamination protection for the heads, actuator, and discs are provided by an impact resistant aluminum enclosure. A self contained recirculating system suplies clean air through a 0.3 micron filter. A special spindle pump assures adequate air flow and uniform temperature distribution throughout the head and disk area. Thermal isolation of the stepper and spindle motor assemblies from the disc enclosure provides significantly greater "off track" margin (temperature changes are less likely to cause read errors). A brushless DC drive motor rotates the spindle at 3600 RPM. The spindle is driven directly with no belt or pulley. The motor and spindle are dynamically balanced to insure a low vibration level. Depending on the revision of Motor Control PCB on the HDA a physical brake mechanism, or a dynamic brake (involving reverse biasing the coils on the disk motor) may be used to provide a fast stop to the spindle motor when power is removed. (continued on the next page) Appendices Page 3.8 rev 10-12-83 Source: David T. Craig # 4. Head Disk Assembly (HDA) (continued) The recording media consists of a lubricated thin magnetic oxide coating on a 130 mm diameter aluminum substrate. This coating formulation, together with the low load force, low mass Winchester type "flying heads", permits reliable contact start/stop operation. The HDA (hard disk assembly) can be operated from $10^{\circ}\text{C}$ to $60^{\circ}\text{C}/.$ This wide operating range, combined with a 75% efficient switching power supply allows ProFile to operate from 10 to $40^{\circ}\text{C}$ in still air without a fan. (For more information on the Pro-File HDA format (including spares tables), used for the Pro-File HDA refer to the Pro-File HDA description in this section.) Appendices Page 3.9 rev 10-12-83 Source: David T. Craig Page 0157 of 0580 # PRO-FILE HDA DESCRIPTION (THE HARD DISK ASSEMBLY) ## PHYSICAL DESCRIPTION OF THE HDA The HDA contains 2 rigid disks, which are constantly rotating at 3600 RPM. Each disk has 2 surfaces, (top and bottom), making a total of 4 surfaces numbered 0, 1, 2, and 3 (see figure 1). The disk surfaces are covered with a metallic film which is very easily magnetized. In the beginning, when the disk is first made, there is no magnetic information on it at all. No information will be put on the disk until its magnetic areas have been specially arranged, or formatted with a Format program run from the Host computer system. A discussion of the features common to formats used for the Pro-File HDA is explained later in this discussion. Each surface has a device called a head, which converts electrical impulses into magnetic impulses and vice versa. The heads are numbered after the surfaces they cover, that is, 0, 1, 2, and 3. During a write operation, binary data in the form of a bit stream is written on the disk surface by the head. As the disk surface rotates under the head, each pulse in the bit stream will cause a small area on the medium (disk surface) to be polarized. Extreme closeness of the head to the medium (in the Pro-File's case 20 microinches) is a distinguishing characteristic of Winchester type disk drives. The head rides (flies) on the thin cushion of air between it and the media (something like an airplane wing). If particles as small as a piece of dust are allowed into the head chamber, they can cause the head to lose its flight stability. The head may then become erratic causing it to crash into the media, and destroy some areas on the disk. For this reason, the HDA is kept in an air-tight enclosure with a small filtered aperture. This allows atmospheric pressure equalization while preventing potentially dangerous particles from gaining access. During a read operation, the head senses the magnetic areas on the disk surface as they pass under the head, and produces an electrical impulse for each change in their polarity. Appendices Page 3.11 rev 10-12-83 Source: David T. Craig Page 0159 of 0580 # DESCRIPTION OF THE PROFILE HDA FORMAT Now you know how binary data is written onto and read from the disk. But how does the drive store different sets of data (files) and keep them separate? To do this, the drive needs a way of writing different files to different areas of the disk, and then finding them when it needs to read them. To understand how the drive does this, you need to understand steps, tracks, blocks, and sectors. Each head is mounted in such a way that it may move in to the center and out to the perimeter of the disk surface as the disk rotates beneath it. A write or read operation will never take place while the head is moving, but only while the head is stationary and the disk is moving under it. The heads move in very exact increments called steps. On the Pro-File the head must take 153 steps to cover the entire area on the disk where data may be stored. The head may stop after any step to read or write data. The 153 possible positions of the head determine the 153 magnetic channels, or tracks, on which data can be stored (refer to figure 1). The selection of which track the head is positioned over is controlled by the firmware program in the ROM on the Z8 microprocessor on the Controller PCB (the particular firmware routine used for this purpose is called the Seek Routine and is discussed in the Firmware Routine descriptions in this section). The Z8 performs track selection by sending step pulses to the motor controlling the head. The number of step pulses the Z8 sends to the stepper motor determines how far the head will move and so which track it will be over. Appendices Page 3.13 rev 10-12-83 Source: David T. Craig Page 0161 of 0580 # DESCRIPTION OF THE PROFILE HDA FORMAT (continued) The firmware program in the Z8 also controls when a read or write operation occurs. When writing, the bit stream to the head travels from the Host (Apple ///, or Lisa), to the Pro-File's electronics, to the head; and when the bit stream is read from the disk it goes back to the Pro-File's electronics, and then to the Host. There are 612 tracks on the HDA (153 tracks on each disk surface, and 4 disk surfaces), and approximately 8,200 bytes on each track. If track selection were the only method the Z8 firmware had to control the location of stored data, it would have a maximum of 612 very large storage places (8,200 bytes apiece). Since most files are considerably smaller than 8,200 bytes, this would be very inefficient. So to make data storage more efficient, the host computer breaks all data up into segments called **data blocks.** If the Host is an Apple /// the data blocks are 512 bytes long, and if the Host is a Lisa they are 532 bytes long. The Pro-File stores these blocks into physically addressable areas on the track called sectors. There are sixteen sectors on each track (refer to figure 1), so each track on the Pro-File can hold 16 data blocks. The sectors are separated from each other by small blank areas of no writing called sector marks. The Pro-File uses these sector marks to detect when one sector ends and a new one begins. Each sector can be divided into 2 fields: the first field is called the sector header, the second field follows the sector header and is called the data block (see figure 2). (Continued on the next page.) Appendices. Page 3.14 rev 10-12-83 Source: David T. Craig Page 0162 of 0580 ## DESCRIPTION OF THE PROFILE HDA FORMAT (continued) Each field in the sector is preceded by sync bytes to allow the Pro-File electronics to synchronize to the data in the field before attempting to read one. The sector header field contains 16 bytes: 2 are "start header" bytes; 3 bytes contain track, sector, and head ID's; 3 bytes contain a complement of the track, sector, and head ID information; and the remaining 8 bytes are all 0's. The data block field consists of the actual data from the Host computer with 2 CRC bytes at the end (a CRC (Cyclic Redundancy Check) byte is used by the Pro-File electronics to detect if an error has occurred during a read or write operation). The data block field is transparent to the Pro-File (which can only locate sectors), so the operating system from the host computer must keep track of which data block is in which sector. The operating system references sectors by block numbers. It knows that it has 9728 (decimal), or 0 to 25FF (hexidecimal) sectors available for data on the Pro-File. So it assigns each block of data to a number from 0 to 25FF called its logical block number and writes/reads the data blocks to/from the Pro-File using this number. The Pro-File converts the logical block number into sector locations to actually store or read the data block. During formatting, the Format program writes the sector marks and headers into their areas within each sector. At this time, all sectors are referenced to a physical location on the disk called the Index (see figure ). The Index position is sensed when a small magnetic tab fastened on the disk motor passes by a magnetic sensor during motor rotation. Note: The Index signal is only used during formatting, although it may be sampled by the technician with a frequency counter to determine the HDA's motor speed. (Continued on the next page.) Appendices Page 3.15 rev 10-12-83 Source: David T. Craig Page 0163 of 0580 # DESCRIPTION OF THE PROFILE HDA FORMAT (continued) In a properly operating Pro-File, sector marks and headers should never change after formatting, since the locations of the sectors will never change. A data block, on the other hand, will change every time its file is written to, by the Host computer system. When looking at figure you probably noticed that the sectors are not sequentially numbered. This is because the sectors are interleaved. When the Pro-File goes after a sector, it reads sector headers to determine where the head is in relation to the target sector. Without sector interleaving if it read the sector header of the sector immediately preceding the target sector, then the electronics in the Pro-File could not react fast enough to begin reading the data block of the target sector, so it would have to wait another complete revolution of the disk to do so. With sector interleaving the program can read a sector header and know that the next sector in the numerical sequence will always occur a specific number of sectors following it, so it has time to prepare within that same revolution. Sector interleaving is a result of the formatting for a given system. The format in the figure shown is for an Apple /// system. Each sector in this format is offset from the next in its numerical sequence by 5 sectors. The interleaving scheme for a Lisa system offsets the numerical sequence of each sector by 7. Appendices Page 3.16 rev 10-12-83 Source: David T. Craig ## SPECIAL FUNCTION TRACKS Directories: Now another question: How does the host computer's operating system keep track of where all the blocks belonging to a file are located? The answer, it uses the Pro-File's HDA to store directory information on each file. Directories are created and maintained by the host computer's operating system. As far as the Pro-File is concerned, they are just data block fields. But without them the operating system would not be able to send the Pro-File the proper block numbers to retrieve the data blocks for a file. NOTE: The following discussion which very briefly describes the Apple /// Sophisticated Operating System's (SOS) directory usage, is for example purposes only, and subject to change as the Sophisticated Operating System is revised. On an Apple /// system, track 0 on the Pro-File is reserved for the Root directory which contains descriptive information about every main file that SOS (the Apple /// operating system) has put on the Pro-File. This information includes: - a. File name The name of the file in ASCII. - b. The block number for each file's key block Each files key block contains many items of information about the file. Among them will be a list of every block number in the file. When an Apple /// host computer wants a file it reads the Root directory which refers it to the files key block (this may be through several subdirectories). The host then reads the key block and sequentially takes each block number from the file's block listing in the key block and sends it to the Pro-File to read the file. The firmware program in the Z8 takes care of converting the logical block number from the host to a sector address so it can actually acquire the data block. (For more information on the Apple /// directory structure refer to the SOS Reference Manual) Appendices Page 3.17 rev 10-12-83 Source: David T. Craig Page 0165 of 0580 #### SPECIAL FUNCTION TRACKS (continued) A Lisa uses a different directory structure, but Pro-File operation is still the same. Because all communication between the Pro-File and the HOST is done block by block, the Pro-File is known as a block device (as opposed to character devices, which communicate one byte at a time (such as a printer)). The next block in the file is not necessarily located in the next sequential sector on that track. In fact very often it is located on an entirely different track. That is why the Pro-File sometimes seems to go through a lot of gyrations as it reads a file. The sectors containing the blocks in the file are probably located on several different disk surfaces and tracks. Track 77 on all disk surfaces is dedicated for the exclusive use of the Pro-File. The host cannot write to these tracks unless the Pro-File is being formatted. The following discussion describes their usage. The Spares Storage Track (Track 77, Disk Surfaces 0, and 1): What happens if there is an error? When the Pro-File looks for a block of data, it performs many tests to confirm that the correct sector is being read accurately (for a more detailed description of these tests, refer to the Firmware Routines description in this section). Sometimes the Pro-File determines that the media where a sector is located is not useable, and so won't use it any more. A sector identified as being unuseable is called a spared sector. If the data block from the spared sector can be salvaged, the Pro-File will store the data block from the faulty sector on a special track reserved for that purpose called the Spares Storage Track (located on track 77 on disk surfaces 0 and 1). Appendices Page 3.18 rev 10-12-83 Source: David T. Craig Page 0166 of 0580 # SPECIAL FUNCTION TRACKS (continued) The Spares Storage Track provides storage for a maximum of 32 spared sectors (2 surfaces, 1 track on each surface, 16 sectors per track). The Spares Table Track (Track 77, on Disk Surfaces 2, and 3): Once the data block from the spared sector has been stored, the Pro-File will record the old sector location of the salvaged data block along with its new spares storage sector location in the Spares Table Track (located on track 77 on disk surfaces 2, and 3). Spares table information is stored redundantly on the Spares Table Track so any addition of a newly spared sector address will require an update to all 32 sectors on both surfaces of this track. When the host sends the Pro-File a block number to be read, the Z8 will search the Spares Table (an image of this table is maintained in RAM), to determine if that block is on the Spares Storage Track. If it is, the Z8 will then go to the spares sector address to acquire the data block. Appendices Page 3.19 rev 10-12-83 Source: David T. Craig Page 0167 of 0580 #### FIRMWARE ROUTINES The following descriptions discuss the operation of some of the firmware routines contained in the ROM of the system Z8 on the Controller PCB, and how they affect the operation of the Pro-File. #### 1. SCAN OPERATION After power up there are several things that take place before the firmware program in the system 28 microprocessor on the Controller PCB will allow communication with the host computer system. Note: The position of the heads over the disks may be visually monitored by observing the position of the Interruptor arm on the HDA (as shown in Sheet 1 of the troubleshooting flowchart). - a. First the power must come up to the proper levels and be stabilized. Note: To indicate this process, upon power up, the Ready Lamp will light for between 0.5 and 3 seconds. - b. Second the Z8 waits for about 20 seconds to allow the HDA motor to come up to 3600 RPM (its operating speed). Note: During this process, the Ready Lamp will remain off. - c. Third the Z8 does a Seek routine to the Spares Table Track on track 77, on disk surfaces 2, and 3. Seek routine operation is standard for any read, write, or write/verify operation requiring head movement to a new track and is performed as follows. During the **Seek** routine the Z8 issues the proper number of steps to the stepper motor to move the head over the target track, and performs a verification process to confirm that the head is over the proper track. During the Seek verification process the Z8 reads 3 alternate sectors from the track the heads are over. (Continued on the next page.) Appendices Page 3.20 rev 10-12-83 Source: David T. Craig Page 0168 of 0580 ## 1. SCAN OPERATION (continued) The sector header fields from these sectors tell the Z8 which head and track have actually been selected. A CRC check is also performed on the data block fields from these 3 sectors. (a) If the head and track ID's read from the 3 sector header fields prove that the proper head is positioned over the proper track, and the 3 data block field's CRC status is OK, then the Z8 will exit the Seek routine and enter the Read routine. The Read routine would normally read every sector on the now confirmed track until the target sector is read. However since each sector on the spares table track is redundant (each sector contains the duplicate copies of the spares table), there is no target sector. Any sector that has a good CRC check during read is acceptable. If the first sector has a CRC error, then the Z8 will just read the next and so on until it finds a good one. - (b)\* If during the attempt to confirm a good Seek to the Spares Table Track on track 77, a sector header is unable to be read, or a CRC error in a sectors data block field occurs, then the Seek routine will continue reading the 3 alternate sectors for up to 64 errors. - \* If over 64 errors occur, then the 28 moves the head to track 0 (the outermost track) and trys the Seek routine to the target track again (in this case track 77). If that fails the Z8 will move the head in to track 155 (the innermost track) and again reseek to the target track. - \* The head movement to track 0 and track 155 and reseeking process during Seek verification is performed twice. If the proper track is still not found, then the Seek routine will be exited, Scan operation is abandoned, and the heads are moved back to park position. (Continued on the next page.) Appendices Page 3.21 rev 10-12-83 Source: David T. Craig Page 0169 of 0580 - 1. SCAN OPERATION (continued) - d. Fourth the firmware program in the Z8 performs a sector header read, and data block CRC check of every sector on the HDA beginning with track 0 as follows: Note: The Ready Lamp will flash on and off during this process. - Each movement of the heads to a new track requires a (1) Seek routine as described above. - If the head and track ID's read from the 3 sectors during the Seek routine prove that the proper head is positioned over the proper track, and their CRC status is OK, then the 28 will exit the Seek routine and enter the Read routine. The Read routine will read each sector header on the track until it finds one that matches the target sector whose sector address is currently in - \* If during the Read routine the correct header is found, then the data block is read and its CRC status is checked. If the data blocks CRC status checks good, then the Scan operation goes on to the next sector to be read. - \* If during the Read routine there is a timeout error (the target header cannot be found within 150 ms), or a CRC error occurs in the target sectors data block field, then the <a href="Retry">Retry</a> routine (described in section 2) is called to attempt to get a good data block read from the sector. - (b) At this point in Scan operation, if an error occurs the Seek error recovery procedure described above will be followed, with the following exception. If after the procedure is accomplished the proper track is still not found, then the 28 will use the last track it could confirm a good seek on, as a reference to approximate the position of the target track, and move the head to that position. Then regardless of whether it could confirm a good seek to the target track or not, it will exit the Seek routine and enter the Read routine to read the target sector. Appendices Page 3.22 rev 10-12-83 Source: David T. Craig #### 2. RETRY ROUTINE The Retry routine is called for the purpose of attempting to read a good data block field after an unsuccessful read operation has occurred. There are 2 variables in the Retry routine, the retry number, and the sparing threshold. These values are given by the host computer's operating system when communications between it and the Pro-File are initiated. During the Scan operation since no communication from a host can occur, default values of 105 for the retry variable, and 31 for the sparing threshold are used. When called the Retry routine will: - a. Read the target sector the number of times specified by the retry variable (in the Scans case the default value is 105) - If after the total number of retrys have occurred, there are no successful reads, the Retry routine will try to reread the sector 90 more times, or until it reads a data block without a CRC error. - (a) If all of the 90 reads are unsuccessful, then the sector address is written to the bad block table in RAM, and the spares table track (track 77 of disk surfaces 2 and 3). If <u>Retry</u> is called during Scan operation, the spares table track (track 77 on disk surfaces 2 Note: or 3) will be updated when the host computer's operating system initiates communication with the Pro-File (this will be after the completion of Scan). (b) If any of the 90 reads are successful a good data block from one of the successful reads is held in RAM while the $\underline{\mbox{Diagnostic}}$ routine (described later) is called to check out the media for the sector in question. If the Diagnostic routine determines that the sector has bad media, it will spare the sector. If the Diagnostic determines the sector to be good, then the Diagnostic and Retry routines are exitted. Appendices Page 3.23 rev 10-12-83 Source: David T. Craig # 2. RETRY ROUTINE (continued) - (2) If after the total number of retrys have occurred, there were successful reads, then the Z8 checks to see if there were more unsuccessful reads than the spares threshold variable allows (in Scans case the default is 31). - (a) If the sparing threshold has not been exceeded then the <u>Retry</u> routine is exitted, and control is given back to the <u>Scan</u> operation. - (b) If the sparing threshold is exceeded, but at least 1 good data block read occurred, then the data block field is rewritten to the questionable sector and the <a href="Diagnostic">Diagnostic</a> routine (described later) is called to check out the target sectors media. If the <u>Diagnostic</u> routine determines that the sector has bad media, it will spare the sector. If the <u>Diagnostic</u> determines the sector to be good, then the <u>Diagnostic</u> routine is exitted and control is given back to the <u>Scan</u> operation. Appendices Page 3.24 rev 10-12-83 Source: David T. Craig Page 0172 of 0580 # 3. DIAGNOSTIC ROUTINE The Diagnostic routine is called for the purpose of checking media quality on a given sector location, and sparing the sector if the media quality is determined to be bad. When the Diagnostic routine is called it will: - a. Read the target sector (specified by the sector address currently in RAM), 100 times. - If over 30 CRC and/or timeout errors occur, then the **Diagnostic** routine will write the data block into a sector on the spares storage track (track 77 of heads 0 or 1). The Diagnostic routine will then write the old sector address, and its new spares track sector address in the spares table in RAM, and after the next handshake with the host system will update the spares table track (track 77 on heads 2 or 3). The Diagnostic routine is then performed on the new spare sector location of the data block to make sure that it is a good media location. - Note: During Scan operation the spares table track (track 77 on disk surfaces 2 or 3) will be updated when the host computer's operating system initiates communication with the Pro-File (this will be after the completion of Scan). - If less than 30 CRC or timeout errors occur, then the Diagnostic routine is exitted, leaving the data block in its present sector (the media must be OK). Appendices Page 3.25 rev 10-12-83 4. During Normal Operation - the Seek and Read routines will be performed just as they were in the Scan operation. If an error occurs, the sequence of operations is the same as that of scan with the exception that the retry and spares threshold variables will be different depending upon the operating system. The **Diagnostic** routine will always be called if the verify fails during a Write/Verify operation. If a sector address is in the Bad Block table, then that means that a Retry routine must have been called for that sector, and during the routine there was never a good read of the data block. This means that the Pro-File does not have a good data block for that sector and can't perform a **Diagnostic** on the questionable sector location until it has one. If the host does a write to that sector address listed in the Bad Block table, then at that time the Pro-File has a good data block for that sector so then the Diagnostic routine is automatically called to verify the media at that location. Of course if it doesn't check out then the sector is spared. In any event, whether the sector is spared, or is determined to be good and left as is, the sector's address will be deleted from the Bad Block table because the Pro-File now knows whether its media is good or not. Appendices Page 3.26 rev 10-12-83 Source: David T. Craig Page 0174 of 0580 174 ## CONTROLLER PCB CIRCUIT DESCRIPTION # What's in This Description On the next six pages you will find tables listing the pins and their functions for the: - a. Host interface plug Pl. - b. Analog PCB interface plug P2. - c. 28 Main Processing Unit on the Controller PCB. Block diagram and circuit descriptions for the main functions on the Controller PCB follow these tables. For specific circuit diagram information refer to the Controller PCB schematic at the end of this section. Appendices rev. 11-14-83 Page 3.27 Source: David T. Craig Page 0175 of 0580 Controller PCB to Host Interface (Pl) The Controller PCB and the Host communicate via a 25 pin plug, Pl. Signals at Pl on the Controller PCB are as follows: | PIN<br>5, 6,<br>8, 11<br>12, 13<br>22, 23 | SIGNAL<br>XD0-XD7 | <pre>DESCRIPTION (bidirectional) /Data lines between the Host and the Pro-File.</pre> | |-------------------------------------------|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 3 | RRW | (input) /Controls the direction of data on lines ${\tt XD0-XD7}$ . | | 17 | CMD | (input) /Initiates communication with the Pro-File. | | 16 | BSY/INT | (output) /Notifies the Host of Pro-File status. | | 15 | PSTRB | (input) /When writing, this signal is generated by the Host to clock a byte into Pro-File's RAM; when reading, the pulse causes the Z8 to increment the Address Counters and so select the next sequential address to be read. During Read, the RAM is always selected to output the contents of the selected address; so after the Host generates PSTRB, it waits a short time and then gates in the byte from the I/O cable. | | 18 | TPARITY | (output) /This signal is high or low, depending on the parity of the byte currently being transferred on data lines XDO-XD7. | | 21 | CRES | (input) /When generated by the Host, this signal resets the Z8 to its initial state. This usually occurs at the beginning of communications, but whenever it happens depends on the Host. | | 25 | CDET | This signal is used by Host interface to detect a disconnected or broken cable. | | 1 | РН0 | (input) /PHO is a timing signal from the Host. | rev. 11-14-83 Page 3.28 Appendices Source: David T. Craig Page 0176 of 0580 176 # Controller PCB to Analog PCB Interface (P2) The Controller PCB and the Analog PCB communicate via P2. The Analog PCB converts the Controller PCB's digital data into analog signals for the disk media. Signals at P2 on the Controller PCB are as follows: | PIN<br>12 | SIGNAL<br>Write Data | | |-----------|----------------------|--------------------------------------------------------------------------------------------------------------------------------------------| | 32 | Read Data | (input) /Digitized NRZ serial data recovered from the disk. | | 10 | Sys Clock | (output) /Provides the 10 MHz system clock to the Analog PCB for write operations. | | 34 | Read Clock | (input) / Provides the Controller PCB with a clock that is in sync with the Read data. | | 30 | Read Gate | (output) /Enables the Read circuitry on the Analog PCB. | | 22 | Write Gate | (output) /Enables the write circuitry on the Analog PCB. | | 4 | Index | (input) /Index is a pulse that occurs once per disk revolution and is only used by the 28 during formatting. | | 8 | Write Sector Ma | rk (output) /Enables the Analog PCB to write DC sector boundaries during formatting. | | 15 | Sector Mark | (input) /Signals the Controller PCB when the heads have encountered a sector mark on the disk. | | 26,<br>28 | Head Select 1,0 | (output) /Causes selection of one of four Read/Write heads. | | 2 | Track 0 | (input) /Indicates that the heads are positioned over the outermost tracks. | | 24 | Precompensation | (output) /Enables the Precompensation and low current circuitry on the Analog PCB when the inner tracks (128 to 152) are being written to. | | | | (output) /Activates stepper motor coils to position heads. Generated by the Z8. | Appendices rev. 11-14-83 Page 3.29 Source: David T. Craig Page 0177 of 0580 122 # 28 Main Processor Pin Descriptions The following are signal descriptions produced from the 28 on the Controller PCB. The Z8 has five sets of pins: - 1. General purpose signals. - 2. Port 0. - 3. Port 1. - 4. Port 2. - 5. Port 3. # 1. General Purpose Signals | $\frac{PIN}{2}$ 3 | SIGNAL<br>Clock | | |-------------------|-----------------|-------------------------------------------------------------------------------------------------------------| | 6 | Reset | 'Power OK'; system reset line or $\overline{\mathtt{CRES}}$ . | | 9 | ĀS | Address strobe, used to latch data from Port 1 and Port 0 [0:3] into LS161 counters (RAM address counters). | | 8 | DS | Data strobe, defines data valid time during Writes or Reads to RAM and writes to 8253 counter. | | 7 | ZRW | <pre>28 Read/Write line. Defines external memory for I/O operation as a Read or Write.</pre> | | | | | NOTE: AS, DS, and ZRW are tri-stated when Port 1 is placed in the high impedance state. ## 2. PORT 0 | • | SIGNAL<br>P00-P02<br>A8-A10 | DESCRIPTION High-order address bits, A8-A10, for RAM access. They are latched into the LS161 address counter during AS. | |----------------|-----------------------------|-------------------------------------------------------------------------------------------------------------------------| | 16 | PO3<br>PCOMP | Precomp/Reduce Write Current command to disk Write electronics. (State is 'don't care' if not writing.) | | 17,18<br>19,20 | P04-P07<br>01-04 | OB2, OB1, OA2, and OA1 commands, respectively, to the stepper motor drive circuitry. | Appendices rev. 11-14-83 Page 3.30 Source: David T. Craig Page 0178 of 0580 148 #### 3. PORT 1 System data bus (8 bits). Its different functions are listed below. # PIN SIGNAL DESCRIPTION 21thru P10-P17 a. Low order address bits and data, 28 2R7-ZR0 multiplexed by AS and DS, for Z8 RAM accesses. - b. Data bits for loading the 8253 counters. (LDCTR, derived from DS when MSELl is low, is the 'Write' input to the 8253.) - c. Data to 1 from the Host. The Z8 program must set Port 1 to the high impedance state. - d. Data to 1 from the disk. The Z8 program sets Port 1 to hi-Z. #### 4. PORT 2 These pins are programmed as inputs or outputs using a 28 mode register. All pins are set to hi-Z (input mode) after a reset. | PIN<br>31 | SIGNAL<br>P20<br>WRTSM | DESCRIPTION Write Sector Mark (WRTSM) output. This signal used in conjunction with Format Enable (FMTEN), which causes WTGT to be true, writes sector marks on the disk. This should happen only during the format operation. | |-----------|------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 32 | P21<br>TRK0 | Track 0 (TRK0) input. Indicates that R/W heads are positioned over outermost track. | | 33 | P22<br>CMD | Command (CMD) input. This line is set true by the Host via the interface card, and it indicates that the Host is requesting access to the controller RAM. The corresponding handshake line, BSY/INT, is a 28 output described later. | | 34 | P23<br>BSY/INT | Busy/Interrupt (BSY/INT). This signal acknowledges the CMD input via the CMD-BSY protocol described elsewhere. BSY can also be used to interrupt the Host if enabled on the Interface card. | (Continued on the next page.) Appendices rev. 11-14-83 Page 3.31 Source: David T. Craig Page 0179 of 0580 129 # (Port 2 pin description is continued from the previous page.) - (MSEL0) The low order select bit to control MSEL0 RAM access. - 36 P25 (MSEL1/PSEL) High order RAM access select MSELl bit. Also controls data input to RAM from the Host or the disk; hi = disk, low = Host. - 37 P26 Start/reset error (START/RSTERR). START/ Read/Write control hardware to begin a Read RSTERR or Write operation at the next sector pulse. Also resets the CRC error flip-flop and the sector timing register. - 38 P27 Disk Read/Write (DRW). Controls the Read/ Write inputs to the RAM for Host or disk DRW accesses. Command input to Read/Write hardware. High when Read, low when Write ## 5. PORT 3 P33-P30 are inputs and/or interrupts; P37-P34 are outputs. | PIN<br>5 | SIGNAL<br>P30<br>SER IN | DESCRIPTION Not currently used. | |----------|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 39 | P31<br>SECTOR | This signal is generated on the Analog PCB whenever it detects a Sector Mark on the disk. | | 12 | P32<br>SECTDN | Sector Done (SECTDN). (Input) Resets the 8253 byte counters and the lower four bits of the RAM address counter when the Read/Write hardware is searching for the target sector. Goes low when the Read/Write operation has been completed. Stays low until START. | (Continued on the next page.) Appendices rev. 11-14-83 Page 3.32 Source: David T. Craig Page 0180 of 0580 180 (Port 3 pin description is continued from the previous page.) - 30 P33 CRC Error (CRCERR). (Input) Goes low if a CRC CRCERR error is detected during a disk Read. - 29,10 P34,P35 Head Select 0, 1 (HS0, HS1). Binary coded HS0,HS1 bits to select head 0, 1, 2, or 3. - 40 P36 Write Sector Mark (WRTSM). (Output) Causes sector marks to be written on the disk if FMTEN is high and the Format jumper is installed. - P37 Read Header/Transmit (RDHDR/TX). Command input to the Read/Write control circuits. If DRW (P27) is high and START/RSTERR (P26) is low, RHDHR hi will cause the leader field on the next sector to be stored in RAM. Appendices rev. 11-14-83 Page 3.33 Source: David T. Craig Page 0181 of 0580 161 #### Principles of Operation Upon power up, the Z8 issues phase steps to the Head Stepper motor on the HDA to move the heads to track 77. The Z8 then performs a Read operation to read the Spares table. If this is successful, the firmware in the Z8 will perform the Scan (For a more detailed explanation of what the firmware in the 28 is doing (i.e., Scan, Seek, etc.), or information on the format used for the Pro-File HDA (i.e., Spares Table, sector . header composition, etc.), refer to the Appendices section of this manual.) The power up reading of the Spares Table and the performance of the Scan sequence are basically composed of Check Header and Read operations. These operations are discussed later. Once the Scan is completed and the initial (operating system specific) handshake has taken place, the Pro-File remains idle until the Host requests an operation. All Host-requested operations in the Pro-File are performed in three steps: the Command Handshake, the Check Header function, and the Operation. 1. The Command Handshake - The Host sends command bytes to the Pro-File to tell it whether to perform a Read, Write, or Write/Verify operation, and on what logical block number to perform it. The Z8 on the Controller PCB converts the logical block to location bytes (i.e., physical location on the disk; target head, track, and sector) and stores them in RAM. The Command Handshake is the same for any of the three operations. (Read, Write, or Write/Verify). (Continued on the following page.) Appendices rev. 11-14-83 Page 3.34 Source: David T. Craig Page 0182 of 0580 182 2. The Check Header Function - If the target sector is on a different head or track from the one already selected, the Z8 will perform the Seek routine to move all 4 heads to the target track (the track containing the target sector) and will enable the target head (the head over the disk surface containing the target track and sector). The Seek routine then uses the Check Header function to read three consecutive sector headers from the track it has moved the head to, and compares them with the target head, track, and sector bytes in RAM. The process used in the Check Header function to read the sector headers (to confirm a Seek to the right track) is almost identical to the first part of the Read, Write, and Write/Verify operations, which also read sector headers to find their target sectors. 3. The Operation - Once a successful Seek is confirmed, the 28 coordinates the circuitry in the Controller PCB and Analog PCB to perform it. Each operation follows a different sequence of events. Appendices rev. 11-14-83 Page 3.35 184 #### CONTROLLER PCB DETAILED BLOCK DIAGRAMS The following is a brief description of each of the 17 functional elements on the Controller PCB. Understanding the functions of these elements will help you to understand the signal flow discussions later. For more specific circuit diagram information refer to the Controller PCB schematic at the end of this section. 28 Main Processing Unit U25 The Controller PCB's MPU is a 28 microprocessor, which has a self-contained ROM program. It provides an intelligent interface to the Host computer. It indirectly controls the Pro-File's electronics by setting modes and directly controls the stepper motor and head selection. #### PAL U27 This single chip is a logic array specifically programmed for this application. It performs complex and/or combinational logic functions. Primarily, it controls the function of the address counter, the direction of data to/from RAM, loading the counter/timer, and the serial/deserial register. #### RAM Address Counter/Register Ul0, Ul6, Ul7 The method of use depends on what operation is currently going on. This element can be preset to a certain point and counted up through a sequential range of addresses for RAM access. It is also used as an Address register where it is loaded with a value for a specific single access. ### RAM Ull, Ul8 The RAM is a two kilobyte RAM array used to hold data to and from the Host and disk. Various locations are used to hold status information and the current spares tables. #### Data Line Drivers U4, U5 These simple Line Drivers drive data to and from the Controller and Host interface PCBs. #### Data In MUX Ul3, U20 This MUX is used to direct data coming in from the Host interface PCB or from the disk. The usual destination of its outputs is the RAM. Appendices rev. 11-14-83 Page 3.37 Source: David T. Craig Page 0185 of 0580 186 ### Bus Parity Checker U3 The BPC forms the other half of the bus parity checking circuit on the Host interface PCB. It constantly monitors the bus, checks the parity at the Controller end, and sends its sum to the Host interface to be compared with the sum on the interface end. A parity error should not occur unless a cable fault exists. #### BYTC State Machine U29, U30 The BYTC (Byte Control) element of the State Machine, one of the two major elements of the Read/Write Control circuitry, steps through the control states for each part of an operation at a bit-time rate. ### RWTC State Machine U37, U38 The RWTC (Read Write Timing Control) element of the State Machine, the second major element of the Read/Write Control, steps through the control states necessary to control the timing for all the operations associated with block/sector reading and writing. #### System Clock Selector U31, U32, U39 The SSC switches from the crystal oscillator, used during idle and Write operations, to the Read clock generated by the Analog PCB during the Read operation. This keeps the logic in sync with the data. #### Divide-by-8 Counter Counts the system bit-clocks that the System Clock Selector has selected (either the clocks from the Controller PCB's crystal oscillator or RDCLKs from the Analog PCB) and produces a positive transition from its QC output for every eight bit-clocks received (one per byte). Its QB and QA outputs enable the State Machine to discriminate phase (bit times) within the processing of a byte. #### Programmable Counter/Timer U33 This chip receives the QC output of the Divide-by-8 Counter as its input clock. It contains three programmable counters, which yield byte-time information to the Read Write Control logic, and it basically keeps track of what part of the particular sector is being processed by the Controller PCB. Appendices rev. 11-14-83 Page 3.39 Source: David T. Craig Page 0187 of 0580 188 #### Read/Write Data MUX U6 The Read Data MUX is used to select one of two sources of data, either Serialized Data from the SER/DESER register, or NRZ Read Data from the Analog PCB. When reading, it gates NRZ Read Data through to the Serial/Deserial Shift Register Ul4. During a Write, it gates serial data from the Serial/Deserial Shift Register Ul4, to the CRC generator U35. #### CRC Generator/Checker U35, U36 The CRC (Cyclic Redundancy Check) circuit is used to compute CRC check characters that are written at the end of each data block on disk during Write operations, to compute CRC for Read data, and to compare the result with the CRC characters that were read at the end of each data block #### Deserialized Data Register U21 This 8-bit register temporarily holds the deserialized data from the disk so that the shift register can receive the next byte. When the logic is ready, it directs the register's contents to RAM though the Data In MUX. #### Serial/Deserial Shift Register Ul4 This register is used to take the parallel data from RAM and shift it out serially to the Analog PCB and to take the serial data from disk and shift it into a parallel format for transfer back into RAM. ## Stepper Motor Drivers U7, U8 The 4 phases required for Stepper motor movement are generated by the 28. The current for these signals is then boosted by the Stepper Motor Drivers U7, and U8. Appendices rev. 11-14-83 Page 3.41 Source: David T. Craig Page 0189 of 0580 189 # PRO-FILE HOST INTERFACE Appendices rev. 11-14-83 Page 3.42 Source: David T. Craig Page 0190 of 0580 190 #### CONTROLLER PCB SIGNAL FLOW DESCRIPTION To understand Controller PCB operation, you should first become familiar with data flow in the three stages of an operation; the Command Handshake, the Check Header function, and the operation itself. The following discussions describe each stage, first in general and then in detail. The Z8 is used to condition the logic, but it is not actively involved with data transfers to/from the disk or Host; that is done by the Read/Write Control logic (RWCL which is just about everything else on the Controller PCB except the Z8, RAM, and Host interface circuitry). (For information on the Pro-File format on composition of the sectors in the format, refer to the Pro-File HDA Description in the Appendices section.) #### A. Command Handshake #### Command Handshake General Explanation Assume that the Pro-File is initially sitting idle with the BSY line high (not active), the disks spinning, and the heads over track 155 (Park position), waiting for the Host to tell it to do something. The Host communicates this message during the Command Handshake. The Host asserts CMD (active low) to initiate communications with the Z8. Upon seeing CMD going low, the Z8 lowers its BSY line and waits for the Host to raise CMD. When the Pro-File sees CMD go high it places a 01 response byte on the interface bus and raises BSY. The Host sees the BSY line go high and interprets the O1 as an ACK, so it lowers the RRW signal. The low RRW signal enables the Pro-File to write the command bytes the Host will send into its RAM. The Host must acknowledge the Pro-File's response with a 55, or the 28 will abort the operation and go back to idle. The Host puts its 55 response byte on the bus and lowers the CMD line. The low RRW and the response of 55 cause the Z8 to condition the bus to receive the command bytes, which are not immediately read by the Z8 but are stored in RAM for future reference. After the Host puts each byte on the I/O bus, it generates PSTRB. The positive transition of the negative pulse PSTRB is used to clock the byte into the RAM. Appendices rev. 11-14-83 Page 3.43 Source: David T. Craig Page 0191 of 0580 192 When CMD goes low again, the 28 interprets the command bytes and responds with the result of its command interpretation. For example, if the Host has said to read a block, the 28 would respond with "02", which means "I'm going to read a block". If it wants the operation to continue, the Host must confirm the response with a 55 on the bus again. If it disagrees or has changed its mind, the Host will send a byte other than a 55 causing the Pro-File to abort the operations. Two handshakes are required to complete a Read operation. The first one is the Command Handshake, and the second is when the Pro-File sends the Read data, and the completion status of the operation back to the Host. Three are required for both a Write and a Write/Verify operation. The first one is the Command Handshake, and the second is when the Host sends the block of write data to the Pro-File, and the third is when the Pro-File sends the completion status of the operation back to the Host. The command identifier bytes for each of the three commands are as follows, 00 fro Read, 01 for Write, and 02 for Write/Verify. A Command Handshake message is composed of the following elements. | Command | Logical Block # | Retry | Sparing | |------------|-------------------|----------|-----------| | Identifier | | Count | Threshold | | xx | Most, Middle, and | Host | Host | | | Least Significant | Specific | Specific | The Pro-File interprets CMD high as a request from the Host to send a byte telling the Host what the Pro-File expects to do next. When the Pro-File is waiting for a command, it sends an '01' in response to CMD high. The Pro-File's other responses are shown in the table below. | Host's command to Pro-File | Pro-File's Response | | |---------------------------------|---------------------|--| | Initiate handshake (lowers CMD) | 01 | | | Read a block | 02 | | | Receive Write data | 03 | | | Receive Write/Verify<br>data | 04 | | | Do the Write or W/V on disk | 06 | | Appendices rev. 11-14-83 Page 3.45 Source: David T. Craig Page 0193 of 0580 # 193 Following a Read or a Write, the Z8 provides the Host with four status bytes, which are placed in the buffer immediately preceding the data just read or written. The significance of the individual bits is listed below: # $\frac{\text{STATUS 1}}{7} =$ - 1 if Pro-File received 55 to its last response - 1 if Write or Write/Verify was aborted because the number of data bytes sent exceeded the data block limits or because the Pro-File couldn't read its spares table - 5 = 1 if the Host's data is no longer in RAM because the Pro-File updated its spares table. - = 1 if SEEK ERROR caused by Pro-File being unable in three tries to read three consecutive headers on a track - = 1 if CRC error, may occur only during an actual Read or verify of Write/Verify, not while trying to read headers after seeking - 2 = 1 if TIMEOUT ERROR (couldn't find target sector's header in nine revolutions - Not set while trying to read headers after seeking) - 1 = N.C. - 0 = 1 if operation is unsuccessful #### STATUS 2 - 1 if SEEK ERROR occurs if Pro-File is unable in one try to read three consecutive headers on a track. - = 1 if spares table overflow (More 32 sectors spared) - N.C. 5 - = 1 if bad block table overflow occurs (Less than 100 bad blocks in table ) - = 1 if the Pro-File is unable to read its status sector. - = 1 if sparing occurs. - = 1 if Seek to wrong track occurs. - = Not used. Appendices rev. 11-14-83 Page 3.46 Source: David T. Craig Page 0194 of 0580 194 $\frac{\text{STATUS 3}}{7} = 1 \text{ if the Pro-File has been reset}$ 6 = 1 if block number is invalid 5 = 1 if block I.D. at end of sector is mismatched 4 = N.C. 3 = N.C. 2 = 1 if the Pro-File has been reset. 1 = 1 if the Pro-File gave a bad response 0 = 1 if CRC error occurs. These bits are sent by the Host driver. STATUS $\frac{4}{7}$ - 0 = the number of errors encountered when rereading a (Continued on the next page.) Appendices rev. 11-14-83 Page 3.47 Source: David T. Craig Page 0195 of 0580 196 When the Host interface's CMD signal goes high, the Z8 responds by sending a "Ol" response byte up to the ZR bus, and off to the left through the buffer to the Host interface. (See figure on the opposite page). The Host lowers RRW and CMD. When the Host interface lowers CMD, the Z8 should see the Host's "55" acknowledgement coming in through the buffer to the Data In MUX directly to the Z8. This acknowledgement and RRW's being low triggers the Z8 to get the RAM ready to accept the command bytes. After the first handshake of CMD and BSY, the Host transfers the actual command and delimiting bytes. They come, as do all data, from the Host through the Data In MUX, and are then stored in RAM. The Z8 then evaluates the command bytes by bringing them in from RAM. After interpreting the command bytes, the Z8 gives its response byte, which is ack'd or nack'd by the Host. Appendices rev. 11-14-83 Page 3.49 Source: David T. Craig Page 0197 of 0580 197 Refer to the Controller PCB schematic at the end of this section for the following discussion. ### Command Handshake Component Explanation 1. When the Host lowers CMD to pin 33 of the Z8, the program in the Z8 will lower BSY on pin 34. When the Host raises CMD, the Z8 puts a 01 on the bus and signals the Host by raising BSY. Because RRW is already high to pin 4 of U9, the direction of the data on the bus is from the Pro-File to the Host. - 2. The Host interprets the 01 as an ACK and lowers RRW, which changes direction of the bus. Then it places 55 on the bus and signals the Pro-File by lowering CMD. - 3. The first phase of every operation is always the same, so the program in the Z8 knows that after sending the O1, the Host should respond with a 55. The 28 must enable the contents of the DI bus (should be a 55) to be gated onto the 2R bus so that it can verify that the Host has sent a 55. - 4. To do this, the Z8 generates the low MSEL1 and MSEL0 signals, to enable the Write Multiplexers (U12 and U20) to select the inputs from the DI bus. Once the 28 senses that CMD has gone low (an indication from the Host that it has put the data, in this case 55, on the data lines), it sends to PAL (U27) the combination of inputs it needs to generate the MUXEN signal, which gates the DI data onto the ZR bus. (For a table showing the conditions necessary to generate PAL signals, refer to the PAL Function Table at the end of this section.) 5. With the signals described above, a data path is established to pass the 55 from the DI (Data In) bus, through the Data In Multiplexers (Ul3, and U20), and onto the ZR bus. The Z8 then reads the 55 from the ZR bus. Appendices rev. 11-14-83 Page 3.50 198 6. The 28 now knows that it will receive some command bytes telling it what operation the Host is requesting, so it puts the first address it wants the command bytes stored in on the ZR bus and causes the PAL to generate the LD (Load) pulse to pin 9 and the clock to pin 2 of each Address Counter. This presets the Address Counters to the address in which it wants to store the first command byte. Note: AlO in the address must be low to select RAM. 7. The Data In Multiplexers (Ul2 and U20) are still enabled to select the DI bus inputs and pass them to the ZR bus. (Recall that after the Z8 read the 55 (Step #3), it sent to PAL (U27) the combination of inputs it needed to generate the SEL signal to RAM). - 8. A data path is now established to pass the command bytes that will shortly follow from the Host to the DI (Data In) bus, through the Write Multiplexers (Ul3 and U20), onto the ZR bus. - 9. The Host waits a short period after each byte is put on the lines for the data to settle, and then generates the PSTRB signal. - 10. Because of the PAL's current inputs, the PSTRB signal causes the PAL to generate the RAMWRITE signal from pin 16, which stores what is on the ZR bus into the RAM address specified by the Address Counters. - 11. PSTRB also causes the PAL to generate an Address Counter Clock from pin 19, to increment the Address Counters for the next byte to come in. - 12. When the Host has finished sending bytes, it raises RRW to pin 4 of U9, to change the direction of the Data bus. The Host then raises CMD again to tell the Z8 that no more command bytes are coming. Now the 28 reads the command bytes from RAM to interpret them. Appendices rev. 11-14-83 Page 3.51 199 13. To read the command bytes, the Z8 sequentially sets the Address Counters to the addresses of the command bytes. RAMSEL and an address on the lines to the 2114-type RAM fully enable the RAM to put the contents of the address on the ZR bus. As each command byte is read onto the ZR $\,$ bus, the 28 reads and interprets it. 14. If the command is for a Read, the Z8 will respond by putting 02 on the ZR bus. If the command is for a Write, the response byte will be 03. If a Write/Verify, the response byte will be 04. After the Z8 puts the response byte on the ZR bus to the Host, it asserts BSY, signifying it is now performing the operation. The response byte is driven by U4 to the interface of the Host. 15. The Host checks the response. Because it knows which command it requested, it knows which response byte to expect. Since the response byte is 02, as expected, the Host acknowledges with 55 and raises CMD (it is true when low, so high means CMD is deactivated). - 16. The Command Handshake is now complete. Once the Host raises CMD, the Z8 performs (if necessary) a Seek routine (explained later) to select the proper head and move it over the target track. - 17. If the command is a Write or Write/Verify, then there will be another handshake to transfer the Write data during the Seek routine. - 18. If the command is a Read, then once the proper head is selected and positioned over the target track, and the Seek has been verified, the 28 will perform the Read. Appendices rev. 11-14-83 Page 3.52 200 #### B. Check Header Function #### Check Header Function General Operation For each Read or Write operation, the specific sector must be located and checked. This is accomplished by the the Z8, and the Read/Write Control Logic, during the Check Header function. Before the 28 conditions the logic to start a Read, Write, or Write/Verify operation, it translates the logical block number requested by the Host into target sector information bytes (i.e., head, track, and sector). It then checks to see if the desired block is in the spares table and sets the track, head, and sector accordingly. The Z8 then sets a complete replica of the target header into a specific area of RAM. (For more information on the Seek routine and other firmware routines used in the Pro-File Z8, refer to the Firmware Routines Description.) #### Seek Routine The Seek routine is a firmware routine in the 28. It controls selecting the proper head, positioning the heads, and putting the Read/Write Control Logic in the proper modes for a Check Header function after it has moved the selects If the current block and the last block read or written have the same track and head, the Z8 will exit the Seek routine because the target head is assumed to be positioned over the target track. If the track is the same but the head is different, the Z8 will send out enable signals to the target head, wait 750us, and then exit the Seek routine to perform the Host-requested operation. If the track is different, the Z8 will generate the proper number of stepper pulses on the stepper phase control lines to position the head where it thinks the target track should be. Then it waits for the sector pulse, generated by the Analog PCB when it detects a sector mark. Controller Circuit Description rev. 11-14-83 Page 53 Source: David T. Craig Page 0201 of 0580 202 When the ${\bf Z8}$ sees the sector pulse it starts the State Machine. (For more information on sector headers and Pro-File disk format refer to the Pro-File HDA description in this section.) Block Diagram For Check Header Operation The State Machine, in combination with the PAL, moves each successive byte of the header replica into the SERIALIZER, where they are serialized and shifted out in sync with the incoming NRZRDTA. The target header information and the NRZDTA are compared, and if any difference exists, the State Machine aborts the attempt and resets to wait for the next incoming sector pulse. The process is repeated until either the header matches the image in RAM or a timeout error occurs (the Z8 program is waiting for the "sector done" from the State Machine). If it doesn't see SECTDN within two revolutions, the Z8 will take over and go through an error recovery routine.) If the desired operation is to read a block, the logic will accept the data in from disk and will move it into RAM. If the operation is to write a block, the logic will be conditioned to move the data from RAM to the disk. The circuit description for Check Header function and the Read, Write, and Write/Verify operations are described in the following pages. Controller Circuit Description rev. 11-14-83 Page 55 Source: David T. Craig Page 0203 of 0580 203 Refer to the Controller PCB schematic at the end of this section for the following discussion. ### Check Header Function Component Explanation - 1. After the Command Handshake, if the Z8 firmware has interpreted the command, the first thing it will do is put the location of the target sector (i.e., head, track, and sector) in RAM. The Z8 selects the RAM addresses the same way it did when reading the command bytes in the Command Handshake (with the Address Selectors). - 2. If the target sector is on a different head or track than the ones already selected, the Z8 will perform the Seek routine to the target track (the one containing the target sector). During the Seek routine, the Z8 issues phases from pins 17-20 through U7 and U8 to the Head Stepper motor on the HDA. It issues the exact number necessary to put the heads where it thinks the the target track is (this is a program function of the Z8). - 3. When the head movement is completed, the Z8 enables (loads) the target head. - 4. At this time, the Z8 lowers ZRW and AS to cause the PAL to produce the TIMSEL signal out of pin 12 to the Programmable Counter Timer U33. The Z8 then writes commands to the Programmable Counter Timer U33 to program the following registers: - a. OUT1 register for 555. - b. OUT2 register for 557. c. OUT3 register for 521. The counts are shown in the diagram on the opposite page with the events they are timing. (Continued on the next page.) Appendices rev. 11-14-83 Page 3.56 Source: David T. Craig Page 0204 of 0580 ## 204 5. The Z8 then causes the SEL signal out of pin 17 of the PAL to be generated. This enables the RAM to gate the contents of address 0 (since that is the address in the Address Counters at this time) onto the ZR bus to the inputs of Ul4, the Deserializer Shift register. Note: Addresses 0, and 1 both contain all 0's. The sector location information begins with the track at address 2. - 6. The 28 then generates the START signal to: - a. Remove the reset to enable the CRC Error FF. - b. Remove the reset to enable the storage FFs for the Programmable Counter/Timer in U34. - c. Remove the reset to enable pin 13 of U39 the System Clock Selector. - d. Remove the reset to enable the latches in the BYTC (U30) and RWTC (U38) State Machine. - 7. When the Analog PCB detects a sector mark (gap) on the target track, it generates the SECTOR signal to pin 30 of the Z8 and pin 15 of U30, the latch for the BYTC State Machine, causing the State Machine to advance from sequence 0 to sequence 1. (Continued on the next page.) Appendices rev. 11-14-83 Page 3.57 Source: David T. Craig Page 0205 of 0580 205 # STATE MACHINE SEQUENCE DIAGRAM # STATE MACHINE PHASE (BIT TIME) DIAGRAM Appendices rev. 11-14-83 Page 3.58 Source: David T. Craig Page 0206 of 0580 206 #### State Machine Operation - 8. Each State Machine is composed of a ROM device and a latch. The inputs to the ROM select the ROM address to be read out. The bits in the contents of this address are used as control signals or select inputs to the latch. The outputs of the latch feed back around to the inputs of the ROM to select the next address in the sequence. - 9. Various events (i.e., SECTOR, ENDCOUNT, DATA, etc.) determine the sequence of the ROM addresses to be read out and, therefore, which control signals will be enabled. These control signals regulate the sequence of functions that must occur for each operation. The sequences for the Check Header function are discussed under that header. - 10. Refer to the diagram at the top of the opposite page for the following discussion. It shows the sequence of State Machine paths and the conditions that determine the next path to be selected. For example, the diagram shows that during sequence 0, the critical signal that the Controller PCB is waiting for is SECTORSYNC (sector mark). - 11. Once that signal occurs, depending on whether RDHDR is true or not (RDHDR is only true while formatting the HDA), a path is selected to sequence 1 or 5. During normal operation, RDHDR is low, so the State Machine advances to sequence 1. At sequence 1 the critical signal is ENDCOUNT. When ENDCOUNT occurs in sequence 1, the only path is to sequence 3, etc. This diagram is true for all operations. During the Command Handshake, the Z8 interprets the command bytes from the Host to determine the operation requested. (Continued on the next page.) Appendices rev. 11-14-83 Page 3.59 207 # STATE MACHINE SEQUENCE DIAGRAM # STATE MACHINE PHASE (BIT TIME) DIAGRAM Appendices rev. 11-14-83 Page 3.60 Source: David T. Craig Page 0208 of 0580 ## 208 - 12. As an operation is implemented, the Z8 and PAL control the selection of sequence paths with their inputs to the State Machine (i.e., A4, RDHDR, CHKHDR/ENAl, DRW). - 13. The program in the Z8 selects these signals depending on which operation it is trying to implement. - 14. The State Machine Phase diagram at the lower part of the opposite page shows when (at which bit time in the processing of a serial byte) a signal may occur during a sequence. For example, during sequence 7, every time a complete byte of data has been processed (QC goes high, indicating 8 clocks have been counted by the Divide-by-8 Counter U22) at clock 1 of the next byte, an SSTRB signal is generated out of pin 15 of U38. Although neither of the diagrams shows the sequence during which SSTRB will occur, the lower diagram does show the bit time of a byte when it might become active. (Continued on the next page.) Appendices rev. 11-14-83 Page 3.61 Source: David T. Craig Page 0209 of 0580 210 - 15. Sequence 0 is a wait state for the State Machine. When the SECTOR signal occurs to pin 13 of U30, it produces a low to pin 19 of U37, selecting the ROM address that advances the RWTC State Machine to sequence 1. - 16. During sequence 1, the GO signal is generated out of pin 14 of U37 (see Timing Diagram). The GO signal enables the Divide-by-8 Counter to count clocks. During sequence 1 the clocks selected by the System Clock Selector U39 are those generated by the crystal oscillator. - 17. To review what has happened so far: We are still in the Check Header function. The heads have finished their movement, and the proper head has been enabled. Now the 28 wants to confirm that the target head is in fact over the target track, which it does $\bar{b}y$ reading three consecutive sector headers and comparing their header information with target head and track information currently in RAM. After the initial setup, the Controller PCB waited for the Analog PCB to detect a sector mark that signified that the beginning of a new sector was about to pass under the selected head. When the SECTOR pulse occurred, it advanced the State Machine to sequence 1. The sector header is the first part of the sector after the first sync byte field. The 28 doesn't want to read the first two bytes of any sync byte field because they are unreliable. So sequence 1 is simply a control state to hold the circuitry for the first two sync bytes, in case spurious data occur during that period. (For more information on the composition of a sector, refer to the Format description of the Pro-File HDA Description in the Appendices section.) 18. Every time the Divide by 8 counter counts 8 bit-clocks it produces a positive transition on its QC output. This signal goes to the clock input of the Programmable Timer (U33), which decrements each of its counters once for every pulse. Appendices rev. 11-14-83 Page 3.63 ## 212 - 19. Each QC also goes to the State Machine, causing U38 to produce the SSTRB pulse out of pin 15 at phase 1 of the following byte. This signal goes to the PAL on pin 7, causing it to increment to the next Address. - 20. The SSTRBs from the first two sync bytes cause the Address Counters UlO, 16, and 17 to increment to a count of 1 (from 0). This causes the signal A1 to go to pin 5 of U29, causing the State Machine to produce the ENDCOUNT signal putting the State Machine in sequence 3. - 21. Sequence 3 allows time for the VCO on the Analog PCB to sync to the sync byte field. While this is happening the Controller PCB is waiting for data (in this case the sector header). In sequence 3, the RDGT signal (pin 7 of U38) is generated by the State Machine. This signal goes to the Analog PCB to enable it to convert the analog signal from the HDA head into NRZ data (NRZRDTA) and to generate RDCLKs in sync with this data. RDGTA also goes to the System Clock Selector U31 and U32 to select RDCLKs as the system bit clock. - 22. Sequence 3 also causes the GO signal to go low from pin 14 of U37 in the State Machine. The low GO signal resets the Deserializer chip (U14). This condition causes a low output from pin 17 of Ul4, which goes to pin 13 of the Exclusive Or in U28. - 23. Pin 12 of U28 is NRZRDTA. At this point in reading the sector, NRZRDTA should be all 0's (because the sync bytes are all 0's), so pin 12 should be low, which, along with the low pin 17, results in a low out of pin 11 of U28. - 24. Pin 11 remains low until the sync byte just before the sector header (which contains a 1) occurs; now the inputs to the Exclusive Or are different, making DATA signal on pin 11 high. Appendices rev. 11-14-83 Page 3.65 214 25. As can be seen from the State Machine Sequence diagram, the high DATA signal is the condition that causes the State Machine to advance to sequence 7. The purpose of sequence 7 is to read the sector header field of a sector. Recall that the Address Counters are pointing to RAM address 01, which contains 0's. The Z8 has the first byte of the target sector header field waiting on the ZR bus (this byte is always a 00). - 26. When the State Machine advances to sequence 7: - a. The LDSDS out of pin 12 of U29 goes high, causing the Deserializer to load the 00 from RAM address 1 (the first byte in the sector header should also contain a 00). - b. Every QC output from the Divide-by-8 Counter (happens once per byte) to pin 3 of U29 will cause pin 8 to go high, causing the SSTRB signal out of pin 15 of U38. - c. The CHKHDR signal out of pin 10 of U38 goes high, enabling the PAL to pass SSTRBs through as Address Counter increment pulses to the Address Counters. - 27. NRZRDTA that comes in during sequence 7 should be sector header information. The first byte of target sector header information in the Deserializer is clocked out in sync with the NRZRDTA coming in from the Analog PCB. These two signals are compared in the Exclusive Or in U28. If any bit does not match up, this gate will output high causing the State Machine to generate a SECTDN signal out of pin 2 of U30, resetting the Read/Write Control circuitry to sequence 0. 28. If the first byte is correct, the QC output from the Divide by 8 chip U22 will cause an SSTRB to increment the Address Counters at bit 1 of the next byte. This signal puts the next byte of target sector location information on the ZR bus. At bit 7 of that byte, if the comparison is still OK, LDSDS will occur to load the second byte of target sector location information into the Deserializer chip. Appendices rev. 11-14-83 Page 3.67 Source: David T. Craig Page 0215 of 0580 # 216 29. The 16 bytes of target sector header information were stored in 16 memory locations of RAM. When the Address Counters increment past 16, A4 goes high, which signifies to the State Machine that a complete sector header has been checked and must be OK because the DATA signal must have remained low. Signal A4 causes the State Machine to advance to sequence 5 or 6, depending on whether DRW is high or low, which depends on which operation the Host requested. 30. If DRW is high, the State Machine will go to sequence 6 for a Read operation. If DRW is low the State Machine will go to sequence 5 for a Write operation. Appendices rev. 11-14-83 Page 3.69 Source: David T. Craig Page 0217 of 0580 218 ## 3. Operations The first part of all operations is the Check Header function (previously described). The following discussions deal with each of the three Pro-File operations after the Check Header function has been performed, which is after sequence 7 of the Read/Write control circuitry. Once the Seek to the target track is confirmed, and the 28 has a reference on where the target track is, the Z8 will condition the circuitry for the execution of an operation a number of sectors before the target sector, called the sector interleave (because the data come off the disk too fast for the circuitry on the Controller PCB to process the target sector's header). The sector interleave is specific to the Host operating system using the Pro-File and to the operation being performed. After the sector interleave, when the sector pulse for the target sector occurs, the 28 enables the control logic to activate the circuitry for the operation requested. 3.1.1 Read Operation General Explanation During a Read operation, after the Check Header function, NRZDTA enters through the Read Data MUX into the Deserializer. In the Deserializer, NRZDTA is converted to parallel bytes, and then transferred to the Deserialized Data Register, held momentarily, and gated through the Data In MUX to the RAM. When the sector (block) is complete, the control logic tells the Z8 to lower the BSY line. It does, and then the Host uses PSTRB to strobe the data out of RAM through the output buffer to the Host interface PCB. The RAM address counter has been set to the beginning of the data, and each strobe sent by the Host increments the Address Counters to the next address. Appendices rev. 11-14-83 Page 3.71 Source: David T. Craig Page 0219 of 0580 219 IF THE HEADER READ, IS NOT FROM THE TARGET SECTOR, THE HARDWARE CONTINUES TO READ SECTOR HEADERS UNTIL THE TARGET HEADER IS FOUND. BSY, AND START REMAIN HIGH. Appendices rev. 11-14-83 Page 3.72 Source: David T. Craig Page 0220 of 0580 220 Refer to the Controller PCB schematic at the end of this section for the following discussion. # 3.1.2 Read Operation Component Explanation - 1. As can be seen in the State Machine Sequence diagram after sequence 7 (the end of the Check Header function), if DRW is high (indicating the command bytes from the Host specified a Read operation) and A4 goes high (indicating all 16 bytes of the sector header field have been checked), the State Machine will advance to sequence - Sequence 6 holds the Read/Write control circuitry in a wait state during the first two bytes of the sync byte field preceding the data field. These first two bytes can contain spurious data that could cause an error. - 3. Because RDGT is not produced in sequence 6, the System Clock Selector U31 and U32 selects clocks from the crystal oscillator. - 4. After two bytes of these clocks have been received, the Al signal from the Address Counters goes true, to pin 5 of U29. This causes the BYTC (Byte Control) State Machine to produce ENDCOUNT out of pin 10 of U30, putting the State Machine in sequence 4 (as shown in the State Machine Sequence diagram). - 5. Sequence 4 allows time for the VCO on the Analog PCB to sync to the sync byte field. While this is going on the Controller PCB is waiting for data (in this case the data field). In sequence 4, the RDGT signal (pin 7 of U38) is generated by the State Machine. This signal goes to the Analog PCB to enable it to convert the analog signal from the HDA head into NRZ data (NRZRDTA) and to generate RDCLKs in sync with this data. RDGTA also goes to the System Clock Selector U31 and U32 to select RDCLKs as the system bit clock. - 6. Because the GO signal is low again at the beginning of sequence 4 the Deserializer chip (U14) is reset. This condition causes a low output from pin 17 of U14, which goes to pin 13 of the Exclusive Or in U28. Appendices rev. 11-14-83 Page 3.73 Source: David T. Craig # 222 - 7. Pin 12 of U28 is NRZRDTA. At this point in reading the sector, NRZRDTA should be all 0's (because the sync bytes are all 0's), so pin 12 should be low, which, along with the low pin 17, results in a low out of pin 11 of U28. - 8. Pin 11 remains low until the sync byte just before the data field (which contains a 1) occurs; now the inputs to the Exclusive Or are different, making DATA signal on pin ll high . - 9. As can be seen from the State Machine Sequence diagram, the high DATA signal is the condition that causes the State Machine to advance to sequence 5. - 10. Sequence 5 generates either RDGT or WTGT, depending on the level of DRW. If DRW is high, the command bytes from the Host have stipulated a Read operation, so RDGT will remain high. If DRW is low, WTGT will occur. Sequence 5's function during Read is to read the data field from the target sector on the HDA. - 11. The GO signal goes high at sequence 5 to enable the Divide-by-8 Counter U22 to begin counting RDCLKs again and to produce QC pulses once per byte to decrement the counting registers in the Programmable Counter/Timer (U34). - 12. Since NRZDTA is in serial form coming from the Analog PCB, it must be deserialized and sent to RAM in bytes. This is done by the Serial/Deserial Shift Register Ul4. NRZRDTA comes in to pins 5 and 6 of the Read Data MUX U6. Because this is a Read operation, pin 2 is low, enabling the Read Data MUX to pass serial NRZRDTA to pin 11 of the Serial/Deserial Shift Register Ul4. - 13. The NRZRDTA is clocked into the Serial/Deserial Shift Register Ul4 with RDCLKs at pin 12. At the phase 0following a byte of data, the contents of the Serial/Deserial Shift Register Ul4 are enabled to merge onto the ZR bus by the signal SDSOE from pin 13 of the PAL U27. This timing relationship can be seen on the State Machine Phase diagram (shown in the Check Header function circuit description). rev. 11-14-83 Page 3.75 Appendices Source: David T. Craig Page 0223 of 0580 # 224 - 14. LDSBF (from pin 12 of U29 the State Machine) also occurs at phase 0, to load the byte from the ZR bus into the Deserialized Data Register U21. - 15. Once U21 contains a byte of received data, its contents merge on the SB bus. The Data In MUXers Ul3 and U21 are enabled by the high MSELl signal from the Z8 to pin 1 to select the SB bus, and so pass the byte to the data input of the RAM. - 16. In sequence 5, the RWTC State Machine produces SSTRBs each phase 1 from pin 15 of U38. This happens once per byte, triggered by the inputs from the Divide-by-8 Counter U22. - 17. During sequence 5, the PAL U27 generates the low RAMWRITE signal, on pin 16, to the RAM each time SSTRB occurs. This enables the byte of information from the Data In MUXers Ul3 and U21 to be stored into the address currently being selected by the Address Counters. - 18. The SSTRBA signal also increments the Address Counters U16, U17, and U10 after storing each byte received from the disk. CRC Operation - 19. Prior to sequence 6, during the Check Header function, the 28 reprogrammed the Programmable Counter/Timer (U34) so that: - a. OUT1 register contained 553. - b. OUT2 register contained 555.c. OUT3 register contained 19. The Programmable Counter/Timer (U34) is enabled to decrement all of its registers each time an SSTRB occurs, but only while GO is high. During the sequences of the first part of the Read operation (including the Check Header function), each of these registers is decremented by the following amounts. | Sequence | Amounts | |----------|---------| | | | 16 rev. 11-14-83 Page 3.77 Appendices Source: David T. Craig Page 0225 of 0580 # 226 This brings the amounts in each register to: - a. OUT1 register contains 535. - b. OUT2 register contains 537. - c. OUT3 register contains 1. - 20. The second byte received during the data field of sequence 5 is never data but instead is a 00. The GO signal is high for this byte, so the SSTRB generated during its reception also decrements the registers in the Programmable Counter/Timer (U34). This causes the OUT3 register to arrive at 0, causing CLRCRC to go high on pin 1 of an Exclusive Or gate in U28. - NOTE: Although the three U28 gates inputting to the CRC circuit are shown to be exclusive Ors, they are being used as inverters. - 21. The other input to this gate (pin 2) is constantly high. Having two highs causes the gate to output a low, removing the high reset on pin 4 of the CRC Generator/Checker U35. - 22. NRZRDTA is going to pin 11 of the CRC Generator/Checker U35. This chip is now enabled to use its internal logic to process each received bit from the data field and reflect its CRC status with its output on pin 13. If an error occurs, pin 13 of the CRC Generator/Checker U35 will go high, setting the CRC Error FF U36, which produces the low CRCERR signal to pin 30 of the Z8. The Z8 then knows it has faulty data, and will perform an error recovery routine. (For more information on the error recovery routines used in the Pro-File's firmware, refer to the Appendices section of this manual.) 23. The OUT1 register is also decremented by the second byte in the data field, bringing its contents to 534. After the remaining 532 bytes of data, and the two CRC bytes are read from the data field, the OUT1 register completes its count causing: - a. The CRC Generator/Checker U35 to freeze its status. - b. The State Machine to generate ENDCOUNT and advance to sequence 2. Appendices rev. 11-14-83 Page 3.79 Source: David T. Craig Page 0227 of 0580 # Apple /// Computer Information • Doc # 78 • ProFile Hard Disk Repair Info Controller PCB Circuit Descriptions 228 24. Sequence 2's purpose is to hold the Read/Write Control Logic in a static state until the Z8 is finished processing the CRC status. This happens when OUT2 decrements to 0, causing the State Machine to output the SECTDN pulse. This pulse accomplishes two functions: - a. It resets the Programmable Counter/Timer (U34). - b. It goes to pin 31 of the Z8. When the Z8 receives the SECTDN pulse, it samples the CRC status from U35 and, when finished processing, lowers the START signal, causing the Read/Write Control circuitry to reset to sequence 0. Appendices rev. 11-14-83 Page 3.81 Source: David T. Craig Page 0229 of 0580 230 **3.2.1** Write Operation General Explanation There are 3 handshakes for the Write or Write/Verify operations. After completing the Command Handshake (the first handshake), the Z8 conditions the Controller PCB logic to accept a block of write data from the Host. During the second handshake, the Host strobes each byte of data into the RAM with PSTRBs. Then the Z8 and Read/Write Control Logic read the parallel write bytes out of the RAM to the Serial/Deserial Shift Register Ul4. Ul4 is then enabled to shift these bytes out in serial to the Analog PCB. During a Write operation the WTGT signal enables the Analog PCB to convert this serial NRZ data to MFM data and then to an analog signal to be written on the disk surface. Once the Write is complete the Pro-File will go through yet another handshake. The third handshake allows the Pro-File to send the completion status for the operation back to the Host. Appendices rev. 11-14-83 Page 3.83 Source: David T. Craig Page 0231 of 0580 232 Refer to the Controller PCB schematic at the end of this section for the following discussion. ### 3.2.2 Write Operation Component Explanation The following discussion explains the Write operation only so far as it differs from the Check Header function. - As can be seen in the State Machine Sequence diagram following sequence 7 (the end of the Check Header function), if DRW is low (indicating the command bytes from the Host specified a Write operation), and A4 goes high (indicating all 16 bytes of the sector header field have been checked) the State Machines will advance to sequence 5. - 2. Sequence 5 will generate either RDGT or WTGT depending on the level of DRW. IF DRW is low, that means the command bytes from the Host stipulated a Write operation so WTGT will go high. If DRW were high RDGT would occur. Sequence 5's purpose during a Write is to read the parallel write data out of RAM (this data was sent to the Pro-File during the second handshake of a Write operation), convert it to serial NRZ write data, and send it to the Analog PCB in sync with the system clock from the crystal oscillator. - 3. Because RDGT is not being generated the System Clock Selector U31, and U32 will select the output from the crystal oscillator to use as the system bit clock for the rest of the Write operation. - 4. The WTGT signal, pin 5 of U30, is generated by the State Machine as a result of being in sequence 5. This signal goes to the Analog PCB to enable it to convert the serial NRZ write data to serial MFM data, and then to an analog signal for the selected head to store on the disk surface. - 6. After sequence 7 the Address Counters will be set to the RAM address of the first byte in the data block to be written. The write data block in RAM is composed of 22 bytes of zeroes, then a sync byte containing a 1, then another zero byte, and then 532 bytes of data. During sequence 5, each write byte is read sequentially from the RAM. Appendices rev. 11-14-83 Page 3.85 Source: David T. Craig Page 0233 of 0580 234 7. Because the State Machine is in sequence 5, the Divideby-8 Counter U22 will be enabled by the high GO signal to count system bit-clocks (since RDGT is low the System Clock Selector U39 will select the clocks from the Controller PCB crystal oscillator). Each QC output from the Divide-by-8 Counter U22 will produce an LSDS output from pin 12 of U29 in the State Machine to pin 19 of the Serial/Deserial Shift Register U14 enabling it LOAD a byte of write data from the ZR bus. As can be seen on the State Machine Phase diagram (shown in the Check Header function circuit description) LDSDS occurs at phase 7 of a byte to load the next byte from the bus. - 8 In sequence 5 the RWTC State Machine will produce SSTRBs from pin 15 of U38. This happens once per byte as a result of the inputs from the Divide-by-8 Counter U22. - 9. As can be seen on the State Machine Phase diagram, SSTRBA will be generated at phase 1 following the generation of LDSDS. And so the SSTRBA signal increments the Address Counters U16, U17, and U10 after the Serial/Deserial Shift Register U14 has accepted one from the ZR bus. - 10. Prior to sequence 5 of the Write operation, during the Check Header function, the 28 reprogrammed the Programmable Counter/Timer (U34) such that: - a. OUT1 register contained 573. - b. OUT2 register contained 575. - c. OUT3 register contained 39. Programmable Counter/Timer (U34) is enabled to decrement all of its registers each time an SSTRB occurs, but only while GO is high. During the sequences of the first part of the Write operation (including the Check Header function), each of these registers was decremented by the following amounts. Sequence Amounts 1 2 7 16 This brings the amounts in each register to: - a. OUT1 register contains 555. - b. OUT2 register contains 557. - c. OUT3 register contains 23. Appendices rev. 11-14-83 Page 3.87 Source: David T. Craig Page 0235 of 0580 236 **CRC** Operation 11. After the 22 sync bytes (which were zero's), and the "one" sync byte (which was a one), have been read out of RAM the OUT3 register will be decremented to 0, and the OUT1 register to 532. The OUT3 register reaching 0 causes a high from pin 15 of U34, removing the high Reset signal to pin 4 of U35 the CRC Generator/Checker. This chip is now enabled to process write data bits to produce 2 unique CRC bytes for the 532 bytes in the data field. 12. Meanwhile the Read Data MUX U6 is enabled by the high WTGT signal to select the serial output of the Serial/Deserial Shift Register Ul4 at pin 19. This serial write data is sent up to pin 11 of the CRC Generator/Checker U35. When 532 bytes have been counted, the OUT1 output from the Programmable Counter Timer U33 goes high causing the FRZN/WRTCRC signal to pin 5 of U28. - NOTE: Although the 3 U28 gates inputting to the CRC circuit are shown to be exclusive Ors, they are being used as inverters. - 13. The resultant low on pin 10 of U6 causes the CRC Generator/Checker U35 to change modes to freeze the CRC generator, and clock out the 2 CRC bytes as NRZ Write data. - 14. The OUT1 signal also goes to pin 19 of the BYTC State Machine to produce ENDCOUNT causing the State Machine to produce SECTDN and advance to sequence 2. - 15. SECTDN goes to pin 31 of the Z8 to tell it that the processing of the sector is finished, and sequence 2 simply holds the Read/Write Control circuitry until the 28 can process the SECTDN signal and drop the START signal. Otherwise spurious data could be stored in RAM. Appendices rev. 11-14-83 Page 3.89 # Apple /// Computer Information • Doc # 78 • ProFile Hard Disk Repair Info Controller PCB Circuit Descriptions 237 # 3.3.1 Write/Verify Operation General Explanation The Write/Verify operation is a combined Write and Read. The data comes from the Host in the same way as it does for a Write. When the Write operaation is complete the Z8 goes through a verification of the data written, much like a Read operation. Appendices rev. 11-14-83 Page 3.90 Source: David T. Craig Page 0238 of 0580 240 #### ANALOG PCB ## 1. General Explanation of the Analog PCB Write Circuits For the following discussion refer to the Overall Block Diagram of the Analog PCB on the opposite page. The Analog PCB serves as the interface between the Controller PCB and the Seagate HDA. It consists of two main parts Write circuitry and Read circuitry. The one Head Selector is shared for both Read and Write. The Write circuitry consists of the following circuits: - a. Non-Return to Zero () to Modified Frequency Modulation (MFM) Write Encoder and Data Precompensater. - b. Write Driver. - c. Head Select Matrix. ### 1.1 NRZ to MFM Write Encoder and Data Precompensator Circuits Prior to any operation (Write or Read), the 28 on the Controller PCB sends the head select matrix inputs to cause it to select one of the four heads (disk surfaces). During a Write operation, serial NRZ WRTDATA (Non Return to Zero simply means the data signal will be high when a one and low when a zero with no clocks) is converted to MFM data by the MFM Encoder/Precompensator. (For information on Modified Frequency Modulation refer to the MFM explanation at the end of this discussion.) The Write Driver converts the MFM write pulses to alternating head current on the selected head. If the data is being written on an inside track (tracks 128 to 152), the MFM write transitions will be peak shift precompensated, and the Write current will be reduced from 24 ma to 19 ma. The Write Driver and Head Select Matrix are covered in more detail later. For information on Write Precompensation refer to the Write Precompensation explanation at the end of this discussion. Appendices rev. 11-14-83 Page 3.93 Source: David T. Craig Page 0241 of 0580 242 # 2. Component Explanation of the Analog PCB Write Circuits Refer to the diagram on the opposite page for the following discussion. Some minor component value changes exist from this drawing to the production version. But, the illustration should be adequate for training purposes. The component population of the Write circuitry is quite small. However, the PAL (programmed array logic-U28) makes up for that by having a large amount of logic. #### 2.1 Clocking- The 10MHz 2F signal is the master clock frequency from the crystal oscillator on the Controller PCB. It is divided to 1F (5MHz) by U2 (a simple divide-by-two stage). The 1F signal is the bit shift clock for the precompensation shift register. It is also used to keep the VCO synchronized to write data during the Write operation. The 2F signal provides the clock enable signals necessary to perform precompensation on the data as it is output from the PAL. ## 2.2 Precomp Shift Register U29 U29 has been externally wired into a shift register. Its output shift pattern provides five of the inputs to the PAL. For clarity, the following is a sketch of U29 and its signals with the "in's" on the left and the "out's" on the right. It makes things easier if you visualize the data stream in reference to the bit named "T". The TMx signals are what T was one or two clocks ago, and the TPx signals are what T will be in one or two clocks. The initial NRZ data is clocked into ql, the next clock places ql at q2, and so forth. The whole intent is to give the PAL a window on the data stream to make the encoding and the early/late/ontime precompensation decisions discussed earlier. Appendices rev. 11-14-83 Page 3.95 Source: David T. Craig Page 0243 of 0580 244 ### 2.3 PAL Chip U28 U28 is a custom array of logic designed specifically for this circuit. It consists of a huge array of AND/OR gates feeding each D input of its output register. The PAL chip is involved in two functions: - To convert the NRZ digital stream into a stream of pulses conforming to the rules of MFM as stated earlier. - To provide the gating signals to advance, retard or leave alone the stream of write data pulses called "UCWDTA" (uncompensated). As a bit is being processed through the PAL chip, its internal array of AND/OR gates receives inputs from the Precomp Shift Register U29, telling the PAL which bit combinations surround that bit. This enables the PAL to determine when to generate a transition to convert it to MFM data and what type of precompensation (if any) to provide. # 2.4 Precompensation Gating U27 UCWDTA goes to the input of a gate enabled with ELY (Early) and to a delay line DLY2, which delays the pulses approximately 15 ns per stage. The outputs of the delay line are partial enables to the OT (Ontime) and LTE (Late) gates respectively. If there is no precompensation, (such as when writing to the outer tracks), the signal OT gates the first delayed data line to the WXS line. If precomp'ing determines that the data transition needs to be advanced, then the ELY signal will gate UCWDTA to the WXS line; and if the signal needs to be retarded, the signal LTE will gate the second delay of data to the WXS line. DLY2 provides the amount of delays needed for each type of precompensation. Only one signal (UCWDTA, ELY, OT, or LTE) can be true at any one time. Appendices rev. 11-14-83 Page 3.97 Source: David T. Craig 246 2.4 Precompensation Gating U27 (continued) The following timing diagram might help make this more clear. | UCWDTA | | . ' | 1 1 | • | ٠. | | | | • • | • | • | ١. | | | | | | • | ٠, | • | • • | • | | | | | | | | • 1 | • • | ŧ | ١. | | • • | | 1 | • • | 3 1 | ٠, | | | | |----------|---------|-----|-----|---|-----|---|-----|---|-----|---|---|-----|---|-----|-----|---|-----|---|-----|---|-----|---|-----|-----|---|-----|---|---|-----|-----|-----|---|-----|---|-----|-----|---|-----|-----|----|-----|---|---| | DLY (5) | | | • • | ٠ | • • | | | | . ' | • | • | • • | • | | | | | | | | • • | • | ١, | | | | | | | • ' | • • | 1 | | • | | | | • • | | • | ٠. | | | | DLY (9) | | | . ' | • | • • | 1 | | • | | • | | 1 1 | 1 | | | • | | • | | • | | | • • | ١. | • | | • | | • | • | ٠, | 1 | • • | • | | | • | • 1 | 1 1 | • | | • | | | OT | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | ELY | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | LTE | • • • • | • • | • • | • | • • | • | • • | • | • • | • | • | • • | • | • • | • • | • | • • | • | • • | • | • • | • | • | • • | • | • • | • | • | • • | • | • • | • | ١. | • | • • | . • | • | • | • | • | • • | • | | | WXS(pred | cmp) | | | | ٠, | • | | | | | • | . , | 1 | | ٠. | | | | | | | | | | • | | | | | | | | | • | | ٠. | | • • | | • | | ı | • | | WXS(nor | n) | | | | . • | • | | • | | | | . • | | • | ٠. | • | | | | | | | | | • | | | | | | | • | ٠. | • | . 1 | ٠. | | • | | • | • • | | 1 | NOTE: this diagram is for training purposes and does not necessarily conform to the rules of precomp....OK? The leading edge of the WXS signal is the working edge that toggles the WXS FF. The slight shift of timing between the precomp and unprecompensated signal is enough to increase Read data recovery by several magnitudes. - 2.5 Miscellaneous Circuits U30 - These drivers shape the TRACK 0 sensor signal and the INDEX pulse from the HDA. The Track 0 circuit forms a noise latching function too (the source signal is pretty ragged). - 2.6 Write Current Gating Ul, U2, U3, U31 Each WXS pulse from the precomp gating circuit toggles the WXS FF, U2. The result is a divide by two function. The output levels of the WXS FF are level shifted by the first set of transistors in Ul. The remaining transistors comprise a constant currentswitching network. These transistors are turned on and off depending on the state of the WXS FF. During Formatting, at the end of every sector the Z8 on the Controller PCB directs the Analog PCB to write a sector mark. It does this by putting a constant low on pin 13 of the WXS FF to clamp it in the reset state for a 10-byte period. Each time this happens, the heads output a DC level (no transitions) for a field (10 bytes long), creating a sector mark. Appendices rev. 11-14-83 Page 3.99 Source: David T. Craig Page 0247 of 0580 248 ## 2.6 Write Current Gating (continued) A string of zeros would not create the DC level because they would be converted by the MFM encoder to a 5 MHz signal at the heads. The Z8 causes WTGT to go low and turns on the current switching circuit when it wishes to perform a Write operation. WTGT (Write Gate), when inactive (high), kills both sides of the level shifter and, therefore, turns off both sides of the current source, effectively killing all write current. The signal PRECOMP-LOCUR is produced by the Z8 to cause a reduction of write current to the heads when writing to the inner tracks (128 to 152). Normal write current is about 24 ma. But, in the inner tracks it is reduced to slightly less than 20 ma because the bits are packed closer together. The POWEROK signal is generated by the power supply. If it goes low that means that the power supply has detected a power problem. If the POWEROK signal does go low, this biases pin 13 of a transistor in U31 to turn it on inhibiting any write from taking place. # 2.7 Head Selection U4 Head selection is done by U4 (7445, one of ten decoder). The signals HSO and HS1 are code outputs from the Z8 to select the proper head (00 selects head 0, 01 selects head 1, 10 selects head 2, and 11 selects head 3). Only one head can be selected at a time. The heads are center tapped, and the center is connected to the 7445 to create a current path for Reading or writing. Appendices rev. 11-14-83 Page 3.101 250 ### 3. GENERAL EXPLANATION OF THE ANALOG READ CIRCUITRY The following circuits are included in the Read circuitry: - 1. Preamplifier and Automatic Gain Control (AGC). - 2. Read Detector and Sector Mark Detector. - 4. Phase Locked Loop (PLL) consisting of: - a. Phase Detector. - b. VCO Charge Pump. - c. Voltage Controlled Oscillator. - 5. MFM to NRZ Read Decoder. During a Read operation, the preamplifier amplifies the low level (.6 to 2.0 mV) signal from the selected head to a 200 mV. The analog read signal is then filtered and amplified to a fixed 1.0 V output signal by the AGC circuit. This analog read signal is fed to the differentiator and gated detector to derive the MFM read pulses. The PLL (Phase Lock Loop) synchronizes its VCO to the MFM read pulses and provides the clock for the MFM to NRZ data converter. The serial NRZ data and clock are sent back to the Controller for deserialization. During format operation, when the initial sector identifier information is written on the disk, sector boundaries are written as DC-erased 10 byte fields. During a Read operation, the sector boundary detector looks for the absence of Read signals for about 10 ms (to detect the DC-erased 10 byte field). When it detects one, it sends a sector pulse to the Z8 on the Controller PCB. Appendices rev. 11-14-83 Source: David T. Craig Page 0251 of 0580 Page 3.103 252 #### 4. Component Explanation of the Analog Read Circuitry ## 4.1 Analog Preamplifier, and AGC (Automatic Gain Control) Circuits The Read circuitry is always on. However, because of the amplitude of the write signal through the heads, it goes into saturation during the Write operation and does not reliably recover the data. During Reading (not writing), the selected head develops a signal on the $-x\ -y$ lines. This signal is about 1 mv and cannot usually be seen with conventional techniques. Probing dampens the signal and induces so much noise that the signal is obliterated. So don't expect to see data directly from the heads. The read signals from the head are brought to the first stage preamplifier, ${\tt U5.}$ The devices used here are ECL (Emitter Coupled Logic), a high speed logic family. Each stage of the preamplifier has a gain of 12. This means that the approximate 1 mV head signal leaves the first stage at about 18~mV. The signal is amplified again, and leaves this stage at about 200~mV. That's nice because the filter network (L1, L2, C8, C9) attenuates the signal about 60%. The analog read signal then enters the AGC (Automatic Gain Control) circuit. FET transistor Q3 controls the reference voltage to to the amplifier U6. The input to the gate of Q\$ comes from the final output of the AGC circuit. Appendices rev. 11-14-83 Page 3.105 254 If the output goes up, the bias on Q3's gate will cause it to increase the reference voltage on pins 11, and 4 of U6. This will cause the output of U6 to decrease. If the output from the AGC circuit goes down, the bias on Q3's gate causes it to decrease the reference voltage on pins 11, and 4 of U6. This causes the output of U6 to increase. The result of this process is that the AGC circuit is continually striving to regulate the input from the heads into a constant output level. However, it takes a certain amount of time for this regulation to take place. That is why if you monitor TPl or TP2 on the Analog PCB while Reading, you will see an increase in signal amplitude at the beginning of each sector. During a sector mark, there is little amplitude at pin 7 of U8 (the final output of the AGC circuit), so Q3 is conducting, putting the reference voltage for U6 at a very low level. The low reference voltages on pins 11, and 14 of U6 cause it to amplify at maximum gain. When the selected head starts receiving the next sector, U6 is still at maximum gain, so the sector read signal leaves U6 at a comparatively high amplitude. Since the gain for the rest of the amplifiers in the AGC circuit is constant, this high output from U6 is amplified even further. When pin 7 of U8 finally goes up, it causes Q3 to conduct less. This increases the reference voltage to U6, which decreases the output of U6, bringing the output of the AGC circuit back to its normal level. This whole process occurs after every sector mark, and can be seen at TPl and TP2 as a flare in amplitude at the beginning of each sector. Appendices rev. 11-14-83 Page 3.107 Source: David T. Craig Page 0255 of 0580 **4.2** Read Detector, and Sector Detector Circuits The Read Detector detects transitions in the analog MFM read signal and produces a 50 ns pulse for each one that occurs. The result is called digitized data. U9, U10, and DLY1 set U11 every time a transition occurs. C20, R65, and R66 make up an RC network that allows the set output of Ull to keep pin 9 of an Exclusive Or in Ul0 above its threshold and pin 7 below its threshold until the RC network's time constant is satisfied (TC = 50 ns). This process produces a 50 ns digitized data pulse (called RDPLS) out of pins 10 and 11 of this Exclusive Or for every transition in the received analog signal. (Refer to the timing diagram on page \* for an example of the timing relationship between the analog MFM read signal, digitized data, MFM data, and NRZ data.) The RDPLS signal is actually digitized MFM data, so it needs to be converted to NRZ data and to be sent to the Controller PCB. It is also used to detect Sector Marks. The output of pins 12 and 13 are sent down to the Sector Mark Detector. The RDPLS is gated down through transistors on Ul2, which pump a charge to C23 at the input of Ul3. If there are no read pulses for approximately 10 ms (this can only happen during a sector mark), R71 slowly discharges C23 and causes U13 pin 12 to go high. This signal is integrated to pin 7 of Ul3, which produces a 2 us pulse, called SECTOR, to the Z8 on the Controller PCB to notify it that a sector mark has occurred. When read pulses reappear (as in the sync field at the beginning of a sector), C23 quickly recharges and U13 pin 12 goes low again. Appendices rev. 11-14-83 Page 3.109 Source: David T. Craig Page 0257 of 0580 257 Appendices rev. 11-14-83 Page 3.110 Source: David T. Craig Page 0258 of 0580 258 Source: David T. Craig #### 4.3 PLL (Phase Locked Loop) All of the circuitry described prior to this point is constantly enabled. However, from this point on, signals will be allowed to pass only when enabled by the RDGT signal from the 28 on the Controller. The block diagram on the opposite page shows the PLL (Phase Locked Loop) on the Analog PCB. The PLL provides a clock frequency in sync with the incoming MFM digitized data signal to enable the MFM to NRZ Data Converter to perform its function and to forward the serial NRZ data stream to the Controller PCB. (for information on Modified Frequency Modulation refer to the MFM explanation at the end of this discussion). The PLL has two modes: The PLL is put in the Idle mode when the RDGT signal from the Z8 on the Controller PCB is inactive (any time the Z8 is not actually performing a Read operation; i.e., Write or Idle). During the Idle mode the PLL syncs the VCO to the master clock frequency from the Controller PCB. This mode has no real purpose and so will not be discussed any further. 2. The PLL is put in the Read mode when the Z8 makes RDGT active during a Read operation. During the Read mode, the PLL syncs the VCO to the incoming MFM digitized data signal. This is performed as follows. The Phase Detector compares the phase of the VCO clock frequency with the digitized data pulses (RDPLS) from the read analog signal. If the Phase Detector receives a RDPLS before it receives a VCO pulse, then the VCO's phase is lagging behind the incoming data, and it needs to speed up. So, the Phase Detector generates the INC (increase) signal to the Charge Pump circuit. Appendices rev. 11-14-83 Page 3.111 Page 0259 of 0580 Appendices rev. 11-14-83 Page 3.112 Source: David T. Craig Page 0260 of 0580 260 4.3 PLL (Phase Lock Loop) (continued) The Charge Pump circuit is then enabled to put a positive charge on C32 and C33. C32 and C33 store the VCO control voltage level that controls the frequency produced by the VCO. The more positive input to the VCO now causes it to increase its output frequency to catch up to the frequency of the incoming data. If the Phase Detector receives a VCO pulse first (before a RDPLS), then the VCO's phase is leading that of the incoming data, and it needs to slow down. So, the Phase Detector generates the DEC (decrease) signal to the Charge Pump circuit. The Charge Pump circuit is then enabled to put a negative charge on C32 and C33. The more negative input to the VCO now causes it to decrease its output frequency, to try to slow down to the frequency of the incoming data. The different circuits in the PLL are explained in greater detail on the following pages. Appendices rev. 11-14-83 Page 3.113 Source: David T. Craig Page 0261 of 0580 262 ## **4.3.1** VCO Phase Detector and MFM to NRZ Data Converter Circuits There are two main circuits shown on the opposite page, the VCO Phase Detector (U15, 16, 17, 18, 19, and 22) and the NRZ to MFM converter (U20 and 21). The VCO Phase Comparator compares the phase of the clocks from the VCO (Voltage Controlled Oscillator) with those of the incoming analog read signal. The 20 MHz (4F) output of the VCO comes in to pin 6 of FF "A" on U22. FF "A" of U22 divides 4F to 2F (10 MHz), FF "B" divides 2F into 1F (5 MHz). Pins 2, 14, and 15 from U22 go to the MFM to NRZ data converter. Pin 3 goes to Selector Gate "C" on U16. The Selector Gates are the inputs to the Phase Dectector and are actually four separate Nand gates. #### VCO Phase Detector Idle Mode During Idle mode, RDGT from the 28 through pin 15 of Ul4 is low. This enables Selector Gate "A" to pass the 1F master clock frequency and Selector Gate "D" to pass the 1F VCO frequency. This keeps the VCO in sync with the master clock on the Controller PCB (there is no real reason for this, because the output NRZRDTA is not enabled to go to the Controller PCB.). #### VCO Phase Detector Read Mode When the 28 is performing a Read operation, RDGT is high, enabling Selector Gate "B" to pass RDPLS (digitized MFM read data) and Selector Gate "C" to pass the 2F VCO frequency. (Pin 9 is actually common to both Selector Gates "B" and "C".) When the Z8 first initiates the Read mode by setting the RDGT signal high, RDGT enters pin 5 of Ul5 to generate a reset signal to flipflops "A" and "B" in Ul9 and flipflop "B" in Ul7. The reset signal from pin 11 of U15 also presets flipflop "A" in U17 causing the VCRS (VCO Reset) signal out of gate "A" of U18. (Incidently it resets the VCO as its name implies.) Appendices rev. 11-14-83 Page 3.115 264 If the Phase Detector receives a RDPLS before it receives a VCO pulse, then that means the VCO's phase is lagging behind the incoming data so the VCO needs to speed up. In this case the low out of pin 2 of Selector Gate "B" caused by the RDPLS sets FF "A" in Ul9 through pin 6, causing it to generate the INC (increase) signal to the Charge Pump circuit. This signal enables the Charge Pump to put a positive charge on C32, and C33 causing the VCO to speed up. Later, when the 2F signal from the VCO causes Selector Gate "C" to output a low, it will set FF "B" in Ul9 through pin 11, gate "B" in Ul8 will then be fully enabled to reset the FFs Ul7, and 19. If the Phase Detector receives a VCO pulse first before a RDPLS, then that means the VCO's phase is leading that of the incoming data so it needs to slow down. In this case the low out of pin 15 of Selector Gate "C" caused by the VCO 2F signal sets FF "B" in U19 through pin 11 causing it to generate the DEC (decrease) signal to the Charge Pump circuit. This signal enables the Charge Pump to put a negative charge on C32, and C33 causing the VCo to slow down. Later when the RDPLS signal arrives, it will cause Selector Gate "B" to output a low, setting FF "A" in Ul9 through pin 6, gate "B" in Ul8 will then be fully enabled to reset the FFs Ul7, and 19. The RDPLS's are gated down to U20, which takes the digitized MFM data stream and beats it against the function of 1F and 2F ((VCO) now in sync with the incoming data) to convert it to NRZ data. The results, RD CLK and RD DATA (this data is in NRZ form) are sent to the Controller PCB. Appendices rev. 11-14-83 Page 3.117 Source: David T. Craig Page 0265 of 0580 266 #### 4.3.2 Charge Pump and VCO circuits There are two circuits shown on the opposite page, the Charge Pump on the left and the VCO on the right. If the Phase Detector receives a RDPLS before it receives a VCO pulse, the VCO's phase is lagging behind the incoming data, so the VCO needs to speed up. In this case, a high INC + (increase) and a low INC - signal come from the Phase Detector. The low INC - turns its NPN transistor on to send a negative voltage to C32 and C33. U25 amp lifies the negative charge on C32 and C33 to Q2 in the VCO. Q2 is biased by the charge on C32 and C33 to control the frequency produced by the VCO. If the Phase Detector receives a VCO pulse before it receives a RDPLS then the VCO's phase is leading the incoming data, so the VCO needs to slow down. In this case, a high DEC + (decrease) and a low DEC - signal come from the Phase Detector. The high DEC + turns its PNP transistor on to send a positive voltage to pin 5 of an amplifier in U25. Which puts the positive charge on to C32 and C33 for storage, etc. Appendices rev. 11-14-83 Page 3.119 262 #### WHAT IS MFM (Modified Frequency Modulation) ?: MFM is a scheme in which the ones and zeros of a digital bit stream are converted to a stream of transitions (phase reversals) according to the following rules: - Ones always cause a pulse at center cell time. - 2. No more than two cells can occur without a transition. - Only one transition can occur per cell time. 3. - Zeroes will cause a pulse at the start cell boundary, if not preceded by a one. Look at a bit stream of 001011000. | cell time | 1 | ! ! | | 1 | . ! | 1 | ! ! | | | |-----------|-------------|-------|-------|-----------|-----------------|---|-----|-------|---| | aigibits | U | O | 1 | 0 | 1 | 1 | 0 | 0 | Λ | | pulses | • • • • • • | `•••• | ••^•• | • • • • • | • • • • • • • • | ^ | | ••••• | | Pulses occurred at the start cell times for the first two zeros. Then a pulse occurred at center cell time for the first one. However, the pulse for the third zero had to be dropped because the following one would have caused another transition to occur less than one cell time away. This would have broken Rule three. The second and third pulses occur at center cell. (All ones cause pulses at center cell, it's the zeros that get played with.) The pulse for the fourth zero gets dropped because it was preceded by a one. The fifth and sixth zeros cause pulses at start cell boundaries because no ones interfere. The diagram on the following page might help you to gain a better understanding of MFM data and its relation to the other methods of modulating data that are used in the Pro-File. For the Pro-File, the data frequency is 5 MHz, sometimes referred to as 1F (2F would be 10 MHz, 3F would be 15 MHz, etc.). Appendices rev. 11-14-83 Page 3.120 Source: David T. Craig Page 0268 of 0580 268 #### WHAT IS PRECOMPENSATION ? When one records things at high density on magnetic media, a phenomenon occurs, called, "don't get too close or I'll push you away." This refers to the polarity of the small magnetic fields, on the disk surface associated with each write pulse. #### Example: pulses .... time ! 1 ! 1.5 ! 2.0 ! 1 ! 1.5 ! 1 ! push <- -> -> <- -> <- -> direction Once data is laid down on the disk, the fields associated with each pulse tend to bend away from their neighbors. If the data were to be written with no procompensation, three conditions could occur when the data are read back from the disk. - Early a bit would be picked up too soon in relation to the last bit read. - 2. Late a bit would be picked up too late in relation to the last bit read. - 3. On time if no pushaways occur, the data bits will be picked up right where they should be, according to MFM rules. To counteract the bit shifting in condition one or two, when the NRZ to MFM Write Encoder and Data Precompensator converts NRZ data to MFM data, it also examines the relationship between each bit in the data stream and its immediate neighbors to determine if it is a one followed by a one, a zero followed by a one, and so forth. The Data Precompensator uses this information to determine if the pushaway phenomenon would occur between the bits in that pair. The Precompensator can shift the actual pulse timing for Write data in one direction or the other in 15 ns increments. Appendices rev. rev. 11-14-83 Page 3.121 269 #### Precompensation: (continued) This slight compensation makes the pulses read back during the Read operation appear to be occurring at the correct time. If a bit pair looks like pushaway might cause a bit to be read early, the Precompensator will direct that bit to be written that much later. If a pair looks like pushaway would cause a bit to be read late, the Precompensator will direct that bit to be written that much earlier. And if the bit pair looks like no pushaway will occur, the Precompensator will allow it to be written as is. Again, for clarity, if the pushaway effect was not compensated for, the data bits, when they were read, would be time shifted, causing read data errors. The Write Precompensator identifies the shift that would occur and compensates for it by shifting the write timing the opposite direction of the shift. That is if a bit would have the tendency to come early it would be retarded. If a bit would have the tendency to come late, it would be advanced. If it was going to be on time, why mess with it. That's precompensation, and it only occurs on the inside tracks, on the outside tracks the bits are far enough apart that pushaway is not a factor. Appendices rev. 11-14-83 Page 3.122 Source: David T. Craig Apple Computer, Inc. Service Engineering Department # Apple /// Computer Repair Document Profile Hard Drive Pro-File Level II Phase 1 Service Manual (Very Preliminary) Author: DAVID T. CRAIG 736 EDGEWATER, WICHITA, KANSAS 67230 [USA] Source: David T. Craig Page 0272 of 0580 Pages: 101 (p.1 not present) # PRO-FILE LEVEL II PHASE 1 SERVICE MANUAL VERY PRELIMINARY Source: David T. Craig Page 0273 of 0580 ### 04/19/82 ILE DEBUG DATA JS #1: - OTHER THAN 55 RESPONCE FROM HOST - 3 BYTE SEPARATOR BETWEEN WRITE BUFFER AND STATUS TABLES BAD OR 52-3 SET. - SPARE TABLES UPDATE OCCURED, BUFFER DATA IS CHANGED - CANNOT READ 3 SECTORS AFTER 2 RESEEKS - READ ERROR - CANNOT FIND TARGET HEADER IN 9 ROTATIONS - OPERATION FAILED US /2: - CANHOT READ 3 SECTORS AFTER SEEK - MORE THAN 32 SPARES - MORE THAN 100 BAD BLOCKS - CANNOT READ STATUS SECTORS - SPARING OCCURRED - SEEK TO THE WRONG TRACK US /3: - PROFILE WAS RESET - REQUESTED BLOCK # OUT OF RANGE - BLOC I.D. HISMATCH SET BY MOST - HOST RESET PROFILE - BAD COICKAND RESPONCE FROM PROFILE - PARITY FRROR ON CABLE PERCENAGE OF READ FAILURES AFTER READ COMMANO 'US #4: . 3 Source: David T. Craig Page 0274 of 0580 • currently supported by SOS. E. Controller Reset (CRES) --- Cn08 and Cn0C CnOC sets the signal high; and CnO8 resets it low. CRES resets the Z8 MPU on the controller card. Used in initializing the system after unseccessful seek attempts. F. Write Buffer (WBUF)-COn0 A write reference to COnO writes a byte of data to the RAM on the controller card. For example, STA COnO writes the contents of the host MPU's accumulator to a predetermined location in the controller's RAM. A read reference to COnO does nothing. G. Clear Parity Error (CLRPE) --- COn3 A write reference to COn3 resets the parity error flip-flop. H. Read Buffer (RBUF) --- COnl Aread reference to COnl reads a byte of data from the controller's RAM. I. Read Status (RSTAT) --- COn2 A read reference to COn2 loads the state of BSY, the Parity FF, and "Open Cable Detect" onto the I/O bus (bits 7,6, and O respectively). Vett*yper* Ved/7 6 #### -- Interface Circuitry, Lets take a tour of the interface schematic. Get your pencils ready to make a few notations as we go so later on we won't have to stop and repeat ourselves. #### Data Bus in the upper right of the drawing U3, U6 are the major data buffering elements of the bus. U1 is the resistor network. U8 a parity generator/checker is used to verify data integreity on the bus, not to generate a parity bit used elsewhere in the system, except for a error status bit. Data from the host is clocked into U3, an 8 bit latch with tri-state outputs. The outputs are enabled when data is being transferred from the host to the controller, when DRW is low- Data from the controller is allowed to pass through U6 to the I/O bus when DRW is high, host Q3 is low, and there is a high PSTRB. This gating is accomplished at U5-12. The parity circuit here is only half of the circuit, the remaining half is on the controller card. Simply there are two parity checkers, one on each end of the cable. And if the total sum of parity (number of "one" bits) doesn't compare a status bit 0 is set and stays set until parity reset occurs. Normal parity operation. Lets say a byte of even parity is sent from the interface to the controller. The parity generator on the controller sees the Even condition and the RPARITY line is taken high. This is placed on the "carry input" of the generator on the interface. This generator sees the even data byte plus the input bit as a ODD sum and therefore takes its EVEN output low. This will be placed on the J input of U7-2, and remembering JK theory a low causes nothing to happen, the FF stays in reset condition. (/K input is strapped high, therefore the JK cannot be reset from data inputs.) If an odd byte is on the bus, the checker on the controller sees the odd sum and takes the RPARITY line low. This on the Input of the interfaces checker with the odd byte on the bus will again cause the EVEN output to be low, again not allowing the Parity FF to be clocked to the set condition. When EVEN output of the interfaces checker is high at the trailing edge of /PSTRB the Parity Error FF will set. When the host checks the interface status byte (RSTAT, COn2) bit 0 will have a "one". The error could be caused by a very noisy bus line, an open or shorted cable connection or some such condition. It should never really occur, and is pretty much an over kill, but it is nice to have, for security. It is purely a passive circuit, it will not stop data transfer, only report the occurance of the first error. Control/Command Decoders 7 In the lower left section of the drawing locate U15 device control decoder and U13 I/O command decoder and latch. U15 is a simple 1 of 8 decoder. Once the ChEn Latch is set by an I/O Selection of the slot U15 decodes each successive DEVSEL reference and developes appropriate strobes. See address reference description in intro for interface section. It should be noted that read or write references equal to or greater than COn4 have no decoded action. #### Write References COn0 /WBUF low COn1 not used COn2 not used COn3 /CLRPE low #### Read References COn0 not used COn1 /RBUF low COn2 /RSTAT low COn3 not used Ul3 is a 8 bit addressable latch (as used on the Apple II and /// main logics) It decodes which bit is being addressed by the action of AO, Al and A3; A2 is used as the "data" input to the latch. On the trailing edge of the the I/O Select reference the condition of those four address lines are strored. It is safe to say that these are flags that are being set/reset, or at least not strobes. Table of Activity for U13 Latch (All addresses are in the CNOx range) | Hex Address | A3 | A2 | Al- | AO | Action | |-----------------|----|----|-----|----|----------------------------------| | CNO O | 0 | 0 | 0 | 0 | Resets CMD low | | Cn01 | 0 | 0 | 0 | 1 | Resets CRW low | | Cn02 | Ŏ | Ö | 1 | 0 | Resets INTEN low | | Cn03 | Ö | Ö | 1 | 1 | Resets DRW low | | Cn04 | Ö | ī | ō | Õ | Sets CMD high | | Cn05 | Ö | ī | Ö | i | Sets CRW high | | Cn06 | Ö | ī | ì | ō | Sets INTEN high | | Cn07 | Ö | ī | 1 | 1 | Sets DRW high | | Cn08 | 1 | ō | ō | ō | Resets CRES low | | Cn09 | 1 | ŏ | ō | i | not used | | CnOA | i | Ö | ī | ō | not used | | | i | ŏ | ī | 1 | not used | | CnOB | 1 | 1 | ō | ō | Sets CRES high | | CnOC<br>CnOD=OF | i | i | x | × | not used (where Al and/or AO =1) | The next big highlight is the circuitry behind PSTRB. This is the master data transfer strobe which is generated anytime a byte is transferred between the controller and the host, be it read or write and/or single byte or DMA modes. PSTRB is generated four ways. The easiest to see is through /RBUF. Each time the host requests a single byte from the controller /RBUF goes low and is or'd 9 Source: David T. Craig Page 0280 of 0580 at U5-11 and develops PSTRB, which in turn enables the data from the controller to be passed to the I/O bus. (so long we have previously set DR/whigh...and Q3 is low) (aside,,, Q3 is used to gate data onto the bus to avoid signal contention on the bus and the resultant noise when the various drivers switch on and off) The next method is byte at a time writing. The host must first set CR/W low which enables the WSTRBEN FF to be set with the first edge of /WBUF. Then a PSTRB is developed with each /WBUF. Because of the action of the gate which develops /WRSTRB (U5-6) the real write strobe is the space after the /WBUF signal and the next working edge of /WBUF. After the last /WBUF the last byte is transferred into the controller by the action of CR/W being taken back high; thus, resetting WSTRBEN FF which will give the last positive edge of /WRSTRB. This method is used in writing the commands string to the controller. It should be noted that if CR/W is held high /WBUF can be used to write a byte of information to the data latch which will not be transferred to the controller RAM....\*\*\*\*\*used to load the "55"? PSTRB can also be generated in a DMA transfer of data to the controller. Again the WSTRBEN FF must be set with the first positive transition of Ull-11. The Apple three conditions itself for a DMA and lowers /DMAOK this is gates /FH1 (PHO) to Ull-13 which develops automatic clocks to the data latch and to the WSTRBEN FF. This auto strobing goes through the enabled U5-6 and then to U5-8 as PSTRB. (Background: The DMA talked about here is not a true DMA where the remote device takes control of the address and data lines. It is really more of a block transfer mode which is controlled by a special routine in the boot rom. The data direction is controlled by the Cr/W and action of the automatic pulses generated by u12-6 described above. SOS sets a page in the ZPAGE register and then calls a routine in ROM which causes the MPU to cycle through the address of a page (itself running in its ZPAGE which causes the ZPAGE register to be gated onto the Address buss. It is all very fixed in nature so once called it will go through the looping routine in ROM until it falls out and goes back to normal stuff.) The remaining method of generating PSTRB is a DMA transfer from the controller to the host. In this case CR/W is left high, which is inverted and is present at the input of U10-9. The Apple /// conditions itself for the block transfer and lowers DMAOK. The same autogeneration of pulses occurs at U12-6, but this time the buffer U10-4 is enabled and passes these pulses directly to U5-10 and PSTRB is toggled. Remember we are transferring data from the controller to the host. That means we must be writing to the Apple /// memory. The pseudo write pulse on the R/W line is accomplished with the output of UlO-8 which is tied to the R/W line of the I/O bus. The auto-strobes of Ul2-6 enable the low at UlO-9 to be passed to the output. The gate U12-11 can be used to enable an IRQ to the host when INTEN is high 13 Source: David T. Craig Page 0284 of 0580 and the appropriate state of the BSY/INT line is reached. This however is implemented in the initial SOS Driver. The remaining logic is either drivers or very elementary bit buffers used to gate the interface status bits to the I/O bus. SPECIAL NOTE: the R-C network at U12-3 and the inductor on U12-8 are used to squelch an oscillatory condition which could occur in the logic supporting the DMA process. 14 #### analog card The analog card serves as the interface between the controller card and the Seagate HDA. It consists of the NRZ to MFM write encoder, write driver, head select matrix, AGC preamplifier, read detector, PLL, MFM to NRZ decoder, and sector detector. The head select matrix selects one of the four heads for a read or write operation. During a write operation, serial NRZ write data and clock (5 MEZ) are converted to MFM write data. The MFM write transitions are peak shift precompensated on the inside cylinders, 128 to 152. The write driver converts the MFM write pulses to alternating head current. On the inside cylinders, the write current is reduced from 24 to 19 ma peak. During a read operation, the automatic gain controlled preamplifier amplifies the low level (.6 to 2.0 mv) head signal to a fixed 1.0 v output signal. This analog read signal is fed to the differentiator and dated detector do derive the MFM read pulses. The phase lock loopp synchronizes its VCO to the MFM read pulses and provides the clock for the MFM to NRZ data seperator. The serial NRZ data and clock are sent back to the controller for describingtion. During the format (initial set up of the disk) operation, sector boundaries are written as DC erased 10 byte fields. During a read operation, the sector boundary detector looks for the absence of read signals and sends a sector pulse to the controller at the end of the 10 byte field. #### Block diagram For the first pass lets divide the diagram into sections. The top left is the only write circuit which drives the heads during the write operations. The rest of the drawing is used in the read mode. The one of four decode head selector is shared for both read and write. During a write WRTDATA is shifted through the MFM encoder/precompensator to the write driver which drives the selected head of the drive. It is time to define MFM and precompesation. MFM is a scheme in which the ones and zeroes of a digital bits stream are converted to a stream of transitions (reversals) following certain rules. In reference to the bit cells and their respective boundaries, a zero causes a reversal at a boundary and a one causes a reversal at center cell time. However no reversal can be 1/2 cell time from a previous reversal. So the following rules come about: - A. Ones always cause a pulse at center cell time. - B. Zeroes cause a pulse at leading cell boundary if not precedeed by a one. Simple? Well lets look at a bit stream of 001011000. | cell time | ! ! | ! | ! | | | | ! ! | | ! | |-----------|-----|-----------|---|-----|---|---|-----|---|---| | digibits | 0 | 0 | 1 | 0 ' | 1 | 1 | 0 | 0 | 0 | | pulses | ^ | • • • • • | ^ | | | | | ` | | You can now see that pulses occured at the leading cell time of the first two 15 Source: David T. Craig Page 0286 of 0580 the pulse for the third zero had to be dropped because it would have occur at a half cell distance from the preceding pulse. The second and third ones occur at center cell (remember all ones cause pulses at center cell and its the zeroes that get played with). The pulse for the fourth zero gets dropped because it was preceded by a one. The fifth and sixth zeroes cause pulses at leading cell boundaries normally. Now, that is MPM, Modified Frequency Modulation. Frequecy? Why I thought you'd never ask. Its 5 MHZ or sometimes referred to as 1F. What pray tell, then, is "precompensation". Well, when one records things at high density on magnetic media a phenomena occurs called, "don't get too close or I'll push you away." This is in reference to the small magnetic fields of associated with each one of the pulses. Lets look at the pulse stream of the above example again: The fields associated with each pulse tend to bend away from their neighbor, which results in a slight time shift, early, ontime, or late in reference to the pick up (read) head. To combat this shifting the precompensation circuit which is encoding the pulse stream looks at the string and can shift the actual pulse timing one direction or the other in 15ns increments (during write operations). This very slight compensation will make the pulses read back during the read operation appear to be occurring back at the "correct" time. Again, for clarity. If left alone the fields when read would be time shifted. The write precompensator shifts the write timing the oppposite direction of the shift. That is if a bit would have the tendency to come early it would be retarded, if a bit would have the tendency to come late it would be advanced. If it was going to be on time, why mess with it. That's precompesation, and it only occurs on the inside tracks, on the outside tracks the bits are far enough apart to not mess with one another. Their is more to the read circuitry. The very small signal from the selected head is amplified and then amplified again (with automatic gain control) then the peaks are detected and are used to keep the VCO in tune and are decoded from MFM to NRZ. If there are no peaks for a while a sector mark is detected. That wasn't too much description, but thats all that happens. It just takes a lot of circuitry to do it. 17 # ANALOG CIRCUITRY IN A LITTLE MORE DEPTE For easy of working with the document a multisheet drawing of the analog schematic has been prepared. (there are some very minor component value changes from this drawing to the production version....but not enough to not understand the way it works) A copy of the analog block diagram with dotten boxes around circuit groups have the sheet numbers of the analog schematic for reference so you can relate the detail to the overall picture. Section One Write MFM Encoder and Write Precompensation. The circuit population of this group is quite small however the PAL (programmed array logic-U28) makes up for that in actual equivilant logic. Refer to appendix on PAL's #### Clocking- IF= SMUZ The 2F (10MEZ) is the master controller crystal oscillator frequency. It is 🛰 divied to 1F by U2 (a simple divide by two stage). The 1F (5MHZ) is the bit 2F = 10MH shift clock for the precompensation shift register. It is also used to keep (cleck) the VCO sync'd during the write operation. 2F is used to update the outputs of the PAL register. ### PRECOMP SHIFT REGISTER NRZ data is shifted into U29 (74LS174) which is externally wired into a shift register (normally a hex d-type latch). This string of delayed bits form five of the inputs of the PAL. For clarity the following is a schetch of the same part with the "in's" on the left and the "out's on the right with the names of the signals (used in the PAL program listing) supplied. | TM1-13 | ld5 q: | 5!12TM2 | |-----------------|-----------------------|--------------| | T11 | d4 q | 4!——10—TM1 | | TP16 | :<br>!d3 q:<br>! 1129 | 3!7 T | | TP2-4 | | 2!5TP1 | | NRZWDTA-3 | !<br>!dl q | 1!2TP2 | | 1F <del>9</del> | !<br>!clk r | s!1Soft 5VDC | | | !<br> | <u> </u> | The initial NRZ data is clocked into ql, the next clock places ql at q2 and so forth. The whole intent is to give the PLA a window on the data stream to make the encoding and early/late/ontime precompensation decisions discussed 19 Source: David T. Craig Page 0290 of 0580 Val earlier. It makes things easier visualize the data stream in reference to the bit named "T". The TMx signals are what T was 1 and 2 clocks ago, and the signals are what T will be in 1 and 2 clocks. #### MFM/PRECOMP PAL To keep us going the PAL (16R6) is custom array of logic designed for just this circuit. It consists of a hugh array of AND/OR gates feeding each D input of the output register. Each output is represented in a formula in the appendix. The equivilant logic is also in the appendix, and if conventional 7400 logic were to have been used the chip count would be increased by about 16 to 18. This little gem saves a lot of landscape (and money). Using the information previously divulged the PAL's function is simply to make the NRZ digital stream in to a stream of pulses conforming to the rules of MFM stated earlier. The other function is to provide the gating signals to advance, retard or leave alone the stream of pulses called "UCWDTA" (uncompensated). #### PRECOMP GATING UCWDTA goes to the input of a gate enabled with ELY and to a delay line which delays the pulses approximately 15 ns per stage. The outputs of the delay line are gated with OT and LTE respectively. Simply if there is no precompenstation (outer tracks) the signal OT gates the first delayed data line to the WXS line. If precomp'ing then if the data transition needs to be advanced ELY gates UCWDTA to the WXS line; and, if the signal needs to be retarded the signal LTE gates the second delay of data to the WXS line. The signals of UCWDTA, ELY, OT, and LTE are syncronous and only one of ELY,OT, or LTE can be true at one time. The following timing diagram might help clear it up a little. | DATA d1<br>DATA d2<br>OT | | | |--------------------------|---------|--| | UVC (nearn) | <br>′′′ | | NOTE: this diagram is for training ppurposes and does not necessarily conform to to the rules of precomp.....OK? The leading edge of the WXS singal is the working edge that toggles the WXS FF the very sight shift of timing between the precomp and unprecompensated signal 21 Source: David T. Craig Page 0292 of 0580 vol is enough to increase read data recovery by several magnitudes. MISC Circuits on sheet 1 The little buffers shape the TRACK 0 sensor signal and the INDEX pulse from the HDA. The Track 0 circuit forms a little noise latching function (the source signal is pretty ragged). WRITE CURRENT GATING AND HEAD SELECTION (SHEET 2) The WXS signal developed in the precomp gating circuit toggles the WXS FF,U2, with each pulse that is developed. So, the result is a divide by two function. The outputs of the WXS FF are level shifted by the first set of transitors in U1. The remaining transistors comprise a constant current switching network. And they follow the command of the WXS FF. The WXS FF is clamped reset during the hardware format (Write Sector Mark) routine. This will cause the heads to write a field (10 bytes long) with no intelligence. Remember a string of zeroes would result in a 2.5 MHZ signal at the heads due to the MFM encoder. WTGT will allow the current switching circuit to turn on when WTGT is true. WTGT (Write Gate) ,when inactive, will kill both sides of the level shifter and therfore turn off both sides of the current source effectively killing all write current. The signal /PRECOMP\*LOCUR will cause a reduction of write current to the heads when writing in the inner tracks. The normal write current is about 25 mils but in the inner tracks it is reduced to slightly less than 20 mils. Head selection is done by U4 (7445, one of ten decoder). The signals HSO and HSI are binary selections of the head from the Z8. Only one head can be selected at a time. The heads are center tapped and the center is connected to the 7445. The selected head now has a current path for reading or writing. The read circuitry is always on...however it goes into saturation during the write operation and does not reliably recover the data. During reading (not writing) the selected head develops a signal on the -x/-y lines. This signal is about 1 mv and usally cannot be seen with conventional techiques. Probing dampens the signal and induces so much noise it is obiterated. So don't expect to see data right off the heads. AUTOMATIC GAIN CONTROLLED AMPLIFIER (SHEET 3) The read signals from the head are brought to the first stage preamplifier. The devices used here are ECL, but are not used in their intended application or environment. (Don't worry it works fine). Each stage of the preamplifier has a gain of 12. This means that the approximate 1 mv head signal leaves the first stage at about 18 mv. The signal is amplified again, and leaves this stage at about 200 mv. Thats nice because the filter network attenuates it about 60% just before it 22 Source: David T. Craig zak gets to the next amplifier. This amplifier has a circuit which will control its gain. Q4:(FET resistor) is the feedback port. By controlling the bias the gate of Q3: the gain is controlled shunting effect the FET has on pins 4 and 11 of U6. The output of this amplifier is reference shifted by the transistors of U7. The rest of U7 and the stages of U8 are the gain control for the FET. Simply if the amplitude of the incoming signal has peaks less than previous peaks the gain will increase. If the peaks are higher than previous peaks then the gain will be reduced. A normal occurance is that as the heads traverse the sector mark the AGC will cause the amplification to go to maximum. So as the data immediately returns after the sector mark the amplification is usually far too high and one can see very strong signals just after the sector mark but they quickly regain the normal gain. Conversely, during the write operation when there is a very strong signal present at the x/y lines the gain is reduced to the minimum, and the circuit requires a little time to recover normal gain when writing stops. READ DETECTOR AND SECTOR DETECTOR (SHEET 4) The Read Detector simply cleans and shapes the signal and by delaying itself in one path clocks itself through Ull and the action of UlO and C2O decern transitions of Ull and develop 50 ns pulses at each transition. The RDPLS go on to be seperated but perform another function on this sheet. The RDPLS is gated down through U12 trannys which pump a little charge to C23 at the input of U13. If there are no read pulses (as during a sector mark) R71 slowly discharges C23 and causes U13-12 to switch. When read pulses reappear (as in the sync field) C23 quickly recharges and U13-12 flips back. This direction of flip is intergrated to U13-10 and an approximate 2usec pulse is developed, SECTOR. This is directly connected to the Z8, so it can do its thing. SOURCE PULSE GATING PHASE COMPARATOR DATA SEPERATOR (SHEET 5) When we are not reading (RDGT false) a lot of the circuitry in this section is disabled. The major activity is to keep the VCO at near optimum frequency and in phase with the master oscillator clock. (the fact that it is in phase with the master clock is a irrelevant fact, it just ends up in phase.) When not reading, the master osc derived IF (5MHZ) signal is gated through to the phase lock loop detector. The actions of U17,U19 in relation to VCO's derived IF clock will cause the VCO to lock on the edges of the master clock and keep at frequency. Also, when not reading the data seperator is turned off. When reading and RDGT is true the phase comparator is now looking at the edges of the data pulses and locks on their edges. If the pulses are coming a little faster than the VCO frequency the VCO is told to INC. If the VCO is faster than the frequency of the pulses it is told to DEC. An INC/DEC decision is made at each data pulse. If the VCO is right on no change is commanded. 24 Source: David T. Craig Page 0295 of 0580 vach The RDPLS's are gated down to U20 which takes the pulse stream and beats in against the functions of 1F and 2F (VCO). The results are RD CLK and RD DATA. VCO (SHEET 6) The VCO is comprised of three elements. The RESYNC GATE, the INC/DEC control, and the Oscillator itself. U26 pulses very quickly at the beginning of each read gate on the first read pulse. This action syncronizes the VCO to the phase, if the VCO starts getting out of phase it is resync'd. The INC/DEC pumps more chargeonto C32 or decreases the charge on C32. The amplifier reads this and alters the potential at the gate of Q2. This bias shift will affect the resultant frequency of the oscillator. Swings in the bias are directy proportional to swings in frequency. The oscillator centers on 20 MHZ. 28 Source: David T. Craig Page 0299 of 0580 1/28/81 . . . . . . . . . . . ----\_ ----THE SM THE T TPE TPE WIGT PROMP THE ~ ○ U DE 12 13 LTE OT ELY F2 F1 19, VCC ELY: = /TM1+/TH1 + T+TP1+/TM2 + 1M1+/1. + TP1+TM2 + PCDMF + F1 ELTER = TM1 + TH/TP1 + /TM1+/TH/TM2 -VTM1+/T%TP1+TM2 + PCDMF/ + F1 DT = TM1\*/TP1\*/PCDMF/ + TM1#/T#/FCOMP ( + /TM1+TP1+/TM2+/PCDMP/ + /TM1+T+TP1+TM2+/PCDMP + /THI=/T=/TPI=TM2=/PCOMP/ + F1#/FCOMF F1 = F1 + /T\*/5M + TM1\*5M + #5M + WTGT' F2: = /5M + F1 + TM1+5M + T+5M + WTGT -LDESCRIPTION: AIS PAL PERFORMS NEZ TO MEM ENCODING US THE EARLY, ON TIME, AND LATE SIGNALS FOR WRITE PRECOMPENSATION NOTE THAT ALL OUTPUTS ARE ACTIVE HIGH, SO THE JEROS OF THE FUNCTIONS ARE IMPLEMENTED IN THE EQUATIONS. 30 Source: David T. Craig Page 0301 of 0580 # CONTROLLER CARL The Profile controller card consists of four main sections; the MPU (Z8), 2K byte RAM, serializing/deserializing and error detectin logic, and the read/write control logic. Functionally, the controller communicates with the Apple ///, provides signals to read and write serial data on the disk, moves the heads to the proper track, and monitors error conditions. The Z8 MPU provides an intelligent interface to the Apple. High level commands (e.g. read, write, status and associated data) are communicated the the MPU via the RAM, then interpreted and executed. the results of the operation (completion status bytes, disk data) are passed back to the Apple via the RAM. Access to the RAM is controlled by the MPU as a function of its current state and the CMD input from the Apple interface card. The MPU responds to the Apple with the BSY line. The CMD/BSY handshake establishes directin of data transfer between the controller and the Apple, and determines when the Apple begins and ends its data transfer. Once the data transfer has been completed, the MPU regains control of the memory and either executes the command or returns to an idle condition if a command has just been completed. ## CONTROLLER/DISK INTERFACE The controller card outputs signals to the analog card over a 25-pin conductor flat cable. The function of the analog card is to translate between the digital data stream at the controller and the analog signals compatible with the heads and disk media. # Signals at the interface are as follows: Write Data (output) Serial Data to be written on the disk. Read Data (input) Serial Data recovered from the disk. (i & o) Defines when Write and Read Data are valid. Read Gate (output) Enables read circuitry on analog card. Write Gate (output) Enables write circuitry on analog card. (input) Defines sector boundaries. (input) A pulse which occurs once per disk revolution. Sector Index Phaes Al, 2 (output) Activates stepper motor coils to position heads. B1,2 (output) Writes DC sector boundaries. Write Sector Mark (output) Causes selection of one of four read/write heads. Read Select 1,0 (input) Indicates that the heads are positioned over the Track 0 outermost tracks. ## READ/WRITE SEEK The MPU supervises the remaining hardware on the controller via signals on its I/O ports and through control information stored in RAM. The MPU directly controls the stepper motor phases to move the actuator and heads from track to 33 Source: David T. Craig Page 0304 of 0580 Moh track (seek control), selects one of four read/write heads, and writes secrements on the disk during the virgin formatting operation (at the factory). Read/Write functions are performed by the Read/Wrtie Control Logic on command from the MPU. This logic in turn controls the parallel to serial conversion when writing, and the serial to parallel conversion when reading; data transfer to and from RAM; and the CRC (Cyclic Redundancy Check); and outputs an error signal to the MPU. If an error occurs, the MPU will automatically perform a data recovery procedure if the number of CRC errors on a given sector exceeds a predetermined level. If the error rate persists, the sector will be spared (relocated to an other area of the disk). Need was to 100410 ## OTHER CONTROLLER FUNCTIONS To prevent heat buildup in the drive, the MPU removes power from the stepper motor if no commands have been received in .75 seconds. After 3 seconds it will move the head to a non data area and shut down again. The BSY signal controls the activity LED which will turn on whenever the controller is idle (not busy). MOP # CONTROLLER DETAILED BLOCK DIAGRAMS The first thing we need to do is to get familiar with where the data goes in each one of the various modes. Once we understand where it is supposed to go it is a lot easier to understand how the control logic gets the job done. By not bothering with the super detail at this point, or using the assumption that it does it as if it were a mystery of life. Trust us! # CONTROLLER/INTERFACE COMMAND HANDSHAKE The MPU having done its previous command is sitting idle and is waiting for the Apple to tell it to do something. The interface raises CMD and the MPU starts its thing. Upon seeing CMD going high the MPU raises its BSY line and places 01 on the interface bus. The apple must ack the Profiles response with a 55 when it lowers the CMD line or the profile will abort the operation and go back to idle. When the interface lowers CMD (and has acked the response with 55 the MPU conditions the bus to receive the command bytes. The command bytes are not read by the MPU at this time but are stored in the RAM. When CMD goes high again the MPU interprets the command bytes and responds with the result of its command interpretation (For example: if the apple had said to read a block, the MPU will respond with "02" which means "I'm going to read a block"). The apple must confirm the response with a 55 on the bus again, if it disagrees or has changed its mind any other byte will cause the Profile to abort the operation. It takes two command handshakes to complete a Read operation, and three handshakes for both a write, and a write/verify operatin. Let's now look at each operation's handshake routine: ### Read Operation - 1. The Apple raises CMD. - 2. Profile places 01 on the bus and signals the apple by raising BSY. - 3. The Apple places 55 on the bus and signals Profile by lowering CMD. - 4. The apple then transfers the read command bytes to profile ram. - 5. The apple the raises CMD again. - 6 Profile looks at the command bytes and reponds with 02 and raises BSY. - 7. Apple checks response, acks with 55 and lowers CMD. - 8. Profile then goes and reads the desired block, keeping BSY high. - 9. When finished reading block from disk to RAM, Profile lowers BSY. - 10. Apple then transfers data from Profile Ram to its own. - 11.Operation complete. #### Write Operation - 1. The Apple raises CMD. - 2. Profile places 01 on the bus and signals the apple by raising BSY. - 3. The Apple places 55 on the bus and signals Profile by lowering CMD. 36 Source: David T. Craig Page 0307 of 0580 NOX - 4. The apple then transfers the write command bytes to profile ram. - 5. The apple the raises CMD again. - 6 Profile looks at the command bytes and reponds with 03 and raises BSY. - 7. Apple checks response, acks with 55 and lowers CMD. - 8. Apple then transfers block to Profile RAM - 9. When finished transferring block to RAM Apple raises CMD. - 10.Profile places 06 on bus and raises BSY. - 11.Apple checks response puts 55 on bus and lowers CMD. - 12. Profile writes data on disk and updates status bytes in RAM. - 13 When done writing Profile lowers BSY. - 14.Apple transfers status bytes from Profile RAM and sees if OK. - 15.Operation complete. ### Write/Verify Operation - 1. The Apple raises CMD. - 2. Profile places 01 on the bus and signals the apple by raising BSY. - 3. The Apple places 55 on the bus and signals Profile by lowering CMD. - 4. The apple then transfers the write/verify command bytes to profile ram. - 5. The apple the raises CMD again. - 6 Profile looks at the command bytes and reponds with 04 and raises BSY. - 7. Apple checks response, acks with 55 and lowers CMD. - 8. Apple then transfers block to Profile RAM - 9. When finished transferring block to RAM Apple raises CMD. - 10.Profile places 06 on bus and raises BSY. - 11.Apple checks response puts 55 on bus and lowers CMD. - 12. Profile writes and verifies data on disk and updates status bytes in RAM. - 13 When done writing Profile lowers BSY. - 14. Apple transfers status bytes from Profile RAM and sees if OK. - 15.Operation complete. This simple handshaking protocol, seems a bit cumbersome but it allows very complete control and acknowledgement of every action before it is allowed to go ahead. We have gone through system level data movement but what goes on inside Profile? Thought you'd never ask. The simplest operation is the read. First one very simple statement, the MPU is used to condition the logic but is not really actively involved with data transfers to/from disk or the Apple, that is done by the Read/Write Control logic. Now let's go. The Read Operation Command Handshake is complete and the MPU has seen both command responses ack'd. It then conditions the logic to start a read. First it interprets the block number requested and selects the proper head, and alters the stepper phase control lines to match the proper track. It then places the head, track, sector infromation in RAM for comparison with infomatin returning from the disks headers. After proper timeouts, if there was eiter a head and/or track change it starts the Read/Wrtie control Logic (hereafter referred to as RWCL). 37 Source: David T. Craig Page 0308 of 0580 not In the overview in the introduction it was stated that there were three or four main circuit groups in the controller. Well that's true, and they are again: - 1. MPU - 2. RAM - 3. Serializer/Deserializer - 4. Read/Write Control The simplified block diagram shows the overall relationship of these elements. But it certainly doesn't help understand operation. So Lets get a little more detailed in the block diagram department. The next level of block breaks the controller into 17 elements. - 1. Data buffers - 2. Data In Mux - 3. Deserialized Data Register - 4. Stepper Motor Drivers - 5. MPU - 6. RAM Address Counter/Regeister - 7. RAM - 8. Programmable Counter Timer - Serial/Deserial Shift Register - 10.PAL (Programmed Array Logic) - 11.BYTC State Machine - 12.RWTC State Machine - 13.Read Data Mux - 14.Write Data Mux - 15.CRC Generator, Checker - 16.System Clock Selector - 17.Bus Parity Checker A very brief functional description of each of these elements will help give a foundation for later discussions. ## DATA BUFFERS Simple octal buffers which gate data to and from the controller and interface cards. ## DATA IN MUX This mux is used to direct data coming in from the interface card or coming "in" from the disk. The usual destination of its outputs is the RAM. #### DESERIALIZED DATA REGISTER This 8 bit register temporarily holds the descrialized data from the disk so that the shift register can recieve the next byte. When the logic is ready it will direct the registers contents to RAM though the DATA IN MUX. 38 Source: David T. Craig MO #### STEPPER MOTOR DRIVERS Using direct outputs of the MPU as inputs the stepper motor drivers provide the level shifting and current source for driving the head positioning stepper motor on the HDA. MPU The MPU is a Z8 microprocessor. It has a self contained rom program. It controlls by setting modes, and directly controls the stepper motor, head selction. It provides the intelligence to control the machine and to interface to the host computer. ### RAM ADDRESS COUNTER/REGISTER This element can be preset to a certain point and counted up through a sequential range of address for RAM access. It is also used as a Address register where it is loaded with a value for a specific single access. The method of use depends on what operation is currently going on. #### RAM The RAM is a 2k byte ram array which is used to hold data to and from the host and disk. Various locations are used to hold status information, and the current sparing tables. #### PROGRAMMABLE COUNTER/TIMER This element contains three programmable counters which yeild byte time information to the Read Write Control logic, and basically keeps track of where in the particular sector the current information is. # SERIAL/DESERIAL SHIFT REGISTER This register is quite busy. It is used to take the parallel data from RAM and shift it out serially to the analog card. It also takes the serial data from disk and shifts into a parrallel format for transfer back into ram. #### PAL This single chip is a logic array specifically programmed for this application. It performs many very complex and/or combintational logic functions. Its primary function is to control the function of the address counter, direction of data to/from ram, loading the counter/timer and controlling the serial/deserial register. #### BYTC STATE MACHINE The BYTC (BYTe Control) State Machine one of the two major elements of the Read Write Control. It steps through the control states for each byte at a bit time rate. RWIC STATE MACHINE 40 Source: David T. Craig Page 0311 of 0580 311 The RWTC (Read Write Timing Control) State Machine is the second major element of the Read Write Control. Its steps through the control states necessary to control the timing for all the operations associated with block/sector reading and writing. #### READ DATA MUX The Read Data Mux is used to select one of two sources of data (either NRZ Read Data or Serialized Data from the SER/DESER reg. It is used in both the read and write modes. In reading it gates NRZ Read Data through. During the write operation it gates serialized data through for use by the CRC generator. #### WRITE DATA MUX The WDM is used to select either serialized data from the shift register or the generated CRC characters to the disk. It is really only used in the write operation, though its ouput is flailing away during reads. #### CRC GENERATOR/CHECKER The CRC (cyclic redundancy check) circuit is used to compute crc check characters that are written at the end of each data block on disk during write operations, and used to compute CRC for read data and compare the result with the CRC characters that were read at the end of each data block. ### SYSTEM CLOCK SELECTOR The SSC switches from the crystal oscillator used during idle and write operations, to the read clock generated by the analog card during the read operation. This keeps the logic in "perfect" sync with the data. #### BUS PARITY CHECKER The BPC forms the other half of the bus parity checking circuit on the interface card. It constantly monitors the bus and check the parity at the controller end and sends its sum to the interface to be compared with the sum on the interface end. There should hardly ever be a parity error unless there is a cable fault. ny # COMMAND ACK' AND RESPONSES Looking at figure XI, we see the MPU's response to the interfaces CMD going high of "OX" coming out of the processor up to the ZR bus and off to the left through the buffer to the interface. When the interface drops CMD the processor will (should) see the apples's "55" acknowledgement coming in through the buffer to the Data In Mux and directly to the processor. This ack will trigger the processor to get the RAM ready to accept the command bytes. #### COMMAND BYTES After the first handshake of CMD and BSY, the Apple transferrs the actual command and delimiting bytes. They come in as does all data from the Apple through the DATA IN MUX, but gets stored in the RAM. There is another CMD handshake, during which the MPU evaluates the command bytes by bringing them in from RAM. The MPU then gives its response byte, which is ack'd or nack'd. ## READ DATA FLOW The control logic conditions the circuitry to accept the NRZRDTA through the READ DATA MUX into the DESERIALIZER where it is converted to parallel bytes. It is then transferred to the DESERIALIZED DATA REGISTER, held momentarily then gated through the DATA IN MUX to the RAM. When the sector(block) is complete the control logic tells the MPU to lower the BSY line. It does and then the Apple strobes the data out of RAM through the output buffer to the interface card. The RAM address counter has been set to the beginning of the data, and each strobe sent by the Apple increments the counter to the next address. ## WRITE DATA FLOW After completing the proper handshake the logic is conditions to accept a block of data from the Apple. The Apple strobes in the data into the RAM and when complete will go through another handshake. This handshake conditions the logic to take the data from the RAM to the SERIALIZER, where it is converted to a serial data stream. Then onto the analog card through the WRITE DATA MUX. ### WRITE/VERIFY The W/V operation is a combined write and read compare. The data comes from the Apple in the same way as it does for a write. When the write operation is complete the MPU goes through a verification of the data written, much like a read operation. NX #### DISK FORMAT The Profile has two disks, each having two sides. Their is a read/write head for each surface. Each surface is divided into 152 concentric tracks. Each Track has 16 sectors. The user has access to 9,728 blocks (sectors). Each sector has 532 bytes of user data. This means that the formatted drive contains 5.17 million bytes of user data. (the equivilant of over 40 DISK II diskettes) #### SECTOR FORMAT Each sector is formatted into two fields, the header and the data block. There is a preamble of 22 bytetimes of zeros before each field. The header contains 16 bytes; two start header bytes, three bytes for track, sector, and head ID's, and three bytes for a redundancy of the compliments of the track, sector head bytes. The rest of the field is filled with zeroes. The data field contains two synce bytes, 532 data bytes, and \*\*\*bytes for the CRC charaters. After the CRC charaters the disk writes zeros until WTGT is lowered. ### CHECK HEADER OPERATION For each read or write operation, the specific sector must be located and checked. This is accomplished by the action of the MPU, RWCL and most all of the logic on the controller. It however is a relatively simple operation. The MPU sets a complete replica of the desired header (exclusive of the first "Ol" start byte) into a specific area of RAM. Then it waits for the sector pulse. When it sees the sector pulse it starts the State Machines. The state machines in combination with the PAL move each successive byte of the header replica into the SERIALIZER which is then serialized and shifted out in sync with the incoming NRZRDTA. It is compared and if there is even a single bit difference in comparison the STATE MACHINES abort the attempt and reset to wait for the next incoming sector then the process is repeated. This will go on until the header matches the image in RAM or there is a timeout error (inside the MPU...its waiting for the "sector done" from the state machine if it doesn't see it in a reasonable amount of time the MPU takes over and goes through an Error routine.) If the desired operation was to read a block, the logic then accepts the data in from disk and moves it into RAM. If the operation was to write a block the logic is conditioned to move the data from RAM to the disk. 319 ## PROFILE COMMUNICATION PROTOCOL This document describes the communication protocol between the Profile hard disk drive and a host computer. Profile is connected to the host by a data bus, a CMD (command) input and a CRES (controller reset) input, a BSY (busy) output, and several other signal lines which are described in the Profile Controller Hardware External Reference Specification and will not be covered in this document. When Profile is turned on, its processor waits 18 seconds for the disk to come up to speed. It then sequentially reads each block on the disk, using the read and write/verify/sparing routines described below, with a retry count of 105 and a sparing threshold of 53, but without the CMD - BSY handshakes. During this disk scan the hardware blinks the ready light about twice per second. The scan usually takes about 55 seconds, but will take more time if errors are encountered. After the scan is done Profile's ready light stays on without blinking, indicating that Profile is ready for use. Profile supports three commands. They are: read, write, and write/verify. The host computer initiates all command sequences by raising the CMD line. Whenever Profile's Z8 processor is idle, it stays in a loop waiting for CMD to go high. After 1 1/2 seconds in this loop (except between the second and third handshakes of a write or write/verify operation) the Z8 will move the head to the innermost position, off the data area of the disk, and turn off the stepper motor. The command bytes for each of the three commands are shown below. | | Blo | ock # | | paring<br>reshold | |------------------|--------------------------|----------------|--------|-------------------| | READ | 00 MS | <br> LS<br> _ | | | | | Blo | ock # | | | | WRITE | | l LS | 1<br> | AZT: | | | Blo | ock # | | - APPLIAL | | WRITE/<br>VERIFY | 02 MS <br> 01 MS | l LS | APPLE | FIDEMAIN | | | | · | W. COL | | 48 Source: David T. Craig Page 0319 of 0580 #### PROFILE COMMUNICATION PROTOCOL Profile interprets CMD high as a request from the host to send it a byte telling it (the host) what Profile expects to do next. When Profile is waiting for a command it sends an '01' in response to CMD high. Profile's other responses are shown in the table below. | PROFILE'S Next Action | PROFILE'S Response | |-----------------------------------------|--------------------| | get a command | 01 | | read a block | 02 | | receive write data | 1 03 | | receive write/verify<br>data | 1 04<br>1 | | do actual write or write/verify on disk | 1 06<br>1 | | | 1 | Profile indicates that its response byte is on the data bug by raising BSY. It then waits (forever, if necessary, as there is no timeout) for CPD to go low. When that occurs, Profile reads the data bus. If the value read is a '55' (hex), Profile executes the next action, and lets the host know that it is done by lowering BSY. If the response from the host is not a '55', Profile sets the NAK received status bit, resets itself to the idle state and waits for CMD to go high again. Profile uses only the number of bytes it needs for each command. Any extra bytes sent are ignored. Valid block numbers range from 000000 to 0025FF inclusive. A block number of FFFFFE will read or write Profile's RAM buffer, while a block number of FFFFFF will read Profile's spare table from the disk. The retry count parameter of the read command tells Profile how many times to reread a block if it gets a CRC or timeout error (zero is a valid number). If a CRC or timeout error occurs, Profile saves the data the first time it reads the block successfully, but rereads the block the full number of times specified in the retry count. If Profile is not able to read a block during any of the retries, it will attempt to read the block an additional 90 times or until the read is successful, whichever comes first. Each timeout error during these 90 retries counts as 9 retries, since that is how many times the disk rotates before a timeout occurs. If Profile is not able to successfully read the block after all these retries, it enters the block number in its bad block table, sets the appropriate error bits (described in detail later), sets up the bus so the host can read the result of its latest read attempt, and lowers BSY to indicate that the operation is finished. If the bad block table is already full (100 entries), Profile will set that error bit instead of entering the block number in the table. If, during the initial retries (those specified by the retry count), the number of errors is less than the number specified in the sparing threshold, Profile sets the four status 49 Source: David T. Craig Page 0320 of 0580 220 ## PROFILE COMMUNICATION PROTOCOL bytes to their appropriate values, sets up the bus for the host, and lowers BSY. However, if the number of errors is equal to or greater than the number specified in the sparing threshold, Profile goes through its write/verify/sparing routine. The w/v/s routine first attempts to write the data on the disk. If the attempt is unsuccessful because there was a seek settle error or because Profile was unable to read its spare table (two conditions which disallow all writes to the disk), Profile will set the operation unsuccessful status bit, set up the data bus for the host, and lower BSY. If the attempt is unsuccessful because of a timeout error, or if the read after write is bad. Profile will retry the whole write/verify routine one more time. If it still is not able to do it, Profile will retry the write/verify/spare routine using a spare sector on the disk. When a write/verify operation is successful, Profile will delete the block number from the bad block table, if it was there, and enter it in the spare table if appropriate. The only difference between a write/verify operation (which uses the write/verify/spare routine described above), and a write operation is that a write operation does not retry on a timeout error, and does not read the block after writing it (and will never spare a block). However, Profile will automatically change a write operation to a write/verify operation if the block being written is in the bad block table. Profile's 9,728 usable blocks are divided into 152 cylinders of 4 surfaces, with 16 blocks (sectors) per track. The blocks are allocated to sectors sequentially, starting with track 0, head 0, sector 0,1,2, ... 15; track 0, head 1, sector 0,1...; track 152, head 3, sector 1,2,...14,15. No blocks are originally assigned to cylinder 77, as it is reserved for the 32 spare sectors and the spare table (which includes some device specific information and the bad block table). Profile's interleave is 5 to 1 for reads, 21 to 1 for writes, and 37 to 1 for write verifies. The latter 2 obviously miss the physical interleave when used with the Apple III. In addition to the wait between successive writes, there is a 30ms wait before the first write after any cylinder change. Profile's rotation speed is 3600 RPM. When the host requests a read or a write from Profile, Profile first translates the block number into the correct track, head and sector values. It then checks to see if the desired block is in the spare table, and sets the track, head, and sector accordingly if so. If the current block and the last block read or written have the same track and head, the Z8 exits the seek routine. If the track is the same but the head is different, the Z8 waits 750us and then exits the routine. Otherwise, the Z8 waits 24ms for the stepper to settle, then tries up to 64 times to read any 3 consecutive sectors on the disk (actually alternate sectors on the disk, since that is the best the hardware can do). If during these reads it determines that it is on the wrong head or track it will set the appropriate error bit and go back to the beginning of the seek routine. If the Z8 is not able to read 3 consecutive sectors because of a timeout (no header found in 26ms) or CRC error, it will retry the entire seek routine up to twice more after moving the stepper off track first to the innermost track and back, and if not successful, then to the outermost track and back. If it is still not able to read 3 consecutive sectors the Z8 will set the seek 50 Source: David T. Craig page 3 m #### PROFILE COMMUNICATION PROTOCOL nage 4 settle error bit, which as mentioned disables all writes to the disk. Following a read or a write the Z8 provides the host with 4 status bytes. They are placed in the buffer immediately preceding the data just read or written. The significance of the individual bits is as follows: #### STATUS 1 - 7 = 1 if Profile received ♦ 55 to its last response 6 = 1 if write or write/verify was aborted because >532 bytes of data were sent or because Profile couldn't read its spare table 5 = 1 if host's data is no longer in RAM because Profile updated its spare table 4 = 1 if SEEK ERROR unable in 3 tries to read 3 consecutive headers on a track 3 = 1 if CRC error (only set during actual read or verify of write/verify, not while trying to read headers after seeking) 2 = 1 if TIMEOUT ERROR (couldn't find header in 9 revolutions not set while trying to read headers after seeking) 1 = N.C. 0 = 1 if operation unsuccessful - STATUS 2 - 7 = 1 if SEEK ERROR unable in 1 try to read 3 consecutive headers on a track 6 = 1 if spared sector table overflow ( > 32 sectors spared) 5 = N.C. 4 = 1 if bad block table overflow ( > 100 bad blocks in table) 3 = 1 if Profile unable to read its status sector 2 = 1 if sparing occurred 1 = 1 if seek to wrong track occurred 2 = N.C. #### STATUS 3 - 7 = 1 if Profile has been reset - 6 = 1 if block number invalid - 5 = 1 if block I.D. at end of sector mismatch - 4 = N.C. - 3 N.C. - 2 = 1 if Profile was reset - 1 = 1 if Profile gave a bad response - 0 = 1 if parity error ## STATUS 4 - 7 0 = the number of errors encountered when rereading a block after any read error - \* These bits are set by the S.O.S. Profile driver. .51 Source: David T. Craig Page 0322 of 0580 32 PROFILE COMMPNICATION PROTOCOL CONFIDENTIAL CONFIDENTIAL As mentioned previously, reading block FFFFFF gets Profile's spare table. The first 13 bytes are allocated for the device name, which is PROFILE followed by 6 blanks. The next 3 bytes are allocated for the device number, which is 00 00 00. The next 2 bytes are used for the program revision number, which currently is 03 90. The next 3 bytes tell how many blocks are available to the user, with the most significant first. These bytes should be 00 26 00. The next 2 bytes tell how many bytes are in each block. These bytes will be 02 14, which equals 532 decimal (however, Profile doesn't care how many bytes the host reads, nor how many bytes the host sends as long as it's not more than 532). The next byte contains the total number of spare sectors available, which is 20 hexadecimal or 32 decimal. This is followed by the number of spares currently allocated (once a spare is allocated it can never be deallocated, except by reformatting the disk), and then followed by the number of bad blocks currently in the bad block table. Finally the numbers of the spared blocks and the numbers of the bad blocks are listed (3 bytes per block number), with delimiters of FF FF FF between the spare and bad block lists and following the bad block list. The diagrams below show how the handshaking works for each of the 3 operations supported by Profile. ## Read Operation #### Write Operation 52 Source: David T. Craig Page 0323 of 0580 . Important: The host must raise CMD following the last operation requested, since changes in Profile's spare and bad block tables do not get rewritten onto the disk until this occurs. After BST goes high, CMD can be lowered as long as anything but 55 (hexadecimal) is on the data bus. .53 Source: David T. Craig Page 0324 of 0580 nix PROFILE COMMUNICATION PROTOCOL Addendum for Controller Versions 3.96 and 3.97 Revision 3.96 of the Profile controller program has several improvements over revisions 3.90 and 3.92 (3.90 and 3.92 are identical except that 3.92 moves the stepper at half the 1.5ms per track rate used by 3.90). Instead of the Z8 falling directly into the write/verify/sparing routine if the number of errors encountered reading a block is greater than the sparing threshold specified by the driver, it rewrites the block then rereads it 100 times. If the error rate is greater than 30%, the block is spared. This 30% sparing criteria is used anytime a write/verify fails to verify, when doing a write or write/verify of a block that is in the bad block table, and when verifying a write to a spare sector. Another change is that a block is spared if the seek was able to read 3 consecutive sectors OK but a timeout error (because of not being able to find the desired header) occurred while doing a write or write/verify. Because of these changes in the sparing algorithm, the sparing threshold during the initial disk scan is now 30% instead of 50%. The last change in revision 3.96 is that the fast seek algorithm is used if the jumper at P6 on the controller board is cut, and the slow seek algorithm is used if the jumper is intact. Revision 3.97 waits 3.28 seconds instead of 1.5 seconds before moving the head off the data area of the disk. SINGLE WESTER PALIGLE TARCETE 330 1-/28/81 TONIFALA SOME ON RAMPAL AS DE ZRU DRW MSEL1 MSELO SSTRB PSTRD BWEN OND CHKHDR CTRCS SDSDE MUXEN PAMOUTEN RAMWPITE PAMSEL ADLDAD ADCLK VCC ADCLK = MSELO+/AS + MSEL1+/MSELO+DRW#/CHKHDP#/RAMWRITE + MSEL1+/MSELO+DRW#CHKHDR#SSTRD + MSEL1+/MSELO+/DRW#JSTRD + /MSEL1+/MSELO+/DRW#JRAMWRITE + /HSEL1+/MSELO+DRW#PSTRD + /ZRW#/AS ADLOAD = MSELO + /ZRW RAMSEL = MSEL1\*MSEL0\*/DS + MSEL1\*/MSEL0\*DRW\*SSTRD + MSEL1\*/MSEL0\*/DRW\*ZRW + MSEL1\*/MSEL0\*CHKHDR + /MSEL1\*/MSEL0\*/DRW\*PSTRR + /MSEL1\*/MSEL0\*DRW\*ZRU AAMWRITE = MSEL1\*MSEL0\*/ZRW + MSEL1\*/MSEL0\*DRW\*/CHKHDR\*SSTRB + /MSEL1\*/MSEL0\*/DRW\*PSTRB + /MSEL1\*MSEL0\*/ZRW\*/DS RAMDUTEN = MSEL1\*MSEL0\*ZRW + MSEL1\*/MSEL0\*DRW\*CHKHDR + MSEL1\*/MSEL0\*/DRW + /MSEL1\*/MSEL0\*DRW + /MSEL1\*MSEL0\*ZRW\*/DS MUXEN = MSEL1\*/MSEL0\*DRW#BWEN\*/CHKHDR#ZRW + /MSEL1\*/MSEL0\*/DRW\*ZRW : SDSDE = MSEL1\*/MSELO\*DRW\*/DWEN\*/CHKHDR CTRCS = /MSEL1\*MSEL0 DESCRIPTION: THIS PAL CONTROLS ACCESS TO THE RAM BUFFER MEMORY FOR THE LS240-LS257 IMPLEMENTATION. WIG BROM. TEXT 60 Source: David T. Craig Page 0331 of 0580 # Introduction The ST506 disc drive is a random access storage device with 1.1 General Description: two non-removable 5% inch discs as storage media. Each disc surface employs one movable head to service 153 data tracks. The total formatted capacity of the four heads and surfaces The total lulimeter capacity of the following per sector, and bytes per sector, 612 tracks). Low cost and unit reliability are achieved through the use of a band actuator and open loop stepper head positioning 612 tracks) . mechanism. The inherent simplicity of mechanical construction and electronic controls allows maintenance free operation throughout the life of the drive. Both Electronic PCB's are mounted outside HDA for field servicability. Mechanical and contamination protection for the heads, actuator and discs are provided by an impact resistant aluminum enclosure. A self contained recirculating system supplies clean air through a 0.3 micronfilter. A second port in the filter assembly allows pressure equalization with ambient air without chance of contamination. A patented spindle pump assures adequate air flow and uniform temperature distribution throughout the head and disc area. Thermal isolation of the stepper and spindle motor assemblies from the disc enclosure yields a very low temperature rise within the enclosure, providing significantly greater off track margin and the ability to immediately perform read and write operations after power up with no thermal stabilization delay. The \$5506 electrical interface is similar to the Shugart Associates SALOOD family of 8 inch fixed disc drives. The ST506 size and mountains is identical to the industry standard ST506 Size and mountains is likely the same DC voltage and minifloppy disc drives and uses the same DC voltage and connector. No AC power is required. - Storage Capacity of 6.38 megabytes unformatted, 5.0 Key Features: - megabytes formatted as shipped. Winchester design reliability, 9.5 gram head load force, - 19 micro-inch flying height. Same physical size and mounting as the minifloppy. - . Same DC voltages as the minifloppy. - Band actuator and stepper motor head positioning. - 5.0 megabit/second transfer rate. - Simple floppy like interface. • Same track capacity as a double density 8 inch floppy. 65 Source: David T. Craig Page 0336 of 0580 CONFIDENTIAL 170 millisecond random average access time, reducible to 95 MS via a simple software algorithm (See Section 4.5.3) #### 1.2 Specification Summary: #### 1.2.1 Physical Specifications: Environmental Limits: Ambient Temperature = 40° to 122°F (4° to 50°C) Relative Humidity = 8 to 80% Maximum Wet Bulb = 78° non-condensing DC Power Requirements +12 volts +5%, 1.8 amps typical 4.5 amps maximum during power on +5 volts +5%, 0.7 amps typical, 1.0 amp maximum Mechanical Dimensions: Height = 3.25 inches Width = 5.75 inches Depth = 8.00 inches Weight = 4.2 lbs. (1.9 kg) Heat Dissipation - 25 watts typical - 29 watts maximum 1.2.2 Reliability Specifications: MTBF = 11,000 POH, typical usage PM = Not required MTTR = 30 minutes Component Design Life = 5 years Error Rates: Soft read errors = 1 per 10<sup>10</sup> bits read \*Hard read errors = 1 per 10<sup>10</sup> bits read Seek errors = 1 per 10<sup>6</sup> bits read = 1 per 10<sup>6</sup> seek \*Not recoverable within 16 re-tries. 1.2.3 Performance Specifications: Capacity Unformatted Per Drive 6.38 Megabytes Per Surface 1.59 Megabytes Per Track 10416 Bytes Formatted Per Drive 5.0 Megabytes 1.25 Megabytes 8192 Bytes Per Surface Per Track Per Sector 532-356 Bytes Dera Sectors per Track \_32- 16 Transfer Rate 5.0 Megabits per second Access Time Track to Track 3 ms Average 170 ms, reducible to 95 ms. (See Section 4.5.3) Maximum 500 ms, reducible to 245 ms. Setting Time 20 ms Average Latency 8.33 msec #### Functional Specifications 1.2.4 3600 rpm ± 1% 7690 bpi max 7690 fci Rotational speed Recording density Flux density Track density - -255 tpi Cylinders 153 152 Tracks -612-608 R/W Heads Disks #### 2.0 Functional Characteristics #### 2.1 General Operation The ST506 disc drive consists of Read/Write and control electronics, read/write heads, track positioning actuator, media, and air filtration system. The components perform the following functions: - Interpret and generate control signals. - Position the heads over the desired track. - 3. Read and write data. - 4. Provide a contamination free environment. WOTEN 32 d 2.2 RE-Desire and Control Electronics Electronics are packaged on two printed circuit boards. The primary board to which power, control and data signals are connected includes: - Index detection circuit. - Head position/actuator circuit. - Read/write circuits. 3. - Drive up to speed circuit - Head select circuit. - Write fault detection circuit. - 7. Step motor drive circuit. - Drive select circuit. - Track zero detector circuit. The series PCB, mounted to the baseplate under the per board derives its power from the primary board and provides power and speed control to the spindle drive motor. #### 2.3 Drive Mechanism A Brushless DC drive motor rotates the spindle at 3600 rpm. The spindle is driven directly with no belt or pulley being used. The motor is thermally isolated from the baseplate to minimize temperature rise in the sealed champer containing the heads and discs. The motor and spindle are dynamically balanced to insure a low vibration level. A brake is used to provide a fast stop to the spindle motor when power is removed. The baseplate is shock mounted to minimize transmissibility of vibration to the chassis or frame. #### 2.4 Air Filtration System (Figure 1) The discs and read/write heads are fully enclosed in a module using a integral recirculation air system with an absolute filter which maintains a clean environment. Integral to the filter is a port which also permits pressure equalization with the ambient air without contaminate entry. #### 2.5 Positioning Mechanism (Figure 2) The read/write heads are mounted on a ball bearing supported carriage which is positioned by a band actuator connected to the stepper motor shaft. The stepper motor is thermally isolated from the baseplate to minimize temperature rise in the sealed chamber containing the heads and discs. 68 Source: David T. Craig Page 0339 of 0580 ### 2.6 Read/Write Heads and Discs The recording media consists of a lubricated thin magnetic oxide coating on a 130 mm diameter aluminum substrate. This coating formulation, together with the low load force/low mass Winchester type flying heads, permit reliable contact start/stop operation. Data on each of the four disc surfaces is read by one read/write head, each of which accesses 155 tracks. #### 3.0 Functional Operations #### 3.1 Power Sequencing (Figure 3) +5 and +12 volts may be applied in any order. +12 volts must be applied to start the spindle drive motor. A speed cense circuit counts 1000 disc revolutions. After 1024 revolutions, the heads will automatically recalibrate to track \$9. (See Section 4.5.2 for exception). For this recalibration to occur, step input signal must be inactive. Track \$9, seek COMPLETE and PEADY signals on the interface will become true simultaneously. The drive will not perform read & write or seek functions until RPADY becomes true. #### 3.2 Drive Selection Drive selection occurs when one of the drive select lines are activated. Only the disc selected will respond to the input signals and only that drive's output signals are then gated to the controller interface. (See Section 4.5.1 for exception). #### 3.3 Track Accessing Read/write head positioning is accomplished by: - a) Deactivating write gate. - b) Activating the appropriate Drive Select Line. - c) Being in the READY condition with SEEK COMPLETE true. - d)\ Selecting the appropriate direction. - e) Pulsing the step line. Each step pulse will cause the heads to move either 1 track in or 1 track out depending on the level of the #### 4.1.6 DRIVE SELECT 1 - 4 DRIVE SELECT, when logically true, connects the drive to the control lines. Cutting the appropriate shunts at IC position 6C will determine which select line on the interface will activate that drive. #### 4.2 CONTROL OUTPUT LINES The output control signals are driven with an open collector output stage capable of sinking a maximum of 40mA at logical zero or true state with maximum voltage of 0.4V measured at the driver. When the line driver is in the logical one or false state, the driver transistor is off and the collector cutoff current is a maximum of 250µA. All J1 output lines are enabled by the respective DRIVE SELECT line. Figure 7 shows the recommended circuit. #### 4.2.1 SEEK COMPLETE This line will go true when the R/W heads have settled on the final track at the end of a seek. Reading or writing should not be attempted when SMEK COMPLETE is false. SEEK COMPLETE will go false in three cases: - A recalibration sequence is initiated (by drive logic) at power on because R/W heads are not over track zero. - 2) 500mS (typical) after the leading edge of a step pulse or series of step pulses. - 3) If +5 volts or +12 volts are lost momentarily but restored. #### 4.2.2 TRACK ØØ This interface signal indicates a true state or logical zero only when the drive's R/W heads are positioned at track zero (the outermost data track). #### 4.2.3 WRITE FAULT This signal is used to indicate a condition exists at the drive that causes improper writing on the disk. When this line is true, further writing and stepping is inhibited at the drive until the condition is corrected. It cannot be reset via the interface. There are three conditions detected: - a) Write current in a head without WRITE GATE active or no write current in the head with WRITE GATE active and DRIVE SELECTED. - b) Multiple heads selected, no head selected, or improperly selected. - c) DC voltages are grossly out of tolerance. #### 4.2.4 INDEX This interface signal is provided by the drive once each revolution (16.67mS nom.) to indicate the beginning of the track. Normally, this signal is a logical one level and makes the transition to the logical zero level to indicate INDEX. Only the transition from one to zero is valid. See Figure 9. #### FIGURE 9 INDEX TIMING #### 4.2.5 READY This interface signal when true together with SEEK COMPLETE, indicates that the drive is ready to read, write or seek, and that the I/O signals are valid. When this line is false, all writing and seeking are inhibited. The typical time after power on for READY to be true is 15 seconds. #### 4.3 DATA TRANSFER LINES All lines associated with the transfer of data between the drive and the host system are differential in nature and may not be multiplexed. These lines are provided at the J2/P2 connectors on all drives. 74 Source: David T. Craig Page 0345 of 0580 Two pairs of balanced signals are used for the transfer of data: WRITE DATA and READ DATA. Figure 10 illustrates the driver/receiver combination used in the ST506 drive for DATA TRANSFER signals. #### FIGURE 10 DATA LINE DRIVER/RECEIVER COMBINATION NOTE: ANY RS 422 DRIVER/RECEIVER PAIR WILL INTERFACE. #### 4.3.1 MFM WRITE DATA This is a differential pair that defines the transitions to be written on the track. The transition of +MFM WRITE DATA line going more positive than the -MFM WRITE DATA will cause flux reversal on the track provided WRITE GATE in active. This signal must be driven to an inactive state (+MFM WRITE DATA more negative than -MFM WRITE DATA) by the host system when in a read mode. To insure data integrity at the error rate specified, the write data presented by the host must be pre-compensated on tracks 64 through 152. 75 Source: David T. Craig Page 0346 of 0580 The optimum amount of pre-compensation is 12nS for both early and late written bits. Figure 11 shows the bit patterns to be compensated. All other patterns are written "on time." #### FIGURE 11 #### WRITE PRE-COMPENSATION PATTERNS Writing should occur out of a shift register which is used to observe the pattern. "On time" represents a nominal delay. Early and late represent less or more delay respectively. 76 Source: David T. Craig Page 0347 of 0580 #### 5.4 J4/P4 Frame Ground Connector Faston AMP P/N 61761-2 Recommended mating connector AMP 62187-1 Note that DC logic ground in the Printed Circuit Board is not connected to frame ground. Use of the frame ground connection is very important to reduce ground loops and noise problems which may cause excess errors. If used, the hole in J4 will accommodate wire size of 18 AWG max. #### 6.0 Physical Specifications This section describes the mechanical dimensions and mounting recommendations for the ST506. #### 6.1 Mounting Orientation Recommended orientation is either vertical on either side or horizontal with PCB down. The only prohibited orientation is horizontal with PCB up (disk surface down, parallel and next to mounting surface). In the final mounting configuration, insure that operation of the four snock mounts which isolate the aluminum base casting from the frame is not restricted. #### 6.2 Mounting Holes Eight mounting holes, four on bottom and two on each side are provided for mounting the drive into an enclosure. The size and location of these holes, shown in Figure 17, are identical to the industry standard minifloppy drive. #### 6.3 Physical Dimensions Overall height/width/depth and other key dimensions are shown in Figures 17 and 18. As in the case of the mounting holes, the dimensions are identical to the minifloppy, allowing a direct physical replacement. #### 6.4 Shipping Requirement During shipping the heads shall be positioned on track 152 to eliminate the possibility of damage. This shall be done while the discs are spinning. CONFIDENTIAL CONFIDENTIAL CONTRACTOR | elc | | | DESCRIPTION | | | | INC BY | APPI | OVAL A | DATE | |---------------------------------------------------------------|--------------------------------|---------------------------|-------------------------------------------------|-------------|-------------------|-------------|--------|-------|--------|-----------| | | 34 | 0 | | | | | | ١. | | | | APP | LICABLE | DOCUMENT | <u>s</u> . | | | | | | | 0 | | | Motor | Control | PCB Assembl | У | | | 20003 | 3-001 | | TIRE | | | Engine | ering Sp | ecification | s: | | | | 1 | CONFIG | SENTIAL ) | | | 2 | and spec | ponents shall<br>ifications se<br>s unless sepa | t forth | in the | follow | ing | | (0) | | | | Main Control PCB (Fab drawing) | | | | 20019-001 | | | | | | | | | | trol PCB (F | | | | 20004 | 4-001 | | | | | ŀ | IDA Assem | bly drawing | | | | | | | | | | ŀ | DS Elect | rical inter | connec | t drav | ring | | | | | | | Magnetic Disc | | | | 30126-001 | | | | | | | | Read/Write Heads | | | | 30125-001 | | | | | | | Interface | | | | 30001-001 · | | | | | | | | | | iead Conn | ector | • | | * | 10420 | 0-016 | | | | | Spindle Motor Connector | | | | | 10417-006 - | | | | | | | Stepper Motor Connector | | | | 10417 | | | 6. 2 | | | | | | Index Con | | | | | 10417 | | | č | | | | Brake Con | nector | <del></del> | | | 10417 | 1 | | | | ODEL NO | <u></u> | ST506 | <u> </u> | | RST USE | FINAL | ASSY | | | | | RAWH | | | 3 | | | | | | | | | HE CX | | | <b>3</b> 5 | EAGATE | TECHNOL | ∞S. | | | | | | PPO(E) | | | | | | · | | | | | | PPD(IN) | HEAD DISC ASSEMBLY | | | | | | | | | | | | OTHERWISE | | | | | | | • | | | | DIMENSIONS ARE IN INCHES TOLERANCES ON DECIMALS ANGLES .XX \$ | | SCALE SIZE DEG NO. 30124- | | | -001 REV. EC 0011 | | | | | | | .xxx | | | DO HOT SCALE | | | <u></u> | SHEET | 1 | or 14 | | | - | | | | : 4 Y | . II . | • | | | • . | | # Apple /// Computer Information • Doc # 78 • ProFile Hard Disk Repair Info 26 Engineering Specification 30124-001 0011 ST-506 HEAD DISC ASM SPECIFICATION SHEET OF TITLE HEAD DISC ASSEMBLY APPLICABLE DOCUMENTS (continued) TK Ø Connector 10417-005 Spin Motor PCB Connector 10419-002 10416-XXX (Ref) Mates with 10417-XXX 10415-XXX (Ref) 10420-XXX 10418-XXX (Ref) " " 10419-XXX Page 0352 of 0580 Source: David T. Craig | | ering Specification 30124 | -001 0011 | |--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------| | TITLES | T-506 HEAD DISC ASM SPECIFICATION SHEET | 3 OF | | CONTEN | TS | | | I. | SCOPE | CONFERMINE | | II. | CAPACITY | (canticia ) | | III. | MEDIA | | | IV. | ENVIRONMENTAL | | | v. | RELIABILITY | | | VI. | POWER | | | VII. | INTERFACE | | | VIII. | DRIVE · | | | IX. | STEPPER MOTOR - ELECTRICAL REQUIREMENTS | | | x. | SPINDLE MOTOR - ELECTRICAL REQUIREMENTS | | | XI. | BAND ASM - MECHANICAL REQUIREMENTS | | | XII. | PHYSICAL REQUIREMENTS | | | I. | SCOPE | | | | | | | | The Head Disc Assembly (HDA) is a sub-assembly. It will to the drive testing before being shipped to the Head Disc Assembly will be a complete Starive less the following hardware: | mdergo all<br>ne customer. | | | ST-506 Final Disc Drive Assembly. It will the drive testing before being shipped to the The Head Disc Assembly will be a complete St | mdergo all<br>ne customer. | | II. | ST-506 Final Disc Drive Assembly. It will a the drive testing before being shipped to the The Head Disc Assembly will be a complete Startve less the following hardware: 1) Main control PCB 2) Motor control PCB | mdergo all<br>ne customer. | | II. | ST-506 Final Disc Drive Assembly. It will a the drive testing before being shipped to the The Head Disc Assembly will be a complete St drive less the following hardware: 1) Main control PCB 2) Motor control PCB 3) Front panel | mdergo all<br>ne customer. | | II. | ST-506 Final Disc Drive Assembly. It will a the drive testing before being shipped to the The Head Disc Assembly will be a complete St drive less the following hardware: 1) Main control PCB 2) Motor control PCB 3) Front panel CAPACITY | mdergo all ne customer. I-506 disc | | II. | ST-506 Final Disc Drive Assembly. It will a the drive testing before being shipped to the The Head Disc Assembly will be a complete St drive less the following hardware: 1) Main control PCB 2) Motor control PCB 3) Front panel CAPACITY Unformatted Mbytes/Drive 6.38 | mdergo all ne customer. I-506 disc | | II. | ST-506 Final Disc Drive Assembly. It will the drive testing before being shipped to the The Head Disc Assembly will be a complete Starive less the following hardware: 1) Main control PCB 2) Motor control PCB 3) Front panel CAPACITY Unformatted Mbytes/Drive 6.38 Bytes/Track 1041 | mdergo all ne customer. 1-506 disc | | II. | ST-506 Final Disc Drive Assembly. It will the drive testing before being shipped to the The Head Disc Assembly will be a complete Starive less the following hardware: 1) Main control PCB 2) Motor control PCB 3) Front panel CAPACITY Unformatted Mbytes/Drive 6.38 Bytes/Track 1041 Formatted 32 Sectors/Track (Soft) Mbytes/Drive 5.0 | mdergo all ne customer. 1-506 disc | | | Eng Specification | | 30124-001 | 001 | |--------|---------------------------------------------------------------------------------------|---------------------------------------|---------------------------------------|----------------------------------------| | ST-506 | HEAD DISC ASM SPECIFI<br>30124-001 | CATION | SHEET 4 | OF | | | Max recording frequer | cy (MHZ) | 2.5 | _0 | | | Transfer Rate | | / | | | | Mbits/Second | | 5.0 | EIDEN | | | Density | | ' | COMFORMAL | | • | Flux Changes/Inch | | 7690 | $\sim$ | | III. | MEDIA | | | | | | Tracks | | | | | | Per Inch Per Surface Per Drive | | 255<br>153<br>612 | | | | Defects (Hard Errors) | · | | | | | Any flaw defined as selength. Sequential circumfrential defection counted separately. | , radial, and cts to be | | | | | Per Drive<br>Per Surface | | 32<br>8 | | | | Per Cylinder Zero | • | Ö | | | IV. | ENVIRONMENTAL | | <b>.</b> | | | | Ambient Temperature* | Operating<br>390 - 135°F<br>40 - 57°C | Shipping<br>25° - 144°F<br>-4° - 62°C | Storage<br>-80 - 176 01<br>-22 C- 80 0 | | | Max Temperature Gradi | ent/Hour | | | | | | 18°F | 18°F | 1801 | | | Relative Humidity | 20 - 80% | 1 - 95% | 1 - 95% | | | Maximum Wet Bulb | 78 <sup>0</sup> | No Condensati | Lon | | | Stray Magnetic Field | (l" from cast: | ing) 20 Ga | uss Max | | | Altitude | | 10,00 | 00 ft. Max | €3 Ambient Temperature is defined as the HDA casting temperature. Source: David T. Craig Page 0354 of 0580 | Apple / | /// Computer Information • Doc # 78 • P | roFile Hard Disk F | Repair Info | |------------------|------------------------------------------------------------------------------------------------------------------|-----------------------------------|----------------------| | 354 Engineer: | ing Specification | 30124-00 | 1 0011 | | ST-S | 506 HEAD DISC ASM SPECIFICATION 24-001 | SHEET 5 | OF U | | ٧. | RELIABILITY Error Rate (Excluding defects) - V Technology PCB P/N 20019-001 Soft read errors (16 retries min.) | When used with ! | Seagate CONFIDENTIAL | | | Soft read errors (16 retries min.) | l per 10 <sup>10</sup> bit | ts transferred | | | Hard read errors | - | ts transferred | | | Seek errors | l per 10 <sup>6</sup> seel | | | | MTBF (Meantime before failure) | | C T OSYT | | | Typical usage | 15,000 hours | SEE NEXT<br>PAGE > | | | PM (Preventive Maintenance) | None | | | | MTTR (Meantime to Repair) | 30 minutes | | | | Component Life | 5 years | | | | Media Life | 10,000 starts/ | stops | | VI. | POWER | | | | | DC Voltages | | | | | +12 VDC + 10%, 1.7 amps typical (3 (More detail on current - see ST-5 | .3 amps during<br>06 OEM Manual 3 | motor start) | | , | BTU/Hr. (1 watt = 3.413 BTU/Hr.) | | | | | Watts<br>BTU/Hr. | 25 + 40%<br>85.3 ± 40% | | | VII. | INTERFACE | | | | | See ST-506 OEM Manual 30001-001 | | | | VIII, | 1 1- · · | using this step | p sequence | | ‡<br>; ; | (Seek = 3 ms) | 2.3 mS | | | * Usin | sg Seagate recommended PCB | 3 mS | | | Septem FILLED | E4 | | | | | | | | | Source: David T. | Craig | | Page 0355 of 0580 | | 353551 | -·-··g | | 1 392 2000 31 0000 | ### Apple /// Computer Information • Doc # 78 • ProFile Hard Disk Repair Info ## 365 Engineering Specification ST-506 HEAD DISC ASM SPECIFICATION TITLE 30124-001 30124-001 0011 SHEET OF Drive Motor Start Time\* Spindle Speed\*\* 15 sec. 3600 rpm ± 17. HDA Cleanliness The air inside the HDA shall be class 100 (0.5 micron particles) Mounting See Figures 1 & 2 Vibration and Shock\*\*\* > Operational Shipping #### B. Electrical For purposes of normalized test data, and unless otherwise stated, all test measurements shall be taken at the ambient conditions of $68 + 5^{\circ}F$ (20 + 3°C) and 40 to 60% relative humidity after the HDA has been stabilized at the test environment for at least 1 hour. Not withstanding this, the HDA shall be capable of meeting all the requirements of this specification over the full operating environment of Paragraph IV, Page 4. #### Warm Up Time The HDA shall meet all operating specifications within 15 seconds after spindle motor has reached 3600 RPM at all operational environmental conditions. - Spindle motor speed regulation 3600 ± 1% RPM - Spindle motor current Start Running 3.6 amps max. 1.0 amps max. 3. Stepper motor/phase 250 ± 50 Ma Typical Using Seagate recommended PCB Adjustments are customer responsibility For shipment, the heads shall be moved to ID while the spindle is rotating £5 Source: David T. Craig Page 0356 of 0580 # Apple /// Computer Information • Doc # 78 • ProFile Hard Disk Repair Info | Doc # 78 • ProFile Hard Disk Repair Info | Doc # 78 • ProFile Hard Disk Repair Info | Doc # 78 • ProFile Hard Disk Repair Info | Doc # 78 • ProFile Hard Disk Repair Info | Doc # 78 • ProFile Hard Disk Repair Info | Doc # 78 • ProFile Hard Disk Repair Info | Doc # 78 • ProFile Hard Disk Repair Info | Doc # 78 • ProFile Hard Disk Repair Info | Doc # 78 • ProFile Hard Disk Repair Info | Doc # 78 • ProFile Hard Disk Repair Info | Doc # 78 • ProFile Hard Disk Repair Info | Doc # 78 • ProFile Hard Disk Repair Info | Doc # 78 • ProFile Hard Disk Repair Info | Doc # 78 • ProFile Hard Disk Repair Info | Doc # 78 • ProFile Hard Disk Repair Info | Doc # 78 • ProFile Hard Disk Repair Info | Doc # 78 • ProFile Hard Disk Repair Info | Doc # 78 • ProFile Hard Disk Repair Info | Doc # 78 • ProFile Hard Disk Repair Info | Doc # 78 • ProFile Hard Disk Repair Info | Doc # 78 • ProFile Hard Disk Repair Info | Doc # 78 • ProFile Hard Disk Repair Info | Doc # 78 • ProFile Hard Disk Repair Info | Doc # 78 • ProFile Hard Disk Repair Info | Doc # 78 • ProFile Hard Disk Repair Info | Doc # 78 • ProFile Hard Disk Repair Info | Doc # 78 • ProFile Hard Disk Repair Info | Doc # 78 • ProFile Hard Disk Repair Info | Doc # 78 • ProFile Hard Disk Repair Info | Doc # 78 • ProFile Hard Disk Repair Info | Doc # 78 • ProFile Hard Disk Repair Info | Doc # 78 • ProFile Hard Disk Repair Info | Doc # 78 • ProFile Hard Disk Repair Info | Doc # 78 • ProFile Hard Disk Repair Info | Doc # 78 • ProFile Hard Disk Repair Info | Doc # 78 • ProFile Hard Disk Repair Info | Doc # 78 • ProFile Hard Disk Repair Info | Doc # 78 • ProFile Hard Disk Repair Info | Doc # 78 • ProFile Hard Disk Repair Info | Doc # 78 • ProFile Hard Disk Repair Info | Doc # 78 • ProFile Hard Disk Repair Info | Doc # 78 • ProFile Hard Disk Repair Info | Doc # 78 • ProFile Hard Disk Repair Info | Doc # 78 • ProFile Hard Disk Repair Info | Doc # 78 • ProFile Hard Disk Repair Info | Doc # 78 • ProFile Hard Disk Repai 4. Performance (Head Disc Asm) Average 2F amplitude 1.0 mv p-p min. Inside window margin (without write precomp) 30 ns total Minimum resolution on any track 60% (without precump.) #### Wide Gap Measurement - 1. DC erase tracks 150, 151, 152 - 2. Write 2F on track 151 - 3. Write 1F on tracks 150 & 152 - 4. Measure IF amplitude relative to 2F amplitude on track 151 using H.P. spectrum analyzer Model No. 3585A or equivalent. - 5. Failure is defined as a measurement $\geq$ 26dB. ----- 67 1060 **E**6 Source: David T. Craig Page 0357 of 0580 ## Apple /// Computer Information • Doc # 78 • ProFile Hard Disk Repair Info JERRATE TREDENCIES Engineering Specification 30124-001 0011 ST-506 SHEET 9 OF TITLE HEAD DISC ASSEMBLY ELECTRICAL REQUIREMENTS SPINDLE MOTOR COLL A Resistance of Winding: A Or $B = 2\Omega NOM$ A Inductance of Winding: COLL B A Or B = 1.6 mH NOM Hall Device Asymmetry B ≤ - 30 db. Hall Device Hall in X NOIES: All measurements shall be done with two discs. 1. Rated Speed : 3600 RPM 2. Input Voltage : 12 VDC ± 10% 3. Start Time : 15 Sec (Max) at Low Voltage 4. Stop Time : 15 Sec (Max) 5. Inertia of Discs: .04 Oz. - In - Sec<sup>2</sup> 6. The horizontal magnetic field in a plane parallel to the plane of the disc shall be less than 0.5 gauss. 89 Source: David T. Craig Page 0359 of 0580 # Apple /// Computer Information • Doc # 78 • ProFile Hard Disk Repair Info 30124-001 0011 199 Engineering Specification ST-506 HEAD DISC ASM SPECIFICATION OF SHEET 10 TITLE 30124-001 IX. PHYSICAL REQUIREMENTS The HDA can be mounted on any side except upside down or front and back. (See Figures 1 & 2) The HDA is shock mounted for vibration isolation. In the final mounting configuration, care shall be taken to insure that the operation of the four shock mounts is not restricted. A shipping bracket shall be provided to hold the two side frames together to minimize shipping damage. During operation, the side frames shall be provided with a tie bracket to simulate the front cover, in applications where the ST-506 front cover is removed. 90 Page 0360 of 0580 Source: David T. Craig ## Apple /// Computer Information • Doc # 78 • ProFile Hard Disk Repair Info SE SEUGERFREDENCIEDEN 360 30124-001 0011 ST-506 Head Disc ASM Specification SHEET OF 30124-001 11 TITLE BAND ASSEMBLY Capstan 2 Assembly. BAND SPECIFICATIONS 1. Band shall be capable of withstanding 2.5 lbs. Max. tension. 2. There shall be no creases on the active portion of the band.-3. Band shall be free of contaminants that would decrease it's life, such as finger prints and edge nicks. C. 7 Page 0361 of 0580 Source: David T. Craig #### APPENDIX A I/O PIN ASSIGNMENTS OF PROFILE SYSTEM SECTION 1-INTERFACE CARD SLOT EDGE CONNECTOR . INTERFACE/CONTROLLER CONNECTOR "P1" | PIN NUMBER | NMEMONIC | DIRECTION | | |------------|---------------|-----------|--| | 1 | PHO | OUTPUT | | | 2 | SIGNAL GROUND | OUTPUT | | | 3 | TR/W | OUTPUT | | | 4 | SIGNAL GROUND | OUTPUT | | | 5 | <b>X</b> D0 | BI | | | 6 | XD1 | BI | | | 7 | N.C. | | | | 8 | XD2 | BI | | | 9 | SIGNAL GROUND | OUTPUT | | 93 Source: David T. Craig Page 0364 of 0580 #### Apple /// Computer Information • Doc # 78 • ProFile Hard Disk Repair Info | 364 | | | |-----|---------------|--------| | 10 | Ħ | ** | | 11 | <b>x</b> D5 | BI | | 12 | <b>X</b> D6 | BI | | 13 | <b>X</b> D7 | BI | | 14 | SIGNAL GROUND | OUTPUT | | 15 | /PSTRB | OUTPUT | | 16 | /BSY | INPUT | | 17 | /CH4D | OUTPUT | | 18 | /RPARITY | INPUT | | 19 | SIGNAL GROUND | OUTPUT | | 20 | | ** | | 21 | /CRES | OUTPUT | | 22 | <b>X</b> D3 | BI | | 23 | <b>3</b> 204 | BI | | 24 | SIGNAL GROUND | OUTPUT | | 25 | /CDET | INPUT | NOTE: ONE MAY USE THIS TABLE FOR THE CONTROLLER CARD P1 JUST REVERSE OUTS/INS SECTION 2 CONTROLLER CARD INTERFACE/CONTROLLER "P1" SEE P1 IN SECTION 1 CONTROLLER TO ANALOG CARD "P2" | PIN NUMBER | NMEMONIC | DIRECTIO | |------------|---------------|----------| | 1 | SIGNAL GROUND | OUTPUT | | 2 | /TRKO | INPUT | | 3 | SIGNAL GROUND | OUTPUT | | 4 | INDEX | INPUT | | 5 | SIGNAL GROUND | OUTPUT | | 6 | POWEROK | INPUT | | 7 | SIGNAL GROUND | OUTPUT | | 8 | /WRTSM | OUTPUT | | 9 | SIGNAL GROUND | OUTPUT | | 10 | 1 OMHZ | OUTPUT | | 11 | SIGNAL GROUND | OUTPUT | | 12 | NRZWDTA | OUTPUT | | 13 | SIGNAL GROUND | OUTPUT | | 14 | MTR DRIVE OAL | OUTPUT | | 15 | SECTOR | INPUT | | 16 | MTR DRIVE 0A2 | OUTPUT | | 17 | +12VDC | OUTPUT | | 18 | MTR DRIVE OB2 | OUTPUT | | | -12VDC | INPUT | | 19 | MTR DRIVE OB1 | OUTPUT | | 20 | | OUTPUT | | 21 | +5VDC | OUTPUT | | 22 | /WIGT | OUTPUT | 94 Source: David T. Craig Page 0365 of 0580 #### Apple /// Computer Information • Doc # 78 • ProFile Hard Disk Repair Info 365 | | | - | |----|----------------|---------| | 23 | +5VDC : | _OUTPUT | | 24 | /PRECOMP*LOCUR | OUTPUT | | 25 | +5VDC | OUTPUT | | 26 | HS0 | OUTPUT | | 27 | +5VDC | OUTPUT | | 28 | HS1 | OUTPUT | | 29 | SIGNAL GROUND | OUTPUT | | 30 | RDGT | OUTPUT | | 31 | SIGNAL GROUND | OUTPUT | | 32 | /NRZDATA | INPUT | | 33 | SIGNAL GROUND | OUTPUT | | 34 | /RDCLK | INPUT | NOTE: ONE MAY USE THIS TABLE FOR ANALOG CARD J15, REVERSE INS AND OUTS POWER SUPPLY TO CONTROLLER "P3" | PIN NUMBER | NMEMONIC | DIRECTION | | |------------|----------|-----------|--| | 1 | +5VDC | INPUT | | | 2 | +12VDC | INPUT | | | 3 | POWEROK | INPUT | | | 4 | -12VDC | INPUT | | | 5 | GROUND | INPUT | | CONTROLLER TO LED "P4" | PIN NUMBER | NMEMONIC | DIRECTION | | |------------|---------------|-----------|--| | 1 | /READY | OUTPUT | | | 2 | R17 SOFT FIVE | OUTPUT | | CONTROLLER TO TEST "P5" SECTION 3 ANALOG CARD | PIN NUMBER | NMEMONIC | DIRECTION | | |------------|----------|-----------|--| | 1 | +5VDC | OUTPUT | | | 2 | 5MHZ | OUTPUT | | | 3 | +5VDC | OUTPUT | | | 4 | 10MHZ | OUTPUT | | | 5 | GROUND | OUTPUT | | | 6 | SYSCLK | OUTPUT | | | 7 | GROUND | OUTPUT | | | 8 | /PHO | OUTPUT | | | 9 | GROUND | OUTPUT | | | | | | | 45 Source: David T. Craig Page 0366 of 0580 ## Apple /// Computer Information • Doc # 78 • ProFile Hard Disk Repair Info 36 MARLOS TO HEARS HDQY HD-Ø HDQX HO1Y HD-1 HOLX 81 HDZY HDZX OUT 81 81 HD3X OUT B1 HD-3 ASOCAI OT SUGS 947 12 our MUR TO STEPPER. 96 Source: David T. Craig Page 0367 of 0580 ### 2 Removals/Adjustments 3.2.1 Main Control P.C.B. Tools Required: 5/64" Hex Driver Loctite #242 - 1) Remove (4) 6-32 x 1/4" button head Screws - 2) Disconnect J4 through J8, noting their positions - 3) Slide the P.C.B. toward the rear of the drive and remove - 4) To re-install, reverse the above procedure using Loctite on the first 3 threads of all 6-32 screws. #### 3.4.2 Motor Control P.C.B Tools Required: 5/64" Hex Driver Loctite #242 - 1) Remove (4) 6-32 x 1/4" Main Control P.C.B. Mounting Screws - 2) Disconnect J4 through J8, noting their positions - 3) Disconnect J1 and J2, noting their operation - 4) Remove the Motor Control P.C.B. - 5) To re-install, reverse the above procedure using Loctite on the first 3 threads of all 6-32 screws. Note: Whenever the Motor Control P.C.B. is replaced or any of its components are changed, the Spindle speed must be adjusted. Connect a frequency counter to Test Point 4 (Index) and adjust R3 on the Motor Control P.C.B. (accessible through the sideframe) to a period of 16.67 msec. Additionally, if C5 is changed, the Motor Control board should be burned in for at least 12 hours settle the capacitor before adjusting the speed. #### 3.2.3 Spindle Brake Tools Required: 5/64" Hex Driver Loctite #242 10 Mil shim (.010") - 1) Remove the Main Control P.C.B. as outlined in Section 3.2.1 - 2) Disconnect J2 at the Motor Control P.C.B.; free the brake wires from their retaining clips - 3) Remove (1) 6-32 x 1" button head brake mounting screw, washer, and spacer. - 4) Remove the brake solenoid 98 Source: David T. Craig Page 0369 of 0580 Blen - 5) To re-install, reverse the above procedure using Loctite on the first 3 threads of the 6-32 screws. Do not tighten the brake mounting screw - 6) Insert the 10 mil shim between the brake pad and the spindle motor housing - 7) Move the brake toward the spindle motor housing until a slight resistance is felt on the shim - 8). Tighten the 6-32 brake mounting screw and verify that the contour of the brake pad aligns with the spindle motor housing - 9) Continue the re-installation procedure #### 3.2.4 Index Sensor Tools Required: 5/64" Hex Driver Loctite #242 30 mil shim - 1) Remove the Main Control P.C.B. as outlined in Section 3.2.1 - 2) Remove the connector from the front panel LED, noting the orientation of the connector - Free the Index wires from their retaining clips. - 4) Remove (2) $6-32 \times 1/8$ button head Index mounting screws and remove the Index mounting bracket - 5) Remove the Index sensor - 6) To re-install, reverse the above procedure using Loctite on the first 3 threads of all 6-32 screws. - 7) Check the gap between the index sensor and the motor hub using the 30 mil shim. If the gap is not 30 mils, loosen the two index screws and adjust it. #### 3.2.5 Ground Spring Tools Required: 5/64" Hex Driver Loctite #242 - 1) Remove the Main Control P.C.B. as outlined in Section 3.2.1 - 2) Remove (1) $6-32 \times 1/8$ " button head ground spring mounting screw - 3) Remove the ground spring - 4) To re-install, reverse the above procedure using Loctite on the first 3 thread of all 6-32 screws - 5) Verify that the ground spring/spindle motor contacts are clean and making good contact. Also center the ground spring over the spindle motor ball. 00 Source: David T. Craig Page 0370 of 0580 #### 3.2.6 Front Cover Tools Required: 5/64" Hex Driver Loctite #242 - 1) Remove the Main Control P.C.B. as outlined in Section 3.2.1 - 2) Remove the connector from the front panel LED, noting the orientation of the connector - 3) Remove (2) $6-32 \times 1/8^{\circ}$ button head from panel mounting screws - 4) Remove the front panel - 5) Remove the LED and grommet from the front panel, noting the orientation of the LED by the small dots on the connector end of the LED - 6) To re-install, reverse the above procedures using Loctite on the first 3 threads of all 6-32 screws #### 3.2.7 Front Cover LED Tools Required: 5/64" Hex Driver Loctite #242 - Remove the Main Control P.C.B. as outlined in Section 3.2.1 - Remove the connector from the front panel LED, noting the orientation of the connector. - 3) Remove the LED and grownet from the front panel, noting the orientation of the LED by the small dots on the connector end of the LED - 4) To re-install, reverse the above procedure using Loctite on the first 3 threads of all 6-32 screws #### 3.2.8 Side Frames Tools Required: 5/64" Hex Driver Loctite #242 - Remove the Main and Motor Control P.C.B.'s as outlined in Section 3.2.2 - 2) Remove (2) $6-32 \times 1/8$ " button head front cover mounting screws. Do not disconnect the LED connector - 3) Remove (4) 6-32 x 5/16" button head side frame mounting screws, grommets, and spacers - 4) Remove the right and left side frames 100 Source: David T. Craig Page 0371 of 0580 #### Apple /// Computer Information • Doc # 78 • ProFile Hard Disk Repair Info 341 5) To re-install, reverse the above procedure using Loctite on the first 3 threads of all 6-32 screws Note: Removal of any assembly not covered in this section is not possible without special clean room facilities and tools. 101 Source: David T. Craig Page 0372 of 0580 Apple Computer, Inc. Service Engineering Department # Apple /// Computer Repair Document Profile Hard Disk DskDbg – Block Device Debugger Version E00.17 Service Manual Author: Apple DAVID T. CRAIG 736 EDGEWATER, WICHITA, KANSAS 67230 [USA] Source: David T. Craig Page 0373 of 0580 #### Apple /// Computer Information • Doc # 78 • ProFile Hard Disk Repair Info DAVID BROMAGEM (CA) 1991? Vages: 26 (#ed 1-24) DSKDBG - BLOCK DEVICE DEBUGGER VERSION E00.17 SERVICE MANUAL EX LIBRIS: DAVID T. CRAIG 736 EDGEWATER WICHITA, KANSAS 67230 RT4D STATUS (DEDUSSED III) H 2(3) Source: David T. Craig Page 0374 of 0580 #### TABLE OF CONTENTS | Sec | tion | | F<br>- | ege | |-----|-------------------|------------------|--------------------------------------------------|-----| | 1. | INTR | ODUCTION | 7 | 1 | | | 1.2 | HOW TO | USE THIS PROGRAM | 1 | | | 1.3 | TYPICAL | COMMAND EXAMPLES | 1 | | 2. | COMMAND STRUCTURE | | | 5 | | | 2.1 | COMMANI | PROMPT | 5 | | | 2.2 | DETAIL | ED COMMAND DESCRIPTIONS | 6 | | | | 2.2.1 | Buffer Fill | 6 | | | | 2.2.2 | Create Spare | 6 | | | | 2.2.3 | Display | 7 | | | | 2.2.4 | Format | 8 | | | , | 2.2.5 | Get Status | 8 | | | | 2.2.6 | Initialize Spare Table | 9 | | 3. | COMM | AND SUM | MARY | 10 | | 4. | NEW | FEATURE | S | 16 | | 5. | SPEC | IAL DAT | A RECOVERY FUNCTIONS OF THE XECUTE (X) COMMAND | 17 | | | 5.1 | USING | THE X COMMAND WITH THE STANDARD ROM | 17 | | | 5.2 | USING | THE X COMMAND WITH THE FORMATTER/DEBUGGER ROM | 18 | | 6. | SAMP | LE SCRE | EN DISPLAY | 19 | | 7. | TYPI | CAL PRO | BLEMS AN HOW TO AVOID THEM | 20 | | 8. | | | IN VERSIONS E00.17 AND E00.16 | | | 9. | STAT | US BYTE | DESCRIPTIONS | 22 | | | 9.1 | STATUS | BYTES WITH STANDARD ROM V-3.98 INSTALLED | 22 | | | 9.2 | STATUS<br>INSTAL | BYTES WITH FORMATTER/DEBUGGER ROM FD3.98, REV 11 | 23 | | | | | · , | | Source: David T. Craig Page 0375 of 0580 #### Block Device Debugger #### 1. INTRODUCTION The Formatter/Debugger program is provided as a service aid for troubleshooting block I/O devices such as the ProFile disk drive. It is a program that allows you to directly communicate with a block I/O device and exercise it through a series of unique commands or build simple test sequences that will assist in debugging the device. It is a particularly helpful tool for servicing devices that have been returned because of a malfunction, etc. For example, the program can be used to detect an error and then by using the loop on error function, you can use an oscilloscope to analyse the circuit that caused the error. You can use the program to service a drive containing either the Formatter/Debugger ROM or the Standard ROM. (The Standard ROM is the operational ROM that is shipped in the disk drive.) The command summary, section 3, specifies which type of ROM must be in the drive to use a given command. #### 1.1 HOW TO USE THIS PROGRAM To use this debugger properly, you should be aware of some of the design concepts. In designing the user interface (command structure) it was decided to use single character commands. This permits you to type in the command very rapidly and use options (which are not always required) to modify certain test variables. The most used test variables are the three byte logical block that is treated as either a 24-bit number or as three 8-bit numbers. As a 24-bit number, the variable represents a standard logical block with a decimal range of 0-16 million blocks (Hex 000000- FFFFFF). As three 8-bit numbers, each variable has a range of 0-255 (Hex 00-FF). The program makes <u>no</u> <u>assumptions</u> about the use of the test variable; it just gives you two ways to talk to it. You can consider it as a large (24 bit) number or as three smaller (8 bit) numbers. This variable is sent to the disk exactly as a 24-bit number which the firmware decides how to interpret. You, the user, must know how the firmware will react to understand what the firmware is doing with the block number. #### 1.2 TYPICAL COMMAND EXAMPLES To help make the concept of this program more clear, here are some examples that show what the more common commands do. Page 1 Source: David T. Craig Page 0376 of 0580 Block Device Debugger R (Read) This command requests data to be read from the unit being tested. It passes the command and the BLOCK variable to the unit and transfers the data from the unit to the input buffer (see the display command, section 2.2.3, for information on displaying the input buffer). R by itself does not change the BLOCK variable; it uses its current value. However, you can change the block variable by adding a modifier to the command in the form of a number. This number is normally treated such that leading zeros are assumed, thus 0, 00, 0000, etc. all produce the 24-bit value 000000. For example: RO or ROO or ROO0000, etc. (read block 000000) R13 or RO13 or R 0013, etc. (read block 000013) In the above example, the BLOCK variable sent is either 000000 or 000013. The number 13 is the same as 013 or 000013 and produces the value 000013 in the BLOCK variable. #### NOTE The number 13 in the example is a HEX number, not a decimal number. 13 Hex = 19 Decimal Remember that the firmware in the disk drive being tested determines how the BLOCK variable will be treated. Normally it is treated as a logical block. Next, let's change the command as shown in the following example: RT1H2S3 or RT01H02S03, etc. (read block 010203) Notice that the command now has 3 modifiers in the form of T and a number, H and a number, and S and a number. The modifier T references the first 8-bits of the BLOCK variable, the H references the second 8-bits, and the S references the third 8-bits. Note that they are separate modifiers and can be used independently. For example: If BLOCK = 000000, then the command RT5 will set BLOCK = 050000 If BLOCK = 050000, then the command RH3 will set BLOCK = 050300 If BLOCK = 050300, then the command RT16S9 will set BLOCK = 160309 Note that the last command in the example happened to affect the first and third bytes. Had the last command been RS9 then the BLOCK would have been 050309. REMEMBER! The numbers used are always Hexidecimal numbers. \$797 \$15/97 \$15/97 Page 2 $H = \phi - 3$ $T = \phi - 97$ $S = \phi - 15$ $B = \phi - - 297\phi 0$ Source: David T. Craig Page 0377 of 0580 3/1 Block Device Debugger W (write) This command requests data to to be written to the unit being tested. It passes the command and the BLOCK variable to the unit and transfers the data to the unit from the output buffer (see the buffer fill command, section 2.2.1, and the display command, section 2.2.3). W by itself does not change the BLOCK variable; it uses its current value. However, as was the case with a read command, the BLOCK variable can be changed by adding a modifier. For example, the commands WO, WT3H2S1, WH9, etc. have the same effect on the BLOCK variable that they do in the Read command. + (plus) This command increments the BLOCK variable. + by itself increments the variable by 1. For example, if the BLOCK variable was 00001F, then after + it will be 000020 (Note the hex numbers). +3 will increment the BLOCK by 3 each time. +3T will increment the first 8-bit variable by 3 each time. For example, if the BLOCK was 050311, then +3T will change it to 080311. H and S work the same way to modify the second and third groups of 8-bit variables. To provide wraparound and carry, the + command will wrap a 24-bit number at FFFFFF. It will wrap T at 97 (97 increments to 0) and will set H an S to 0 to provide full wrap. H will wrap at 3 (3 goes to 0) creating a carry to T and S will wrap at F (F goes to 0) creating a carry to H. Future enhancements will be to find out what the maximum block count for a device is and then wrap the 24-bit number at that count. D (Display) This command displays the contents of the input or output buffers. - D by itself will display the input buffer. - DI is the same as D. - DO will display the output buffer. - DS will decode the contents of the input buffer as extended status information. The form of the display is the same as that for an APPLE monitor memory dump. It will display the first 256 bytes of the buffer and pause so that you can study the values. At the bottom of the screen it asks for ESCAPE to terminate, RETURN to quit, ANY other key to continue. ESCAPE stops further display and cancels the rest of the command line effectively stopping processing and returning 5-563N Page 3 Source: David T. Craig Page 0378 of 0580 #### Block Device Debugger control to the user. RETURN quits the display command and causes the program to go on to the next command. Pressing any of the other keys, except the space bar, will allow the program to display the next 256 bytes of the buffer. Pressing the space bar will allow you to display the buffer line by line. #### CAUTION If you just keep hitting a key to see the next 256 bytes you will see first the buffer you requested and then memory above it. There are areas of ram above the buffers that will, when displayed cause your screen to get VERY sick and you will have to either re-boot the program or be very familiar with APPLE III hardware and monitor. Just incase you are not familiar with the monitor memory display, here is an example. (The monitor doesn't display the descriptive information above the dashed line.) Address 0 1 2 3 4 5 6 7 8 9 A B C D E F 8000: 00 1A 23 92 FF FE A5 2F 33 34 00 00 00 00 00 00 8010: 12 11 34 87 FE 44 00 00 3E 4C 00 20 A9 0F C5 00 etc. Page 4 2329 #### 2. COMMAND STRUCTURE Each command consists of one or more characters and modifiers in command groups. Each group is separated by one or more spaces. The command line is one or more command groups. There is enough space in the command buffer for 255 characters. Multiple command lines are possible by use of the Macro Add command. #### 2.1 COMMAND PROMPT The program prompt consists of the following two lines: S1 D1 COMMAND (B,C,D,F,G,H,I,L,M,N,O,P,Q,R,S,T,V,W,X,+,-,/, ?) => The first line contains two flags, S1 D1, that tell which slot and drive the program is set to test. Two other flags can also appear on this line to indicate when pause on error is active and when the Macro table is full. They are identified by the letters P (pause on error active) and M (macro table full) on a white background. The second line of the prompt consists of the first letter of each valid command. A list of the commands is always available by typing H or ? and pressing RETURN. In this manual you will see this written as H(n) or P(n). (The n is the symbol for newline, often called RETURN.) #### NOTE After typing a command and pressing RETURN to execute it, you can press ESCAPE to terminate the command. However, if you wish to review the command that you just executed for the purpose of changing it, etc., you can type CONTROL A instead of ESCAPE. Page 5 Source: David T. Craig Page 0380 of 0580 ж<sup>0</sup> #### 2.2 DETAILED COMMAND DESCRIPTIONS Following are descriptions of some of the commands that require more detailed explanations than others. In depth examples of some of the more commonly used commands such as Read, Write, Increment, and Display were provided in section 1.2. For an overall summary of all commands, refer to section 3. #### 2.2.1 BUFFER FILL Syntax B[num] ---- where num is an optional 16 bit hex number (eg., B0123) The buffer fill command is used to fill the output buffer with a specific data pattern. It can be used with either the Formatter/Debugger ROM or the Standard ROM installed in the drive. To use the command, type B followed by a number which will be treated as a 16 bit (2 byte) pattern. For example, the command RO B1234 WO B45 W1<n1> would read logical block-0, fill the output buffer with 12341234..., write block-0, fill the output buffer with 00450045..., and finally write this data to block-1. #### 2.2.2 CREATE SPARE Syntax C(n1) ---- the C-command must be the first command on the line. The create spare command is used to force a peripheral device to transfer a logical block to a new (spare) physical location on the device. The command will then request the block number to be spared and will then request confirmation from the user. If confirmed, the logical block will be spared by the device controller. This command should only be used when the Standard ROM is installed in the drive. Using this command will allow you to fix flaky blocks found during testing. The user will be asked for confirmation of this command. Respond with Y (Yes) or N (no). #### NOTE Do not attempt to use the create spare command when the Formatter/Debugger ROM, version D3.11 or earlier, is installed in your drive. Page 6 Source: David T. Craig Page 0381 of 0580 381 2.2.3 DISPLAY Syntax D[I,0,S] ---- where I is input buffer, O is output buffer, and S is the extended status information in the input buffer. The display command can be used with either the Formatter/Debugger ROM or the Standard ROM installed in the drive. It is used to display the contents of the input or output buffers. These buffers occupy the following Hex locations in the computer's memory: ``` input buffer ----8000H - 8213H output buffer ---8300H - 8523H ``` The display will show 256 bytes at a time, scrolling to the next 'page' after each key press. To end the display and continue executing the command line, press RETURN. To abort the command line press ESCAPE. With the display on the screen, you can press the spacebar to cause a scroll to the first line of the next 'page'. Then, each time you press the space bar, the display will scroll one line forward. The Display Status command works only slightly differently in that it decodes the input buffer into Extended status info about the spares and bad blocks and it will not stop until it is finished or until the space bar, RETURN key, or the ESCAPE key are pressed. REMEMBER! The Display Status command will decode anything found in the input buffer so be sure to use the Get Status command first to make sure that the information is valid. Before using the Display Status command with the Formatter/Debugger ROM installed, you must initialize the spare tables (see section 2.2.6) and then use the Get Status command, otherwise the display will contain garbage. With the Standard ROM installed, you only have to issue the Get Status command before displaying the extended status of the input buffer. Here are some additional tips about using the Display Status command. - After typing D[S] and pressing RETURN, press the space bar to stop the listing. Press the space bar again each time you wish to step through another line of the listing. Pressing any other key will cause a fast scan of the listing. - Pressing ESCAPE will cancel the rest of the display function. - Pressing RETURN will terminate the spare sector listing and start the bad block listing. Page 7 Source: David T. Craig Page 0382 of 0580 36V Block Device Debugger #### 2.2.4 FORMAT Syntax F<nl> ---- this command must be the <u>first command</u> in the command line. The Format command is used with the Formatter/Debugger ROM installed in the drive. It is used to erase all old data from memory and lay down a new pattern of address and data. After formatting a drive with the Formatter/Debugger ROM installed, you can type D[I] to get a list of the defective blocks. The list will end with FF FF FF. Refer to the documentation provided for the F/D ROM for further details. #### WARNING This command is very dangerous and should only be used if damage to the address headers has occurred and only after every reasonable attempt has been made to recover other data from the device. The user will be asked to confirm this command. Respond with Y (Yes) or N (No). Remember! This command will erase all previously recorded data. Following is an example of the error message that will be displayed if you attempt to format a drive with a Standard ROM installed. I/O ProFile Block R1 R2 R3 R4 S1 S2 S3 S4 S5 S6 FORMAT S1 D1 00 03 5F 00 00 00 00 55 55 55 55 00 00 The 55's in this example are the error indicators. 2.2.5 GET STATUS Syntax G<n1> The Get Status command is used to obtain extended status information from the drive and place it in the input buffer. (You will need to execute the Display command to view the contents.) The Get Status command makes sure that the status you are going to view is valid. When using a ProFile you can also get the status by reading block FFFFFF. Page 8 Source: David T. Craig Page 0383 of 0580 36° Block Device Debugger #### 2.2.6 INITIALIZE SPARE TABLE Syntax I<nl> ---- this command must be the first command in the command line. The Initialize command is used by the ProFile Formatter/Debugger ROM to setup the spare tables in the ProFile drive. After the Debugger ROM has formatted the disk, the entire disk is available to read from or write on so that certification of the entire disk is possible. After the spare table sectors have been certified, the tables need to be initialized to allow the controller ROM to work properly. The Initialize command is not used when the Standard ROM is installed in the drive. #### WARNING This command is potentially dangerous as it effectively erases any old spared table data and if used incorrectly will cause the loss of valuable data on the ProFile. The user will be asked to confirm this command. In response, type Y (Yes) or N (No). Page 9 Source: David T. Craig Page 0384 of 0580 364 #### 3. COMMAND SUMMARY Following is a summary of all the commands that can be used with this program: NOTE Data shown in [] or () is optional. BUFFER FILL B[<nl>] or B[num] Fill the output buffer. where num is a 16 bit hex fill number used with both Formatter/Debugger and Standard ROMs CREATE SPARE C<n1> Force the drive to spare the current block. must be the first command on the command line used only with Standard ROM DISPLAY $D[\langle n1 \rangle]$ or D[1] or D[0] or D[S] Display the I/O buffers. used with both Formatter/Debugger and Standard ROMs FORMAT F<nl> Format the device. this is a <u>dangerous command</u> used only with Formatter/Debugger ROM Page 10 Source: David T. Craig Page 0385 of 0580 #### Apple /// Computer Information • Doc # 78 • ProFile Hard Disk Repair Info nggs ock Device Debugger GET STATUS G[<n1>] Get extended status information. Remember! When using the ProFile, RFFFFFF (read block FFFFFF) also returns status information used with both the Formatter/Debugger and Standard ROMs HELP $H[\langle n1 \rangle]$ or H[E] or H[E2] or H[char] Print a list of commands, or errors, or a detailed description of each command. where E is to display errors when the Standard ROM is installed where E2 is to display errors when the Formatter/Debugger ROMis installed where char is any legal command shown in this command summary INITIALIZE SPARE TABLE I<n1> Clear the spare block table. this is a dangerous command must be the first command on the command line used only with Formatter/Debugger ROM requires confirmation (Y or N) Page 11 Source: David T. Craig Page 0386 of 0580 Block Device Debugger LOOPON LPF[S,H,D] Send Loop on Format commands to the firmware. where S = sector marks H = address headers D = data field LPF can be followed by any combination of S, H, and D executed following a Read Track command to loop on format of the current track (eg., R[T] reads the T byte of the block variable to determine the current track) used only with Formatter/Debugger ROM MACRO M[A(0-9),C,L,0-9] Use macro functions (alternate command lines). where A = add current line to macro table C = clear all macros L = list macros used with either Formatter/Debugger or Standard ROM N,O Not implemented yet PAUSE $P[\langle n1 \rangle]$ or P[A(num), C, E(num), N(num)] Pause and wait for user. Where A = any error/nonerror C = clear any error/nonerror E = on error N = on no error (num) is a 16-bit mask of S1 S2 Note: All four digits of the 16-bit mask must be turned on used with either Formatter/Debugger or Standard ROM Page 12 Source: David T. Craig Page 0387 of 0580 zer Block Device Debugger QUIT Q[<n1>] Return to calling routine (This module is a subroutine). READ R[(num),T(num),H(num),S(num)] Read a block. where (num) = 24 bit number (8 bit if T,H,S) T = first (Hi) byte of block H = second (Mid) byte of block S = third (Lo) byte of block Remember! The firmware of the device tested determines how the number is treated. See the following example: T H S - Formatter/ Debugger ROM ProFile 00 00 00 Hi Mid Lo - Standard ROM used with either Formatter/Debugger or Standard ROM >0 means read to the output buffer ( Eg., R23>0 ) SCAN S<n1> Order the firmware to scan the entire disk (read only). Requires confirmation (Y or N) after scanning, use D[I] to get list of any bad blocks found during scan used only with Formatter/Debugger ROM TURN OFF STEPPER T[<n1> Turn off the power to the stepper motor. Page 13 Source: David T. Craig Page 0388 of 0580 3<sup>44</sup> Block Device Debugger V Not implemented yet WRITE W[(num),T(num),H(num),S(num)] Write to a block (same format as read). where (num) = 24 bit number (8 bit if T,H,S) T = first (Hi) byte of block H = second (Mid) byte of block S = third (Lo) byte of block Remember! The firmware of the device tested determines how the number is treated. See the following example: T H S - Formatter/ Debugger ROM ProFile 00 00 00 Hi Mid Lo - Standard ROM <I means write from the input buffer ( eg., W23<I )</pre> used with either Formatter/Debugger or Standard ROM XECUTE X[<nl>] or X[E(num)] Execute the current command line again. where E = execute the line to this point on error num = 16 bit error mask of S1 S2 X[E] will execute a function over and over again, if an error has occurred, up to the point where the error occurred Page 14 Source: David T. Craig Page 0389 of 0580 ``` Block Device Debugger +[(num),T(num),H(num),S(num)] Increment the block number. where (num) = 24 bit number (8 bit if T,H,S) T = first (Hi) byte of block H = second (Mid) byte of block S = third (Lo) byte of block -[(num),T(num),H(num),S(num)] Decrement the block number. where (num) = 24 bit number (8 bit if T,H,S) T = first (Hi) byte of block H = second (Mid) byte of block S = third (Lo) byte of block /[C,D(num),M,O,S(num),T] Choose options (/H for help). where C = compare input to output buffer D = device set M = move input to output buffer 0 = option flag setup S = slot set T = translate current block to cylinder/head/sector Help. ``` Page 15 Source: David T. Craig Page 0390 of 0580 #### Block Device Debugger #### 4. NEW FEATURES The following new features have been developed since the release of DSKDBG V-E00.16 and are included in DSKDBG V-E00.17. - \* The Help errors command has been slightly modified. HE or HEl provides help for the Standard ROM and HE2 returns help for the Formatter/Debugger ROM. - \* The Help command lists the form of the extended help commands. - \* Display now has a command to allow the decoding of the status table into the version, spare list, and bad block list. DS = display status info. - \* Use ESCAPE or RETURN to terminate a long list of spares or bad blocks. - \* The /C command allows you to compare the input buffer to the output buffer. - \* The /M command moves the contents of the input buffer to the output buffer. - \* An additional modifier is available for read/write commands that allows you to specify which buffer you are reading to or writing from. For example, a read command followed by >0 means read to the output buffer. A write command followed by <I means write from the input buffer. Page 16 Source: David T. Craig Page 0391 of 0580 391 5. SPECIAL DATA RECOVERY FUNCTIONS OF THE XECUTE (X) COMMAND. The X command has a special function that allows primitive loop control. This function was added (V-E00.14) to allow very basic data recovery for profile. It performs a simple loop back to the beginning of the command line on and error condition occurring in either status bytes 1 or 2 of the profile status. Activating this function is the same as activating Pause on error. Syntax X[<n1>] or X[E] where X is always the last command executed or XE is the last command executed if an error occurred 5.1 USING THE X COMMAND WITH THE STANDARD ROM Following is an example of using the X command when the Standard ROM is installed in the drive: RO $\langle$ n1 $\rangle$ Read Block 0 /S1 / R>O XE /S4 / W $\langle$ O XE + X In this example the inital RO followed by RETURN sets up the program to start reading on block 0. In the next command line, Sl selects slot l as the input drive (drive to read from). REMEMBER! Don't forget the space after the l as it is required. You must include a space whenever a blank area is indicated as shown in the above command line example. The R command reads the block (0 at first). If an error occurs during read (indicated in status bytes 1 and 2) then the XE command will cause control to transfer back to the beginning of the line to S1 and the program tries again. If the read is ok, the program goes on to S4 which switches to slot 4. Then it writes to the current block. (notice that the program hasn't changed the block number yet.) Another check of the status is made by the XE command. The program will continue on and if no error occurs on the write it will go back to the beginning of the line and try again. If no error is detected, the + command causes the program to increment the block counter. Finally, the X command at the end of the command line returns the program to the beginning of the line where it goes back to slot 1 and reads the next block. The program will not stop at the end of the disk but it will not harm anything if it goes passed the end. The current block number being read/written will be greater then 25FF and the user can stop the program by pressing the escape key. Page 17 Block Device Debugger 5.2 USING THE X COMMAND WITH THE FORMATTER/DEBUGGER ROM If the Standard ROM can't be used and the Formatter/Debugger ROM is required then the the command takes on one minor change. Instead of incrementing the 24-bit number with the + command, you increment the 8-bit S variable as shown in the following example: /S1 / R>O XE /S4 / W<O XE + S This command works the same except we now increment track (cylinder), head, and sector which is the form expected by the Formatter/Debugger. As with the previous command the program will not stop at the end of the disk. It will, however, wrap around to TO HO SO and start through again so you have to watch and stop the program at this point. Page 18 Source: David T. Craig Page 0393 of 0580 #### 6. SAMPLE SCREEN DISPLAY Here is a sample readout from the screen. Remember that this display moves very fast and you may not see it clearly. Also Status S5 and S6 are for Twiggy and are set to 0 by the program when using Profile.IO. | | | | 1/0 | Profile | |-------|-------|----------|-------------|-------------------| | | | Block | R1 R2 R3 R4 | S1 S2 S3 S4 S5 S6 | | READ | S1 D1 | 00 00 01 | 00 00 00 00 | 00 00 00 00 00 00 | | WRITE | S4 D1 | 00 00 01 | 00 00 00 00 | 00 00 00 00 00 00 | | READ | S1 D1 | 00 00 02 | 00 00 00 00 | 00 00 00 00 00 00 | | WRITE | S4 D1 | 00 00 02 | 00 00 00 00 | 00 00 00 00 00 00 | | READ | S1 D1 | 00 00 03 | 00 00 00 00 | 00 00 00 00 00 00 | | WRITE | S4 D1 | 00 00 03 | 00 00 00 00 | 00 00 00 00 00 | | READ | S1 D1 | 00 00 04 | 00 00 00 00 | 08 00 00 00 00 00 | | READ | S1 D1 | 00 00 04 | 00 00 00 00 | 00 80 00 00 00 00 | | READ | S1 D1 | 00 00 04 | 00 00 00 00 | 00 00 00 00 00 00 | | WRITE | S4 D1 | 00 00 04 | 00 00 00 00 | 00 00 00 00 00 00 | | READ | S1 D0 | 00 00 05 | 00 00 00 00 | 00 00 00 00 00 00 | | WRITE | S4 D0 | 00 00 05 | 00 00 00 00 | 00 00 00 00 00 00 | Page 19 Source: David T. Craig Page 0394 of 0580 394 - 7. TYPICAL PROBLEMS AND HOW TO AVOID THEM. - \* The + (Increment) command doesn't work. This is to date the most common problem. Usually the command line will look something like RO PE + X What you were trying to do is sequentially read thru the disk starting at block 0. What you said was Read block 0 (block = 0), Pause on error, Increment block (block = 1), Repeat line, Read block 0 (block again = 0) ...... To fix this problem just do one line to set block 0 and then go on to the next line to do the Read, Pause on error etc. For example: RO<n1> R PE + X<n1> \* Display Status Won'T Work Or Won't Stop The display status command allows you to display the input buffer and make assumptions about what the data means. For it to work, the Get status command must successfully read the status informtion from the drive. If the input buffer has garbage in it, the Display Status command may go round and round trying to display all the spared sectors and bad blocks. To stop the command when it is caught in a loop or is listing a bunch of bad blocks, simply press the RETURN key or the ESCAPE key. The functions of the other keys are the same as for all other display commands. Page 20 #### Block Device Debugger #### 8. KNOWN BUGS IN VERSIONS E00.17 AND E00.16 The Macro command has 3 known bugs. The first occurs when a macro is added to the list and there is already one there of that number. The effect is to make both of them disappear. The second bug occurs when the macro is invoked on a line with the X command (eg., Ml X). This disables the ESCAPE key so the program can only be halted by re-booting. The third bug also involves the X command. When a macro is added (eg., R MAl X), it will keep asking to delete the old macro. Pause on any error doesn't work. The - command doesn't decrement properly for H and S modifiers Page 21 Source: David T. Craig Page 0396 of 0580 ### Block Device Debugger 294 ### 9. STATUS BYTE DESCRIPTIONS This section provides a bit-by-bit description of the four status bytes available with the Standard ROM or the Formatter/Debugger ROM. ### 9.1 STATUS BYTES WITH STANDARD ROM V-3.98 INSTALLED ### STATUS 1 ``` 7 = 1 if ProFile did not receive 55 to its last response 6 = 1 if write or write/verify was aborted because >532 bytes if data were sent if ProFile couldn't read its spare table 5 = 1 if host's data is no longer in RAM because ProFile updated its spare table 4 = 1 if SEEK ERROR - unable in 3 tries to read 3 consecutive headers on a track 3 = 1 if CRC error (only set during actual read or verify of write/verify, not while trying to read headers after seeking) 2 = 1 if TIMEOUT ERROR (couldn't find header in 9 revolutions - not set while trying to read headers after seeking) 1 = N/A 0 = 1 if operation unsuccessful ``` ### STATUS 2 ``` 7 = 1 if SEEK ERROR - unable in 1 try to read 3 consecutive D=0 1=1 headers on a track 0=3 6 = 1 if spared sector table overflow ( > 32 sectors spared) 5 = N/A ヘハニリ 4 = 1 if bad block table overflow ( > 100 bad blocks in table) a, = 5 3 = 1 if ProFile unable to read its status sector : 0=6 2 = 1 if sparing occurred 1=7 1 = 1 if seek to wrong track occurred 0 = N/A 00=8 )I=9 OFA STATUS 3 1=8 7 = 1 if ProFile has been reset 50=C 6 = 1 if block number invalid 21=0 5 = 1 if block I.D. at end of sector mismatch 4 = N/A 10=E 3 = N/A 1 = F 2 = 1 if ProFile was reset 1 = 1 if ProFile gave a bad response 0 = 1 if parity error ``` Page 22 Source: David T. Craig Page 0397 of 0580 Block Device Debugger ### STATUS 4 - 7 0 = the number of errors encountered when rereading a block after any read error - \* These bits are set by the SOS ProFile driver and are not used by the Dskdbg ProFile.IO. - 9.2 STATUS BYTES WITH FORMATTER/DEBUGGER ROM FD3.98 REV 11 INSTALLED ### STATUS 1 - 7 = 1 if Profile did not receive 55 to its last response - 6 = 1 if no index found during formatting - 5 = 1 if no sector mark found during formatting - 4 = 1 if SEEK ERROR unable to read 3 consecutive headers on a track (one try only) - 3 = 1 if CRC error (only set during actual read or verify of - write/verify, not while trying to read headers after seeking) 2 = 1 if TIMEOUT ERROR (couldn't find header in 9 revolutions - - not set while trying to read headers after seeking) - 1 = N/A - 0 = 1 compare error on a write compare ### STATUS 2 - 7 = 1 if ProFile has been reset - 6 = 1 if track number invalid while reading or writing a sector - 5 = N/A - 4 = N/A - 3 = N/A - 2 = N/A - 1 = 1 if seek to wrong track occurred - 0 = N/A Page 23 Source: David T. Craig Page 0398 of 0580 zag Block Device Debugger ### STATUS 3 ${\tt D7}$ , ${\tt D6}$ , and ${\tt D5}$ , along with ${\tt D4}$ and ${\tt D3}$ from STATUS 1, tell why a write compare operation failed. | | D7 | D6 | D5 | | |---------------|----|----|----|--| | write timeout | 0 | 0 | 0 | | | read timeout | 1 | 0 | 0 | | | read CRC | 1 | 1 | 0 | | | data compare | 1 | 1 | 1 | | ### STATUS 4 7 - 0 = the number of errors encountered when formatting data fields or scanning the disk. Page 24 Source: David T. Craig Page 0399 of 0580 39g Apple Computer, Inc. Service Engineering Department ### Apple /// Computer Repair Document COMPONENT NAME ProFile Hard Disk DOCUMENT TITLE How to Use the Rev. 18 Debugger to Copy ProFiles Author: Apple DAVID T. CRAIG 736 EDGEWATER, WICHITA, KANSAS 67230 [USA] Source: David T. Craig Page 0400 of 0580 ### How To Use The REV. 18 Debugger To Copy Profiles Hoo TO COPY THE CONTENTS OF ONE PROFILE TO ANOTHER THE FOLLOWING COMMAND LINE CAN BE USED WITH EITHER THE SYSTEM PROM OR THE DEBUG PROM. HOWEVER THERE IS A SLIGHT DIFFERENCE SO BOTH EXAMPLES WILL BE SHOWN. THE EXAMPLES ASSUME YOU HAVE THE MASTER DRIVE IN SLOT1 AND THE SLAVE DRIVE IN SLOT3. YOU CAN USE ANY SLOT YOU WANT. WITH THE 3.98 SYSTEM PROM AND THE REV. 18 DEBUGGER THE COMMAND LINE WOULD LOOK LIKE THIS /S1 (RETURN) R0000 (RETURN) /S3 (RETURN) R0000 (RETURN) /S1-/-R-XE-/S3-/-W<I-XE-+-X(RETURN) THE (-) INDICATES A SPACE MUST BE INSERTED HERE. WITH THE REV. 11 DEBUGGER PROM AND THE REV. 18 DEBUGGER SOFTWARE, THE COMMAND LINE WOULD LOOK LIKE THIS. /S1 (RETURN) RTOHOSD (RETURN) /S3 (RETURN) RTOHOSO (RETURN) /S1-/-R-XE-/S3-/-W(I-XE-+S-X(RETURN) AGAIN THE (-) INDICATES A SPACE MUST BE INSERTED. 1-1 FINIS Source: David T. Craig Page 0401 of 0580 Apple Computer, Inc. Service Engineering Department ### Apple /// Computer Repair Document COMPONENT NAME Pro File Hard Disk DOCUMENT TITLE ProFile Production Format Test Procedure with Apple 111 Author: Apple 18 May 1982 DAVID T. CRAIG 736 EDGEWATER, WICHITA, KANSAS 67230 [USA] Source: David T. Craig Page 0402 of 0580 402 PROFILE PRODUCTION FORMAT TEST PROCEDURE WITH AIII 9/82 ry 3/ ---4/6/82 ry RL 6---4/19/82 ry REV 0---5/7/82 ry REV E---5/10/82 ry REV F---5/18/82 ry Pages: 6 ### 1.0. OBJECTIVE: The objective of this procedure is to format the ProFile disk drive and reject improperly formatted HDA assemblies. ### 2.0. EQUIPMENT NECESSARY: - 2.1. ProFile format test fixture - 2.2. AIII/MIII - 2.3. Shorting plug or jumper switch. - 2.4. Format EPROM---FD3.98 - 2.5. ProFile Format/Certify disk---E00.12 ### 3.0. TEST TIME/UNIT: 4.5 minutes ### ... PRELIMINARY TEST: - 4.1. Allow drive to warm up (>1min) at the warm-up station. - 4.2. Adjust index to 16.667ms (+/-) 0.5%. The limits are 16.584ms to 16.750ms. ### J. Ø. TEST PROCEDURF: - 5.1. Insure that the DC power on the test fixture is OFF! - 5.2. Place drive vertically onto the test fixture and connect pluss P6, P7, and P8. Now, set drive horizontally and connect DC power plus and head cable (P5). - 5.3. Turn on AC power to the ProFile. - 5.4. Insert the ProFile Format/Certify Production disk into the AIII. After a delay of 20 seconds, press (RTN) and the ProFile's READY LED should turn on. - 5.5. The monitor should prompt "PRESS "RETURN" WHEN PROFILE IS READY". Type '(RTN)' and the monitor should prompt "INSTALL JUMPER, PRESS ANY KEY TO CONTINUE". Install jumper, or place JUMPER SWITCH on INSTALL position and type '(RTN)'. The ProFile should begin the Format cycle. After the ProFile has completed the Format cycle successfully, the monitor should prompt "REMOVE JUMPER, PRESS ANY KEY TO CONTINUE". Remove jumper, or place JUMPER SWITCH on REMOVE position and type '(RTN)'. The ProFile should now execute the following commands automatically: 5.5.1. Scan all sectors, heads, and tracks 5.5.2. Compare buffers on TRK077 1-6 Source: David T. Craig Page 0403 of 0580 405 5.5.3. Certify all sectors on TRK077 5.5.4. Initialize spare tables on TRK077. - 5.6. The AIII will ring its bell when the test has been completed or failed. Be sure to turn OFF AC power to the ProFile test fixture here. - 5.6.1. A good HDA unit will pass each of the above commands and should be sent to the certification test station. - 5.6.2. Any failure to any of the commands will halt the automatic sequence, indicate fault, and halt test progress. If a failure occurs, identify drive with problem mode, and set HDA aside as failure. - 5.7. For consecutive format test runs, do not power the AIII off. Instead, simply connect the next HDA unit, turn ON the ProFile test station, and wait for 20 seconds until the ready light turns on. Return to step 5.5 and repeat test procedure. ----end of test---- 2-6 Source: David T. Craig Page 0404 of 0580 AFTER FORMATTUR 15 Complete Bereen will LOOK Luce This NoTe: The operator must insure That The Jumper 1s Removed. PRESS RETURN OPERATION IS Being Donethe Screen will Look Like this IF Everything 15 END UP LIKE This AND A PRINT OUT TEST VERSION FOR MILL FORMAL SCAN, COLUB. SCAN COMPLETED. BUFFER COMPLETED. PASS CERTIFYING COMPLETED. PASS REMOVE THIS SPARE THE DOMPLETED. PASS REMOVE THIS PARE THE STEED THE PASS PASS THE PASS THE STEED THE PASS THE STEED THE PASS THE PASS THE STEED THE PASS T Source: David T. Craig Page 0405 of 0580 System Booted UP WITH Profile Connected AND PREADY Press Return AFTER YOU PRESS RETURN YOU WILL See This NOTE: The OPERATOR MUST INSUL THAT The Jumper is Install Install Jumpea Priss putvan Screen will Look Like This while Formatting 4-6 Source: David T. Craig Page 0406 of 0580 DIF PROFILE IS Connected But NOT TURNED ON OFF NOT READY THE SCREEN DISPLAY WILL LOOK LIKE This. To Get Into The FORMATTING MODE YOU MUST REBOOT the DISKette 2) 1= The Profile 15 Connected And Reading You will See This on Boot up 3) IF the Profile 15 Not Connected you will See This on Boot UP FINIS 6-6 Source: David T. Craig Page 0408 of 0580 9 Apple Computer, Inc. Service Engineering Department # Apple /// Computer Repair Document Profile Hard Disk Converting 5M Profile to 10M Author: ? DAVID T. CRAIG 736 EDGEWATER, WICHITA, KANSAS 67230 [USA] Source: David T. Craig Page 0409 of 0580 410 PROFILE I/O CARD RESISTOR NETWORKS SHOULD BE LOO I 341-0035 - KR3600 4KZB - TAKES 2732 4KXB WMB - I EPROM DIAG STANDARD RUNNING SOFTWARE 3.98 ZB ASSEMBLER - SEE JOHN 2-4 Source: David T. Craig Page 0411 of 0580 NB 10 Apple Computer, Inc. Service Engineering Department ### Apple /// Computer Repair Document Profile Hard Disk DOCUMENT TITLE Profile Certification and Failure Criteria Author: Apple DAVID T. CRAIG 736 EDGEWATER, WICHITA, KANSAS 67230 [USA] Source: David T. Craig Page 0414 of 0580 ### Apple 11 Profile HD Pages: 2 ### CERTIFY CRITERIA | | | | | | | | · | |--------------------|-------|--------|------|---------|-----------|-------------|------------------------------------------------------------------------------------------------------| | IMMEDIATE FAILURES | | | | | | | | | | 1 | - | 61 | 00 00 ( | 00 - | AND<br>SPAR | TE SEPERATOR BETWEEN WRITE BUFFER STATUS TABLES BAD OR S2-3 SET. E TABLES UPDATE OCCURED, BUFFER | | | • | | 00 | 02 00 ( | 20 | | IS CHANGED. OPERATION FAILED. | | | 1 | - | 00 | | | | TO THE WRONG TRACK OR PLUGS 6 & 8 NALOG BOARD ARE SWITCHED AROUND. | | | MAXIM | UM | | CODE | | | | | | ERROR | | | S2 S3 | <u>S4</u> | | DATA | | | 10 | - SOFT | - 08 | 00 00 | (0009) | | READ ERROR. (0009) PERCENTAGE OF READ FAILURES AFTER READ COMMAND. | | | 2 | - HARD | - 08 | 00 00 | (10) | | READ ERROR. (10) PERCENTAGE OF READ FAILURES AFTER READ COMMAND. | | | 2 | · - | 09 | 00 00 | 00 | - | READ ERROR. OPERATION FAILED. | | | 2 | - | 05 | 00 00 | 00 | | CANNOT FIND TARGET HEADER IN 9 ROTATIONS. OPERATION FAILED. | | | 2 | - | 19 | 80 00 | 00 | | CAN'T READ 3 SECTORS AFTER 2 RESEEKS. READ ERROR. OPERATION FAILED. CAN'T READ 3 SECTORS AFTER SEEK. | | | 2 | - | 11 | 80 00 | 00 | | CAN'T RÉAD 3 SECTORS AFTER 2<br>RESEEKS.OPERATION FAILED.CAN'T<br>READ 3 SECTORS AFTER SEEK. | IN ALL CASES WHEN MAXIMUM ERRORS ARE REACHED, FAIL UNIT AND SEND TO REWORK. Source: David T. Craig Page 0415 of 0580 Apple Computer, Inc. Service Engineering Department ## Apple /// Computer Repair Document Profile Hard Disk Profile Debng Data Status Byte Definitions > DAVID T. CRAIG 736 EDGEWATER, WICHITA, KANSAS 67230 [USA] Source: David T. Craig Page 0417 of 0580 | 1 | | |--------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Kich | ERROR SYMPTOM CODES | | <b>0</b> 002 00 00 | 2 - Seek to wrong track occurred | | <b>90</b> 80 00 00 | 8 - Unable to read/write status sectors | | 0082 00 00 | <ul><li>8 - Unable to read/write status sector</li><li>2 - Seek to wrong track occurred</li></ul> | | <b>04</b> -00 00 00 | 4 - Time out error | | Ø <del>4</del> -04 00 00 | 4 - Time out error<br>4 - Sparing occurred | | Ø4-08 00 00 | <ul><li>4 - Time out error</li><li>8 - Unable to read/write status sectors</li></ul> | | <b>ე5</b> 00 00 00 | <ul><li>5 - Unable to read/write data (data is bad)</li><li>Time out error, couldn't find header in</li><li>3 revolutions</li></ul> | | 00 00 08 <b>2</b> 0 | <ul><li>5 - Time out error, could find header in</li><li>3 revolutions-unable to read/write data (data is bad)</li><li>8 - Unable to read/write status sectors</li></ul> | | <b>78</b> 04 00 00 | 8 - CRC error<br>4 - Sparing occurred | | 00 00 00 <b>PO</b> | 9 - CRC error-unable to read/write data (data is bad) | | <b>05</b> 30 00 00 | <ul> <li>1 - Unable to read/write data (data is bad)</li> <li>5 - Time our error (couldn't find header in 3 revolutions)</li> <li>8 - Unable to read/write status sectors</li> </ul> | | <i>O</i> 8<br>3 82 00 00 | 1 - Unable to read/write (data is bad) 8 - CRC error 8 - Unable to read/write status sectors 2 - Seek to wrong track occurred | | • | | Source: David T. Craig Page 0419 of 0580 Source: David T. Craig Page 0420 of 0580 Apple Computer, Inc. Service Engineering Department ## Apple /// Computer Repair Document Profile Hard Disk DOCUMENT TITLE Power Supply (class B) Specification DAVID T. CRAIG 736 EDGEWATER, WICHITA, KANSAS 67230 [USA] Source: David T. Craig Page 0421 of 0580 423 - 1.7 OPERATING TEMPERATURE: 0 to +70°C (Ambient) - 1.8 STORAGE TEMPERATURE: -20 to+85°C. - 1.9 PROTECTION CIRCUITS: The input must be protected by a fast blow fuse and a thermister inrush current limiter. The +5 volts d.c. TTL voltage must be protected from over voltage output by means of an active crowbar. All three d.c. outputs must be short circuit capable for an indefinite period. - 1.9.1 HOLD UP TIME: 20 msec nominal at 30 watts load. - 1.9.2 TEMPERATURE COEFFICIENT: 0.02%. - 1.9.3 AC ISOLATION: to safety ground and A.C. input to output 4.5KVDC - 1.9.4 OUTPUT TO SAFETY GROUND: 0.5KVDC - 1.9.5 INSULATION AC TO GROUND: 50 MEG ohm nominal. - 1.9.6 LEAKAGE CURRENT: 240 VAC input IRMS = 3.5 ma RMS - 1.9.7 LINE CONDUCTED EMI: FCC 20780 limits. See attached specifications. - 1.9.8 SAFETY APPROVALS: UL and CSA required VDE required after, 9/81 ### 2.0 MECHANICAL REQUIREMENTS: The supply shall conform to attached envelope. - 2.1 THERMAL: The power supply shall be capable of operating under all conditions of line and load at 0-70°C continuously. - 2.2 STORAGE TEMPERATURF: -20 to +85°C. - 2.3 HUMIDITY: Operating: 95% RH @ 35°C. Storage: 95% RH @ 50°C. - 2.4 VIBRATION: 10 to 500 Hz double sweep at 1 active per minute with pk-pd excursion of 1.5mm or 10g acceleration. - 2.5 RANDOM DROP: 45 min. at rate of 5 RPM. - 2.6 BURN IN: A minimum 24 hour burn in at low line, full DC load at 70°C is required. Vendor will burn in all units. Source: David T. Craig Page 0424 of 0580 - 2.7 SERIALIZATION: All supplies shall have a serial number affixed and recorded so that test and failure records can be tracked throughout the life of the product. CSA 22.2 No. 15 VDE after 9/81 2.9 INDUCTORS No solenoidal filter inductors should be used in this product. 2.95 INPUT AND OUTPUT CONNECTOR: Molex Connector Pin Designation. A.C. Input D.C. Connector - 1. AC Neutral - 2. Key ' - 3. AC Line - 1. Reset Monitor Output - 2. Key - 3. -12V - 4. +12V - 5. +12V - 6. Common - 7. " - 8. - 9. - 10. Common - 11. +5V - 12. +5V - 13. +5V Mating Molex Connectors: DC P/N 09-50-3131 AC P/N 09-50-3030 The output connector will be a single, in-line connector combining the above two parts number. rapple computer inc. SIZE DRAWING NUMBER A 062-0182-A SCALE: SHEET 3 OF 6 Source: David T. Craig Page 0425 of 0580 SPECIFICATION: ELECTROMAGNETIC COMPATIBLITY This unit must pass FCC Class B limits in both conducted and radiated emissions. 1. Emissions: Applicable assemblies, subassemblies and peripheral devices shall be 6 dB below limits of (1) Federal Communications Commission (FCC) Parts 15 Sections 15.830 (radiation limit) and 15.832 (conduction limit) for units operated from 60Hz line voltage and (2) VDE 0871/6.78 section 3.2.1 (conducted) and sections 3.2.2 and 3.2.3 (radiated) for units operated from 50 Hz line voltage. Those units rated 50/60 Hz shall meet both requirements. The upper frequency limit for both FCC and VDE conducted emissions limits is 30~MHz. However, due to radiated emissions from the AC power cord the Apple conducted limit is extended to 60~MHz. For convenience, limit amplitudes, less 6 dB, are reproduced herein. (Tabulated limits are Apple Computer EMI limits; FCC and VDE limits and 6 dB higher). However, the in-effect version of FCC part 15 or VDE 0871 are the binding documents. ### RADIATED | | | Frequency<br>Range (MHz) | Field<br>(uV/m) | Strengths<br>(dB uV) | Distance (meters) | |----------------|---------|--------------------------|-----------------|----------------------|-------------------| | 1. FCC Part 15 | 30-88 | 50 | 34 | 3 | | | | 86-216 | 75 | 38 | 3 | | | | | 216-1,000 | 100 | 40 | 3 | | 2. VDE 0871 | 0.01-30 | 20 | 26 | 30 | | | | 30-470 | 20 | 26 | 10 | | | | | 470-1,000 | 80 | 38 | 10 | ### CONDUCTED | | | Frequency<br>Range (MHz) | Voltage<br>(uV) | (dB uV) | LISN<br><u>Impedance</u> | |----|---------------|--------------------------|-----------------|---------|--------------------------| | ı. | FCC Part 15 | 0.45-60 | 125 | 42 | 50 | | 2. | VDE 0871/6.78 | 0.01-0.15 | * | | 150 | | | 0.15-0.50 | 200 | 46 | | | | | | 0.50-60 | 100 | 40 | | \*straight line from 10 kHz (3.5mV, 71 dB V) to 150 kHz (300uV, 50 dBuV) Test and measurement equipment and procedures shall be as specified in applicable specifications. Final acceptance tests are performed with assembly or peripheral installed in system intended to be marketed with; such system to consist of the basic Apple Computer (II, III, etc.) and full memory installed and as many peripheral devices (disk drives, printer, monitors) and optional components (language card, serial card, parallel card, etc.) as possible to simulate worst-case operating conditons as closely as possible. Qualification tests with "remote exercisers", generators or other manufacturer Personal CPUs are unacceptable. SIZE DRAWING NUMBER 062-0182-A SCALE: SHEET 4 OF 6 Source: David T. Craig Page 0426 of 0580 ### Apple /// Computer Information • Doc # 78 • ProFile Hard Disk Repair Info une II. SUSCEPTIBILITY (to be determined). Under consideration: The device shall not have uncorrectable data errors when subjected to the following field strengths or voltages - Irradiated: 0.0'-1,000 MHz, 5V/m (100% moudulated with 1 kHz square wave). Transient Line Noise:\*\* 1. Class A products: 400V pulse with 100 nonosecond width and 10 nsec risetime. 2. Class B products: 200V pulse (same characteristics) Conducted RF: 0.01-100 MHz: 3V rms. \*\*no soft errors allowed. SIZE DRAWING NUMBER 062-0182-A tappie computer inc. A SHEET 5 OF 6 SCALE Page 0427 of 0580 Source: David T. Craig 13 ` Apple Computer, Inc. Service Engineering Department ### Apple /// Computer Repair Document Profile Hard Disk DOCUMENT TITLE Power Supply (class A2, International) Specification DAVID T. CRAIG 736 EDGEWATER, WICHITA, KANSAS 67230 [USA] Source: David T. Craig Page 0429 of 0580 2.0 PURPOSE: The purpose of this document is to define the criteria, both electrically and mechanically, that Profile power supplies, part number 699-5008, must meet. ### 3.0 REQUIREMENTS: - 3.1 Materials and construction shall be exactly as initial qualifying pieces. No deviation is allowed without written approval from the M.S.D.Engineering Group and written authorization from Apple Purchasing. - 3.2 The power supply is a totally enclosed module provided with a standard IEC connector, On-Off switch and output connector/cable. The power supply is intended to be conduction cooled and maintain specifications up to 75 Degrees Celsius. - 3.3 All markings shall be permanent in nature and remain legible when subject to the specified operating, storage, and environmental requirements. All marking shall be insoluable in such standard solvents as water and halogenaced hydrocarbons. WARNING: Do not use halogenated hydrocarbon solvents for cleaning circuit boards containing aluminum electrolytic capacitors. ### 3.4 Cosmetics, Aluminum Enclosure: 3.4.1 Definition of Cosmetic Surfaces and Defects: ### 3.4.1.1. Surfaces: 3.4.1.1.1. Class A Surface: The end of the power supply with silk screening and on-off switch. 3.4.1.1.2. Class B Surface: The bottom surface; the right side (when looking at the silk screened end). apple computer inc. SIZE DRAWING NUMBER A 699-5008-A SCALE - SHEET SHEET 2 OF 9 Source: David T. Craig Page 0431 of 0580 gappie computer inc. no dents, butts or deep gouges. Source: David T. Craig Page 0432 of 0580 Any surface finish is acceptable provided there are | 123M | 1 | | | | | |----------------|-----------------------------------------------------------------------------------------------------------------------|---------------------------------------|-------------|--------------|--------------| | N | <u> </u> | · · · · · · · · · · · · · · · · · · · | <del></del> | | | | | | MIN. | NOM. | MAX. | UNIT | | | +5v Crowbar Firing<br>+12v Crowbar Firing<br>(Tested with a 1000MV) | 12.60<br>Cap across +1 | 2v line) | 7<br>13.60 | Volt<br>Volt | | | DC Conversion<br>Efficiency Full Load | 75 | | | % | | | +5/-5v Ripple pk. to pk. | | | 50 | mV | | | +12/-12v Ripple pk. to pk. | | | 100 | mV | | | Line/Load +5v<br>Transient Envelope | 4.75 | | 5.25 | v | | | 25% Load Stép Response Time<br>(Recovery of output to wit | hin .1% of f: | inal volt | 500<br>(age) | uSec | | | Line Drop Out<br>. Capability (full load, nom | 1 . | | | Cyc1 | | | Isolation: AC Input<br>to SELV Output | 3.75 | | | KVAC | | | Isolation: AC Input<br>to Safety Gnd. | 3.75 | | | KVAC | | , | Insulation Resistance: AC to Gnd. | 7 | | | Mohms | | | Insulation Resistance: AC to output | 7 | | | Mohms | | | Insulation Resistance:<br>Output to Gnd. | 7 | | | Mohms | | | Leakage Current Vin 230 VAC to | o G <b>nd</b> . | | 0.75. | mAmps | | 3.6 Electromag | netic Compatibility: | | | | | | 3.6.1. | Emissions: The power supply, configured Apple III system shof VDE 0871/6.78 Section 3.2.3 3.2.2 and 3.2.3 (radiated). | nall be 6 dB | below li | mits | | | | For convenience, limit amplitureproduced herein. However, to (less 6dB) of VDE 0871 is the | he in-effect | version | | | SIZE DRAWING NUMBER 699-5008-A SCALE SHEET 5 OF 9 Source: David T. Craig Page 0434 of 0580 | RADIATED | Frequency<br>Range (MHz) | Field (uV/m) | Strengths<br>(db uV) | Distance<br>(meters) | |--------------------|-----------------------------------|------------------|----------------------|----------------------| | <b>VDE</b><br>0871 | 0.01-30<br>30-470<br>470-1,000 | 20<br>20<br>80 | 26<br>26<br>38 | 30<br>10<br>10 | | CONDUCTED | Frequency<br>Range (MHz) | Voltage<br>( uV) | (db uV) | LISN<br>Impedance | | VDE<br>0871/6.78 | 0.01-0.50<br>0.15-0.50<br>0.50-30 | *<br>200<br>100 | 46<br>40 | 150 | <sup>\*</sup> Straight line from 10kHz (3.5 mV, 71dBuV) to 150kHz (300uV, 50dB uV). A fully configured Apple III system and compatibility will be determined by the Apple Computer Corporate Engineering EMC Group and the above limits verified. The system will include an Apple III with maximum memory, Disk III disk drive, language card, Profile, Silentype Printer, and Monitor ///. ### 3.7 Environmental: 3.7.1. Acoustic Noise Output: The power supply shall emit no perceivable and audible noise when located in a library-like acoustic environment; defined as less than 50 db sound power. This acoustic output from the power supply shall contain no predominant tones greater than 5 db above ambient noise referenced against adjacent 1/3 octive band sound levels as measured using the methods of ANSI S1.13 - 1971, Appendix A. This condition shall hold for the power supply when connected to the computer or peripheral device, during all normal modes of computer or device operation and environment. ### 3.7.2. Temperature Range Operating: 00 to 750 C Storage: -400 to 850 C ## 3.7.3. Hamidity: (non-condensing) $25^{\circ}$ C to $40^{\circ}$ C (ambient) with a relative humidity of 5 to 95%. papple computer inc. SIZE DRAWING NUMBER 699-5008-A SCALE SHEET 6 OF 3 Source: David T. Craig Page 0435 of 0580 3.7.4. Vibration and Shock: The power supply must be able to survive a vibration within a frequency range of 3 of 200 and 200 to 3 Hz at a constant acceleration of 0.5 G's, for on (1) hour in its' shipping orientation axis. (Reference the Apple shock and vibration document \$062-0086.) ### 3.8 Reliability and Quality Assurance: - 3.8.1. The complete power supply shall have an MTBF of no less than 30,000 hours when operated over the entire range of operating parameters specified in 3.5 and environments specified in 3.7. This reliability level shall be demonstrated at a minimum 80% confidence level by a stress model reliability prediction and a reliability qualification test based on MIL-HDBK-217C. - 3.8.2. Burn-in (accelerated aging) of production level supplies shall be performed to assure that the instantaneous failure rate of supplies delivered to Apple does not exceeding of the inverse of the MTBF specified in 3.8.1. Following acceptance by Apple of qualification data no changes shall be made to the burn-in process unless authorized in writing by Apple Computer. - 3.8.3. Apple Computer shall be provided with reproducible copies of a complete set of documentation including PCB artwork, envelope drawings, schematics, bills of material, component specifications, approved vendor lists for all components, and manufacturing instructions (including assembly, test, detail/fabrication, inspection, workmanship, adjustment/calibration procedures, and flow-routing sheets). No changes shall be made to the design or component mix of this supply without prior written agreement of Apple Computer 60 days in advance of any changes or implementation. It is understood that this documentation is the property of Apple Computer. - 3.8.4. The vendor will provide Apple Computer with copies of all Engineering Change Notices, Manufacturing Change Orders, and the like to assure that current documentation is available at Apple Computer and establish a knowledgeable documentation liaison to ensure this process. - 3.8.5. Apple Computer has the right to perform source inspection and manufacturing audits at the manufacturing sites for the supply. Acceptance of product by Apple representatives does not guarantee final acceptance of the material by Apple Computer. Final acceptance shall be at Apple Computer. The vendor shall perform final inspection to assure each power supply meets the requirements of this specification. SCALE — SHEET 7 OF 3 Source: David T. Craig Page 0436 of 0580 ## 43Y - 3.8.6. The vendor shall maintain verifiable evidence of all inspections and tests performed on finished supplies, results obtained, and dispositions of nonconforming materials. These records shall be traceable to individual supplies or production lots and shall be made available to Apple representatives upon request. - 3.8.7. The contractor shall provide service documentation, including theory of operation, at a level adequate for both Field and Factory service. ### 3.9 Shipping Protection: Each unit is to be protected from damage by a corrugated box. The packing shall be adequate to provide protection against damage, breakage or loss during overseas shipment and shall be of a type not destroyed by opening. Each master shipping carton shall be legibly marked with the following: part numbers, date of shipment, quantity, and country of origin. ### 3.10 Safety Agency Approval: The design, component selection, and construction shall conform to and meet the following (Class 1, SELV) Product Safety Requirements: IEC 380, Safety of Electrically Energized Office Machines. Note: The main power transformer must be a safety isolating type for SELV circuits. ### 3.11 Construction: The enclosure for the power supply is to be fabricated from steel, plated to prevent corrosion. CALE - SHEET ? OF ? Source: David T. Craig Page 0437 of 0580 1236 Apple Computer, Inc. Service Engineering Department # Apple /// Computer **Repair Document** COMPONENT NAME ProFile Hard Disk Head Disc Assembly Specification (from Seagate Techology) DAVID T. CRAIG 736 EDGEWATER, WICHITA, KANSAS 67230 [USA] Source: David T. Craig Page 0439 of 0580 ### Apple /// Computer Information • Doc # 78 • ProFile Hard Disk Repair Info **AEVISIONS** INC BY DESCRIPTION APPROVAL & DATE MIC APPLICABLE DOCUMENTS Motor Control PCB Assembly 20217-001 Engineering Specifications: The HDA components shall meet all requirements and specifications set forth in the following documents unless separately specified herein. Motor Control PCB (Fab drawing) 20218-001 HDA Assembly drawing 58157-001 HDS Electrical interconnect drawing 30126-001 Magnetic Disc Read/Write Heads 30134-001 Head Connector 10420-016 10417-006 Spindle Motor Connector 10417-005 Stepper Motor Connector 10417-005 Index Connector NEXT ASSY MODEL NO. ST-412.9 FINAL ASSY FIRST USE FIRST USE DRAWN CHECK SEAGATE TECHNOLOGY APPO(E) APPD (M) 1.19.81 ST412.9 HEAD DISC ASSEMBLY UNLESS OTHERWISE SPECIFIED DIMENSIONS ARE IN INCHES TOLERANCES ON REV. EC DWG NO. SCALE SIZE DECIMALS ANGLES 0292 30173-001 XX. xxx. DO NOT SCALE 14 SHEET 1 OF DRAWING Source: David T. Craig Page 0440 of 0580 | | ring Specification | 30173-001 | 0292 | |----------------------|----------------------------------------------------------------------|-------------------------------------|------| | ST 412<br>TITLE HEAD | 2.9 HEAD DISC ASM SPECIFICATION D DISC ASSEMBLY | SHEET 2 OF | | | APPLICABI | LE DOCUMENTS (continued) | | | | _ | TK Ø Connector | 10417-005 | | | • | Spin Motor PCB Connector | 10419-002 | | | | 10416-XXX (Ref) Mates with | 10417-XXX | | | | 10415-XXX (Ref) " " | 10420-XXX | - | | | 10418-XXX (Ref) " " Shock & Vibration Spec. Acoustical Specification | 10419-XXX<br>30138-001<br>30131-001 | | | | Shock & Vibration Spec. | 30138-001 | | | | | | | | | | | | | • | · • | İ | | | . • | | ì | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | ### Apple /// Computer Information • Doc # 78 • ProFile Hard Disk Repair Info THE JOHN OF SIGHLICEN 0292 30173-001 Engineering Specification ST 412.9 HEAD DISC ASM SPECIFICATION SHEET 3 OF 30173-001 ITLE CONTENTS SCOPE I. CAPACITY II. MEDIA III. ENVIRONMENTAL IV. RELIABILITY ٧. VI. POWER VII. INTERFACE DRIVE VIII. IX. STEPPER MOTOR - ELECTRICAL REQUIREMENTS SPINDLE MOTOR - ELECTRICAL REQUIREMENTS Х. XI. BAND ASM - MECHANICAL REQUIREMENTS XII. PHYSICAL REQUIREMENTS I. SCOPE The Head Disc Assembly (HDA) is a sub-assembly of the ST412.9 Final Disc Drive Assembly. It will undergo all the drive testing before being shipped to the customer. The Head Disc Assembly will be a complete ST412.9 disc drive less the following hardware: 1) Main control PCB 2) Front panel II. CAPACITY Unformatted 12.76 Mbytes/Drive 10416 Bytes/Track Formatted 32 Sectors/Track (Soft) Mbytes/Drive 10.0 Bytes/Track Source: David T. Craig 3192 Page 0442 of 0580 | Α | pple /// Computer Information • Doc # 78 • ProFile Hard Disk F | Repair Info | |------------|----------------------------------------------------------------|-------------------------------------------------| | | | | | yy1/Eng | -001 <i>O29</i> . | | | TITLE | ST 412.9 HEAD DISC ASM SPECIFICATION SHEET 4 | OF | | | 302.3 | | | | Max recording frequency (MIZ) 2.5 | | | | Transfer Rate | | | | Mbits/Second 5.0 | · | | | Density | | | | Flux Changes/Inch 9074 | , | | 111 | <u>MEDIA</u> | • | | 1 | Tracks | | | | Per Inch 345<br>Per Surface 306 | | | | Per Drive 1224 | | | • | <u>Defects</u> (Hard Errors) | | | O | | | | | | | | 1 | Per Drive 12 | - | | | Per Cylinder Zero 0 | · | | | | ! | | ' IV | ENVIRONMENTAL Operating Shipping | storage | | | Ambient Temperature* 390 - 1350F 250 - 1440 - 62 | Storage<br>For -80 - 176 oc<br>2°C -22°C- 80 oc | | | Max Temperature Gradient/Hour | ! | | | 18°F 18 | 8°F 18° | | | Relative Humidity 20 - 80% TBD | TBD | | | Maximum Wet Bulb 78° No Conder | nsation | | | Stray Magnetic Field (1" from casting) | 20 Gauss Max | | | Altitude | 10,000 ft. Max | | * | Ambient Temperature is defined as the HDA casting | temperature. | | Source: Da | vid T. Craig | Page 0443 of 0580 | | Apple /// | Computer Information • Doc # 78 • Prof | File Hard Disk R | tepair Info | |---------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------|------------------------------------------------| | · · · · · · · · · · · · · · · · · · · | <u> </u> | | <u>. </u> | | | THE AMERICAN | 1 | I | | KWY Engineerin | g Specification | 30173- | -001 0292 | | ST 412<br>ITLE 30173 | 9.9HEAD DISCSM SPECIFICATION | SHEET 5 | OF | | | | | | | v. | RELIABILITY | | | | | Error Rate (Excluding defects) - W. Technology PCB P/N TOD | hen used with | Seagate | | | Soft read errors (16 retries min.) | l per 10 <sup>10</sup> b | its transferred | | | Hard read errors | 1 per 10 <sup>12</sup> b | its transferred | | ١. | Seek errors | 1 per 10 <sup>6</sup> se | eks | | | MTBF (Meantime before failure) | | | | | Typical usage | 11,000 hours | <b>3</b> | | | PM (Preventive Maintenance) | None | | | · | MTTR (Meantime to Repair) | 30 minutes | | | | Component Life | 5 years | | | | Media Life | 10,000 start | s/stops | | | POLITIN | | | | · | POWER TO THE | | | | | DC Voltages (To motor speed control | | • | | | $\pm 12$ VDC $\pm$ 10%, .3 AMP running currenctor start current. (see ST412 magnetical start current. | ent; 2.7 AMPs<br>inual for star | typical<br>rt profile). | | · | BTU/Hr. (1 watt = 3.413 BTU/Hr.) | | • | | | Watts | 25 + 40%<br>85.3 + 40% | | | | BTU/Hr. | 85.3 <u>±</u> 40% | | | VII. | INTERFACE | | | | -82 | | | | | | | | | | VIII. | DRIVE A. Mechanical | | | | | Seek Settle Time* Uncontrolled 75% | using this st | tep sequence | | | - Controlled | 78∆ mS — | | | ≭ Using | Seagate recommended PCB | mS — | <del>-</del> | | Source: David T. C | Craig | | Page 0444 of 0580 | | | J | | | ### Apple /// Computer Information • Doc # 78 • ProFile Hard Disk Repair Info Engineering Specification ST412.9 HEAD DISC ASM SPECIFICATION 30173-001 30173-001 0292 SHEET 6 OF Drive Motor Start Time 15 sec. Spindle Speed\*\* 3600 rpm + 1% **HDA Cleanliness** The air inside the HDA shall be class 100 (0.5) micron particles) Mounting See Figures 1 & 2 Vibration and Shock Shall meet the requirements of Seagate Specification 30132-001 B. Electricial For purposes of normalized test data, and unless otherwise stated, all test measurements shall be taken at the ambient conditions of $68 + 5^{\circ}F$ (20 + 3°C) and 40 to 60% relative humidity after the HDA has been stabilized at the test environment for at least $l_{\rm z}$ hour. Not withstanding this, the HDA shall be capable of meeting all the requirements of this specification over the full operating environment of Paragraph IV, Page 4. Warm Up Time The HDA shall meet all operating specifications within 15 seconds after spindle motor has reached 3600 RPM at all operational environmental conditions. 1. Spindle motor speed regulation 3600 + 1% RPM 2. Spindle motor current. Start Running 2.75amps max. 1.0 amps max. 3. Stepper motor/phase TBD \*\*Adjustments are customer responsibility \*\*\*For shipment, the heads shall be moved center track while the spindle is rotating. Source: David T. Craig Page 0445 of 0580 # Apple /// Computer Information • Doc # 78 • ProFile Hard Disk Repair Info TELL MARTIN Late Health Control Who Engineering Specification 0292 30173-001 ST 412.9HEAD DISC ASM SPECIFICATION SHEET OF TITLE 30173-001 4. Performance (Head Disc Asm) Average 2F amplitude 1.0 mv p-p min. Inside window margin 30 ns total (without write precomp) Minimum resolution on any track 60% (without precamp.) Wide Gap Measurement DC erase tracks 303, 304, 305 2. Write 2F on track 304 3. Write 1F on tracks 303 & 305 4. Measure 1F amplitude relative to 2F amplitude on track 151 using H.P. spectrum analyzer Model No. 3585A or equivalent. 5. Failure is defined as a measurement -26dB. Source: David T. Craig Page 0446 of 0580 ### Apple /// Computer Information • Doc # 78 • ProFile Hard Disk Repair Info # ELECTRICAL REQUIREMENTS STEPPER MOTOR # Switching Sequence for CCW Rotation Facing Mounting End | Step | Pin 4<br>Blue | Pin 5<br>Red | Pin 2<br>Write | Pin l<br>Yellow | Pin 3<br>Not Us | |------|---------------|--------------|----------------|-----------------|-----------------| | 1 | - | + | + | _ | | | 2 | + | <b>-</b> · | + | _ | | | 3 | + | | - | + | | | 4 | . <b>-</b> | + | - | + | | | 5 | - | + . | + | - | | ### SCHEMATIC | SPECIFICATIONS | | | | |------------------------------------------------|--|--|--| | Step per revolution: 400 (0.9° per step) | | | | | Step to step accuracy (Notes 1,2,): +6% | | | | | Positional Accurácy (1,3): + 6% | | | | | Rotor Inertia: 20 Gcm <sup>2</sup> (.28 MOISS) | | | | | DC Phase Resistance: 38 ± 3.8 at 25° C | | | | | Phase Inductance: 27 mH + 20% at 1 KHZ | | | | | Phase Voltage: 9.2 | | | | | Phase Current (Steady State): 240ma | | | | | Holding Torque: 720 gam (100z IN) Nom. | | | | | | | | | | Pull-out Torque: 360 gcm (5 oz IN) NOM. | | | | ### MOTES: - 1. Measurements made at rated current on each phase. - 2. Between any two adjacent step positions. - 3. Maximum error in 360°. - 4. Motor to be driven bipolar. The above specifications is of a motor in bipolar mode. - 5. Leads: 4, No. 26 ANG PVC insulation UL & CSA approved. TBD. Source: David T. Craig Page 0447 of 0580 # Apple /// Computer Information • Doc # 78 • ProFile Hard Disk Repair Info 0292 30173-001 WWY Engineering Specification ST412.9HEAD DISC ASM SPECIFICATION SHEET OF 30173-001 TITLE\_ PHYSICAL REQUIREMENTS IX. The HDA can be mounted on any side except upside down or front and back. (See Figures 1 & 2) $\,$ The HDA is shock mounted for vibration isolation. In the final mounting configuration, care shall be taken to insure that the operation of the three shock mounts is not restricted. Page 0448 of 0580 Source: David T. Craig # Apple /// Computer Information • Doc # 78 • ProFile Hard Disk Repair Info 기념(B): Halling Harr 30173-001 ST412.9 Head Disc ASM Specification SHEET OF 10 TITLE 30173-001 BAND ASSEMBLY - Capstan Band Assembly BAND SPECIFICATIONS 1. Band shall be capable of withstanding 2.5 lbs. Max. 2. There shall be no creases on the active portion of the band. 3. Band shall be free of contaminants that would decrease it's life, such as finger prints and edge nicks. Source: David T. Craig Page 0449 of 0580 Apple Computer, Inc. Service Engineering Department # Apple /// Computer Repair Document Pro File Hard Disk Interface Card Set-Up and Test Procedure, Apple III/ Profile DAVID T. CRAIG 736 EDGEWATER, WICHITA, KANSAS 67230 [USA] Source: David T. Craig Page 0452 of 0580 # Cabbie computer inc. PAGE 2 OF 6 - 1.0 TITLE: PROFILE/APPLE III INTERFACE CARD SET-UP AND TEST PROCEDURE - 2.0 PURPOSE: This is a guide to setting up and automatically testing the Profile Apple III Interface Card. This test is used in production to test and debug the boards. - 3.0 EQUIPMENT: - 3.1 Apple II Computer - 3.2 Disk Drive with Controller - 3.3 Monitor - 3.4 Silentype Printer and Interface Card - 3.5 VIA Test Interface Card - 3.6 Profile Interface Card Test Fixture with Cables - 3.7 Oscilloscope (nothing fancy needed) - 3.8 Profile Apple III Interface Automatic Test Disk - 3.9 Profile Apple III Interface Schematic - 4.0 REFERENCE DOCUMENTS: ``` 899-8002 Assy, Interface Tester, Profile/Apple III Assy, PCB, Interface Test Card, Profile/Apple III 890-6002 Assy, Enclosure/Interface Test Card, Profile/Apple III 890-6003 Enclosure, Interface Tester, Profile/Apple III 890-0201 890-0202 Strain Relief 2.5 x .5 x .12, Interface Tester Profile/Apple III Strain Relief 3.44 x .5 x .12, Interface Tester 894-0203 Profile/Apple III 051-0194 Schematic, VIA Card, Interface Tester, Profile/Apple III 051-0195 Schematic, Interface Test Card, Profile/Apple III 821-0183 PCB, Interface Test Card, Profile/Apple III Diskette, Auto Interface Test, Profile/Apple III 889-0019 ``` - 5.0 TEST PROCEDURE SET-UP: - 5.1 Connect the two cable connectors to J3 and J4 on the VIA (Apple III Tester Interface) Card. The Cables are labeled accordingly. - 5.2 Plug the VIA Card into the Apple slot #2. - 5.3 Plug the Silentype into slot #1. - 5.4 Attach the disk Drive in the conventional manner into slot #6. - 6.0 TEST PROCEDURE: - 6.1 Insert the Test Disk and turn the Apple II Power on. - 6.2 The Disk will boot with the message: "LOADING PROFILE/APPLE III INTERFACE CARD TEST PROGRAM" and then ask you to plug in the Interface Card and attach the DB-25 connector. It is important Source: David T. Craig Page 0454 of 0580 | Capple Capple | computer | Inc. | |---------------|----------|------| |---------------|----------|------| | DOCUMENT | NO. | 063-0128-A | |----------|-----|------------| | PAGE | 3 | 05 6 | that the Board Under Test is inserted into the zero force insertion test socket with the components facing you with the DB-25 connector on your right. Also, note and use the lever on the connector for opening and closing the pins. After the Card is plugged in corectly press either a "P" or an "S" to start the test and print any errors to the P(rinter or the S(creen. - 6.3 The program will take about 30 seconds to test the Card and will respond with the message: "NO PROBLEM FOUND" or will print the failures on the selected output device. - 6.4 If the Board is good type an "A" and the original prompt will be shown. If the Card is bad, the selected output device will print the message: "PROFILE INTERFACE CARD TEST IC LIST/LINES IN ERROR:" followed by some short IC addresses ("A2 A5 B4 C8" for instance) followed by a list of the incorrect lines. In many cases the IC addresses will not be displayed. This will happen if the failure pattern is not in the Apple fault tables. - After the fault is printed the following message is displayed on the screen: "DO YOU WISH TO LOOP THROUGH THE TEST? (Y/N) ". If you choose N(o, the program will display the beginning test prompt and you can continue to test as before. If you choose Y(es, the program will continue to send test data to the Card and you can use the scope for troubleshooting. Press the ESC key to end the looping. (It could take up to 30 seconds for the present cycle to complete itself and the Apple will appear as if it is just sitting there.) - During the GO-NO GO testing tear the print-out off the printer and tape it to the board so the debug person can save this step in the debug process. NOTE: Typically there is more than one person testing and debugging the boards. The Go-No Go testing can be accomplished in the printer mode and this person can tape the printed error messages to the boards and another person can do the debugging in the screen mode and use the looping function with the scope. Source: David T. Craig Page 0455 of 0580 ### Apple /// Computer Information • Doc # 78 • ProFile Hard Disk Repair Info | V66 Capple | computer inc | | |--------------|---------------|---| | المرادان الم | Compacer inc. | • | #### ADDENDUM APPLE III INTERFACE FOR PROFILE INTERFACE TESTER VIA CARD MODIFICATIONS DESCRIPTION The VIA card in its original condition will not work properly if it is fully stuffed with components and connected to the Interface Card Test Interface Board. There are a few simple modifications that have to be made so that the board will work properly. In the first place, only the top three VIA chips are needed in the board to communicate with the board under test. Do not insert chips U5 and U8 into the board. Likewise, do not insert connectors J1 and J2 into the board as they are not used either. Also, Ul is not needed and there needs to be a jumper soldered between pads 4 and 7 of this chip on the board. If you look up at the top left hand corner of the schematic you will see that this will enable pin 1 of U2 permanently. There is one last modification to the board and the purpose of this is to bring +5V out to pins 26, 28, $3\emptyset$ , and 32 of connector J4. To do this, the four traces that connect VIA chip Ull to connector J4 must be cut on the front side of the board. To do this, locate the group of traces connecting the upper right-most VIA chip to the connnector above it. The traces that need to be cut with the Exacto knife are the fifth, sixth, seventh, and eighth traces over from the left. Just to be sure, there should be four traces still connected to the left of these. The final step in this modification is to connect a large jumper wire between pins 26 through 32 of the back side of connector J4 and the +5V bus. This is used to bring a solid +5 volts out to the card under test. ### TESTER PC BOARD MODIFICATIONS Originally there was a large resistor in series with the board under test. There was also a LED and resistor across it which would light when there was a short. This has been eliminated. Add a jumper wire between the Pads of R1. Source: David T. Craig Page 0456 of 0580 火火 Apple Computer, Inc. Service Engineering Department # Apple /// Computer Repair Document Profile Hard Disk Profile Analog Board Functional Test (05 Jan 1984) DAVID T. CRAIG 736 EDGEWATER, WICHITA, KANSAS 67230 [USA] Source: David T. Craig Page 0462 of 0580 PROFILE ANALOG BOARD FUNCTIONAL TEST January 5, 1983 Pages: 6 # NIALOG BOARD READ TESTS HITH DEBUG TESTER - 1. SCOPE, TEXTRONIX 465 or equivalent 100 Mmz scope - 2. SCOPE PROBES, x10, 3 probes, two w/shound - 3. PROFILE, known good, without Analog board - 4. PROFILE A/// I/O board and cable - 5. A/// computer, H/// monitor - 6. RIBBON CABLE, 12 inches long, Controller to Analog board 7. EXTENTION ADAPTOR CABLE, PG, P7, P8 from HDA - 8. PIGGY BACK Z8, with "Debusser Rev. 11" Eprom - 9. DISKETTE, Debug Test (889-6003), "Disk Debugger Rev. 17" - 10. TRRY, Profile Production, foam lined (918-0123A) ### STATION SETUP: **EUUIPHENT:** - 1. Remove top cover of Profile. - 2. Remove Power Supply/Controller board, and HDA/Analos board assemblies from the Profile Plastic base and put them in the Profile tray. - 3. Remove ribbon cable from controller to analog board, set aside. - 4. Turn HDA upside down so flat cover plate with MARNING label is down, and round end of HDA is toward controller board. - 5. Connect long ribbon cable to controller board connector P2 from HDA. - 6. Insert A/// I/O board in slot 4 (floppy drive side). Connect A/// ${ m I/O}$ board to controller board P1 connector with ${ m I/O}$ cable. - 7. Remove plastic Z8 (341-0171) from Controller U25 socket and save. - 8. Install ceramic Piggy-back Z8 with "Debugger Rev 11" mounted on top into 40 Pin socket at Controller board U25. Check Pin 1 direction is correct (toward P1 connector). - 9. Attach one scope probe with no around clip to triager input of scope, and other end to TP1 (near P2) on controller board. Set time base to 1 mS/div, External trissering. - 10. Attach probe with ground clip to scope channel 1. Set to 1 wolt/div. AC coupled. - 11. Attach probe with ground clip to scope channel 2. Set to .5 volts/div, DC coupled. Set scope trace (grounded) to a reference line. Variations from this line will be used to adjust UCO Pot, and show UCO problems later. - 12. Plus in AC power cord to Profile power supply under controller board. - 13. Insert "Debug Test" disk into A/// built-in drive and boot up the computer. Computer may be left on while testing and during Analog board under test changes. Source: David T. Craig Page 0463 of 0580 # PROCEDURE: 409 - 1. Place Analog board to test on HDA. Plug in head connector J5 as the board is slipped in. - 2. Plus P6, P7, P8 from the HDA into Analos board connectors J6, J7, and J8. Check that they are plussed into the correct connectors. - Install hold down screw at ground lug (near TP5). Ground strap from HDR HUST be attached here also. No other mounting is required. - 4. Plus in ribbon cable from controller board to J2 on Analos board. - 5. Turn ON Profile power switch at back of supply. - 6. Attach channel 1 scope probe at Analog board TP1 or TP2 Read Amp, next to U7 (CR3127). Attach ground clip from scope probe to meanest ground test point. - 7. Scope probe from channel 2 clip onto TP8 UCO, near U2 (7474). - 8. Hait for the HDA stepper arm to move from "park" to track 0. The analog data signal on scope channel 1 should look like the photos of "good signal". If not, check that the spindle motor is turning, and that scope probe 1 is properly connected. - 9. Break UCO pot on the Analos board (R56) loose, so it will turn freely. Set the UCO pot by setting scope channel 2 to ground, and adjusting to a ground reference line. Set back to DC coupling, and turn the pot (R56) from lock to lock. The UCO signal on the scope should move up and down at least .50 Volts. - 10. Set UCO Pot to ground reference line (UCO = 0 Volts +/-.25 Volts) and slue. - 11. Type "RO" RETURN to start at track 0. The stepper arms should move around about 1/2 turn. - 12. Enter the command to start scanning the sectors, "R PE +H X" RETURN. The monitor will show that the track, head, and sector numbers are increasing. The stepper arm will move around counter-clockwise one track at a time. - 13. Watch the read data on score channel 1 and the UCO signal on score channel 2, and FAIL the analog board if it does not meet the following: Read signal = 2 Volts minimum (peak to peak). AGC signal = 1 Volt base to peak on at least one side (top or bottom). AGC shall show "bell" effect immediatly after sector gap periods. UCO signal = No excessive noise or oscillation, 200mU MAXIMUM peak/peak. 14. If a data read error occurs, the monitor display will stop and say "ERROR - Press space key to continue". Record the track/head/sector, and the error number from the last data line of the monitor on the board reject tag. 2-6 Source: David T. Craig Page 0464 of 0580 - 15. Press the A/// space bar to continue if an error occured. Stop the test if more than 7 errors occur or when the track number soes around to zero by pressing the ESCAPE key. - 16. If any errors occured on the monitor, re—try that sector to verify by typing "RTxxHxSx" RETURN where "x" are the numbers of track/head/sector that error occured on. Then type "R PE X" RETURN. If the error appears continuously, the Analog board is defective. REJECT the analog board if any of the errors appear consistantly. ### 17. IMPORTANT: Enter the command "RT99" RETURN before ever shutting power OFF to park the heads off the formatted data areas. Failure to do this will eventually destroy the disk surface causing permanent errors. - 18. Turn OFF the power switch in back of the Profile power supply. - 19. Remove the score probes attached to the Analos board TP1 or TP2, and TP8. Carefully unplus the connectors at J6, J7, and J8. - 20. Remove the shound wire screw and start to pull up the board from the J2 connector edse. Push off the HDR head connector (J2) when the Analos board is part way out. 3-6 Source: David T. Craig Page 0465 of 0580 ### II. ANALOG BOARD HRITE TEST HITH ANALOG TEST FIXTURE EQUIPMENT NECESSARY: - 1. PROFILE ANALOG TESTER with cables (890-0184) - 2. POHER SUPPLY, 3 output, Lambda LPT-7207-FH (or equivalent) - 3. DUH, Fluke 8010A (or equivalent) - 4. SCREHDRIVER, medium phillips - 5. SCREMORIVER, small flat - 6. JUMPER, with clip on each end ### TESTER SET-UP: - 1. Install and secure the Analos board Under Test to the test fixture using standoff to hold the board in place. (The screw MUST be mounted in the GROUND LUG hole) - 2. Connect the board to the tester as follows: - 1. Tester J2 to board J2 (Controller to Analos connection) - 2. Tester J5 to board J5 (Head Cable connection) - 3. Tester J6 to board J6 (Index Cable connection) - 4. Tester J7 to board J7 (Stepper Motor connection) 5. Tester J8 to Board J8 (Track 00 connection) - 6. Tester J9 to board TP1 and 2 (2 wires) 7. Tester J9 to board TP8 (1 wire) - 8. Jumper from TP8 on Reference Analos Board to R80 next to J2 on Board Under Test (use jumper for this). ### NOTE: The Analog Board Tester has a modified Profile Analog Board mounted on it for signal reference. This board can be identified as missing R-106, Pin 5 of IC U2 Pushed out of its socket, and a jumper to TP8 from U2 pin 5 on the back of the board. The Reference Board will be driven by the clock signal on the Board Under Test. DO NOT REMOVE any ICs or the Reference Analog Board for any reason!!! ### NORHAL TEST SHITCH POSITIONS: Set the AF switch to the "MIDDLE" Position Set all the other switches toward you (OFF) Set the Bit Shift dial Pot at 0.0 Set the X, Y Pots both at 5.0. Several LEDs will be lit on the board when power is applied to it. This is normal, do not pay attention to them unless told to do so in a test. Source: David T. Craig Page 0466 of 0580 ### PÜHER SUPPLY SET UP: Hove the DUM probes to the Reference Analog board and re-adjust the power supply so that the voltages on the board are correct. - +12V +/-0.1 volt (across Analos board Under Test C38) -12V +/-0.1 volt (across Analos Board Under Test C39) + 5V +/-0.1 volt (across Analos Board Under Test C40) - If the voltages are low or shorted, do the following for the board under test: - A. Locate C38, C39, and C40 on the board. Use an ohameter to determine if they are shorted. - B. Also check for any cut or shorted traces on the board. If the +5U line is the only one shorted, locate and check RG1 (three terminal resulator 1) on the Analos board Under Test. #### CAUTION: DO NOT apply power to a known shorted Analos board. You may DAMAGE the board and/or the power supply beyond repair. ### TEST PROCEDURE: - 1. HRITE CURRENT TESTS: (Lower and Higher) - A. Hrite Current Test (Lower) - (1) Set PCP, HCR, POK, and HC switches ON. Set HRT/RD to HRT. - (2) Check DUM on board. Reading should be 310mU to 370mU. (Divide reading by 10 for Peak to Peak write current) - If test fails, check IC U4, U1, R14, and R10. - B. Hrite Current Test (Higher) - (1) Leave HCA, POK, HRT, and HC switches set ON. - (2) Set PCP switch OFF. - (3) Check DVH on board. Reading should be 410mV to 500mV. - (4) Using Head Select switches HS0 and HS1, verify that current checks good in all 4 heads. This verifies the head diode matrix. - (5) Set POK switch OFF. DUM reading will decrease at least 100mU, indicating write enable circuit operation. - If test fails, check IC U1, U4, U31, R10, R14, R16, and R17. If any one head selection failed, check diodes CR5-CR12, U31. - C. Return all controls to normal position. 5-6 Source: David T. Craig Page 0467 of 0580 ### 2. HRITE PRECOMP TEST: - W/X A. Select HDØ. (Verify HCA switch OFF, AF switch MIDDLE) - B. Set PCP, POK, HRT switches ON. - C. Set X Pot at 5.0 - D. Set Y and Bit Shift Pots at 0.0 - E. Turn Y Pot CLOCKHISE until PCHPA LED moes ON. - F. Note Y Pot reading. - G. Continue turning Y Pot CLOCKHISE until PCMPA LED goes OFF. - H. Note Y Pot reading. The difference between the two readings should be less than 1 turn. - I. Continue turning the Y Pot CLOCKHISE until the PCHPA LED goes ON asain or the Pot is turned all the way around. If the LED turns on again, there should have been no more than 1/2 turn between OFF and ON. - J. If the PCMPA LED came on asain, turn the Y Pot until the PCMPA LED goes OFF again. The LED should have been on for no more than 1 turn of the Y Pot. If any test fails, check IC's U27, U28, U29, U30, and U2. K. Return all controls to normal position. 6-6 FINIS Source: David T. Craig Page 0468 of 0580 Work Apple Computer, Inc. Service Engineering Department # Apple /// Computer Repair Document ProFile Hard Disk DOCUMENT TITLE ProFile Analog Board Debug Test (08 Dec 1983) DAVID T. CRAIG 736 EDGEWATER, WICHITA, KANSAS 67230 [USA] Source: David T. Craig Page 0469 of 0580 MA Pages: 3 December 8, 1983 #### PROFILE ANALOG BOARD DEBUG TEST #### EQUIPMENT: - 1. SCOPE, TEKTRONIX 465 or equivalent 100 Mhz scope - 2. SCOPE PROBES, x10, 3 probes, two w/ground - 3. PROFILE, known good, without Analog board - 4. PROFILE A/// I/O board and cable - 5. A/// computer, M/// monitor - 6. RIBBON CABLE, 12 inches long, Controller to Analog board - 7. ADAPTOR CABLE, PG, P7, P8 extention from HDA - 8. PIGGY-BACK Z8, with "Debugger Rev 11" Epron - 9. DISKETTE, "Disk Debugger Rev 17" - 10. TRRY, Profile production, foam lined #### STATION SETUP: - 1. Remove top cover of Profile. - 2. Remove Power Supply/Controller board, and HDR/Amalog board assemblies from the Profile plastic base and put them in the Profile tray. - 3. Remove ribbon cable from controller to analog board, set aside. - Turn HDA upside down so flat cover plate with HARNING label is down, and round end of HDA is toward controller board. - 5. Connect long ribbon cable to controller board connector P2 from HDA. - 6. Insert A/// I/O board in slot 4 (floppy drive side). Connect A/// I/O board to controller board P1 connector with I/O cable. - 7. Remove plastic Z8 (341-0171) from Controller U25 socket and save. - 8. Install ceramic Piggy-back Z8 with "Debugger Rev 11" mounted on top into 40 pin socket at Controller board U25. Check pin 1 direction is correct (toward P1 connector). - Attach one scope probe with no snound clip to trisser input of scope, and other end to TP1 (near P2) on controller board. Set time base to 1 mS/div, External trissering. - Attach probe with ground clip to scope channel 1. Set to 1 volt/div, AC coupled. - 11. Attach probe with ground clip to scope channel 2. Set to .5 volts/div, DC coupled. Set scope trace (grounded) to a reference line. Variations from this line will be used to adjust UCO pot, and show UCO problems later. - Plus in AC power cond to Profile power supply under controller board. - 13. Insert Disk Debusser disk into A/// built-in drive and boot up the computer. Computer may be left on while testing and Analog board changes. 1-3 Source: David T. Craig Page 0470 of 0580 #### PROCEDURE: - $\sqrt{N}$ 1. Place Analog board to test on HDA. Plug in head connector ${f J5}$ as - 2. Plus P6. P7. P8 from the HDA into Analos board connectors J6. J7. and J8. Check that they are plugged into the correct connectors. - 3. Install hold down screw at around lus (near TP5). Ground strap from HDA MUST be attached here also. No other mounting is required. - 4. Plug in ribbon cable from controller board to J2 on Analog board. - 5. Turn ON Profile power switch at back of supply. - 6. Attach channel 1 scope probe at Analos board TP1 or TP2 Read Amp. next to U7 (CR3127). Attach ground clip from scope probe to meanest ground test point. - 7. Scope probe from channel 2 clip onto TP8 UCO, near U2 (7474). - 8. Hait for the HDA stepper arm moving from "park" to track 0. The analog data signal on scope channel 1 should look like the photos of "good signal". If not, check that the spindle motor is turning, and that scope probe 1 is properly connected. - 9. Break UCO pot on the Analos board (R56) loose, so it will turn freely. Set the UCO pot by setting scope channel 2 to ground, and adjusting to a ground reference line. Set back to DC coupling, and turn the pot from lock to lock. The UCO signal on the scope should move up and down at least .5 Volts. - 10. Set the pot to ground reference line (UCO = 0 Volts +/-.25 Volts) and slue. - 11. Type "RT60" to start at track 60. The stepper arms should move around about 1/2 turn. - 12. Enter the command to start scanning the sectors, "R PE +S X" RETURN. The monitor will show that the track, head, and sector numbers are increasing. The stepper arm will move around counter-clockwise one track at a time. - 13. Watch the read data on scope channel 1 and the VCO signal on scope channel 2, REJECTING the analog board for the following: Read signal = 2 Volts minimum (peak to peak). AGC signal = 1 Wolt base to peak on at least one side (top or bottom). AGC shall show "bell" effect immediatly after sector gap periods. UCO signal = no excessive noise or oscillation. - 14. If a data read error occurs, the monitor display will stop and say "ERROR - Press space key to continue". Record the track/head/sector, and the error number from the last data line of the monitor on the board reject tas. - 15. Press the A/// space bar to continue. Stop the test if more than 7 errors occur or when the track number soes around to zero by pressing the ESCAPE key. 1-3 Source: David T. Craig Page 0471 of 0580 16. If any errors occured on the monitor, re-try that sector to verify by typing "RTxxHxSx" where "x" are the numbers of track/head/sector that error occured on. Then type "R PE X" RETURN. If the error that error occured on the Onalno heard is defective. REJECT the appears continuously, the Analog board is defective. REJECT the analog board if any of the data errors appear consistantly. #### 17. IMPORTANT: Enter the command "RT99" RETURN, parking the heads off the data areas BEFORE ever turning OFF the MDA. Failure to do this will eventually destroy the disk surface causing permanent errors. - 18. Turn OFF the power switch in back of the Profile power supply. - 19. Remove the scope probes attached to the Analos board TP1 or TP2, and TP8. Unplue the connectors at J2, J6, J7, and J8. - 20. Remove the ground wire screw and start to pull up the board from the J2 connector edge. Push off the HDA head connector when the Analog board is part way out. 3-3 FINIS Source: David T. Craig Page 0472 of 0580 # Apple /// Computer Repair Document Pro File Hard Disk Profile Analog Board Debug Test Repair Notes (08 Dec 1983) DAVID T. CRAIG 736 EDGEWATER, WICHITA, KANSAS 67230 [USA] Source: David T. Craig Page 0473 of 0580 XXY PROFILE ANALOG BOARD DEBUG TEST December 8, 1983 Pages: #### REPAIR NOTES For AGC: 95 U 4 - 1. Check C5, C10, C19 for damage. - 2. Check IC UG is not Signetics (NE592). - 3. If AGC signal is less than 2 volts meak-meak: - A. Change U7, then U6, then U8. - B. Change Q1 (UCR2N). - C. Remove DLY1 (Delay Line), if AGC signal improves, change DLY1. #### For UCO: - 1. Check IC U17, U19 are not Motorola 10131. - 2. Check capacitors C28, C29, C30, C32, C33, C34, C35, C53 for cold solder connections. - 3. Check RP2, RP3, RP4, RP5, RP6, RP7, RP8 are not Allen Bradley SIP resistor packs (white ceramic with black paint, 108A561). - 4. If UCO OSCILLATES 200 mU or more, change U19, then U25. - 5. If UCO is NOISY 200 mU or more, change U25, then U19. - 6. If no VCO signal, change U16, then U14. - 7. If UCO drifts up or down off scope, change U24. - 8. If UCO will not adjust 500 mV, change U26, then R56. For stop on error (04, 08, 14): - 04: Read sector header was bad (track, head, sector address) usually read amp, AGC, or data separator related. (14 SAME AS %) - 08: Read sector data was bad usually read amp, or AGC related. - 1. Change U13, then U12. - 2. Change U23, then U21. For won't step (or can't find track 0): 1. change U30. Source: David T. Craig Page 0474 of 0580 CR 18 CKIT CAZO Apple Computer, Inc. Service Engineering Department # Apple /// Computer Repair Document ProFile Hard Disk ProFile Analog Board Upgrade DAVID T. CRAIG 736 EDGEWATER, WICHITA, KANSAS 67230 [USA] Source: David T. Craig Page 0475 of 0580 ## ANALOG BOARD UPGRADIE UNDERSIDE OF BOARD - LOCATION UZ Pin 10 Shorted To Pin 9 OF U2 Source: David T. Craig Page 0476 of 0580 Apple Computer, Inc. Service Engineering Department # Apple /// Computer Repair Document Profile Hard Disk ProFile Interface Board Tester Operation and Maintenance Manual 1982 WXX DAVID T. CRAIG 736 EDGEWATER, WICHITA, KANSAS 67230 [USA] Source: David T. Craig Page 0478 of 0580 Pages: 8 APPLE COMPUTER SERVICE ENGINEERING PROFILE INTERFACE BOARD TESTER OPERATION AND MAINTENANCE MANUAL OBJECTIVE: To provide a test method to determine if the Profile Interface board is functional. This manual outlines the setup, operation, troubleshooting methods, and maintenance of the Profile Interface Board Tester. 1982 Apple Computer, Cupertino, CA. 95014 Service Engineering Dept. 1-8 Source: David T. Craig Page 0479 of 0580 #### TABLE OF CONTENTS Section 1 - EQUIPMENT NECESSARY 1.1 Equipment identification. Section 2 - SET-UP PROCEDURES 2.1 Cable connections. 2.2 Slot identification. 2.3 Tester board installation. 2.4 Interface board test sequence. Section 3 - OPERATION 3.1 Test enable commands. 3.2 Test results good message. 3.3 Test results fail message. 3.4 Loop on fail sequence. 3.5 Program reset command. Section 4 - ERROR ANALYSIS 4.1 Error detection. 4.2 Failure analysis. 4.3 Component swap procedures. Section 5 - TESTER TROUBLESHOOTING 5.1 Identification procedures. 5.2 Tester software verification 5.3 VIA tester instructions. 5.4 Interface tester verification. 7 missing 2-8 Source: David T. Craig Page 0480 of 0580 #### SECTION 1 - EQUIPMENT NECESSARY: - 1. Apple II computer (48K) and disk drive or Apple /// computer with internal disk drive and Apple II emulation diskette. - 2. Monitor. - 3. Profile Interface Board tester. (Apple # 890-0183) - 4. Interface tester test program diskette. - 5. Media Tester Interface (VIA) board. (Apple # 890-6009) - 6. VIA board test diskette. - 7. Interface board schematic. (Apple # 050-5005B) - 8. VIA board schematic. - 9. Oscilloscope. (Tektronix 463 or equivalent) - 10. Silentype printer. (optional) 3-8 (Apple # 051-0194A) Source: David T. Craig Page 0481 of 0580 4c6\ #### SECTION 2 - SET-UP PROCEDURE: - 2.1. Connect the two cables from the interface tester to J3 and J4 on the Media Tester Interface (VIA) card. The cables are labeled accordingly. - 2.2. Make sure the computer power is OFF and plug the VIA card into Slot 2 of the computer. In the Apple II, the third slot from the left. In the Apple ///, the second slot from the left. - 2.3. Open the ZIF (zero insertion force) connector on the tester and insert the interface board to be tested in it. Make sure the card is properly oriented by the short end of the interface board being at the same end of the connector as the board release handle. Close the handle, making sure that the board does not tilt or twist in the connector. Next, connect the DB-25 connector at the end of the tester cable to the corresponding socket on the interface board. 4-8 Source: David T. Craig Page 0482 of 0580 Section 3 - OPERATION: 3.1. Booting the diskette will display the message: LOADING PROFILE/APPLE III INTERFACE CARD TEST PROGRAM After about 30 seconds, the program will then ask you to plug the interface card to be tested into the test fixture by displaying: AUTO TEST INSERT INTERFACE CARD INTO TEST FIXTURE AND PLUG IN THE DB-25 CONNECTOR If not already done, connect the DB-25 cable from the test fixture to the card and make sure the board is properly inserted in the connector. The card will only fit one way properly as the connector handle will be blocked if it is backwards. The display will also prompt the test enable with: TYPE "P" OR "S" TO TEST P = LIST ERROR ON PRINTER (If available) S = LIST ERROR ON SCREEN 3.2. The test will take about 15 seconds to run. If no errors are found, the computer will print: NO PROBLEM FOUND 3.3. If any errors are detected, the computer will indicate the possible problem area and display the message: PROFILE INTERFACE CARD TEST IC LIST/LINES IN ERROR This will be followed by a list of the incorrect signal lines on the board and/or the location of any associated ICs. The signal lines will be identified by the signal mnemonics used on them such as DMA1 or PSTRB. If an IC is determined to be the failure the device position will be called out, such as A2 or C4. If the error is still in the board, it has to be either a bad line or faulty component other than an IC. You will need to repeat the test and look for the bad line with a scope. Go to step 3.4 in this test sequence. 5-8 Source: David T. Craig Page 0483 of 0580 Kan 3.4. If a fault is detected and displayed the computer will ask: #### DO YOU WISH TO LOOP THROUGH TEST This allows you to cycle the test program while looking for the error line with a scope. To do this, choose "Y". If you do not wish to do so, choose "N", and the program will display the beginning test prompt. 3.5. To stop the looping cycle, press ESCAPE. If the program has just started to cycle, pressing ESCAPE will not halt it, but just keep it from repeating itself. You will have to wait 15 seconds or so before getting the beginning prompt again. #### SECTION 4 - ERROR ANALYSIS - 4.1. The computer indicates the probable error by matching the detected error with a series of error messages in the test program. These error messages were developed by using gate isolation procedures, identifying all the individual gates in the circuit and the problems each one would cause if it failed. This is an extensive circuit mapping technique and will catch a majority of failures. However, if a board has massive failures in the way of shorted or open lines, the errors may not be able to be decoded by the computer. - 4.2. This means that the computer can only match up the error with what it has on file. In the event of this happening, the computer will give all the failure listing associated with the detected errors, both component and/ or line. - If the computer did not associate any one error found with any of the error table entries in memory, it will indicate all the component and line failures detected. At first glance the printout may seem confusing but it is easy to understand if the individual failures are related to the schematic. All of the ICs on the board have several different circuit functions. If a device has massive failures all of these associated functions will be identified, giving a complex failure readout. - 4.3. The easiest way to troubleshoot a problem like this is to replace the first IC identified in the printout and run the test again. If the problem is still in the board, swap out the second identified IC. Keep doing this until all of the ICs in the failure printout have been swapped. If the error table changes or indicates a repaired board, go back to the components first replaced. Try them again one at a time until all of them have been verified as either good or bad. 6-8 Source: David T. Craig Page 0484 of 0580 Kak #### SECTION 5 - TESTER TROUBLESHOOTING PROCEDURES - 5.1. In the event of a failure in the tester, the following procedures should be used by the technician to isolate, identify, and correct the faulty component. - 5.2. Using a known good Interface Board, run the test sequence. Power down the computer and boot it up again using the other set of tester software. If the test results are different, swap the known good board for another known good board and determine if the copy of the tester software that gives the errors is bad. If this happens, throw away the bad diskette. Make another copy of the good software diskette before running the tests. Verify both copies by running the tests again. - 5.3. To diagnose a possible failure of any device on the VIA card, run the VIA board tester. An Apple /// is needed to do this but first read the listing below and follow the instructions. 7-8 Source: David T. Craig Page 0485 of 0580 (6.3-continued) To enable the program, type RUN followed by a Carriage Return. The display will now show: #### VIA BOARD TESTER STEP-BY-STEP INSTRUCTIONS FOR TESTING VIA BOARDS: - 1 OBTAIN TWO SHORT TEST JUMPERS (40 AND 50 PIN) - 2 OBTAIN FULLY OR PARTIALLY STUFFED VIA BOARD TO TEST - 3 JUMPER J1-J2 AND (DR) J3-J4 IN PAIRS WHICHEVER IS APPROPRIATE - 4 INSERT BOARD INTO SLOT 2 OF THE APPLE /// (SEE NOTE) - 5 BOOT THE PROGRAM AND FOLLOW THE TEST INSTRUCTIONS - 6 REFER TO THE VIA BOARD SCHEMATIC TO CHECK THE TEST RESULTS WHEN USING A PARTIALLY STUFFED BOARD NOTE: IN CASE YOU HAVEN'T NOTICED, IT IS NECESSARY TO TURN THE APPLE ON TO SEE THE TEST INSTRUCTIONS. IT IS ALSO IMPORTANT TO HAVE THE POWER OFF WHEN THE BOARD IS INSERTED. IF ALL THE PREVIOUS TEST INSTRUCTIONS HAVE BEEN FOLLOWED AND YOU'RE READY TO TEST, PRESS ALMOST ANY KEY AND THE TEST WILL START These instructions are shown here to provide a check list to follow before powering up the Apple ///. The program will exercise all of the VIA board lines, looking for any shorts, opens, or data errors. It is a good idea to run this program on the board before testing any interface boards, and to run it in case a high error rate suddenly occurs. Like all software, several copies should be available in case one is destroyed. - 5.4. To verify the proper operation of the tester, follow these steps. Test at least two known good boards with the tester. Using a good Profile, set up the Apple /// system and check out the Interface boards with the following criteria: - A. Read the Profile directory file. - B. Write to a file in the Profile, and verify that the write data was recorded. If both of the boards passed the tester and work in the Profile, the tester may still have a problem. Remove any one of the ICs from the Interface board and test it again. The tester should indicate massive line failures in addition to the removed IC. 8-8 FINIS Source: David T. Craig Page 0486 of 0580 Apple Computer, Inc. Service Engineering Department # Apple /// Computer Repair Document Profile Hard Visk Disk Debug Test User's Manual, ProFile 5MB DAVID T. CRAIG 736 EDGEWATER, WICHITA, KANSAS 67230 [USA] Source: David T. Craig Page 0487 of 0580 Pages: 21 apple computer inc. PAGE \_\_2 OF \_\_22\_\_ 1.0 TITLE: DISK DEBUG TEST USER'S MANUAL, PROFILE 5MB (P. 1 of 22 not present) 2.Ø INTRODUCTION The Formatter/Debugger program is provided as a service aid for troubleshooting block I/O devices such as the ProFile disk drive. It is a program that allows you to directly communicate with a block I/O device and exercise it through a series of unique commands or build simple test sequences that will assist in debugging the device. It is a particularly helpful tool for servicing devices that have been returned because of a malfunction, etc. For example, the program can be used to detect an error and then by using the loop on error function, you can use an oscilloscope to analyse the circuit that caused the error. You can use the program to service a drive containing either the Formatter/Debugger ROM or the Standard ROM. (The Standard ROM is the operational ROM that is shipped in the disk drive.) The command summary, section 3, specifies which type of ROM must be in the drive to use a given command. #### 2.1 HOW TO USE THIS PROGRAM To use this debugger properly, you should be aware of some of the design concepts. In designing the user interface (command structure) it was decided to use single character commands. This permits you to type in the command very rapidly and use options (which are not always required) to modify certain test variables. The most used test variables are the three byte logical block that is treated as either a 24-bit number or as three 8-bit numbers. As a 24-bit number, the variable represents a standard logical block with a decimal range of $\emptyset$ -16 million blocks (Hex $\emptyset\emptyset\emptyset\emptyset\emptyset$ -FFFFFFF). As three 8-bit numbers, each variable has a range of $\emptyset$ -255 (Hex The program makes no assumptions about the use of the test variable; it just gives you two ways to talk to it. You can consider it as a large (24 bit) number or as three smaller (8 bit) numbers. This variable is sent to the disk exactly as a 24-bit number which the firmware decides how to interpret. You, the user, must know how the firmware will react to understand what the firmware is doing with the block number. #### 2.2 TYPICAL COMMAND EXAMPLES To help make the concept of this program more clear, here are some examples that show what the more common commands do. orm# A C 101-01 Source: David T. Craig Page 0488 of 0580 R (Read) This command requests data to be read from the unit being tested. It passes the command and the BLOCK variable to the unit and transfers the data from the unit to the input buffer (see the display command, section 3.2.3, for information on displaying the input buffer). R by itself does not change the BLOCK variable; it uses its current value. However, you can change the block variable by adding a modifier to the command in the form of a number. This number is normally treated such that leading zeros are assumed, thus $\emptyset$ , $\emptyset\emptyset$ , $\emptyset\emptyset\emptyset\emptyset$ , etc. all produce the 24-bit value $\emptyset\emptyset\emptyset\emptyset\emptyset\emptyset\emptyset$ . For example: RØ or RØØ or RØØØØØØ, etc. (read block ØØØØØØ) R13 or RØØ13 or RØØ13, etc. (read block ØØØØ13) The above example is applicable only when using the Standard ROM. Notice that the BLOCK variable sent is either 999999 or 999913. The number 13 is the same as 913 or 999913 and produces the value 999913 in the BLOCK variable. #### NOTE The number 13 in the example is a HEX number, not a decimal number. 13 Hex = 19 Decimal Remember that the firmware in the disk drive being tested determines how the BLOCK variable will be treated. Normally it is treated as a logical block. In the next example, let's change the command to show how it would be used with the Formatter/Debugger ROM: RT1H2S3 or RTØ1HØ2SØ3, etc. (read block Ø1Ø2Ø3) Notice that the command now has 3 modifiers in the form of T and a number, H and a number, and S and a number. The modifier T (Track) references the first 8-bits of the BLOCK variable, the H (Head) references the second 8-bits, and the S (Sector) references the third 8-bits. Note that they are separate modifiers and can be used independently. For example: If BLOCK = 000000, then the command RT5 will set BLOCK = 050000 If BLOCK = 050000, then the command RH3 will set BLOCK = 050300 If BLOCK = 050300, then the command RT16S9 will set BLOCK = 160300 Form# A.C 101-01 Source: David T. Craig Page 0489 of 0580 ## mappie computer inc. PAGE \_\_4 \_\_ OF \_\_22 \_\_ Note that the last command in the example happened to affect the first and third bytes. Had the last command been RS9 then the BLOCK would have been \$65\$3\$9. When all three modifiers are used, they must be in the T, H, S sequence. REMEMBER! The numbers used are always Hexidecimal numbers. W (write) ----- This command requests data to to be written to the unit being tested. It passes the command and the BLOCK variable to the unit and transfers the data to the unit from the output buffer (see the buffer fill command, section 3.2.1, and the display command, section 3.2.3). W by itself does not change the BLOCK variable; it uses its current value. However, as was the case with a read command, the BLOCK variable can be changed by adding a modifier. For example, the commands WØ, WT3H2S1, WH9, etc. have the same effect on the BLOCK variable that they do in the Read command. + (plus) This command increments the BLOCK variable. + by itself increments the variable by 1. For example, if the BLOCK variable was \$9991F, then after + it will be \$9992\$ (Note the hex numbers). +3 will increment the BLOCK by 3 each time. +3T will increment the first 8-bit variable by 3 each time. For example, if the BLOCK was \$959311, then +3T will change it to \$989311. H and S work the same way to modify the second and third groups of 8-bit variables. To provide wraparound and carry, the + command will wrap a 24-bit number at FFFFFF. It will wrap T at 97 (97 increments to $\emptyset$ ) and will set H an S to $\emptyset$ to provide full wrap. H will wrap at 3 (3 goes to $\emptyset$ ) creating a carry to T and S will wrap at F (F goes to $\emptyset$ ) creating a carry to H. Future enhancements will be to find out what the maximum block count for a device is and then wrap the 24-bit number at that count. Source: David T. Craig ----- Nao ### mappie computer inc. D (Display) ----- This command displays the contents of the input or output buffers. D by itself will display the input puffer. DI is the same as D. DO will display the output buffer. DS will decode the contents of the input buffer as extended status information. The form of the display is the same as that for an APPLE monitor memory dump. It will display the first 256 bytes of the buffer and pause so that you can study the values. At the bottom of the screen it asks for ESCAPE to terminate, RETURN to quit, ANY other key to continue. ESCAPE stops further display and cancels the rest of the command line effectively stopping processing and returning control to the user. RETURN quits the display command and causes the program to go on to the next command. Pressing any of the other keys, except the space bar, will allow the program to display the next 256 bytes of the buffer. Pressing the space bar will allow you to display the buffer line by line. #### CAUTION If you just keep hitting a key to see the next 256 bytes you will see first the buffer you requested and then memory above it. There are areas of ram above the buffers that will, when displayed cause your screen to get VERY sick and you will have to either re-boot the program or be very familiar with APPLE III hardware and monitor. Just in case you are not familiar with the monitor memory display, here is an example. (The monitor doesn't display the descriptive information above the dashed line.) Hex Address Ø 1 2 3 4 5 6 7 8 9 A B C D E F 8000: 00 1A 23 92 FF FE A5 2F 33 34 00 00 00 00 00 00 8010: 12 11 34 87 FE 44 00 00 3E 4C 00 20 A9 0F C5 00 etc. Form# & C 101\_01 Source: David T. Craig Page 0491 of 0580 | ya1 | <b>C</b> appia | computær | Inc | |-----|----------------|----------|-----| |-----|----------------|----------|-----| PAGE \_\_6 \_\_ OF \_\_22\_\_ #### 3.Ø COMMAND STRUCTURE Each command consists of one or more characters and modifiers in command groups. Each group is separated by one or more spaces. The command line is one or more command groups. There is enough space in the command buffer for 255 characters. Multiple command lines are possible by use of the Macro Add command. #### 3.1 COMMAND PROMPT The program prompt consists of the following two lines: The first line contains two flags, S1 D1, that tell which slot and drive the program is set to test. The second line of the prompt consists of the first letter of each valid command. A list of the commands is always available by typing H or ? and pressing RETURN. In this manual you will see this written as H(n) or P(n). (The P(n) is the symbol for newline, often called RETURN.) #### NOTE After typing a command and pressing RETURN to execute it, you can press ESCAPE to terminate the command. However, if you wish to review the command that you just executed for the purpose of changing it, etc., you can type CONTROL A instead of ESCAPE. Form# A.C. 101-01 Source: David T. Craig Page 0492 of 0580 ## gapple computer inc. #### 3.2 DETAILED COMMAND DESCRIPTIONS Following are descriptions of some of the commands that require more detailed explanations than others. In depth examples of some of the more commonly used commands such as Read, Write, Increment, and Display were provided in section 2.2. For an overall summary of all commands, refer to section 4.0. #### 3.2.1 BUFFER FILL Syntax B[num] ---- where num is an optional 16 bit hex number (eg.,BØ123) The buffer fill command is used to fill the output buffer with a specific data pattern. It can be used with either the Formatter/Debugger ROM or the Standard ROM installed in the drive. To use the command, type B followed by a number which will be treated as a 16 bit (2 byte) pattern. For example, the command RØ B1234 WØ B45 W1<n1> would read logical block- $\emptyset$ , fill the output buffer with 12341234..., write block- $\emptyset$ , fill the output buffer with $\emptyset\emptyset45\emptyset\emptyset45...$ , and finally write this data to block-1. #### 3.2.2 CREATE SPARE Syntax C<nl> ---- the C-command must be the only command on the line. The create spare command is used to force a peripheral device to transfer a logical block to a new (spare) physical location on the device. The command will then request the block number to be spared and will then request confirmation from the user. If confirmed, the logical block will be spared by the device controller. This command should only be used when the <u>Standard</u> ROM is installed in the drive. Using this command will allow you to $\underline{\text{fix}}$ $\underline{\text{flaky}}$ $\underline{\text{blocks}}$ found during testing. The user will be asked for confirmation of this command. Respond with Y (Yes) or N (no). #### NOTE Do not attempt to use the create spare command when the Formatter/Debugger ROM, version D3.11 or earlier, is installed in your drive. Form# A.C. 101-01 Source: David T. Craig Page 0493 of 0580 ### rapple computer inc. DOCUMENT NO. 063-6006-A PAGE \_\_ 8 \_\_ 0F \_\_ 22 \_\_ 3.2.3 DISPLAY Syntax D[I,0,S] ---- where I is input buffer, 0 is output buffer, and S is the extended status information in the input buffer. The display command can be used with either the Formatter/Debugger ROM or the Standard ROM installed in the drive. It is used to display the contents of the input or output buffers. These buffers occupy the following Hex locations in the computer's memory: input buffer ----8000H - 8213H output buffer ---8300H - 8523H The display will show 256 bytes at a time, scrolling to the next 'page' after each key press. To end the display and continue executing the command line, press RETURN. To abort the command line press ESCAPE. With the display on the screen, you can press the spacebar to cause a scroll to the first line of the next 'page'. Then, each time you press the space bar, the display will scroll one line forward. The Display Status command works only slightly differently in that it decodes the input buffer into Extended status info about the spares and bad blocks and it will not stop until it is finished or until the space bar, RETURN key, or the ESCAPE key are pressed. REMEMBER! The Display Status command will decode anything found in the input buffer so be sure to use the Get Status command first to make sure that the information is valid. Before using the Display Status command with the Formatter/Debugger ROM installed, you must initialize the spare tables (see section 3.2.6) and then use the Get Status command, otherwise the display will contain garbage. With the Standard ROM installed, you only have to issue the Get Status command before displaying the extended status of the input buffer. Here are some additional tips about using the Display Status command. - After typing D[S] and pressing RETURN, press the space bar to stop the listing. Press the space bar again each time you wish to step through another line of the listing. Pressing any other key will cause a fast scan of the listing. - Pressing ESCAPE will cancel the rest of the display function. - Pressing RETURN will terminate the spare sector listing and start the bad block listing. Source: David T. Craig Page 0494 of 0580 ### <sup>χηχ</sup> **π**appie computer inc. DOCUMENT NO. \_\_\_063-6006-A PAGE 9 OF 22 #### 3.2.4 FORMAT Syntax $F(n) \longrightarrow$ this command must be the <u>only</u> command in the command line. The Format command is used with the Formatter/Debugger ROM installed in the drive. It is used to erase all old data from memory and lay down a new pattern of address and data. After formatting a drive with the Formatter/Debugger ROM installed, you can type D[I] to get a list of the defective blocks. The list will end with FF FF FF. Refer to the documentation provided for the F/D ROM for further details. #### WARNING This command is very dangerous and should only be used if damage to the address headers has occurred and only after every reasonable attempt has been made to recover other data from the device. The user will be asked to confirm this command. Respond with Y (Yes) or N (No). Remember! This command will erase all previously recorded data. Following is an example of the error message that will be displayed if you attempt to format a drive with a Standard ROM installed. I/O ProFile Block R1 R2 R3 R4 S1 S2 S3 S4 S5 S6 FORMAT S1 D1 00 03 5F 00 00 00 55 55 55 55 00 00 The 55's in this example are the error indicators. 3.2.5 GET STATUS Syntax G<n1> The Get Status command works only with the Standard ROM. It is used to obtain extended status information from the drive and place it in the input buffer. (You will need to execute the Display command to view the contents.) The Get Status command makes sure that the status you are going to view is valid. When using a Profile you can also get the status by reading block FFFFFF. Form= 4 0 101 01 Source: David T. Craig Page 0495 of 0580 #### Apple /// Computer Information • Doc # 78 • ProFile Hard Disk Repair Info ψ<sup>ή</sup> **παρρί**α ### rapple computer inc. DOCUMENT NO. \_\_063-6006-A PAGE \_\_\_\_10 OF \_\_22 \_\_\_ #### 3.2.6 INITIALIZE SPARE TABLE Syntax $I(n) \longrightarrow$ this command must be the first command in the command line. The Initialize command is used by the ProFile Formatter/Debugger ROM to setup the spare tables in the ProFile drive. After the Debugger ROM has formatted the disk, the entire disk is available to read from or write on so that certification of the entire disk is possible. After the spare table sectors have been certified, the tables need to be initialized to allow the controller ROM to work properly. The Initialize command is not used when the Standard ROM is installed in the drive. #### WARNING This command is potentially dangerous as it effectively erases any old spared table data and if used incorrectly will cause the loss of valuable data on the ProFile. The user will be asked to confirm this command. In response, type Y (Yes) or N (No). Form= A.C. 101-01 Source: David T. Craig Page 0496 of 0580 ## gapple computer inc. #### 4.0 COMMAND SUMMARY Following is a summary of all the commands that can be used with this program: NOTE Data shown in [] or () is optional. BUFFER FILL B[<n1>] or B[num] Fill the output buffer. where num is a 16 bit hex fill number used with both Formatter/Debugger and Standard ROMs CREATE SPARE C<n1> Force the drive to spare the specified block. must be the only command on the command line used only with Standard ROM DISPLAY $D[\langle n1 \rangle]$ or D[1] or D[0] or D[S] Display the I/O buffers. used with both Formatter/Debugger and Standard ROMs FORMAT F<n1> Format the device. this is a <u>dangerous command</u> used only with Formatter/Debugger ROM Source: David T. Craig Enrar A 0 101 01 Page 0497 of 0580 PAGE 12 OF 22 GET STATUS G[<n1>] Get extended status information. Remember! When using the ProFile, RFFFFFF (read block FFFFFF) also returns status information used only with the Standard ROM HELP $H[\langle n1 \rangle]$ or H[E] or H[E2] or H[char] Print a list of commands, or errors, or a detailed description of each command. where E is to display errors when the Standard ROM is installed where E2 is to display errors when the Formatter/Debugger ROMis installed where char is any legal command shown in this command summary INITIALIZE SPARE TABLE I<nl> Clear the spare block table. this is a dangerous command must be the first command on the command line used only with Formatter/Debugger ROM requires confirmation (Y or N) Source: David T. Craig Page 0498 of 0580 DOCUMENT NO. 063-6006-A PAGE 13 OF 22 LOOPON LPF[S,H,D] Send Loop on Format commands to the firmware. where S = sector marks H = address headers D = data field LPF can be followed by any combination of S, H, and D executed following a Read Track command to loop on format of the current track (eg., R[T] reads the T byte of the block variable to determine the current track) used only with Formatter/Debugger ROM MACRO $M[A(\emptyset-9),C,L,\emptyset-9]$ Use macro functions (alternate command lines). where A = add current line to macro table C = clear all macros L = list macros used with either Formatter/Debugger or Standard ROM not effectively implemented at this time N,0 Not implemented yet PAUSE P[<nl>] or P[A(num),C,,E(num),N(num)] Pause and wait for user. Where A = any error/nonerror C = clear any error/nonerror E = on error N = on no error (num) is a 16-bit mask of S1 S2 Note: All four digits of the 16-bit mask must be turned on used with either Formatter/Debugger or Standard ROM Source: David T. Craig Page 0499 of 0580 Read a block. QUIT Q[<nl>] Return to calling routine (This module is a subroutine). READ R[(num),T(num),H(num),S(num)] where (num) = 24 bit number (8 bit if T,H,S) T = first (Hi) byte of block H = second (Mid) byte of block S = third (Lo) byte of block Remember! The firmware of the device tested determines how the number is treated. See the following example: T H S - Formatter/ Debugger ROM ProFile $\emptyset\emptyset$ $\emptyset\emptyset$ Hi Mid Lo - Standard ROM >0 means read to the output buffer ( Eg., R23>0 ) used with either Formatter/Debugger or Standard ROM SCAN S<n1> Order the firmware to scan the entire disk (read only). Requires confirmation (Y or N) after scanning, use D[I] to get list of any bad blocks found during scan used only with Formatter/Debugger ROM Source: David T. Craig Enrar 1 0 101 01 Page 0500 of 0580 ### rapple computer inc. PAGE \_\_15 OF \_\_22 \_\_ ``` TURN OFF STEPPER T[<n1> Turn off the power to the stepper motor. used with Formatter/Debugger ROM but not normally used with Standard ROM ٧ Not implemented yet W[(num),T(num),H(num),S(num)] WRITE Write to a block (same format as read). where (num) = 24 bit number (8 bit if T,H,S) T = first (Hi) byte of block H = second (Mid) byte of block S = third (Lo) byte of block Remember! The firmware of the device tested determines how the number is treated. See the following example: - Formatter/ Debugger ROM ØØ ØØ ProFile Hi Mid Lo - Standard ROM <I means write from the input buffer ( eg., W23<I )</pre> used with either Formatter/Debugger or Standard ROM XECUTE X[<nl>] or X[E(num)] Execute the current command line again. where E = execute the line to this point on error num = 16 bit error mask of S1 S2 ``` Form= A C 101-01 Source: David T. Craig Page 0501 of 0580 X[E] will execute a function over and over again, if an error has occurred, up to the point where the error occurred ## gapple computer inc. ``` +[(num),T(num),H(num),S(num)] Increment the block number. where (num) = 24 bit number (8 bit if T,H,S) T = first (Hi) byte of block H = second (Mid) byte of block S = third (Lo) byte of block -[(num),T(num),H(num),S(num)] Decrement the block number. where (num) = 24 bit number (8 bit if T,H,S) T = first (Hi) byte of block H = second (Mid) byte of block S = third (Lo) byte of block the - command does not decrement properly for H and S modifiers /[S(num),T] Choose options (/H for help). where S = slot set T = translate current block to cylinder/head/sector ? Help. ``` Source: David T. Craig Earme A O -0- 0- Page 0502 of 0580 ## Goffapple computer inc. DOCUMENT NO. <u>063-6006-A</u> PAGE <u>17</u> OF <u>22</u> #### 5.0 NEW FEATURES The following new features have been developed since the release of DSKDBG V-E00.16 and are included in DSKDBG V-E00.17. - \* The Help errors command has been slightly modified. HE or HEl provides help for the Standard ROM and HE2 returns help for the Formatter/Debugger ROM. - \* The Help command lists the form of the extended help commands. - \* Display now has a command to allow the decoding of the status table into the version, spare list, and bad block list. DS = display status info. - \* Use ESCAPE or RETURN to terminate a long list of spares or bad blocks. - \* An additional modifier is available for read/write commands that allows you to specify which buffer you are reading to or writing from. For example, a read command followed by >0 means read to the output buffer. A write command followed by <I means write from the input buffer. Source: David T. Craig Page 0503 of 0580 ### mapple computer inc. DOCUMENT NO. \_\_\_\_\_063-6006-A\_\_\_\_\_ PAGE <u>18</u> OF <u>22</u> - 6.0 TYPICAL PROBLEMS AND HOW TO AVOID THEM. - \* The + (Increment) command doesn't work. This is to date the most common problem. Usually the command line will look something like RØ PE + X What you were trying to do is sequentially read thru the disk starting at block $\emptyset$ . What you said was Read block Ø (block = Ø), Pause on error, Increment block (block = 1), Repeat line, Read block Ø (block again = Ø) ...... To fix this problem just do one line to set block Ø and then go on to the next line to do the Read, Pause on error etc. For example: RØ<nl> R PE + X<nl> \* Display Status Won't Work Or Won't Stop The display status command allows you to display the input buffer and make assumptions about what the data means. For it to work, the Get status command must successfully read the status information from the drive. If the input buffer has garbage in it, the Display Status command may go round and round trying to display all the spared sectors and bad blocks. To stop the command when it is caught in a loop or is listing a bunch of bad blocks, simply press the RETURN key or the ESCAPE key. The functions of the other keys are the same as for all other display commands. Forms & C 101.01 Source: David T. Craig Page 0504 of 0580 # mapple computer inc. ### 7.0 KNOWN BUGS IN VERSIONS E00.17 AND E00.16 The Macro command has 3 known bugs. The first occurs when a macro is added to the list and there is already one there of that number. The effect is to make both of them disappear. The second bug occurs when the macro is invoked on a line with the X command (eg., M1 X). This disables the ESCAPE key so the program can only be halted by re-booting. The third bug also involves the X command. When a macro is added (eg., R MA1 X), it will keep asking to delete the old macro. Pause on any error flag (P on a white background) doesn't work. The - command doesn't decrement properly for H and S modifiers. Enrm- 1 0 101 01 Source: David T. Craig Page 0505 of 0580 ## apple computer inc. DOCUMENT NO. \_\_\_063-6006-A PAGE 20 OF 22 ### STATUS BYTE DESCRIPTIONS 8.0 This section provides a bit-by-bit description of the four status bytes available with the Standard ROM or the Formatter/Debugger ROM. STATUS BYTES WITH STANDARD ROM V-3.98 INSTALLED ### STATUS 1 - 7 = 1 if ProFile did not receive 55 to its last response 6 = 1 if write or write/verify was aborted because >532 bytes if data were sent if ProFile couldn't read its spare table - 5 = 1 if host's data is no longer in RAM because ProFile updated its spare table - 4 = 1 if SEEK ERROR unable in 3 tries to read 3 consecutive headers on a track - 3 = 1 if CRC error (only set during actual read or verify of write/ - verify, not while trying to read headers after seeking) 2 = 1 if TIMEOUT ERROR (couldn't find header in 9 revolutions not set while trying to read headers after seeking) - 1 = N/A - $\emptyset = 1$ if operation unsuccessful ### STATUS 2 - 7 = 1 if SEEK ERROR unable in 1 try to read 3 consecutive headers on a track - 6 = 1 if spared sector table overflow ( > 32 sectors spared) - 5 = N/A - 4 = 1 if bad block table overflow ( > 100 bad blocks in table) - 3 = 1 if ProFile unable to read its status sector - 2 = 1 if sparing occurred 1 = 1 if seek to wrong track occurred - $\emptyset = N/A$ ### STATUS 3 - 7 = 1 if ProFile has been reset - 6 = 1 if block number invalid - 5 = 1 if block I.D. at end of sector mismatch - 4 = N/A - 3 = N/A - 2 = 1 if ProFile was reset - 1 = 1 if ProFile gave a bad response - $\emptyset = 1$ if parity error - \* These bits are set by the SOS ProFile driver and are not used by the Dskdbg ProFile. IO. Form + A C 101 01 Source: David T. Craig Page 0506 of 0580 # Golf apple computer inc. PAGE 21 OF 22\_ ### STATUS 4 7 - Ø = the number of errors encountered when rereading a block after any read error 7.2 STATUS BYTES WITH FORMATTER/DEBUGGER ROM FD3.98 REV 11 INSTALLED ### STATUS 1 7 = 1 if Profile did not receive 55 to its last response 6 = 1 if no index found during formatting 5 = 1 if no sector mark found during formatting 4 = 1 if SEEK ERROR - unable to read 3 consecutive headers on a track (one try only) 3 = 1 if CRC error (only set during actual read or verify of write/ verify, not while trying to read headers after seeking) 1 = N/A Ø = 1 compare error on a write compare ### STATUS 2 7 = 1 if ProFile has been reset 6 = 1 if track number invalid while reading or writing a sector 5 = N/A 4 = N/A 3 = N/A 2 = N/A 1 = 1 if seek to wrong track occurred $\emptyset = N/A$ Source: David T. Craig Enra- 10 101 01 Page 0507 of 0580 | 1.0/ | | | |------|---------------|------| | 90x | e computer | Inc. | | | C 0011111-01- | | ## STATUS 3 D7, D6, and D5, along with D4 and D3 from STATUS 1, tell why a write compare operation failed. | | D7 | D6 | D5 | |---------------|-----|----|----| | write timeout | Ø | Ø | Ø | | read timeout | 1 | Ø | Ø | | read CRC | , 1 | 1 | Ø | | data compare | 1 | 1. | 1 | ## STATUS 4 7 - 9 = the number of errors encountered when formatting data fields or scanning the disk. FINIS Source: David T. Craig Page 0508 of 0580 # Apple /// Computer Repair Document Pro File Hard Pisk DOCUMENT TITLE Formatting the ProFile HDA 25 Feb 1983 DAVID T. CRAIG 736 EDGEWATER, WICHITA, KANSAS 67230 [USA] Source: David T. Craig Page 0509 of 0580 509 Profile Level 2 Technical Procedures Pages: 8 Contents: Formatting the Profile HDA.....1.3 (25 Feb 1983) 1-8 Profile Level 2 Procedures Rev. 82/25/83 Page 1.1 Source: David T. Craig Page 0510 of 0580 Figure 1 - Profile Controller Board Figure 2 - HDA End View 2-8 Profile Level 2 Procedures Rev. 82/25/83 Page 1.2 Source: David T. Craig Page 0511 of 0580 ## FORMATTING THE PROFILE HDA ### Equipment Necessary: Format Firmware - Rev 18 Jumper Wire Profile Format Diskette - Rev 12 Profile Final System Test - Rev 23 Frequency Counter Small Screwdriver IC Extractor Apple /// w/Profile interface and cable Known good Profile System minus the HDA. ### Procedure: - Place the HDA to be formatted into a known good Profile system. The controller should contain the piggy-back development type Z8 (shown in Figure 1). - 2. Remove the System ROM from the piggy back on the Z8 then install the Format Firmware. Locate the connectors J6, J7 and J8 (shown in Figure 2) that connect the HDA to the analog board. They are a constant source of problems. Move the wires around and make sure that they are securely fastened to the connectors. Connect an external LED to P4 (shown in Figure 1). - Power up the Profile and allow 1 minute for the drive speed to stabilize. - 4. To check the speed of the HDA, set up the frequency counter to display milliseconds, and connect the input of the frequency counter to TP9 on the analog card. The frequency counter should read 16.67 milliseconds +/- .5%. If it does not, adjust R3, on the side of the HDA (shown in Figure 3) as close to 16.67 milliseconds as possible. Profile Level 2 Procedures Rev. 82/25/83 Page 1.3 Source: David T. Craig Page 0512 of 0580 ζ\<sup>5</sup> - 5. Install the Profile interface card into slot 1, and a Silentype Printer into Port A of the Apple ///. Connect the cable between the interface and the Profile. - 6. Boot the Format/Certify Test diskette. When the program is loaded, the following message should appear: PRESS "RETURN" WHEN PROFILE IS READY - 7. After the (RETURN) key is pressed, the following message will appear: INSTALL JUMPER, PRESS ANY KEY TO CONTINUE - 8. Install a jumper between the two pins at P7 on the controller card and then press the (RETURN) key. Although the prompt says that you can press any key to continue, only the (RETURN) key will work. - When the (RETURN) key is pressed, the LED should start to flash and the stepper motor will step outward. The HDA surface is now being formatted. - 18. After approximately 3 minutes, the HDA will be formatted and the following message will appear: REMOVE JUMPER, PRESS ANY KEY TO CONTINUE Remove the jumper wire from P7 on the controller card. Although the message again states that you may press any key to continue, only the <RETURN> key will work. 11. When the (RETURN) key is pressed the Profile will scan, certify and initialize the spares table on the HDA surface. The results of each process are reported on the printer, ending with the following pass or a fail message for the completion of the test: TEST COMPLETED, SYSTEM PASSES (FAILS) If the test fails, the HDA is defective and should be returned. - 12. Power off the Profile and replace the Format Firmware with the 3.98 System Firmware (P/N 341-8888B) or with the masked ZB microprocessor (P/N - 13. Power on the Profile, and observe that it goes though the power up sequence. When the LED is steadily on, boot the Profile Final System Test. 5-8 Profile Level 2 Procedures Rev. 82/25/83 Page 1.5 Source: David T. Craig Page 0514 of 0580 14. After the Final Test has booted, observe the printout on the Silentype. The following message is printed: CONTROLLER VERSION NO. D3.98 Directly below, the printer will print: SPARE SECTORS BAD BLOCKS The number under "SPARE SECTORS" (this should be SPARED SECTORS) is the number of sectors that have already been spared by the Profile. A spared sector is a logical block that has been assigned a new physical location because the old physical location has reached an unacceptable error rate threshold during transfer operations. There are 32 spare sectors on the Profile that can be used for this purpose. The number under "BAD BLOCKS" is the number of blocks that cannot be accessed at all. Any number here indicates a potentially bad Profile. If there are any bad blocks listed here, run the test and match it to the FST Results Chart at the end of this procedure. - 15. After a 5 second pause, the final test will begin transferring blocks of data between the Apple /// and the Profile. Figure 1 illustrates the monitor display. The bottom line of the header is the status line, which returns the inforamtion about the current block being transferred. When an error occurs, the status will be printed on the bottom line of the monitor and on the Silentype. - 16. After the test has completed 588,888 block transfers (about 24 hours), the test is completed. Use the FST Results Chart on the next page to determine the kinds of errors that have occurred and if the unit has passed or failed. . -5--- Profile Level 2 Procedures Rev. 82/25/83 Page 1.6 Source: David T. Craig Page 0515 of 0580 ### Profile Status Bytes Description ### STATUS BYTE 1 - 7 = 1 if Profile did not receive 55 to its last response - 6 = 1 if write or write/verify was aborted because more than 532 bytes of data were sent or Profile could not read the spares table. - 5 = 1 if host data is no longer in RAM because Profile updataed its spares table. - 4 = 1 if SEEK ERROR unable in 3 trys to read 3 consecutive headers on a track - 3 = 1 if CRC error (only set during actual read or verify of write/verify, not while trying to read headers after seeking) - 2 = 1 if TIMEOUT ERROR (couldn't find header in 9 revolutions not set while trying to read headers after seeking) - 1 = N.C. - $\theta = 1$ if operation was unsuccessful ### STATUS BYTE 2 - 7 = 1 if SEEK ERROR unable in 1 try to read 3 consecutive headers on a track - 6 = 1 if spared sector table overflow (> 32 sectors spared. - 5 = N.C. - 4 = 1 if bad block table overflow (greater than 188 bad blocks in table. - 3 = 1 if Profile unable to read its status sector. - 2 = 1 if sparing occured. - 1 = 1 if seek to wrong track occurred - $\theta = N.C.$ ### STATUS BYTE 3 - 7 = 1 if Profile has been reset. - 6 = 1 if block number is invalid. - 5 = 1 if block ID at end of sector mismatch\* - 4 = N.C. - 3 = N.C. - 2 = 1 if Profile was reset\* - 1 = 1 if Profile gave a bad response.\* - 8 = 1 if parity error occured\* ### STATUS 4 7 - 8 = the number of errors encountered when re-reading a block after any read error. \*This bits are set by the Profile driver. 7-8 Profile Level 2 Procedures Rev. 02/25/83 Page 1.7 Source: David T. Craig Page 0516 of 0580 ### FST RESULTS CHART The Profile under test FAILS if: 1. There are 26 or more soft errors. a. To identify a soft error look at the Profile Status bytes. S1 S2 S3 S4\* \*S4 is a decimal number 88 88 88 89 <-- S4 is less than 18 2. There are 6 or more hard errors on the Silentype printout of the following type: S1 S2 S3 S4\* 88 88 88 18 <-- S4 is equal to or greater than 18. 3. There are 2 or more lines on the Silentype printout that are seek errors: S1 S2 S3 S4\* 00 02 00 00 4. There are ANY of the following errors or the blocks transferred counter stops counting: > UNIT FAILS BUFFER COMPARE ERROR INVALID RANDOM SEED Any error with an S1 that has an odd value. Any error where S1 equals 84 Any error where S1, S2 or S3 has value of FF. 5. After the Profile Final System Test as been rebooted: The number of SPARE SECTORS is 16 or more. The number of BAD BLOCKS is 1 or more. 8-8 FINIS Profile Level 2 Procedures Rev. 02/25/83 Page 1.8 Source: David T. Craig Page 0517 of 0580 61X Apple Computer, Inc. Service Engineering Department # Apple /// Computer Repair Document COMPONENT NAME Profile Hard Disk DOCUMENT TITLE Power Supply, ProFile, Class A- DAVID T. CRAIG 736 EDGEWATER, WICHITA, KANSAS 67230 [USA] Source: David T. Craig Page 0518 of 0580 | | * | |--------|----------------------------------------------------------------------------------------------------------------------------------| | • | REV. ZONE ECO# A 806 INITIAL RELEASE | | | B P120 Deleted pg. 4, AC Line Monitor Elec. Req., also pgs. 7-9, dwgs & schematic C P171 Dimension change (page 6) 3.75 was 3.65 | | | | | | | | | 1.0 ELECTRICAL CHARACTERISTICS | | | 1.1 INPUT VOLTAGE: 115 VAC or 230 VAC Selected by jumper on pcb. 47 to 63 Hz | | | 1.2 OPERATING RANGE: 90 to 135 VAC RMS 180 to 270 VAC RMS | | | 1.3 CONVERSION EFFICIENCY: 75% minimum acceptable; with 78% as a target in production. | | - | 1.4 DELIVERED POWER: 30 watts steady state. 55 watts starting for a minimum of 14 seconds. | | | 1.5 OUTPUT VOLTAGES AND CURRENTS: | | | Vout <sub>1</sub> +12 VDC $\pm$ 6% 1.5 Adc steady state and 3.5 to 4.0 amps for 10 - 14 seconds. | | | Vout <sub>2</sub> +5 VDC ± 2% 2.0 Adc continuous. | | | Vout <sub>3</sub> -12 VDC ± 6% 0.1 Adc continuous. | | | 1.6 RIPPLE AND NOISE CONTENT; OUTPUT: 50MVP-Pon +5VDC;10CHV P-P, +12 VDC. 1Hz to 10 MHz. | | | TOLERANCES UNLESS OTHERWISE SPECIFIED DIMENSIONS ARE IN INCHES. DECIMALS .X ± .XX ± .XX ± .APPROVED BY DATE TITLE TITLE | | | ANGLES XX.X± UDIVAC 1/7/81 FRACTIONS ± RELEASED BY DATE DOMENSIONS IN PARENTHESIS ARE IN MELLO STEEDS SIZE DRAWING NUMBER | | | MATERIAL: A 062-0074-C | | NEXT A | SCALE: SHEET 1 OF 6 CLASS "A" | - 1.7 OPERATING TEMPERATURE: 0 to +70 °C (Ambient) - 1.8 STORAGE TEMPERATURE: -20 to +85°C. - 1.9 PROTECTION CIRCUITS: The input must be protected by a fast blow fuse and a thermister inrush current limiter. The +5 volts d.c. TTL voltage must be protected from over voltage output by means of an active crowbar. All three d.c. outputs must be short circuit capable for an indefinite period. - 1.9.1 HOLD UP TIME: 20 msec nominal at 30 watts load. - 1.9.2 TEMPERATURE COEFFICIENT: 0.02%. - 1.9.3 AC ISOLATION: to safety ground and A.C. input to output 4.5KVDC - 1.9.4 OUTPUT TO SAFETY GROUND: 0.5KVDC - 1.9.5 INSULATION AC TO GROUND: 50 MEG ohm nominal. - 1.9.6 LEAKAGE CURRENT: 240 VAC input IRMS = 3.5 ma RMS - 1.9.7 LINE CONDUCTED EMI: FCC 20780 limits. See attached specifications - 1.9.8 SAFETY APPROVALS: UL and CSA required. VDE required after 9/81. - 2.0 MECHANICAL REQUIREMENTS: The supply shall conform to attached envelope. - 2.1 THERMAL: The power supply shall be capable of operating under all conditions of line and load at 0-70°C continuously. - 2.2 STORAGE TEMPERATURE: -20 to +85°C. - 2.3 HUMIDITY: Operating: 95% RH @ 35°C. Storage: 95% RH @ 50°C. - 2.4 VIBRATION: 10 to 500 Hz double sweep at 1 active per minute with pk-pk excursion of 1.5mm or 10g acceleration. - 2.5 RANDOM DROP: 45 min. at a rate of 5 RPM. - 2.6 BURN IN: A minimum 24 hour burn in at low line, full DC load at $70^{\circ}$ C is required. Vendor will burn in all units. Source: David T. Craig Page 0521 of 0580 - 2.7 SERIALIZATION: All supplies shall have a serial number affixed and recorded so that test and failure records can be tracked throughout the life of the product. - 2.8 SAFETY REQUIREMENTS: UL 478 UL 1201 CSA 22.2 No. 154 VDE after 9/81 2.9 INDUCTORS No solenoidal filter inductors should be used in this product. 2.95 INPUT AND OUTPUT CONNECTOR: Molex Connector Pin Designation. A.C. Input D.C. Connector 1. AC Neutral 1. At neutral 2. Key 3. AC Line 1. Reset Monitor Output 2. Key 3. -12V 4. +12V 5. +12V Common 7. 8. 9. 10. Common 11. **+5V** 12. +5V 13. +5V ### Mating Molex Connectors: DC P/N 09-50-3131 AC P/N 09-50-3030 The output connector will be a single, in-line connector combining the above two part numbers. computer inc. SIZE DRAWING NUMBER A 062-0074-C SCALE: --- SHEET 3 OF 6 Source: David T. Craig Page 0522 of 0580 ### SPECIFICATION: ELECTRCMAGNETIC COMPATIBILITY Emissions: Applicable assemblies, subassemblies and periphical devices shall be 6 dB below limits of (1) Federal Communications Commission (FCC) Part 15 Sections 15.830 (radiation limit) and 15.832 (conduction limit) for units operated from 60 Hz line voltage and (2) VDE 0871/6.78 section 3.2.1 (conducted) and sections 3.2.2 and 3.2.3 (radiated) for units operated from 50 Hz line voltage. Those units rated 50/60 Hz shall meet both requirements. The upper frequency limit for both FCC and VDE conducted emissions limits is 30 MHz. However, due to radiated emissions from the AC power cord the Apple conducted limit is extended to 60 MHz. For convenience, limit amplitudes, less 6 dB, are reproduced herein. (Tabulated limits are Apple Computer EMI limits; FCC and VDE limits are 6 dB higher). However, the in-effect version of FCC part 15 or VDE 0871 are the binding documents. ### RADIATED | 1. FCC Part 15 | Frequency<br>Range (MHz)<br>30-88 | Field<br>(uV/m) | Strengths<br>(dB uV) | Distance (meters) | |----------------|-----------------------------------|-----------------|----------------------|-------------------| | 1. TOO FAIL 15 | 88-216 | 50<br>75 | 34 | 3 | | | | 75 | <b>3</b> 8 | . 3 | | | 216-1,000 | 100 | 40 | 3 | | 2. VDE 0871 | 0.01-30 | 20 | 26 | 30 | | | 30-470 | 20 | 26 | 10 | | | 470-1,000 | 80 | <b>3</b> 8 | 10 | ### CONDUCTED | 1. FCC Part 15 | Frequency<br>Range (MHz)<br>0.45-60 | Voltage<br>(uV)<br>125 | (dB uV)<br>42 | | | Impe | ISN<br>edano<br>50 | <u>:e</u> | |------------------|---------------------------------------------|------------------------|---------------|------|------|------|--------------------|-----------| | 2. VDE 0871/6.78 | 0.01-0.15<br>0.15-0.50 | *<br>200 | 46 | | | 1 | 50 | <b>.</b> | | | 0.50-60<br>*straight line<br>(300uV, 50 dBu | | 40<br>(3.5mV, | 71 d | B V) | to | 150 | kHz | Test and measurement equipment and procedures shall be as specified in applicable specifications. Final acceptance tests are performed with assembly or peripheral installed in system intended to be marketed with; such system to consist of the basic Apple Computer (II, III, etc.) and full memory installed and as many peripheral devices (disk drives, printer, monitors) and optional components (language card, serial card, parallel card, etc.) as possible to simulate worst-case operating conditions as closely as possible. Qualification tests with "remote exercisers", generators or other manufacturer Personal CPUs are unacceptable. ### II. <u>SUSCEPTIBILITY</u> (to be determined). Under consideration: The device shall not have uncorrectable data errors when subjected to the following field strengths or voltages - Irradiated: 0.01-1,000 MHz, 5V/m (100% modulated with 1 kHz square wave). | pappie computer inc. | SIZE<br>A | DRAWING NUMBER<br>062-0074-C | | | |----------------------|-----------|------------------------------|--------------|--| | | SCALE: | | SHEET 4 OF 6 | | Source: David T. Craig Page 0523 of 0580 # Apple /// Computer Information • Doc # 78 • ProFile Hard Disk Repair Info II. SUSCEPTIBILITY (to be determined) - continued. Transient Line Noise:\*\* 1. Class A products: 400V pulse with 100 nonosecond width and 10 nsec risetime. 2. Class B products: 200V pulse (same characteristics) Conducted RF: 0.01-100 MHz: 3V rms. \*\*no soft errors allowed. Source: David T. Craig Size A DRAWING NUMBER 062-0074-C SCALE: SHFET 5 OF 6 Page 0524 of 0580 5% Apple Computer, Inc. Service Engineering Department # Apple /// Computer Repair Document Profile Hard Disk / Drive DOCUMENT TITLE Profile Sector Interleave Charts DAVID T. CRAIG 736 EDGEWATER, WICHITA, KANSAS 67230 [USA] Source: David T. Craig Page 0526 of 0580 Pages: Z Apple // ProFile HD Sector Interleave Charts 1-2 Source: David T. Craig Page 0527 of 0580 52X 2-2 | 0 - 0000 | 8-1000 | |----------|--------| | 1-0001 | 9-1001 | | 2-0010 | A-1010 | | 3-0011 | B-1011 | | 4-0100 | C-1100 | | 5-0101 | D-1101 | | 6-0110 | E-1110 | | 7-0111 | F-1111 | トエNエら Source: David T. Craig Page 0528 of 0580 25 Apple Computer, Inc. Service Engineering Department # Apple /// Computer Repair Document COMPONENT NAME ProFile Hard Prive DOCUMENT TITLE ProFile Status Information DAVID T. CRAIG 736 EDGEWATER, WICHITA, KANSAS 67230 [USA] Source: David T. Craig Page 0529 of 0580 # GP Apple 11 Profile HD: Status Info Pages: 2 1-2 Source: David T. Craig Page 0530 of 0580 2-2 FINIS 10740.0 (20.100 Cty 40 See 10741. 60 1101 60 25 00 95 00 09 60 25 00 98 00 02 A STATUS TABLES READ W/DEDUG ROM 93= 147 14= 148 95= 149 97=151 98=152 Status tables Read W/Program SPAPEL SECTORS & BAD Blocks PLAN WITE - 06 DEBUG SOFTWARE + PROGRAM ROM Source: David T. Craig Page 0531 of 0580 Apple Computer, Inc. Service Engineering Department # Apple /// Computer Repair Document Profile Hard Drive DOCUMENT TITLE Misc. Profile Oscilloscope Charts DAVID T. CRAIG 736 EDGEWATER, WICHITA, KANSAS 67230 [USA] Source: David T. Craig Page 0532 of 0580 WOULD NOT START SCAN REPLACES Z8 & COMPATED SCAN WITH TROUBLE DE 3"7 8 113,4,6,7,9 151 152 (5<sup>2</sup>) HORZ = 2 ms/DIV CLY 148 HD BAD BLOCKS (Seets 3, 7, 4, 1, 9, 6 ANALOG DATA 1NDex = 721997 R 13|0|0|A|7|4|1|E|B|8|5|2|F|C|9|6| Area with B DeLay at . 5 Ms/OIV Apple // ProFile HD: Oscilloscope Charts - Misc. Source: David T. Craig Page 0533 of 0580 Highlighter AFREA (a) .5 ms/DIV SAME AS ABOVE WITH INTERPTER MOVED SLighthy TOWARD TK 147 Morcates 28 Problem Writing Between Trancks - 2-5 Source: David T. Craig Page 0534 of 0580 COULD NOT PROMO TRACES CONSISTANTLY - FROM TK 70 TO 152 NOT AT ALL PASCRUATION - ANALOG DATA SIGNAL APROX. HALF of WORMAL - OTHERWIEL DATA LOOKED OF Reading OK AUHLOG DATA = 15/DIV VCO = 15 4/DIV Insex = Thigger ReplaceD ANALOG CARD READS ÁLL KS WITHOUT EPROTZ AS ABOVE Source: David T. Craig Page 0536 of 0580 Sox Apple Computer, Inc. Service Engineering Department # Apple /// Computer Repair Document Profile Hard Drive DOCUMENT TITLE ProFile Controller ROM Misc. Facts DAVID T. CRAIG 736 EDGEWATER, WICHITA, KANSAS 67230 [USA] Source: David T. Craig Page 0538 of 0580 ``` Kages: 1 Alus For P3.97 CONTROLLER ROM 3.98 €IT THNAK LAST COMMAND 3 BYTE SEPORATOR BETHEEN WRITE BUFFER AND STATUS TABLES BAD OR $2-3 SET SPARE TABLE UPDATE OCCURRED, BUFFER DATA IS CHANGED LAN NOT READ 3 SECTORS AFTER 2 RESEEKS 3=CRC ERROR (READ ERROR) 2=CAN NOT FIND TARGET HEADER IN 3 REVOLUTIONS) 0=REQUESTED OPERATION FAILED E:IT 7=CAN NOT READ 3 SECTORS AFTER SEEK S=MORE THAT 32 SPARES (SPARE TABLE OVERFLOH) Apple // Profile HD; Controller Rom Controller Facts Misc. Facts 4=MORE THAN 100 BAD BLOCKS (BAD BLOCK TABLE OVERFLOW) 3=CAN NOT READ STATUS SECTOR 2=9PARING OCCURRED 1=SEEK TO WRONG TRACK ≕N.C. BIT TEPROFILE WAS RESET 6=REQUESTED BLOCK DUT OF RANGE [-0=N.C. READ FAILURE AFTER READ COMMAND TUS FOR FD3.97 FORMATTER ROM FMAK LAST COMMAND 6=NO INDEX FOUND DURING FORMATTING 5=NO SECTOR MARK FOUND DURING FORMATTING 4=SEEK ERROR (UNABLE TO READ 3 CONSECUTIVE HEADERS ON A TRACK) 3=CRC ERROR (ONLY FOR READ WRITE, OR WRITE/VERIFY) 2=TIMEOUT ERROR (UNABLE TO FIND HEADER IN 9 REUS.) 1=N.C. 0=COMPARE ERROR ON A WRITE/COMPARE) 7=PROFILE HAS BEEN RESET 6=FOUND INVALID TRACK NUMBER WHILE READING OR WRITING 5-2=N.C. 1=SEEK TO HRONG TRACK OCCURRED Ø=M.C. IT 6 5 E TIMEOUT Ū ij Ø TIMEOUT 1 Ø 13 CRC 1 1 Ø COMPARE 1 ' JMBER OF ERRORS EMCOUNTERED WHEN FORMATTING DATA FIELDS SCANNING FINIS ``` Source: David T. Craig Page 0539 of 0580 Apple Computer, Inc. Service Engineering Department # Apple /// Computer Repair Document Profile Hard Disk DOCUMENT TITLE Misc. Profile Facts DAVID T. CRAIG 736 EDGEWATER, WICHITA, KANSAS 67230 [USA] Source: David T. Craig Page 0540 of 0580 Apple 11 Profile HD: Misc. HD Facts Drive Runs at 3600 RAM. 2 Platers (131 Hex) 4 Heads 305 Total track: 16 Sectors Apr Track Spares table at Cyl 99 Hds 0-3 Sectors O-F Hds 0,1 Location were spared Data is written Hds 2,3 Physical Location of spared sector To Pause on Error - Pause Flag mu Be inverse (second Line from the top) Just type "P (Return). to cance! Type of Debug Soffware (10mostre Debugger) will only work with the Debug Prom, Doesn't work with the System Drom. Pages: 4 1-4 Source: David T. Craig Page 0541 of 0580 B= Fill Output Buffer E = Erase Track H = Hard Reset Drive K = Write a Header 0 = Turn off Stepper R = Road Block U= Park arm X= Do Commands again 7= HEIP C = Compare Buffers F = Formate I = Init Spares Tables L= Set Range Limits P= Toggle Pause/Arint 5 = Set Slot Number V= Scan all Blocks D= Display Buffers 6= 60 See K J= Read a Header M= Write Sector Marks Q= Quit T - Test Controller Ram w = Write Block +,-,= Increment, Decrement Block 2-4 DEBUGGER SOFTWARE COMMANDS Source: David T. Craig Page 0542 of 0580 6xV Protile Media Percription Info | | , | ı | í | I | |--------|---|------|------|-------------------------------------------| | XF | | 5 | 出 | | | Ä | . | 8 | 出 | 1 | | ۵<br>۲ | • | 8 | 77 | S Depends on Rom Version | | ž | | 8 | FF | | | X<br>8 | • | - | # | | | ¥ | ٤ | \$ | T. | | | 44 | 0 | 30 | * | Number of Actual Bad Blocks | | 80 | _ | 31 | × | Number of Actual Spares | | × | ١ | 20 | 20 | Number of overall spared Sector Available | | 9<br>X | E | 45 | 14 | Number of Bytes Per Sector | | × 5 | ۲ | 45 | 02 | | | Xd | T | 49 | 8 | | | × | f | 5 | 46 | | | 77 | 0 | 井 | 8 | SPACE | | × | ∞ | 22 | 99 | Rom Version in Profile Cont. Board | | QX | a | 20 | 03 | is updated Each Time Spare table upd | | | | 0000 | 0100 | , | 3-4 Source: David T. Craig Page 0543 of 0580 64g To Read q track RTØ HØSØ RTØ RHØ RSØ RØ = TØ HØSØ Read B/k Inc. Sect. Repeat. ROW Aturn R, ISI, X Road, Increment Sect by I, Execute J-Read a Header loesn't Seen'to Work Range Limits LT - LH - LS - LR(Limits Reset) LTLOW - THISH LT 5-T10 LH LOW - H HIGH LH I - HZ LS LOW - 5 High LS5-SE L(Block LOW)-(Block High) Must use comas instead of Spaces Between Commands 4-4 FINIS Source: David T. Craig Page 0544 of 0580 Apple Computer, Inc. Service Engineering Department # Apple /// Computer Repair Document COMPONENT NAME ProFile Hard Disk DOCUMENT TITLE Apple III- ProFile Interface Card Schematic DAVID T. CRAIG 736 EDGEWATER, WICHITA, KANSAS 67230 [USA] Source: David T. Craig Page 0545 of 0580 Sixte 30 Apple Computer, Inc. Service Engineering Department # Apple /// Computer Repair Document Profile Hard Drive Profile Format and Viagnostic Program Revision O.11 (Preliminary) DAVID T. CRAIG 736 EDGEWATER, WICHITA, KANSAS 67230 [USA] Source: David T. Craig Page 0547 of 0580 ## Apple // Profile HD: Profile Format and Diagnostic Program Revision O.11 (Prelim) FOR THE Province Formut and Disensatic Program Revision U.— (Preliminary) Profile, to do a scan of all sectors, to read or write any sector (including those sectors not normally accessable because they're reserved for spares and spare tables or are sectors that have already been spared), to initialize Profile's spare tables, to read or write any of Profile's 1024 bytes of DAI, to read or write the internal registers of Profile's Z8 microprocessor, to read any header (including the data field), to loop on reading any header, to loop on formatting sector marks, to loop on formatting headers, to loop on formatting data fields, to loop on formatting sector marks and headers, and to loop on formatting sector marks, headers, and data fields. The command bytes for each of the commands is shown below. READ | 00 | track | head | sector A read of track FF gets the status table header, which includes the name of the device and the program revision number, preceded by the letter 'D'. WRITE COMPARE | 02 | track | head | sector | FORMAT | 03 | SCAN | 04 | 1-6 Source: David T. Craig INITIALIZE SPARE TABLES Page 0548 of 0580 Pages: 6 ## Apple /// Computer Information • Doc # 78 • ProFile Hard Disk Repair Info 6x6 . READ REGISTERS | į | | İ | | - | |---|----|---|--------------|---| | l | Uσ | ļ | let register | ı | | I | | į | | 1 | Even though the 26 control registers have addresses from FO through FF, the program expects values from 80 through 8F. They immediately follow the general purpose registers when read by the host. | | | | _ | | | _ : | | | | |-------|----|----------|--------------|----|---------------|----------|------|-------|------------| | WRITE | A. | REGISTER | <br> -<br> - | 07 | <br> - <br> - | register | <br> | value | _<br> <br> | For the write a register command the program expects the control registers to be referenced by their real addresses F0 through FF. Any register can be written to (at the user's own risk). The Ports (registers 0 through 3), the working registers (40 hex through 4F hex), the control registers, and a few others will probably be changed before the user gets a chance to read them. Restoring the registers to their original values is highly recommended. | | 4, | beginnin | ng address | ı | |--------------------------------|----------------|-------------|------------|-----------------| | READ RAM | 08 | | LSB | -<br>!<br>! | | | | beginnin | g address | - | | WRITE RAM | I<br>I 09<br>I | l MSB <br> | LSB | -<br> <br> <br> | | LOOP ON FORMAT<br>SECTOR MARKS | <br> OA <br> | track | head | | | LOOP ON FORMAT<br>HEADERS | 1 OB 1 | track | head | | | LOOP ON FORMAT<br>DATA FIELDS | | track | head | | 2-6 Source: David T. Craig Page 0549 of 0580 ## Apple /// Computer Information • Doc # 78 • ProFile Hard Disk Repair Info SUL | | | - 1 | | - 1 | | - 1 | | 1 | | 1 | | | |-------|--------|-----|----|-----|--------|-----|------|----|--------|---|-----------------|--| | لأحت | HEADER | i | υĎ | ! | tracit | i | head | i | sector | | control | | | (מיית | DATA) | 1_ | | _ | | | | 11 | | 1 | . , , , , , , , | | The sector parameter is actually the physical sector. The first one after index (logical sector 0) is $10 \, (decimal)$ and the ones following range from 1 to 15. The control byte is decremented once, then rotated left after each read, with D7 getting shifted into D0. Profile will loop on reading headers until a zero'is shifted out of D7. | LOOP ON FORMAT<br>SECTOR MARKS<br>AND HEADERS | 0E ; | track | head | |----------------------------------------------------------------|------|-------|------| | LOOP ON FORMAT<br>SECTOR MARKS,<br>HEADERS, AND<br>DATA FIELDS | | track | head | | TURN OFF STEPPER | 1 10 | | | The read sector, format, scan, initialize status sectors, read registers, and turn off stepper commands use the read protocol shown below. ## Read Protocol In the timing diagram above, n (the Z8's response to the second command high) is always equal to the command byte plus 2. And while the turn off stepper command uses the protocol shown above, the data available after the 4 status bytes is undefined. The data read by the read sector and read registers commands is obviously the sector and register data, respectively. The data read by the format and scan 3-6 Source: David T. Craig Page 0550 of 0580 commands is a list of the trick, head, and sector where an error occurred, along with the first status byte of the error itself. Only the first 32 errors are listed. The first 255 errors are counted in status 4. The scan and format operations will abort if there are more than 255 errors. The list of errors if followed by a delimiter of FF FF FF. The data read by the initialize spare table command is a list of the all spare table sectors that Profile was unable to do a write compare on (a write, followed by a read, followed by a data compare), along with some error status information. The organization of the list will be described later in this decument. The read RAM command uses the read protocol shown above, except that no status bytes are made available to the host. If the control byte in the read header command is not zero, the read protocol is used but only the first of the four status bytes precedes the data, instead of all four. The write register command uses the read protocol, execept that no status or data bytes are made available to the host. The write and write compare commands use the protocol shown below ### Write Protocol The write RAM command uses the write protocol shown above, except that no status bytes are made available to the host. All other commands use the looping protocol shown below. ### Looping Protocol 4-6 Source: David T. Craig Page 0551 of 0580 rollowing is a description of the bits of the four status bytes. STATUS I 7 = 1 if Provide received $\Leftrightarrow$ 55 to its last response 6 = 1 if no index found during formatting 5 = 1 if no sector mark found during formatting 4 = 1 if SEEK ERROR - unable to read 3 consecutive headers on a track (one try only) 3 = 1 if CRC error (only set during actual read or verify of write/verify, not while trying to read headers after seeking) 2 = 1 if TIMEOUT ERROR (couldn't find header in 9 revolutions - not set while trying to read headers after seeking) 1 = N.C. 0 = 1 compare error on a write compare STATUS 2 7 = 1 if Profile has been reset 6 = 1 if track number invalid while reading or writing a sector $5 = N \cdot C$ 4 = N.C. 3 = N.C. 2 = N.C. 1 = 1 if seek to wrong track occurred 0 = N.C. STATUS 3 ${\tt D7}$ , ${\tt D6}$ , and ${\tt D5}$ , along with ${\tt D4}$ and ${\tt D3}$ from STATUS 1, tell why a write compare operation failed. | · _ | D7 | D6 | D5 | |---------------|----|----|----| | write timeout | 0 | 0 | 0 | | read timeout | 1 | 0 | 0 | | read CRC | 1 | 1 | 0 | | data compare | 1 | 1 | 1 | STATUS 4 7-0= the number of errors encountered when formatting data fields or scanning the disk. No attempt will be made to initialize the spare tables if Profile is unable to read 3 consecutive sectors when seeking to that track and 5-6 Source: David T. Craig Page 0552 of 0580 ## Apple /// Computer Information • Doc # 78 • ProFile Hard Disk Repair Info head. The data after the status bytes following an initialize spare tables commands consists of a list of all the sector that couldn't be written to (one byte each) OR'd with the STATUS 3 result when the error occurred. The D4 bit differentiates between head 2 (0) and head 3 (1). 6-6 FINIS Source: David T. Craig Page 0553 of 0580 Apple Computer, Inc. Service Engineering Department # Apple /// Computer Repair Document COMPONENT NAME Profile Hard Prive DOCUMENT TITLE Software Perice Driver Info (for 111 505) > DAVID T. CRAIG 736 EDGEWATER, WICHITA, KANSAS 67230 [USA] Source: David T. Craig Page 0554 of 0580 $\ensuremath{\mathrm{I/0}}$ control-block definitions for Peripheral test systems Pages: 5 In general the Z-flag C-flag and accumulator will have most of the useful return status information. Z=1 then all ok Z=0 then if C=0 then non-fatal error (we got job done) Z=0 then if C=1 then Fatal error (we didn't get it done) Acc will always have the first byte of status information (the same information which is returned in the status buffer) The length of data given/returned in the data/status buffers is potentially different for different devices and it is up to the programmer to provide enough space for the data for any particular driver. So far the drivers we have designed have the following specs Profile data 532 bytes. status 8 bytes. Duofile data 536 bytes status 9 bytes Clock data 18 bytes max (format dependent)( ends with NULL status 1 byte data 25 hytes may (format dependent) Barcode data 25 bytes max (format dependent) status 1 byte Apple III ProFile HD: Software Driver Info for 6502 systems (i.e. 111 SOS) 1-5 Source: David T. Craig Page 0555 of 0580 ## Apple /// Computer Information • Doc # 78 • ProFile Hard Disk Repair Info Profile: | command | Single byte command to instruct the profile on what to do | Buf-lo | Pointer to the location in memory to get/give the requested data | Buf-hi | Hi byte of pointer | Stat-lo | Pointer to the location in memory to give status information | Stat-hi | Hi byte of pointer | Slot | Slot number of the device (0= no slot) | Device | For drivers that will talk to more than 1 device per slot (0=1) | Blk-lo | For block orented devices this is the lo byte of the block number | Blk-med | The medium byte (it is a 3-byte field) | Spf=lo | Pointer to the location in memory to give/get special functions | Spf-hi | For devices that have special functions or controls (0000=none) | Blk-hi | The hi byte 2-5 Source: David T. Craig Page 0556 of 0580 ``` 660 Duofile: | command | Single byte command to instruct the profile on what to do | Buf-lo | Pointer to the location in memory to get/give the requested data | Buf-hi | Hi byte of pointer | Stat-lo | Pointer to the location in memory to give status information | Stat-hi | Hi byte of pointer | Slot | Slot number of the device (0= no slot) | Device | For drivers that will talk to more than 1 device per slot (0=1) | Blk-lo | For block orented devices this is the lo byte of the block number | Blk-med | The medium byte (it is a 3-byte field) | Blk-hi | The hi byte | Spf=lo | Pointer to the location in memory to give/get special functions | Spf-hi | For devices that have special functions or controls (0000=none) | Mode | Duofile mode control | Addr hi | Hi address of execute local pgm command | Addr lo | Lo address | Dld Lo | Lo address of location in APPLE ramspace to start downlo | Dld Hi | Hi address of start location | Dldl lo | Lo and hi length of datas going into the ramspace | Dldl Hi | Hi byte of length ``` 3-5 Source: David T. Craig Page 0557 of 0580 ·Command Summary 44X - 00 Null command. Do nothing. - O1 Status command. Return the extended status information from the controller. - O2 Execute Run program placed in ram at location specified in the special function table for the device - 03 Modify the registers in the controllers CPU according to device dependent requirements (messy sigh) - 04 Unload Unload the data transfer device from the media and prepare to release the media, (this includes turning off spindle moto or shutting down laser ect. as required) - O5 Write Write data onto (into) the media at location specified (Do an automatic seek as neccessary). For block devices the length of the data will usually be 512 or 536 bytes per block - 06 Format Write header (address/data) information onto the media in pre for use as a block device - 07 Seek Position the transfer device onto (into?) the correct area of the media for the requested block. - 08 Read Read data from the media at location specified (Do an automatic seek as neccessary). For block devices the length of the data will usually be 512 or 536 bytes per block - 09 Load Prepare to engage the media, (this includes turning on spindl motor or powering up the laser ect. as required). Then Load the data transfer device onto (into) the media (if neccessary - OA-17 Reserved for future expansion. These are specalized commands available to a few controllers - 18 Stproff Turn off power to the device which moves the transfer device. - 19 Spmoff Turn off power to the device which moves the media. - 1A 1F Reserved for future expansion 4-5 Source: David T. Craig Page 0558 of 0580 These are commands for just the I/O driver 20 - Reset the device by hardware switch if possable else command the device to do a software reset. 21 - Init Initalize the internal defaults of the driver (including the special functions) 28 - Version Return the Version number and Driver I.D. in the form Enn.nn-ddmmyy-xxxxxx<NULL> Where E is E for experimental or R for released nn.nn is the Version number (E.G. 02.31) dd is the day mm is the month yy is the year of the revision/or minor update xxxxxx is the 6 digit Identifier NULL is a null (\$0) character (its a handy terminator) FINIS 5-5 Source: David T. Craig Page 0559 of 0580 32 Apple Computer, Inc. Service Engineering Department # Apple /// Computer Repair Document COMPONENT NAME Profile Hard Drive Profile Controller Board Photos DAVID T. CRAIG 736 EDGEWATER, WICHITA, KANSAS 67230 [USA] Source: David T. Craig Page 0560 of 0580 Apple Computer, Inc. Service Engineering Department 33 # Apple /// Computer Repair Document Profile Hard Drive Functional Description of the Profile Analog Board DAVID T. CRAIG 736 EDGEWATER, WICHITA, KANSAS 67230 [USA] Source: David T. Craig Page 0564 of 0580 ## God Apple III ProFile Hard Drive ## FUNCTIONAL DESCRIPTION OF THE PROFILE ANALOG BOARD (Refer to the six page schematic for reference details) ( rough draft) The following document has been written with the purpose of describing the circuitry on the Profile Analog Board in detail. It is not meant to be a troubleshooting guide, but is aimed at informing the technician of the different circuits and operating parameters of the board. This document should be used with the Profile Analog Board Tester, Apple Part #878-0184, in testing and repairing any problem on the board. In the event that it is desired to troubleshoot the board onboard the Profile unit itself, the board may be accessed using the following method: Turn the Profile off and let it sit for a minute until the drive stops rotating. Access the Profile Analog board by turning the Profile over on its top, providing the top cover is on the unit. Remove the metal cover under the cabinet which accesses the Analog board. Power the drive back up and refer to the schematic for the test points and waveforms. No harm can come to the drive while it is running in this position, but random data errors will probably occur. Make sure that the drive cannot fall over or receive any sharp jolt or shock as this will damage the HDA media. 253 dilect. 0+1 - Spany on 8+1 Pages:16 1-16 Source: David T. Craig Page 0565 of 0580 ### PAGE ONE The connector J2 on the left connects the Analog hoard to the Controller board. The signals coming into the board are the write data (NRZWDTA), the 10mhz write clock (2F), the write precompensation and current control signal (PCOMP-LOCUR), and the write gate signal (WTGT). Dutputs to the Controller board are the TRK 0 detection and Index pulse signals coming from the HDA assembly. Power and ground inputs to the board are also shown for reference. The track 0 signal indicates when the head stepper motor assembly is at track 0 or the outer track location, while the index pulse occurs once per drive revolution. The index pulse can be monitored at test point TP-9 and used as an oscilloscope trigger for viewing the track analog data at test point TP-1. The +/- 0A and +/- 0B stepper motor control phases pass through the board and are routed to the HDA stepper motor at connector ${\sf J7}$ . The Track 0 signal is obtained from the photosensor mounted on the HDA stepper motor. The sensor is tripped by the rotating arm assembly on the motor shaft when the head array is at the track 0 position, and the sensor output comes in the board at connector J6. The signal is detected and amplified by device UC30 and passed to the Controller board at J2 pin 2. The Index signal comes from the photosensor mounted under the HDA. The sensor is tripped by a small metal tab fastened to the bottom plastic cover of the drive spin motor and comes in the board at connector J8. The signal is detected and amplified by device UC30 and passed to the Controller board at J2 pin 4. The write encoding and precompensation circuitry consists of devices UC27, 28, 29, and 30. The 10mhz write clock is divided by UC2 to create a 5mhz clock (1F) for VCO reset control purposes. The data and control signals are decoded by the FAL logic array UC28, and DLY 2 provides delay references of 10 and 20nsec for data signal precompensation. 2-16 Source: David T. Craig Page 0566 of 0580 This is done to compensate for the magnetic fluxes on the disk media trying to repel each other because of their polarity differences. If this happens, the flux reversals on the media will all have more or less the same distance between them, resulting in a sine wave pattern on the disk with no 1F or 2F signal component margin between flux reversals. The signal outputs of the PAL indicate Early, On Time, or Late data occurances as detected in the PAL data register. These are generated by comparing the data bit pattern and defining the three potential transition points for every flux reversal with the write timing. These signals then shift the write data signal by selecting the proper amount of delay (usually 20 nsec) to over-write any potential bit shift on the media surface. This precompensates the data on the disk surface, allowing a higher bit density without loss of resolution. 3-16 Source: David T. Craig Page 0567 of 0580 ### PAGE\_TWO On this page are the write amplifier, write current control, head select, and read detection circuitry. The write data (WXS) is gated through UC2 into the write current driver array UC1 (MPQ6700) and UC31 (MPQ2907). The data through UC2 will be blocked if the WRTSM' write sector mark signal is true, as this is used to write blank areas on the track for disk sector formatting identification. The current level of the final driver transistor array is set by a voltage reference developed across zener CR1. This diode has a value of 1.2 to 1.25 VDC, which sets the drive level of UC1 to 24ma of write current (48ma peak-to-peak). This level is used to write tracks 0 through 128, while tracks 129 to 152 use less current because of the thinner media coating and smaller disk radial area per bit on the inner tracks. Remember that the drive spin is a constant speed, and the head covers more area on an outer track than it does an inner track during the same time period. In addition, the media surface coating on the disk is thinner towards the center. The smaller available area requires less current to effectively write the media than the larger. To set the lower current value, the PCOMP-LOCUR' (Precompensation- Low Current) signal goes active, causing UC3 to "steal" 5ma from the write current value through the 1.78kohm resistor R10. This results in a lower head write current level of 19ma (38ma peak-to-peak) for the inner tracks. The write current passes through diodes CR4 and CR13 to four connector pins ABCD, and from there directly to the heads. If desired, a pin to pin wire loop can be used at pins AB or CD to monitor the actual write current with a current probe, as the pins are shunted with 22 ohm resistors to the head matrix. 4-16 Source: David T. Craig Page 0568 of 0580 Signals HS-1 and HS-0 are decoded by 1 of 4 decoder UC4. The output selects one of the four heads for either reading or writing by correctly biasing the center tap of the head coil. The other heads are held in an off condition allowing only one head to be selected at a time. The POWEROK signal is a monitor function of the power supply and instantly terminates any write signal if the main power to the Profile unit is lost. The POWEROK line is dropped low by the power supply if the incoming AC is lost, causing the voltage drop across R16 to turn on UC13. This cuts off UC1 while there is still power out of the supply maintaining the system electronics. The POWEROK signal also holds the stepper motor, Z8 controller, and write amplifiers off for a brief moment after initial power on. This delay action can be seen by the READY lamp on the front panel lighting for 1 to 1 & 1/2 seconds when Profile power is first turned on. The WRTSM' signal is used to "write" (actually erase) the track sector marks. The Profile uses 16 blank sector marks per track, radially aligned on the disk, and this signal inhibits any write action to the head during the formatting of the these areas on the disk. The sector marks are erased as 20usec long blank spaces and the disk read logic needs a minimum of 10usec to identify the mark. If any sector mark on a track is written over, the data in that sector is effectively destroyed and cannot be used. For read operation the forward biased diode matrix detects the differential analog transitions (-X and -Y) of the selected head. The other heads are biased so that there is no current flow in the coil, preventing any signal detection. It can alog signal transitions are extremely small and atsoluting to view them in this diode network is impossible. 5-16 Source: David T. Craig Page 0569 of 0580 56g ### PAGE THREE The -X and -Y analog signals enter the ECL 10114 preamplifiers, which are power supply isolated by RG1 for noise immunity. The 10114 was selected because of its excellent input geometry with very little noise. The signals then pass through a low pass filter which is set for 7.5Mhz, 3 times the maximum read signal frequency of 2.5Mhz (2F). inis filter attenuates the major error element of the detected signal, which is the third harmonic of the flux reversal. If viewed on a scope, this is the "Knee" part of the waveform transition midway between signal peaks. The signal then enters a 592 video amplifier UC6, which acts as the AGC (Automatic Gain Control) integrator and controller. The AGC level is developed by device Q\$, a VCR2N junction whose bias level is controlled by UC8, a 353 AGC detector and amplifier. The AGC controlled output of the 592 passes through an emitter follower and buffer network UC7 and is available for monitoring purposes at test points TP1 and TP2 at the bottom of the page. These are differential signals and can be shown individually or compared with each other. The signal levels at these test points are still analog in form and should be around 1.5 to 2 volts peak-to-peak. Anything outside of these levels is indicative of a bad AGC network and renders the data unreadable to the system. If the AGC is lost, the Profile cannot perform the initial scan function after power up. If this should happen, suspect anything in this network. However, remember that the signals into the circuit are far too small to be monitored directly. The best way to troubleshoot anything in this area is to swap out the ICs in the circuit. Troubleshooting to a bad component other than an IC is almost impossible and the board may have to be scrapped out if any other component is at fault. To the right of West UCB pin 7 is a jumper used to set the AGC at a fixed level referenced to -12VDC. This is done only in board manufacture test and the jumper should never be found in the field. Remove it if installed. 6-16 Source: David T. Craig Page 0570 of 0580 *لا*م ## PAGE FOUR The AGC controlled analog signals enter two 10116 ECL schmitt level circuits (UC9) which make up the zero crossing detector. If any signal dropout occurs because of poor AGC, it will be detected by this circuit and interpreted as data. The upper portion of the circuit sets the gain for a minimum amplitude symmetrical signal level. The lower circuit has a delay line in parallel which acts as a 1/4 wavelength delay line through the sum and cancel effect on the signal. In addition, the delay line acts as a good low pass filter to eliminate "hash". The output of the OR gate UC10 is the detected signal pulse. This is allowed to happen only during the "signal allowed" period set by the delay circuit. The detected signal is then gated through UC11 which outputs a low going pulse for every signal that is detected by the zero crossing detector circuit. The output of UC11 is developed by an RC network consisting of C20, R65, and R66, which forms a 50nsec pulse for every flip-flop transition of UC11. If the pulse width is less than 40nsec, capacitor C20 should be replaced to increase the time factor and corresponding pulse width. As previously outlined, Profile uses blank areas on the track for sector identification. These marks indicate the 16 individual track sectors and are placed on the track when it is initially formatted. If any sector mark is over-written or lost, that one sector cannot be read by the system and the data within it is lost. Another schmitt trigger device (UC13) coupled with a slow response time RC circuit is used to detect these blank marks and will not detect any "no signal" period less than 10usec long. The input develops the signal across CR18, CR19, and CR20 with the RC circuit of C23 and R74 delaying the response of one side of UC13. This means that sec in cannot be detected if any noise or off track data has over-written the blank disk area to the point where it is less than 10usec long. The sectors are written in 20usec periods during formatting, so some degradation can occur before the sector is completely lost. The AM HOLD or address mak hold is a function of the Write Sector Mark and Write Gate signals on page 2. It is used to clamp the circuit during write operations, which prevents the output from indexing any data to the controller card. 7-16 Source: David T. Craig Page 0571 of 0580 ## PAGE FIVE On this page are the VCO (Voltage Controlled Oscillator) phase comparator control and data output circuits. The read gate RDGT provides the control element for the circuit. The VCO is reset during any "no read" condition by the 1F 5Mhz signal. This allows the VCO to be triggered almost instantaneously by the RDGT signal instead of recovering from an extreme compliance condition. The circuit at the top of the page sets the time constant of the reset signal (usually a few microseconds). When the read gate goes active it triggers the VCO. The circuit then acts to lock the leading edge of the VCO pulse to the leading edge of the 50nsec signal data pulse. This is done by phase comparing the data pulse with the VCO pulse and generating a corresponding +/- INC or +/- DEC control signal. This pulse goes to the charge pump on page 6 which controls the VCO operating frequency. It takes about 20 read data pulses to properly control the VCO as the pulse train consists that a pulses at different intervals due to MFM criteria. The net effect of the VCO control is to compensate for any difference between the read circuit timing and the speed of the disk. Any speed difference creates an error in the data decoding as the data has to occur at 200nsec cycle periods. The VCO compensates for this, allowing a motor speed deviation of up to 3%. The circuit does this by acting as a "lock", which keeps the data referenced to the center of the VCO pulse "window". The lock lines up the data pulse in the center of the window for stability and proper detection. The VCO output and the data pulse can be monitored at (TP6 and TP7, respectively) to verify the leading edge of both signals occurring simultaneously. The last portion of the circuit is the ECL to TTL level transition network at the bottom of the page. The detected NRZ data and clock signals are fed to the Controller board through connector J2. 8-16 Source: David T. Craig Page 0572 of 0580 Source: David T. Craig Page 0573 of 0580 5x3 ## PAGE SIX On this page is the VCO circuit itself. The main portion of the circuit is the "charge pump" formed with UC24 and the network around it. The voltage level of the circuit is controlled by the INC -/+ and DEC -/+ signals from page 5. The input of the network acts as a "sample and hold" circuit, setting the current level of the ouput transistors. The output passes through a low pass RC filter to a buffer amp UC25. This serves to buffer the current that sets the voltage control level at the MV104 varactor, controlling the VCO frequency. The output of the charge pump can be monitored at TP8. The VCO output is approximately 20Mhz, and is routed to UC22 on page 5. This is a divide by 4 circuit and the resulting 5Mhz signal is the 200nsec VCO "window" into which the incoming read data is locked. 10-16 Source: David T. Craig Page 0574 of 0580