Method to detect power loss through data storage device spindle speed

Information

  • Patent Grant
  • 9437237
  • Patent Number
    9,437,237
  • Date Filed
    Friday, February 20, 2015
    9 years ago
  • Date Issued
    Tuesday, September 6, 2016
    7 years ago
Abstract
A method for detecting power loss on a data storage device (DSD) includes: as part of a device initialization of the DSD, measuring a rotational speed of a spindle of a rotating media; comparing the measured spindle rotational speed to a threshold rotational speed value; and based on the comparison, determining whether the device initialization has been triggered due to a power-on reset of the DSD.
Description
BACKGROUND

1. Technical Field


Apparatuses and methods consistent with the present inventive concept relate to detecting loss of power in a data storage device (DSD), and more particularly to detecting power loss in a DSD based on rotational speed of a spindle of a rotating media.


2. Related Art


When connected to a host system, a DSD may experience failures related to power loss events. For example, a write splice, whereby a write operation to the DSD storage media is interrupted part way through the operation, may occur as a result of a sudden power loss (i.e., a power glitch or power drop-out). The power loss may be due to faulty power supplies, unstable voltage supply lines, defective or loose connectors, etc. The power loss may be only milliseconds in duration but may be severe enough to cause the DSD to initiate power-on reset (PoR).


Users of the host system (e.g., laptop computers, desktop computers, factory test equipment, etc.) may not be aware of the power loss since the DSD will automatically reconnect and reinitialize. In order to provide feedback to host system users, power loss events should be counted. Features currently exist that detect low power supply voltages to prevent the write operations from occurring; however, an abrupt power loss will not be logged as an event.





BRIEF DESCRIPTION OF THE DRAWINGS

Aspects and features of the present inventive concept will be more apparent by describing example embodiments with reference to the accompanying drawings, in which:



FIG. 1 is a block diagram illustrating a data storage device (DSD) according to various embodiments;



FIG. 2 is a graph illustrating a relationship of spindle rotational speed with respect to time from power loss for a DSD according to various embodiments;



FIG. 3A is a flow chart illustrating a method according to various embodiments;



FIG. 3B is a flow chart illustrating a method according to various embodiments;



FIG. 4A is a flow chart illustrating a method of operation of an apparatus according to various embodiments; and



FIG. 4B is a flow chart illustrating a method of operation of an apparatus according to various embodiments.





DETAILED DESCRIPTION

While certain embodiments are described, these embodiments are presented by way of example only, and are not intended to limit the scope of protection. The 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 example methods and systems described herein may be made without departing from the scope of protection.


Overview


Sudden power loss due to, for example faulty power supplies, unstable voltage supply lines, defective or loose connectors, etc., may be only milliseconds in duration but may be severe enough to cause the DSD to initiate a PoR. Rotational speed of a spindle driving rotating media may differ during DSD device initialization between a power-up of a DSD from standstill and rotational speed of the spindle caused by sudden power loss. The difference in spindle rotational speed may be used to differentiate DSD initiated resets from sudden power loss events.


Detecting Power Loss Through Spindle Speed



FIG. 1 is a block diagram illustrating a data storage device (DSD) 100 according to various embodiments. Referring to FIG. 1, the DSD may include storage media 110, a spindle 120, a motor 130, a rotational speed sensor 140, a power supply 150, a control unit 160, a power-loss counter 170, a PoR counter 180, and nonvolatile storage 190.


The spindle 120 may be connected to the motor 130 and the storage media 110 to cause the storage media 110 to rotate. The rotational speed sensor 140 may sense a rotational speed of the spindle 120 and provide a signal to the control unit 160. One of ordinary skill in the art will appreciate that the rotational speed sensor 140 may be any type of rotational speed sensor known to those in the art without departing from the scope of the present inventive concept.


The control unit 160 may determine the rotational speed of the spindle 120 based at least in part on the signal from the rotational speed sensor 140. The control unit 160 may control overall operation of the DSD 100 and its components. The control unit 160 may be, for example, but not limited to, a microcontroller, microprocessor, or other programmable device. The control unit 160 may include internal storage 162, for example, but not limited to, volatile and/or nonvolatile storage. The control unit 160 may include a threshold value counter 164.


