Data storage device compensating for fabrication tolerances when measuring spindle motor current

Information

  • Patent Grant
  • 9396751
  • Patent Number
    9,396,751
  • Date Filed
    Friday, June 26, 2015
    9 years ago
  • Date Issued
    Tuesday, July 19, 2016
    8 years ago
Abstract
A data storage device is disclosed comprising a spindle motor configured to rotate a disk, wherein the spindle motor comprises a stator, a rotor, and a plurality of windings. The data storage device further comprises an isolation circuit configured to isolate the windings from a supply voltage, a head actuated over the disk, and control circuitry comprising a spindle motor driver comprising a plurality of switches including a first switch and a second switch configured to commutate the windings. While driving the isolation circuit with a first calibration current, the first switch is driven with a second calibration current and a first current flowing through the first switch is measured. While driving the isolation circuit with the first calibration current, the second switch is driven with the second calibration current and a second current flowing through the second switch is measured.
Description
BACKGROUND

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



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





BRIEF DESCRIPTION OF THE DRAWINGS


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



FIG. 2A shows a data storage device in the form of a disk drive according to an embodiment comprising a head actuated over a disk rotated by a spindle motor comprising a plurality of windings.



FIG. 2B is a flow diagram according to an embodiment wherein while driving an isolation circuit with a first calibration current, driving the first switch with a second calibration current and measuring a first current flowing through the first switch, and while driving the isolation circuit with the first calibration current, driving the second switch with the second calibration current and measuring a second current flowing through the second switch.



FIG. 3 shows an embodiment wherein control circuitry of the disk drive comprises a spindle motor driver comprising a plurality of switches including a first switch and a second switch configured to commutate the windings of the spindle motor.



FIG. 4 illustrates an embodiment for generating a compensation value based on the measured first current, wherein the compensation value compensates for a fabrication tolerance including a thermal response.



FIG. 5 shows an embodiment wherein the thermal effect of the VCM driver is taken into account when compensating for the thermal response of the first switch.



FIG. 6A shows an embodiment wherein a current transient response of at least one of the windings is measured to estimate a position of the rotor relative to the stator and the average of the current transient response is used to calibrate the compensate value.



FIG. 6B is a flow diagram according to an embodiment wherein the estimated position of the rotor relative to the stator is estimated based on the measured current transient response of the windings using the calibrated compensation value.



FIG. 7A shows an embodiment wherein the root-mean-square (RMS) of the winding driving current during normal operation is used to calibrate the compensation value.



FIG. 7B is a flow diagram according to an embodiment wherein while the spindle motor is spinning at speed the measured current of the windings is adjusted by the calibrated compensation value.



FIG. 8 shows an embodiment wherein the compensation value adjusts the measured current flowing through a switch of the spindle motor driver in the digital domain.





DETAILED DESCRIPTION


FIG. 2A shows a data storage device in the form of a disk drive according to an embodiment comprising a spindle motor 1 configured to rotate a disk 3, wherein the spindle motor 1 comprises a stator, a rotor, and a plurality of windings (FIG. 3). The data storage device further comprises an isolation circuit 5 configured to isolate the windings from a supply voltage 7, a head 9 actuated over the disk 3, and control circuitry 11 comprising a spindle motor driver (FIG. 3) comprising a plurality of switches 15 including a first switch and a second switch configured to commutate the windings. FIG. 2B is a flow diagram according to an embodiment wherein while driving the isolation circuit with a first calibration current (block 16), the first switch is driven with a second calibration current (block 18) and a first current flowing through the first switch is measured (block 20). While driving the isolation circuit with the first calibration current (block 22), the second switch is driven with the second calibration current (block 24) and a second current flowing through the second switch is measured (block 26).


In the embodiment of FIG. 2A, the disk 3 comprises a plurality of servo sectors 280-28N that define a plurality of servo tracks 30, wherein data tracks are defined relative to the servo tracks at the same or different radial density. The control circuitry 11 processes a read signal 32 emanating from the head 9 to demodulate the servo sectors 280-28N 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. A servo control system in the control circuitry 11 filters the PES using a suitable compensation filter to generate a control signal 34 applied to a voice coil motor (VCM) 36 which rotates an actuator arm 38 about a pivot in order to actuate the head 9 radially over the disk 3 in a direction that reduces the PES. The servo sectors 280-28N 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 (FIG. 1).



