Embodiments of the present invention relate to the manufacture and operation of integrated circuits. More particularly, embodiments of the present invention relate to computer implemented processes for operating an integrated circuit at an optimal voltage for that integrated circuit.
A significant problem faced by mobile, e.g., battery powered computers is the length of time such computers are capable of operating between charges. An additional concern is heat dissipation of the electronics. As computer processors become more capable, they tend to run at higher clock rates and to dissipate more power. In addition, more capable peripherals, e.g., higher capacity hard drives and wireless high speed networks, also compete with the main computer processor for an ever-increasing portion of the available battery power. At the same time, the size and weight of portable computers is constantly being reduced to make them more portable. Since batteries generally are a very significant component of the weight of portable computers and other portable devices, the tendency has been to maintain battery size and thus battery capacity at a minimum. The compact nature of portable devices also intensifies heat dissipation issues.
A great deal of time, expense and effort has been directed to techniques for extending the operating life of portable computers. Presently, typical processors and computer systems include circuitry and software for disabling various power-draining functions of portable computers when those functions are unused for some extensive period. For example, various techniques have been devised for turning off the display screen when it has not been used for some selected period. Similar processes measure the length of time between use of hard drives and disable rotation after some period. Another of these processes is adapted to put a central processor into a quiescent condition after a period of inactivity.
In general, these processes are useful in extending the operating life of a portable computer. However, the life still does not in general achieve a desirable duration. In fact, battery life is a highly competitive specification among portable processor and computer manufacturers, and there is an almost universal desire for more battery life.
There has been a significant amount of research conducted from which processors requiring less power might be produced. Most processors used in computer systems today are made using complimentary metal oxide semiconductor (CMOS) technology. The power consumed by a CMOS integrated circuit is comprised of two components, a static portion and a dynamic portion. Dynamic power is given approximately by p=CV2f, where C is the active switching capacitance, V is the supply voltage, and f is the frequency of operation, and static power is expressed as idle or “off” current times voltage.
It is desirable to operate a processor at the lowest possible voltage at a frequency that provides the computing resource desired by the user at any given moment. For instance, if a processor is operating at 600 MHz, and the user runs a process that is only half as demanding of the processor, the frequency can be decreased by approximately a factor of two. Correspondingly, in many cases the voltage can also be decreased by a factor of two. Therefore, dynamic power consumption can be reduced by a factor of eight. Various methods of implementing this dynamic frequency-voltage scaling have been described in the conventional art.
A highly effective system for adjusting voltage to correspond with processing demands is commercially available on processors from Transmeta Corporation of Santa Clara, Calif. Embodiments of such systems are described in U.S. patent application Ser. No. 09/484,516, entitled Adaptive Power Control, to S. Halepete et al., filed Jan. 18, 2000, and assigned to the assignee of the present Application.
Halepete et al. disclose a processor's ability to dynamically adapt its voltage and clock frequency to correspond to the demands placed on the processor by software. Because dynamic power varies linearly with clock speed and by the square of voltage, adjusting both can produce cubic or higher order reductions in dynamic power consumption, whereas prior processors could adjust power only linearly (by only adjusting the frequency).
Curve 110 may be established as a standard for a population of microprocessors, e.g., by collecting frequency versus voltage information for a number of microprocessor samples. By using a variety of well known statistical analysis methods, curve 110 may be established to achieve an optimal trade-off of performance and process yield. For example, curve 110 may be established such that 90% of all production exhibits better frequency-voltage performance than curve 110. Using curve 110, a set of frequency-voltage operating points may be established. For example, frequency 150 is paired with voltage 190, frequency 140 with voltage 180, frequency 130 with voltage 170 and frequency 120 with voltage 160. Such a set of frequency-voltage pairings (or points) may also be expressed in the form of a table, as illustrated in Table 1, below:
Such processors are configured to operate at a number of different frequency and voltage combinations, or points. Special power management software monitors the processor and dynamically switches between these operating points as runtime conditions change in order to advantageously minimize dynamic power consumption by the processor.
Unfortunately, in the prior art, such power management software has been limited to operate with a single set of frequency-voltage operating points. A set of frequency-voltage operating points is determined, for example, during qualification testing of a specific processor model for a specific manufacturing process, and used in the operation of every device of that processor model. Such a set of frequency-voltage operating points is determined based upon a worst case operation of a population of processor devices, determined, e.g., prior to general availability of the processor devices.
Numerous characteristics related to power consumption of a processor integrated circuit (“microprocessor”) are highly variable across a manufacturing process. For example, maximum operating frequency, threshold voltage and capacitance may each vary by 30% or more, from batch to batch and even within the same wafer. Leakage current is exponential to the threshold voltage and may vary by 500% from nominal. As an unfortunate consequence, such a set of frequency-voltage operating points is based upon the worst case operation of a population of processor devices, determined, e.g., during a qualification process, generally prior to general availability of the processor devices.
Many processors, typically a majority of a manufactured population, are able to operate at more desirable frequency-voltage operating points than the single standard set based upon worst case performance. For example, if the standard set specifies 600 MHz operation at 1.2 volts, many individual processor devices may be able to operate at 600 MHz at only 1.1 volts. Such better performing processors, however, are detrimentally set to operate at the standard frequency-voltage operating point, wasting power. Further, such parts will typically have a lower threshold voltage, and if forced to operate at a higher supply voltage will demonstrate an increased leakage current. Both effects consume excess power and cause an undesirably shorter battery life than is optimal for such a particular processor device.
In addition, during the commercial lifetime of a processor model, numerous refinements and improvements in its manufacturing processes are typically made. Some of these may improve the power characteristics of the processor population, for example, rendering the pre-existing standard set of frequency-voltage operating points less than optimal.
The conventional art has focused primarily on reducing the dynamic power consumption of microprocessors. Unfortunately, static power consumption in modern semiconductor processes, e.g., processes with a minimum feature size of about 0.13 microns and smaller, is no longer a negligible component of total power consumption. For such processes, static power may be one-half of total power consumption. Further, static power, as a percentage of total power, is tending to increase with successive generations of semiconductor process.
For example, maximum operating frequency is generally proportional to the quantity (1−Vt/Vdd), that is, one minus the threshold voltage divided by the supply voltage (for small process geometries). As process geometry shrinks, supply voltage (Vdd) typically also is decreased in order to avoid deleterious effects such as oxide breakdown. Consequently, threshold voltage should also be decreased in order to maintain or increase a desirable maximum operating frequency. Correspondingly, gate oxides are made thinner so that a gate can maintain control of the channel. A thinner gate oxide leads to an increased gate capacitance. Since “off” or leakage current of a CMOS device is generally proportional to gate capacitance, the trend to make gate oxides thinner tends to increase leakage current. Unfortunately, increasing leakage current deleteriously increases static power consumption. As an unfortunate result, the on-going decrease in semiconductor process size also leads to an ever-increasing share of total power consumption deriving from static power dissipation.
In addition, because leakage current is influenced by numerous aspects of device geometry and implant characteristics, static power may vary by as much as 500% above or below nominal levels. As performance in terms of power consumption is a critical attribute for a mobile processor, processor manufacturers typically test and certify that a part will meet a particular clock rate at a maximum power level, e.g., 1 GHz at 8.5 watts. When operating with a fixed set of frequency-voltage operating points, such a maximum power level must be achieved at a voltage specified by the set of frequency-voltage operating points.
If a particular processor device is unable to meet the maximum power limit at the standard frequency-voltage operating point, then it is rejected or placed into a higher power, and therefore less desirable category or “bin” at manufacturing test. Such a part represents a yield loss and a loss of potential revenue to the manufacturer. However, such a part may oftentimes be able to achieve both the required clock rate and power consumption specifications at a lower voltage.
Thus, while the systems and techniques of controlling frequency-voltage operating points in the prior art have brought about improvements in reduced power consumption of processors, the use of a standard set of operating points across a variable population of processors results in less than optimal power consumption and manufacturing yield losses that are highly undesirable.
Therefore, systems and methods of adaptive power control based on pre package characterization of integrated circuits reflective of characteristics of specific integrated circuits are required.
In the following detailed description of the present invention, adaptive power control based on pre package characterization of integrated circuits, numerous specific details are set forth in order to provide a thorough understanding of the present invention. However, it will be recognized by one skilled in the art that the present invention may be practiced without these specific details or with equivalents thereof. In other instances, well-known methods, procedures, components, and circuits have not been described in detail as not to unnecessarily obscure aspects of the present invention.
Notation and Nomenclature
Some portions of the detailed descriptions which follow (e.g., processes 600, 700, 800, 900, 1000, 1100, 1200 and 1300) are presented in terms of procedures, steps, logic blocks, processing, and other symbolic representations of operations on data bits that can be performed on computer memory. These descriptions and representations are the means used by those skilled in the data processing arts to most effectively convey the substance of their work to others skilled in the art. A procedure, computer executed step, logic block, process, etc., is here, and generally, conceived to be a self-consistent sequence of steps or instructions or firmware leading to a desired result. The steps are those requiring physical manipulations of physical quantities. Usually, though not necessarily, these quantities take the form of electrical or magnetic signals capable of being stored, transferred, combined, compared, and otherwise manipulated in a computer system. It has proven convenient at times, principally for reasons of common usage, to refer to these signals as bits, values, elements, symbols, characters, terms, numbers, or the like.
It should be borne in mind, however, that all of these and similar terms are to be associated with the appropriate physical quantities and are merely convenient labels applied to these quantities. Unless specifically stated otherwise as apparent from the following discussions, it is appreciated that throughout the present invention, discussions utilizing terms such as “accessing” or “indexing” or “processing” or “computing” or “translating” or “calculating” or “determining” or “selecting” or “storing” or “recognizing” or “generating” or “selecting” or “moving” or “encoding” or “combining” or “testing” of “setting” or “operating” or “transforming” or “determining” or “optimizing” or “synthesizing” or “grouping” or “estimating” or “describing” or “measuring” or “recording” or “associating” or the like, refer to the action and processes of a computer system, or similar electronic computing device, that manipulates and transforms data represented as physical (electronic) quantities within the computer system's registers and memories into other data similarly represented as physical quantities within the computer system memories or registers or other such information storage, transmission or display devices.
Embodiments of the present invention are described in the context of design and operation of highly integrated semiconductors. More particularly, embodiments of the present invention relate to adaptive power management of microprocessors. It is appreciated, however, that elements of the present invention may be utilized in other areas of semiconductor operation.
U.S. patent application Ser. No. 09/484,516, entitled Adaptive Power Control, to S. Halepete et al., filed Jan. 18, 2000, is hereby incorporated herein by reference in its entirety.
A semiconductor manufacturing process is generally considered to be highly self-consistent, that is, the process is very good at producing “exact” copies of an integrated circuit design. This is especially the case for semiconductor products operated in the digital domain. Functionally, the semiconductor arts have succeeded in producing essentially perfect copies that function similarly.
However, numerous analog characteristics of a semiconductor are highly variable. For example, threshold voltage, capacitance, gate delay, current consumption, minimum operating voltage and maximum operating frequency may vary 30% or more from chip to chip. Leakage, or “off” current may be even more variable. For example, it is not uncommon for leakage current to vary 500% above or below a nominal level. More particularly, parameters related to power consumption of an integrated circuit are highly variable.
Curve 210 represents a specific integrated circuit with frequency-voltage characteristics that are better than standard curve 110. For example, the integrated circuit represented by curve 210 is able to achieve frequency 150 at supply voltage 260, which is less than supply voltage 190, as specified by the standard frequency-voltage characteristic (Table 1). As a beneficial result, such an integrated circuit could provide the same level of processing performance (represented by frequency) at a lower voltage (e.g., voltage 260) and consequently lower power compared to operating at a standard voltage (e.g., voltage 190).
Curve 210 represents an integrated circuit with a frequency-voltage characteristic that is more desirable than the standard curve (110). Typically, a majority of a manufacturing population will have superior frequency-voltage characteristics, as a standard curve is determined, at least in part, to maximize the yield of the manufacturing process. A deleterious effect of such a standard frequency-voltage characteristic, however, is that most of the integrated circuits are capable of better power performance than they are rated.
Since performance in terms of power consumption is a critical attribute for a mobile processor, processor manufacturers typically test and certify that a part will meet a particular clock rate at a maximum power level. When operating with a fixed set of frequency-voltage operating points, such a maximum power level must be achieved at a voltage corresponding to the desired frequency where the voltage is specified by the set of frequency-voltage operating points. For example, the power level of an integrated circuit must be less than the maximum limit for frequency 150 at supply voltage 190.
“Fast” parts, for example an integrated circuit corresponding to curve 210, are able to achieve higher operating frequencies at lower voltages compared to “slower” parts. Fast parts typically also have increased current consumption at a given voltage compared to slower parts. Accordingly, while the integrated circuit corresponding to curve 210 is easily able to operate at frequency 150 at supply voltage 190, because it generally will consume more current, it may exceed the power limit at the test voltage. Deleteriously, under the conventional art, an integrated circuit corresponding to curve 210, though able to achieve a desired operating frequency, e.g., frequency 150, at a lower voltage than specified by the standard frequency-voltage characteristic, would be rejected for consuming too much power.
Testing of integrated circuits at typical operating frequencies, e.g., a few hundred megahertz into the gigahertz range, such as the testing required to generate curve 210, is generally performed after an integrated circuit has been packaged. Test fixtures required to test a packaged part are generally less expensive than test fixtures required to test at a bare die or wafer level. In addition, the packaging, including, for example a lead frame, introduces numerous additional electrical and thermal characteristics that may affect the performance, particularly the frequency performance, of a packaged device.
Unfortunately, the packaging process is expensive, in the form of packaging materials, operating expenses and capacity of process equipment. If a packaged semiconductor is found to have undesirable power characteristics after packaging, the expense of packaging is lost. In addition, certain types of non-volatile elements of a semiconductor, e.g., data storage fuses, may typically be set only prior to packaging. For example, a data storage fuse may be a semiconductor structure that is directly accessed (e.g., via laser) or via pads that are generally not bonded out. For these and other reasons it is frequently desirable to determine power performance of an integrated circuit prior to packaging.
Power consumed by CMOS circuitry is comprised of two components, a static portion and a dynamic portion. Dynamic power is given approximately by p=CV2f, where C is the active switching capacitance, V is the supply voltage, and f is the frequency of operation, and static power is expressed as idle current times voltage. As described previously, it is typically not possible to accurately test an integrated circuit at frequency prior to packaging. Consequently, dynamic power may not be measured accurately prior to packaging of an integrated circuit. However, capacitance, C, and idle current are relatively unaffected by packaging and may be accurately measured at a bare die and/or wafer level.
Advantageously, given capacitance, dynamic power may be estimated prior to packaging based upon an assumed operating frequency, according to an embodiment of the present invention. For example, based upon a measured value for capacitance, dynamic power may be estimated for a desired frequency of operation. An operating voltage may be specified, for example, per a standard frequency-voltage operating point. Further, since idle current may be measured on an unpackaged device, total power (at a desired operating frequency) may be directly estimated.
According to an embodiment of the present invention, such an estimation of power consumption (for a desired operating frequency) could be used to test reject parts based upon excessive power consumption, prior to packaging. However, as previously described, a rejection based upon such criteria may deleteriously reject integrated circuit devices, e.g., the integrated circuit corresponding to curve 210 of
According to an alternative embodiment of the present invention, it is more desirable to determine a maximum voltage required to achieve a maximum power limit, assuming that a desired operating frequency is achievable. For example, in the power estimation above, specify power (as a maximum limit) and solve for voltage. The resulting voltage is the maximum voltage at which the integrated circuit device may be operated at a desired frequency to achieve an acceptable power level. It is to be appreciated that the integrated circuit has not been tested at the desired frequency. However, to meet the power limit, the integrated circuit should operate at the desired frequency at a voltage equal to or less than the determined resulting voltage.
According to an embodiment of the present invention, a representation of such resulting voltage may be encoded, e.g., programmed, into a non-volatile element, e.g., a data storage fuse (e.g., a non-resettable semiconductor feature), electrically erasable programmable read only memory (EEPROM) or the like, of the integrated circuit. For example, the maximum voltage allowed may be encoded into the integrated circuit. Alternatively, a mapping into varying sets of frequency-voltage characteristics may be encoded.
Referring once again to
Based upon determining a maximum voltage allowable (so as not to exceed a maximum power level) for a desired operating frequency, specific integrated circuits may be placed into one of the above groupings. Curve 220 may become a second set of frequency-voltage operating points. With two sets of frequency-voltage operating points, represented by curves 110 and 220, integrated circuits could be operated at more optimal power levels based upon specific characteristics of a given, specific integrated circuit. For example, the integrated circuit corresponding to curve 210 could be operated at the frequency-voltage operating points of curve 220, saving power relative to operating the same integrated circuit at the standard frequency-voltage operating points of curve 110. An encoded non-volatile circuit element may determine which set of frequency-voltage operating points should be used during operation.
Table 2, below, illustrates an exemplary pair of sets of frequency-voltage operating points, according to an embodiment of the present invention.
Table 2 illustrates two sets of frequency-voltage operating points, a standard set in the two left columns and a set for “fast” parts in the two right columns. For example, if the “fast” set of frequency-voltage operating points corresponds with curve 220, then an integrated circuit corresponding to curve 210 may be advantageously operated at frequency-voltage points in the “fast” set of Table 2. When operated according to such “fast” operating points, a “fast” integrated circuit will consume less power than when operated at a standard set of operating points.
Embodiments of the present invention are well suited to other methods of representing frequency-voltage characteristics of integrated circuits. For example, a frequency-voltage characteristic could be represented as coefficients of a polynomial describing, or approximately describing, a frequency-voltage characteristic.
Further, and in a similar fashion, such an encoded non-volatile circuit element may be used to determine a supply voltage for dynamic power testing of a packaged device. For example, fast parts, such as the integrated circuit corresponding to curve 210, should be tested at a lower supply voltage for a desired frequency, corresponding to curve 220. Whereas under the conventional art a fast part may have failed a maximum power limit test operating at a standard frequency-voltage operating point, e.g., curve 110, a higher percentage of devices will pass such a test operating at a lower voltage corresponding to curve 220. As a beneficial result, embodiments of the present invention advantageously increase the manufacturing yield.
It is to be appreciated that embodiments of the present invention are well suited to segmenting a manufacturing population into more than the illustrated two groups. More sets of frequency-voltage characteristics could be created and more bits used to identify such sets could be encoded into each specific integrated circuit.
Speed, or operating frequency for most semiconductors varies with temperature. For example, at a given voltage an integrated circuit may run faster at a lower temperature than at a higher temperature. As a corollary, an integrated circuit may typically be operated at a desired frequency with a lower supply voltage at a lower temperature when a higher supply voltage is required to operate at the same desired frequency at a higher temperature.
According to an embodiment of the present invention, chip temperature may be used to select an optimal voltage of operation for a desired operating frequency. Table 3, below, illustrates exemplary sets of frequency-voltage operating points incorporating chip temperature, according to an embodiment of the present invention.
Table 3 illustrates four sets of frequency-voltage operating points, two standard sets in the second and third columns and two sets for “fast” parts in the two right columns. There are two standard sets and two fast sets, based upon chip temperature, e.g., “hot” and “cool.” If chip temperature is known to be less than or equal to 50° C., an integrated circuit may be advantageously operated at frequency-voltage points in the “cooler” or bottom portion of Table 3. When operated according to such “cool” operating points, an integrated circuit will consume less power than when operated at a standard set (that doesn't account for temperature, e.g., Table 2) of operating points.
It is to be appreciated that embodiments of the present invention are well suited to characterizing frequency-voltage characteristics into more than the illustrated two temperature groups. More sets of temperature dependent frequency-voltage characteristics could be created and more bits used to identify such sets could be encoded into each specific integrated circuit.
While encoding a mapping into varying sets of frequency-voltage characteristics into an integrated circuit is sometimes desirable, there are limitations as well. A first limitation relates to the amount of information that may actually be encoded into an integrated circuit. Microprocessors typically have extremely limited amounts of or no non-volatile storage. The reasons for a paucity of such on-chip non-volatile storage include circuit size, e.g., a bit of non-volatile storage consumes valuable circuit area, more optimally used for microprocessor circuitry. Another reason relates to semiconductor processes, e.g., many types of integrated circuit non-volatile storage require additional semiconductor masks and process steps not required for standard microprocessor circuitry. Such masks and process steps are expensive and add complexity to a manufacturing process, thereby increasing costs and reducing yield. For these reasons and others, non-volatile storage requiring additional process steps is typically not included in a microprocessor.
A second limitation involves the capacity and capabilities of die/wafer level testing. Die and wafer level testers are expensive, more so than packaged testers, and as previously described typically can not fully characterize the frequency-voltage behavior of an integrated circuit because of the electrical effects of packaging. Consequently, it is sometimes more desirable to characterize the frequency-voltage behavior of an integrated circuit after packaging.
It is to be appreciated that embodiments of the present invention are well suited to encoding a mapping into varying sets of frequency-voltage characteristics into an integrated circuit after packaging. For example, on-chip non-volatile storage may be accessible via package pins, and a tester could write mapping information into such storage. However, it will frequently be the case that on-chip non-volatile storage may not be encoded after packaging. At other times there may not be sufficient on-chip non-volatile storage available for encoding the desired amount of information.
In such cases, alternative means of associating one or more frequency-voltage characteristics with a specific integrated circuit should be employed.
According to an embodiment of the present invention, a frequency-voltage characteristic, or a mapping of a frequency-voltage characteristic, of a specific integrated circuit may be encoded in a non-volatile memory device that is associated with the specific integrated circuit. Example devices include without limitation electrically erasable programmable read only memory (EEPROM), battery-backed up random access memory (RAM), mask ROM, ferro-magnetic RAM, data storage fuses within semiconductor packaging, data storage fuses that are a part of an integrated circuit, wiring connections (e.g., encoding by coupling pins to Vcc and/or ground), and the like.
One desirable method of associating a non-volatile memory device with specific integrated circuit is to include a memory device in the packaging of the specific integrated circuit, for example in a multi-chip module.
Embodiments of the present invention are well suited to other methods of associating a frequency-voltage characteristic, or a mapping of a frequency-voltage characteristic, of a specific integrated circuit with the specific integrated circuit. One method maintains a database in computer readable media of a plurality of frequency-voltage characteristics for a plurality of integrated circuits. A specific frequency-voltage characteristic of a specific integrated circuit may then be referenced by an identifying attribute of the integrated circuit, e.g., a unique serial number.
The specific frequency-voltage characteristic may then be transferred by a wide variety of means, e.g., internet download, and referenced at many points during the manufacture and/or use of products using the integrated circuit. For example, if the integrated circuit was a microprocessor, the manufacturer of a computer comprising the microprocessor could assemble the computer, electronically access the microprocessor serial number, access the specific frequency-voltage characteristic, e.g., in a data file, and configure a unique ROM for that computer. Such a ROM would then reflect the specific frequency-voltage characteristic of the microprocessor at the heart of that particular computer.
Encoding information after a packaging operation typically makes a greater amount of storage available that pre-packaging encoding. For example, a memory semiconductor typically comprises millions of bits of information as opposed to a few bits which might be included in a microprocessor. In addition, numerous types of well known computer systems that may be coupled to a microprocessor, e.g., testing machines, may have, or be further coupled to essentially unlimited storage.
Further, since an integrated circuit may be fully characterized after packaging, it is typically possible to encode greater amounts of information specific to a particular integrated circuit after packaging. According to an embodiment of the present invention, information of specific integrated circuit frequency-voltage characteristics may be encoded after packaging the integrated circuit.
Such post packaging encoding may store a variety of types of information. For example, an integrated circuit may be characterized as belonging to one of a plurality of groups of integrated circuits which have similar frequency-voltage characteristics. Information encoded may identify which of such groups best describes a specific integrated circuit.
Alternatively, a frequency-voltage characteristic of a specific integrated circuit may be encoded. For example, attributes of curve 210 (
Embodiments of the present invention are well suited to a wide variety of well known methods of representing curves, including data reduction techniques, such as a frequency-voltage curve of an integrated circuit. According to one embodiment of the present invention, tables containing coordinate points are used to represent frequency-voltage characteristics. According to an alternative embodiment, a frequency-voltage characteristic may be represented as coefficients of a polynomial describing, or approximately describing, a frequency-voltage characteristic.
Table 4, below, illustrates a frequency-voltage characteristic of a specific microprocessor, according to an embodiment of the present invention.
It is to be appreciated that only one set of voltage-frequency characteristics (optionally per temperature) is included in Table 4.
Embodiments of the present invention are also well suited to modules comprising a microprocessor which is directly attached to a circuit board, e.g., via direct chip attach (DCA). Integrated circuits which are DCA-mounted typically have an encapsulant or “glop top” applied after mounting, although this is not required by embodiments of the present invention. No requirement of physical proximity of components of a module is intended by the foregoing discussion.
Non-volatile storage 320 is well suited to a wide variety of types of non-volatile storage. For example, storage 320 may be an integrated circuit device, including without limitation electrically erasable programmable read only memory (EEPROM), battery-backed up random access memory (RAM), mask ROM, and ferro-magnetic RAM. Storage 320 is also well suited to a wide variety of other types of data storage, including data storage fuses within semiconductor packaging, data storage fuses that are a part of an integrated circuit, wiring connections (e.g., encoding by coupling pins to Vcc and/or ground), and the like.
Memory space 450 is coupled to microprocessor 410. Memory space 450 is well suited to a wide variety of well known types of memory, including without limitation internal RAM or ROM within microprocessor 410, RAM or ROM outside of microprocessor 410 and other forms of computer readable media.
Voltage supply 420 is coupled to microprocessor 410. Voltage supply 420 furnishes a selectable voltage 430 to microprocessor 410. Microprocessor 410 is coupled to voltage supply 420 via coupling 440, in order to cause voltage supply 420 to select an optimal voltage.
According to an alternative embodiment of the present invention, device 400 may further comprise memory space 460. Memory space 460 is coupled to microprocessor 410, for example via the same coupling means as memory space 450. Memory space 460 is well suited to similar types of memory as previously described for memory 450, and is further well suited to being within the same physical device as memory space 450. However, memory space 460 is not required to be in the same physical device as memory space 450, and some optimizations of computer 400 may preferentially separate the two memories by type and/or device.
According to another alternative embodiment of the present invention, device 400 may comprise logic 470. Logic 470 is coupled to memory 460 and microprocessor 410. Logic 470 accesses a desired frequency of operation, which may be determined by microprocessor 410, and uses memory 460 to determine a corresponding voltage. Logic 470 causes microprocessor 410 to operate at the desired frequency of operation and at the corresponding voltage. Logic 470 is well suited to software embodiments executing, for example, on microprocessor 410. Logic 470 may also execute on a second processor (not shown), or comprise a functional set of gates and/or latches. Logic 470 is well suited to being internal or external to microprocessor 410.
Data structure 505 comprises voltage-frequency relationship information specific to processor 501. In contrast to the conventional art, information of data structure 505 is based upon testing of processor 501, as opposed to being information generally about a population of processors of similar design. Data structure 505 may reside in memory 506, which is external to processor 501. Memory 506 may be, for example, a ROM integrated circuit. Embodiments of the present invention are well suite to other types of memory as well, e.g., RAM, rotating magnetic storage, etc.
Control logic 507 uses information from data structure 505 to control the voltage and/or frequency of operation for processor 501. Such control may be to minimize power consumption of processor 501. Control logic 507 is well suited to software executing on processor 501.
Data structure 530 comprises voltage-frequency relationship information for a class of processors of the type of processor 503. Likewise, data structures 540 and 550 comprises voltage-frequency relationship information respectively for other classes of processors of the type of processor 503. In contrast to the conventional art, information of data structures 530-550 represents, segments of a manufacturing population of processors of the same type as processor 503. Typically, information 530, 540 and 550 will differ. Embodiments of the present invention are well suited to varying numbers of such data structures. Data structures 530, 540 and 550 may reside in memory 560, which is external to processor 503. Memory 560 may be, for example, a ROM integrated circuit. Embodiments of the present invention are well suite to other types of memory as well, e.g., RAM, rotating magnetic storage, etc.
Class identifier 520 comprises information as to which voltage-frequency relationship (e.g., contained in data structure 530, 540 or 550) best corresponds to processor 503. Class identifier 520 is determined and recorded during production of processor 503. Such determination and recording of a class identifier may be performed prior to packaging of processor 503. Class identifier 520 is typically a few bits, and is well suited to many types of non-volatile storage, e.g., data storage fuses or electrically erasable programmable read only memory (EEPROM).
Control logic 525 accesses information from class identifier 520 to determine which data structure, e.g., 530, 540 or 560, corresponds to processor 503 and should be used to control the voltage and/or frequency of operation for processor 503. Such control may be to minimize power consumption of processor 503. Control logic 525 is well suited to software executing on processor 503.
Data structure 505 comprises voltage-frequency relationship information specific to processor 502. In contrast to the conventional art, information of data structure 505 is based upon testing of processor 502, as opposed to being information generally about a population of processors of similar design. Data structure 505 is internal to processor 502. Data structure 505 may be stored in a wide variety of well known memory types are may be included in a processor, e.g., non-volatile RAM, electrically erasable programmable read only memory (EEPROM), etc.
Control logic 508 uses information from data structure 505 to control the voltage and/or frequency of operation for processor 502. Such control may be to minimize power consumption of processor 502. Control logic 508 is well suited to software executing on processor 502.
In step 620, information of the voltage is stored into computer readable media. Embodiments of the present invention are well suited to storing the information in a wide variety of types of computer readable media, including memory or storage systems of an integrated circuit tester or manufacturing data logging systems, integrated circuits within common packaging of the microprocessor, separate integrated circuit memories and the like. According to an embodiment of the present invention, the information comprises frequency voltage relations specific to the microprocessor.
In step 720, information of the plurality of relations is stored into computer readable media. Embodiments of the present invention are well suited to storing the information in a wide variety of types of computer readable media, including memory or storage systems of an integrated circuit tester or manufacturing data logging systems, integrated circuits within common packaging of the microprocessor, separate integrated circuit memories and the like.
In step 820, a voltage required by one of the plurality of unpackaged microprocessors to meet a power limit at a specified frequency is determined. The voltage may be determined by measuring capacitance and/or idle current of the microprocessor.
In step 830, information of said voltage is encoded into the microprocessor. Embodiments of the present invention are well suited to a wide variety of well known types of storage that may be a part of a microprocessor and encoded in step 830. Examples include, without limitation, data storage fuses and electrically erasable read only memory and the like.
In step 920, the frequency-voltage characteristic is associated with the integrated circuit for optimizing the operation of the integrated circuit. The frequency-voltage characteristic may be associated with the integrated circuit in a wide variety of ways, including via encoding information in the integrated circuit or encoding information in a device that will be delivered to a customer with the integrated circuit. According to an alternative embodiment of the present invention, associating may take the form of maintaining a database in computer readable media of a plurality of frequency-voltage characteristics for a plurality of integrated circuits. A specific frequency-voltage characteristic of a specific integrated circuit may then be referenced by an identifying attribute of the integrated circuit, e.g., a unique serial number.
In step 930, the integrated circuit is operated at a voltage and frequency specified by the frequency-voltage characteristic.
In step 1020, an optimal voltage for operating the microprocessor at the desirable operating frequency is selected. The optimal voltage selected is based upon characteristics that are specific for the microprocessor.
In step 1030, the microprocessor is operated at the optimal voltage. For example, the microprocessor may cause a selectable voltage supply, e.g., voltage supply 420 of
In step 1130, a corresponding set voltage at which the microprocessor optimally operates at the set frequency is determined using the set frequency. The determining is based on a voltage-frequency relationship that is specific to the microprocessor.
In step 1140, the microprocessor is operated at the set frequency and the corresponding set voltage.
In optional step 1110, the set frequency is determined by examining a contemporaneous set of operations performed by the microprocessor.
In step 1220, the frequency-voltage relationship is associated with the microprocessor so that said frequency-voltage relationship can be accessed and used during operation of the microprocessor for optimal use thereof.
In step 1320, information specific to the microprocessor is accessed. For example, the information may be stored in memory, e.g., memory 450 of
According to an alternative embodiment of the present invention, the information may be accessed from within the microprocessor.
In step 1330, the microprocessor is operated at the optimal voltage. For example, the microprocessor may cause a selectable voltage supply, e.g., voltage supply 420 of
A system and method of adaptive power control of integrated circuits are disclosed. A desirable operating frequency is determined for the integrated circuit. The integrated circuit may be a microprocessor. The desirable operating frequency may be determined based upon a determined processing load desired of the microprocessor. An optimal voltage for operating the microprocessor at the desired operating frequency is selected. The selection is based upon characteristics that are specific to the microprocessor. The microprocessor is operated at the optimal voltage.
Embodiments of the present invention provide a means to adaptively control power consumption of an integrated circuit based upon specific characteristics of the integrated circuit. Further embodiments of the present invention provide for the above mentioned solution to be achieved with existing semiconductor processes and equipment without revamping well established tools and techniques.
The preferred embodiment of the present invention, adaptive power control based on pre package characterization of integrated circuits, is thus described. While the present invention has been described in particular embodiments, it should be appreciated that the present invention should not be construed as limited by such embodiments, but rather construed according to the below claims.
The preferred embodiment of the present invention, adaptive power control based on pre-package characterization of integrated circuits, is thus described. While the present invention has been described in particular embodiments, it should be appreciated that the present invention should not be construed as limited by such embodiments, but rather construed according to the below claims.
This Application is a Continuation Application of, and claims priority to, commonly owned U.S. patent application Ser. No. 10/334,748, now U.S. Pat. No. 7,228,242, filed Dec. 31, 2002, which is hereby incorporated herein in its entirety by reference for all purposes.
Number | Name | Date | Kind |
---|---|---|---|
4246517 | Dakroub | Jan 1981 | A |
4769784 | Doluca et al. | Sep 1988 | A |
4798974 | Reczek et al. | Jan 1989 | A |
4912347 | Morris | Mar 1990 | A |
4929621 | Manoury et al. | May 1990 | A |
5039877 | Chern | Aug 1991 | A |
5086501 | DeLuca et al. | Feb 1992 | A |
5113088 | Yamamoto et al. | May 1992 | A |
5124632 | Greaves | Jun 1992 | A |
5167024 | Smith et al. | Nov 1992 | A |
5201059 | Nguyen | Apr 1993 | A |
5204863 | Saint-Joigny et al. | Apr 1993 | A |
5218704 | Watts, Jr. et al. | Jun 1993 | A |
5230055 | Katz et al. | Jul 1993 | A |
5239652 | Seibert et al. | Aug 1993 | A |
5254883 | Horowitz et al. | Oct 1993 | A |
5336986 | Allman | Aug 1994 | A |
5386135 | Nakazato et al. | Jan 1995 | A |
5394026 | Yu et al. | Feb 1995 | A |
5406212 | Hashinaga et al. | Apr 1995 | A |
5422591 | Rastegar et al. | Jun 1995 | A |
5422806 | Chen et al. | Jun 1995 | A |
5440520 | Schutz et al. | Aug 1995 | A |
5447876 | Moyer et al. | Sep 1995 | A |
5461266 | Koreeda et al. | Oct 1995 | A |
5483434 | Seesink | Jan 1996 | A |
5495184 | Des Rosiers et al. | Feb 1996 | A |
5502838 | Kikinis | Mar 1996 | A |
5506541 | Herndon | Apr 1996 | A |
5511203 | Wisor et al. | Apr 1996 | A |
5519309 | Smith | May 1996 | A |
5560020 | Nakatani et al. | Sep 1996 | A |
5592173 | Lau et al. | Jan 1997 | A |
5682093 | Kivela | Oct 1997 | A |
5692204 | Rawson et al. | Nov 1997 | A |
5717319 | Jokinen | Feb 1998 | A |
5719800 | Mittal et al. | Feb 1998 | A |
5727208 | Brown | Mar 1998 | A |
5744996 | Kotzle et al. | Apr 1998 | A |
5745375 | Reinhardt et al. | Apr 1998 | A |
5752011 | Thomas et al. | May 1998 | A |
5754869 | Holzhammer et al. | May 1998 | A |
5757171 | Babcock | May 1998 | A |
5778237 | Yamamoto et al. | Jul 1998 | A |
5781060 | Sugawara | Jul 1998 | A |
5812860 | Horden et al. | Sep 1998 | A |
5815724 | Mates | Sep 1998 | A |
5818290 | Tsukada | Oct 1998 | A |
5825674 | Jackson | Oct 1998 | A |
5838189 | Jeon | Nov 1998 | A |
5842860 | Funt | Dec 1998 | A |
5848281 | Smalley et al. | Dec 1998 | A |
5884049 | Atkinson | Mar 1999 | A |
5894577 | MacDonald et al. | Apr 1999 | A |
5900773 | Susak | May 1999 | A |
5920226 | Mimura | Jul 1999 | A |
5923545 | Nguyen | Jul 1999 | A |
5929621 | Angelici et al. | Jul 1999 | A |
5933649 | Lim et al. | Aug 1999 | A |
5940020 | Ho | Aug 1999 | A |
5940785 | Georgiou et al. | Aug 1999 | A |
5940786 | Steeby | Aug 1999 | A |
5952871 | Jeon | Sep 1999 | A |
5974557 | Thomas et al. | Oct 1999 | A |
5986947 | Choi et al. | Nov 1999 | A |
5996083 | Gupta et al. | Nov 1999 | A |
5996084 | Watts | Nov 1999 | A |
5999040 | Do et al. | Dec 1999 | A |
6006169 | Sandhu et al. | Dec 1999 | A |
6018264 | Jin | Jan 2000 | A |
6021500 | Wang et al. | Feb 2000 | A |
6035407 | Gebara et al. | Mar 2000 | A |
6047248 | Georgiou et al. | Apr 2000 | A |
6048746 | Burr | Apr 2000 | A |
6078084 | Nakamura et al. | Jun 2000 | A |
6078319 | Bril et al. | Jun 2000 | A |
6087820 | Houghton et al. | Jul 2000 | A |
6087892 | Burr | Jul 2000 | A |
6091283 | Murgula et al. | Jul 2000 | A |
6100751 | De et al. | Aug 2000 | A |
6118306 | Orton et al. | Sep 2000 | A |
6119241 | Michail et al. | Sep 2000 | A |
6141762 | Nicol et al. | Oct 2000 | A |
6157092 | Hofmann | Dec 2000 | A |
6202104 | Ober | Mar 2001 | B1 |
6215235 | Osamura | Apr 2001 | B1 |
6216235 | Thomas et al. | Apr 2001 | B1 |
6218708 | Burr | Apr 2001 | B1 |
6226335 | Prozorov | May 2001 | B1 |
6229379 | Okamoto | May 2001 | B1 |
6232830 | Fournel | May 2001 | B1 |
6272642 | Pole, II et al. | Aug 2001 | B2 |
6279048 | Fadavi-Ardekani et al. | Aug 2001 | B1 |
6281716 | Mihara | Aug 2001 | B1 |
6303444 | Burr | Oct 2001 | B1 |
6304824 | Bausch et al. | Oct 2001 | B1 |
6305407 | Selby | Oct 2001 | B1 |
6311287 | Dischler et al. | Oct 2001 | B1 |
6314522 | Chu et al. | Nov 2001 | B1 |
6320453 | Manning | Nov 2001 | B1 |
6337593 | Mizuno et al. | Jan 2002 | B1 |
6345362 | Bertin et al. | Feb 2002 | B1 |
6345363 | Levy-Kendler | Feb 2002 | B1 |
6347379 | Dai et al. | Feb 2002 | B1 |
6370046 | Nebrigic et al. | Apr 2002 | B1 |
6373323 | Kuroda | Apr 2002 | B2 |
6373325 | Kuriyama | Apr 2002 | B1 |
6378081 | Hammond | Apr 2002 | B1 |
6388432 | Uchida | May 2002 | B2 |
6415388 | Browning et al. | Jul 2002 | B1 |
6424203 | Bayadroun | Jul 2002 | B1 |
6424217 | Kwong | Jul 2002 | B1 |
6425086 | Clark et al. | Jul 2002 | B1 |
6427211 | Watts, Jr. | Jul 2002 | B2 |
6442746 | James et al. | Aug 2002 | B1 |
6457135 | Cooper | Sep 2002 | B1 |
6466077 | Miyazaki et al. | Oct 2002 | B1 |
6469573 | Kanda et al. | Oct 2002 | B2 |
6476632 | La Rosa et al. | Nov 2002 | B1 |
6477654 | Dean et al. | Nov 2002 | B1 |
6486729 | Imamiya | Nov 2002 | B2 |
6487668 | Thomas et al. | Nov 2002 | B2 |
6489224 | Burr | Dec 2002 | B1 |
6496027 | Sher et al. | Dec 2002 | B1 |
6496057 | Wada et al. | Dec 2002 | B2 |
6510400 | Moriyama | Jan 2003 | B1 |
6510525 | Nookala et al. | Jan 2003 | B1 |
6513124 | Furuichi et al. | Jan 2003 | B1 |
6518828 | Seo et al. | Feb 2003 | B2 |
6519706 | Ogoro | Feb 2003 | B1 |
6529421 | Marr et al. | Mar 2003 | B1 |
6531912 | Katou | Mar 2003 | B2 |
6563371 | Buckley, III et al. | May 2003 | B2 |
6570371 | Volk | May 2003 | B1 |
6574577 | Stapleton et al. | Jun 2003 | B2 |
6574739 | Kung et al. | Jun 2003 | B1 |
6600346 | Macaluso | Jul 2003 | B1 |
6617656 | Lee et al. | Sep 2003 | B2 |
6642774 | Li | Nov 2003 | B1 |
6675360 | Cantone et al. | Jan 2004 | B1 |
6677643 | Iwamoto et al. | Jan 2004 | B2 |
6700434 | Fujii et al. | Mar 2004 | B2 |
6731221 | Dioshongh et al. | May 2004 | B1 |
6737909 | Jaussi et al. | May 2004 | B2 |
6741118 | Uchikoba et al. | May 2004 | B2 |
6774705 | Miyazaki et al. | Aug 2004 | B2 |
6784722 | Tang et al. | Aug 2004 | B2 |
6791146 | Lai et al. | Sep 2004 | B2 |
6791212 | Pulvirenti et al. | Sep 2004 | B2 |
6792379 | Ando | Sep 2004 | B2 |
6803633 | Mergens et al. | Oct 2004 | B2 |
6809968 | Marr et al. | Oct 2004 | B2 |
6865116 | Kim et al. | Mar 2005 | B2 |
6882172 | Suzuki et al. | Apr 2005 | B1 |
6889331 | Soerensen et al. | May 2005 | B2 |
6906582 | Kase et al. | Jun 2005 | B2 |
6917240 | Trafton et al. | Jul 2005 | B2 |
6922783 | Knee et al. | Jul 2005 | B2 |
6927620 | Senda | Aug 2005 | B2 |
6936898 | Pelham et al. | Aug 2005 | B2 |
6967522 | Chandrakasan et al. | Nov 2005 | B2 |
6986068 | Togawa | Jan 2006 | B2 |
6992508 | Chow | Jan 2006 | B2 |
7012461 | Chen et al. | Mar 2006 | B1 |
7030681 | Yamazaki et al. | Apr 2006 | B2 |
7096145 | Orenstien et al. | Aug 2006 | B2 |
7100061 | Halepete et al. | Aug 2006 | B2 |
7119604 | Chih | Oct 2006 | B2 |
7120804 | Tschanz et al. | Oct 2006 | B2 |
7129771 | Chen | Oct 2006 | B1 |
7228242 | Read et al. | Jun 2007 | B2 |
7362165 | Chen | Apr 2008 | B1 |
7562233 | Sheng et al. | Jul 2009 | B1 |
7774625 | Sheng et al. | Aug 2010 | B1 |
7941675 | Burr et al. | May 2011 | B2 |
7953990 | Stewart et al. | May 2011 | B2 |
20010028577 | Sung et al. | Oct 2001 | A1 |
20020011650 | Nishizawa et al. | Jan 2002 | A1 |
20020026597 | Dai et al. | Feb 2002 | A1 |
20020067638 | Kobayashi et al. | Jun 2002 | A1 |
20020073348 | Tani | Jun 2002 | A1 |
20020083356 | Dai | Jun 2002 | A1 |
20020087219 | Dai | Jul 2002 | A1 |
20020087896 | Cline et al. | Jul 2002 | A1 |
20020116650 | Halepete et al. | Aug 2002 | A1 |
20020130701 | Kleveland | Sep 2002 | A1 |
20020138778 | Cole et al. | Sep 2002 | A1 |
20020140494 | Thomas et al. | Oct 2002 | A1 |
20020194509 | Plante et al. | Dec 2002 | A1 |
20030006590 | Aoki et al. | Jan 2003 | A1 |
20030036876 | Fuller, III et al. | Feb 2003 | A1 |
20030065960 | Rusu et al. | Apr 2003 | A1 |
20030071657 | Soerensen et al. | Apr 2003 | A1 |
20030074591 | McClendon et al. | Apr 2003 | A1 |
20030098736 | Uchikoba et al. | May 2003 | A1 |
20030189465 | Abadeer et al. | Oct 2003 | A1 |
20040025061 | Lawrence | Feb 2004 | A1 |
20040073821 | Naveh et al. | Apr 2004 | A1 |
20040103330 | Bonnett | May 2004 | A1 |
20040108881 | Bokui et al. | Jun 2004 | A1 |
20040246044 | Myono et al. | Dec 2004 | A1 |
20050225376 | Kin Law | Oct 2005 | A1 |
20070283176 | Tobias et al. | Dec 2007 | A1 |
Number | Date | Country |
---|---|---|
0381021 | Aug 1990 | EP |
0501655 | Sep 1992 | EP |
0504655 | Sep 1992 | EP |
0624909 | Nov 1994 | EP |
0978781 | Sep 2000 | EP |
1398639 | Mar 2004 | EP |
0474963 | Sep 2009 | EP |
63223480 | Sep 1988 | JP |
63233480 | Sep 1988 | JP |
04114365 | Apr 1992 | JP |
11118845 | Apr 1999 | JP |
2000172383 | Jun 2000 | JP |
2001345693 | Dec 2001 | JP |
2003324735 | Nov 2003 | JP |
409185589 | Sep 2009 | JP |
0127728 | Apr 2001 | WO |
0238828 | May 2002 | WO |
03041403 | Jul 2004 | WO |
Entry |
---|
“Computer Software”, Wikipedia, http://en.wikipedia.org/wiki/software, retrieved May 2, 2007. |
“High Speed Digitally Adjusted Step-Down Controllers for Notebook CPUS”; Max1710/Max1711; MAXIM Manual; p. 11 and p. 21. |
“Operation U (Refer to Functional Diagram)”. TLC 1736, Linear Technology Manual, p. 9. |
“Shmoo plotting: the black art of IC testing”, (Baker et al.), IEEE design & test of computers, pp. 90-97, Jul. 1997 [XP783305]. |
“Wafer Burn-In Isolation Circuit”, IBM Technical Disclosure Bulletin, IBM Corp., New York, US, vol. 32, No. 6B, Nov. 1, 1989, pp. 442-443, XP00073858 ISSN:0018-8689 the whole document. |
CMOS Circuit Design, Layout Simulation; R. Jacob Baker, Harry W. Li, David E. Boyce; IEEE Press; 1998. |
Desai et al., “Sizing of Clock Distribution Networks for High Performance CPU Chips”, Digital Equipment Corporation, Hudson, MA, pp. 389-394, 1996. |
Hsu, Jui-Ching, “Fabrication of Single Walled Carbon Nanotube (SW-CNT) Cantilevers for Chemical Sensing”, M. Sc Thesis, Louisiana State University, Dec. 2007. |
Merriam-Webster's Collegiate Dictionary, tenth edition, pp. 252 and 603 (Merriam-Webster Inc., Springfield, Mass, USA). |
Oner, H. et al., “A compact monitoring circuit for real-time on-chip diagnosis of hot-carrier induced degradation”, Microelectronic Test Structures, 1997. ICMTS 1997. Proceedings, IEEE International Conference on Monterey, CA, Mar. 17-20, 1997, pp. 72-76. |
Advisory Action Dated May 7, 2007; U.S. Appl. No. 10/334,918. |
Final Rejection Dated Jan. 31, 2007; U.S. Appl. No. 10/334,918. |
Final Rejection Dated Feb. 15, 2006; U.S. Appl. No. 10/334,918. |
Final Rejection Dated Aug. 4, 2009; U.S. Appl. No. 10/334,918. |
Final Rejection Dated Oct. 30, 2006; U.S. Appl. No. 10/334,918. |
Final Rejection Dated Nov. 26, 2008; U.S. Appl. No. 10/334,918. |
Non-Final Office Action Dated Feb. 18, 2009; U.S. Appl. No. 10/334,918. |
Non-Final Office Action Dated May 13, 2008; U.S. Appl. No. 10/334,918. |
Non-Final Office Action Dated May 15, 2006; U.S. Appl. No. 10/334,918. |
Non-Final Office Action Dated Jun. 13, 2005; U.S. Appl. No. 10/334,918. |
Final Rejection Dated Jan. 6, 2009; U.S. Appl. No. 10/334,919. |
Final Rejection Dated Feb. 21, 2007; U.S. Appl. No. 10/334,919. |
Final Rejection Dated Mar. 9, 2006; U.S. Appl. No. 10/334,919. |
Non-Final Office Action Dated May 15, 2007; U.S. Appl. No. 10/334,919. |
Non-Final Office Action Dated May 28, 2009; U.S. Appl. No. 10/334,919. |
Non-Final Office Action Dated Jun. 13, 2005; U.S. Appl. No. 10/334,919. |
Non-Final Office Action Dated Jul. 21, 2008; U.S. Appl. No. 10/334,919. |
Non-Final Office Action Dated Aug. 7, 2006; U.S. Appl. No. 10/334,919. |
Non-Final Office Action Dated Nov. 23, 2007; U.S. Appl. No. 10/334,919. |
International Preliminary Examination Report 157WO, Oct. 1, 2005. |
International Preliminary Examining Authority, Written Opinion 157WO, Aug. 10, 2004. |
International Search Report 157WO, May 10, 2004. |
Non-Final Office Action Dated Jun. 24, 2004; U.S. Appl. No. 10/334,748. |
Notice of Allowance Dated Jan. 5, 2005; U.S. Appl. No. 10/334,748. |
Notice of Allowance Dated Aug. 10, 2006; U.S. Appl. No. 10/334,748. |
Notice of Allowance Dated Sep. 22, 2005; U.S. Appl. No. 10/334,748. |
Non-Final Office Action Dated Aug. 21, 2007; U.S. Appl. No. 10/334,748. |
Restriction Requirement Dated Mar. 19, 2007; U.S. Appl. No. 10/334,748. |
Final Office Action Dated Apr. 13, 2005; U.S. Appl. No. 10/747,015. |
Final Office Action Dated Dec. 2, 2005; U.S. Appl. No. 10/747,015. |
Non-Final Office Action Dated Apr. 18, 2006; U.S. Appl. No. 10/747,015. |
Non-Final Office Action Dated Jul. 29, 2005; U.S. Appl. No. 10/747,015. |
Non-Final Office Action Dated Dec. 23, 2004; U.S. Appl. No. 10/747,015. |
Notice of Allowance Dated Jun. 21, 2006; U.S. Appl. No. 10/747,015. |
Non-Final Office Action Dated Aug. 1, 2007; U.S. Appl. No. 11/591,431. |
Notice of Allowance Dated Dec. 13, 2007; U.S. Appl. No. 11/591,431. |
Non-Final Office Action Dated Feb. 3, 2009; U.S. Appl. No. 10/874,407. |
Non-Final Office Action Dated Aug. 9, 2006; U.S. Appl. No. 10/874,407. |
Notice of Allowance Dated Jul. 13, 2009; U.S. Appl. No. 10/874,407. |
Notice of Allowance Dated Oct. 1, 2008; U.S. Appl. No. 10/874,407. |
Notice of Allowance Dated Nov. 23, 2007; U.S. Appl. No. 11/591,431. |
Non-Final Office Action Dated Dec. 23, 2004; U.S. Appl. No. 12/107,733. |
Non-Final Office Action Dated May 21, 2009; U.S. Appl. No. 12/107,733. |
Final Office Action Dated Mar. 9, 2009; U.S. Appl. No. 12/107,733. |
Final Office Action Dated Apr. 22, 2005; U.S. Appl. No. 10/747,016. |
Final Office Action Dated Oct. 30, 2007; U.S. Appl. No. 10/747,016. |
Final Office Action Dated Dec. 7, 2006; U.S. Appl. No. 10/747,016. |
Non-Final Office Action Dated Mar. 20, 2008; U.S. Appl. No. 10/747,016. |
Non-Final Office Action Dated May 16, 2007; U.S. Appl. No. 10/747,016. |
Non-Final Office Action Dated Jun. 23, 2006; U.S. Appl. No. 10/747,016. |
Non-Final Office Action Dated Nov. 18, 2005; U.S. Appl. No. 10/747,016. |
Non-Final Office Action Dated Dec. 22, 2004; U.S. Appl. No. 10/747,016. |
Notice of Allowance Dated Mar. 13, 2009; U.S. Appl. No. 10/747,016. |
Notice of Allowance Dated Aug. 20, 2009; U.S. Appl. No. 10/747,016. |
Notice of Allowance Dated Aug. 27, 2008; U.S. Appl. No. 10/747,016. |
Notice of Allowance Dated Dec. 18, 2008; U.S. Appl. No. 10/747,016. |
Non-Final Office Action Dated Dec. 22, 2004; U.S. Appl. No. 10/747,022. |
Notice of Allowance Dated Sep. 28, 2005; U.S. Appl. No. 10/747,022. |
Final Office Action Dated Jan. 12, 2009; U.S. Appl. No. 10/746,539. |
Final Office Action Dated Apr. 2, 2008; U.S. Appl. No. 10/746,539. |
Final Office Action Dated Apr. 11, 2005; U.S. Appl. No. 10/746,539. |
Final Office Action Dated Jun. 15, 2007; U.S. Appl. No. 10/746,539. |
Final Office Action Dated Aug. 31, 2006; U.S. Appl. No. 10/746,539. |
Final Office Action Dated Dec. 19, 2005; U.S. Appl. No. 10/746,539. |
Non-Final Office Action Dated Jan. 23, 2007; U.S. Appl. No. 10/746,539. |
Non-Final Office Action Dated Apr. 11, 2006; U.S. Appl. No. 10/746,539. |
Non-Final Office Action Dated Jun. 2, 2009; U.S. Appl. No. 10/746,539. |
Non-Final Office Action Dated Aug. 11, 2005; U.S. Appl. No. 10/746,539. |
Non-Final Office Action Dated Aug. 25, 2008; U.S. Appl. No. 10/746,539. |
Non-Final Office Action Dated Nov. 30, 2007; U.S. Appl. No. 10/746,539. |
Non-Final Office Action Dated Dec. 10, 2004; U.S. Appl. No. 10/746,539. |
Final Office Action Dated Jan. 23, 2007; U.S. Appl. No. 11/358,482. |
Final Office Action Dated May 23, 2008; U.S. Appl. No. 11/358,482. |
Final Office Action Dated Aug. 23, 2007; U.S. Appl. No. 11/358,482. |
Non-Final Office Action Dated Apr. 4, 2007; U.S. Appl. No. 11/358,482. |
Non-Final Office Action Dated Jul. 23, 2009; U.S. Appl. No. 11/358,482. |
Non-Final Office Action Dated Oct. 14, 2008; U.S. Appl. No. 11/358,482. |
Non-Final Office Action Dated Dec. 26, 2007; U.S. Appl. No. 11/358,482. |
Final Office Action Dated Feb. 28, 2007; U.S. Appl. No. 10/874,772. |
Final Office Action Dated Jun. 20, 2007; U.S. Appl. No. 10/874,772. |
Final Office Action Dated Sep. 6, 2006; U.S. Appl. No. 10/874,772. |
Notice of Allowance Dated Apr. 2, 2008; U.S. Appl. No. 10/874,772. |
Notice of Allowance Dated Nov. 20, 2007; U.S. Appl. No. 10/874,772. |
Number | Date | Country | |
---|---|---|---|
Parent | 10334748 | Dec 2002 | US |
Child | 11810516 | US |