The power-loss counter 170 may be incremented to count power loss events determined by the control unit 160. The power-loss counter 170 may be implemented as part of the control unit 160 or may be implemented as circuitry separate from the control unit 160. One of ordinary skill in the art will appreciate that the power-loss counter 170 may be implemented as hardware, software, firmware, or a combination thereof without departing from the scope of the present inventive concept.


The PoR counter 180 may be incremented to count power-on reset events. The PoR counter 180 may be implemented as part of the control unit 160 or may be implemented as circuitry separate from the control unit 160. One of ordinary skill in the art will appreciate that the PoR counter 180 may be implemented as hardware, software, firmware, or a combination thereof without departing from the scope of the present inventive concept.


The nonvolatile storage 190 may store programs necessary for operation of the DSD 100 that are executed by the control unit 160, as well as application data and system data, for example, but not limited to, data generated by the power-loss counter 170 and/or PoR counter 180.


The power supply 150 may provide electrical power for the DSD.



FIG. 2 is a graph 200 illustrating a relationship of spindle rotational speed (Y axis, in rotations per minute (RPM)) with respect to time from power loss (X axis, in milliseconds) for a DSD according to various embodiments. Referring to FIGS. 1 and 2, during normal operation, the spindle 120 will rotate at a substantially constant operational rotational speed 210 (5,400 RPM in the example shown). Spindle 120 rotational speed 220 may decrease when electrical power is removed from the DSD 100. One of ordinary skill in the art will appreciate that the illustrated line 210 representing operational rotational speed of the spindle 120 and the illustrated curve 220 representing rotational speed of the spindle 120 are only exemplary, and various operational rotational speeds and spindle rotational speeds may apply to various embodiments without departing from the scope of the present inventive concept.


Rotational speed 220 of the spindle 120 may differ during DSD 100 device initialization when the initialization is caused by a cold boot (i.e., a DSD 100 powering up from standstill) as compared to when the initialization is caused by a reset caused by sudden power loss. Sudden power loss may result in higher rotational speed 220 of the spindle 120 at an initial point of DSD 100 device initialization. For example, as shown in FIG. 2, the rotational speed only decreases slightly, for example, to about 5,000 RPM about 55 ms from power loss. So if a DSD experiences a power glitch or interruption of short duration, when power is restored and the DSD undergoes an initialization, the rotational speed may still be relatively high and close to the operational speed. Thus, rotational speed 220 of the spindle 120 may be measured during an initial portion of the DSD 100 device initialization path to determine the cause of the initialization. The DSD 100 device initialization path is normally only taken only once during a PoR of the DSD 100 or during DSD 100 initiated resets. Device initialization caused by DSD 100 initiated resets may be differentiated from device initialization caused by PoR of the DSD 100, through measuring the rotational speed. During device initialization caused by DSD 100 initiated resets, system variables may be preserved and may be evaluated to determine that device initialization was caused by a DSD 100 initiated event.



FIG. 3A is a flow chart illustrating a method 300 according to various embodiments. Referring to FIGS. 1-3A, as part of a device initialization of the DSD 100, rotational speed of the spindle 120 may be measured (305). For example, the rotational speed sensor 140 may sense the rotational speed of the spindle 120 and transmit a signal proportional to the rotational speed to the control unit 160. The control unit 160 may determine the rotational speed of the spindle 120 based on the signal received from the rotational speed sensor 140.


The control unit 160 may compare the measured rotational speed of the spindle 120 to a threshold rotational speed value (310). The threshold rotational speed value may be determined based on a rotational speed difference of the spindle 120 from an operational rotational speed 210 of the spindle 120 (see FIG. 2), and may be stored in the nonvolatile storage 190 and/or the internal storage 162 of the control unit 160. For example, a threshold rotational speed value of 5,000 RPM may be used. The threshold rotational speed value may be adjustable via a value stored in the nonvolatile storage 190 and/or the internal storage 162 of the control unit 160. Based on the comparison of the measured rotational speed of the spindle 120 to the threshold rotational speed value, the control unit 160 may determine if the DSD 100 device initialization was triggered by PoR of the DSD 100 (315). Following up on the example set forth above, a measured rotational speed over the threshold rotational speed value of 5,000 RPM may indicate that the device initialization was triggered by PoR.