FIG. 3 shows control circuitry 11 according to an embodiment wherein a back electromotive force (BEMF) voltage 40 generated by the windings of the spindle motor 1 may be processed in order to drive the commutation sequence of a commutation controller 42. A spindle control block 44 may process a BEMF signal 46 which may be a square wave representing the BEMF zero-crossings as detected by a BEMF detector 48. The commutation controller 42 may generate a control signal 50 which configures the BEMF detector 48 to detect the zero-crossing of the BEMF voltage generated by each winding as the disk rotates. The commutation controller 42 also generates a control signal 52 applied to commutation logic 54. In the embodiment of FIG. 3, the commutation logic 54 is configured by the control signal 52 to control the state of switches 15 in order to drive the windings with voltage Vpwr. The commutation logic 54 may operate in any suitable manner, such as by driving the switches 15 as linear amplifiers that apply continuous-time sinusoidal voltages to the windings. In another embodiment, the commutation logic 54 may drive the switches 15 using pulse width modulation (PWM), such as using square wave PWM, trapezoidal PWM, or sinusoidal PWM. Regardless as to how the windings are driven, the commutation controller 42 generates the control signal 52 so that the windings are commutated at the correct periods, thereby generating the desired rotating magnetic field that causes the spindle motor to rotate. In one embodiment, the spindle control block 44 may generate a control signal 56 that controls the effective amplitude of the periodic driving voltage applied to the windings (continuous or PWM), thereby controlling the speed of the spindle motor 1.


If a power failure occurs while the disk 3 is spinning, there is residual kinetic energy as the disk 3 continues to rotate the spindle motor 1, and therefore the spindle motor 1 can be converted into a power generator used to power the control circuitry 11 while executing power down operations, such as completing a current write operation to the disk 3 before unloading the head 9 onto a ramp. During the power failure, the isolation circuit 5 isolates the windings of the spindle motor 1 from the supply voltage 7 to prevent current from back flowing into the supply voltage 7. Any suitable isolation circuit 5 may be employed, such as a diode or a field effect transistor (FET) operated as a switch.


In one embodiment, each switch for driving the windings of the spindle motor 1 comprises a suitable current sensor for measuring a current flowing through each switch (and corresponding winding or windings). For example, in one embodiment a current transient response of the windings may be measured in order to estimate a position of the rotor relative to the stator in a technique referred to as inductive sense. In another embodiment, the winding current may be measured in order to optimize the commutation sequence of the commutation controller 42 so as to optimize the torque of the spindle motor 1. Regardless as to why the winding current is measured, in one embodiment a fabrication tolerance of the control circuitry (e.g., the switches 15) may affect the accuracy of the relative current sensing measurements. In addition, the thermal response of the control circuitry may exacerbate the affect of fabrication tolerances on the relative current sensing measurements. For example, when the switches 15 shown in FIG. 3 are fabricated with other control circuitry such as the isolation circuit 5, the heating effect of the isolation circuit 5 during normal operation may affect the accuracy of the relative current sensing measurements. Accordingly in one embodiment, compensation values may be calibrated to compensate for the effect that the fabrication tolerances and thermal response have on the relative current sensing measurements.



FIG. 4 shows control circuitry according to an embodiment wherein a select number of the switches 15 shown in FIG. 3 comprises a current sensor (e.g., current sensor 58) comprising a transistor configured as a current mirror and a differential amplifier comprising an adjustable gain and optionally an adjustable offset. For example, in the embodiment of FIG. 4 each low-side switch of each phase may comprise a current sensor implemented as a current mirror. The isolation circuit 5 of FIG. 3 comprises in FIG. 4 a FET controlled by block 60 as well as a current sensor 62 configured to sense the current flowing through the FET. An analog multiplexer 64 is configured to select between the current sensors, wherein the output of the multiplexer 64 is converted into a digital value 66 by an analog-to-digital converter (ADC) 68.


