Embodiments in accordance with he present invention relate to a disk drive apparatus and a method for writing and/or reading user data thereof. More particularly, the present invention relates to clock frequency control according to a timing of detecting a servo sector.
An aspect of embodiments in accordance with the present invention is a method for writing and/or reading user data on a rotating recording surface having a plurality of servo sectors separately arranged in the circumferential direction and a plurality of data areas for user data storage between the plurality of servo sectors. This method comprises the steps of estimating a detection timing of the next adjacent servo sector using a difference between an actual detection timing and an expected detection timing of a servo sector that has been already detected; controlling a clock frequency according to the detection timing of the next expected servo sector; and writing and/or reading user data between current servo sector and the next adjacent servo sector according to a clock signal having the above-mentioned controlled frequency. This makes it possible to easily and effectively perform clock control and write and/or read user data according to a rotational jitter on the recording surface.
To ensure easy stable control, the detection timing of the next adjacent servo sector may be expected using an integral term of a difference between an actual detection timing and an expected detection timing of plural servo sectors which have already been detected. Further, the detection timing of the next adjacent servo sector may be expected using an integral term of a difference between an actual detection timing and an expected detection timing of plural servo sectors which have already been detected and a difference term between the actual detection timing and expected detection timing of the current servo sector. Further, the detection timing of the next adjacent servo sector may be expected using an integral term of a difference between an actual detection timing and an expected detection timing of plural servo sectors which have already been detected, a difference term between the actual detection timing and the expected detection timing of the current servo sector, and a differential term of the difference between the actual detection timing and the expected detection timing of the current servo sector, and a difference between an actual detection timing and an expected detection timing of immediately previous servo sector which has been detected.
Whether user data can be written or not may be determined based on the above-mentioned expected detection timing. This makes it possible to prevent user data from being written onto a wrong position when a rotational jitter component is large.
A disk drive apparatus concerning another aspect of the present invention comprises: a motor which rotates a disk having a plurality of servo sectors separately arranged in the circumferential direction and a plurality of data areas for user data storage between the plurality of servo sectors; a controller which expects a detection timing of next adjacent servo sector using a difference between an actual detection timing and an expected detection timing of a servo sector which has already been detected; a clock generation circuit which generates a clock signal having a frequency controlled according to the detection timing of the next expected servo sector; and a head which writes and/or reads user data between current servo sector and the next adjacent servo sector according to a clock signal having the above-mentioned controlled frequency. This makes it possible to easily and effectively perform clock control and write and/or read user data according to a rotational jitter on the recording surface.
To ensure easy and stable control, the above-mentioned controller may expect a detection timing of the next adjacent servo sector using an integral term of a difference between an actual detection timing and an expected detection timing of plural servo sectors which have already been detected. Further, the above-mentioned controller may expect a detection timing of the next adjacent servo sector using an integral term of a difference between an actual detection timing and an expected detection timing of plural servo sectors which have already been detected and a difference term between the actual detection timing and expected detection timing of the current servo sector. The above-mentioned controller may control the above-mentioned clock frequency based on PID control using a difference between a actual detection timing and an expected detection timing of a servo sector which has already been detected.
A disk drive apparatus may further comprises a fixed clock generation circuit which generates a clock signal having a fixed frequency, wherein the above-mentioned controller measures a detection timing of each servo sector by use of the clock signal having the above-mentioned fixed frequency. This makes it possible to effectively perform clock control on a small circuit scale.
A disk drive apparatus concerning still another aspect of the present invention comprises: a motor which rotates a disk having a plurality of servo sectors separately arranged in the circumferential direction and a plurality of data areas for user data storage between the plurality of servo sectors; a controller which determines a clock frequency using a multiply-and-accumulation value of detection intervals between servo sectors which have already been detected, the detection intervals being multiplied by a weighting factor that is set so that it becomes smaller for more past data; a clock generation circuit which generates a clock signal having the above-mentioned determined click frequency; and a head which writes and/or reads user data between current servo sector and the next adjacent servo sector according to the clock signal from the above-mentioned clock generator circuit. This makes it possible to easily and effectively perform clock control and write and/or read user data according to a rotational jitter on the recording surface.
The above-mentioned controller may calculate a value obtained by multiplying the multiply-and-accumulation value used to determine a clock frequency in immediately previous servo sector by a predetermined coefficient, and determines the above-mentioned clock frequency using a sum of the detection interval between current servo sector and the immediately previous servo sector, and the above-mentioned calculated value. This makes calculations easier. Further, it is preferable that the predetermined coefficient be a positive value less than one.
In accordance with embodiments of the present invention, it is possible to write and/or read user data at more accurate timing.
An embodiment of the present invention will be described hereunder using an example of a hard disk drive (HDD), a type of disk drive apparatus, with reference to the accompanying drawings. In order to clarify explanations, the following descriptions and drawings are omitted or simplified as required and, in each drawing, the same symbols are assigned to the same elements and duplicated explanations are omitted as required.
A HDD according to an embodiment controls a clock frequency so that a rotational jitter of a magnetic disk be compensated when writing and/or reading user data. The HDD expects a detection timing of next adjacent servo sector using an error between an actual detection timing and an expected detection timing of a servo sector which has already been detected. The clock frequency is controlled by use of the expected timing, and user data between current servo sector and next adjacent servo sector is written and/or read according to the clock signal.
To make it easier to understand features of the present embodiment, a general configuration of the HDD will be described first.
The HDD 1 further includes a circuit board 20 fixed to the outside of the enclosure 10. On the circuit board 20, installed are a read/write channel (R/W channel) 21, a motor driver unit 22, a hard disk controller (HDC), and a hard disk controller (HDC)/microprocessing unit (MPU) integrated circuit (hereinafter referred to as HDC/MPU) 23, and other ICs such as a RAM 24. Circuit components can be integrated in a single IC or implemented in a plurality of ICs.
User data from an external host 51 is received by the HDC/MPU 23 and then written onto the magnetic disk 11 by the head element sections 12 through the R/W channel 21 and AE 13. Further, user data stored on the magnetic disk 11 is read by the head element sections 12 and then outputted from the HDC/MPU 23 to the external host 51 through the AE 13 and R/W channel 21.
The magnetic disk 11 is fixed to the SPM 14. The SPM 14 rotates the magnetic disk 11 at a predetermined angular speed. The motor driver unit 22 drives the SPM 14 in accordance with control data from the HDC/MPU 23. The magnetic disk 11 of this example is provided with data recording surfaces on both sides, and the head element sections 12 corresponding to each recording surface are implemented.
Each head element section 12 is fixed to a slider (not shown) which is fixed to the actuator 16. The actuator 16, connected to a VCM15, rotates around a rotating shaft to move the head element sections 12 (and the slider) in the radial direction on the magnetic disk 11. The motor driver unit 22 drives the VCM 15 according to control data from the HDC/MPU 23. The head element sections 12 include a writing element which converts an electrical signal into a magnetic field according to write data to the magnetic disk 11, and a reading element which reconverts the magnetic field from the magnetic disk 11 into the electrical signal. The number of magnetic disks 11 may be one or more, and a recording surface may be formed on one side or both sides of the magnetic disk 11.
The AE 13 selects one of the head element sections 12 that performs data access, amplifies with a fixed gain a read signal reproduced by the selected head element section 12, and transmits the signal to the R/W channel 21. Further, the AE 13 transmits a record signal from the R/W channel to the selected head element section 12.
In the write process, the R/W channel 21 performs code modulation of the data supplied from the HDC/MPU 23, converts the code-modulated data into a write signal, then supplies the write signal to the AE 13. Further, in the read process, the R/W channel 21 amplifies the read signal supplied from the AE 13 to obtain a constant amplitude, extracts the read data from the acquired read signal, then performs decode processing. The decoded data is then transferred to the HDC/MPU 23. The R/W channel 21 includes a servo clock generation circuit 211 and a data clock generation circuit 212. Further, the R/W channel 21 of the present embodiment controls (performs frequency modulation of) the clock frequency of the data clock generation circuit 212 in response to a request from the HDC/MPU 23. Each of the clock generation circuits 211 and 212 will be described later herein.
The MPU in the HDC/MPU 23, a type of controller, operates according to microcodes that have been loaded into the RAM 24. As the HDD 1 starts operating, the data required for control and data processing, as well as the microcodes that operate in the MPU, is loaded from the magnetic disk 11 or a ROM (not shown) into the RAM 24. The HDC/MPU 23 performs general control of the HDD 1, in addition to necessary data processing such as interface control and servo-data-based positioning control of the head element sections 12. Clock control for reading and writing of the user data of the present embodiment is performed by the HDC/MPU 23. This point will be described later herein.
As explained with reference to
The preamble is a repetitive pattern at a certain frequency used for synchronization. The R/W channel 21 controls the servo clock generation circuit 211 for synchronization with a preamble signal read from the magnetic disk 11. Further, the R/W channel 21 controls the gain of a variable gain amplifier (not shown) to adjust the output with a specified value. The SAM is a portion which indicates the start of actual information, such as a servo track ID. The HDC/MPU 23 controls reading and writing of user data with reference to detection of the SAM.
The servo track ID indicates a position and sequence of a servo sector in the radial direction, and the servo sector number indicates a sequence of a servo sector in the circumferential direction. The burst pattern (BURST) is a signal which indicates a more precise position of a track indicated by the servo track ID. In this example, the burst pattern includes four different amplitude signals (A, B, C, and D) that are written in a zigzag fashion at slightly different circumferential positions along each servo track. Each of these bursts is a single-frequency signal having the same period as the preamble (PREAMBLE).
b) shows a part of a servo sector. Each servo sector has servo data of a plurality of servo tracks arranged in the radial direction.
With reference to detection of a SAM of a servo sector, the HDC/MPU 23 reads and writes user data between the servo sector and next adjacent servo sector. Specifically, as shown in
In the write process, the HDC/MPU 23, after receiving SAM DETECTION, starts counting the clock signal (DATA CLOCK) of the data clock generation circuit 212 to measure time. When a predetermined number has been counted, the HDC/MPU 23 asserts a control signal (WRITE GATE) to give an instruction for writing user data to the data processing unit 213. The data processing unit 213 then processes the user data according to the clock signal (DATA CLOCK) of the data clock generation circuit 212 and transfers it to the AE 13.
Likewise in the read process, the HDC/MPU 23, after receiving SAM DETECTION from the data processing unit 213, starts counting the clock signal (DATA CLOCK) of the data clock generation circuit 212 to measure time. When a predetermined number has been counted, the HDC/MPU 23 asserts a control signal (READ GATE) to give an instruction for reading user data to the data processing unit 213. The data processing unit 213 then processes the read user data according to the clock signal (DATA CLOCK) of the data clock generation circuit 212 and transfers it to the HDC/MPU 23.
If a rotational jitter of SPM 14 or disk shift causes a large difference between the frequency of the user data on the recording surface and the frequency of the data clock generation circuit 212 which is a signal processing clock used for actual read/write operation, it would be likely that user data is written onto a servo area or user data cannot be read correctly. Further, a large gap is required as a buffer area between data sectors or between a data sector and a servo sector so that the difference be absorbed.
The HDC/MPU 23 of the present embodiment controls the frequency of the data clock generation circuit 212 so that time expansion or reduction of a data area between servo sectors by a rotational jitter of the SPM 14 or disk shift be compensated. This makes it possible to prevent write/read errors of user data and reduce buffer areas required in data areas, resulting in an increase in the storage capacity of the magnetic disk 11.
In order to control the frequency of the data clock generation circuit 212, the HDD 1 of the present embodiment measures a length of each data area (interval between servo sectors), calculates how much the measured value has shifted from a specified design value, and controls the frequency of the data clock generation circuit 212 so that the shift be compensated. For this reason, the HDC/MPU 23 measures a detection timing of a SAM in each servo sector and uses a time difference of a SAM detection timing between consecutive servo sectors as a time length for the corresponding data area. It would be possible that measurement of a SAM detection timing is performed by the R/W channel 21 and the results be transferred to the HDC/MPU 23.
SAM detection time of a servo sector [i] is denoted as Ts[i], where i is a suffix which indicates the servo sector number. Further, Ds[i] indicates a time interval between SAM detection timings in adjacent servo sectors [i] and [i+1] in the circumferential direction.
Therefore, Ds[I] is expressed as following:
Ds[i]=(Ts[i+1]−Ts[i]) Expression (1)
Before disk shift occurs, SAM detection time of the servo sector [i] during normal rotation is denoted as Ts0[i]. Further, a time interval between SAM detection timings in the servo sectors [i] and [i+1] is denoted as Ds0[i]. Ideally, Ds0[i] is constant for all servo sectors in a single circumference on the magnetic disk 11. Ds0[i] is measured in the manufacturing process before shipment of the HDD 1. Specifically, the R/W channel 21 measures SAM detection time of each sector and Ds0[i] is calculated therefrom.
Typically, the R/W channel 21 measures each Ds0[i] in plural revolutions the magnetic disk 11. The HDC/MPU 23 obtains Ds0[i] for each revolution and stores each average as Ds0[i]. Data of each Ds0[i] can be saved in a management area on the magnetic disk 11 as control data. It would be possible that the HDC/MPU 23 measures Ts0[i] and Ds0[i] by use of a SAM detection signal from the R/W channel 21.
An initial frequency value of the data clock generation circuit 212 at the time of manufacture is set as f0. The HDC/MPU 23 controls the clock frequency of the clock generation circuit 211 by C_factor according to actual rotational fluctuation of the magnetic disk 11. Therefore, since the initial frequency setting or preset frequency is f0, a newly controlled frequency is represented by
(1+C_factor)*f0 Expression (2)
where C_factor is a positive or negative number near zero.
The HDC/MPU 23 controls this frequency for each servo sector. A frequency corresponding to each servo sector [i] (data area) is represented by f[i]. The HDC/MPU 23 can change the frequency of the data clock generation circuit 212 by setting a data value representing a frequency in a register in the data clock generation circuit 212.
The following describes a case when a jitter in the rotating speed of the magnetic disk 11 is caused by disk shift after shipment of the HDD 1 or a rotational jitter of the SPM 14. When SAM detection time in each servo sector is denoted as Tsm[i] and a time interval between SAM detection timings of servo sectors which are continuously detected is denoted as Dsm[i], Dsm[i] is represented by the following expression:
Dsm[i]=Tsm[i+1]−Tsm[i] Expression (3)
In the following explanation, time measurement of a servo sector is performed based on the clock signal of the servo clock generation circuit 211. The frequency of the servo clock generation circuit 211 is fixed to a constant value. By performing measurement based on the clock signal of the servo clock generation circuit 211 having a certain frequency and controlling the frequency of the data clock generation circuit 212 by means of the technique of the present embodiment, clock frequency control can effectively be performed on a small circuit size.
As mentioned above, the following relationship is satisfied in a situation of the ideal rotation.
Ds0[i]=Ts0[i+1]−Ts0[i] Expression (4)
Further, Ds0[i] is preset in the HDD 1 in the manufacturing stage. Then, an expected value of SAM detection time of a servo sector [i] is denoted as Texp[i]. Further, a timing error between the actual SAM detection time Tsm[i] and expected SAM detection time Texp[i] of the servo sector [i] is denoted as Tes[i].
Therefore, the following relationship is satisfied:
Tes[i]=Tsm[i]−Texp[i] Expression (5)
Further, at a SAM detection timing of the servo sector [i], an integral value of Tes[k] in each servo sector which has already been detected is denoted as Sumtes. Therefore, the following relationship is satisfied:
Sumtes[i]=Sumtes[i−1]+Tes[i]=ΣTes[k] Expression (6)
The HDC/MPU 23 expects SAM detection time of a servo sector [i+1] based on the following expression:
Texp[i+1]=Tsm[i]+Ds0[i]−kd*(Tes[i]−Tes[i−1)−kp*Tes[i]−ki*Sumtes[i] Expression (7)
An initial value is given by the following expression without any problem.
Texp[0]=Tsm[0], and Sumtes=0 Expression (8)
The symbols kd, kp, and ki are coefficients for a differential term (Tes[i]−Tes[i−1]), a current term (proportional term) (Tes[i]), and an integral term (Sumtes), respectively. For each of these coefficients, an appropriate value is determined according to the design for each individual product and preset in the HDD 1.
The HDC/MPU 23 determines the frequency control factor C_Factor of the data clock generation circuit 212 so that the following relationship be satisfied.
1+C_Factor[i]=Ds0[i]/(Texp[i+1]−Texp[i]) Expression (9)
Further, the frequency of the data clock generation circuit 212 satisfies a relationship which can be represented by the following expression (10):
f[i]=f0*(1+C_Factor[i]) Expression (10)
Specifically, for writing and reading user data between the servo sector [i] and servo sector [i+1], the clock frequency of the data clock generation circuit 212 is set to f[i] represented by expression (10).
Although each of above-mentioned expressions represents a detection timing of each servo sector by means of the SAM detection time thereof, an expected detection timing can likewise be represented also by the time interval from current servo sector to next adjacent servo sector. Specifically, an expected time interval from the time when the SAM of current servo sector [i] is detected to the time when the SAM of next adjacent servo sector [i+1] is detected is denoted as Dexp[i], and a timing error between an actual measurement time Dsm[i−1] and expected time Dexp[i−1] of each servo sector is denoted as Des[i−1]. Therefore, the following relationship is satisfied.
Des[i−1]=Dsm[i−1]−Dexp[i−1] Expression (11)
Des[i] can be used to determine the frequency of the data clock generation circuit 212 by means of the same technique as the above-mentioned one. Therefore, an expected time Dexp satisfies the following relationship:
Dexp[i]=Dsm[i−1]+(Ds0[i−1]−Ds0[i−2])−kd*(Des[i−1]−Des[i−2])−kp*Des[I−1]−ki*Sumdes[I−1] Expression (12)
Sumdes is defined by the following expression:
Sumdes[i−1]=Sumdes[i−2]+Des[i−1] Expression (13)
Further, an appropriate value of each coefficient is selected in design of the HDD 1.
The frequency control factor C_Factor of the data clock generation circuit 212 and the frequency thereof are determined by the following expressions:
1+C_Factor[i]−Ds0[i]/Dexp[i] Expression (14)
f[i]=f0*(1+C_Factor[i]) Expression (15)
These two techniques having different expressions perform the same operation. Specifically, the HDC/MPU 23 expects a detection timing of each servo sector and specifies an error between the expected value and actual detection timing. The HDC/MPU 23 controls the frequency of the data clock generation circuit 212 based on PID control using a detection timing error of servo sectors which have already been detected.
An example of a specific processing method of the HDC/MPU 23 and R/W channel 21 will be described hereunder. The R/W channel 21 measures a time interval between SAM detection timings, Dsm[i−1], of consecutive servo sectors based on the SAM detection time of each servo sector. The R/W channel 21 measures Dsm[i−1] by use of the clock signal of the servo clock generation circuit 211. The HDC/MPU 23 obtains each Dsm[i−1] from the R/W channel 21.
The HDC/MPU 23 expects a SAM detection timing of each of next adjacent servo sector [i+1] according to expression (12). Specifically, it derives an expected value Dexp[i] of a time interval from detected current servo sector [i] to next adjacent servo sector [i+1]. The HDC/MPU 23 controls the frequency of the data clock generation circuit 212 according to the expected value Dexp[i].
In this manner, the HDC/MPU 23 corrects an expected value of a detection timing of next adjacent servo sector using a sum (multiply-and-accumulation value) of terms which are obtained by multiplying respective coefficients of an integral term, proportional term, and differential term of a difference between an actual detection timing and an expected timing of servo sectors which have already been detected. Specifically, a frequency change factor C_factor[i] is represented as a function calculated from an error between an actual detection timing and expected timing of each servo sector (SAM) (proportional component), a sum of errors that have occurred so far (integral component), and a difference between errors between current servo sector and immediately previous servo sector (differential component).
In this manner, the HDC/MPU 23 changes a clock frequency f[i] in synchronization with the rotation of the magnetic disk 11 by controlling the frequency of the data clock generation circuit 212 according to f0*(1+C_Factor), making it possible to effectively compensate a rotational jitter of the magnetic disk 11.
To realize stable control with a low error rate, it is preferable that clock frequency control be based on the PID control using a difference between an actual detection timing and an expected detection timing of a servo sector, as mentioned above. However, it would be possible to control the clock frequency based on the PI control or integral-term-based control depending on the HDD design. From the viewpoint of the control stability, the PI control is more preferable than the integral-term-based control.
Further, as another preferable technique, it would be possible to control the frequency of the data clock generation circuit 212 by use of a measured detection interval Dsm[i−1] of each sector. Specifically, this technique multiplies the detection intervals between servo sectors which have already been detected by a weighting factor and uses a total sum of these values to control the frequency of the data clock generation circuit 212. The weighting factor is set so that it becomes smaller for more past data. Preferable calculations are represented by the following expression:
(1+C_Factor) is represented by the following expression:
1+C_Factor[i−1]=Sum[i−1]/Sum0 Expression (17)
From a time interval Ds0 between servo sectors in ideal rotation, Sum0 is represented by the following expression:
Sum0=Ds0+(½)*Ds0+(¼)*Ds0+ Expression (18)
One of advantages of this technique is that the HDC/MPU 23 is not required to hold many of past measurement data since it calculates a frequency correction factor. As shown in expression (16), the HDC/MPU 23 can calculate a frequency correction coefficient from a sum of a value obtained by multiplying Sum[i−1] calculated for immediately previous servo sector by a predetermined coefficient (½ in the above-mentioned example), and a sector interval time Dsm[i−1] identified by the detection of current servo sector. The weighting factor for each term is a positive number less than one. Further, it is preferable that the weighting factor be a power of ½, or addition or subtraction of the powers of ½. This makes it possible to easily calculate Sum through shift operation.
In one aspect, the HDC/MPU 23 can determine whether data can be written or not based on a calculated expected timing. Specifically, when an expected timing or any term representing the expected timing exceeds a predetermined tolerance range, the HDC/MPU 23 stops writing of user data. For example, the HDC/MPU 23 has a reference range with respect to Sumtes or Sumdes. The HDC/MPU 23 compares Sumtes or Sumdes with the reference range and, if Sumtes or Sumdes exceeds the reference range, it stops writing of user data. The HDC/MPU 23 can also perform the similar data write control using Sum.
Results of simulation of read/write control of the present embodiment will be described hereunder.
In
While the present invention has been described taking a preferred embodiment as an example, the invention is not limited to the above-mentioned embodiment. Persons skilled in the art can easily modify, add, and/or transform the constituent elements of the embodiment within the scope of the invention. For example, embodiments in accordance with the present invention are applicable to disk drive apparatuses using other types of disks, not limited to HDDs.
Although it is preferable that embodiments in accordance with the present invention be applied to reading and writing of user data, there is no restraint to apply the invention only to reading or writing, or to a disk drive apparatus which performs only reading. Further, although it is preferable that a detection timing of each servo sector continuously detected be used, there is no restraint to control the clock frequency for read/write operation using a part of data of servo sectors which have already been detected, as long as the HDD design is allowed.
Number | Date | Country | Kind |
---|---|---|---|
2006-115306 | Apr 2006 | JP | national |