Disk drive with improved spin-up control

Information

  • Patent Grant
  • 9147428
  • Patent Number
    9,147,428
  • Date Filed
    Monday, September 8, 2014
    10 years ago
  • Date Issued
    Tuesday, September 29, 2015
    9 years ago
Abstract
A disk drive is disclosed comprising a head actuated over a disk, and a spindle motor operable to rotate the disk. The disk drive comprises control circuitry configured to a rotation speed of the spindle motor, generate a gain as a function of the measured rotation speed, wherein the function comprises a polynomial having a degree greater than one, and spin-up the spindle motor based on the gain.
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.


A spindle motor rotates the disk (or disks) at a high speed so that the head essentially flies over the disk surface on an air bearing. When the disk drive is powered on, a spin-up operation is executed in order to spin up the disk to the operating speed before loading the head over the disk surface. It is desirable to spin up the disk as fast as possible in order to minimize the delay before a host may access the disk drive. In addition, it may be desirable to achieve a substantially consistent spin-up time across a family of disk drives so that a disk drive manufacturer may provide an accurate specification for the spin-up time, thereby enabling the design of storage systems based on the spin-up specification.





BRIEF DESCRIPTION OF THE DRAWINGS


FIGS. 1A and 1B show a disk drive according to an embodiment comprising a head actuated over a disk, and a spindle motor for rotating the disk.



FIG. 1C is a flow diagram according to an embodiment wherein a plurality of electrical cycle periods of the spindle motor are measured, at least two of the cycle periods are combined, and a rotation speed of the spindle motor is measured based on the combined cycle periods.



FIG. 1D shows an embodiment wherein the cycle periods are combined using a moving average filter that averages N consecutive electrical cycle periods of the spindle motor.



FIGS. 2A and 2B show a disk drive according to an embodiment comprising a head actuated over a disk, and a spindle motor for rotating the disk.



FIG. 2C is a flow diagram according to an embodiment wherein a spin-up gain is generated as a function of a measured rotation speed of the spindle motor, wherein the function comprises a polynomial having a degree greater than one.



FIG. 2D shows control circuitry for spinning up the spindle motor based on the spin-up gain according to an embodiment.



FIG. 2E shows a polynomial of degree greater than one for generating the spin-up gain as a function of the measured rotation speed of the spindle motor according to an embodiment.



FIGS. 3A and 3B show a disk drive according to an embodiment comprising a head actuated over a disk, and a spindle motor for rotating the disk.



FIG. 3C is a flow diagram according to an embodiment wherein a feed-forward spin-up control is generated based on a measured rotation speed of the spindle motor.



FIG. 3D shows control circuitry for spinning up the spindle motor based on the feed-forward spin-up control according to an embodiment.



FIGS. 4A and 4B show a disk drive according to an embodiment comprising a head actuated over a disk, and a spindle motor for rotating the disk.



FIG. 4C is a flow diagram according to an embodiment wherein the spindle motor is spun up based on a speed command profile that ensures a minimum spin-up time and a limited power consumption under a worst case environmental condition.



FIG. 4D shows control circuitry for spinning up the spindle motor based on the speed command profile according to an embodiment.



FIG. 4E shows an example speed command profile according to an embodiment.



FIGS. 5A and 5B show a disk drive according to an embodiment comprising a head actuated over a disk, and a spindle motor for rotating the disk.



FIG. 5C is a flow diagram according to an embodiment wherein the spindle motor is spun up over a second fraction of a spin-up time based on an initial measured rotation speed of the spindle motor.



FIG. 5D shows control circuitry for spinning up the spindle motor over the second fraction of a spin-up time according to an embodiment.



FIG. 5E shows how the second fraction of the spin-up time may be determined based on an initial measured rotation speed of the spindle motor according to an embodiment.



FIGS. 6A and 6B show a disk drive according to an embodiment comprising a head actuated over a disk, and a spindle motor for rotating the disk.



FIG. 6C is a flow diagram according to an embodiment wherein after spinning up the spindle motor, an integrator of a constant-speed controller is initialized based on a state of a spin-up controller.



FIG. 6D shows control circuitry for spinning up the spindle motor using a spin-up controller according to an embodiment.