In one embodiment shown in FIG. 4, when calibrating the compensation value for the current sensor of a first one of the switches 15 (e.g., the phase C switch), a first current source 70 drives the FET of the isolation circuit 5 with a first calibration current that corresponds to a normal operating mode of the disk drive, and a second current source 72 drives the phase C switch with a second calibration current. A third current source 74 drives the phase A and phase B switches with a third calibration current that corresponds to the normal operating mode of the disk drive. Driving the FET of the isolation circuit 5 as well as the phase A and phase B switches with a calibration current simulates the heating affect on the phase C current sensor. The multiplexer 64 is configured to select the sensed current flowing through the FET of the isolation circuit 5 which, in one embodiment, becomes a reference current. The multiplexer 64 is then configured to select the sensed current flowing through the phase C switch, and a compensation value is generated (at balance control block 76) to adjust the gain and optionally offset of the current sensor of the phase C switch so that the sensed current of the phase C switch equals a target value relative to the reference current flowing through the isolation circuit 5. The compensation value for the phase C switch is saved in a memory of the balance control block 76 and used to adjust the sensed current of the phase C switch during normal operation of the disk drive (e.g., during inductive sense).


A similar current sense measurement is generated for the phase A switch by driving the phase A switch with the second current source 72 and driving the phase B and phase C switches with the third current source 74. A compensation value is generated relative to the reference current, and the compensation value is saved in the memory of the balance control block 76. A similar current sense measurement is generated for the phase B switch by driving the phase B switch with the second current source 72 and driving the phase A and phase C switches with the third current source 74. A compensation value is generated relative to the reference current, and the compensation value is saved in the memory of the balance control block 76. During normal operation, the compensation values saved in the memory of the balance control block 76 are used to adjust the sensed current for each switch, thereby compensating for the relative difference between the current sense measurements due to a variety of reasons, e.g., the fabrication tolerances and thermal response of the control circuitry. That is, after applying the compensation values the difference between the measured currents flowing through each switch more accurately reflects the actual relative currents of the switches (and the windings) rather than the difference in fabrication tolerances and thermal response of the control circuitry.


The current sources shown in FIG. 4 may be configured to generate any suitable calibration currents when calibrating the compensation values. In one embodiment, the current sensor 62 of the isolation circuit 5 is used as a reference current sensor for calibrating the current sensors of the spindle motor driver. A reference current measurement is generated by configuring the first current source 70 to drive the isolation circuit 5 with a calibration current that corresponds to a normal operating mode of the disk drive. The second and third current sources 72 and 74 are set to zero so that a voltage source 82 sinks the current flowing through the FET of the isolation circuit 5. In one embodiment, the voltage source 82 generates a calibration voltage at node 84 that corresponds to the normal mode of operation for the disk drive. The multiplexer 64 is configured to select the sensed current flowing through the FET of the isolation circuit 5 which becomes the reference current measurement. The second and third current sources 72 and 74 are then configured to generate a calibration current that approximates the calibration current flowing through the FET of the isolation circuit 5 in order to generate the compensation values described above. For example, in one embodiment the second and third current sources 72 and 74 may be configured to the same setting as the first current source 70. In another embodiment, the second and third current sources 72 and 74 may be configured to a setting equal to the first current source 70 minus a quiescent current. That is, in one embodiment the actual current flowing through the FET of the isolation circuit 5 may equal the calibration current generated by the first current source 70 minus a quiescent current. In this embodiment, the gain and optionally the offset of each current sensor of the spindle motor driver are adjusted until the measured current equals the above described reference current measurement. These adjustment values are then saved at the balance control block 76 as the compensation value for each current sensor.



FIG. 5 shows an embodiment wherein the control circuitry (e.g., integrated circuit) comprises a VCM driver 78 comprising switches (e.g., configured as an H-bridge) that drive current through a voice coil of the VCM 36 (FIG. 2A). In on embodiment, it may be desirable to measure the current flowing through the windings of the spindle motor 1 while the VCM driver is controlling the VCM 36 during a normal operating mode (e.g., during a seek operation to seek the head over the disk or during a tracking operation to track the head over a data track). Accordingly, in this embodiment the thermal effect of the VCM driver 78 when measuring the current flowing through the switches of the spindle motor driver may be taken into account when calibrating the compensation values by driving the VCM driver 78 with a calibration current that corresponds to the normal mode of operation. In this embodiment, a fourth current source 80 generates the calibration current applied to the VCM driver 78 when calibrating the compensation values for the spindle motor current measurements. Also in this embodiment, the calibration current generated by the first current source 70 is increased to simulate the increase in current consumption by the VCM driver 78 (i.e., increased by the setting of the fourth current source 80). When measuring the calibration current flowing though each switch of the spindle motor driver, the voltage source 82 sinks the additional current generated by the first current source 70.


