Control systems are often used to position a control object. Such control systems often utilize servo data in the form of positional indicia to detect the position of the control object. Depending on the configuration of the control system, the positional indicia can include both radial and angular values.
For example, in some data storage devices the servo data are embedded onto recording surfaces of rotatable storage media to define a number of adjacent concentric tracks (cylinders). User data are stored in data sectors defined along the tracks. A suitable addressing scheme is employed to enable a servo control circuit to identify the physical location of each of the various sectors, so that the transducer can be moved thereto to carry out a requested data I/O operation.
The servo data can indicate radial position such as in terms of identifying a particular track address, and angular position such as along the track with respect to a once-around index (0° reference) point. A disadvantage of some existing control systems, however, is the inability to decode the angular position until the index point is actually reached.
In accordance with various embodiments, an angular location of a first servo field along an annular track is determined in relation to a difference between a first code value of the first servo field and a second code value of a second servo field along the track. A radial location of the track is obtained in relation to the determined angular location of the first servo field.
The device 100 includes a housing 102 formed from a base deck 104 and top cover 106. An internally disposed spindle motor 108 is configured to rotate a number of storage media 110. The media 110 are accessed by a corresponding array of data transducers 112. While
A head-stack assembly (“HSA” or “actuator”) is shown at 114. The actuator 114 preferably rotates through application of current to a voice coil motor (VCM) 116. Controlled operation of the VCM 116 causes the transducers 112 to align with tracks defined on the media surfaces to store data thereto or retrieve data therefrom.
A flex circuit assembly 118 provides electrical communication paths between the actuator 114 and device control electronics on an externally disposed printed circuit board (PCB) 119. The flex circuit assembly 118 preferably includes VCM signal paths to accommodate the application of current to the VCM 116, and I/O signal paths to accommodate the transfer of write data to the media 110 and readback data from the media 110, respectively.
The preamp circuit 122 preamplifies and filters the readback signals from the transducer 112, and provides the processed servo data to a demodulation (demod) circuit 124. The demod circuit 124 is preferably disposed on the device PCB 119, and operates to detect and condition the servo data, including application of automatic gain control (AGC) and conversion of the signals to digital form.
A servo controller 126 processes the digitized servo data to generate a current command signal that is supplied to a motor driver circuit 128. In response, the driver circuit 128 applies the appropriate current to the VCM 116 to position the transducer 112.
The servo controller 126 is preferably characterized as a programmable processor with associated servo code to direct the operation of the servo loop, although the controller can take other forms such as being partially or fully realized in hardware. The controller 126 generally operates in two primary modes, seeking and track following. Seeking generally involves controlled movement of the selected transducer 112 from an initial track to a destination track. Track following generally comprises operation of the controller 126 to maintain the selected transducer 112 over the center (or other commanded position) a selected track in order to carry out data I/O operations with the track.
An exemplary data track is shown at 132. The data track 132 circumferentially extends about the medium, preferably in the form of a concentric circle although the track could alternatively form a portion of a spiral. As shown in
The servo field 136 is shown in
As explained below, an angular/radial (A/R) code pattern field 144 provides A/R codes to enable the servo circuit 120 to decode both angular and radial location of the associated field 136. A burst pattern field 146 includes a succession of radially extending dibit patterns (e.g., AB, ABCD, ABCDEF, etc.) to provide intra-track positional alignment. A read zero acceleration path (ZAP) field 148 and a write ZAP field 150 respectively store compensation values that are used by the servo circuit 120 during servo processing to reduce the effects of repeated runout (RRO) error associated with misalignments of the burst patterns.
As will be recognized, some prior art servo systems utilize an index field to provide once-around index reference point identification, and a Gray code (GC) field to provide an encoded track address value. While operable, a disadvantage of this approach is that although the radial location can be immediately determined once the transducer reaches a particular track, the angular location generally remains unknown until the once-around index point is actually reached. This can require a latency period during which the system waits for the medium to rotate adjacent the transducer until the index point is detected, and this latency delays the ability of the system to proceed with an I/O operation upon data sectors on the track.
While such systems can utilize a separate manager function to continually count the servo wedges and thus keep track of how many wedges “to go” until index, this information is not always available upon an initialization or calibration operation. Thus, each time the device is initialized, as well as each time during operation that the index is not properly decoded (due to an error, misalignment, head switch, etc.), it may be necessary to endure this latency period before the system can be resynchronized and normal processing resumed.
By contrast, the A/R codes of field 144 are preferably selected to provide absolute decoding of both angular and radial values for the associated servo field 136 after reading as few as any two successive servo fields along the track 132. Preferably, the A/R codes along a given track are different for each field 144 along that track. Angular location of a selected field is preferably determined in relation to a difference between two successive A/R codes, and the radial location is decoded from the decoded angular position.
At step 202, an initial format for the device is selected in terms of the number of cylinders (tracks) and the number of servo sectors (wedges) for each recording surface. The values can take any suitable numbers as desired, but for purposes of the present example it will be contemplated that the total number of cylinders is several hundred thousand (e.g., 300,000), and the total number of wedges is in the hundreds (e.g., 200).
At step 204, a suitable encoding function is selected. While a number of alternative exemplary functions will be set forth below, for purposes of the present example a simple encoding function is given as:
CODE(n,k)=CYL(n)+K*(SEC(k))(SEC(k+1)) (1)
where CODE is the A/R code value for a particular field 144, CYL is the sequential cylinder no. (with n from 1 to 300,000), SEC is the sector, or wedge no. (with k from 1 to 200), and K is a constant. K can take any suitable value, but is preferably a power of 2 for computational efficiency. For purposes of providing a simplified example, it will be contemplated that K is set equal to two (K=2).
The code values are next generated at step 206. This preferably entails a stepwise computation through each cylinder 132, and each servo field 136 of each cylinder, using the associated CYL and SEC values. The code values can be generated offline or on-the-fly by the servo controller 126 or other mechanism. At step 208, the values determined during step 206 are written to the respective fields 144 during a suitable STW process.
From the data in
CODE(1000, 1)=1000+(2)(1)(2)=1000+4=1004 (2)
whereas the code value for the servo field 136 at cylinder 1001, servo sector 199 is generated as:
The code value for the servo field 136 at cylinder 1002, servo sector 200 is generated as:
and so on. It will be appreciated that the various values in table 210 are represented in base 10 format; the corresponding values are each preferably written to the fields 144 as a multi-bit logical (e.g., base 2) sequence. Additional encoding such as run length limiting (RLL) encoding can be applied to the values represented in table 210 to enhance fault tolerance and data recovery. The total bit-size of the A/R code pattern fields 144 will be selected to accommodate the largest encoded code value(s). It is contemplated that in most cases, the fields 144 will have a size that is equal to or less than the size of a conventional GC field for a particular device (e.g., 16 bits or less).
The angular location (position) in terms of sector no. is preferably decoded from any two adjacent code values from
SEC(k)=(CODE(n,k)−CODE(n,k−1))/(2*K) (5)
Where SEC(k) is the particular servo sector 136 in question, CODE(n,k) is the code value from that servo sector, CODE(n,k−1) is the previously read code value from the immediately preceding servo sector on the associated track, and K is the constant from equation (1). By way of illustration, the respective code values at (1000:2) and (1000:3) in
SEC(k)=(1024−1012)/(2*2)=12/4=3 (6)
In other words, the servo sector with CODE=1024 is affirmatively identified as servo wedge no. 3, or the second wedge after the index. Similar decoding can be readily determined for each of the remaining pairs of servo fields on the device.
In the present example, the simplified function of equation (1) does not necessarily produce excessively large code values. Nevertheless, a suitable rounding (modulo) function can be applied to the code values in equation (5) to strip off the unnecessary larger order bits and reduce complexity of the processing effort.
Once the angular location is known, the radial location (e.g., cylinder no.) is readily determined as:
CYL(n)=CODE(n,k)−K*(SEC(k))(SEC(k+1)) (7)
Where as before, CODE is the code value for a selected servo field 136 at wedge no. SEC(k), and SEC(k+1) is the subsequent wedge number. Using the example from equation (6) above, after having determined for the selected servo field 136 a code value of 1024 and a wedge no. of 3, equation (7) provides:
CYL(n)=1024−(2)(3)(4)=1024−24=1000 (8)
From the table 210 of
To the extent that any ambiguities arise from a given encoding scheme, additional pairs of servo fields can be sampled during the decoding process to confirm the accuracy of the decoded angular and radial locations. For example, a second angular location for the second servo field can be determined using the second code value and the next (third) code value, etc.
A review of the exemplary table 210 of
The code values are used to identify angular location at step 224 such as in accordance with equation (5), and the angular location is used at step 226 to determine the radial location such as in accordance with equation (7). As indicated at step 228, the detected angular and/or radial locations can further be used as desired to initiate or confirm tracking thereof by a separate manager of the servo circuit, as set forth by
At such point, processed read signals are supplied to a code detection block 230 from the demod circuitry 124 (
The block 230 generally operates to identify the CODE1 and CODE2 values from the supplied signals. This operation may include the application of RLL decoding or other processing as required.
The decoded CODE1 and CODE2 values are supplied to an angular position detection block 232 which identifies an angular position of the associated servo field 136. As discussed above, the angular position is preferably expressed as a particular wedge no. in which the servo field 136 is disposed.
This information is provided to a radial position detection block 234 which identifies a radial position of the associated servo field 136 therefrom. As before, the radial position is preferably expressed as the particular cylinder in which the servo field 136 is disposed; that is, the block 234 preferably decodes a track address for the track being followed.
In a preferred embodiment, the block 232 further outputs a signal indicative of the number of wedges “to go” until the index reference point is reached. In the above example, if the wedge no. is found to be 3, then at this point the system knows that there are 200−3=197 wedges to go before the once-around index point reaches the transducer. However, since the absolute value is known now, it is not necessary to endure a rotational latency period which the system waits until index is reached before I/O operations commence.
Accordingly, the wedges to go value can be used by the manager to provide servo tracking. While a number of solutions can be used, in
It will be appreciated that the foregoing embodiments preferably eliminate the need to provide separate index and GC (or other track addressing) fields. This, along with a reduction in the size of the A/R code pattern fields, reduces overhead and expands the media space available to store user data.
However, in an alternative preferred embodiment, a separate index bit is maintained and used (either as part of the A/R field 144 or another field in the servo wedges 130) in a nominally conventional fashion to provide an independent once-around index detection mechanism. In such case, an index counter such as at 238 can operate based on the detection of the index pulses while a separate counter or other circuitry can provide an independent index indication using the routine of
As mentioned above, any number of other encoding/decoding schemes can be utilized in lieu of the exemplary scheme of equations (1), (5) and (7). For example, one alternative encoding scheme can be expressed as:
If (SEC(k) &1), then CODE(n,k)=CYL(n)+K*SEC(k) else CODE(n,k)=CYL(n) (9)
This will generally provide an incremented sequence of (0, 1, 0, 3, 0, 5 . . . ) along the track. Thereafter, during the decoding of CODE1 and CODE2 values,
If CODE(k)>CODE(k−1), then SEC(k)=CODE(k)−CODE(k−1) else SEC(k)=1+CODE(k−1)−CODE(k) (10)
Other possible encoding schemes include:
If (SEC(k) & 1), then CODE(n,k)=CYL(n)+K*SEC(k) else CODE(n,k)=CYL(n)−K*SEC(k) (11)
which generally provides an incremental sequence of (0, 1, −2, 3, −4 . . . ). Another possible encoding scheme is:
If (SEC(k) &1), then CODE(n,k)=CYL(n)+SEC(k+1)/2 else CODE(n,k)=CYL(n)−SEC(k+1)/2 (12)
which generally provides an incremental sequence of (0, −1, 1, −2, 2 . . . ). Other encoding and decoding schemes can be readily devised in view of the foregoing discussion and tailored to the requirements of a particular application.
While the various preferred embodiments discussed herein have generally been embodied in the environment of a data storage device that controls a transducer adjacent a storage medium, such is not limiting as the disclosed subject matter can have any number of practical applications in other types of control systems. The term “track” will accordingly be understood broadly to describe a trajectory associated with a control object, irrespective of whether data are, or can be, stored therealong.
It is to be understood that even though numerous characteristics and advantages of various embodiments of the present invention have been set forth in the foregoing description, together with details of the structure and function of various embodiments of the invention, this detailed description is illustrative only, and changes may be made in detail, especially in matters of structure and arrangements of parts within the principles of the present invention to the full extent indicated by the broad general meaning of the terms in which the appended claims are expressed.
Number | Name | Date | Kind |
---|---|---|---|
4977472 | Volz et al. | Dec 1990 | A |
5253131 | Chevalier | Oct 1993 | A |
5737145 | Jung | Apr 1998 | A |
5828508 | Whaley et al. | Oct 1998 | A |
6038097 | Le et al. | Mar 2000 | A |
6104558 | Greenberg et al. | Aug 2000 | A |
6108150 | Lee | Aug 2000 | A |
6304398 | Gaub et al. | Oct 2001 | B1 |
6404582 | Rodrigues de Miranda | Jun 2002 | B1 |
7106686 | Nishiuchi et al. | Sep 2006 | B2 |
7110202 | Vasquez | Sep 2006 | B1 |
7242546 | Ooi et al. | Jul 2007 | B2 |
RE39809 | Holsinger et al. | Sep 2007 | E |
RE39831 | Le et al. | Sep 2007 | E |
20060133232 | Carson | Jun 2006 | A1 |
Number | Date | Country | |
---|---|---|---|
20090059777 A1 | Mar 2009 | US |