FIG. 6E shows control circuitry for spinning the disk using a constant-speed controller after completing the spin-up operation according to an embodiment.



FIG. 7 shows control circuitry for spinning up the spindle motor using a combination of the above-described techniques according to an embodiment.





DETAILED DESCRIPTION


FIGS. 1A and 1B show a disk drive according to an embodiment comprising a head 2A actuated over a disk 4, and a spindle motor 6 operable to rotate the disk 4. The spindle motor 6 operates according to a plurality of electrical cycles over a single revolution of the spindle motor 6, where each electrical cycle spans a cycle period. The disk drive further comprises control circuitry 8 operable to execute the flow diagram of FIG. 1C, wherein a plurality of the cycle periods are measured (block 10), at least two of the cycle periods are combined (block 12), and a rotation speed of the spindle motor is measured based on the combined cycle periods (block 14).


In the embodiment of FIG. 1B, the disk surface 4A comprises a plurality of servo tracks 16 defined by servo sectors 180-18N, wherein data tracks are defined relative to the servo tracks at the same or different radial density. The control circuitry 8 processes a read signal emanating from the head 2A to demodulate the servo sectors 180-18N 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 8 filters the PES using a suitable compensation filter to generate a control signal 20 applied to a voice coil motor (VCM) 22 which rotates an actuator arm about a pivot in order to actuate the head 2A radially over the disk surface 4A in a direction that reduces the PES. The servo sectors 180-18N 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 spin-up operation, the control circuitry 8 measures a rotation speed of the spindle motor 6 which is compared to a target rotation speed of a speed command profile. A control signal 24 is generated based on the difference (error) so that the rotation speed of the spindle motor substantially follows the speed command profile until reaching the spin-up rotation speed. The performance of the spin-up operation may depend on the accuracy of the measured rotation speed of the spindle motor.


In one embodiment, the rotation speed of the spindle motor may be measured by evaluating the back electromotive force (BEMF) zero-crossings in each winding of the spindle motor. The spindle motor typically operates according to a plurality of electrical cycles over a single revolution, wherein the total number of electrical cycles depends on the number of pole-pairs employed in the spindle motor. For example, a 6-pole-pair spindle motor will generate six electrical cycles over a single revolution. Accordingly, at each BEMF zero crossing representing the end of an electrical cycle, the rotation speed of the spindle motor may be represented as:







SpindleSpeed


[
RPM
]


=

60

cycle_period
·

[

#





of_pole

_pairs

]








However, due to a misalignment of the poles, measuring the rotation speed of the spindle motor based on a single electrical cycle period results in a noisy measurement, thereby reducing the performance of the spin-up operation. Accordingly, in one embodiment the noise due to the misalignment of the poles is attenuated by combining at least two of the cycle periods, and then measuring the rotation speed of the spindle motor based on the combined cycle periods.



FIG. 1D shows control circuitry according to an embodiment wherein the spindle motor operates according to N electrical cycles over a single revolution of the spindle motor, and the cycle periods are combined by summing N consecutive cycle periods. Block 26 measures an electrical cycle period 28 of the spindle motor, such as by detecting a zero crossing in the BEMF voltage generated by the windings. The measured electrical cycle periods 28 are shifted into a delay line 30, and after measuring N electrical cycle periods, a mechanical cycle period 32 is generated as the sum of the last N measured electrical cycle periods 28. The mechanical cycle period 32 is converted at block 34 into a measured rotation speed 36 in rotations per minute (RPM). The measured electrical cycle periods are accumulated 38 to generate a time index 40 used to index a speed command profile (SCP) 42 that outputs a target rotation speed 44 over a spin-up interval. The measured rotation speed 36 is subtracted from the target rotation speed 44 to generate an error signal 46 processed by a controller 48. The controller 48 generates a control signal 50 applied to a driver 52 in order to generate the control signal 24 applied to the spindle motor 6 to thereby accelerate the spindle motor 6 so that the rotation speed substantially follows the target speed output by the SCP 42.


In the embodiment of FIG. 1D, as each new electrical cycle period 28 is measured at block 26, the mechanical cycle period 32 is updated based on the running N consecutive electrical cycle periods. That is, the delay line 30, adder 54, and scalar 34 implement a moving average filter (MAF) of the form:







