Data storage device saving absolute position at each servo wedge for previous write operations

Information

  • Patent Grant
  • 9355667
  • Patent Number
    9,355,667
  • Date Filed
    Tuesday, November 11, 2014
    9 years ago
  • Date Issued
    Tuesday, May 31, 2016
    8 years ago
Abstract
A data storage device is disclosed comprising a head actuated over a disk comprising a plurality of tracks defined by servo sectors, wherein each servo sector comprises a plurality of servo bursts and the servo sectors define a plurality of servo wedges. A first write operation is executed to a first track and a first absolute position for the head is generated corresponding to a first servo wedge. A second write operation is executed to a second track and a second absolute position for the head is generated corresponding to the first servo wedge. An off-track write condition is detected when executing the second write operation based on the first absolute position and the second absolute position. The first absolute position comprises a track address of the first track and a position error measurement based on the servo bursts in the first servo wedge.
Description
BACKGROUND

Disk drives comprise a disk and a head connected to a distal end of an actuator arm which is rotated about a pivot by a voice coil motor (VCM) to position the head radially over the disk. The disk comprises a plurality of radially spaced, concentric tracks for recording user data sectors and servo sectors. The servo sectors comprise head positioning information (e.g., a track address) which is read by the head and processed by a servo control system to control the actuator arm as it seeks from track to track.



FIG. 1 shows a prior art disk format 2 as comprising a number of servo tracks 4 defined by servo sectors 60-6N recorded around the circumference of each servo track. Each servo sector 6, comprises a preamble 8 for storing a periodic pattern, which allows proper gain adjustment and timing synchronization of the read signal, and a sync mark 10 for storing a special pattern used to symbol synchronize to a servo data field 12. The servo data field 12 stores coarse head positioning information, such as a servo track address, used to position the head over a target data track during a seek operation. Each servo sector 6i further comprises groups of servo bursts 14 (e.g., N and Q servo bursts), which are recorded with a predetermined phase relative to one another and relative to the servo track centerlines. The phase based servo bursts 14 provide fine head position information used for centerline tracking while accessing a data track during write/read operations. A position error signal (PES) is generated by reading the servo bursts 14, wherein the PES represents a measured position of the head relative to a centerline of a target servo track. A servo controller processes the PES to generate a control signal applied to a head actuator (e.g., a voice coil motor) in order to actuate the head radially over the disk in a direction that reduces the PES.





BRIEF DESCRIPTION OF THE DRAWINGS


FIG. 1 shows a prior art disk format comprising a plurality of tracks defined by servo sectors that form servo wedges.



FIG. 2A shows a data storage device in the form of a disk drive according to an embodiment comprising a head actuated over a disk comprising a plurality of tracks defined by servo sectors, wherein each servo sector comprises a plurality of servo bursts and the servo sectors define a plurality of servo wedges.



FIG. 2B is a flow diagram according to an embodiment wherein an absolute position of the head is evaluated to detect an off-track write condition.



FIG. 2C illustrates an off-track write condition detected based on the absolute positions of adjacent track writes according to an embodiment.



FIGS. 3A-3D illustrate an embodiment wherein the absolute position of the head at each servo wedge during write operations is saved in a position buffer representing a circumference of the disk.



FIG. 4 is a flow diagram according to an embodiment wherein the position buffer is updated based on a current write operation.



FIG. 5 is a flow diagram according to an embodiment wherein an off-track write condition may be detected based on the absolute position of the head and an absolute reference position.



FIG. 6 is a flow diagram according to an embodiment wherein when an off-track write condition is detected, at least one data wedge of the previously written, adjacent track is rewritten.



FIG. 7 is a flow diagram according to an embodiment wherein an off-track write condition may be predicted before it occurs.



FIG. 8 shows an embodiment wherein the disk is divided into a number of radial zones, wherein each radial zone is tracked using a position buffer and a data buffer.



FIG. 9A shows a data storage device in the form of a disk drive according to an embodiment comprising a head actuated over a disk.



FIG. 9B is a flow diagram according to an embodiment wherein an off-track write threshold is selected based on a write throughput and a read throughput of the data storage device.



FIG. 10 illustrates an embodiment wherein the off-track write threshold is selected as the minimum of the measured off-track write thresholds that substantially maximizes the write throughput biased by a first weighting and the read throughput biased by a second weighting.





DETAILED DESCRIPTION


FIG. 2A shows a data storage device in the form of a disk drive according to an embodiment comprising a head 16 actuated over a disk 18 comprising a plurality of tracks 20 defined by servo sectors 220-22N, wherein each servo sector comprises a plurality of servo bursts and the servo sectors 220-22N define a plurality of servo wedges. The disk drive further comprises control circuitry 24 configured to execute the flow diagram of FIG. 2B, wherein a first write operation is executed to a first track and a first absolute position for the head is generated corresponding to a first servo wedge (block 26). A second write operation is executed to a second track and a second absolute position for the head is generated corresponding to the first servo wedge (block 28). An off-track write condition is detected (block 32) when executing the second write operation based on the first absolute position and the second absolute position (block 30). The first absolute position comprises a track address of the first track and a position error measurement based on the servo bursts in the first servo wedge.


In the embodiment of FIG. 2A, the servo sectors 220-22N define a plurality of servo tracks, wherein data tracks are defined relative to the servo tracks at the same or different radial density. The control circuitry 24 processes a read signal 34 emanating from the head 16 to demodulate the servo sectors 220-22N and generate a position error signal (PES) representing an error between the actual position of the head and a target position relative to a target track. The control circuitry 24 filters the PES using a suitable compensation filter to generate a control signal 36 applied to a voice coil motor (VCM) 38 which rotates an actuator arm 40 about a pivot in order to actuate the head 16 radially over the disk 18 in a direction that reduces the PES. The servo sectors 220-22N may comprise any suitable head position information, such as a track address for coarse positioning and servo bursts for fine positioning. The servo bursts may comprise any suitable pattern, such as an amplitude based servo pattern or a phase based servo pattern.