In one embodiment, the calibration currents generated by the current sources in FIG. 4 and FIG. 5 may correspond to different operating modes of the disk drive, and therefore in this embodiment there may be multiple compensation values calibrated for the spindle motor driver current sensors, where each compensation value may correspond to a different operating mode. For example, in one embodiment the disk drive may be in a spin-up mode wherein the spindle motor driver current may be measured when the spindle motor is not yet spinning and/or while the spindle motor is spinning up to speed. The spindle motor driver current may also be measured while the spindle motor is spinning at speed while the VCM 36 is idle (e.g., in a parked position). In yet another embodiment, the spindle motor driver current may be measured while the spindle motor is spinning at speed and while the VCM 36 is being driven during a seek operation or a tracking operation. In yet another embodiment, the spindle motor driver current may be measured at different phases of a seek operation, such as during an acceleration phase, coast phase, and a deceleration phase of the VCM 36. Accordingly, in one embodiment the current sources shown in FIG. 4 and FIG. 5 may be configured to generate calibration currents that simulate the operating mode of the disk drive in order to calibrate a corresponding compensation value for each current sensor of the spindle motor driver. During normal operation, the compensation value that corresponds to the current operating mode may then be used to adjust the measured currents flowing through the switches of the spindle motor driver, thereby compensating for the thermal response of the control circuitry at the different operating modes.



FIG. 6A illustrates an inductive sense technique for measuring the position of the rotor relative to the stator. In this embodiment, a current transient response of the windings is measured by applying a control voltage and measuring a current response characteristic of the windings. For example, the rise time for the measured current to reach a threshold may depend on the inductance of the windings, wherein the inductance of the windings varies based on the position of the rotor relative to the stator. In one embodiment, the current transient response may be measured for two of the windings connected in series (e.g., phase A and phase B) resulting in six current pulses (plus a dummy pulse) as shown in FIG. 6A wherein each current pulse represents one of the six possible combinations for two out of the three windings. In one embodiment, the calibration current generated by the first and second current sources 72 and 74 shown in FIG. 4 are configured based on the average of the current transient response as shown in FIG. 6A, thereby simulating the heating effect on the current sensor measurements during the inductive sense mode.



FIG. 6B is a flow diagram according to an embodiment wherein a compensation value for each current sensor of the spindle motor driver is generated as described above (block 83). During the inductive sense mode, a current flowing through a winding (or windings) is measured using the compensation value (block 85). For example, in one embodiment the compensation value is used to adjust the gain and optionally the offset of a corresponding current sensor such as shown in FIG. 4 so that the measured winding current compensates for the fabrication tolerances and thermal response of the control circuitry. The position of the rotor relative to the stator is then estimated based on the measured current (block 86).



FIG. 7A shows an embodiment wherein the winding current may be measured in order to optimize the commutation sequence of the commutation controller 42 so as to optimize the torque of the spindle motor 1. In this embodiment, the winding current is measured while the spindle motor is spinning at speed, and therefore the current flowing through the windings is a sinusoidal current as shown in FIG. 7A. In one embodiment, the current sources shown in FIG. 4 are configured to simulate the current flowing through the windings while the spindle motor is spinning at speed by generating the calibration current based on the root-mean-square (RMS) of the sinusoidal winding current shown in FIG. 7A.



FIG. 7B is a flow diagram according to an embodiment wherein a compensation value for each current sensor of the spindle motor driver is generated as described above (block 88). While the spindle motor is spinning at a normal operating speed, a current flowing through a winding (or windings) is measured using the compensation value (block 90). For example, in one embodiment the compensation value is used to adjust the gain and optionally the offset of a corresponding current sensor such as shown in FIG. 4 so that the measured winding current compensates for the fabrication tolerances and thermal response of the control circuitry. The spindle motor may then be commutated based on the measured current, for example, to optimize the torque generated by the spindle motor (block 92). As described above with reference to FIG. 5, different compensation values may be calibrated corresponding to different operating modes while the spindle motor is spinning at speed, for example, while seeking the head over the disk or tracking the head over a data track.



