Nothing Special   »   [go: up one dir, main page]

WO2004061604A2 - Optimizing processor clock frequency in a hard disk drive to minimize power consumption while maximizing performance - Google Patents

Optimizing processor clock frequency in a hard disk drive to minimize power consumption while maximizing performance Download PDF

Info

Publication number
WO2004061604A2
WO2004061604A2 PCT/US2003/041094 US0341094W WO2004061604A2 WO 2004061604 A2 WO2004061604 A2 WO 2004061604A2 US 0341094 W US0341094 W US 0341094W WO 2004061604 A2 WO2004061604 A2 WO 2004061604A2
Authority
WO
WIPO (PCT)
Prior art keywords
processor
clock
code
servo
current command
Prior art date
Application number
PCT/US2003/041094
Other languages
French (fr)
Other versions
WO2004061604A3 (en
Inventor
Thorsten Schmidt
Original Assignee
Matsushita Electric Industrial Co. Ltd.
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Priority claimed from US10/413,198 external-priority patent/US7089432B2/en
Priority claimed from US10/413,017 external-priority patent/US7072138B2/en
Application filed by Matsushita Electric Industrial Co. Ltd. filed Critical Matsushita Electric Industrial Co. Ltd.
Priority to AU2003300305A priority Critical patent/AU2003300305A1/en
Publication of WO2004061604A2 publication Critical patent/WO2004061604A2/en
Publication of WO2004061604A3 publication Critical patent/WO2004061604A3/en

Links

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F1/00Details not covered by groups G06F3/00 - G06F13/00 and G06F21/00
    • G06F1/26Power supply means, e.g. regulation thereof
    • G06F1/32Means for saving power
    • G06F1/3203Power management, i.e. event-based initiation of a power-saving mode
    • G06F1/3206Monitoring of events, devices or parameters that trigger a change in power modality
    • G06F1/3215Monitoring of peripheral devices
    • G06F1/3221Monitoring of peripheral devices of disk drive devices
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F1/00Details not covered by groups G06F3/00 - G06F13/00 and G06F21/00
    • G06F1/26Power supply means, e.g. regulation thereof
    • G06F1/32Means for saving power
    • G06F1/3203Power management, i.e. event-based initiation of a power-saving mode
    • G06F1/3234Power saving characterised by the action undertaken
    • G06F1/324Power saving characterised by the action undertaken by lowering clock frequency
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F1/00Details not covered by groups G06F3/00 - G06F13/00 and G06F21/00
    • G06F1/26Power supply means, e.g. regulation thereof
    • G06F1/32Means for saving power
    • G06F1/3203Power management, i.e. event-based initiation of a power-saving mode
    • G06F1/3234Power saving characterised by the action undertaken
    • G06F1/325Power saving in peripheral device
    • G06F1/3268Power saving in hard disk drive
    • GPHYSICS
    • G11INFORMATION STORAGE
    • G11BINFORMATION STORAGE BASED ON RELATIVE MOVEMENT BETWEEN RECORD CARRIER AND TRANSDUCER
    • G11B21/00Head arrangements not specific to the method of recording or reproducing
    • G11B21/02Driving or moving of heads
    • G11B21/08Track changing or selecting during transducing operation
    • G11B21/081Access to indexed tracks or parts of continuous track
    • G11B21/083Access to indexed tracks or parts of continuous track on discs
    • GPHYSICS
    • G11INFORMATION STORAGE
    • G11BINFORMATION STORAGE BASED ON RELATIVE MOVEMENT BETWEEN RECORD CARRIER AND TRANSDUCER
    • G11B5/00Recording by magnetisation or demagnetisation of a record carrier; Reproducing by magnetic means; Record carriers therefor
    • G11B5/48Disposition or mounting of heads or head supports relative to record carriers ; arrangements of heads, e.g. for scanning the record carrier to increase the relative speed
    • G11B5/54Disposition or mounting of heads or head supports relative to record carriers ; arrangements of heads, e.g. for scanning the record carrier to increase the relative speed with provision for moving the head into or out of its operative position or across tracks
    • G11B5/55Track change, selection or acquisition by displacement of the head
    • G11B5/5521Track change, selection or acquisition by displacement of the head across disk tracks
    • G11B5/5526Control therefor; circuits, track configurations or relative disposition of servo-information transducers and servo-information tracks for control thereof
    • YGENERAL TAGGING OF NEW TECHNOLOGICAL DEVELOPMENTS; GENERAL TAGGING OF CROSS-SECTIONAL TECHNOLOGIES SPANNING OVER SEVERAL SECTIONS OF THE IPC; TECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
    • Y02TECHNOLOGIES OR APPLICATIONS FOR MITIGATION OR ADAPTATION AGAINST CLIMATE CHANGE
    • Y02DCLIMATE CHANGE MITIGATION TECHNOLOGIES IN INFORMATION AND COMMUNICATION TECHNOLOGIES [ICT], I.E. INFORMATION AND COMMUNICATION TECHNOLOGIES AIMING AT THE REDUCTION OF THEIR OWN ENERGY USE
    • Y02D10/00Energy efficient computing, e.g. low power processors, power management or thermal management

Definitions

  • the present invention relates to the design of hard disk drives to minimize power consumption while maintaining performance levels. More particularly, the present invention relates a technique for minimizing power consumption by one or more processors controlling the disk drive.
  • a hard disk drive assembly is a mass-storage device from which data may be read and/or written.
  • the hard disk drive includes one or more randomly accessible rotatable storage media, or disks upon which data is encoded.
  • the data is encoded as bits of information using magnetic field reversals grouped in tracks on the magnetic hard surface of rotating disks.
  • a transducer head supported by an actuator arm is used to read data from or write data to the disks.
  • a voice control motor (NCM) attached to the actuator controls positioning of the actuator, and thus the transducer head position over a disk. Data read from the disk or written to the disk is provided through circuitry to a processor.
  • NCM voice control motor
  • Servo position data read from the disk is processed by the processor, enabling the processor to provide servo current command signals to control the NCM for proper positioning of a transducer head relative to a disk
  • the system is typically set to operate at a low power level. With a low power, overall performance is typically sacrificed in return for maximizing battery life. For non-portable hard disk drives not requiring batteries, system power levels are not a significant issue and the system power levels can be set high to maximize performance.
  • the operation frequency, and thus power consumption can be linearly adjusted by reducing the clock rate. Adjusting both clock rate and system voltage level can produce approximately cubic reductions in power consumption.
  • the processor clock rate is set to facilitate a compromise between reducing power to maintain battery life and maintaining a desired level of system performance.
  • disk drive processor speed is changed during run time to optimize the trade-off between minimizing power consumption and maximizing performance.
  • Changing processor speed satisfies the general desire to keep the processor frequency low so that the power consumption is low, while maintaining some critical operations at a fast run time because they significantly affect system performance.
  • processor clock speed is modified such that different parts of code running on the processor execute at different speeds.
  • processor speed for executing certain code is related to how much the code affects performance of the drive.
  • Code that is critical to performance is set to run faster than code that is not critical to performance.
  • One example of critical code is the code that starts from the assertion of the servo interrupt until the output of the servo current control signal from the processor to the NCM controller.
  • the processor clock speed is maximized.
  • an ASIC containing the processor is selected which provides the ability to switch clock rates of the processor during processor run time.
  • critical code is the code processed in a bottleneck between when the disk drive processor receives a command to transfer data, and when the processor starts the execution of a seek command.
  • the seek command requires the actuator to move the head from the current track to a different track, and requires some time for the processor to generate, in part because the processor typically has to generate an appropriate destination from the transfer data command. This can result in a code bottleneck between the receipt of a transfer data command and start of the seek command.
  • Fig. 1 shows a block diagram of components of a hard disk drive configured to minimize power consumption in accordance with the present invention
  • Fig. 2 illustrates the subdivision of tracks programmed on a hard disk into servo sectors
  • Fig. 3 shows a timing diagram illustrating the time from the start of the servo interrupt to the sending of the current command
  • Fig. 4 shows a diagram illustrating the time from the start of the servo interrupt to the sending of the current command as well as the time from the sending of the current command to the end of the servo interrupt.
  • Fig. 1 shows a block diagram of components of a hard disk drive system configured to minimize power consumption in accordance with the present invention.
  • the hard disk drive includes a rotating disk 2 containing a magnetic medium for storing data in defined tracks. Data is written to or read from the storage medium using a transducer or read/write head 4 provided on an actuator
  • the actuator movement is controlled by a voice control motor (NCM) 8 made up of a magnet and a coil configured for receiving an external control signal.
  • NCM voice control motor
  • NCM driver 10 receives current command signals from a processor 12, enabling the NCM driver 10 to apply an amount of current to the coil of the NCM 8 to position the actuator 6 over a desired track of the rotating disk 2.
  • the disk 2 contains multiple tracks where data is stored.
  • the data is read from or written to the rotating disk 2 using the transducer head 4.
  • the analog data read is provided through a read/write (R/W) pre-amplifier 14.
  • the amplified read data is provided to the R/W channel 16, which includes circuitry to convert the data from analog to digital and decode the digital data to provide to the hard disk controller (HDC) 34.
  • the R/W channel 16 further converts data received from the HDC to be written from digital to analog for providing through the R/W preamps 14 to transducer head 4.
  • the data read includes servo data provided in digital form from the HDC 34 to the processor 12.
  • Servo data provided to the processor 12 includes information indicating track positioning of the transducer head 4 over the rotating disk 2.
  • the track positioning information indicates the track the transducer head 4 is placed over, as well as any misalignment of the transducer head 4 relative to a track.
  • Servo data is recorded periodically along each track on the rotating disk 4 between other non-servo data.
  • the real-time servo control algorithm is typically run on an interrupt basis on the processor, with the interrupt being triggered, for example by servo demodulation hardware typically provided in the HDC 34.
  • the interrupt causes the processor to cease other functions it is performing and deal with the servo position data.
  • the processor 12 determines track misalignment and computes a current command which is sent to the NCM driver 10 to correct for the track misalignment.
  • This interrupt is typically initiated approximately when all the servo position information contained in the servo wedge is read into the ASIC 20. It is well known that reducing the time between the position information written on the disk and the subsequent current command improves servo performance. Thus, enhancing the processor performance during the time from the start of the interrupt to the sending of the current command at the expense of additional power consumption is typically desirable.
  • the processor 12 executes code which generates a target position consistent with the desired read or write data and sends a request to the servo code to move from the current position to the new target position.
  • the request to move the head from one location to another is typically called a seek. Because it improves performance to minimize the time from the receipt of the read or write command to the start of the seek, enhancing processor performance during execution of this code at the expense of additional power consumption is typically desirable.
  • Processor 12 executes instructions acquired from a stored control program to control disk drive functions.
  • the control program is embedded in flash memory, or other non-volatile memory and then either executed directly, or loaded into a random access memory RAM 19 connected to the processor 12 and executed.
  • Various firmware routines are stored in memory locations for controlling the operation of the actuator 7 and spindle motor 30.
  • control programs include the instructions the processor 12 executes, and tables, parameters or arguments used during the execution of these programs.
  • the processor 12 also communicates with the HDC 34 which has access to components external to the hard disk drive system through an advanced technology attachment (ATA) interface bus 20.
  • ATA advanced technology attachment
  • the ATA bus 20 is also referred to as an integrated drive electronics (IDE) bus, and although specifically shown as an ATA bus, may be another type of external component interface, such as an SCSI, in accordance with the present invention.
  • IDE integrated drive electronics
  • the HDC 34 further provides access to additional DRAM memory 36. Control programs for the processor may reside in DRAM 36, or in RAM 19 directly accessible by the processor.
  • ASICs application specific integration circuits
  • FIG. 1 the ASIC 26 integrates the processor 12, RAM 19, R/W channel 16, HDC 34, DRAM 36, and ATA interface bus 20 all onto a single chip.
  • the chip for disk drive control is often referred to as a system on a chip (SOC).
  • SOC system on a chip
  • components such as the NCM driver 10 and the processor 12 are shown to be included on the single ASIC 26, it is understood that the present invention contemplates that the components may similarly be included as separate non-integrated circuits, or the processing functions can be distributed to other components such as the HDC 34.
  • a single processor 12 is shown, it is understood that the functions of processor 12 can be divided among multiple processors when desirable.
  • a crystal oscillator 30 is provided external to the ASIC 26. Although a crystal oscillator is shown, other types of oscillators may be used.
  • An oscillator input signal is typically provided to one or more phase locked loops (PLLs) on an ASIC.
  • PLLs include frequency dividers to convert the frequency from the oscillator to the desired frequency for individual components on the ASIC. For the ASIC 26 illustrated in Fig. 1, four such PLLs 21 -24 are shown.
  • the PLLs 21-23 are shown providing a clock signal to the processor 12. Note that although the PLLs 21-23 are shown connected directly to the processor 12, many configurations are possible. For instance, the PLLs can be provided indirectly through the HDC 34 to the processor 12. The HDC 34 can then include a multiplexer controlled by the processor to select one of the PLL outputs to provide to the processor 12 at a time. In accordance with the present invention, code executing on the processor can select one of the desired clock signals depending on the frequency of operation desired. Code stored in the RAM 19, or other memory if present, selects different clock signals as desired.
  • a single PLL such as PLL 21, could be configured to provide the clock signal to the processor 12, with control signals provided to the PLL 21 to control its frequency division to selectively provide different clock signal frequencies to the processor 12.
  • Multiple PLLs may, however, be desirable because of the time period required for a PLL to stabilize after its frequency divider is reset.
  • the clock signal frequency of the processor 12 is varied during processor run time to minimize power consumption, while maximizing performance.
  • clock frequency of the processor is reduced, power provided to the processor is also significantly reduced.
  • clock speed of the processor 12 is not reduced when performance critical code is executed by the processor 12.
  • the performance critical code where clock speed is maximized is code starting from initial receipt of a servo interrupt until code is executed by the processor 12 causing a resulting current command signal to be sent to the NCM driver 10.
  • the increased power consumption of the processor 12 from the start of the interrupt to the sending of the current command is considered desirable because it reduces phase loss due to control delays, improving overall servo performance.
  • Fig. 2 illustrates a number of data tracks 51-53 programmed on a rotating disk.
  • the tracks 51-53 are subdivided, such as between lines 61 and 62, to form servo sectors, such as sector 63, where servo data is written on a track.
  • the servo sectors such as sector 63, occur periodically around the tracks 51-53.
  • the servo data read from servo sectors is received periodically, with equal time periods between reception of the servo sector bursts.
  • the servo wedges may not extend linearly from inner diameter (ID) to outer diameter (OD), but may be curved slightly in order to adjust for the trajectory of the head as it sweeps across the disk.
  • Fig. 3 shows a timing diagram illustrating a performance critical portion of the servo interrupt, namely the time from the start of the interrupt to the sending of the current command.
  • Different such critical servo interrupt portions are executed periodically during time periods 71 and 72.
  • the processor 12 typically receives a servo interrupt associated with a servo sector every time period ⁇ .
  • the period ⁇ is typically in the range of 20 to 200 ⁇ sec, and is influenced by the number of tracks per inch (TPI) which are recorded on the disk.
  • TPI tracks per inch
  • some systems can have multiple servo interrupts for each servo sector, using a commonly known concept called multi-rate control.
  • the processor 12 executes other non- servo interrupt code.
  • a first fast clock signal can be provided to the processor 12 between the start of the servo interrupt and the sending of the current command to improve disk drive performance, while a second slower clock signal can be provided to processor 12 when the rest of the servo interrupt code is executing to minimize power consumption by the processor 12.
  • the faster clock reduces the time between the position data written on the disk passing under the head, and output of the servo control to the actuator. This means that phase loss due to control delay is reduced, a factor in improving servo performance.
  • the clock can run slower at other times, including potentially the rest of the servo interrupt.
  • Fig. 4 is a timing diagram that divides the servo interrupt into two sections.
  • the first part, 81 illustrates the servo code execution time from the start of the interrupt to the sending of the current command. This is timing critical code and includes determining position and computing the current command signal.
  • the second part, 82 illustrates the servo code execution time from the output of the current command signal from the processor to the end of the servo interrupt. Processor speed is essential during the first part 81, but processor speed during the second part 82 is not as essential. Thus, after servo current command is sent from processor 12 to the NCM driver 10, processor speed is reduced in one embodiment of the present invention to minimize power consumption during the rest of the interrupt 82.
  • processor speed is again increased.
  • Code running as part of the interrupt increases and decreases the processor clock frequency as appropriate.
  • the interrupt portion 81 is shown as approximately one quarter of the total servo interrupt, the relative time in portion 81 and 82 can vary significantly.
  • the portion 81 accounts for a significant phase loss in the control system at the servo open loop crossover frequency (approximately 1 to 5 degrees), so increasing clock speed during the portion 81 provides a significant performance improvement with only a small increase in power.
  • processor power consumption is linearly reduced.
  • two or more different clock speeds may be used to optimize the tradeoff between minimizing power consumption and maximizing performance.
  • the processor speed is maximized when performance critical code is executed that is, in time, between the receipt of a read or write command through the host interface, such as the ATA interface, to code that is executed to cause a seek request to be sent.
  • performance critical code is executed that is, in time, between the receipt of a read or write command through the host interface, such as the ATA interface, to code that is executed to cause a seek request to be sent.
  • One aspect of the disk drive performance is to reduce the time between the receipt of the read or write command and the completion of such a command. The time from the receipt of the command and the start of the seek is a critical component of this overall time and thus performance. Consequently, increasing the processor clock frequency during the execution of this code can provide a significant increase in disk drive performance.
  • the system in accordance with the present invention contemplates use of a very low clock speed for a sleep mode when the drive is basically inoperative, hi accordance with the present invention, it is contemplated that clock signals with faster speeds be provided to the processor during processing of some code when design considerations dictate that speed is preferable over processor power consumption.
  • the present invention is described for use with hard disk drives for recording in magnetic media, it is understood that principles in accordance with the present invention can be used with optical disk drives.

Landscapes

  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Moving Of The Head To Find And Align With The Track (AREA)
  • Rotational Drive Of Disk (AREA)
  • Signal Processing For Digital Recording And Reproducing (AREA)

Abstract

Clock speed of the processor in a hard disk drive is controlled during run time to optimize the trade-off between minimizing power consumption and maximizing performance. Processor clock speed is increased during processing of code more performance critical to the disk drive system, while processor clock speed is reduced when less performance critical code is processed. An example of more critical code where processor clock speed is increased is the code executed by the processor from the start of a servo interrupt until output of resulting servo current command is provided from the processor to the actuator controller. To enable changing processor clock speed, an ASIC containing the disk drive processor is selected which provides the ability to switch clock rates of the processor during processor run time.

Description

OPTIMIZING PROCESSOR CLOCK FREQUENCY IN A HARD DISK DRIVE TO MINIMIZE POWER CONSUMPTION WHILE MAXIMIZING
PERFORMANCE
CLAIM FOR PRIORITY This application claims priority to U.S. Provisional Patent Application No. 60/436,752 filed December 27, 2002, U.S. Provisional Patent Application No. 60/436, 680 filed December 27, 2002, U.S. Non-Provisional Application No. 10/413,198 filed April 14, 2003, and U.S. Non-Provisional Application No. 10/413,017 filed April 14, 2003.
BACKGROUND Technical Field The present invention relates to the design of hard disk drives to minimize power consumption while maintaining performance levels. More particularly, the present invention relates a technique for minimizing power consumption by one or more processors controlling the disk drive.
Related Art
A hard disk drive assembly is a mass-storage device from which data may be read and/or written. Typically the hard disk drive includes one or more randomly accessible rotatable storage media, or disks upon which data is encoded. In a magnetic disk drive, the data is encoded as bits of information using magnetic field reversals grouped in tracks on the magnetic hard surface of rotating disks. A transducer head supported by an actuator arm is used to read data from or write data to the disks. A voice control motor (NCM) attached to the actuator controls positioning of the actuator, and thus the transducer head position over a disk. Data read from the disk or written to the disk is provided through circuitry to a processor. Servo position data read from the disk is processed by the processor, enabling the processor to provide servo current command signals to control the NCM for proper positioning of a transducer head relative to a disk When a hard drive system is intended to be mobile, and includes an internal battery, the system is typically set to operate at a low power level. With a low power, overall performance is typically sacrificed in return for maximizing battery life. For non-portable hard disk drives not requiring batteries, system power levels are not a significant issue and the system power levels can be set high to maximize performance.
One way to reduce power consumption is to reduce the core clock frequency of a component. Power varies approximately linearly with clock speed and by the square of voltage as evidenced by the following equation:
Power = (Total Capacitance x Frequency x Noltage2)/2
The operation frequency, and thus power consumption can be linearly adjusted by reducing the clock rate. Adjusting both clock rate and system voltage level can produce approximately cubic reductions in power consumption.
However, it is also desirable to increase the performance level of the system by increasing the processor clock frequency. For a processor of a hard disk drive intended for a battery operated portable device, the processor clock rate is set to facilitate a compromise between reducing power to maintain battery life and maintaining a desired level of system performance.
SUMMARY hi accordance with the present invention, disk drive processor speed is changed during run time to optimize the trade-off between minimizing power consumption and maximizing performance. Changing processor speed satisfies the general desire to keep the processor frequency low so that the power consumption is low, while maintaining some critical operations at a fast run time because they significantly affect system performance.
In accordance with the present invention, processor clock speed is modified such that different parts of code running on the processor execute at different speeds. In particular, processor speed for executing certain code is related to how much the code affects performance of the drive. Code that is critical to performance is set to run faster than code that is not critical to performance. One example of critical code is the code that starts from the assertion of the servo interrupt until the output of the servo current control signal from the processor to the NCM controller. In accordance with the present invention, during a time period between receipt of a servo interrupt and output of resulting servo current control information from the processor, the processor clock speed is maximized. To enable changing processor clock speed, an ASIC containing the processor is selected which provides the ability to switch clock rates of the processor during processor run time.
Another example of critical code is the code processed in a bottleneck between when the disk drive processor receives a command to transfer data, and when the processor starts the execution of a seek command. The seek command requires the actuator to move the head from the current track to a different track, and requires some time for the processor to generate, in part because the processor typically has to generate an appropriate destination from the transfer data command. This can result in a code bottleneck between the receipt of a transfer data command and start of the seek command.
BRIEF DESCRIPTION OF THE DRAWINGS Further details of the present invention are explained with the help of the attached drawings in which: Fig. 1 shows a block diagram of components of a hard disk drive configured to minimize power consumption in accordance with the present invention; and
Fig. 2 illustrates the subdivision of tracks programmed on a hard disk into servo sectors;
Fig. 3 shows a timing diagram illustrating the time from the start of the servo interrupt to the sending of the current command; and
Fig. 4 shows a diagram illustrating the time from the start of the servo interrupt to the sending of the current command as well as the time from the sending of the current command to the end of the servo interrupt.
DETAILED DESCRIPTION
Fig. 1 shows a block diagram of components of a hard disk drive system configured to minimize power consumption in accordance with the present invention. The hard disk drive includes a rotating disk 2 containing a magnetic medium for storing data in defined tracks. Data is written to or read from the storage medium using a transducer or read/write head 4 provided on an actuator
6. The actuator movement is controlled by a voice control motor (NCM) 8 made up of a magnet and a coil configured for receiving an external control signal.
Current is provided to the coil of the NCM to control the position of the actuator using a hard disk or NCM driver 10. The NCM driver 10 in turn receives current command signals from a processor 12, enabling the NCM driver 10 to apply an amount of current to the coil of the NCM 8 to position the actuator 6 over a desired track of the rotating disk 2.
The disk 2 contains multiple tracks where data is stored. The data is read from or written to the rotating disk 2 using the transducer head 4. The analog data read is provided through a read/write (R/W) pre-amplifier 14. The amplified read data is provided to the R/W channel 16, which includes circuitry to convert the data from analog to digital and decode the digital data to provide to the hard disk controller (HDC) 34. The R/W channel 16 further converts data received from the HDC to be written from digital to analog for providing through the R/W preamps 14 to transducer head 4. The data read includes servo data provided in digital form from the HDC 34 to the processor 12. Servo data provided to the processor 12 includes information indicating track positioning of the transducer head 4 over the rotating disk 2. The track positioning information indicates the track the transducer head 4 is placed over, as well as any misalignment of the transducer head 4 relative to a track. Servo data is recorded periodically along each track on the rotating disk 4 between other non-servo data. The real-time servo control algorithm is typically run on an interrupt basis on the processor, with the interrupt being triggered, for example by servo demodulation hardware typically provided in the HDC 34. The interrupt causes the processor to cease other functions it is performing and deal with the servo position data. The processor 12 determines track misalignment and computes a current command which is sent to the NCM driver 10 to correct for the track misalignment. This interrupt is typically initiated approximately when all the servo position information contained in the servo wedge is read into the ASIC 20. It is well known that reducing the time between the position information written on the disk and the subsequent current command improves servo performance. Thus, enhancing the processor performance during the time from the start of the interrupt to the sending of the current command at the expense of additional power consumption is typically desirable.
Also, if it is desired to read data from or write data to other tracks on the rotating disk 4, the processor 12 executes code which generates a target position consistent with the desired read or write data and sends a request to the servo code to move from the current position to the new target position. The request to move the head from one location to another is typically called a seek. Because it improves performance to minimize the time from the receipt of the read or write command to the start of the seek, enhancing processor performance during execution of this code at the expense of additional power consumption is typically desirable.
Processor 12 executes instructions acquired from a stored control program to control disk drive functions. During startup, the control program is embedded in flash memory, or other non-volatile memory and then either executed directly, or loaded into a random access memory RAM 19 connected to the processor 12 and executed. Various firmware routines are stored in memory locations for controlling the operation of the actuator 7 and spindle motor 30. Here, control programs include the instructions the processor 12 executes, and tables, parameters or arguments used during the execution of these programs.
The processor 12 also communicates with the HDC 34 which has access to components external to the hard disk drive system through an advanced technology attachment (ATA) interface bus 20. The ATA bus 20 is also referred to as an integrated drive electronics (IDE) bus, and although specifically shown as an ATA bus, may be another type of external component interface, such as an SCSI, in accordance with the present invention. The HDC 34 further provides access to additional DRAM memory 36. Control programs for the processor may reside in DRAM 36, or in RAM 19 directly accessible by the processor.
For a hard disk drive, application specific integration circuits (ASICs) have been created to integrate a number of circuit components onto a single chip. One such ASIC 26 is illustrated in Fig. 1. As shown, the ASIC 26 integrates the processor 12, RAM 19, R/W channel 16, HDC 34, DRAM 36, and ATA interface bus 20 all onto a single chip. The chip for disk drive control is often referred to as a system on a chip (SOC). Although components such as the NCM driver 10 and the processor 12 are shown to be included on the single ASIC 26, it is understood that the present invention contemplates that the components may similarly be included as separate non-integrated circuits, or the processing functions can be distributed to other components such as the HDC 34. Further, although a single processor 12 is shown, it is understood that the functions of processor 12 can be divided among multiple processors when desirable.
For components requiring a clock, a crystal oscillator 30 is provided external to the ASIC 26. Although a crystal oscillator is shown, other types of oscillators may be used. An oscillator input signal is typically provided to one or more phase locked loops (PLLs) on an ASIC. The PLLs include frequency dividers to convert the frequency from the oscillator to the desired frequency for individual components on the ASIC. For the ASIC 26 illustrated in Fig. 1, four such PLLs 21 -24 are shown.
On the ASIC 26, the PLLs 21-23 are shown providing a clock signal to the processor 12. Note that although the PLLs 21-23 are shown connected directly to the processor 12, many configurations are possible. For instance, the PLLs can be provided indirectly through the HDC 34 to the processor 12. The HDC 34 can then include a multiplexer controlled by the processor to select one of the PLL outputs to provide to the processor 12 at a time. In accordance with the present invention, code executing on the processor can select one of the desired clock signals depending on the frequency of operation desired. Code stored in the RAM 19, or other memory if present, selects different clock signals as desired. As an alternative to multiple PLLs 21-23, a single PLL, such as PLL 21, could be configured to provide the clock signal to the processor 12, with control signals provided to the PLL 21 to control its frequency division to selectively provide different clock signal frequencies to the processor 12. Multiple PLLs may, however, be desirable because of the time period required for a PLL to stabilize after its frequency divider is reset.
In accordance with the present invention, the clock signal frequency of the processor 12 is varied during processor run time to minimize power consumption, while maximizing performance. When clock frequency of the processor is reduced, power provided to the processor is also significantly reduced. To maximize performance, clock speed of the processor 12 is not reduced when performance critical code is executed by the processor 12.
In one embodiment, the performance critical code where clock speed is maximized is code starting from initial receipt of a servo interrupt until code is executed by the processor 12 causing a resulting current command signal to be sent to the NCM driver 10. The increased power consumption of the processor 12 from the start of the interrupt to the sending of the current command is considered desirable because it reduces phase loss due to control delays, improving overall servo performance. To illustrate where servo data is stored on a disk in one embodiment of the present invention Fig. 2 illustrates a number of data tracks 51-53 programmed on a rotating disk. The tracks 51-53 are subdivided, such as between lines 61 and 62, to form servo sectors, such as sector 63, where servo data is written on a track. As shown, the servo sectors, such as sector 63, occur periodically around the tracks 51-53. The servo data read from servo sectors is received periodically, with equal time periods between reception of the servo sector bursts. In a system where the actuator arm rotates about a pivot point such as a bearing, the servo wedges may not extend linearly from inner diameter (ID) to outer diameter (OD), but may be curved slightly in order to adjust for the trajectory of the head as it sweeps across the disk.
Fig. 3 shows a timing diagram illustrating a performance critical portion of the servo interrupt, namely the time from the start of the interrupt to the sending of the current command. Different such critical servo interrupt portions are executed periodically during time periods 71 and 72. The processor 12 typically receives a servo interrupt associated with a servo sector every time period τ. The period τ is typically in the range of 20 to 200 μsec, and is influenced by the number of tracks per inch (TPI) which are recorded on the disk. Increasing TPI tends to decrease the period τ and servo performance, while a decrease in TPI tends to increase the period τ and servo performance. It is understood that some systems can have multiple servo interrupts for each servo sector, using a commonly known concept called multi-rate control. Between execution of servo interrupt code, the processor 12 executes other non- servo interrupt code. With servo interrupt code periodically executing, in accordance with the present invention, a first fast clock signal can be provided to the processor 12 between the start of the servo interrupt and the sending of the current command to improve disk drive performance, while a second slower clock signal can be provided to processor 12 when the rest of the servo interrupt code is executing to minimize power consumption by the processor 12. The faster clock reduces the time between the position data written on the disk passing under the head, and output of the servo control to the actuator. This means that phase loss due to control delay is reduced, a factor in improving servo performance. The clock can run slower at other times, including potentially the rest of the servo interrupt.
Fig. 4 is a timing diagram that divides the servo interrupt into two sections. The first part, 81, illustrates the servo code execution time from the start of the interrupt to the sending of the current command. This is timing critical code and includes determining position and computing the current command signal. The second part, 82, illustrates the servo code execution time from the output of the current command signal from the processor to the end of the servo interrupt. Processor speed is essential during the first part 81, but processor speed during the second part 82 is not as essential. Thus, after servo current command is sent from processor 12 to the NCM driver 10, processor speed is reduced in one embodiment of the present invention to minimize power consumption during the rest of the interrupt 82. Upon initial receipt of a subsequent servo interrupt portion 81, processor speed is again increased. Code running as part of the interrupt increases and decreases the processor clock frequency as appropriate. Although the interrupt portion 81 is shown as approximately one quarter of the total servo interrupt, the relative time in portion 81 and 82 can vary significantly. The portion 81 accounts for a significant phase loss in the control system at the servo open loop crossover frequency (approximately 1 to 5 degrees), so increasing clock speed during the portion 81 provides a significant performance improvement with only a small increase in power.
As indicated previously, with a reduction in clock speed, processor power consumption is linearly reduced. For the embodiment described above, two or more different clock speeds may be used to optimize the tradeoff between minimizing power consumption and maximizing performance.
In another embodiment of the present invention, the processor speed is maximized when performance critical code is executed that is, in time, between the receipt of a read or write command through the host interface, such as the ATA interface, to code that is executed to cause a seek request to be sent. One aspect of the disk drive performance is to reduce the time between the receipt of the read or write command and the completion of such a command. The time from the receipt of the command and the start of the seek is a critical component of this overall time and thus performance. Consequently, increasing the processor clock frequency during the execution of this code can provide a significant increase in disk drive performance.
Depending on disk drive system requirements, it may be considered essential to process code other than code between the start of a servo interrupt and the sending of the current command or code between the receipt of a read or write command and the start of the seek at a fast clock speed without concern for power consumption. It may also be desirable to use intermediate clock speeds for some processing requirements. For instance, the system in accordance with the present invention contemplates use of a very low clock speed for a sleep mode when the drive is basically inoperative, hi accordance with the present invention, it is contemplated that clock signals with faster speeds be provided to the processor during processing of some code when design considerations dictate that speed is preferable over processor power consumption. Further, although the present invention is described for use with hard disk drives for recording in magnetic media, it is understood that principles in accordance with the present invention can be used with optical disk drives.
Although the present invention has been described above with particularity, this was merely to teach one of ordinary skill in the art how to make and use the invention. Many additional modifications will fall within the scope of the invention, as that scope is defined by the following claims.

Claims

What Is Claimed Is:
1. A storage apparatus comprising: a rotatable disk; a transducer; an actuator that supports the transducer, the actuator configured to receive a signal controlling the actuator to move the transducer relative to the disk; a processor coupled to transfer data to and from the magnetic media by the transducer and providing servo current command signals indicating actuator movement should occur; and a clock signal generation circuit connected to selectively provide one of a plurality of different clock signals having different clock rates to the processor, wherein a first one of the clock signals is provided having a first clock rate when first code to cause an operation of the disk drive system is processed by the processor, and wherein a second one of the clock signals is provided having a second clock rate which is less than the first clock rate after the first code is processed to limit power consumption of the disk drive system.
2. The storage apparatus of claim 1, wherein the first code ranges from initial receipt of a servo interrupt until a resulting servo current command signal is provided from the processor to cause movement of the actuator.
3. The storage apparatus of claim 1, wherein the clock signal generation circuit comprises: a first phase locked loop configured for receiving a reference clock signal and generating the first clock signal having the first clock rate; a second phase locked loop configured for receiving the reference clock signal and generating the second clock signal having the second clock rate; and a clock controller connected to the first and second phase locked loops, the clock controller configured for selectively providing one of the first and second clock signals as the clock signal of the processor.
4. The storage apparatus of claim 3, wherein the clock controller is integrated with the processor.
5. The storage apparatus of claim 1, wherein the clock signal generation circuit comprises: a phase locked loop having a clock signal input for connecting to an oscillator operating at a fixed frequency, the phase locked loop having a control input and an output, the control input for receiving a signal enabling the phase locked loop output to provide a clock signal at a predetermined frequency relative to the clock signal input; and a clock controller connected to the phase locked loop, the clock controller providing the control input to the phase locked loop to selectively set the output clock frequency to one of the first and second clock rates.
6. The storage apparatus of claim 1, wherein the first code ranges from receipt of a data request code, until a resulting track seeking servo current command signal is provided from the processor to control movement of the actuator.
7. The storage apparatus of claim 1, further comprising: a memory for storing data which can be read by the processor, the data including code for causing the processor to select the first clock signal as a clock signal used by the processor when the first code is processed by the processor, and to select the second clock signal as a clock signal used by the processor after the resulting servo current command signal is provided from the processor.
8. The storage apparatus of claim 7, wherein the memory is a random access memory.
9. A disk drive system comprising: a rotatable disk containing magnetic media with data recordable in defined tracks; a transducer; an actuator arm that supports the transducer; a voice control motor (NCM) connected to the actuator arm to cause movement of the actuator arm, the NCM configured to receive a signal to move the actuator arm so that the transducer is moved relative to the disk; a processor coupled to receive servo data read from the magnetic media tracks using the transducer and to provide current command signals indicating actuator movement should occur; a NCM control circuit configured to receive the servo current command signals from the processor and to provide current to the NCM in response to control movement of the actuator; and a clock signal generation circuit connected to selectively provide one of a plurality of different clock signals having different clock rates to the processor, wherein a first one of the clock signals is provided having a first clock rate when a servo interrupt code is initially processed by the processor until a resulting servo current command signal is provided from the processor to the NCM control circuit, and wherein a second one of the clock signals is provided having a second clock rate less which is less than the first clock rate after the resulting servo current command signal is provided to the NCM control circuit to limit power consumption of the processor.
10. A disk drive system comprising: a rotatable disk containing magnetic media with data recordable in defined tracks; a transducer; an actuator arm that supports the transducer; a voice control motor (NCM) comiected to the actuator arm to cause movement of the actuator arm, the NCM configured to receive a signal to move the actuator arm so that the transducer is moved relative to the disk; a processor coupled to receive servo data read from the magnetic media tracks using the transducer and to provide servo current command signals indicating actuator movement should occur; a NCM control circuit configured to receive the servo current command signals from the processor and to provide current to the NCM in response to control movement of the actuator; and a clock signal generation circuit connected to selectively provide one of a plurality of different clock signals having different clock rates to the processor, wherein a first one of the clock signals is provided having a first clock rate when a data request code is initially processed by the processor until a resulting track seeking servo current command signal is provided from the processor to the NCM control circuit, and wherein a second one of the clock signals is provided having a second clock rate less which is less than the first clock rate after the resulting track seeking servo current command signal is provided by the processor.
11. A disk drive system comprising: a processor coupled to read data from and writing data to a rotatable disk; and a clock signal generating means for providing at least two different clock signals, each having a different clock rate, wherein a first one of the clock signals is provided to the processor when first code is processed, and wherein a second one of the clock signals is provided when second code is processed, wherein the second clock signal has a clock rate less than the first clock signal to limit power consumption of the processor.
12. A method of controlling power consumption in a disk drive, the method comprising the steps of: controlling clock speed of a processor to operate at a first rate when the processor processes first code to control an operation of the disk drive; and controlling clock speed of the processor to operate at a second rate when the processor is processing second code to limit power consumption of the processor.
13. The method of claim 12 wherein the first code comprises code starting from a start of a servo interrupt until a servo current command signal is provided from the processor to a hard disk controller to control position of the actuator.
14. The method of claim 12 wherein the first code comprises code ranging from a start of a data read code to code executed to cause a current command signal to be provided from a processor to a hard disk controller to cause a track seeking operation.
15. The method of claim 12 wherein the second rate is applied when servo information is processed enabling the processor to set up for receipt of subsequent servo data.
PCT/US2003/041094 2002-12-27 2003-12-22 Optimizing processor clock frequency in a hard disk drive to minimize power consumption while maximizing performance WO2004061604A2 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
AU2003300305A AU2003300305A1 (en) 2002-12-27 2003-12-22 Optimizing processor clock frequency in a hard disk drive to minimize power consumption while maximizing performance

Applications Claiming Priority (8)

Application Number Priority Date Filing Date Title
US43668002P 2002-12-27 2002-12-27
US43675202P 2002-12-27 2002-12-27
US60/436,752 2002-12-27
US60/436,680 2002-12-27
US10/413,198 US7089432B2 (en) 2002-12-27 2003-04-14 Method for operating a processor at first and second rates depending upon whether the processor is executing code to control predetermined hard drive operations
US10/413,017 US7072138B2 (en) 2002-12-27 2003-04-14 Apparatus for optimizing processor clock frequency in a hard disk drive to minimize power consumption while maximizing performance
US10/413,017 2003-04-14
US10/413,198 2003-04-14

Publications (2)

Publication Number Publication Date
WO2004061604A2 true WO2004061604A2 (en) 2004-07-22
WO2004061604A3 WO2004061604A3 (en) 2004-12-23

Family

ID=32719476

Family Applications (1)

Application Number Title Priority Date Filing Date
PCT/US2003/041094 WO2004061604A2 (en) 2002-12-27 2003-12-22 Optimizing processor clock frequency in a hard disk drive to minimize power consumption while maximizing performance

Country Status (2)

Country Link
AU (1) AU2003300305A1 (en)
WO (1) WO2004061604A2 (en)

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
EP1746603A3 (en) * 2005-07-22 2010-04-07 STMicroelectronics, Inc. System partitioning for hard disk drive electronics

Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5586308A (en) * 1994-10-19 1996-12-17 Advanced Micro Devices, Inc. Clock control unit responsive to a power management state for clocking multiple clocked circuits connected thereto
US5691948A (en) * 1995-06-08 1997-11-25 Fujitsu Limited Memory apparatus

Patent Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5586308A (en) * 1994-10-19 1996-12-17 Advanced Micro Devices, Inc. Clock control unit responsive to a power management state for clocking multiple clocked circuits connected thereto
US5691948A (en) * 1995-06-08 1997-11-25 Fujitsu Limited Memory apparatus

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
EP1746603A3 (en) * 2005-07-22 2010-04-07 STMicroelectronics, Inc. System partitioning for hard disk drive electronics

Also Published As

Publication number Publication date
AU2003300305A1 (en) 2004-07-29
AU2003300305A8 (en) 2004-07-29
WO2004061604A3 (en) 2004-12-23

Similar Documents

Publication Publication Date Title
US8111476B2 (en) Disk drive spin control
US7089432B2 (en) Method for operating a processor at first and second rates depending upon whether the processor is executing code to control predetermined hard drive operations
US20050174678A1 (en) Stepping power consumption levels in a hard disk drive to maximize performance while minimizing power consumption
US6657811B1 (en) Mobile device and disk drive having a seek current profile responsive to an environment signal
US6122131A (en) Adaptively-controlled disk drive assembly
US8433937B1 (en) Automated transitions power modes while continuously powering a power controller and powering down a media controller for at least one of the power modes
KR101340715B1 (en) Data storage drive with reduced power consumption
US6067206A (en) Method and apparatus to compensate for servo wedge rotational offset after a head switch
JP2578297B2 (en) Direct access storage device and its operation method
US20050144491A1 (en) Variable power consumption levels in a hard disk drive
US7072138B2 (en) Apparatus for optimizing processor clock frequency in a hard disk drive to minimize power consumption while maximizing performance
JPH0973705A (en) Magnetic recorder
JP2002298307A (en) Data storage device, write current control circuit and write circuit control method
US20090015960A1 (en) Magnetic disk drive and magnetic disk medium
US6785080B1 (en) Method and apparatus for providing a variable rate oversampling digital filter for resonance compensation in disk drive servo control systems
US7468590B1 (en) Method and apparatus for initializing operation of a disk drive
US6332196B1 (en) Disk storage apparatus and power supply control method for the same
JPH09288804A (en) Recording current control circuit and method for magnetic recorder
WO2004061604A2 (en) Optimizing processor clock frequency in a hard disk drive to minimize power consumption while maximizing performance
US6747832B2 (en) Disk apparatus and head position control method
JPH11317035A (en) Disk storage device and head positioning control system applied to the device
CN108665908B (en) Magnetic disk apparatus, controller and seek method
US20100268972A1 (en) Method and apparatus for controlling clock frequency
JPH06342345A (en) Disk drive and method for formatting magnetic disk
JP2003108314A (en) Data storage device, computer device, write data processing device and write data processing method

Legal Events

Date Code Title Description
AK Designated states

Kind code of ref document: A2

Designated state(s): AE AG AL AM AT AU AZ BA BB BG BR BW BY BZ CA CH CN CO CR CU CZ DE DK DM DZ EC EE EG ES FI GB GD GE GH GM HR HU ID IL IN IS JP KE KG KP KR KZ LC LK LR LS LT LU LV MA MD MG MK MN MW MX MZ NI NO NZ OM PG PH PL PT RO RU SC SD SE SG SK SL SY TJ TM TN TR TT TZ UA UG UZ VC VN YU ZA ZM ZW

AL Designated countries for regional patents

Kind code of ref document: A2

Designated state(s): BW GH GM KE LS MW MZ SD SL SZ TZ UG ZM ZW AM AZ BY KG KZ MD RU TJ TM AT BE BG CH CY CZ DE DK EE ES FI FR GB GR HU IE IT LU MC NL PT RO SE SI SK TR BF BJ CF CG CI CM GA GN GQ GW ML MR NE SN TD TG

121 Ep: the epo has been informed by wipo that ep was designated in this application
WWE Wipo information: entry into national phase

Ref document number: 20038A9562X

Country of ref document: CN

122 Ep: pct application non-entry in european phase
NENP Non-entry into the national phase

Ref country code: JP

WWW Wipo information: withdrawn in national office

Country of ref document: JP