SpindleSpeed


[
RPM
]


=

60


[

1
+

z

-
1


+


z

-
2





+

z

-

(

N
-
1

)




]

·
cycle_period







The moving average filter represented by the above equation effectively filters out the noise in the measured rotation speed of the spindle motor caused by the misalignment of the poles. In one embodiment, the above moving average filter may be modified to sum fewer or more than the N electrical cycle periods over a revolution of the spindle motor.



FIGS. 2A and 2B show a disk drive according to an embodiment wherein the control circuitry 8 is operable to execute the flow diagram of FIG. 2C during a spin-up operation. A rotation speed of the spindle motor is measured (block 56), and a gain is generated as a function of the measured rotation speed (block 58), wherein the function comprises a polynomial having a degree greater than one. The spindle motor is spun up based on the gain (block 60).



FIG. 2D shows control circuitry for spinning up the spindle motor according to an embodiment wherein block 62 measures a rotation speed 64 of the spindle motor 6, such as by measuring the electrical cycle periods as described above. A function 66 generates a gain Kfbk 68 that is used to spin up the spindle motor, where in the embodiment of FIG. 2D, the gain Kfbk 68 is multiplied by the error signal 46 to generate the control signal 50. That is, the control circuitry in the embodiment of FIG. 2D comprises at least a proportional controller for spinning up the spindle motor, wherein the gain of the proportional controller is generated as a function of the measured rotation speed of the spindle motor.



FIG. 2E illustrates an embodiment wherein the function 66 for generating the gain Kfbk in FIG. 2D comprises a polynomial having a degree greater than one. In the example of FIG. 2D, the function 66 comprises a quadratic polynomial; however, other embodiments may use a higher degree polynomial. In one embodiment, the gain Kfbk may be computed for a number of different rotation speeds based on a design bandwidth of the control loop using a complex equation, which consists of the transfer functions of the spindle motor 6, motor driver 52, and the function for measuring the rotation speed of the spindle motor (e.g., the MAF described above). After generating the gain Kfbk for the number of different rotation speeds, the gain values may be fitted to a curve representing a polynomial having a degree greater than one. The following is an example derivation of the gain Kfbk based on the measured rotation speed and the bandwidth of the control loop:


Define Units:






RPM
:=




2





π





rad


60

s







kRPM

:=


1000





RPM





gmf

:=



10

-
3







kgf





j

:=


-
1










Motor Parameters:






Inertia
:=


44






gm
·

cm
2



=

4.4
×

10

-
6









m
2

·
kg











K
e

:=


0.61


V
kRPM







K
t


:=


K
e

=

5.825
×


10

-
3


·


N
·
m

A

















K
f

:=

0.45



gmf
·
cm

kRPM









R
w

:=


3.6





Ω






R
i


:=


0.124





Ω






R
d


:=

0.648
·
Ω










L
w

:=


0.6





mH






R
a


:=



R
w

+

R
i

+

R
d


=

4.372





Ω











Speed
0

:=


5400





RPM






ω
0


:=


Speed
0

=

565.487
·

rad
s
















T
s

:=



2





π


ω
0


=

0.011





s









Ecycles
:=


6






ω

e





0



:=



ω
0

·
Ecycles

=

3.393
×


10
3

·

rad
s


















T
es

:=



2





π



ω
0

·
Ecycles


=



1.852
·
ms






SpClockFreq

:=

100





MHz















SpClockDiv
:=


32






V
supply


:=


5





V





nBitsKval

:=
12















f
olbw

:=


1

48






T
es



=

11.25
·
Hz















K
d

:=



1

1





RPM


·

1
1

·

V


2
nBitsKval

-
1



=

0.012
·
V
·
s













MarginLT
:=


0.8






MarginK
e


:=
0.9






Basic Calculations:







Electric





Pole


:







Pole
e



:

=


R
a


L
w



=

7.287
×


10
3

·
Hz









Equivalent





Impedance


:







R
eq


:=





(


ω

e





0


·

L
w


)

2

+

R
a
2



R
a


=

5.32





Ω









Mechaniacal





Pole