During a write operation, the head 16 may deviate from the center of the target track resulting in an off-track write condition. In one embodiment shown in FIG. 2C, the off-track write condition is detected relative to the absolute position of the head 16 when writing a current track n+1 and the absolute position of the head 16 when writing a previous track n. For example, if the difference between the absolute positions is less than a threshold at block 30 of FIG. 2B, then an off-track write condition is detected. Referring to the example of FIG. 2C, an off-track write condition is not detected at servo wedge SS[i] whereas an off-track write condition is detected at servo wedge SS[i+1]. In one embodiment, in order to detect the off-track write condition, the absolute position of the head when writing the adjacent track n is saved in a position buffer. In one embodiment, the position buffer stores an absolute position corresponding to each servo wedge so that if the entire track n is written, then each entry of the position buffer is updated with the absolute position generated at each servo wedge. In one embodiment, write operations may be executed to non-adjacent tracks (including partial tracks) such that the position buffer may store the absolute position for each servo wedge that may correspond to different, non-adjacent tracks.


An example of this embodiment is illustrated in FIGS. 3A-3D which illustrate how the position buffer may be updated when executing a number of write operations. This example shows the disk 18 may comprise 14 servo wedges (0-13); however, the disk 18 may comprise any suitable number of servo wedges. FIG. 3A shows a first write operation to a first track n, wherein the first write operation spans servo wedges 2-6 and therefore a corresponding absolute position generated at servo wedges 2-6 is stored in the position buffer. FIG. 3B shows a second write operation to a second, adjacent track n+1, wherein the second write operation spans servo wedges 4-10 and therefore a corresponding absolute position generated at servo wedges 4-10 is stored in the position buffer. In this example, the absolute position previously stored in the position buffer for servo wedges 4-6 when executing the first write operation (FIG. 3A) are overwritten with the absolute position generated for servo wedges 4-6 during the second write operation (FIG. 3B).


When executing the second write operation, the absolute position generated at servo wedge 4 may be compared to the absolute position saved in the position buffer in order to detect an off-track write condition. If the off-track write condition is not detected, the absolute position generated at servo wedge 4 during the second write operation may replace the absolute position previously stored in the position buffer. In an alternative embodiment, the absolute position generated at each servo wedge during the second write operation may be stored in a scratch buffer. If the second write operation completes successfully without detecting an off-track write condition, then the absolute position values stored in the scratch buffer may replace the absolute position values stored in the position buffer. This embodiment may facilitate rewriting one or more of the data wedges during a retry write operation if an off-track write condition is detected.



FIG. 3C shows a third write operation to a third, non-adjacent track n+7 (non-adjacent to track n+1), wherein the third write operation spans servo wedges 8-11 and therefore a corresponding absolute position generated at servo wedges 8-11 is stored in the position buffer. When executing the third write operation, the difference between the absolute position stored in the position buffer for servo wedge 8 (which corresponds to writing track n+1) and the absolute position generated for the third write operation will be very large since the third track n+7 is non-adjacent with the previously written track n+1. Therefore an off-track write condition based on the absolute position stored in the position buffer will not be detected. During the fourth write operation to track n+2 as shown in FIG. 3D, an off-track write condition may be detected for servo wedges 4-5 since the absolute position stored in the position buffer corresponds to adjacent track n+1. Accordingly, in this embodiment the position buffer stores an absolute position for each servo wedge around the circumference of the disk; however, the absolute positions stored in the position buffer may correspond to different (potentially non-adjacent) tracks. A benefit provided by this embodiment is that an off-track write condition may be detected based on the absolute position of the head during the write operations without having to store the absolute position for every track written. Further, by storing the absolute position (as compared to just storing the PES for each servo wedge) in the position buffer, the case where the written tracks are non-adjacent is automatically taken into account.


In one embodiment shown in FIG. 8, the disk may be divided into a number of radial zones, wherein a separate position buffer (ABP buffer) may be maintained for each radial zone. This embodiment may improve the chances of detecting an off-track write condition since the content of each position buffer will more likely correspond to an adjacently written track. For example, in one embodiment one or more of the radial zones may correspond to a “shingled zone” wherein the tracks may be written as a circular buffer using log structured writes. In this embodiment, the tracks of a “shingled zone” are written consecutively such that the corresponding position buffer will typically comprise the absolute position information of an adjacent, previously written track. Even in radial zones where the writes may not always be consecutive, at least part of the position buffer may store absolute position information of a previously written, adjacent track such that an off-track write condition may be detected using the position buffer as described above.


In the embodiment described above, the absolute position may comprise a track address and a position error measurement based on the servo bursts in the servo wedge. In another embodiment, the absolute position may further include a head number corresponding to the disk surface being written in a multi-disk surface disk drive. In this embodiment, an off-track write condition may be detected based on the absolute position stored in the position buffer when writing to the same disk surface.