FIG. 3B is a flow chart illustrating a method 350 according to various embodiments. Referring to FIGS. 1, 2 and 3B, as part of a device initialization of the DSD 100, rotational speed of the spindle 120 may be measured (355). For example, the rotational speed sensor 140 may sense the rotational speed of the spindle 120 and transmit a signal proportional to the rotational speed to the control unit 160. The control unit 160 may determine the rotational speed of the spindle 120 based on the signal received from the rotational speed sensor 140.


The control unit 160 may compare the measured rotational speed of the spindle 120 to a threshold rotational speed value (310). The threshold rotational speed value may be determined based on a rotational speed difference of the spindle 120 from an operational rotational speed 210 of the spindle 120 (see FIG. 2), The threshold rotational speed value may be adjustable via a value stored in the nonvolatile storage 190 and/or the internal storage 162 of the control unit 160. The control unit 160 may determine if the measured rotational speed of the spindle 120 is equal to or greater than a threshold rotational speed value (365).


If the control unit 160 determines that the measured rotational speed of the spindle 120 is equal to or greater than a threshold rotational speed value (365—Y), the control unit 160 may determine that the DSD 100 device initialization was triggered by a power loss event (370). The control unit 160 may increment a count of the power-loss counter 170 (370) indicating that the DSD 100 device initialization was triggered by the power loss event.


The control unit 160 may cause the count of the power-loss counter 170 to be stored in the nonvolatile storage 190. Alternatively or additionally, the control unit 160 may cause the count of the power-loss counter 170 to be stored on the rotating storage media 110.


If the control unit 160 determines that the measured rotational speed of the spindle 120 is not equal to or greater than a threshold rotational speed value (365—N), the control unit 160 may determine that the DSD 100 device initialization was triggered by a PoR event (380). The control unit 160 may increment a count of the PoR counter 180 (385) indicating that the DSD 100 device initialization was triggered by the PoR event. In other embodiments, if the measured rotational speed is equal to the threshold, the 365-N path is taken instead.


In addition to detecting device initialization caused by PoR, measuring rotational speed may also be useful for estimating the duration of the power loss/interruption, as further illustrated by FIGS. 4A and 4B. FIG. 4A is a flow chart illustrating a method of operation 400 of an apparatus, for example, but not limited to, the DSD 100, according to various embodiments. Referring to FIGS. 1, 2 and 4A, as part of a device initialization of the DSD 100, rotational speed of the spindle 120 may be measured (405). For example, the rotational speed sensor 140 may sense the rotational speed of the spindle 120 and transmit a signal proportional to the rotational speed to the control unit 160. The control unit 160 may determine the rotational speed of the spindle 120 based on the signal received from the rotational speed sensor 140.


The control unit 160 may compare the measured rotational speed of the spindle 120 to a plurality of successively lower threshold rotational speed values corresponding to successively longer time durations (410). The threshold rotational speed values may be determined based on rotational speed differences of the spindle 120 from an operational rotational speed 210 of the spindle 120 (see FIG. 2), and may be stored in the nonvolatile storage 190 and/or the internal storage 162 of the control unit 160. The threshold rotational speed values may be adjustable via values stored in the nonvolatile storage 190 and/or the internal storage 162 of the control unit 160. Based on the comparison of the measured rotational speed of the spindle 120 to the successively lower threshold rotational speed values, the control unit 160 may determine a power loss duration for a power loss event (415). As shown in FIG. 2, there is a relationship (e.g., curve 220) between the rotational speed and the duration of power loss. Such a relationship may be determined by characterization of the DSD based on observation under a power loss condition. Thus, once such relationship is known/characterized, a series of threshold rotational speed values may be set accordingly, with corresponding power loss durations set based on the relationship (e.g., stored as a look up table or as a function). In one embodiment, when the successive comparisons as described above are made, the first comparison at which the measured rotational speed exceeds or equals to a threshold rotational value of the series, may indicate an approximate power loss duration.



