1. Field of the Invention
The present invention relates generally to an apparatus and method for controlling power supply and power distribution system noise. More specifically, the present invention provides a method and apparatus for detecting noise events in a system with time variable operating points.
2. Description of the Related Art
Power supply and power distribution system noise, especially dips due to large step activity increases in a microprocessor, are a limiting factor in how fast the circuits in such a processor can operate. This either limits the system operating frequency or limits chips that can yield at any given objective frequency. Traditionally, decoupling capacitors have been used to limit the magnitude of this noise. However, as design frequencies have risen over the years, decoupling capacitance is becoming either less effective at the frequencies that are required to have an effect, or are too costly in financial terms or power dissipation terms. That is, in terms of chip real estate and oxide leakage impact on chip power requirements.
Electrical distance from capacitor placement sites to circuits on chips constrained by physical space availability can make discrete capacitors completely or nearly ineffective. Therefore, it would be useful to have a mechanism for detecting noise events that indicate that further executions will cause the voltage in a circuit to dip to unacceptably low levels.
Current solutions may utilize a circuit with a precision direct current (DC) reference to determine if the noise being detected is of a sufficient magnitude to cause action to be taken. However, use of a fixed DC reference will not allow distinguishing between high frequency noise and other drift, set-point granularity, voltage drops due to current and power distribution resistance, and other low frequency and DC variances from the perfect reference. Drift is a low frequency fluctuation. Set-point granularity means that there are only finite discrete points that can be generated. Points between these finite points are off limits and cannot be generated. Therefore, it would be desirable to determine a way to address these issues in a cost effective manner by using the voltage being monitored as the reference.
Exemplary embodiments provide a circuit and a method for detecting noise events in a system with time variable operating points. A switched capacitor filter comprising a plurality of capacitor units, samples a first voltage to determine an average of a set of voltage measurements, forming an average voltage. A filter control unit controls the plurality of capacitor units in the switched capacitor filter. A comparing unit compares the average voltage to the first voltage to form a comparison. A signaling unit generates a signal to instruct circuits in a processor to initiate actions to keep the first voltage from drooping below a threshold level in response to the comparison.
The novel features believed characteristic of the invention are set forth in the appended claims. The invention itself, however, as well as a preferred mode of use, further objectives and advantages thereof, will best be understood by reference to the following detailed description of an illustrative embodiment when read in conjunction with the accompanying drawings, wherein:
Resistors 106 and 108 comprise a second resistor divider network that presents a second fraction for the Vdd voltage to the non-inverting input of the comparator 112. This voltage is filtered by capacitor 110 so that the voltage at the non-inverting input of the comparator 112 is averaged over the time period determined by the values of resistors 106 and 108 and capacitor 110. The second fraction is slightly less than the first fraction. The second fraction is represented by the term (φ−δ). δ is representative of a value between 0 and that represented by first fraction φ. δ divided by φ represents the fraction of the average voltage on Vdd, which should the noise droop below that average voltage on Vdd, then initiation of instruction executions will be stalled. Latch 114 is comprised of Din, where the comparator inputs to the latch; Qout, which sends the output signal to prevent scheduling of an execution task; and a processor clock input. The unfiltered Vdd containing noise, φVdd, is compared to the filtered Vdd, (φ−δ)Vdd, by comparator 112. If φVdd is lower than (φ−δ)Vdd, then comparator 112 sends a signal to latch 114, and latch 114 sends the message to disallow the scheduling of a subsequent execution task.
Exemplary embodiments utilize switched capacitor technology in a novel manner in order to obtain very accurate criteria for averaging period and droop threshold level without requiring any calibration processes to mitigate process tolerances on the circuit elements. Exemplary embodiments do not impose any variations in normal integrated circuit manufacturing processes.
A traditional switched capacitor unit first charges a capacitor of value C to voltage Vin within a given sequence of events. This sequence of events is repeated at a sampling frequency F. The capacitor C is charged rapidly with respect to the period of the sampling frequency. During the time period that the capacitor C is not being charged to the input voltage Vin, the input voltage Vin is shorted to another capacitor C′. For this well known circuit, the voltage across C′ is related to the input voltage as Vc=Vie−t/τ where the time constant τ=C′/(Cf). This can also be expressed as a −3 dB Bandwidth of 1/(2πτ), or Cf/(2πC′). In a traditional switched capacitor filter, the capacitor C along with the switches to transfer charge into and out of it at a frequency F act equivalent to a resistor of value 1/(Cf).
The input signal sampling is done so that the average of the unit capacitor to total capacitance along with the sampling rate of that input signal sets both the bandwidth of the filter as well as the low frequency attenuation of the filter. Thus, the tolerances of the capacitors that make up the switched capacitor circuits do not affect the accuracy of the bandwidth and the low frequency attenuation parameters, as would use of a passive RC filter, resistive voltage divider, or simple switched capacitor filter.
Latch 208 is comprised of Din, where the comparator inputs to the latch; Qout, which sends the output signal to prevent scheduling of an execution task; and processor clock input 210. The unfiltered input voltage containing noise, Vdd, is compared to the attenuated and filtered average filtered Vdd(avg), by comparator 206. The attenuated and filtered Vdd(avg) is decreased by switched capacitor filter 204 such that it is on average some set fraction less in voltage than Vdd. If Vdd is lower than Vdd(avg), then comparator 206 sends a signal to latch 208, and latch 208 sends the message to disallow the scheduling of a subsequent execution task.
In another exemplary embodiment, comparator 206 sends a signal to latch 208, and latch 208 sends a signal to other circuits in the processor to initiate actions to keep the voltage from drooping below a threshold level if Vdd is lower than Vdd(avg) by a specified criteria. In another exemplary embodiment, comparator 206 sends a signal to latch 208, and latch 208 sends a signal to other circuits in the processor to initiate actions to keep the voltage from drooping below a threshold level if Vdd is higher than Vdd(avg) by a specified criteria. The specific criteria will vary with the particular implementation. However, some examples of specific criteria may be if the voltage is higher or lower than a specific amount, or range, or if the voltage exceeds a certain range. Another example would be if the Vdd were either higher or lower than the Vdd(avg) by a specific percentage of the Vdd(avg).
The α control signal, sometimes referred to simply as an α signal or α, is a charging control signal. That is, the α signal controls sampling or charging of the capacitor units. The γ control signal, sometimes referred to simply as a γ signal or γ, is a discharging control signal. The β control signal, sometimes referred to simply as a β signal or β, is a strong switch charge averaging control signal. The ζ control signal, sometimes referred to simply as a ζ signal or ζ, is a weak switch charge averaging control signal.
In timing chart 500, time is the horizontal axis. Timing chart 500 comprises chart segments 502, 504 and 506. Filter period 508 is the filter period. Chart segment 502 represents the timing relationship of a capacitor unit n=0. Chart segment 504 represents the timing relationship of a capacitor unit n=1. Chart segment 506 represents the timing relationship of a capacitor unit n=i−1. Make before break 510 illustrates that the β0 transistor of the (n−1=0)th capacitor unit turns on before the ζ1 and β1 transistor of the (n=1)th capacitor unit turns off. Break before make 512 illustrates that the ζ0 and β0 transistor of the (n=0)th capacitor unit turns off before the α0 or γ0 transistor of that capacitor unit turns on. Break before make 512 also illustrates that the α0 or γ0 transistor of the (n=0)th capacitor unit turns off before the ζ0 transistor of that capacitor unit turns on.
Timing chart 500 assumes that signal γ was not activated. Thus, switched capacitor network 300 in
The larger and stronger that the transistor or pass gate is the more undesired noise that the transistor or pass gate induces on the filtered output voltage. A physically larger gate and channel, which are parts of the transistor, result in large transistor gate capacitance relative to the capacitor C capacitance. Weaker transistors will have higher resistance when switched on than stronger ones. The transistor or pass gate associated with ζ is weaker than the one associated with β so that the noise introduced on the Vdd(avg) node is minimized. Thus, ζ is referred to as a weak switch charge averaging control signal while β is referred to as a strong switch charge averaging control signal.
Because all βs are active except the nth one when αn is activated, all capacitors not involved in sampling the input voltage are involved in storing an accumulated charge. The equation of the capacitance times the sampled voltage minus the average voltage, expressed as C*(Vsampled−Vavg), is the charge delivered to i minus one times capacitance capacitors, expressed as (i−1)*C capacitors, each period at a frequency, F.
Therefore, since the charge can also be represented by the ratio of the average current to the frequency, expressed as Iavg/F, then, by rearranging the variables, the expression Iavg/F=C(dV) or dV/Iavg=1/(C*F) is arrived at. In other words, the average current divided by the sampling, or charge transfer frequency, is equal to the capacitance of the capacitor divided by the voltage change when charging the capacitor. Rearranging variables, the voltage change divided by the average current is equal to the reciprocal of capacitance times the charge transfer or sampling frequency.
Thus a capacitor unit controlled by the α, β, γ, and ζ control signals as shown in
By sequencing through all i capacitor units, exemplary embodiments significantly reduce the tolerance effects of the capacitor units. The average capacitance of all i capacitors is Cavg, and the deviation from this average capacitance for the nth unit is Cdeltan. Then the filter's single pole response −3 dB Bandwidth may be expressed as the multiplicative inverse of 2π times the ratio of the sampling frequency multiplied by the quantity of the average capacitance plus the deviation from the average capacitance to the number of unit capacitors multiplied by the average capacitance minus the average capacitance minus the deviation from the average capacitance, F* (Cavg+Cdeltan)/2π(i*Cavg−Cavg−Cdeltan). Assuming that Cdeltan is small compared to (i−1)*Cavg, then the −3 dB Bandwidth is approximately {F/2π(i−1)}*(1+Cdeltan/Cavg). In other words, the tolerance of the switched capacitor filter's −3 dB Bandwidth is the same as that of the unit capacitor. Tolerance is the fraction of variance in the expected performance or value relative to the design nominal performance or value.
Exemplary embodiments provide that each of the unit capacitors are used to do the sampling such that each unit capacitor is used over i sample periods, then the tolerance contribution from each unit capacitor would be an ith of the tolerance of the unit capacitor, and the sum of i of these tolerance contributions would be zero (0). This is because the definition of average is that the sum of all the contributing variations from the average is zero (0). In other words, the average aavg=(a0+a1+ . . . +an+ . . . +ai)/i, if a0=aavg+adeleta
Exemplary embodiments provide a circuit that uses all unit capacitors in a switched capacitor network equally to sample the input voltage. Thus, the bandwidth tolerance is dominated by the frequency tolerance. The collection of capacitor unit 400 of
Since in this configuration, exemplary embodiments are sampling i samples per the frequency of activating αn, then the single pole −3 dB Bandwidth of the filter is F*i/2π(i−1). Therefore, for example, assume a processor clock frequency of 4.6 GHz, and a low pass filter with a three decibel (3 dB) bandwidth of four hundred and ninety kilo-hertz (490 KHz) for voltage averaging is required. If there are 32 capacitor units (i) then an αn signal would have to be activated every 1536 clock cycles. This means that αn+1 would be activated 48 clock cycles after αn was activated.
The γ control allows the filter's low frequency attenuation to be adjusted. This low frequency attenuation is the gain of the filter at low frequency as the frequency asymptotically approaches DC. For purposes of the present exemplary embodiments, the low frequency attenuation will always be less than one. Adjusting the filter's low frequency attenuation is required in the voltage droop sensing mechanism so that a noise droop threshold can be implemented in the sensing mechanism. In an exemplary embodiment, a function of the filter control would determine when the activation of any αn should instead activate a γn. A ratio of the number of α to the number of α+γ activations determines the low frequency transfer function of the filter. α and γ are never active at the same time (see timing chart 500 in
In order that the low frequency attenuation is not affected by capacitance tolerances, the repetition rate of α/γ must be chosen so that the rate does not share prime number factors with i. By making sure this repetition rate is not divisible by the number of capacitor units i, then any one single particular capacitor unit will not always be involved in the γ activation. By cycling through capacitor units that are involved in the γ activation, the capacitor tolerances will average out. This is easy to accomplish if either i or α/γ is set as a power of two (2) and the other is set as an odd number. In an exemplary embodiment i is chosen to be the statistically significant value of thirty-two (32), which is a power of two (2), and α/γ is chosen to be twenty-five (25). This sets the low frequency transfer function at 25/26ths of the Vdd with a very small tolerance.
State machine 600 is initially configured by programming the parameter ‘k’ to control the time delays between activation of the α, β, γ, and ζ control signals to one nth capacitor unit 304 of
For example, the state machine transitions between states 602 and 604 at some processor clock input 210 of
Phase select state machine 700 is then sequenced forward by a master filter control state machine as reflected in the state transition from cycle 612 to cycle 602 of state machine 600 of
Eventually phase select state machine 700 is sequenced by the master filter control state machine to state 706. State 706 indicates that that unit capacitor i should have αi and βi reflect the α and β values from state machine 600 of
Cycle γ control state machine 800 is then cycled by a master filter control state machine from state 804 back to state 802. This causes cycle γ control state machine 800 to multiplex the global γ signal to a global α signal. Thus, if a master filter control state machine activates a global α signal while cycle γ control state machine 800 is in state 802, a global α signal will be activated.
Filter control 900 comprises master filter control state machine 902, cycle γ control state machine 904, phase select state machine 906, AND gates 918, and NOT gates 920. An AND gate is a basic logic element. An AND gate produces an output of one (1) only if all of the received inputs are one (1). A NOT gate, often referred to as a complement gate or an inverter, is a basic logic element that produces an output value that is the opposite of the input value.
Master filter control state machine 902 may be implemented as state machine 600 in
Cycle γ control state machine 904 illustrates a circuit implementation that satisfies the function of cycle γ control state machine 800 in
The average voltage is then compared to an instance of the first voltage by a comparator to form a comparison (step 1108). In response to the comparison, a signal is generated to instruct the processor to initiate actions to keep the first voltage from drooping below a threshold level (step 1110) and the operation ends.
Thus, exemplary embodiments utilize switched capacitor technology in a novel manner in order to obtain very accurate criteria for averaging period and droop threshold level without requiring any calibration processes to mitigate process tolerances on the circuit elements. Furthermore, exemplary embodiments do not impose any variations in normal integrated circuit manufacturing processes.
Those skilled in the art may recognize that these functions described above may be accomplished via other means such as logic sequencers, random logic macros, asynchronous state machine logic, etc. The parameter values, including representative numbers of capacitor unit 400, bandwidth, etc. referenced in the description above can be increased or decreased to meet the needs of the applications according to the principles described herein. Those skilled in the art will recognize that additional transistors or switches with controls incorporated in and around the basic comparator unit 206 do not alter the basic function of the circuits, but may provide additional mechanisms to manage noise. The description above has been presented for purposes of illustration and description, and is not intended to be exhaustive or limited to the invention in the form disclosed. Many modifications and variations will be apparent to those of ordinary skill in the art. The embodiment was chosen and described in order to best explain the principles of the invention, the practical application, and to enable others of ordinary skill in the art to understand the invention for various embodiments with various modifications as are suited to the particular use contemplated.
Another exemplary embodiment of the present invention provides for sensing the Vdd voltage with sample and hold circuitry such that the samples were taken at the same point in the processor clock cycle period so that the high frequency ripple may be filtered out at frequency.
This circuit may be replicated around each of the execution units in a microprocessor and may operate either in sync, or independently from similar circuits placed throughout the microprocessor. The execution stall can be done on a per unit basis if need be, and indeed may be an exemplary embodiment since the spatial separation of units may result in some electrical isolation as well.
The circuit as described above is part of the design for an integrated circuit chip. The chip design is created in a graphical computer programming language, and stored in a computer storage medium (such as a disk, tape, physical hard drive, or virtual hard drive such as in a storage access network). If the designer does not fabricate chips or the photolithographic masks used to fabricate chips, the designer transmits the resulting design by physical means (e.g., by providing a copy of the storage medium storing the design) or electronically (e.g., through the Internet) to such entities, directly or indirectly. The stored design is then converted into the appropriate format (e.g., GDSII) for the fabrication of photolithographic masks, which typically include multiple copies of the chip design in question that are to be formed on a wafer. The photolithographic masks are utilized to define areas of the wafer (and/or the layers thereon) to be etched or otherwise processed.
The description of the present invention has been presented for purposes of illustration and description, and is not intended to be exhaustive or limited to the invention in the form disclosed. Many modifications and variations will be apparent to those of ordinary skill in the art. The embodiment was chosen and described in order to best explain the principles of the invention, the practical application, and to enable others of ordinary skill in the art to understand the invention for various embodiments with various modifications as are suited to the particular use contemplated.
Number | Name | Date | Kind |
---|---|---|---|
4810101 | Kage et al. | Mar 1989 | A |
5606511 | Yach | Feb 1997 | A |
5894423 | Ling et al. | Apr 1999 | A |
6191647 | Tanaka et al. | Feb 2001 | B1 |
6219723 | Hetherington et al. | Apr 2001 | B1 |
6472856 | Groom et al. | Oct 2002 | B2 |
6538497 | Thomas et al. | Mar 2003 | B2 |
6636976 | Grochowski et al. | Oct 2003 | B1 |
6675301 | Kurosawa et al. | Jan 2004 | B1 |
6721903 | Yoshioka et al. | Apr 2004 | B2 |
6799070 | Wolfe et al. | Sep 2004 | B2 |
6819538 | Blaauw et al. | Nov 2004 | B2 |
6922111 | Kurd et al. | Jul 2005 | B2 |
6934865 | Moritz et al. | Aug 2005 | B2 |
6978388 | Cornelius | Dec 2005 | B1 |
7000122 | Zafarana et al. | Feb 2006 | B2 |
7035785 | Grochowski et al. | Apr 2006 | B2 |
7071723 | Krishnamoorthy et al. | Jul 2006 | B2 |
7134036 | Guan | Nov 2006 | B1 |
7233163 | Krishnamoorthy et al. | Jun 2007 | B2 |
7236920 | Grochowski et al. | Jun 2007 | B2 |
7239494 | Naffziger | Jul 2007 | B2 |
7339411 | Yuuki et al. | Mar 2008 | B2 |
7467050 | Douriet et al. | Dec 2008 | B2 |
7480810 | Gonzalez et al. | Jan 2009 | B2 |
7483248 | Ho et al. | Jan 2009 | B1 |
20040085085 | Muhtaroglu et al. | May 2004 | A1 |
20040123166 | Gauthier et al. | Jun 2004 | A1 |
20050062507 | Naffziger et al. | Mar 2005 | A1 |
20060132086 | Altenburg et al. | Jun 2006 | A1 |
20070006012 | Mosur et al. | Jan 2007 | A1 |
20070283172 | Douriet et al. | Dec 2007 | A1 |
20070296391 | Bertin et al. | Dec 2007 | A1 |
20080007272 | Ferraiolo et al. | Jan 2008 | A1 |
20080082887 | Dhong et al. | Apr 2008 | A1 |
20090048794 | Douriet et al. | Feb 2009 | A1 |
20090063065 | Weekly | Mar 2009 | A1 |
20090063884 | Weekly | Mar 2009 | A1 |
Number | Date | Country | |
---|---|---|---|
20090091378 A1 | Apr 2009 | US |