FIG. 4 is a flow diagram according to an embodiment for executing a write operation (block 42), wherein when the head reaches servo sector i (block 44) an absolute position ABPw is generated (block 46) corresponding to the servo wedge. A difference between the absolute position ABPw and the corresponding absolute position ABP[i] stored in the position buffer is compared to a threshold (block 48). If the difference is greater than the threshold, then an off-track-write condition is not detected and the absolute position ABPw is stored in the position buffer at ABP[i] (block 50). The write operation then continues (block 52) until the write operation finishes (block 54) or until an off-track write condition is detected at block 48. If it is not completed at block 54, the next servo sector is processed (increments i) and the process returns to block 44. In the embodiment of FIG. 4, when an off-track write condition is detected at block 48, the write operation is aborted (block 56). In an alternative embodiment, the absolute positions generated at block 46 may be saved in a scratch buffer, and the content of the scratch buffer copied to the position buffer after the write operation has successfully completed. This embodiment may facilitate a retry write operation when a write operation is aborted due to detecting an off-track write condition.



FIG. 5 is a flow diagram according to an embodiment which extends on the flow diagram of FIG. 4, wherein when an off-track write condition is not detected at block 48 based on the position buffer, an off-track write condition may still be detected at block 58 if the absolute position ABPw deviates sufficiently from a reference absolute position (ABRw) which corresponds to the center of the track being written. That is, if the difference between the absolute position ABPw and the reference position ABRw exceeds a threshold (block 58) an off-track write condition is detected and the write operation is aborted at block 56.


In one embodiment, the control circuitry 24 of FIG. 2A is configured to define a data buffer corresponding to a circumference of the disk. When a first write operation is executed to write first write data to a first track, the first write data is stored to a first part of the data buffer. When second write operation is executed to write second write data to a second track, at least part of the second write data is stored to a second part of the data buffer. When a third write operation is executed to write third write data to a third track, at least part of the third write data is stored to a third part of the data buffer. The data buffer simultaneously stores at least part of the first write data, the second write data, and the third write data, wherein the third track is non-adjacent to the first track. An example of this embodiment may be understood with reference to FIGS. 3A-3D described above, except that each block of the buffer corresponds to a data wedge of a write operation rather than an absolute position generated for each servo wedge.



FIG. 6 is a flow diagram illustrating this embodiment which extends on the flow diagram of FIG. 5, wherein when executing a write operation the write data written to a data wedge of the track is stored in a data buffer (block 60) similar to storing the absolute position information in the position buffer at block 50. When writing data to different data tracks, the write data overwrites the previously stored write data in the data buffer at block 60. Accordingly, the data buffer may store data wedges for different tracks, including for non-adjacent tracks. In this manner, when an off-track write condition is detected at block 48 based on the position buffer when writing to a current track, the write data stored in the data buffer may be used to refresh the data written to a previously written, adjacent track (block 62). When an off-track write condition is detected at block 58 based on the absolute reference position, the write operation is aborted (block 64) without refreshing a previously written, adjacent track since the data stored in the data buffer does not correspond to a previously written, adjacent track.



FIG. 8 illustrates an embodiment wherein the control circuitry may maintain a data buffer for each radial zone similar to maintaining a position buffer for each radial zone. Accordingly, if an off-track write condition is detected based on the position buffer for a radial zone, the corresponding data buffer may be used to refresh the data written in the previously written, adjacent track before retrying the current write operation to the current track.



FIG. 7 is a flow diagram illustrating an embodiment which extends on the flow diagram of FIG. 6, wherein when an off-track write condition is not detected at block 48 based on the position buffer, and an off-track write condition is not detected at block 58 based on the absolute reference position ABRw, an off-track write condition may still be predicted at block 66. In this embodiment, a predicted absolute position (ABPpw) corresponding to a next servo wedge is generated using any suitable algorithm. For example, in one embodiment the predicted absolute position is generated based on:

ABPpw(k)=2·ABPw(k)−ABPw(k−1)

If a difference between the ABPpw and the absolute position stored in the position buffer APB[i+1] for the next servo wedge exceeds a threshold at block 66, an off-track write condition is detected. In one embodiment, when an off-track write condition is detected based on the predicted absolute position of a next servo wedge, the write operation is aborted at block 64 without refreshing the data of the previously written, adjacent track.



FIG. 9A shows a data storage device in the form of a disk drive according to an embodiment comprising a head 16 actuated over a disk 18, and control circuitry 24 configured to execute the flow diagram of FIG. 9B. A write throughput and a read throughput of the disk drive are measured for a plurality of different off-track write thresholds (block 67). An operating off-track write threshold is selected based on the measurements (block 68), and a write operation to the disk is aborted based on the operating off-track write threshold (block 70).



FIG. 10 shows an example of this embodiment wherein the write throughput of the disk drive increases as the off-track write threshold increases since there are fewer off-track write conditions detected and fewer write aborts. However, increasing the off-track write threshold eventually causes the read throughput of the disk drive to decrease since the reliability of the recorded data decreases which increases the data recovery time due, for example, to executing more retry reads and/or other heroic error recovery procedures. In one embodiment, the control circuitry 24 is configured to select the operating off-track write threshold that substantially maximizes the write throughput biased by a first weighting and the read throughput biased by a second weighting. For example, in one embodiment the control circuitry 24 is configured to select the operating off-track write threshold as the minimum of the measured off-track write thresholds that substantially maximizes the write throughput biased by a first weighting and the read throughput biased by a second weighting. Any suitable first weighting and second weighting may be selected to bias the write/read throughputs, for example, to achieve a target ratio between the write/read throughputs. For example, in one embodiment the first weighting may be different than the second weighting so that the disk drive exhibits better read throughput performance as compared to write throughput.


Any suitable operating off-track write threshold may be calibrated by executing the flow diagram of FIG. 9B, such as the position buffer threshold at block 48 of FIG. 7, the absolute reference position ABRw threshold at block 58 of FIG. 7, and/or the predictive threshold at block 66 of FIG. 7. In one embodiment, two or more off-track write thresholds may be calibrated relative to the write/read throughput of the disk drive.


