1. Field
The present invention relates to integrated circuits and, more particularly, to systems and methods for dynamically de-aging integrated circuit performance.
2. Background
Integrated circuits have grown increasingly complex. To improve trade-offs between performance and power, an integrated circuit may operate at different frequencies and different voltages at different times. For example, an integrated circuit may operate in various frequency-voltage modes that include a high-performance mode and a low-power mode. The high-performance mode uses a high clock frequency and high supply voltage and thus provides high performance but also has high power consumption. The low-power mode uses a low clock frequency and low supply voltage and thus provides low power consumption but also has low performance. Additionally, various blocks inside an integrated circuit may operate at different frequencies and at different voltages.
The specific supply voltage that provides for a given clock frequency can vary based on various conditions. For example, manufacturing variations may result in different integrated circuits produced according to the same design having different relationships between voltage and frequency. Additionally, variations in circuit characteristics within an integrated circuit may result in different sections of the integrated circuit having different relationships between voltage and frequency. Temperature also affects the relationship between voltage and frequency. Furthermore, there may be drops in supply voltages that vary depending on the operations of various modules in the integrated circuit. Adaptive voltage scaling (AVS) can be used to control the supply voltage based on a sensed performance measure of the integrated circuit.
Device aging, particularly in nanometer technologies, results in changes in the electrical parameters of an integrated circuit. For example, transistor threshold voltages can be increased by effects such as positive bias temperature instability (PBTI) and negative bias temperature instability (NBTI). Circuits generally operate more slowly with aging. This further affects the relationship between supply voltage and clock frequency. The rate and amount of aging can vary with the usage of the integrated circuit. For example, a mobile phone may age more when the user uses the phone for multiple tasks such as texting, phone calls, streaming video, and playing games throughout the day compared to a user whose phone is in standby most of the day.
Prior aging compensation schemes estimate a priori the effect of aging on a device. Then, based on a worst-case scenario, effects of device aging are accounted for by including a large guard band so that the device meets its design requirements if the full effects of aging manifest themselves near the end of the expected operating life of the device. This results in a conservative design and can result in significant performance loss.
In one aspect, a circuit for sensing aging of an integrated circuit is provided. The circuit includes: a first delay chain having a first input and a first output; a second delay chain having a second input and a second output; and a control module configured to place the first delay chain and the second delay chain in an aging state, an aged oscillating state, or a non-aged oscillating state.
In one aspect, a method is provided for de-aging an integrated circuit. The method includes: initializing operation of the integrated circuit with a safe voltage and frequency; enabling dynamic voltage and frequency scaling of the integrated circuit using initial values in a coefficient table containing target performance sensor measurement values for a plurality of operating frequencies; sensing aging of the integrated circuit; updating the coefficient table based on the sensed aging; and continuing dynamic voltage and frequency scaling using the updated coefficient table.
In one aspect, an integrated circuit is provided that includes: an aging sensor configured to sense aging of circuitry in the integrated circuit, wherein the aging sensor uses the same circuit to measure circuit speeds in both aged and un-aged condition; and a core power reduction controller module configured to control a supply voltage used in the integrated circuit, wherein the supply voltage is based at least in part on aging sensed by the aging sensor.
In one aspect, an integrated circuit is provided that includes: means for sensing aging of circuitry in the integrated circuit using the same circuit to measure circuit speeds in both aged and un-aged condition; and a means for de-aging the integrated circuit configured to control a supply voltage used in the integrated circuit, wherein the supply voltage is based at least in part on aging sensed by the integrated circuit.
Other features and advantages of the present invention should be apparent from the following description which illustrates, by way of example, aspects of the invention.
The details of the present invention, both as to its structure and operation, may be gleaned in part by study of the accompanying drawings, in which like reference numerals refer to like parts, and in which:
The detailed description set forth below, in connection with the accompanying drawings, is intended as a description of various configurations and is not intended to represent the only configurations in which the concepts described herein may be practiced. The detailed description includes specific details for the purpose of providing a thorough understanding of the various concepts. However, it will be apparent to those skilled in the art that these concepts may be practiced without these specific details. In some instances, well-known structures and components are shown in simplified form in order to avoid obscuring such concepts.
The system includes various modules that perform operational functions for the system. The term operation is used to distinguish functions that may be considered to provide the primary utility of the electronic system from those functions that may be considered ancillary. The example system illustrated in
A clock generation module 113 receives a reference clock input and supplies one or more clock signals to the other modules. The clock generation module 113 may include phase locked loops and dividers to supply the clock signals at various frequencies. The clock generation module 113 supplies the clocks to the other modules at frequencies controlled by a core power reduction (CPR) controller module 111. All or parts of the functions of the clock generation module 113 may be located in the various modules that use the clock signals.
A power management integrated circuit (PMIC) 115 supplies one or more voltages to the other modules in the system. The PMIC 115 may include switching voltage regulators and low-dropout regulators. The PMIC 115 may be a separate integrated circuit. The voltages supplied by the PMIC 115 are also controlled by the core power reduction controller module 111. Modules of the systems may have one voltage supply or multiple voltages supplies and multiple modules may operate with a common voltage supply.
The processor module 120, the graphics processing unit 130, the modem module 140, and the core module 150 include performance sensors. In the example system of
The core power reduction controller module 111 controls the clock frequencies and the supply voltages used by the modules in the system. The core power reduction controller module 111 may, for example, control the frequencies and voltages based on an operating mode selected by the processor module 120. In an embodiment, the processor selects operating frequencies and the core power reduction controller module 111 determines the supply voltage. The core power reduction controller module 111 can determine the supply voltages based on performance measurements from the performance sensors in the corresponding modules and based on aging from the aging sensors. The core power reduction controller module 111 may determine a supply voltage so that it equals or only slightly (e.g., 10 mV) exceeds the minimum voltage needed for a selected operating frequency. In other embodiments, the core power reduction controller module 111 may control just the clock frequencies. The system may, alternatively or additionally, control other parameters, such as substrate voltage, that affect performance. Example functions of the core power reduction controller module 111 will be further described with reference to the process illustrated in
Prior systems that do not include dynamic de-aging set the supply voltage to a value that substantially exceeds the minimum voltage needed by a guard band amount. The guard band amount (for example, 100 mV) is used to compensate for, among other things, the effect of aging (whose magnitude at any given time is not known). In prior systems, the amount of guard banding for aging is fixed and applied even at the beginning of operation of the system when no aging has occurred. Guard banding has also been used with other parameters, such as clock frequency. The de-aging systems and methods described herein eliminate or reduce the performance loss for guard banding.
The integrated circuit of
The integrated circuit also includes performance sensors 261 that are spaced throughout the integrated circuit area. Although
The performance sensor of
The performance sensor includes an aging sensor 330. The aging sensor 330 can measure the effect of circuit aging. The aging sensor 330 includes delay lines that can be controlled (e.g., by the core power reduction controller module 111) to be in an aging state, an aged oscillating state, or a non-aged oscillating state. In an example embodiment, in the aging state, the delay lines are held in a static powered state. The delay lines are powered with the same supply voltage used by the circuit whose aging is to be sensed by the aging sensor. In the aged oscillating state, the delay lines are coupled to produce a clock output that oscillates at a frequency based on delays of aged circuitry. In the non-aged oscillating state, the delay lines are coupled to produce a clock output that oscillates at a frequency based on delays of non-aged circuitry. The same transistors are used in both the aged oscillating state and the non-aged oscillating state.
The performance sensor includes a control module 320. The control module 320 provides an interface to other modules, for example, to the core power reduction controller module 111 to communicate sensed performance measurements. The control module 320 may also include counters to count oscillations of the PVT sensors 311-319 and the aging sensor 330. The counters can count for a known time interval to measure frequencies of oscillators in the PVT sensors 311-319 or the aging sensor 330. The control module 320 may cause the voltage supply to the PVT sensors 311-319 to be removed when the PVT sensors 311-319 are not performing measurements. The aging sensor 330, however, remains powered during the aging state.
The aging sensor of
The aging sensor includes an aging sensor control module 425 that controls functions of the aging sensor. The aging sensor control module 425 also produces a clock output (CLKOUT) that can indicate performance of both aged circuits and non-aged circuits. The aging sensor control module 425 receives a run control input (RUN). When the run control input is low, the aging sensor is not running (aging state) and the delay chains (also referred to as delay lines) are held in a particular state to age the delay elements. When the run control input is high, the delay chains are coupled to form a ring oscillator whose frequency is slowed by aging (aged oscillating state) or coupled to form a ring oscillator whose frequency is not slowed by aging (non-aged oscillating state). Selection of the aged oscillating state or non-aged oscillating state is controlled by a MIN/MAX control input.
In the embodiment illustrated in
Multiplexer 441 selects between the output (A8) of the first delay chain (when in the run state) and a static low voltage (when not in the run state). Multiplexer 461 selects between the output (B8) of the second delay chain (when in the run state) and a static high voltage (when not in the run state).
Multiplexer 440 selects between the output (AOUT) of multiplexer 441 and the output (BOUT) of multiplexer 461 to supply the input (AIN) of the first delay chain 411. Multiplexer 460 selects between the output (AOUT) of multiplexer 441 and the output (BOUT) of multiplexer 461 to supply the input (BIN) of the second delay chain 412. The selection performed by multiplexer 440 is controlled by a first control signal (INITA) supplied by the aging sensor control module 425, and the selection performed by multiplexer 460 is controlled by a second control signal (INITB) supplied by the aging sensor control module 425.
In the aging state, the input of the first delay chain 411 has a first logic value and the input to the second delay chain 412 has a second logic vale that is the complement of the first logic value. In the embodiment of
In the aging state, multiplexer 441 selects the low voltage input and AOUT is high and multiplexer 461 selects the high voltage input and BOUT is low. The aging sensor control module 425 produces the first control signal (INITA) to be high. Thus, multiplexer 440 selects BOUT (which is low) and the multiplexer output (AIN) is high. The aging sensor control module 425 produces the second control signal (INITB) to be low. Thus, multiplexer 460 selects AOUT (which is high) and the multiplexer output (BIN) is low. This results in the first delay chain 411 and the second delay chain 412 being held in complementary states with alternating delay elements having complementary outputs. In detail, in the first delay chain 411, the output (A0) of the first delay element 450 is low, the output (A1) of the second delay element 451 is high, the output (A2) of the third delay element 452 is low, and so on through to the output (A8) of the ninth delay element 458 being low. And in the second delay chain 412, the output (B0) of the first delay element 470 is high, the output (B1) of the second delay element 471 is low, the output (B2) of the third delay element 472 is high, and so on through to the output (B8) of the ninth delay element 478 being high.
The static voltages on the delay elements tend to age the delay elements so that transitions into the aged states are slowed. For example, the output (A0) of the first delay element 450 was low during aging and falling transitions on that output will be slowed by aging effects. Similarly, the output (A1) of the second delay element 451 was high during aging and rising transitions on that output will be slowed by aging effects. Since rising and falling transitions alternate from delay element to delay element and the transitions that are affected by aging also alternate from delay element to delay element, the entire delay chain is affected by aging for the same transition on the input to the delay chain. The first delay chain 411 is slowed by aging for rising transitions on its input. Similarly, the second delay chain 412 is slowed by aging for falling transitions on its input.
In the aged oscillating state, the aging sensor control module 425 controls the first and second control signals so that the delay chains oscillate with a period that includes the delay of the first delay chain 411 for rising transitions on its input and the delay of the second delay chain for falling transitions on its input. Operation in the aged oscillating state is illustrated in the waveform diagram of
At time 701, the run control input switches high and the MIN/MAX control input is high so that the aging sensor enters the aged oscillating state. The first control signal (INITA) switches high so that multiplexer 440 switches and the input (AIN) to the first delay chain 411 switches low. The falling transition on the input to the first delay chain 411 propagates through the delay chain and through multiplexer 441 to AOUT, which falls at time 702. At this time, the first and second control signals from the aging sensor control module 425 are both low so that AOUT is selected and the inputs to both delay chains rise (the falling of AOUT inverted by multiplexer 440 and multiplexer 460).
The rising transitions on the inputs to the delay chains propagate through both delay chains concurrently. Delays in the first delay chain 411 for a rising transition on its input are slowed by aging. Delays in the second delay chain 412 for a rising transition on its input are not slowed by aging. The rise on the input to the second delay chain 412 propagates through to its output at time 703 and the rise on the input to the first delay chain 411 propagates through to its output at time 704. The difference between time 704 and time 703 is the effect of aging. In
Before time 703, the first and second control signals from the aging sensor control module 425 are set so that multiplexer 440 and multiplexer 460 select AOUT (from the delay chain affected by aging for a rising input). Thus, the inputs to both delay chains fall (the rising of AOUT inverted by multiplexer 440 and multiplexer 460) after time 704.
The rising transitions on the inputs to the delay chains propagate through both delay chains concurrently. Delays in the first delay chain 411 for a falling transition on its input are not slowed by aging. Delays in the second delay chain 412 for a falling transition on its input are slowed by aging. The fall on the input to the first delay chain 411 propagates through to its output at time 705 and the fall on the input to the second delay chain 412 propagates through to its output at time 706. The difference between time 706 and time 705 is the effect of aging.
Before time 705 the first and second control signals from the aging sensor control module 425 are set so that multiplexer 440 and multiplexer 460 select BOUT (from the delay chain affected by aging for a falling input). Thus, the inputs to both delay chains rise and one oscillation of the delay chains is completed. The sequence of signal transitions then repeats as described beginning from time 702.
At time 709, the run control input switches low and the aging sensor switches back to the aging state. The aged oscillating state in
The aging sensor control module 425 can time transitions on its control signals to multiplexer 440 and multiplexer 460 using signals from midpoints of the delay chains. For example, the outputs (A3, B3) of the fourth delay elements in each delay chain may be logically NANDed it to produce the clock output CLKOUT. The clock output may then be used to generate the control signals (INITA, INITB).
In the aged oscillating state (from time 701 to time 709), the period of the clock output combines the delay of the first delay chain for rising transitions on its input and the delay of the second delay chain for falling transitions on its input. Each of these cases is slowed by aging so that the frequency of oscillation can be used to measure the amount of aging that has occurred.
In the non-aged oscillating state, the aging sensor control module 425 controls the first and second control signals so that the delay chains oscillate with a period that includes the delay of the first delay chain 411 for falling transitions on its input and the delay of the second delay chain for rising transitions on its input. Operation in the non-aged oscillating state is illustrated in the waveform diagram of
At time 801, the run signal switches high and the MIN/MAX control signal is low so that the aging sensor enters the non-aged oscillating state. The first control signal (INITA) switches low so that multiplexer 440 switches and the input (AIN) to the first delay chain 411 switches low. The falling transition on the input to the first delay chain 411 propagates through the delay chain and through multiplexer 441 to AOUT, which falls at time 802. At this time, the first and second control signals from the aging sensor control module 425 are both low so that AOUT is selected and the inputs to both delay chains rise (the falling of AOUT inverted by multiplexer 440 and multiplexer 460).
The rising transitions on the inputs to the delay chains propagate through both delay chains concurrently. Delays in the first delay chain 411 for a rising transition on its input are slowed by aging. Delays in the second delay chain 412 for a rising transition on its input are not slowed by aging. The rise on the input to the second delay chain 412 propagates through to its output at time 803 and the rise on the input to the first delay chain 411 propagates through to its output at time 804. The difference between time 804 and time 803 is the effect of aging. In
Before time 803 the control signals from the aging sensor control module 425 are set so that multiplexer 440 and multiplexer 460 select BOUT (from the delay chain not affected by aging for a rising input). Thus, the inputs to both delay chains fall (the rising of AOUT inverted by multiplexer 440 and multiplexer 460) after time 803.
The rising transitions on the inputs to the delay chains propagate through both delay lines concurrently. Delays in the first delay chain 411 for a falling transition on its input are not slowed by aging. Delays in the second delay chain 412 for a falling transition on its input are slowed by aging. The fall on the input to the first delay chain 411 propagates through to its output at time 805 and the fall on the input to the second delay chain 412 propagates through to its output at time 806. The difference between time 806 and time 805 is the effect of aging.
Before time 805 the control signals from the aging sensor control module 425 are set so that multiplexer 440 and multiplexer 460 select AOUT (from the delay chain not affected by aging for a falling input). Thus, the inputs to both delay chains rise and one oscillation of the delay chains is completed. The sequence of signal transitions then repeats as described beginning from time 802.
At time 809, the run control input switches low and the aging sensor switches back to the aging state. The non-aged oscillating state in
The aging sensor control module 425 can time transitions on its control signals to multiplexer 440 and multiplexer 460 using signals from midpoints of the delay chains as described from the aged oscillating state.
In the non-aged oscillating state (from time 801 to time 809), the period of the clock output combines the delay of the first delay chain for falling transitions on its input and the delay of the second delay chain for rising transitions on its input. Each of these cases is not slowed by aging so that the frequency of oscillation can be used to indicate the amount of aging that has occurred. In some cases, the effect of aging may increase the frequency of oscillation in the non-aged oscillating state.
The delay element is an inverter that includes three p-channel transistors 511, 512, 513 whose sources and drains are connected in series between a voltage supply and the output. The gates of the p-channel transistors 511, 512, 513 connect to the input. The delay element includes three n-channel transistors 521, 522, 523 whose sources and drains connected in series between a ground reference and the output. The gates of the n-channel transistors 521, 522, 523 connect to the input. The use of transistors in series can increase the delay of the delay element so that the delay chains in the aging sensor can have fewer stages. Many other types of delay elements may also be used, for example, depending upon particular aging effects of interest.
The aging sensor control module uses NAND gate 611 and buffer 615 to produce the clock output from midpoints (A3, B3) of the delay chains and the run control input (RUN). NAND gate 631 and NAND gate 632 form a set-reset latch that is initialized when the run control input is low and toggled when the clock output rises. The output of NAND gate 631 will be low while the run control input is low (in the aging state) and will then transition high on the first falling edge of the clock output.
Exclusive-OR gate 621 is used to toggle the control signals (INITA, INITB) based on the clock output with their polarity determined by the MIN/MAX control input. The beginning of transitions (after the rise of the run control signal) on the control signals is enabled by NAND gate 622. The first control signal (INITA) is buffered by NAND gate 641 which also controls the value of the first control signal during the aging state (when the run control input is low). The second control signal (INITB) is buffered by inverter 642.
The process uses an aging sensor, for example, the aging sensor of
The relationship between aging measured by the aging sensor and aging of an operational circuit can be determined by characterization testing of actual integrated circuits. For example, the integrated circuits may be operated at various temperatures, frequencies, and voltages and the performance of the aging sensors and performance of the operational modules of the integrated circuit measured over time.
Concepts and variables that are used in the dynamic de-aging process or in the description of the process are defined below.
Aging RO Degradation (ARD) reflects the degradation due to aging of the ring oscillators in the aging sensor. ARD expresses the sensor aging as a percentage change in sensor oscillating frequency due to aging. In an embodiment, ARD=(Fnon-aged−Faged)/Fnon-aged+AED in percent. Fnon-aged is the frequency of the aging sensor in the non-aged oscillating state, which is not sensitive to transistor aging; Faged is the frequency of the aging sensor in the aged oscillating state, which is sensitive to aging and will gradually slow down as the transistors degrade. Therefore, ARD will gradually increase as transistors age. For a domain having multiple aging sensors, ARD is the maximum measurement value from all the aging sensors in the domain. ARD should be >=0. This can be achieved using AED to offset negative values. Alternatively or additionally, the process may set negative ARD values to 0. ARD can be voltage dependent: ARD generally increases as measurement voltage decreases.
Aging Error Distribution (AED) indicates the systematic random variation in the measurements of ARD at time 0 (before aging). Ideally, ARD (at time=0) should be 0, but ARD may be a small random value with a distribution centered on 0. Because ARD is the largest measured value from all of the aging sensors in a domain, it is very likely that ARD (at time=0) is >=0, instead of negative. ARD>=0 at time 0 is fine, but if ARD<0 at time 0, AED is used to guard band ARD. If during product characterization at time=0, the ARD of a domain is negative, then its worst case absolute value will set the AED value.
Aging Scaling Ratio (ASR) indicates the relationship between sensor aging and aging of operational circuits in the associated domain. The aging of operational circuits can be expressed as the change in the maximum operating frequency (Fmax) of those circuits. The process can set ASR=Fmax Degradation/ARD. Fmax Degradation is the amount of change in the maximum operating frequency of the circuits in a domain for particular conditions. The unit level ASR value can be collected from the product high-temperature operating life (HTOL) test units with the worst readout value (of multiple readouts made over the HTOL test) used as the ASR value for circuits in a given domain. One ASR value can be determined from multiple readouts during the product HTOL test. Alternatively, multiple ASR values may be used, for example, in a derating table.
A voltage to frequency scaling factor indicates the relationship between voltage and maximum operating frequency of an operational circuit. The voltage to frequency scaling factor may be expressed as a Voltage of Percent Fmax (VPF) indicating the amount of voltage increase needed to deliver a 1% Fmax increase in a domain. VPF can be determined from product characterization. The highest VPF value measured for a given domain should be used. VPF may be voltage dependent. The voltages can be divided into ranges with multiple VPF values used or a highest VPF value used for all voltages.
Aging Guard Band (AGB) is the amount of voltage increase needed to compensate transistor degradation to maintain the Fmax for circuits of a domain. The process can set AGB=VPF*ASR*ARD. AGB can be updated after each ARD measurement. AGB could be voltage dependent. The process can use multiple AGB values for different ranges of voltages or may scale one AGB value for use at other voltages.
Aging Target Addon (ATA) is a value, converted from AGB, that the process can use to update a coefficient table that indicates what performance sensor measurement values are needed for associated operational modules to operate at various frequencies. This conversion maps the AGB values (which indicate an amount of aging compensation in voltage) to target performance sensor values. This mapping can use, for example, a relationship between supply voltage and performance sensor measurements obtaining from an integrated circuit characterization. The ATA values update the coefficient table values to compensate aging degradation. For example, a coefficient table value that indicates a particular performance sensor measurement value that is needed for an associated operation module to operate at a particular frequency can be increased. In a system that does not use the coefficient table described above, translation of ATA values may be omitted or replaced with other calculations appropriate for that system.
The process of
In block 910, the integrated circuit is initialized with safe voltages and frequencies. This combination of voltages and frequencies has sufficient guard band for reliable operation of the integrated circuit under all expected conditions. The expected conditions may include all conditions for which the integrated circuit is specified to operate. The safe voltages and frequencies allow reliable operation of the integrated circuit for the worst-case aging.
In block 920, the process enables dynamic voltage and frequency scaling in the integrated circuit using initial values in a coefficient table. The coefficient table contains target performance sensor measurement values for various operating frequencies. An example of a dynamic voltage and frequency scaling operation includes measuring performance to obtain a performance sensor measurement, looking up the current operating frequency in the correction table to obtain the corresponding target performance sensor measurement value, and conditionally adjusting the voltage based on the relative values of the performance sensor measurement and the target value. If for example, the performance sensor measurement is less than the target value, the voltage may be raised to increase circuit speeds. The initial values in the coefficient table include sufficient guard banding for end-of-life (EOL) aging of the integrated circuit. The initial values may be determined by characterization of the integrated circuit. The guard banding for end-of-life aging may be effected by using an initial ATA value. The process then continues to perform de-aging based on sensed aging.
In block 930, the process measures aging of the integrated circuit. Block 930 can include measuring ARD according to ARD=(Fnon-aged−Faged)/Fnon-aged+AED. In an embodiment, Faged is measure before Fnon-aged. This can avoid or minimize reversal of effects of aging that may occur when the aging sensor oscillates to perform the measurements. The process can then calculate AGB according to AGB=VPF*ASR*ARD. AGB is calculated in the normal (non-standby) mode. The process can then calculate ATA to replace the initial (or current) ATA. In an embodiment, the process limits the amount of ATA to a maximum end-of-life value, which may be determined by characterization of the integrated circuit. In various embodiments, ARD may be measured at a fixed voltage or at currently used operating voltages associated with the aging sensors.
In block 940, the process updates the coefficient table based on the aging sensed in block 930. A process can update the coefficient table for one frequency, all frequencies, or a range of frequencies. Alternatively, the process may update the coefficient table before enabling dynamic voltage and frequency scaling. In another alternative, update the coefficient table for the initialized operating frequency, enables dynamic voltage and frequency scaling, and then updates the full coefficient table.
In block 950, the integrated circuit operates using dynamic voltage and frequency scaling with the updated coefficient table from block 940.
Periodically, the process returns to blocks 930 and 940 to further update the coefficient table for the effects of aging. The process may update the coefficient table based on expiration of a timer. The period of the updates may be, for example, one minute, 10 minutes, or hourly. The period between updates may change over time, for example, with less frequent updates as the integrated circuit ages. Additionally or alternatively, the process may update the coefficient table based on a change in operational mode of the integrated circuit or an operational module of the integrated circuit. For example, the coefficient table may be updated when the integrated circuit switches from an operating mode to a standby mode or vice versa.
The process for dynamic de-aging may be modified, for example, by adding, omitting, reordering, or altering blocks. For example, the process may de-age by adjusting clock frequencies (or other performance parameters). In such an embodiment, the process may omit the calculations using the voltage to frequency scaling factor. Additionally, blocks may be performed concurrently.
Although embodiments of the invention are described above for particular embodiments, many variations of the invention are possible. For example, the numbers of various components may be increased or decreased. The described systems and methods may be modified depending upon the particular aging effects that are most important in an integrated circuit. The aging sensor may be tailored according to the specific fabrication technology of an integrated circuit. An integrated circuit may contain multiple aging sensors to measure multiple aging effects. Additionally, features of the various embodiments may be combined in combinations that differ from those described above.
Those of skill will appreciate that the various illustrative blocks and modules described in connection with the embodiments disclosed herein can be implemented in various forms. Some blocks and modules have been described above generally in terms of their functionality. How such functionality is implemented depends upon the design constraints imposed on an overall system. Skilled persons can implement the described functionality in varying ways for each particular application, but such implementation decisions should not be interpreted as causing a departure from the scope of the invention. In addition, the grouping of functions within a module or block is for ease of description. Specific functions can be moved from one module or block or distributed across to modules or blocks without departing from the invention.
The various illustrative logical blocks and modules described in connection with the embodiments disclosed herein can be implemented or performed with a general purpose processor, a digital signal processor (DSP), application specific integrated circuit (ASIC), a field programmable gate array (FPGA) or other programmable logic device, discrete gate or transistor logic, discrete hardware components, or any combination thereof designed to perform the functions described herein. A general-purpose processor can be a microprocessor, but in the alternative, the processor can be any processor, controller, microcontroller, or state machine. A processor can also be implemented as a combination of computing devices, for example, a combination of a DSP and a microprocessor, a plurality of microprocessors, one or more microprocessors in conjunction with a DSP core, or any other such configuration.
The steps of a method or algorithm described in connection with the embodiments disclosed herein can be embodied directly in hardware, in a software module executed by a processor, or in a combination of the two. A software module can reside in RAM memory, flash memory, ROM memory, EPROM memory, EEPROM memory, registers, hard disk, a removable disk, a CD-ROM, or any other form of storage medium. An exemplary storage medium can be coupled to the processor such that the processor can read information from, and write information to, the storage medium. In the alternative, the storage medium can be integral to the processor. The processor and the storage medium can reside in an ASIC.
The above description of the disclosed embodiments is provided to enable any person skilled in the art to make or use the invention. Various modifications to these embodiments will be readily apparent to those skilled in the art, and the generic principles described herein can be applied to other embodiments without departing from the spirit or scope of the invention. Thus, it is to be understood that the description and drawings presented herein represent a presently preferred embodiment of the invention and are therefore representative of the subject matter which is broadly contemplated by the present invention. It is further understood that the scope of the present invention fully encompasses other embodiments that may become obvious to those skilled in the art and that the scope of the present invention is accordingly limited by nothing other than the appended claims.
This application claims the benefit of U.S. provisional application Ser. No. 61/973,765, filed Apr. 1, 2014, which is hereby incorporated by reference.
Number | Date | Country | |
---|---|---|---|
61973765 | Apr 2014 | US |