:







Pole
m


:=





K
f

·

R
eq


+


K
e

·

K
t




Inertia
·

R
eq



=

1.545
·
Hz








Gain
:=



K
t




K
f

·

R
eq


+


K
t

·

K
e




=

161.032
·

A

m
·
N









Motor Transfer function:








G
m



(
s
)


:=


K
t



s
·
Inertia
·

R
eq


+


K
f

·

R
eq


+


K
t

·

K
e









Moving Average Filter:







MAFz


(
z
)


:=



z
5

+

z
4

+

z
3

+

z
2

+
z
+
1


6
·

z
5












MAFs


(
s
)


:=

MAFz


(


2
+

s
·

T
es




2
-

s
·

T
es




)







Open Loop Transfer function:








G
open



(
s
)


=



G
m



(
s
)


·

MAFs


(
s
)


·

(



K
fbk

·

K
d


-


K
e

·

MarginK
e


-



R
a

·

K
f

·
MarginLT


K
t



)







PI Controller coefficents:







f
olbw

=



11.25
·
Hz







ω
olbw


:=


2





π






f
olbw


=

70.686
·

rad
s













K
fbk

:=








1
+






G
m



(

j
·

ω
olbw


)


·

MAFs


(

j
·

ω
olbw


)





·







(



K
e

·

MarginK
e


+



R
a

·

K
f

·
MarginLT


K
t



)








K
d

·


G
m



(

j
·

ω
olbw


)


·

MAFs


(

j
·

ω
olbw


)






=
25.457






In the above example, the gain Kfbk=25.457 has been computed for a measured rotation speed of 5400 RPM. The following table shows the gain Kfbk computed using the above derivation for different measured rotation speeds of the spindle motor. The gain Kfbk values in the table may then be fitted to a curve represented by the following polynomial:

Kfbk=0.797+0.3255·(RPM/100)+0.0024·(RPM/100)2


















Spindle
Sample
Open Loop




Speed (RPM)
Frequency (Hz)
Bandwidth (Hz)
Kfbk





















300
30
0.63
1.743



400
40
0.83
2.081



500
50
1.04
2.448



750
75
1.56
3.38



1000
100
2.08
4.33



1500
150
3.13
6.304



1750
175
3.65
7.305



2000
200
4.17
8.326



2250
225
4.69
9.368



2500
250
5.21
10.435



3000
300
6.25
12.651



3500
350
7.29
14.995



4500
450
9.38
20.173



5400
540
11.25
25.457











FIGS. 3A and 3B show a disk drive according to an embodiment wherein the control circuitry 8 is operable to execute the flow diagram of FIG. 3C during a spin-up operation. A rotation speed of the spindle motor is measured (block 70), and feed-forward control is generated based on the measured rotation speed (block 72). The spindle motor is spun up based on the feed-forward control (block 74).



FIG. 3D shows control circuitry for spinning up the spindle motor according to an embodiment wherein a feedback controller 76 generates a feedback control signal 78 based on the error signal 46. The feedback controller 76 may implement any suitable feedback algorithm, such as the proportional control shown in FIG. 2D. The feedback control signal 78 is adjusted by a feed-forward control signal 80 to generate the control signal 50 applied to the driver 52. The feed-forward control signal 80 may compensate for one or more disturbances injected into the control loop, such as a BEMF of the spindle motor 6, or a drag torque of the spindle motor 6.


In one embodiment, the BEMF of the spindle motor 6 counteracts the acceleration torque of the control signal 50, thereby requiring a higher control signal (e.g., a higher driving current) in order to apply the desired acceleration torque to the spindle motor 6. In one embodiment, the BEMF of the spindle motor 6 increases proportionally with the rotation speed Nm of the spindle motor, and therefore in the embodiment shown in FIG. 3D, a first feed-forward control signal 82 is generated by multiplying the measured rotation speed 64 by a gain Ke 84 representing the BEMF constant of the spindle motor 6. In one embodiment, the BEMF constant of the spindle motor varies based on the ambient temperature, and therefore in the embodiment of FIG. 2D the gain Ke 84 is adjusted based on a measured ambient temperature T of the disk drive.