Any suitable control circuitry may be employed to implement the flow diagrams in the above embodiments, such as any suitable integrated circuit or circuits. For example, the control circuitry may be implemented within a read channel integrated circuit, or in a component separate from the read channel, such as a disk controller, or certain operations described above may be performed by a read channel and others by a disk controller. In one embodiment, the read channel and disk controller are implemented as separate integrated circuits, and in an alternative embodiment they are fabricated into a single integrated circuit or system on a chip (SOC). In addition, the control circuitry may include a suitable preamp circuit implemented as a separate integrated circuit, integrated into the read channel or disk controller circuit, or integrated into a SOC.


In one embodiment, the control circuitry comprises a microprocessor executing instructions, the instructions being operable to cause the microprocessor to perform the flow diagrams described herein. The instructions may be stored in any computer-readable medium. In one embodiment, they may be stored on a non-volatile semiconductor memory external to the microprocessor, or integrated with the microprocessor in a SOC. In another embodiment, the instructions are stored on the disk and read into a volatile semiconductor memory when the disk drive is powered on. In yet another embodiment, the control circuitry comprises suitable logic circuitry, such as state machine circuitry.


In various embodiments, a disk drive may include a magnetic disk drive, an optical disk drive, etc. In addition, while the above examples concern a disk drive, the various embodiments are not limited to a disk drive and can be applied to other data storage devices and systems, such as magnetic tape drives, solid state drives, hybrid drives, etc. In addition, some embodiments may include electronic devices such as computing devices, data server devices, media content storage devices, etc. that comprise the storage media and/or control circuitry as described above.


The various features and processes described above may be used independently of one another, or may be combined in various ways. All possible combinations and subcombinations are intended to fall within the scope of this disclosure. In addition, certain method, event or process blocks may be omitted in some implementations. The methods and processes described herein are also not limited to any particular sequence, and the blocks or states relating thereto can be performed in other sequences that are appropriate. For example, described tasks or events may be performed in an order other than that specifically disclosed, or multiple may be combined in a single block or state. The example tasks or events may be performed in serial, in parallel, or in some other manner. Tasks or events may be added to or removed from the disclosed example embodiments. The example systems and components described herein may be configured differently than described. For example, elements may be added to, removed from, or rearranged compared to the disclosed example embodiments.


While certain example embodiments have been described, these embodiments have been presented by way of example only, and are not intended to limit the scope of the inventions disclosed herein. Thus, nothing in the foregoing description is intended to imply that any particular feature, characteristic, step, module, or block is necessary or indispensable. Indeed, the novel methods and systems described herein may be embodied in a variety of other forms; furthermore, various omissions, substitutions and changes in the form of the methods and systems described herein may be made without departing from the spirit of the embodiments disclosed herein.

