In certain embodiments, a method includes determining an error while attempting to read certain data sectors in a first data track while following a first path, estimating an offset position of each of the certain data sectors, and generating a second path for a read transducer to follow to read data from the certain data sectors based, at least in part, on the estimated offset position.
In certain embodiments, hard disk drive includes a magnetic recording medium comprising data sectors along a data track, a read/write head comprising a read transducer, and an integrated circuit including circuitry. The circuitry is programmed to: determine, in connection with a first path, respective read errors associated with N number of the data sectors; estimate respective offset positions of the N number of the data sectors; and generate a second path based, at least in part, on the respective estimated offset positions.
In certain embodiments, a system-on-a-chip includes a read/write channel and a servo controller. The read/write channel is configured to: determine, in connection with a first path, respective read errors associated with N number of the data sectors; estimate respective offset positions of the N number of the data sectors; and generate a second path based, at least in part, on the respective estimated offset positions. The servo controller is configured to cause adjustment of a position of a read transducer based on the second path.
While multiple embodiments are disclosed, still other embodiments of the present invention will become apparent to those skilled in the art from the following detailed description, which shows and describes illustrative embodiments of the invention. Accordingly, the drawings and detailed description are to be regarded as illustrative in nature and not restrictive.
While the disclosure is amenable to various modifications and alternative forms, specific embodiments have been shown by way of example in the drawings and are described in detail below. The intention, however, is not to limit the disclosure to the particular embodiments described but instead is intended to cover all modifications, equivalents, and alternatives falling within the scope of the appended claims.
When hard disk drives are initially unable to successfully read data from data sectors on a magnetic recording medium, hard disk drives identify the error and try to read the missed data sectors again. This process of identifying the error and then re-reading the missed data sectors is sometimes called error recovery. Re-reading the missed data sectors can be challenging because one common cause for missing data sectors is that the missed data sectors may be misaligned or offset from the center of the data track. As such, following the same path along the center of the data track may result in missing the same data sectors again. Certain embodiments of the present disclosure are accordingly directed to methods and devices for error recovery.
The data storage device 100 includes an interface 108 (e.g., an input/output interface) for transferring data to and from the data storage device 100. For example, the interface 108, among other features, can be communicatively coupled between a host 10 (e.g., a laptop, a personal computer, or a data storage system such as a server) and the read/write heads 104A and 104B to facilitate communication, using a standardized communication protocol (e.g., SATA, SAS, SCSI), between the read/write heads 104A and 1046 and the host 10.
The data storage device 100 can include a system on a chip (“SOC”) 110 (shown in dashed lines) that includes a system controller 112, which can include a controller processor 114 (e.g., a microprocessor), a servo processor 116 (e.g., a microprocessor), and memory 118 coupled to the controller processor 114 and the servo processor 116. The SOC 110 can include multiple distinct banks of memory. For example, one bank of memory 118 can be dedicated to the controller processor 114 and its functions while another bank of memory 118 can be dedicated to the servo processor 116 and its functions (e.g., the memory 118 and the servo processor 116 together functioning as a servo controller 126). The interface 108 may also be part of the SOC 110.
The SOC 110 can also include one or more read/write channels 120A and 120B, which encode and decode data associated with write commands and with read commands. The SOC 110 may be an integrated circuit such as an application-specific integrated circuit (“ASIC”) and field-programmable gate array (“FPGA”) that includes instructions (e.g., in the form of firmware) for carrying out various functions of the data storage device 100. For example, the SOC 110 can include circuitry to control and carry out various aspects of the data storage device 100 as described in more detail below. Although the interface 108, system controller 112, etc., are shown as being part of a single SOC, the components and their functions can be distributed among several integrated circuits. The system controller 112 can be coupled to and control access to a buffer 122, which can temporarily store data associated with read commands and write commands. The buffer 122 can be a volatile memory, such as a dynamic random access memory (“DRAM”), static random access memory (“SRAM”), or other volatile memory.
During operation, the data storage device 100 receives various data transfer commands (e.g., a read command or a write command) from the host 10. Data associated with a write command may be received from the host 10 by the interface 108 and initially stored to the buffer 122. The data is encoded or otherwise processed by respective read/write channels 120A or 120B and eventually stored to the magnetic recording media 106 via one of the read/write heads 104A or 1046 coupled to the respective first actuator 102A or the second actuator 102B. Data associated with a read command may be retrieved from the magnetic recording media 106, processed by one of the read/write channels 120A or 120B, and stored in the buffer 122. Such data is then transferred to the host 10 by the interface 108. In certain embodiments, the servo processor 116 controls operations of respective pre-amplifiers 124A and 124B, which provide signals to the respective read/write heads 104A and 104B for writing magnetic transitions to the magnetic recording media 106 and for receiving signals from the respective read/write heads 104A and 104B in response to detecting magnetic transitions written to the magnetic recording media 106.
The data storage device 100 includes a servo controller 126 (schematically shown in more detail in
As shown in
The VCM assemblies 136A and 136B are used to position (e.g., rotate) the actuators 102A and 1026 to position the read/write heads 104A and 1046 over a desired data track on the magnetic recording media 106 for data reading and data writing operations. For example, in response to a command to read data from or write data to a data track located a certain distance away from where a respective read/write head 104A or 104B is currently positioned (i.e., a track-seeking operation), a current may be supplied by the power supply 138 and applied to the voice coil of the respective VCM assemblies 136A and 136B to rotate the respective actuators 102A and 102B (and therefore the respective read/write heads 104A and 104B) towards the desired data track. The applied current through the coil generates a magnetic field that interacts with magnets of the VCM assemblies 136A and 136B. The applied current may follow a current profile determined by and commanded by the servo processor 116. As the respective read/write heads 104A and 1046 near the desired data track, less current is applied to the VCM assemblies 136A and 1366 such that the read/write heads 104A and 1046 begin to settle over the desired data track (i.e., a track-settling operation). Once the respective read/write heads 104A and 104B are positioned over the desired data track, the servo control system 126 compensates for small positioning errors (i.e., a track-follow operation) to keep the desired read/write heads 104A and 104B over the desired data tracks on the magnetic recording medium 106 during a read operation or a write operation.
The tracks of the magnetic recording medium 106 can include user data regions 142 and servo data regions 144 (which are sometimes referred to as servo wedges) positioned between the user data regions 142. The servo wedges 144 extend radially between an inner diameter 146 and an outer diameter 148 of the magnetic recording medium 106. Data on the magnetic recording media 106 is stored on data tracks which extend circumferentially around the top/bottom surfaces of each magnetic recording medium 106. The portion of the data tracks in the user data regions 142 store user data, and the portion of the data tracks in the servo wedges 144 are comprised of individual servo sectors 150 (some of which are shaded in
Servo data is written to both sides of the magnetic recording medium 106 by, for example, a servo writer or disk writer before the magnetic recording medium 106 is installed in the data storage device 100 or by the data storage device 100 itself using a process referred to as self-servo track writing (SSW) or concentric SSW process. SSW may include using the electronics (e.g., the SOC 110) of the data storage device 100 to write the concentric servo sectors independent of an external servo writer.
The read/write channels 120A and 120B, the preamplifiers 124A and 124B, and various components of the system controller 112 operate so that the servo data read by the read/write heads 104A and 1046 can be processed and used by the data storage device 100 to maintain proper positioning of the read/write heads 104A and 1046.
As shown in
In
Some reread approaches involve offsetting the read/write head a pre-determined amount in a positive direction or negative direction, attempting to reread the failed data sectors, offsetting the read/write head in an opposite direction, and again attempting to reread the failed data sectors. However, this approach takes multiple revolutions of the magnetic recording medium and still may not result in successful reading of the failed data sectors.
The description below outlines approaches for retrying to read data of failed data sectors in a single revolution and/or with an increased chance of success. In short, a customized path (e.g., trajectory) for the read transducer of the read/write head is generated based on estimated read offsets of each failed data sector. This customized path attempts to more closely align the read transducer with centerlines of the failed data sectors.
Using the
The SOC 110 of the data storage device 100 may determine that certain data sectors 162 were not successfully read. These missed data sectors 162 can be distributed throughout the data track 158. For example, as shown in
Once the SOC 110 detects a missed data sector 162, the SOC 110 may determine that a read error has occurred and initiate one or more error recovery routines. One of the error recovery routines can include estimating an offset position of each of the missed data sectors 162. In certain embodiments, the estimated offset position includes a direction (e.g., positive or negative radial direction with respect to the centerline 160) and an offset amount. The offset amount can be determined in terms of a percentage of a pitch of the data track 158. The offset amount can attempt to estimate a difference between the centerline 160 of the data track 158 and respective centerlines of the missed data sectors 162. Separate offset positions can be estimated for each missed data sector 162.
In certain embodiments, the offset positions of the missed data sectors 162 are estimated based on information collected during the first attempt. For example, the offset positions can be based, at least in part, on a position error signal generated during the first attempt at reading the data sectors 162.
In some embodiments, the offset positions of the missed data sectors 162 are estimated based on information collected during a subsequent attempt at reading the data sectors 162. This subsequent attempt may be a read-retry operation initiated once a read error is detected. Waiting until the subsequent read attempt can help address errors caused by factors such as seek-settle effects. However, waiting may increase the overall time consumed by the error recovery process.
In certain embodiments, the offset positions of the missed data sectors 162 are estimated based on information collected either during the first attempt or during subsequent attempt at reading the data sectors 162—depending on certain factors. As one example, when an error is detected while carrying out a sequential read (during which seek-settle effects are limited), the offset positions may be estimated using information collected during the first read attempt rather than a subsequent read attempt. Another example involves using information from the first read attempt when the detected error is associated with a data sector positioned in the last half (e.g., second semicircle) of the data track 158. In this example, the read-write head is likely to have settled by the time the later data sector is read, so the information collected during first attempt is not largely affected by seek-settle issues.
U.S. patent application Ser. No. 17/410,840 (filed Aug. 24, 2021) and Ser. No. 17/466,327 (filed Sep. 3, 2021) describe approaches for estimating offset positions and are hereby incorporated by reference for such purposes. U.S. patent application Ser. No. 17/466,327 (filed Sep. 3, 2021) is also hereby incorporated by reference for purposes of disclosing embodiments featuring read/write heads with multiple read transducers.
As shown in
In certain embodiments, the new path 164 can be generated by creating a path that passes through N points, where N is the number of missed data sectors 162. In the example of
In certain situations, even if the new path 164 is followed, some data sectors 162 will be missed again and should be attempted to be read again. Using one approach, a second new path is generated and is designed to pass over the centerlines of the data sectors 162 that remain unread. As such, the data sectors 162 that were successfully recovered using the new path 164 do not contribute to generating the second new path.
In certain situations, adjacent missed data sectors 162 have estimated offset positions that are too far apart for a read/write head to successfully move from one data sector centerline to the next centerline in time. These disparate offset positions may be a result of the data sectors being written during different write commands. Another possible cause is that the centerline of a data sector can be “pushed” as a result of writing a data sector on a data track that is adjacent to the data sector of interest. In these situations, the SOC can apply additional techniques.
One technique involves creating two new paths where a first new path is designed to pass over centerlines of a first set of missed data sectors and a second new path is designed to pass over centerlines of a second set of missed data sectors. These sets of missed data sectors can be mutually exclusive sets. Two sets can be grouped by the similarity of their estimated offset position and/or how closely spaced adjacent missed data sectors are from each other. The first new path is used during one revolution of the magnetic recording medium while the second new path is used during another revolution of the magnetic recording medium.
Another technique involves applying one or more constraints when generating the new path 164. One example constraint involves generating a path that minimizes—over all missed data sectors 162—the squared error between the estimated offset position and points along the actual generated path. Another example constraint involves applying minimums and maximums such as a maximum radial offset per length along the data track 158.
In certain embodiments, the new path 164 can be generated based on calculating the average of the individual estimated offset positions of the missed data sectors 162. The description below outlines details for using averages.
Equation 1 below describes the new path 164 (denoted by T0) as a function of the initial set of missed data sectors 162 (denoted by F0) and individual estimated offset positions (denoted by R0):
T0=f(F0,R0) (1)
Given the initial set of missed data sectors—F0={f0,1, f0,2, . . . , f0,N0}—and corresponding estimated offset positions—R0={r0,1, r0,2, . . . , r0,N0}—the SOC generates the new path 164 which is intended to pass the read transducer over each of the missed data sectors at the estimated offset position. Ideally, T0 would equal R0. However, if constraints are used when generating the new path 164, T0 will not equal R0.
As noted above, when the read transducer follows the new path 164, some of the initially missed data sectors may be missed again. A second new path can be generated based on the remaining missed data sectors and estimated offset positions: F1={f1,1, f1,2, . . . , f1,N1} and R1={r1,1, r1,2, . . . r1,N1}.
Although two estimates offset positions have been calculated for each remaining missed data sector, averaging the two positions may not be helpful because the position of the read transducer has been modified between the first read operation and the first reread operation. However, because the modified position is known (e.g., from the new path, T0), the modified position can be used to calculate an average estimated offset position, denoted as G1 in equation 2 below. The remaining missed data sectors will be associated with an f0 and f1 with estimated offset positions r0 and r1 and an actual offset T0 when r1 information was collected. Therefore, an average for each remaining missed data sector can be made using (r0+(r1−t0))/2. The averaged estimated offset positions can be used to generate a second new path:
T1=f(F1,G1) (2)
This concept can be extended to the kth revolution:
Tk=f(Fk,Gk) (3)
As such, the SOC can use averaging to generate updated paths for attempting to recover data from remaining missed data sectors.
Various modifications and additions can be made to the embodiments disclosed without departing from the scope of this disclosure. For example, while the embodiments described above refer to particular features, the scope of this disclosure also includes embodiments having different combinations of features and embodiments that do not include all of the described features. Accordingly, the scope of the present disclosure is intended to include all such alternatives, modifications, and variations as falling within the scope of the claims, together with all equivalents thereof.
Number | Name | Date | Kind |
---|---|---|---|
6046870 | Karube | Apr 2000 | A |
6252731 | Sloan et al. | Jun 2001 | B1 |
6538839 | Ryan | Mar 2003 | B1 |
6754030 | Seng et al. | Jun 2004 | B2 |
7088535 | Kim et al. | Aug 2006 | B2 |
7136244 | Rothberg | Nov 2006 | B1 |
7215494 | Wang et al. | May 2007 | B2 |
7813069 | Evans et al. | Oct 2010 | B2 |
7920350 | Au et al. | Apr 2011 | B2 |
8059353 | Chen | Nov 2011 | B1 |
8116025 | Chan et al. | Feb 2012 | B1 |
8149529 | Mathew et al. | Apr 2012 | B2 |
8929019 | Tagami et al. | Jan 2015 | B2 |
9236099 | Alhussien et al. | Jan 2016 | B2 |
9613652 | Link et al. | Apr 2017 | B2 |
9875763 | Jury et al. | Jan 2018 | B1 |
9928872 | Jury | Mar 2018 | B1 |
10014026 | Wu et al. | Jul 2018 | B1 |
10192570 | Kawabe et al. | Jan 2019 | B2 |
10607648 | Wu et al. | Mar 2020 | B1 |
10748568 | Chahwan | Aug 2020 | B1 |
10867633 | Liu et al. | Dec 2020 | B1 |
11018842 | Bellorado et al. | May 2021 | B1 |
20020089778 | Shimokoshi et al. | Jul 2002 | A1 |
20030202268 | Wang et al. | Oct 2003 | A1 |
20180240483 | Nylander-Hill | Aug 2018 | A1 |