FIG. 4B is a flow chart illustrating a method of operation 450 of an apparatus, for example, but not limited to, the DSD 100, according to various embodiments. Referring to FIGS. 1, 2 and 4B, as part of a device initialization of the DSD 100, rotational speed of the spindle 120 may be measured (455). For example, the rotational speed sensor 140 may sense the rotational speed of the spindle 120 and transmit a signal proportional to the rotational speed to the control unit 160. The control unit 160 may determine the rotational speed of the spindle 120 based on the signal received from the rotational speed sensor 140.


The control unit 160 may initialize the threshold value counter 164 (460). The control unit 160 may compare the measured rotational speed of the spindle 120 to a minimum threshold rotational speed value (465). If the control unit 160 determines that the measured rotational speed of the spindle 120 is less than a minimum threshold rotational speed value (465—Y), the control unit 160 may determine that the DSD 100 device initialization was triggered by a PoR event and may increment a count of the PoR counter 180 (470) indicating that the DSD 100 device initialization was triggered by the PoR event.


If the control unit 160 determines that the measured rotational speed of the spindle 120 is not less than a minimum threshold rotational speed value (465—N), the control unit 160 may compare the measured rotational speed of the spindle 120 to a threshold speed value corresponding to the count of the threshold value counter 164 (480).


If the control unit 160 determines that the measured rotational speed of the spindle 120 is not greater than the threshold speed value corresponding to the count of threshold value counter 164 (480—N), the control unit 160 may increment the count of the threshold value counter 164 (485). The control unit 160 may compare the measured rotational speed of the spindle 120 to a next threshold speed value corresponding to the threshold value counter 164 (475). The control unit 160 may repeat compare (475), determine (480), and increment (485) operations for successively lower threshold rotational speed values corresponding to successively longer time durations that correspond to the count of the threshold value counter 164. As illustrated in FIG. 2, the rotational speed of the spindle 120 decreases with increasing time duration from power loss. The successively lower threshold rotational speed values and the minimum threshold rotational speed value may be determined based on rotational speed differences of the spindle 120 from an operational rotational speed 210 of the spindle 120 (see FIG. 2), and may be stored in the nonvolatile storage 190 and/or the internal storage 162 of the control unit 160.


If the control unit 160 determines that the measured rotational speed of the spindle 120 is greater than a threshold speed value corresponding to the count of the threshold value counter 164 (480—Y), the control unit 160 may store a time duration corresponding to a threshold speed value immediately preceding the threshold speed value corresponding to the count of the threshold value counter 164 (490). The control unit 160 may increment the count of the power-loss counter 170 (495).


The control unit 160 may cause the time duration and the count of the power-loss counter 170 to be stored in the nonvolatile storage 190. Alternatively or additionally, the control unit 160 may cause the time duration and the count of the power-loss counter 170 to be stored on the rotating storage media 110.


One of ordinary skill in the art will appreciate that the operations described with respect to FIGS. 3A, 3B, 4A, and 4B may be implemented as a non-transitory computer readable medium having stored therein instructions for executing the described operations.


While certain embodiments have been described, these embodiments have been presented by way of example only, and are not intended to limit the scope of the protection. The methods and systems described herein may be embodied in a variety of other forms. Various omissions, substitutions, and/or changes in the form of the example methods and systems described herein may be made without departing from the spirit of the protection.


The accompanying claims and their equivalents are intended to cover such forms or modifications as would fall within the scope and spirit of the protection. For example, the example systems and methods disclosed herein can be applied to hard disk drives, hybrid hard drives, and the like. In addition, other forms of storage, for example, but not limited to, DRAM or SRAM, battery backed-up volatile DRAM or SRAM devices, EPROM, EEPROM memory, etc., may additionally or alternatively be used. As another example, the various components illustrated in the figures may be implemented as software and/or firmware on a processor, ASIC/FPGA, or dedicated hardware. Also, the features and attributes of the specific example embodiments disclosed above may be combined in different ways to form additional embodiments, all of which fall within the scope of the present disclosure.