In one embodiment, the spindle motor 6 may exhibit a counteracting drag torque that may also vary based on the rotation speed of the spindle motor 6 according to:







(

LT
=

f


[

T
,
Nm

]



)

·


Rw


[
T
]



Kt


{
T
]








where LT represents the load torque which is a function of the rotation speed Nm and ambient temperature T, Rw represents a winding resistance which is a function of ambient temperature T, and Kt represents a torque constant of the spindle motor which is a function of ambient temperature T. Accordingly, the control circuitry of FIG. 3D comprises blocks 86 and 88 representing the above equation to generate a second feed-forward control signal 90 added to the first feed-forward control signal 82 to generate a composite feed-forward control signal 80. Any suitable function may be employed to compute the load torque (LT) as a function of the rotation speed Nm and the ambient temperature T, wherein in one embodiment the function may be generated by curve fitting nominal load torque measurements over a number of different ambient temperatures taken for a representative subset of spindle motors.



FIGS. 4A and 4B show a disk drive according to an embodiment wherein the control circuitry 8 is operable to execute the flow diagram of FIG. 4C during a spin-up operation. A rotation speed of the spindle motor is measured (block 92), and a control signal is generated based on the measured rotation speed and a speed command profile (block 94). The spindle motor is spun up based on the control signal (block 96).



FIG. 4D shows control circuitry for spinning up the spindle motor according to an embodiment wherein the speed command profile 42 is generated to ensure a minimum spin-up time and a limited power consumption under a worst case environmental condition. A controller 98 generates the control signal 50 based on a difference (error signal 46) between the measured rotation speed 64 of the spindle motor and a target rotation speed generated by the speed command profile 42. FIG. 4E shows an example of a speed command profile 42 comprising a target speed as a function of the spin-up time. The speed command profile may be generated in any suitable manner, such as by empirically evaluating a representative subset of spindle motors over worst case environmental conditions, such as worst case ambient temperature. In another embodiment, the speed command profile may be computed theoretically based on nominal technical characteristics of the spindle motor, as well as a nominal characterization of the spindle motor under worst case environmental conditions. In one embodiment, the speed command profile may account for a maximum current draw of the spindle motor. By taking into account the worst case environmental conditions, together with the maximum current draw of the spindle motor, the speed command profile 42 may be generated that will ensure a minimum (as well as consistent) spin-up time and a limited power consumption across all operating conditions.



FIGS. 5A and 5B show a disk drive according to an embodiment wherein the control circuitry 8 is operable to execute the flow diagram of FIG. 5C during a spin-up operation. A rotation speed of the spindle motor is measured (block 106), and a control signal is generated based on a difference between the measured rotation speed and a target rotation speed (block 108). The spindle motor is spun-up based on the control signal generated over a second fraction of a spin-up time (block 110), wherein the target rotation speed is generated based on a speed command profile and the second fraction of the spin-up time. The second fraction of the spin-up time is determined based on an initial measured rotation speed of the spindle motor (block 104) prior to generating the control signal.


In the embodiment of FIG. 5C, the control circuitry 8 begins spinning up the spindle motor during a first fraction of the spin-up time using an open loop control system (block 100). After the first fraction of the spin-up time, the initial rotation speed of the spindle motor is measured (block 102) so that the second fraction of the spin-up time may be determined (block 104). In one embodiment illustrated by the speed command profile shown in FIG. 5E, the spindle motor is spun-up over a spin-up time with a corresponding target speed increasing over time. During the first fraction of the spin-up time, the spindle motor is controlled open loop (independent of the control signal 50), wherein at the end of this time the spindle motor will be rotating at an unknown rotation speed. Before enabling the closed loop control circuitry of FIG. 5D, the initial rotation speed of the spindle motor is measured so that a corresponding point on the speed command profile of FIG. 5E may be determined, and so that the time index 40 may be appropriately initialized.