FIG. 8 illustrates an alternative embodiment wherein the compensation values may be used to adjust the winding current measurements in the digital domain by the balance control block 76. That is, the compensation values are used to adjust the digital values generated by the ADC 68 at block 94 in order to adjust the gain and optionally the offset of the measured winding currents to compensate for the fabrication tolerances and thermal response of the control circuitry.


In the embodiments described above, the current sources shown in FIG. 4 and FIG. 5 generate DC calibration currents that simulate the average current consumption during the different operating modes of the disk drive (e.g., inductive sense). In another embodiment, the current sources may be configured to generate AC calibration currents that more accurately simulate the actual current consumption of the disk drive during a normal operating mode. In this embodiment, the control circuitry may calibrate different compensation values each corresponding to the estimated current consumption at any given moment during a particular operating mode, thereby increasing the accuracy of the thermal response compensation when measuring the winding currents during the different operating modes.


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


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


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


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


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

Claims
  • 1. A data storage device comprising: a disk;a spindle motor configured to rotate the disk, wherein the spindle motor comprises a stator, a rotor, and a plurality of windings;an isolation circuit configured to isolate the windings from a supply voltage;a head actuated over the disk; andcontrol circuitry comprising a spindle motor driver comprising a plurality of switches including a first switch and a second switch configured to commutate the windings, the control circuitry configured to: while driving the isolation circuit with a first calibration current, drive the first switch with a second calibration current and measure a first current flowing through the first switch; andwhile driving the isolation circuit with the first calibration current, drive the second switch with the second calibration current and measure a second current flowing through the second switch.
  • 2. The data storage device as recited in claim 1, wherein the control circuitry further comprises a first current source for generating the first calibration current and a second current source for generating the second calibration current.
  • 3. The data storage device as recited in claim 1, wherein the control circuitry is further configured to: generate a compensation value based on the measured first current;measure a third current flowing through the first switch using the compensation value; andestimate a position of the rotor relative to the stator based on the measured third current.
  • 4. The data storage device as recited in claim 3, wherein the compensation value compensates for a fabrication tolerance.
  • 5. The data storage device as recited in claim 3, wherein the control circuitry is further configured to generate the first calibration current based on a sum of a quiescent current and the second calibration current.
  • 6. The data storage device as recited in claim 1, wherein the control circuitry is further configured to: measure a current transient response of at least one of the windings to estimate a position of the rotor relative to the stator; andgenerate the first calibration current and the second calibration current based on an average of the current transient response.
  • 7. The data storage device as recited in claim 1, wherein the control circuitry is further configured to apply a calibration voltage to the isolation circuit when measuring the first current and when measuring the second current.
  • 8. The data storage device as recited in claim 7, wherein the control circuitry comprises a voltage source configured to generate the calibration voltage.
  • 9. The data storage device as recited in claim 8, wherein the voltage source is configured to sink at least part of the first calibration current when measuring the first current and when measuring the second current.
  • 10. The data storage device as recited in claim 1, further comprising a voice coil motor (VCM) configured to actuate the head over the disk and a VCM driver, wherein the control circuitry is further configured to: while driving the isolation circuit with the first calibration current and driving the VCM driver with a third calibration current, drive the first switch with the second calibration current and measure a third current flowing through the first switch; andwhile driving the isolation circuit with the first calibration current and driving the VCM driver with the third calibration current, drive the second switch with the second calibration current and measure a fourth current flowing through the second switch.
  • 11. The data storage device as recited in claim 10, wherein the third calibration current corresponds to a driving current applied to the VCM during at least one of a seek operation to seek the head over the disk and a tracking operation to track the head over a data track.
  • 12. The data storage device as recited in claim 10, wherein the control circuitry is further configured to generate the first calibration current based on a sum of the second calibration current and the third calibration current.
  • 13. The data storage device as recited in claim 10, wherein the control circuitry is further configured to: generate a compensation value based on the measured third current;measure a fifth current flowing through the first switch using the compensation value; andestimate a position of the rotate relative to the stator based on the measured fifth current.
  • 14. The data storage device as recited in claim 1, wherein while driving the isolation circuit with the first calibration current and driving the first switch with the second calibration current, the control circuitry is further configured to drive the second switch with a third calibration current while measuring the first current flowing through the first switch.
  • 15. The data storage device as recited in claim 14, wherein the control circuitry comprises a current source for generating the third calibration current.
  • 16. A method of operating a data storage device, the method comprising: while driving an isolation circuit with a first calibration current, driving a first switch of a spindle motor driver with a second calibration current and measuring a first current flowing through the first switch; andwhile driving the isolation circuit with the first calibration current, driving a second switch of the spindle motor driver with the second calibration current and measuring a second current flowing through the second switch.
  • 17. The method as recited in claim 16, further comprising generating the first calibration current using a first current source and generating the second calibration current using a second current source.
  • 18. The method as recited in claim 16, further comprising: generating a compensation value based on the measured first current;measuring a third current flowing through the first switch using the compensation value; andestimating a position of a rotor of a spindle motor relative to a stator of the spindle motor based on the measured third current.
  • 19. The method as recited in claim 18, wherein the compensation value compensates for a fabrication tolerance.
  • 20. The method as recited in claim 18, further comprising generating the first calibration current based on a sum of a quiescent current and the second calibration current.
  • 21. The method as recited in claim 16, further comprising: measuring a current transient response of at least one of the windings to estimate a position of a rotor of a spindle motor relative to a stator of the spindle motor; andgenerating the first calibration current and the second calibration current based on an average of the current transient response.
  • 22. The method as recited in claim 16, further comprising applying a calibration voltage to the isolation circuit when measuring the first current and when measuring the second current.
  • 23. The method as recited in claim 22, further comprising generating the calibration voltage using a voltage source.
  • 24. The method as recited in claim 23, further comprising the voltage source sinking at least part of the first calibration current when measuring the first current and when measuring the second current.
  • 25. The method as recited in claim 16, further comprising: while driving the isolation circuit with the first calibration current and driving a voice coil motor (VCM) driver with a third calibration current, driving the first switch with the second calibration current and measuring a third current flowing through the first switch; andwhile driving the isolation circuit with the first calibration current and driving the VCM driver with the third calibration current, driving the second switch with the second calibration current and measuring a fourth current flowing through the second switch.
  • 26. The method as recited in claim 25, wherein the third calibration current corresponds to a driving current applied to the VCM during at least one of a seek operation to seek a head over a disk and a tracking operation to track the head over a data track.
  • 27. The method as recited in claim 25, further comprising generating the first calibration current based on a sum of the second calibration current and the third calibration current.
  • 28. The method as recited in claim 25, further comprising: generating a compensation value based on the measured third current;measuring a fifth current flowing through the first switch using the compensation value; andestimating a position of a rotate of the spindle motor relative to a stator of the spindle motor based on the measured fifth current.
  • 29. The method as recited in claim 16, wherein while driving the isolation circuit with the first calibration current and driving the first switch with the second calibration current, further comprising driving the second switch with a third calibration current while measuring the first current flowing through the first switch.
  • 30. The method as recited in claim 29, further comprising generating the third calibration current using a current source.
  • 31. Control circuitry of a data storage device, the control circuitry configured to: while driving an isolation circuit with a first calibration current, drive a first switch of a spindle motor driver with a second calibration current and measure a first current flowing through the first switch; andwhile driving the isolation circuit with the first calibration current, drive a second switch of the spindle motor driver with the second calibration current and measure a second current flowing through the second switch.
  • 32. The control circuitry as recited in claim 31, wherein the control circuitry further comprises a first current source for generating the first calibration current and a second current source for generating the second calibration current.
  • 33. The control circuitry as recited in claim 31, wherein the control circuitry is further configured to: generate a compensation value based on the measured first current;measure a third current flowing through the first switch using the compensation value; andestimate a position of a rotor of a spindle motor relative to a stator of the spindle motor based on the measured third current.
  • 34. The control circuitry as recited in claim 33, wherein the compensation value compensates for a fabrication tolerance.