Although the present disclosure provides certain example embodiments and applications, other embodiments that are apparent to those of ordinary skill in the art, including embodiments which do not provide all of the features and advantages set forth herein, are also within the scope of this disclosure. Accordingly, the scope of the present disclosure is intended to be defined only by reference to the appended claims.

Claims
  • 1. A method for detecting power loss on a data storage device (DSD), the method comprising: as part of a device initialization of the DSD, measuring a rotational speed of a spindle of a rotating media;comparing the measured spindle rotational speed to a threshold rotational speed value; andbased on the comparison, determining whether the device initialization has been triggered due to a power-on reset of the DSD,wherein the method is performed under the control of a processor.
  • 2. The method of claim 1, further comprising: in response to a determination that the measured spindle rotational speed is equal to or greater than the threshold rotational speed value, incrementing a count of a power-loss counter.
  • 3. The method of claim 2, wherein the count of the power-loss counter is stored in nonvolatile storage.
  • 4. The method of claim 2, wherein the count of the power-loss counter is stored on the rotating media.
  • 5. The method of claim 1, further comprising: in response to a determination that the measured spindle rotational speed is less than the threshold rotational speed value, incrementing a count of a power-on reset counter.
  • 6. The method of claim 1, wherein the threshold rotational speed value is based on a rotational speed difference from an operational rotational speed of the spindle.
  • 7. The method of claim 1, wherein the threshold rotational speed value is adjustable.
  • 8. A data storage device (DSD), comprising: rotating media;a spindle configured to cause the rotating media to rotate;a rotational speed sensor configured to sense a rotational speed of the spindle as part of a device initialization of the DSD;a power-loss counter configured to count power-loss events; anda control unit configured to:determine the rotational speed of the spindle based on a signal from the rotational speed sensor;compare the determined rotational speed of the spindle to a threshold rotational speed value; andbased on the comparison, determine whether the device initialization has been triggered due to a power-on reset of the DSD.
  • 9. The DSD of claim 8, wherein in response to a determination that the spindle rotational speed is equal to or greater than the threshold rotational speed value, the control unit is further configured to increment a count of the power-loss counter.
  • 10. The DSD of claim 9, further comprising: nonvolatile storage,wherein the control unit is further configured to store the count of the power-loss counter in the nonvolatile storage.
  • 11. The DSD of claim 9, wherein the control unit is further configured to store the count of the power-loss counter on the rotating media.
  • 12. The DSD of claim 8, further comprising: a power-on reset counter,wherein in response to a determination that the spindle rotational speed is less than the threshold rotational speed value, the control unit is further configured to increment a count of the power-on reset counter.
  • 13. A non-transitory computer readable medium having stored therein a program for making a processor execute a method for detecting power loss on a data storage device (DSD), said program including executable instructions for performing operations comprising: as part of a device initialization of the DSD, measuring by the processor a rotational speed of a spindle of a rotating media;comparing by the processor the measured spindle rotational speed to a threshold rotational speed value; andbased on the comparison, determining by the processor whether the device initialization has been triggered due to a power-on reset of the DSD.
  • 14. The non-transitory computer readable medium having stored therein a program as defined in claim 13, the program further comprising executable instructions for performing operations including: in response to a determination that the spindle rotational speed is equal to or greater than the threshold rotational speed value, incrementing a count of a power-loss counter.
  • 15. The non-transitory computer readable medium having stored therein a program as defined in claim 14, the program further comprising executable instructions for performing operations including: storing the count of the power-loss counter in nonvolatile storage.
  • 16. The non-transitory computer readable medium having stored therein a program as defined in claim 14, the program further comprising executable instructions for performing operations including: storing the count of the power-loss counter on the rotating media.
  • 17. The non-transitory computer readable medium having stored therein a program as defined in claim 13, the program further comprising executable instructions for performing operations including: in response to a determination that the spindle rotational speed is less than the threshold rotational speed value, incrementing a count of a power-on reset counter.
  • 18. The non-transitory computer readable medium having stored therein a program as defined in claim 13, the program further comprising executable instructions for performing operations including: determining the threshold rotational speed value based on a rotational speed difference from an operational rotational speed of the spindle.
  • 19. An apparatus for detecting power loss duration on a data storage device (DSD), the apparatus comprising: a control unit configured to, as part of a device initialization of the DSD:measure a rotational speed of a spindle of a rotating media;compare the measured spindle rotational speed to a plurality of successively lower threshold rotational speed values corresponding to successively longer time durations; anddetermine a power loss duration based on comparisons of the measured spindle rotational speed with the plurality of successively lower threshold rotational speed values.
  • 20. The apparatus of claim 19, wherein the control unit is further configured to: in response to a determination that the measured spindle rotational speed is greater than one of the successively lower threshold rotational speed values:store a time duration corresponding to an immediately preceding threshold rotational speed value as a power loss duration, andincrement a count of a power-loss counter.
  • 21. The apparatus of claim 20, wherein the control unit is further configured to store the count of the power-loss counter in nonvolatile storage.
  • 22. The apparatus of claim 20, wherein the control unit is further configured to store the count of the power-loss counter on the rotating media.
  • 23. The apparatus of claim 19, wherein the control unit is further configured to: in response to a determination that the measured spindle rotational speed is less than a minimum threshold rotational speed value, incrementing a count of a power-on reset counter.
  • 24. The apparatus of claim 19, wherein the successively lower threshold rotational speed values are based on rotational speed differences from an operational rotational speed of the spindle.