In the embodiment illustrated in FIG. 5E, a delta is added to the initial measured rotation speed so that an initial target rotation speed when enabling the closed loop control circuitry of FIG. 5D is higher than the initial measured rotation speed. In this manner, the initial target rotation speed ensures the spindle motor continues accelerating from the initial measured rotation speed after enabling the control circuitry of FIG. 5D. After adding the delta to generate the initial target rotation speed, the corresponding time in the speed command profile may be determined. The time 38 in FIG. 5D may be initialized to zero, and an offset 112 added to the time 38 that is based on the initial measured rotation speed 114 of the spindle motor. Referring again to FIG. 5E, after adding the offset 112 to the time 38, the speed command profile then generates the target rotation speed over the second fraction of the spin-up time, wherein the control signal 50 in the closed loop control circuitry of FIG. 5D is generated based on this target rotation speed.



FIGS. 6A and 6B show a disk drive according to an embodiment wherein the control circuitry 8 is operable to execute the flow diagram of FIG. 6C during a spin-up operation. The spindle motor is spun up to a target rotation speed using a spin-up controller (block 116). After spinning up the spindle motor, an integrator is initialized based on a state of the spin-up controller (block 118), and the spindle motor is then controlled using a constant-speed controller comprising the integrator (block 120).



FIG. 6D shows control circuitry comprising a spin-up controller 122 operable to spin up the spindle motor 6 using, for example, one or more of the above described techniques. FIG. 6E shows control circuitry according to an embodiment wherein at the end of the spin-up operation, a constant-speed controller 124 is used to control the speed of the spindle motor 6. In the embodiment of FIG. 6E, the constant-speed controller 124 comprises a proportional/integral (PI) controller including a proportional gain Kp 126 for multiplying the error signal 46 and an integrator 128 for integrating the error signal 46. The error signal 46 may be generated as the difference between the measured rotation speed 64 of the spindle motor 6 and a target speed 130 corresponding to a constant rotation speed during normal operation of the disk drive.


In one embodiment, when the control circuitry 8 transitions from the spin-up controller 122 shown in FIG. 6D to the constant-speed controller 124 shown in FIG. 6E, the integrator 128 of the constant-speed controller 124 is initialized based on a state of the spin-up controller 122 in order to minimize any undershoot or overshoot. In one embodiment, the control circuitry 8 will transition from the spin-up controller 122 to the constant-speed controller 124 when the end of the speed command profile is reached at the final target speed (at the end of the spin-up interval), and the error signal 46 is changing at a slow rate which ensures the spin-up controller 122 has reached a steady state. Accordingly, when the spin-up controller 122 has reaches the steady state, the acceleration control signal 50 being generated by the spin-up controller 122 becomes a good candidate for the initial state of the integrator 128 in the constant-speed controller 124. In one embodiment, the control circuitry is operable to initialize the integrator 128 according to:

Accel−Kp·SpeedErr

where Accel represents the acceleration control signal 50 of the spin-up controller 122 at the end of the spin-up operation, Kp represents the gain 126 of the constant-speed controller 124, and SpeedErr represents the error signal 46.



FIG. 7 shows control circuitry according to an embodiment operable to spin up the spindle motor 6 using a combination of the above-described techniques. However, other embodiments may employ fewer of the above described techniques, or a different technique in combination with one or more of the above-described techniques. For example, in some embodiments it may be unnecessary to employ a moving average filter in order to measure the rotation speed 36 of the spindle motor 6 if there is an insignificant misalignment of the poles. Other embodiments may employ a moving average filter in order to measure the rotation speed 36 with or without employing one or more of the other techniques described above.


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 power integrated circuit (PIC), or in a component separate from the PIC, such as a disk controller, or certain operations described above may be performed by a PIC and others by a disk controller. In one embodiment, the PIC 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 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.


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 inventions disclosed herein.