US Referenced Citations (342)
Number Name Date Kind
5631999 Dinsmore May 1997 A
5959417 Maggio et al. Sep 1999 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
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
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
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
6879128 Coutu et al. Apr 2005 B2
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
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
7158329 Ryan Jan 2007 B1
7180703 Subrahmanyam et al. Feb 2007 B1
7184230 Chue et al. Feb 2007 B1
7196864 Yi et al. Mar 2007 B1
7199966 Tu et al. Apr 2007 B1
7203021 Ryan et al. Apr 2007 B1
7209321 Bennett Apr 2007 B1
7212364 Lee May 2007 B1
7212374 Wang et al. May 2007 B1
7215504 Bennett May 2007 B1
7224546 Orakcilar et al. May 2007 B1
7248426 Weerasooriya et al. Jul 2007 B1
7251098 Wang et al. Jul 2007 B1
7253582 Ding et al. Aug 2007 B1
7253989 Lau et al. Aug 2007 B1
7265933 Phan et al. Sep 2007 B1
7289288 Tu Oct 2007 B1
7298574 Melkote et al. Nov 2007 B1
7301717 Lee et al. Nov 2007 B1
7304819 Melkote et al. Dec 2007 B1
7330019 Bennett Feb 2008 B1
7330327 Chue Feb 2008 B1
7333280 Lifchits et al. Feb 2008 B1
7333290 Kupferman Feb 2008 B1
7339761 Tu et al. Mar 2008 B1
7365932 Bennett Apr 2008 B1
7388728 Chen et al. Jun 2008 B1
7391583 Sheh et al. Jun 2008 B1
7391584 Sheh et al. Jun 2008 B1
7433143 Ying et al. Oct 2008 B1
7440210 Lee Oct 2008 B1
7440225 Chen et al. Oct 2008 B1
7450334 Wang et al. Nov 2008 B1
7450336 Wang et al. Nov 2008 B1
7453661 Jang et al. Nov 2008 B1
7457071 Sheh Nov 2008 B1
7466509 Chen et al. Dec 2008 B1
7468855 Weerasooriya et al. Dec 2008 B1
7477471 Nemshick et al. Jan 2009 B1
7480116 Bennett Jan 2009 B1
7489464 McNab et al. Feb 2009 B1
7492546 Miyamura Feb 2009 B1
7495857 Bennett Feb 2009 B1
7499236 Lee et al. Mar 2009 B1
7502192 Wang et al. Mar 2009 B1
7502195 Wu et al. Mar 2009 B1
7502197 Chue Mar 2009 B1
7505223 McCornack Mar 2009 B1
7542225 Ding et al. Jun 2009 B1
7548392 Desai et al. Jun 2009 B1
7551390 Wang et al. Jun 2009 B1
7557557 Sugie Jul 2009 B2
7558016 Le et al. Jul 2009 B1
7573670 Ryan et al. Aug 2009 B1
7576941 Chen et al. Aug 2009 B1
7580212 Li et al. Aug 2009 B1
7583470 Chen et al. Sep 2009 B1
7595954 Chen et al. Sep 2009 B1
7602575 Lifchits et al. Oct 2009 B1
7616399 Chen et al. Nov 2009 B1
7619844 Bennett Nov 2009 B1
7626782 Yu et al. Dec 2009 B1
7630162 Zhao et al. Dec 2009 B2
7639447 Yu et al. Dec 2009 B1
7656604 Liang et al. Feb 2010 B1
7656607 Bennett Feb 2010 B1
7659678 Maiocchi Feb 2010 B2
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
7893638 Akama Feb 2011 B2
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
8217603 Akama Jul 2012 B2
8228046 Ingemi Jul 2012 B2
8254222 Tang Aug 2012 B1
8300348 Liu et al. Oct 2012 B1
8315005 Zou et al. Nov 2012 B1
8320069 Knigge et al. Nov 2012 B1
8351174 Gardner et al. Jan 2013 B1
8358114 Ferris et al. Jan 2013 B1
8358145 Ferris et al. Jan 2013 B1
8390367 Bennett Mar 2013 B1
8432031 Agness et al. Apr 2013 B1
8432629 Rigney et al. Apr 2013 B1
8432775 Miyagoe Apr 2013 B2
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
8587238 Maiocchi Nov 2013 B2
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
8749183 Bonvin Jun 2014 B2
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
9013123 Innes Apr 2015 B2
9054607 Otaguro Jun 2015 B2
9093106 Otaguro Jul 2015 B2
9142248 Otaguro Sep 2015 B2
20080265819 Chen et al. Oct 2008 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
20140217943 Bonvin Aug 2014 A1