US Referenced Citations (332)
Number Name Date Kind
4495621 Nakagomi et al. Jan 1985 A
5307439 Enami Apr 1994 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
6639749 Kazmierczak 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
6751079 Bretschneider Jun 2004 B2
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
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 et al. Feb 2008 B1
7333280 Lifchits et al. Feb 2008 B1
7333290 Kupferman Feb 2008 B1
7339761 Tu et al. Mar 2008 B1
7365932 Bennett Apr 2008 B1
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
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
7660067 Ji et al. Feb 2010 B1
7663835 Yu et al. Feb 2010 B1
7675707 Liu et al. Mar 2010 B1
7679854 Narayana et al. Mar 2010 B1
7688534 McCornack Mar 2010 B1
7688538 Chen et al. Mar 2010 B1
7688539 Bryant et al. Mar 2010 B1
7697233 Bennett et al. Apr 2010 B1
7701661 Bennett Apr 2010 B1
7710676 Chue May 2010 B1
7715138 Kupferman May 2010 B1
7729079 Huber Jun 2010 B1
7733189 Bennett Jun 2010 B1
7746592 Liang et al. Jun 2010 B1
7746594 Guo et al. Jun 2010 B1
7746595 Guo et al. Jun 2010 B1
7760461 Bennett Jul 2010 B1
7800853 Guo et al. Sep 2010 B1
7800856 Bennett et al. Sep 2010 B1
7800857 Calaway et al. Sep 2010 B1
7839591 Weerasooriya et al. Nov 2010 B1
7839595 Chue et al. Nov 2010 B1
7839600 Babinski et al. Nov 2010 B1
7843662 Weerasooriya et al. Nov 2010 B1
7852588 Ferris et al. Dec 2010 B1
7852592 Liang et al. Dec 2010 B1
7864481 Kon et al. Jan 2011 B1
7864482 Babinski et al. Jan 2011 B1
7869155 Wong Jan 2011 B1
7876522 Calaway et al. Jan 2011 B1
7876523 Panyavoravaj et al. Jan 2011 B1
7916415 Chue Mar 2011 B1
7916416 Guo et al. Mar 2011 B1
7916420 McFadyen et al. Mar 2011 B1
7916422 Guo et al. Mar 2011 B1
7929238 Vasquez Apr 2011 B1
7961422 Chen et al. Jun 2011 B1
8000053 Anderson Aug 2011 B1
8031423 Tsai et al. Oct 2011 B1
8054022 Ryan et al. Nov 2011 B1
8059357 Knigge et al. Nov 2011 B1
8059360 Melkote et al. Nov 2011 B1
8072703 Calaway et al. Dec 2011 B1
8077428 Chen et al. Dec 2011 B1
8078901 Meyer et al. Dec 2011 B1
8081395 Ferris Dec 2011 B1
8085020 Bennett Dec 2011 B1
8116023 Kupferman Feb 2012 B1
8145934 Ferris et al. Mar 2012 B1
8179626 Ryan et al. May 2012 B1
8189286 Chen et al. May 2012 B1
8213106 Guo et al. Jul 2012 B1
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
8451697 Rigney et al. May 2013 B1
8482873 Chue et al. Jul 2013 B1
8498076 Sheh et al. Jul 2013 B1
8498172 Patton, III et al. Jul 2013 B1
8508881 Babinski et al. Aug 2013 B1
8531798 Xi et al. Sep 2013 B1
8537486 Liang et al. Sep 2013 B2
8542455 Huang et al. Sep 2013 B2
8553351 Narayana et al. Oct 2013 B1
8564899 Lou et al. Oct 2013 B2
8576506 Wang et al. Nov 2013 B1
8605382 Mallary et al. Dec 2013 B1
8605384 Liu et al. Dec 2013 B1
8610391 Yang et al. Dec 2013 B1
8611040 Xi et al. Dec 2013 B1
8619385 Guo et al. Dec 2013 B1
8630054 Bennett et al. Jan 2014 B2
8630059 Chen et al. Jan 2014 B1
8634154 Rigney et al. Jan 2014 B1
8634283 Rigney et al. Jan 2014 B1
8643976 Wang et al. Feb 2014 B1
8649121 Smith et al. Feb 2014 B1
8654466 McFadyen Feb 2014 B1
8654467 Wong et al. Feb 2014 B1
8665546 Zhao et al. Mar 2014 B1
8665551 Rigney et al. Mar 2014 B1
8670206 Liang et al. Mar 2014 B1
8687312 Liang Apr 2014 B1
8693123 Guo et al. Apr 2014 B1
8693134 Xi et al. Apr 2014 B1
8699173 Kang et al. Apr 2014 B1
8711027 Bennett Apr 2014 B1
8717696 Ryan et al. May 2014 B1
8717699 Ferris May 2014 B1
8717704 Yu et al. May 2014 B1
8724245 Smith et al. May 2014 B1
8724253 Liang et al. May 2014 B1
8724524 Urabe et al. May 2014 B2
8737008 Watanabe et al. May 2014 B1
8737013 Zhou et al. May 2014 B2
8743495 Chen et al. Jun 2014 B1
8743503 Tang et al. Jun 2014 B1
8743504 Bryant et al. Jun 2014 B1
8749904 Liang et al. Jun 2014 B1
8760796 Lou et al. Jun 2014 B1
8767332 Chahwan et al. Jul 2014 B1
8767343 Helmick et al. Jul 2014 B1
8767354 Ferris et al. Jul 2014 B1
8773787 Beker Jul 2014 B1
8779574 Agness et al. Jul 2014 B1
8780473 Zhao et al. Jul 2014 B1
8780477 Guo et al. Jul 2014 B1
8780479 Helmick et al. Jul 2014 B1
8780489 Gayaka et al. Jul 2014 B1
8792202 Wan et al. Jul 2014 B1
8797664 Guo et al. Aug 2014 B1
8804267 Huang et al. Aug 2014 B2
8824081 Guo et al. Sep 2014 B1
8824262 Liu et al. Sep 2014 B1
20040085668 Sakamoto May 2004 A1
20070103809 Lee May 2007 A1
20100035085 Jung et al. Feb 2010 A1
20110299247 Zhang Dec 2011 A1
20120284493 Lou et al. Nov 2012 A1
20130120870 Zhou et al. May 2013 A1
20130148240 Ferris et al. Jun 2013 A1