Claims
  • 1. A disk drive comprising: a head actuated over a disk;a spindle motor operable to rotate the disk; andcontrol circuitry operable to: measure a rotation speed of the spindle motor;generate a gain as a function of the measured rotation speed, wherein the function comprises a polynomial having a degree greater than one; andspin-up the spindle motor based on the gain.
  • 2. The disk drive as recited in claim 1, wherein the gain comprises a feedback gain operable to amplify a feedback error signal based on a difference between the measured rotation speed and a target rotation speed.
  • 3. The disk drive as recited in claim 1, wherein the polynomial consists of a degree of two.
  • 4. A method of operating a disk drive comprising a head actuated over a disk, and a spindle motor operable to rotate the disk, the method comprising: measuring a rotation speed of the spindle motor;generating a gain as a function of the measured rotation speed, wherein the function comprises a polynomial having a degree greater than one; andspinning up the spindle motor based on the gain.
  • 5. The method as recited in claim 4, wherein the gain comprises a feedback gain operable to amplify a feedback error signal based on a difference between the measured rotation speed and a target rotation speed.
  • 6. The method as recited in claim 4, wherein the polynomial consists of a degree of two.
  • 7. Control circuitry for use in a disk drive comprising a head actuated over a disk, and a spindle motor operable to rotate the disk, wherein the control circuitry is operable to: measure a rotation speed of the spindle motor;generate a gain as a function of the measured rotation speed, wherein the function comprises a polynomial having a degree greater than one; andspin-up the spindle motor based on the gain.
  • 8. The control circuitry as recited in claim 7, wherein the gain comprises a feedback gain operable to amplify a feedback error signal based on a difference between the measured rotation speed and a target rotation speed.
  • 9. The control circuitry as recited in claim 8, wherein the polynomial consists of a degree of two.
CROSS-REFERENCED TO RELATED APPLICATION(S)

This application is a divisional application of U.S. application Ser. No. 13/869,885, filed Apr. 24, 2013, entitled “DISK DRIVE WITH IMPROVED SPIN-UP CONTROL”, the disclosure of which is hereby incorporated by reference in its entirety.

US Referenced Citations (345)
Number Name Date Kind
5170386 Tateishi Dec 1992 A
5432766 Ando et al. Jul 1995 A
5473230 Dunn et al. Dec 1995 A
5650886 Codilian et al. Jul 1997 A
5682334 Plutowski et al. Oct 1997 A
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
6078158 Heeren et al. Jun 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
6122133 Nazarian et al. Sep 2000 A
6122135 Stich Sep 2000 A
6141175 Nazarian et al. Oct 2000 A
6160368 Plutowski Dec 2000 A
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
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
6462896 Codilian et al. Oct 2002 B1
6476996 Ryan Nov 2002 B1
6484577 Bennett Nov 2002 B1
6493169 Ferris et al. 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
6577088 Heydt et al. Jun 2003 B2
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
6724564 Codilian et al. Apr 2004 B1
6731450 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
6788483 Ferris et al. Sep 2004 B1
6791785 Messenger et al. Sep 2004 B1
6795268 Ryan Sep 2004 B1
6819518 Melkote et al. Nov 2004 B1
6825622 Ryan 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
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
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
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
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
6989953 Codilian 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
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
7158328 Fayeulle Jan 2007 B2
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
7197410 Heydt et al. Mar 2007 B2
7199966 Tu et al. Apr 2007 B1
7203021 Ryan et al. Apr 2007 B1
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 et al. 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
7378810 Sutardja et al. May 2008 B1
7388728 Chen et al. Jun 2008 B1
7391583 Sheh et al. Jun 2008 B1
7391584 Sheh et al. Jun 2008 B1
7433143 Ying et al. Oct 2008 B1
7440210 Lee Oct 2008 B1
7440225 Chen et al. Oct 2008 B1
7443628 Oyabu Oct 2008 B2
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
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
7499239 Chang Mar 2009 B2
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
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
7602129 Shirai et al. Oct 2009 B2
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
8217615 Tan et al. Jul 2012 B2
8254222 Tang Aug 2012 B1
8258729 Ito et al. Sep 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
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
20030007278 Ang et al. Jan 2003 A1
20050099148 DuLaney May 2005 A1
20100035085 Jung et al. Feb 2010 A1
20120284493 Lou et al. Nov 2012 A1
20130120870 Zhou et al. May 2013 A1
20130148240 Ferris et al. Jun 2013 A1
20140320998 Calaway et al. Oct 2014 A1
Non-Patent Literature Citations (1)
Entry
José Carlos Gamazo-Real, et al., “Position and Speed Control of Brushless DC Motors Using Sensorless Techniques and Application Trends”, Sensors 2010, pp. 6901-6947.
Divisions (1)
Number Date Country
Parent 13869885 Apr 2013 US
Child 14480566 US