Claims
  • 1. A data storage device comprising: a disk comprising a plurality of tracks defined by servo sectors, wherein each servo sector comprises a plurality of servo bursts and the servo sectors define a plurality of servo wedges;a head actuated over the disk; andcontrol circuitry configured to: execute a first write operation to a first track and generate a first absolute position for the head corresponding to a first servo wedge;execute a second write operation to a second track and generate a second absolute position for the head corresponding to the first servo wedge; anddetect an off-track write condition when executing the second write operation based on the first absolute position and the second absolute position;wherein the first absolute position comprises a track address of the first track and a position error measurement based on the servo bursts in the first servo wedge.
  • 2. The data storage device as recited in claim 1, wherein the first absolute position comprises a head number representing the head.
  • 3. The data storage device as recited in claim 1, wherein the control circuitry is further configured to abort the second write operation when the off-track write condition is detected.
  • 4. The data storage device as recited in claim 1, wherein for a first radial zone of the disk comprising the first track and the second track the control circuitry is further configured to save an absolute position corresponding to each servo wedge, wherein at least one of the saved absolute positions corresponds to the first write operation and at least one of the saved absolute positions corresponds to the second write operation.
  • 5. The data storage device as recited in claim 4, wherein at least one of the saved absolute positions corresponds to a third write operation to a third track non-adjacent to the first track.
  • 6. The data storage device as recited in claim 4, wherein for a second radial zone of the disk comprising a third track and a fourth track, the control circuitry is further configured to save an absolute position corresponding to each servo wedge, wherein at least one of the saved absolute positions corresponds to a third write operation to the third track and at least one saved absolute positions corresponds to a fourth write operation to the fourth track.
  • 7. A data storage device comprising: a disk comprising a plurality of tracks defined by servo sectors;a head actuated over the disk; andcontrol circuitry configured to: define a first data buffer corresponding to a first circumference of the disk;execute a first write operation to write first write data to a first track and store the first write data to a first part of the first data buffer;execute a second write operation to write second write data to a second track and store at least part of the second write data to a second part of the first data buffer; andexecute a third write operation to write third write data to a third track and store at least part of the third write data to a third part of the first data buffer;wherein: the first data buffer simultaneously stores at least part of the first write data, the second write data, and the third write data; andthe third track is non-adjacent to the first track.
  • 8. The data storage device as recited in claim 7, wherein the control circuitry is further configured to overwrite at least part of the first write data saved in the first data buffer with at least part of the third write data.
  • 9. The data storage device as recited in claim 7, wherein the first circumference of the disk is within a first radial zone of the disk and the control circuitry is further configured to: define a second data buffer corresponding to a second circumference of the disk within a second radial zone of the disk; andsave write data in the second data buffer for write operations to the tracks in the second radial zone.
  • 10. The data storage device as recited in claim 7, wherein the control circuitry is further configured to: detect an off-track write condition when executing the second write operation; andwhen the off-track write condition is detected, rewrite at least part of the first write data saved in the first data buffer to the first track.
  • 11. A data storage device comprising: a disk;a head actuated over the disk; andcontrol circuitry configured to: measure a write throughput and a read throughput for a plurality of different off-track write thresholds;select an operating off-track write threshold based on the measurements; andabort a write operation to the disk based on the operating off-track write threshold.
  • 12. The data storage device as recited in claim 11, wherein the control circuitry is further configured to select the operating off-track write threshold that substantially maximizes the write throughput biased by a first weighting and the read throughput biased by a second weighting.
  • 13. The data storage device as recited in claim 11, wherein the control circuitry is further configured to select the operating off-track write threshold as the minimum of the measured off-track write thresholds that substantially maximizes the write throughput biased by a first weighting and the read throughput biased by a second weighting.
  • 14. The data storage device as recited in claim 11, wherein: the write throughput increases when the off-track write threshold increases; andthe read throughput decreases when the off-track write threshold increases.
  • 15. A method of operating a data storage device, the method comprising: executing a first write operation to a first track on a disk using a head and generating a first absolute position for the head corresponding to a first servo wedge on the disk;executing a second write operation to a second track and generating a second absolute position for the head corresponding to the first servo wedge; anddetecting an off-track write condition when executing the second write operation based on the first absolute position and the second absolute position;wherein the first absolute position comprises a track address of the first track and a position error measurement based on servo bursts in the first servo wedge.
  • 16. The method as recited in claim 15, wherein the first absolute position comprises a head number representing the head.
  • 17. The method as recited in claim 15, wherein the method further comprises aborting the second write operation when the off-track write condition is detected.
  • 18. The method as recited in claim 15, wherein for a first radial zone of the disk comprising the first track and the second track the method further comprises saving an absolute position corresponding to each servo wedge, wherein at least one of the saved absolute positions corresponds to the first write operation and at least one of the saved absolute positions corresponds to the second write operation.
  • 19. The method as recited in claim 18, wherein at least one of the saved absolute positions corresponds to a third write operation to a third track non-adjacent to the first track.
  • 20. The method as recited in claim 18, further comprising, for a second radial zone of the disk comprising a third track and a fourth track, saving an absolute position corresponding to each servo wedge, wherein at least one of the saved absolute positions corresponds to a third write operation to the third track and at least one saved absolute positions corresponds to a fourth write operation to the fourth track.
  • 21. A method of operating a data storage device, the method comprising: defining a first data buffer corresponding to a first circumference of a disk;executing a first write operation to write first write data to a first track on the disk and storing the first write data to a first part of the first data buffer;executing a second write operation to write second write data to a second track on the disk and storing at least part of the second write data to a second part of the first data buffer; andexecuting a third write operation to write third write data to a third track on the disk and store at least part of the third write data to a third part of the first data buffer;wherein: the first data buffer simultaneously stores at least part of the first write data, the second write data, and the third write data; andthe third track is non-adjacent to the first track.
  • 22. The method as recited in claim 21, further comprising overwriting at least part of the first write data saved in the first data buffer with at least part of the third write data.
  • 23. The method as recited in claim 21, wherein the first circumference of the disk is within a first radial zone of the disk and the method further comprises: defining a second data buffer corresponding to a second circumference of the disk within a second radial zone of the disk; andsaving write data in the second data buffer for write operations to the tracks in the second radial zone.
  • 24. The method as recited in claim 21, further comprising: detecting an off-track write condition when executing the second write operation; andwhen the off-track write condition is detected, rewriting at least part of the first write data saved in the first data buffer to the first track.
  • 25. A method of operating a data storage device, the method comprising: measuring a write throughput and a read throughput for a plurality of different off-track write thresholds;selecting an operating off-track write threshold based on the measurements; andaborting a write operation to a disk based on the operating off-track write threshold.
  • 26. The method as recited in claim 25, further comprising selecting the operating off-track write threshold that substantially maximizes the write throughput biased by a first weighting and the read throughput biased by a second weighting.
  • 27. The method as recited in claim 25, further comprising selecting the operating off-track write threshold as the minimum of the measured off-track write thresholds that substantially maximizes the write throughput biased by a first weighting and the read throughput biased by a second weighting.
  • 28. The method recited in claim 25, wherein: the write throughput increases when the off-track write threshold increases; andthe read throughput decreases when the off-track write threshold increases.
US Referenced Citations (351)
Number Name Date Kind
6014283 Codilian et al. Jan 2000 A
6052076 Patton, III et al. Apr 2000 A
6052250 Golowka et al. Apr 2000 A
6067206 Hull et al. May 2000 A
6078453 Dziallo et al. Jun 2000 A
6091564 Codilian et al. Jul 2000 A
6094020 Goretzki et al. Jul 2000 A
6101065 Alfred et al. Aug 2000 A
6104153 Codilian et al. Aug 2000 A
6111714 Ueda et al. Aug 2000 A
6122133 Nazarian et al. Sep 2000 A
6122135 Stich Sep 2000 A
6141175 Nazarian et al. Oct 2000 A
6160368 Plutowski Dec 2000 A
6181493 Wakefield Jan 2001 B1
6181502 Hussein et al. Jan 2001 B1
6195222 Heminger et al. Feb 2001 B1
6198584 Codilian et al. Mar 2001 B1
6198590 Codilian et al. Mar 2001 B1
6204988 Codilian et al. Mar 2001 B1
6215608 Serrano et al. Apr 2001 B1
6243223 Elliott et al. Jun 2001 B1
6281652 Ryan et al. Aug 2001 B1
6285521 Hussein Sep 2001 B1
6292320 Mason et al. Sep 2001 B1
6310742 Nazarian et al. Oct 2001 B1
6320718 Bouwkamp et al. Nov 2001 B1
6342984 Hussein et al. Jan 2002 B1
6347018 Kadlec et al. Feb 2002 B1
6369972 Codilian et al. Apr 2002 B1
6369974 Asgari et al. Apr 2002 B1
6421197 Abdelnour Jul 2002 B1
6462896 Codilian et al. Oct 2002 B1
6476996 Ryan Nov 2002 B1
6484577 Bennett Nov 2002 B1
6493169 Ferris et al. Dec 2002 B1
6496320 Liu Dec 2002 B1
6496324 Golowka et al. Dec 2002 B1
6498698 Golowka et al. Dec 2002 B1
6507450 Elliott Jan 2003 B1
6534936 Messenger et al. Mar 2003 B2
6538839 Ryan Mar 2003 B1
6545835 Codilian et al. Apr 2003 B1
6549359 Bennett et al. Apr 2003 B1
6549361 Bennett et al. Apr 2003 B1
6560056 Ryan May 2003 B1
6568268 Bennett May 2003 B1
6574062 Bennett et al. Jun 2003 B1
6577465 Bennett et al. Jun 2003 B1
6614615 Ju et al. Sep 2003 B1
6614618 Sheh et al. Sep 2003 B1
6636377 Yu et al. Oct 2003 B1
6690536 Ryan Feb 2004 B1
6693764 Sheh et al. Feb 2004 B1
6707635 Codilian et al. Mar 2004 B1
6710953 Vallis et al. Mar 2004 B1
6710966 Codilian et al. Mar 2004 B1
6714371 Codilian Mar 2004 B1
6714372 Codilian et al. Mar 2004 B1
6717757 Levy et al. Apr 2004 B1
6724564 Codilian et al. Apr 2004 B1
6731450 Codilian et al. May 2004 B1
6735033 Codilian et al. May 2004 B1
6735041 Codilian et al. May 2004 B1
6738220 Codilian May 2004 B1
6747837 Bennett Jun 2004 B1
6760186 Codilian et al. Jul 2004 B1
6781780 Codilian Aug 2004 B1
6788483 Ferris et al. Sep 2004 B1
6791785 Messenger et al. Sep 2004 B1
6795262 Codilian et al. Sep 2004 B1
6795268 Ryan Sep 2004 B1
6819518 Melkote et al. Nov 2004 B1
6826006 Melkote et al. Nov 2004 B1
6826007 Patton, III Nov 2004 B1
6847502 Codilian Jan 2005 B1
6850383 Bennett Feb 2005 B1
6850384 Bennett Feb 2005 B1
6867944 Ryan Mar 2005 B1
6876508 Patton, III et al. Apr 2005 B1
6882489 Brunnett et al. Apr 2005 B1
6882496 Codilian et al. Apr 2005 B1
6885514 Codilian et al. Apr 2005 B1
6900958 Yi et al. May 2005 B1
6900959 Gardner et al. May 2005 B1
6903897 Wang et al. Jun 2005 B1
6914740 Tu et al. Jul 2005 B1
6914743 Narayana et al. Jul 2005 B1
6920004 Codilian et al. Jul 2005 B1
6924959 Melkote et al. Aug 2005 B1
6924960 Melkote et al. Aug 2005 B1
6924961 Melkote et al. Aug 2005 B1
6934114 Codilian et al. Aug 2005 B1
6934135 Ryan Aug 2005 B1
6937420 McNab et al. Aug 2005 B1
6937423 Ngo et al. Aug 2005 B1
6940679 McNeil et al. Sep 2005 B1
6952322 Codilian et al. Oct 2005 B1
6954324 Tu et al. Oct 2005 B1
6958881 Codilian et al. Oct 2005 B1
6963465 Melkote et al. Nov 2005 B1
6965488 Bennett Nov 2005 B1
6967458 Bennett et al. Nov 2005 B1
6967811 Codilian et al. Nov 2005 B1
6968422 Codilian et al. Nov 2005 B1
6970319 Bennett et al. Nov 2005 B1
6972539 Codilian et al. Dec 2005 B1
6972540 Wang et al. Dec 2005 B1
6972922 Subrahmanyam et al. Dec 2005 B1
6975468 Melrose et al. Dec 2005 B1
6975480 Codilian et al. Dec 2005 B1
6977789 Cloke Dec 2005 B1
6980389 Kupferman Dec 2005 B1
6987636 Chue et al. Jan 2006 B1
6987639 Yu Jan 2006 B1
6989954 Lee et al. Jan 2006 B1
6992848 Agarwal et al. Jan 2006 B1
6992851 Cloke Jan 2006 B1
6992852 Ying et al. Jan 2006 B1
6995941 Miyamura et al. Feb 2006 B1
6999263 Melkote et al. Feb 2006 B1
6999267 Melkote et al. Feb 2006 B1
7006320 Bennett et al. Feb 2006 B1
7016134 Agarwal et al. Mar 2006 B1
7023637 Kupferman Apr 2006 B1
7023640 Codilian et al. Apr 2006 B1
7027256 Subrahmanyam et al. Apr 2006 B1
7027257 Kupferman Apr 2006 B1
7035026 Codilian et al. Apr 2006 B2
7046472 Melkote et al. May 2006 B1
7050249 Chue et al. May 2006 B1
7050254 Yu et al. May 2006 B1
7050258 Codilian May 2006 B1
7054098 Yu et al. May 2006 B1
7061714 Yu Jun 2006 B1
7064918 Codilian et al. Jun 2006 B1
7068451 Wang et al. Jun 2006 B1
7068459 Cloke et al. Jun 2006 B1
7068461 Chue et al. Jun 2006 B1
7068463 Ji et al. Jun 2006 B1
7088547 Wang et al. Aug 2006 B1
7095579 Ryan et al. Aug 2006 B1
7097110 Sheperek et al. Aug 2006 B2
7110208 Miyamura et al. Sep 2006 B1
7110214 Tu et al. Sep 2006 B1
7113362 Lee et al. Sep 2006 B1
7113365 Ryan et al. Sep 2006 B1
7116505 Kupferman Oct 2006 B1
7126781 Bennett Oct 2006 B1
7158329 Ryan Jan 2007 B1
7180703 Subrahmanyam et al. Feb 2007 B1
7184230 Chue et al. Feb 2007 B1
7196864 Yi et al. Mar 2007 B1
7199966 Tu et al. Apr 2007 B1
7203021 Ryan et al. Apr 2007 B1
7209305 Chan et al. Apr 2007 B2
7209321 Bennett Apr 2007 B1
7212364 Lee May 2007 B1
7212374 Wang et al May 2007 B1
7215504 Bennett May 2007 B1
7224546 Orakcilar et al. May 2007 B1
7248426 Weerasooriya et al. Jul 2007 B1
7251098 Wang et al. Jul 2007 B1
7253582 Ding et al. Aug 2007 B1
7253989 Lau et al. Aug 2007 B1
7265933 Phan et al. Sep 2007 B1
7289288 Tu Oct 2007 B1
7298574 Melkote et al. Nov 2007 B1
7301717 Lee et al. Nov 2007 B1
7304819 Melkote et al. Dec 2007 B1
7330019 Bennett Feb 2008 B1
7330327 Chue et al. Feb 2008 B1
7333280 Lifchits et al. Feb 2008 B1
7333290 Kupferman Feb 2008 B1
7339761 Tu et al. Mar 2008 B1
7365932 Bennett Apr 2008 B1
7388728 Chen et al. Jun 2008 B1
7391583 Sheh et al. Jun 2008 B1
7391584 Sheh et al. Jun 2008 B1
7423828 Emo et al. Sep 2008 B2
7426086 Tobari et al. Sep 2008 B2
RE40545 Ioannou et al. Oct 2008 E
7433143 Ying et al. Oct 2008 B1
7440210 Lee Oct 2008 B1
7440225 Chen et al. Oct 2008 B1
7450334 Wang et al. Nov 2008 B1
7450336 Wang et al. Nov 2008 B1
7453661 Jang et al. Nov 2008 B1
7457071 Sheh Nov 2008 B1
7466509 Chen et al. Dec 2008 B1
7468855 Weerasooriya et al. Dec 2008 B1
7474491 Liikanen et al. Jan 2009 B2
7477471 Nemshick et al. Jan 2009 B1
7480116 Bennett Jan 2009 B1
7489464 McNab et al. Feb 2009 B1
7492546 Miyamura Feb 2009 B1
7495857 Bennett Feb 2009 B1
7499236 Lee et al. Mar 2009 B1
7502192 Wang et al. Mar 2009 B1
7502195 Wu et al. Mar 2009 B1
7502197 Chue Mar 2009 B1
7505223 McCornack Mar 2009 B1
7542225 Ding et al. Jun 2009 B1
7545593 Sun et al. Jun 2009 B1
7548392 Desai et al. Jun 2009 B1
7551390 Wang et al. Jun 2009 B1
7558016 Le et al. Jul 2009 B1
7573670 Ryan et al. Aug 2009 B1
7576941 Chen et al. Aug 2009 B1
7580212 Li et al. Aug 2009 B1
7583470 Chen et al. Sep 2009 B1
7595954 Chen et al. Sep 2009 B1
7602575 Lifchits et al. Oct 2009 B1
7616399 Chen et al. Nov 2009 B1
7619844 Bennett Nov 2009 B1
7626782 Yu et al. Dec 2009 B1
7630162 Zhao et al. Dec 2009 B2
7639447 Yu et al. Dec 2009 B1
7656604 Liang et al. Feb 2010 B1
7656607 Bennett Feb 2010 B1
7660067 Ji et al. Feb 2010 B1
7663835 Yu et al. Feb 2010 B1
7675707 Liu et al. Mar 2010 B1
7679854 Narayana et al. Mar 2010 B1
7688534 McCornack Mar 2010 B1
7688538 Chen et al. Mar 2010 B1
7688539 Bryant et al. Mar 2010 B1
7697233 Bennett et al. Apr 2010 B1
7701661 Bennett Apr 2010 B1
7710676 Chue May 2010 B1
7715138 Kupferman May 2010 B1
7729079 Huber Jun 2010 B1
7733189 Bennett Jun 2010 B1
7746592 Liang et al. Jun 2010 B1
7746594 Guo et al. Jun 2010 B1
7746595 Guo et al. Jun 2010 B1
7760461 Bennett Jul 2010 B1
7800853 Guo et al. Sep 2010 B1
7800856 Bennett et al. Sep 2010 B1
7800857 Calaway et al. Sep 2010 B1
7839591 Weerasooriya et al. Nov 2010 B1
7839595 Chue et al. Nov 2010 B1
7839600 Babinski et al. Nov 2010 B1
7843662 Weerasooriya et al. Nov 2010 B1
7852588 Ferris et al. Dec 2010 B1
7852592 Liang et al. Dec 2010 B1
7864481 Kon et al. Jan 2011 B1
7864482 Babinski et al. Jan 2011 B1
7869155 Wong Jan 2011 B1
7876522 Calaway et al. Jan 2011 B1
7876523 Panyavoravaj et al. Jan 2011 B1
7916415 Chue Mar 2011 B1
7916416 Guo et al. Mar 2011 B1
7916420 McFadyen et al. Mar 2011 B1
7916422 Guo et al. Mar 2011 B1
7929238 Vasquez Apr 2011 B1
7961422 Chen et al. Jun 2011 B1
8000053 Anderson Aug 2011 B1
8031423 Tsai et al. Oct 2011 B1
8054022 Ryan et al. Nov 2011 B1
8059357 Knigge et al. Nov 2011 B1
8059360 Melkote et al. Nov 2011 B1
8072703 Calaway et al. Dec 2011 B1
8077428 Chen et al. Dec 2011 B1
8078901 Meyer et al. Dec 2011 B1
8081395 Ferris Dec 2011 B1
8085020 Bennett Dec 2011 B1
8116023 Kupferman Feb 2012 B1
8145934 Ferris et al. Mar 2012 B1
8179626 Ryan et al. May 2012 B1
8189286 Chen et al. May 2012 B1
8213106 Guo et al. Jul 2012 B1
8254222 Tang Aug 2012 B1
8300348 Liu et al. Oct 2012 B1
8315005 Zou et al. Nov 2012 B1
8320069 Knigge et al. Nov 2012 B1
8351174 Gardner et al. Jan 2013 B1
8358114 Ferris et al. Jan 2013 B1
8358145 Ferris et al. Jan 2013 B1
8390367 Bennett Mar 2013 B1
8432031 Agness et al. Apr 2013 B1
8432629 Rigney et al. Apr 2013 B1
8451697 Rigney et al. May 2013 B1
8482873 Chue et al. Jul 2013 B1
8498076 Sheh et al. Jul 2013 B1
8498172 Patton, III et al. Jul 2013 B1
8508881 Babinski et al. Aug 2013 B1
8531798 Xi et al. Sep 2013 B1
8537486 Liang et al. Sep 2013 B2
8542455 Huang et al. Sep 2013 B2
8553351 Narayana et al. Oct 2013 B1
8564899 Lou et al. Oct 2013 B2
8576506 Wang et al. Nov 2013 B1
8605382 Mallary et al. Dec 2013 B1
8605384 Liu et al. Dec 2013 B1
8610391 Yang et al. Dec 2013 B1
8611040 Xi et al. Dec 2013 B1
8619385 Guo et al. Dec 2013 B1
8625215 Burd et al. Jan 2014 B1
8630054 Bennett et al. Jan 2014 B2
8630059 Chen et al. Jan 2014 B1
8634154 Rigney et al. Jan 2014 B1
8634283 Rigney et al. Jan 2014 B1
8643976 Wang et al. Feb 2014 B1
8649121 Smith et al. Feb 2014 B1
8654466 McFadyen Feb 2014 B1
8654467 Wong et al. Feb 2014 B1
8665546 Zhao et al. Mar 2014 B1
8665551 Rigney et al. Mar 2014 B1
8670206 Liang et al. Mar 2014 B1
8687312 Liang Apr 2014 B1
8693123 Guo et al. Apr 2014 B1
8693134 Xi et al. Apr 2014 B1
8699173 Kang et al. Apr 2014 B1
8711027 Bennett Apr 2014 B1
8717696 Ryan et al. May 2014 B1
8717699 Ferris May 2014 B1
8717704 Yu et al. May 2014 B1
8724245 Smith et al. May 2014 B1
8724253 Liang et al. May 2014 B1
8724524 Urabe et al. May 2014 B2
8737008 Watanabe et al. May 2014 B1
8737013 Zhou et al. May 2014 B2
8743495 Chen et al. Jun 2014 B1
8743503 Tang et al. Jun 2014 B1
8743504 Bryant et al. Jun 2014 B1
8749904 Liang et al. Jun 2014 B1
8760796 Lou et al. Jun 2014 B1
8767332 Chahwan et al. Jul 2014 B1
8767343 Helmick et al. Jul 2014 B1
8767354 Ferris et al. Jul 2014 B1
8773787 Beker Jul 2014 B1
8779574 Agness et al. Jul 2014 B1
8780473 Zhao et al. Jul 2014 B1
8780477 Guo et al. Jul 2014 B1
8780479 Helmick et al. Jul 2014 B1
8780489 Gayaka et al. Jul 2014 B1
8792202 Wan et al. Jul 2014 B1
8797664 Guo et al. Aug 2014 B1
8804267 Huang et al. Aug 2014 B2
8824081 Guo et al. Sep 2014 B1
8824262 Liu et al. Sep 2014 B1
20040109253 Nishiyama et al. Jun 2004 A1
20070139809 Liikanen et al. Jun 2007 A1
20100035085 Jung et al. Feb 2010 A1
20100265611 Jun Oct 2010 A1
20120162806 Champion et al. Jun 2012 A1
20120284493 Lou et al. Nov 2012 A1
20120307400 Kawabe Dec 2012 A1
20130120870 Zhou et al. May 2013 A1
20130148240 Ferris et al. Jun 2013 A1
Non-Patent Literature Citations (4)
Entry
Daniel J. Gunderson, et al., U.S. Appl. No. 13/246,600, filed Sep. 27, 2011, 17 pgs.
Wei Xi , et al., U.S. Appl. No. 13/911,365, filed Jun. 6, 2013, 20 pages.
Office Action dated Apr. 24, 2014 from U.S. Appl. No. 13/911,365, 15 pages.
Notice of Allowance dated Sep. 9, 2012 from U.S. Appl. No. 13/911,365, 46 pages.