Login| Sign Up| Help| Contact|

Patent Searching and Data


Title:
ADAPTIVE DIGITAL CONTROLLER INCLUDING LINEAR AND NON-LINEAR CONTROL MECHANISM
Document Type and Number:
WIPO Patent Application WO/2018/191067
Kind Code:
A1
Abstract:
Some embodiments include apparatuses and methods of using such apparatuses. One of the apparatuses includes a control circuitry to generate error information based on a value of the feedback voltage generated from an output voltage, generate output information to control a power switching unit based on the error information provided to a forward path in the control circuitry, and adjust a gain of the forward path based on a gain factor computed based at least in part on a first value of the output information in order to cause the output information to have a second value. The control circuitry also computes a value of correction information when the output voltage is within a target value range, and adjusts the control information, based on the correction information, when the output voltage is outside the target value range.

Inventors:
MAHAJAN TARUN (IN)
MUTHUKARUPPAN RAMNARAYANAN (IN)
SIDANA RAJESH (IN)
PAI SRINATH B (IN)
Application Number:
PCT/US2018/025897
Publication Date:
October 18, 2018
Filing Date:
April 03, 2018
Export Citation:
Click for automatic bibliography generation   Help
Assignee:
INTEL CORP (US)
International Classes:
G06F1/32; G05B6/02; G05F1/66
Foreign References:
US20160282889A12016-09-29
US8587274B22013-11-19
US7777461B22010-08-17
US20140266119A12014-09-18
US20140125306A12014-05-08
Other References:
See also references of EP 3610353A4
Attorney, Agent or Firm:
PERDOK, Monique M., Reg. No. 42,989 et al. (US)
Download PDF:
Claims:
CLAIMS

What is claimed is:

1. An electronic apparatus comprising:

an output to provide output information to control transistors of a power switching unit;

a node to receive a feedback voltage based on an output voltage generated by the power switching unit; and

a control circuitry to:

generate error information based on a value of the feedback voltage generated from the output voltage;

generate the output information based on the error information provided to a forward path coupled to the output; and

adjust a gain of the forward path based on a gain factor computed based at least in part on a first value of the output information during a first time interval in order to cause the output information to have a second value during a second time interval.

2. The apparatus of claim 1, wherein the control circuitry is to cause the output information to have the first and second values when the output voltage is within a target value range.

3. The apparatus of claim 1, wherein the control circuitry includes a linear controller, the linear controller includes a multiplier, the multiplier including: a first input to receive input information based on the first value of the output information;

a second input to receive information from a memory circuit in the control circuitry; and

an output to provide the gain factor.

4. The apparatus of claim 1, wherein the control circuitry is to receive a clock signal and generate the error information based on timing of the clock signal, and the control circuitry is to adjust the gain of the forward path in each cycle of the clock signal.

5. The apparatus of claim 1, wherein the control circuitry is to:

generate the output information based on the error information provided to an addition forward path coupled to the output; and

adjust a gain of the additional forward path based on an additional gain factor computed based at least in part on the first value of the output information during the first time interval in order to cause the output information to have the second value during the second time interval.

6. The apparatus of any of claims 1-5, further comprising an analog-to- digital converter to generate the error information based on the feedback voltage and a range of reference voltages.

7. The apparatus of any of claims 1-5, wherein the control circuitry includes:

a first forward path to receive the error information, the first forward path including a first adaptive gain circuitry to generate the gain factor to adjust the gain of the first forward path;

a second forward path to receive the error information, the second forward path including a second adaptive gain circuitry to generate an additional gain factor to adjust a gain of the second forward path based on the additional gain factor; and

a feedback path coupled to the output and the first and second forward paths.

8. An electronic apparatus comprising:

an output port to provide control information to control transistors of a power switching unit; and

a control circuitry to:

generate the control information such that a value of an output voltage generated by the power switching unit is less than a value of an input voltage provided to the power switching unit;

compute a value of correction information during a first time interval when the output voltage has a first value within a target value range; and adjust a value of the control information, based on the correction information, during a second time interval when the output voltage has a second value outside the target value range.

9. The apparatus of claim 8, wherein the control circuitry is to compute the value of the correction information based on a rate of change of a current at a node where the output voltage is provided.

10. The apparatus of claim 8, wherein the correction information indicates an amount of current to be adjusted at the node during the second time interval.

11. The apparatus of any of claims 8- 10, wherein the control circuitry is to receive a clock signal, and the control circuitry is to adjust the value of the control information at a time less than one cycle of the clock signal from a time the second value of the output voltage is detected to be outside the target value range.

12. The apparatus of any of claims 8-10, wherein the control circuitry is to receive a clock signal, and wherein:

the second value of the output voltage is detected to be outside the target value range at a first edge of the clock signal; and

the control circuitry is to start to adjust the value of the control information at a second edge of the clock signal, the second edge occurring in less than one cycle of the clock signal from an occurrence of the first edge.

13. The apparatus of any of claims 8-10, wherein the control circuitry is to receive a clock signal, and the control circuitry is to compute the correction information during a time interval between two consecutive edges of the clock signal.

14. The apparatus of any of claims 8-10, wherein the control circuitry is to receive a clock signal, the control circuitry is to compute the correction information based on a count value, and the count value corresponds to a number of rising and falling edges of the clock signal.

15. The apparatus of any of claims 8- 10, wherein the control circuitry is to compute the value of the correction information based on a rate of change of a current from a time the second value of the output voltage is detected to be outside the target value range to a time a half cycle after the time the second value of the output voltage is detected to be outside the target value range.

16. The apparatus of any of claims 8-10, wherein:

the control circuitry is to adjust the value of the control information during a first portion of the second time interval based on the correction information; and

the control circuitry is to adjust the value of the control information during a second portion of the second time interval based on error information generated from a comparison of a range of reference voltages with a feedback voltage generated from the output voltage.

17. An electronic apparatus comprising:

a power switching unit to receive an input voltage to provide an output voltage having a value less than a value of the input voltage;

an error code generator to generate first error correction information and second error correction information based on errors in the output voltage;

a first controller to generate first output information to control the power switching unit during a first mode when the output voltage has a first value within a target value range, the first controller to compute a gain of a forward path during the first mode in order to cause the first output information to have a second value during the first mode; and

a second controller to compute a value of correction information during the first mode, and to control the power switching unit during a second mode, based on the correction information, when the output voltage has a second value outside the target value range.

18. The apparatus of claim 17, wherein the first controller includes forward paths implemented based on a single set of coefficients.

19. The apparatus of claim 17, wherein the first controller includes a memory circuit to store information to compute the gain.

20. The apparatus of any of claims 17-20, wherein the second controller is to control the power switching unit in an initial stage of the second mode, and the second controller is to control the power switching unit in a second stage of the second mode based on error information different from the correction information.

21. An electronic apparatus comprising:

a semiconductor die;

a processing unit located on the semiconductor die; and

a voltage regulator located on the semiconductor die and coupled to the processing unit, the voltage regulator including:

a power switching unit to receive an input voltage to provide an output voltage having a value less than a value of the input voltage;

an error code generator to generate first error correction information and second error correction information based on errors in the output voltage;

a first controller to generate first output information to control the power switching unit during a first mode when the output voltage has a first value within a target value range, the first controller to compute a gain of a forward path during the first mode in order to cause the output information to have a second value during the first mode; and

a second controller to compute a value of correction information during the first mode, and to control the power switching unit during a second mode, based on the correction information, when output voltage has a second value outside the target value range.

22. The apparatus of claim 21, wherein the first mode includes a linear mode, and the second mode includes a non-linear mode.

23. The apparatus of claim 21 or 22, wherein the semiconductor die, the processing unit, and the voltage regulator are parts of a system-on-chip (SoC).

24. A method of operating an electronic apparatus, the method comprising: generating control information at a first controller of a voltage regulator to control a voltage at a node;

computing a gain of a forward path in the first controller to adjust a first value of the control information during a first mode of the voltage regulator when the voltage has a first value within a target value range;

generating correction information at a second controller of the voltage regulator during the first mode; and

adjusting a second value of the control information, based on the correction information, during a second mode of the voltage regulator when the voltage has a second value outside the target value range.

25. The method of claim 24, wherein the forward path is part of multiple forward paths of the first controller, and the multiple paths are implemented using a single set of coefficients.

Description:
ADAPTIVE DIGITAL CONTROLLER INCLUDING LINEAR AND NON-LINEAR CONTROL MECHANISM

CLAIM OF PRIORITY

[0001] This patent application claims the benefit of priority to U. S.

Application Serial No. 15/484,404, filed April 11, 2017, which is incorporated by reference herein in its entirety.

TECHNICAL FIELD

[0002] Embodiments described herein pertain to power management in electronic systems. Some embodiments relate to voltage regulators.

Background

[0003] Many electronic devices or systems (e.g., computers, tablets, and cellular phones) have power management components (e.g., voltage regulators) to control voltage (e.g., supply voltage) in the device or system. The power management components may regularly monitor the value of voltage in the device or system order to maintain the voltage within a target value range.

During some events (e.g., a surge in current consumption) in the operations of the device, the value of the voltage may suddenly deviate from the target value range. Some conventional techniques provide control mechanisms to deal with such events. However, different devices have different operational schemes. Thus, some conventional control mechanisms designed to work with certain devices may be unsuitable for some other devices.

BRIEF DESCRIPTION OF THE DRAWINGS

[0004] FIG. 1 shows a block diagram of an apparatus including a voltage regulator and a load, according to some embodiments described herein.

[0005] FIG. 2 shows a schematic diagram of an error code generator of the voltage regulator of FIG. 1, according to some embodiments described herein. [0006] FIG. 3 shows a plant model for a power-FET (field-effect transistor) structure implemented in the voltage regulator of FIG. 1, according to some embodiments described herein.

[0007] FIG. 4 illustrates a simplified implementation of a digital linear controller of the voltage regulator of FIG. 1, according to some embodiments described herein.

[0008] FIG. 5 A shows a diagram of adaptive gain circuitry of the digital linear controller of FIG. 4, according to some embodiments described herein.

[0009] FIG. 5B shows a multiplier of the adaptive gain circuitry of FIG. 5 A, according to some embodiments described herein.

[0010] FIG. 6 shows a diagram of another adaptive gain circuitry of the digital linear controller of FIG . 4, according to some embodiments described herein.

[0011] FIG.7 shows an example waveform of an output voltage and a load current during an example droop event, according to some embodiments described herein.

[0012] FIG. 8 shows a simplified architecture diagram of a non-linear controller of the voltage regulator of FIG. 1, according to some embodiments described herein.

[0013] FIG. 9 shows a block diagram of count measurement logic circuitry of the non-linear controller of FIG. 8, according to some embodiments described herein.

[0014] FIG. 10 shows an apparatus in the form of an electronic system, according to some embodiments described herein.

[0015] FIG. 11 is a flowchart showing a method of operating an apparatus, according to some embodiments described herein.

DETAILED DESCRIPTION

[0016] In many devices (e.g., processors), power management (e.g., fine- gain power-management using dynamic voltage and frequency scaling (D VFS)) becomes important in improving performance relative to power ratio in different power states of the device. In these devices, entry and exit from certain operating modes (e.g., idle to burst mode) can happen very quickly (e.g., in few core clock cycles with core frequency in GHz range). Functional units (e.g., multi-core central processing units (CPUs)) in these devices may operate with a wide load current (LOAD) range, which in turn can lead to wide variation in the rate (di/dt) at which the load current changes during load step (when load current increases). These fast load transients (e.g., fast changes in load current) can result in large droops (a sudden decrease in voltage value) on the supply voltage of a device where on-die load capacitance may be limited (e.g., due to small die area). Such droops in the supply voltage could limit the speed (e.g., core frequency) of the device.

[0017] Conventional low-dropout (LDO) regulator circuitry provides a viable low-cost solution where switching voltage controller integration into die/package is impractical. The LDO circuitry can also allow second-level power management (a second level of fine-grain power-management) if a voltage supply from the same supply rail provides power to multiple functional units in the same device. LDO circuitry can allow optimal voltage supply for each functional unit. Digital LDO circuitry is becoming increasingly popular due to its scalability and ultra-low voltage operation (near-threshold operation) where analog circuits may be unsuitable. The digital control of LDO circuitry and associated power transistors may allow flexibility for device re- configurability. Some conventional linear digital controllers can provide a stable and smooth transient response with low steady-state error for different ranges of load current and output voltage conditions. However, such linear digital controllers may operate with fixed sampling frequency and may be limited by the band- width of the control loop. This may make such conventional linear controllers unsuitable to provide sufficient responses during some operating conditions, such as fast transient responses during droop events.

[0018] Further, some conventional linear control techniques are designed for a relatively smaller range of load current and for worst case operating conditions. Such techniques may fail to provide an adequate response for a relatively wider load current range. Plus, even for a small load current range, loop performance in such conventional linear control techniques may degrade because the conventional techniques usually apply fixed compensation to correct errors caused by the droop, regardless of load variations. Moreover, lack of robust non-linear control is prone to over-correction and under-correction for a relatively wider range of load current and large variation in start and end points of the rate of change of load current across an output voltage range.

[0019] The techniques described herein with reference to FIG. 1 through FIG. 11 include a voltage regulator including digital linear control and nonlinear control that can support wide load current and voltage dropout range. Detailed circuit elements, operations, and improvements are described below with reference to FIG. 1 through FIG. 11.

[0020] FIG. 1 shows a block diagram of an apparatus 100 including a voltage regulator 110 and a load 115, according to some embodiments described herein. Apparatus 100 can include or be included in an electronic device or system, such as a computer (e.g., desktop, laptop, or notebook), a tablet, a cellular phone, wearable electronics (e.g., smart watches), or other electronic devices or systems.

[0021] As shown in FIG. 1, a voltage regulator 110 can include a control unit 111 to generate control information (e.g., a digital code) control code to control a power switching unit 112. Control unit 111 can monitor and detect an error in the value of a voltage VOUT at a node 102 to control (e.g., adjust) the value of control information control code in order to maintain the value of voltage VOUT at a target value. An error in the value of voltage VOUT can occur when the value of voltage VOUT deviates from the target value. The target value can be a voltage value within a target value range (e.g., a pre-determined value range).

[0022] Power switching unit 112 can be controlled by control unit 111 such that a difference in values between a voltage VTN (e.g., supply voltage Vcc) and VOUT (e.g., output voltage) is relatively small (e.g., low drop-out (LDO)). Thus, the value of VOUT can be less than the value of voltage VTN by a relatively small amount. Therefore, voltage regulator 110 can operate as a low-drop out (LDO) voltage regulator.

[0023] Load 115 may use voltage VOUT as its supply voltage (e.g., regulated supply voltage). Load 115 can include or be included in a functional unit such as a processor (e.g., single-core processor, a multicore processor) that can include at least one a central processing unit (CPU), a memory device, or other functional units. Voltage regulator 110 and load 115 can be located on (e.g., formed in, formed on, or integrated in) the same integrated circuit (IC) die (e.g., an IC chip). The IC die can include a semiconductor die (e.g., a silicon die). Alternatively, voltage regulator 110 and load 115 can be located on different IC die. For example, voltage regulator 110 can be located on one IC die of a device on a circuit board (e.g., motherboard), and load 115 can be located on a different IC die of another device on the circuit board. Power switching unit 112 can be formed outside voltage regulator 110 and load 115 (e.g., excluded from an IC die (or IC dice) where voltage regulator 110 and load 1 15 are located. Alternatively a portion of power switching unit 112 or the entire power switching unit 112 can be located on (e.g., formed in, formed on, or integrated in) the same IC die with voltage regulator 110. Apparatus 100 can include or be included in a system on chip (SoC), such that voltage regulator 110 and load 115 can be included (e.g., integrated) in the SoC.

[0024] Voltage regulator 110 can operate in linear mode (e.g., steady state mode) and non-linear mode. Voltage regulator 110 can operate in a linear mode if an error in voltage VOUT has a value less than a specific (e.g., predetermined) value (e.g., when the value of VOUT is within a target value range). Voltage regulator 110 can change from a linear mode to a non-linear mode if the error in voltage VOUT has a value greater than that specific value (e.g., when the value of VOUT is outside the target value range). The error that causes voltage regulator 110 to change from the linear mode to the non-linear mode may include a droop in voltage VOUT (e.g., a decrease in the value of VOUT). Such a droop (or droop event) may occur during a load transient event at load 115. A load transient event may occur when load 115 changes from one operating state (e.g., an idle state) to another operating state (e.g., an active state). As described in more detail with reference to FIG. 2 through FIG. 9, voltage regulator 110 can adaptively and dynamically correct errors (e.g., correct droops) in voltage VOUT until the value of voltage VOUT returns to a target value.

[0025] As shown in FIG. 1, control unit 111 can include an error code generator 120, control circuitry 125 including a digital linear controller 130 and a non-linear controller 140, and a selector 150 (e.g., a multiplexer). Control unit 111 can also include a capacitor Ci, a capacitor C loa d (e.g., load capacitor), a resistor R er s, and resistors Rl and R2 (e.g., a voltage divider). The components of control unit 111 can form digitally-controlled LDO circuitry in a closed loop to control the value of voltage VOUT in both linear and non-linear modes of voltage regulator 110.

[0026] Error code generator 120 can operate to generate error information (e.g., digital error code) error_code_p and error information (e.g., digital error code) error code n based on errors in voltages VOUT. An error in voltage VOUT occurs when the value of voltage VOUT deviates from a target value.

[0027] Digital linear controller 130 can generate output information

(e.g., a digital linear output code) dlc out based on error information

error_code_p. Output information can be used during the linear mode to maintain the value of voltage VOUT at zero error or near zero error in steady- state.

[0028] Non-linear controller 140 can generate output information (e.g., a digital non-linear output code) nl out based on error information error_code_p and error information error code n. Non-linear controller 140 can also generate a signal nl mode en (the non-linear mode enable signal), which can be activated (e.g., changed from a lower signal level (e.g., logic zero level) to a higher signal level (e.g., logic one level)) to indicate an entry into the non-linear mode (from the linear mode). Output information nl out can be used during the non-linear mode to improve transient responses of voltage regulator 110 during load steps (e.g., when current at node 102 increases).

[0029] Selector 150 can select (based on the signal level of signal nl mode en) either output information dlc out or output information nl out to be control information control code at output port 126 of control circuitry 125, depending on which mode (e.g., linear or the non-linear mode) voltage regulator 110 operates at a particular time. Thus, in the linear mode, control information control code is based on output information dlc out (e.g., control code = dlc out in the linear mode), and in the non-linear mode, control information control code is based on output information nl out (e.g., control code = nl out in the non-linear mode). As an example, if each output information dlc out and output information dlc out is an N-bit code (where N is the number of bits), then control information control code is also an N-bit code in either the linear mode or the non-linear mode. Thus, in this example, control code = dlc out = N in the linear mode, and control code = nl out = N in the non-linear mode.

[0030] For simplicity, this description sometimes uses either the term 'control code' (with quotation marks) or the term control code (without quotation marks and without the associated label "control information") to refer to control information control code or the value (e.g., the value of N bits) of control information control code. Similarly, the term 'dlc out' (with quotation marks) or the term dlc out (without quotation marks) refers to output information dlc out or the value (e.g., the value of N bits) of output information dlc out. And the term 'nl out' (with quotation marks) or the term nl out (without quotation marks) refers to output information nl out or the value (e.g., the value of N bits) of output information nl out. The same pattern applies to other items (e.g., variables or parameters) described herein, such that a particular term (with or without quotation marks) associated with an item refers to the name or the value of such an item.

[0031] As shown in FIG. 1, error code generator 120 can receive voltages VFB and VREFJN. The voltage VFB is a feedback voltage that can be generated based on voltage VOUT. For example, the value of voltage VFB can be a divided value of voltage VOUT based on the values of resistors Rl and R2. Voltage VREFJN can be generated from a bandgap-based reference voltage (not shown). As described in more detail below, error code generator 120 can generate a range of reference voltages from voltage VREFJN. Error code generator 120 can compare voltage VFB with the range of reference voltages, and generate error information error codejp and error code n based on the result of the comparisons. Error code generator 120 can receive a clock signal Fclk (e.g., a sampling clock signal) that can be used as timing for the comparisons. Each of error information error_code_p and error information error code n is a digital code (e.g., digital error code) that includes a number of bits. Error code generator 120 can generate error information error_code_p based on a comparison of voltage VFB and the range of reference voltages at positive edges (e.g., rising edges) of clock signal Fclk. Error code generator 120 can generate error information error code n based on a comparison of voltage VFB and the range of reference voltages at negative edges (e.g., falling edges) of clock signal Fclk.

[0032] Control circuitry 125 can use control information control code to control (e.g., turn on or turn off) a number of current paths (e.g., "legs") in power switching unit 112 in order to maintain the value of voltage VOUT within a target value range. Control circuitry 125 can regularly adjust (e.g., update) the value of control information control code (which can be either output information dlc out or nl out, depending of the mode of voltage regulator 110). As mentioned above, control information control code can include a number of bits (e.g., N bits).

[0033] Output port 126 that provides control information control code can include conductive nodes (e.g., part of parallel conductive lines) that can carry different signals (e.g., carry the signals in parallel on output port 126). Each of the signals on output port 126 can include signal levels corresponding to binary 0 (logic zero) and binary 1 (logic 1). The signal levels of the signals carried by output port 126 can represent the value control information control code. For example, if control information control code has 12 bits (e.g., N = 12 bits), then output port 126 can include 12 nodes (or 12 conductive lines) to concurrently carry 12 respective signals that include the bit values of N = 12 bits. As described above, control code = dlc out = N in the linear mode, and control code = nl out = N in the non-linear mode. Thus, in the example here, dlc_out includes N = bits, and nl_out includes N = bits.

[0034] As shown in FIG. 1, power switching unit 112 can include a transistor bank 113 including transistors (e.g., power transistors) 114a, 114b, 116a, and 116b coupled in between nodes 101 and 102. Transistors 114a, 114b, 116a, and 116b can include field effect transistor (FETs), such as p-channel FETs. Transistor bank (e.g., power FET bank) 113 can be binary- weighted transistor bank. Each of transistors 114a and 114b can be controlled by different bits among the bits (e.g., N bits) included in control information control code.

[0035] Transistors 114a, 114b, 116a, and 1 16b can be parts of different current paths (e.g., parallel current paths) between nodes 101 and 102. For example, transistors 114a and 114b can be part of a current path 164, and transistors 116a and 116b can be part of a current path 165. In this description, current paths 164 and 165 are sometimes called "current legs" or simply "legs". Thus, the current flowing on each of current paths 164 and 165 can be called "current per leg" or alternatively "I_per_leg". Transistor bank 113 can provide a current ILOAD (e.g., load current).

[0036] FIG. 1 shows transistor bank 113 including only four transistors

114a, 114b, 116a, and 116b as an example. Transistor bank 113 can include a different number of transistors. The number of transistors of can be based on the number of bits (e.g., N bits) of control information control code. For example, if control code includes 12 bits, then transistor bank 113 can include 24 transistors (e.g., 12 transistors similar to transistors 1 14a and 116a coupled to another 12 transistors similar to transistors 114b and 116b). In this example, the 24 transistors can be parts of 24 different current paths (e.g., 24 legs) similar to current paths (e.g., legs) 164 and 165. As described above, voltage VOUT is maintained within a target value range during the steady state. Control information control code can be used to control (e.g., turn on or turn off) an appropriate number of transistors (e.g., 114a and 116a) in order to control the value of voltage VOUT.

[0037] As shown in FIG. 1, power switching unit 112 can also include a replica portion 1 17 that includes transistors 117a and 117b, an amplifier 118, and a reference current source 119 to generate a current Iref. The value of current Iref can be a predetermined (e.g., known) value. During operation, the transistors (e.g., transistors 114a, 114b, 116a, and 116b) of transistor bank 113 can form a current limiter acting as a controllable current source, with fixed current per leg (I_per_leg) maintained within reliability limits for higher dropouts (e.g., dropout of greater than lOOmV), using a replica portion 117. A dropout (or voltage dropout) is the difference between VIN and VOUT (e.g., dropout = VIN - VOUT).

[0038] Replica portion 117 can use amplifier 1 18 to receive a voltage

(e.g., a reference voltage) Vref mid to generate a voltage VBIAS to set the current per leg to be a multiple of current 'Iref. However, the current source provided by the transistors (e.g., 114b and 116b) of transistor bank 113 has finite output resistance (Ro), which can vary with the dropout. For lower dropouts (e.g., dropouts of less than lOOmV), transistors 114b and 116b can behave like resistors (e.g., fully turned-on transistors) because voltage VBIAS may be zero (e.g., ground potential) or closer to zero, and current per leg can fall within safe limits but is no longer a constant. The current per leg depends on the dropout across transistors 114a, 114b, 116a, and 116b at lower dropouts. Transistors 114a and 116a are digitally controlled (e.g., turned on or turned off) based on the bits (e.g., N bits) of the control code in order to turn on a corresponding number of legs. This allows power switching unit 112 to provide (e.g., source) enough current needed by load 115 at higher dropouts, or to maintain the voltage drop across transistors 114a, 114b, 116a, and 116b for the value of voltage VOUT at lower dropouts.

[0039] As described above, voltage regulator 110 can operate in linear and non-linear modes. In the linear mode (e.g., during steady state), control circuitry 125 can operate at fixed frequency with dlc out updating at each positive clock edge based on error_code_p. Control circuitry 125 can activate signal nl mode en to enter the non-linear mode from the linear mode when a droop or an over-shoot event at VOUT is detected. Output information nl out can be used to correct the droop at voltage VOUT in a much faster response than that of output information dlc out. Non-linear controller 140 can operate at twice the frequency of digital linear controller 130. This can be achieved by generating 'error_code_p' and 'error code n' using both edges of clock signal Fclk. Control code can switch between dlc out and nl out autonomously based on the latest values of error_code_p and error code n.

[0040] Thus, voltage regulator 110 can use dlc out for control code

(e.g., control code = dlc out = N bits) during the linear mode, described below with reference to FIG. 2 through FIG. 6. Voltage regulator 110 can use nl out for control code (control code = nl out = N bits) during the non-linear mode, described below with reference to FIG. 7 through FIG. 9.

[0041] FIG. 2 shows a schematic diagram of error code generator 120 of

FIG. 1, according to some embodiments described herein. Error code generator 120 can include a reference generation circuitry 210 and an analog-to-digital converter (ADC) 220, which can include a windowed flash ADC. Reference generation circuitry 210 and ADC 220 can operate to generate a range of reference voltages for comparison with voltage VFB (which is based on voltage VOUT) and for generation of error code error_code_p and error code n.

[0042] Reference generation circuitry 210 can generate a divided voltage

VDIV based on VREFJN (e.g., a band-gap based voltage) and resistors R3 and R4 (e.g., a voltage divider). VDTV can be buffered by a unity-gain buffer 212 to generate a voltage Dac ref, which is fed to a digital-to-analog converter (DAC) 214 (e.g., a 7-bit primary R-DAC). DAC 214 can include resistor circuitry 214a and a multiplexer circuitry (MUX) 214b (e.g., 2 x MUX with 126 taps). DAC 214 can receive codes Dac code 1 (e.g., 7-bit code) and Dac code 2 (e.g., 7-bit code) and generate voltages Vref top and Vref bot at respective outputs of DAC 214. Voltages Vref top and Vref bot can be top- and bottom-most thresholds, respectively, of ADC 220.

[0043] Voltages Vref top and Vref bot can be buffered by unity-gain buffers 216a and 216b by to feed a secondary DAC 217 (e.g., R-DAC) to generate eight reference voltages Vref_tap_pl, Vref_tap_p2, Vref_tap_p4, Vref_tap_p6, Vref tap ml, Vref_tap_m2, Vref_tap_m4, and Vref_tap_m6 (collectively called "the ADC input reference voltages" for simplicity). The ADC input reference voltages are provided as input reference voltages to ADC 220 for determining the magnitude of error in voltage VOUT in an error range (e.g., voltage VOUT in +/-60mV error range).

[0044] The value of each of the eight ADC input reference voltages can be relative to a voltage Vref mid, which can be a midpoint value between the values of Vref_tap_p6 and Vref_tap_m6. The value of each of Vref_tap_pl, Vref_tap_p2, Vref_tap_p4, Vref_tap_p6 can be the value of Vref mid plus 1 Vx, 2Vx, 4Vx, and 6Vx, respectively. Voltage Vx is an amount (e.g., predetermined amount) of voltage. For example, if Vx = 6mV, then

[0045] Vrefjapjp 1 = Vref mid + 1 Vx = Vrefjnid + 6mV

[0046] Vref_tap_p2 = Vref mid + 2Vx = Vref mid + 12mV

[0047] Vref_tap_p4 = Vref mid + 4Vx = Vref mid + 24mV

[0048] Vref_tap_p6 = Vref mid + 6Vx = Vrefjnid + 36m V.

[0049] The value of each of Vref tap ml, Vref_tap_m2, Vref_tap_m4,

Vref_tap_m6 can be the value of Vref mid minus lVx, 2Vx, 4Vx, and 6Vx, respectively. [0050] Thus, if Vx = 6mV (based on the above example), then

[0051] Vref tap ml = Vref mid + 1 Vx = Vref mid - 6m V

[0052] Vref_tap_m2 = Vref mid + 2Vx = Vref mid - 12mV

[0053] Vref_tap_m4 = Vref_mid + 4Vx = Vref_mid - 24mV

[0054] Vref_tap_m6 = Vref mid + 6Vx = Vref mid - 36mV.

[0055] As shown in FIG. 2, ADC 220 can include a comparator circuit

224 having eight comparators 225 (e.g., positive-edge clocked comparators using clock signal Fclk) to compare VFB with each of the eight ADC input reference voltages. The outputs of comparators 225 can be obtained based on positive edges of clock signal Fclk. Based on the result of the comparison, comparator circuit 224 can generate error_code_p, which can include eight bits (8-bit thermometer code) [7:0]. Each of the eight bits [7:0] of error codejp can be generated at one of comparators 225 at a positive edge of clock signal Fclk. The value of the bits [7:0] of error_code_p represents the voltage error of voltage VOUT obtained based on positive edges of VOUT. The bits [7:0] of error_code_p is provided as input to digital linear controller 130 and non-linear controller 140 (FIG. 1) of control circuitry 125. Control circuitry 125 can perform a thermometric-to-binary conversion to convert bits [7:0] of

error_code_p into positive ADC error levels pos_error_code +/-1, +1-2, +/-4, +/- 6 (for example), where positive values (e.g., +1, +2, +4, and +6) can indicate a droop in VOUT, and negative values (e.g., -1, -2, -4, and -6) can indicate an overshoot in VOUT. The value of error of VOUT can be based on pos error code (ADC error level) multiplied by a voltage value (e.g., a predetermined value). For example, the value of error of VOUT can be based on pos_error_code*10mV.

[0056] As shown in FIG. 2, ADC 220 can also include a comparator circuit 226 having five comparators (e.g., negative-edge clocked comparators using clock signal Fclk) 227 to compare VFB with each of five input reference voltages (among the eight ADC five input reference voltages) Vref_tap_pl, Vref_tap_p4, Vref tap ml, Vref_tap_m4, and Vref_tap_m6. The outputs of comparators 227 can be obtained based on negative clock edges of clock signal Fclk. Based on result of the comparison, comparator circuit 226 can generate error code n, which includes five bits (5-bit thermometer code) [4:0]. Each of the five bits [4:0] of error code n can be generated at one of comparators 227 at a negative edge of clock signal Fclk. The value of the five bits [4:0] of error code n represents the voltage error of voltage VOUT obtained based on negative edges of clock signal Fclk. The bits [4:0] of error code n are provided as non-linear controller 140 (FIG. 1) of control circuitry 125. Control circuitry 125 can perform a thermometric-to-binary conversion to convert bits [4:0] of error_code_n into negative ADC error levels neg_error_code +/-1, +/-4, +/-6 (for example). During load step, if VOUT crosses a non-linear threshold (e.g., +/-4 corresponding to +/-40mV output error) on either positive or negative clock edge (e.g., due to a droop or an over-shoot at VOUT), then control circuitry 125 can enter the non-linear mode, and non-linear controller 140 can operate to correct the error.

[0057] In FIG. 2, comparators 225 and 227 of comparator circuits 224 and 226, respectively, can use auto-zero offset cancellation to ensure comparator offset is kept low (e.g., within +/-1/2 LSB (least significant bit)) and ADC output is monotonia

[0058] Control circuitry 125 can perform a bubble correction on the 8-bit

[7:0] thermometer code of error_code_p and the 5 -bit [4:0] thermometer code of error code n to ensure proper thermometer to binary code conversion of the ADC error code. A calibration may be performed in the reference generation to improve the ADC input reference voltages provided to inputs of comparators 225. For example, online calibration can be used to trim the random offset of unity-gain buffers 216a and 216b. The effect of any residual offset in unity-gain buffers 216a and 216b may be on the ADC range and not on the delta between different references generated due to the use of secondary DAC 217.

[0059] FIG. 2 shows comparator circuits 224 and 226 including eight comparators 225 and five comparators 227, respectively, as an example.

However, the number of comparators in one or both of comparator circuits 224 and 226 can vary. For example, the number of comparators in one or both of comparator circuit 224 and 226 can be increased to provide higher resolution or range.

[0060] The above description with reference to FIG. 1 and FIG. 2 discussed generation of error information error codejp and error code n using error code generator 120. Non-linear controller 140 and digital linear controller 130 (FIG. 1) can use error information error_code_p and error code n to adjust the value of control information control code in order to maintain the value of voltage VOUT within a target value range. The following description discusses structures and operations of digital linear controller 130 (FIG. 3 through FIG. 6) and non-linear controller 140 (FIG. 7 through FIG. 9).

Digital Linear Control Techniques

[0061] The operating condition of voltage regulator 110 (FIG. 1) can be defined by static parameters, including Vin (input voltage), VOUT (output voltage), current per leg (I_per_leg) of power switching unit 112, and on- resistance corresponding to process corners of the IC chip that include voltage regulator 110. The mentioned parameters may change over time, but their changes may not be as dynamic as the change of load current (e.g., ILOAD) for a resistive load (e.g., load 115) during load transients. The on-die load

capacitance may also vary based on the number of functional units (e.g., processor cores in a multicore processor in load 115) that are turned on in a given state. The digital linear control techniques described herein employ dynamic load pole cancellation and dynamic adjusting of adaptive direct-current (DC) gain to effectively counter rapid changes in the load and slow changes in the operating condition of voltage regulator 110, as discussed below with reference to FIG. 3 through FIG. 6.

Plant Transfer Function

[0062] FIG. 3 shows a plant model 305 for the digital linear control techniques that can be implemented in digital linear controller 130, according to some embodiments described herein. The plant model 305 of FIG. 3 can be used to describe a plant (transistor bank 113 + load resistance RL + load capacitor Goad) transfer function. Current Ics presents the ideal current source current value with output resistance Ro in parallel. The combination of current Ics and output resistance Ro is used to model the power-FET. The term 'N' represents control code (e.g., N bits generated by digital linear controller 130 during the linear mode) that determines the number of legs (current paths) in transistor bank 113 to turn on. Besides load resistance RL varying over a wide load current range (e.g., 0.1 A to 15A), output resistance Ro of transistor bank 113 can vary, and the current per leg I unit can drop in low dropout range (e.g., less than lOOmV). Intrinsic capacitance Ci may vary with the functional units (e.g., processor cores) in load 115 that are turned on. However, if the change in capacitance Ci is small relative to the overall load capacitance, then capacitance Ci can be ignored. The digital linear control techniques described herein can provide dynamic compensation to tighten the closed-loop response across the plant variations using a single set of coefficients.

[0063] The plant model 305, as shown in FIG. 3, is seen to have a second-order transfer function for d(Vout)/d(N) which can be re-written using approximate methods as shown below.

where Go is the DC voltage-gain per unit code change, w z is the zero, and w pl , w p2 are the poles of the transfer function.

[0064] Resr is mostly a value per unit of C loa d. Thus, Resr*C loa d, and w zl can remain a constant. Ci is also generally much smaller than C load . Therefore, w p2 does not change significantly for amplitude and phase response of the transfer function in the band of interest. However, load resistance RL, N, and Go can vary significantly with the load current. The term 'N' represents control code, which is equal to dlc out in linear mode (e.g., control code die out = N in linear mode). For example, a change in load current from 250 mA to 15A can cause a ratio change of 6000 in RL (where RL = Nominal Output voltage (e.g., Vour)/Load Current). Similar scale changes can happen in N

(where N = Load current/I U nit) and hence in Go. Thus, the dominant pole w pl and DC-gain Go can vary widely with the changes in load current. Output resistance Ro can also vary with voltage dropout, and RL can further vary within some output voltage ranges (e.g., 0.5V to 1.13V). Designing a digital compensator with fixed coefficients for such a plant, which can change significantly (as discussed above), can pose a challenge. However, as described below, the techniques described herein provide fixed coefficients (e.g., a single set of coefficients) using a digital compensator across a wide load range without impacting (e.g., without degradation) in transient performance or stability. The digital compensator discussed here and below can be included in (e.g., part of) digital linear controller 130 of FIG. 1.

Adaptive Pole Cancellation and Adaptive DC Gain Equations

[0065] The digital compensator (which can be included in digital linear controller 130), based on the techniques described herein, implements a dynamic zero to cancel the dynamic dominant pole of the plant, and an adaptive DC-gain to cancel changes in DC-gain of the plant. Thus, the transfer function of the digital compensator in the loop would have a dynamic (or adaptive) DC-gain which is inverse to the change in the plant, and a dynamic (or adaptive) zero to cancel the dynamic pole in the plant across varying operating conditions.

[0066] Hence, with this understanding, and writing (RL | | Ro/N) in short form as 'Req', the initial transfer function of the digital compensator can be written as follows.

where Gsetpoint is the plant DC Gain at setpoint used for coefficient computation,

[0067] In this form, the Req (= RL || RO/N) term occurs only as a gain factor in the first term and is completely absent in the second term. That is, the digital compensator can be implemented with adaptive gain, and adaptive coefficients can be ignored (e.g., implemented with only adaptive gain without adaptive coefficients). Besides the dynamic zero, the digital compensator also has a static pole to set the target bandwidth and a proportional integrator (PI) to stabilize the system and reduce steady-state error. The following equation indicates the full transfer function of the digital compensator including the static pole and the PI compensator.

where W p is the pole, and K p +Ki/s is the PI compensator. Resr is mostly a value computed per unit of C loa d and hence 'Resr.C l0 ad' is a constant and can be written as 'R«esr' . Based on the above, the adaptive DC gain terms can be expressed as follows.

where H(s) is a strict function and can hence be implemented.

Z-domain Implementation

[0068] For implementing in z-domain, the s-transfer function can be converted into a z-transfer function using the bilinear or Tustin transformation

where Ao, Ai, Bo, and Bi are constants.

Simplifying,

where ao, ai, a 2 , a' 0 , a'i, a' 2 , bi, and b 2 are the coefficients of the digital compensator that can be programmed, and AGi and AG 2 are the adaptive gain multiplier factors in the two forward numerator paths of the digital compensator, which can be included in digital linear controller 130 of FIG. 1.

Implementation of the described Digital Compensator

[0069] FIG. 4 illustrates a simplified implementation of digital linear controller 130 of FIG. 1, which can include the digital compensator based on the z-transfer function H(z) described above, according to some

embodiments described herein. As shown in FIG. 4, digital linear controller 130 can include forward paths (e.g., finite impulse response (FIR) filters) 410 and 420 that include respective adaptive gain circuitry 411 (which can provide adaptive gain multiplier factor AGI), and adaptive gain circuitry 422 (which can provide adaptive gain multiplier factor AG2). Digital linear controller 130 can include a feedback path 430. The FIR filters of forward paths 410 and 420 can provide information (FIR filter outputs) FIRl out and FIR2_out, respectively. Forward path 420 can provide information (output of forward path 420)

FWD2_out, which is added to the output of forward path 410 before subtracting the output of feedback path 430.

[0070] As shown in FIG. 4, coefficients aO, al, and a2 are fixed coefficients in forward path 410, coefficients a0', al', and a2'are fixed coefficients in forward path 420, and coefficients bl and b2 are the fixed coefficients in feedback path 430. For simplicity, feedback path 430 can be implemented using adders (as shown in FIG. 4) by reversing the sign of coefficients bl and b2.

[0071] In FIG. 4, adaptive gain circuitry 411 uses information VID code

(known digital information corresponding to Vnom, and Vnom can be a target VOUT), and Vdropout (e.g., VIN - VOUT) information to adjust the gain of forward path 410, whereas adaptive gain circuitry 422 uses the current per leg (W) information (I„nit is current per leg in transistor bank 113 in FIG. 1) to adjust the gain of forward path 420. The dependency of AG 2 (adaptive gain multiplier factor) on I unit may be seen only at lower dropouts where I unit falls.

[0072] As shown in FIG. 4, digital linear controller 130 can receive error_code_p and generate dlc out (e.g., N-bit code). The value of dlc out can also be based on feedback from nl out (the output of non-linear controller 140 in FIG. 1) that can be selected by multiplexers 433 and 435 using signal nl mode en, as shown in FIG. 4. In operation, the value of dlc out can be updated at each clock cycle, based on error_code_p, to control (e.g., turn on or turn off) the legs (e.g., current paths 164 and 165) in the transistor bank 113 (FIG. 1). Output information dlc out can also be fed back to adaptive gain circuitry 411 to adjust the gain based on current operating condition. Since the error code takes only a few known values (e.g., 0, +/-1, +1-2, +/-4, +/-6), the coefficients multiplied by error_code_p can be stored (e.g., pre-programmed) and kept ready or used as inputs of a multiplexer, using the binary code information as the select line of the multiplexer. This avoids using an additional multiplier (or multipliers) in forward path 410 besides a multiplier used in adaptive gain circuitry 411 for adjusting DC as described herein. This helps voltage regulator 110 to run at a relatively high frequency (e.g., in range of hundreds of mega-hertz) with a relatively free of timing issues or negligible timing issues.

Adaptive Gain 1 (AG1) Derivation and Implementation

[0073] In the equations of AGi and AG 2 as mentioned above, both W

(current per leg) and Req (which is RL || Ro/N) can vary. I unit depends on the dropout because current per leg falls at lower dropouts. Thus, I unit may be adjusted only in the low dropout range. However, Req can vary significantly with load resistance RL and output resistance Ro of transistor bank 113. Output resistance R 0 can vary with dropout especially for dropouts in the middle range (e.g., lOOmV to 400m V) when transistor bank 113 operates in mostly linear region and not in saturation. Thus, KGi may need to be re-computed and refreshed each clock cyc le.

For dropouts < lOOmV, the transistors of transistor bank 113 can behave as a resistor and I unit can vary with dropout. Thus, the above equation can be rewritten as shown below.

where, Vnom can be a target output voltage (e.g., target VOUT) known from a target information VID code (digital information corresponding to Vnom)- I unit *Ro is mostly a constant for a given dropout voltage and can be fed from a look-up table with respect to dropout. The value of V dropout can be computed in digital value from known information VIN code (digital information

corresponding to VIN) and VID code, such that digital value of V dropout =

VIN code - VID code. The varying load current is indirectly represented by control code (e.g., N) of the previous cycle (since control code = dlc out in the linear mode, control code of the previous cycle = dlc out of the previous cycle), and Vnom, I unit .Ro', and V dropout are available in digital code.

[0074] FIG. SA shows a diagram of adaptive gain circuitry 411 of FIG.

4, according to some embodiments described herein. As shown in FIG. 5 A, AGi (adaptive gain multiplier factor) can be computed as a function of dlc out from the previous cycle, making it adaptive to the load current. For example, if dlc out is an N-bit code (where N is the number bits), then dlc out from the previous cycle can be provided by the value of the N bits from previous cycle.

[0075] As shown in FIG. SA, dlc out can be divided by factors Ml

(where Ml = 1/G setpint ) and M2 (where M2 = 1/N setpint )- Dividers S02 and 503 (e.g., using shift right registers as dividers) can be used to divided dlc out from the previous cycle. A multiplexer 504 can be used to select (based on signal Low dropout thres sel) the output of dividers 502 and 503 as information N/M. Divide factors Ml and M2 can be chosen to be power of 2 to realize the divider using a shifter. Using a multiplier 550 (FIG. 5B), information N/M is then provided as input information to be multiplied by a gain factor selected using a final index, which is computed based on VID code (Vnom) and Vdropout information, as described below. As described above, Vnom is a target output voltage known from a target VID code, ' limit. Ro' is mostly a constant for a given dropout voltage and can be fed from a look-up table with respect to dropout, and Vdropout can be computed in digital value from known VIN_code (VEST) and VID code (Vnom, which is a target VOUT).

[0076] FIG. 5B shows multiplier 550 of adaptive gain circuitry 411 of

FIG. 5 A, according to some embodiments described herein. As shown in FIG. 5B, the gain factor multiplication using final index (e.g., eight bits [7:0] final index) can be done using shift-and-add logic on top of output code N/M (from FIG. 5A) to avoid using an outright multiplier(s)/divider(s). The shift- and-add logic in FIG. 5B has the form

2 Λ 3 *x(7)+2 Λ 2*x(6)+2 Λ l *x(5)+2 Λ 0*x(4)+2 Λ - 1 *x(3)+2 Λ -2*x(2)+2 Λ -3 *x( 1)+2 Λ - 4*x(0) where x is based on the bits from the final index.

Final Index Computation

[0077] Referring again to FIG. 5 A, a look-up table based implementation can be used to compute the index for AGi (adaptive gain multiplier factor) instead of real arithmetic computation.

[0078] The value of -— can be stored as a fixed look-up table 'vid lut'

*nom

for the target Vnom range (e.g., 0.5V to 1.13V) and can be divided into a number of equal sub-ranges. For example, as shown in FIG. 5A, 'vid lut' can be divided into 16 values vid lutO through vid_lut l5, which can be provided as inputs of a multiplexer 510.

[0079] The value of — can be stored in a programmable look-up

'unit-Ro

table 'reg luRo lut' and can be divided into a number of sub-ranges. For example, as shown in FIG. 5 A, 'reg luRo lut' can be divided into 16 values reg luRo lutO through reg_IuRo_lutl5, which can be provided as inputs of a multiplexer 511. Values reg luRo lutO through reg luRo lutl 5 can be selected based on current voltage dropout, with higher resolution in the middle dropout region where it varies the most (e.g., lOOmV to 400mV dropout range) in resolution of 20mV-40mV, for example. The look-up table for can be

programmed based on known output resistance Ro, which may vary with skew, and known measured I unit information.

[0080] value can also be stored as a fixed look-up table

'vdrop lut' with respect to dropout information available from Vdropout information. For example, as shown in FIG. can be divided into 16

values vdrop lutO through vdrop_lutl 5, which can be provided as inputs of a multiplexer 512. As described above, Vdropout = VIN - VOUT (which is based on Vnom, and Vnom is based on VID code). Thus, in FIG. 5 A, the digital value of Vdropout can be obtained based on a subtraction of VID code (e.g., Vnom) code from VTN_code (e.g., Vnsr). Hence, the digital value of Vdropout = VIN_code - \TD_code,

[0081] This value may be stored only in the region of low dropout (e.g., in lOmV resolution).

[0082] In operation, value is normally used (e.g., always used) and

is selected by logic circuit 520 using signal VID index (based on VID code). However, logic circuits 521 and 522 (using Vdrop indexl and Vdrop_index2, respectively) select either index value based on Vdropout

(e.g., low dropout or high dropout). As shown in FIG. 5A, a multiplexer 530 can use signal low dropout thres sel to select between based on

dropout as explained in the equations for AG above and shown in FIG. 5 A. Signal low dropout thres sel can be activated (e.g., from logic zero level to logic one level) if V dropout < V threshold (e.g., approximately lOOmV) or if current per leg I un j t falls below a threshold (e.g., voltage regulator 110 enters low-dropout region). The selected look-up table value of either or

(selected by low dropout thres sel) is added (using adder 540) to the

selected look-up table value (selected by signal VID index of logic circuit

520) to generate the final index. The final index is used for selecting the appropriate gain (as described above with reference to FIG. 5B) based on the operating point.

[0083] Digital linear controller 130 or control circuitry 125, or both, can include a memory circuit (e.g., registers or other types of memory, not shown) to store (e.g., program) the values (e.g., in the form of look-up table entries) of

As described above, the value of the final index is

generated based on the values of Thus, the value of

the final index is based on values stored in the memory circuit of digital linear controller 130 or control circuitry 125, or both.

[0084] The value of can sometimes be ignored. For example, can be ignored in a lower dropout region due a much lower contribution to the gain from - relative to that of However, at a certain dropout (e.g., a

relatively high dropout) can start to dominate, with small or negligible contribution from because output resistance Ro generally increases at

higher dropouts (e.g., in some technology nodes).

[0085] The above description discusses techniques for computation and implementation of adaptive gain circuitry 411 to compute AGi (adaptive gain multiplier factor) of FIG. 4. Similar techniques can be used for implementing adaptive gain circuitry 422 (i.e., AG 2 - adaptive gain multiplier factor) in forward path 420.

[0086] FIG. 6 shows a diagram of adaptive gain circuitry 422 of digital linear controller 130 of FIG. 4, according to some embodiments described herein. In FIG. 6, the structure of multiplier 650 of adaptive gain circuitry 422 of forward path 420 can similar to (or the same as) the structure of multiplier 550 of FIG. 5B. As shown in FIG. 6, the value of can b e stored in a

look-up table 'Iunit lut", which can include different selectable values. For example, 'Iunit lut' can include 16 values lunit lutO through Iunit lutlS, which can be provided as inputs of a multiplexer 622. Values lunit lutO through Iunit_lutl5 can be appropriately selected using information sensed lunit code (e.g., four bits [3:0] code). The value of sensed lunit code can be based on dynamic l unit information from the current sense logic (not shown) for the power gates used for telemetry purposes. The R_eq (which is RL | | Ro/N) at set-point is consumed in the coefficient terms associated with forward path 420 to make the term AG2 (Adaptive Gain 2) only dependent on the ratio of current per leg at set-point to the current per leg at the operating point that may vary mainly at lower dropouts. As shown in FIG. 6, multiplier 650 can generate information FWD out based on the product (multiplication) of one of values lunit lutO through Iunit_lutl5 (selected to output of multiplexer 622) and information FIR2_out (from FIR filter of forward path 420 in FIG. 4).

Information FWD out can be added to information from forward path 410, as described above with reference to FIG. 4.

[0087] Thus, as described above with reference to FIG. 1 through FIG.

6, the linear control techniques in voltage regulator 110 can cancel the load- dependent varying dominant pole and varying DC gain of the plant with a corresponding zero and a new adaptive DC gain adjustment technique. The described techniques are applicable to different load conditions and are not to be limited to a specific load condition. This means that voltage regulator 110 dynamically adjusts itself to counter the change that happens to the plant at different load conditions over time. Thus, the described linear control techniques help improve closed-loop performance in terms of fast and stable response, and reduced peak droop, over-shoot, or both, across a wide range of current load and a wide output voltage range. The described linear control techniques also allow a single set of coefficients to be used for the digital filter across a wide operating range of voltage regulator 110 for different load conditions. All of these factors allow the described linear control techniques to have improvements over some conventional techniques.

[0088] For example, as mentioned above, some conventional linear control techniques are design for the worst-case condition at a specific output voltage and load condition. If such specific load condition is altered, it may result in degraded performance, slow response time, higher droop/over-shoot due to low bandwidth. Such conventional technique may handle a relatively small range of load current with one set of coefficients.

[0089] In the techniques described herein, voltage regulator 1 10 uses a single set of coefficients for a much wider range of load current, input voltage range and load capacitance. Further, the performance of the loop in the described technique may remain relatively unchanged over the range in terms of stability and loop bandwidth, which results in better transient response in terms of worst-case droop and settling time.

Non-Linear Control Techniques

[0090] As described above with reference to FIG. 1, control circuitry 125

(FIG. 1) enters the non-linear mode when an error (e.g., a droop or an over-shoot event) is detected at VOUT. In the non-linear control techniques described herein, non-linear controller 140 uses output information nl out (digital non-linear output code) to perform a non-linear correction to correct an error in VOUT in two stages, an initial stage and a subsequent stage. The computation for nl out is different from the initial stage and the subsequent stage. In the non-linear control techniques described herein, non-linear controller 140 computes (e.g., pre-computes) correction information nl dlc step while VOUT is still within a target value range (before VOUT crosses a non-linear target threshold). This allows non-linear controller 140 to quickly correct VOUT as soon as (e.g., in half cycle of clock signal Fclk) VOUT is detected to be outside the target value range. Non-linear controller 140 also computes (e.g., pre-computes) the value of correction information nl dlc step based on operating conditions at that time, such that non-linear controller 140 can smoothly and accurately correct an error in VOUT to avoid over-correction or under-correction.

[0091] As part of the operation of computing nl dlc step, non-linear controller 140 counts the number of clock edges (positive and negative edges) that the error code (e.g., generated based on error_code_p and error code n) is outside a zero error zone and before the value of VOUT crosses the non-linear entry threshold (e.g., +4 for droop event and -4 for the over-shoot event). The value of the count value is used in a non-linear entry time computation. Correction information nl dlc step is computed based on the computed nonlinear entry time computation. Then, non-linear controller 140 uses the computed nl dlc step to compute nl out and have nl out ready for use in the initial stage after an error in VOUT is detected. After the initial stage, non-linear controller 140 uses a different computation for nl out in the subsequent stage and continues to correct the error in VOUT until VOUT returns to the target value range, at which non-linear controller 140 exits the non-linear mode and hands over the operation to digital linear controller 130.

[0092] The following description discusses computation of correction information nl dlc step, which is used for the computation of nl out (digital non-linear output code) for the initial stage of correcting error VOUT at entry of the non-linear mode.

[0093] The values (initial values) of nl out to be used in the initial stage of correcting error (e.g., a droop or an over-shoot) in VOUT are computed based on the equations below.

[0094] nl out = dlc out (previous cycle) + nl dlc step ( for droop)

[0095] nl out = dlc out (previous cycle) - nl dlc step ( for overshoot)

[0096] FIG. 7 shows an example waveform of voltage VOUT and current ILOAD during an example droop event, according to some embodiments described herein. FIG. 7 also shows an example of the effect of propagation delay on the droop, and the time at which droop correction starts. Current ILOAD can have an initial value (shown as "INITIAL LOAD" in FIG. 7) and a final value (shown as "FINAL LOAD" in FIG. 7). As mentioned above, non-linear controller 140 uses a count of the number of clock edges (positive and negative edges) as part of the operation of computing correction information nl dlc step. In FIG. 7, the 'count' can be set (or reset) at time TRSL Then, 'count' can start at time Tc with count = 1 and continue (e.g., sequentially increases) until it is reset (e.g., at time TRS 2 ) to count = 0. For simplicity, only a few values (e.g., count = 0, 1, 2) of 'count' are shown in FIG. 7.

[0097] In the example of FIG. 7, target value range 714 is an example target value range of voltage VOUT. In this example, target value range 714 is assumed to be between an upper target value 714U and a lower target value 714L. Upper target value 714U can correspond to ADC error = -4 (e.g., +40mV). Lower target value 714L can correspond to ADC error = +4 (e.g., - 40mV). The nl entry threshold is assumed to be at ADC error = +4 (e.g., lower target value 714L). Thus, in this example, if the value of voltage VOUT is detected to be less than its target value by 40mV (e.g., a droop occurs) or greater than its target value by 40mV (e.g., an over-shoot occurs), then the non-linear mode is entered, and non-linear controller 140 can start correcting the error (e.g., droop or over-shoot) in VOUT. In FIG. 7, zero error zone 710 indicates a zone (range) where VOUT is deemed to be free of error (zero error or close to zero error). Thus, in this example, if the value of voltage VOUT is detected to be lower than (or higher than) a target value by less than lOmV, the linear mode is maintained (e.g., non-linear mode is not entered) and digital linear controller 130 (FIG. 1) remains to operate in controlling the value of VOUT. Time computation from start of load step to application of non-linear correction

[0098] In the following discussion, Ts is the period (e.g., 2.5ns) of clock signal Fclk (FIG. 1 and FIG. 2) that is used by ADC 120 to sample errors in voltage VOUT. Samples for non-linear logic in non-linear controller 140 can be obtained at each half cycle (half period or Ts/2) based on the positive and negative edges of clock signal Fclk.

[0099] T nlentry = Ts/2 + (count + l)*(Ts/2), where T nlentry is the time (e.g., at time T2 in FIG. 7) to non-linear entry after a load step starts (e.g., at time TO), and count is the value of the count at taken at the time (e.g., time Tl) that is a half cycle of clock signal Fclk before the time (e.g., time T2) that the non-linear entry threshold crossing is detected. Thus, in the example of FIG . 7, the count used in equations (e.g., T nlentry and Tstart recovery (below)) for timing computation is count = 2 (as shown in FIG. 7 at time Tl). However, the value of a count can vary based on di/dt of the load step. For example, at the time that is a half cycle of clock signal Fclk, before the time that the non-linear entry threshold crossing is detected, the value of the count can be less than two (e.g., if the load step is fast) or more than two (e.g., if the load step is slow). In the description here, the cycle refers to the cycle of clock signal Fclk (sampling clock signal). [00100] In the example of FIG. 7, T nlentry = Ts/2 + (count + l)*(Ts/2) = Ts/2 + (2 + l)*(Ts/2) = Ts/2 + 3*(Ts/2) = 4*(Ts/2). This means that

T nlentry is four half cycles after time TO (load step start time), which is at time T2, as shown in FIG. 7.

[00101] Tstart recovery = T nlentry + Ts/2 (here, Ts/2 is added because of propagation delay from ADC output at non-linear entry), where

Tstart recovery is the time that correction starts after a load step is applied (e.g., at time TO in FIG. 7).

[00102] Based on the above,

[00103] Tstart jecovery = (count + 3)*(Ts/2) (Eq. 1 )

[00104] Thus, in the example of FIG. 7, Tstartjecovery = (2 + 3)*(Ts/2) = 5*(Ts/2). This means that Tstart recovery is five half cycles after time TO (load step start time), which is at time T2, as shown in FIG. 7.

[00105] The non-linear correction described herein applies correction information nl dlc step (included in nl out) in order to provide (e.g., source) enough current in the immediate half cycle (Ts/2) after recovery starts. The applied current would give a delta voltage (e.g., delta V) rise greater than delta voltage droop that would happen if non-linear correction were not applied, and the load current had continued to increase at the same di/dt rate for that cycle. This prevents the droop from dropping further because the voltage (e.g., delta V) is computed with an expectation to cause voltage VOUT to recovery immediately. For this reason, di/dt of the load and the voltage error at non-linear entry can be determined, such that correction information nl dlc step satisfies the criteria described above.

[00106] For example, assuming that 'deltaV is the additional droop possible in half cycle if non-linear correction were not applied, in order to prevent voltage VOUT from dropping further in the immediate next half cycle, the same amount of charge (based on deltaV) can be replenished in the immediate next half cycle. This allows voltage VOUT to start recovery (e.g., start to return to the target value range) in the immediate next half cycle after an error in VOUT is detected (e.g., after non-linear entry is detected). The computation for 'deltaV and 'nl dlc step' is as follows.

[00107] Based on I = C*dv/dt, then [00108] nl_dlc_step*I_per_leg = C_load*deltaV/(Ts/2)

[00109] nl_dlc_step = (C l0 ad/I_per_leg)*(2/Ts)*deltaV (Eq. 2 )

[00110] where C loa d is the total load capacitance seen at the output, I_per_leg is the fixed current per leg of transistor bank 113 (FIG. 1), and

'deltaV computation is shown below.

[00111] deltaV = integral(lLOAD*dt)/ C loa d between Tstart_recovery (e.g., time T3 in FIG. 7) to Tstart recovery + Ts/2 (e.g., time T4 in FIG. 7).

[00112] By computing the area under ILOAD curve between the above two time instants (e.g., between times T3 and T4) with approximation and substituting Tstart recovery from Eq. 1, 'deltaV can be obtained as follows.

[00113] deltaV = delta_Ih*(count+3)*(Ts/2)/C loa d (Eq. 3 )

[00114] where delta lh is the change in load current in half cycle for the linear load step. The value for delta lh can be computed as shown below.

[00115] In the following description, droop at entry is the voltage droop at non-linear entry point (e.g., at time T2 in FIG. 7) at which an error in VOUT is detected. The value of droop at entry is approximately known from

nl error at entry (which is sampled ADC error at entry) and the known ADC resolution which is also known (e.g., a fixed voltage value (e.g., 0.01 V).

[00116] There may be additional droop compared with 'nl error at entry' sampled for faster load transients (e.g., when 'count' has a lower value). The accuracy of the 'nl error at entry' (e.g., how close nl error at entry is to the actual voltage droop) can be improved when the load step is slow (e.g., when 'count' has higher value) because voltage VOUT takes more time to cross nonlinear entry threshold (nl entry threshold) than the time it takes for VOUT to cross non-linear entry threshold in the case when the load step is fast. Based on these relationships, the voltage droop at entry can be accurately determined as a function of 'count' and 'nl error at entry'. The accuracy can be improved further if a relatively higher number of samples (e.g., four or more) is taken in one ADC clock period (e.g., period of clock signal Fclk), or if the number of comparators in ADC 220 (FIG. 2) is increased.

[00117] The following equations can be used to compute voltage droop at entry (droop at entry) that is based on the function of 'count' and

' nl error at entry ' . [00118] nl err entry adj = nl error at entry + 1 (for count <=3)

[00119] nl err entry adj = nl error at entry (for count > 3 and <= 5)

[00120] nl err entry adj = nl error at entry - 1 (for count > 5)

[00121] where 'nl error at entry' is the magnitude of error code at nonlinear entry. As an example, nl error at entry' can be 4 or 6, and the non-linear entry threshold can be 40m V error (for example).

[00122] droop at entry = nl err entry adj * 0.01 = integral(lLOAD

*dt)/C loa d from t = 0 (e.g., time TO) to T nlentry (e.g., time T2)

[00123] Assuming linear change in load current and computing area under

ILOAD curve gives,

[00124] droop at entry =

(l/C l0 ad)*(l/2)*T_nlentry*delta_Ih*T_nlentry/(Ts/2)

[00125] After substituting 'T nlentry' it gives,

[00126] deltajh = 4*C_load*fs*0.01*nl_err_entry_adj/[(count+2) Λ 2]

(Eq. 4)

[00127] where fs = 1/Ts (which is the sampling clock frequency)

[00128] Combining equations 2, 3 and 4, the value of correction

information nl dlc step (e.g., the final controller step half cycle before non- linear entry is detected) that can be applied in the non-linear mode is as follows.

[00129] nl_dlc _step = (0.04* C loa d *fs/I_per_leg)*

[00130] nl_err_entry_adj* (count+3)/[(count+2) Λ 2] (Eq. 5)

[00131] As described above, nl dlc step is the correction information that non-linear controller 140 uses to compute (e.g., pre-compute) the value of nl out to be used (e.g., to adjust control code) in the initial stage of the non-linear correction after voltage VOUT is detected as being outside the target value range.

Non-linear Controller Implementation

[00132] FIG. 8 shows a simplified architecture diagram of non-linear controller 140 of FIG. 1, according to some embodiments described herein. For implementation, the above equation 5 for correction information nl dlc step can be re-written as shown below.

[00133] nl_dlc_step = K_fixed*K_count (Eq. 6) [00134] where K fixed = (0.04*C_load*fs/I_per_leg), can be a programmable value (shown as an example 10-bit reg K fixed [0:9] in FIG. 8) based on actual measured (known) values of load capacitance C loa d, I_per_leg is the current per leg of transistor bank 113 (FIG. 1), and 'fs' is the sampling frequency (e.g., the frequency of clock signal Fclk). Non-linear controller 140 or control circuitry 125, or both, can include a memory circuit (e.g., registers or other types of memory, not shown) to store (e.g., program) the value of K fixed (the value represented by 10-bit reg K fixed in FIG. 8).

[00135] K count = nl err entry adj *(count+3)/[(count+2) Λ 2], which can be implemented as a look-up table based on 'count' for nl error at entry = 4. In wide-range load scenario, the value of 'count' (FIG. 7) may vary. For example, 'count' may vary between 0 and 9. Thus, in this example, the look-up table can include 10 different entries (values) for 'K count', such as count values (e.g., reg Kcount valO through reg_Kount_val9, each having an example of eight bits [7:0], as shown in FIG. 8), which can be provided as inputs to multiplexer 810. Non-linear controller 140 or control circuitry 125, or both, can include a memory circuit (e.g., registers or other types of memory, not shown) to store (e.g., program) the values of K count (e.g., reg Kcount valO through

reg_Kount_val9) that can be different selectable values.

[00136] During operation of non-linear controller 140, count measurement logic circuitry 805 (FIG. 8) can generate count information 'Kcount meas sel' to select an appropriate 'K count' value among the stored count values from the look-up table. Depending on the value of 'Kcount meas sel', multiplexer 810 can select one of reg Kcount valO through reg_Kount_val9 to be a selected 'K count' (called 'K count selected'). 'K count selected' is multiplied with reg K fixed (which corresponds to 'K fixed' in equation 6) by a multiplier 812 to generate correction information nl dlc step.

[00137] As shown in FIG. 8, 'K count' (which is one of reg_Kcount_val0 through reg_Kount_val9) can be adjusted by 1.5 times (e.g., can be multiplied by 1.5 by circuit 814) for cases when nl error at entry = 6, before applying correction information nl dlc step to the output of non-linear controller 140.

[00138] Non-linear controller 140 can use signal nl error at entry sel to cause a multiplexer 816 to either select nl dlc step = reg K fixed* K count selected (e.g., if nl error at entry = 4) or select nl dlc step = reg_K_fixed*K_count_selected*1.5 (e.g., if nl error at entry = 6). As described above, 'K count selected' is one of reg Kcount valO through reg_Kount_val9 that is selected based on the value of 'Kcount meas sel'.

[00139] FIG. 9 shows a block diagram of count measurement logic circuitry 805 of FIG. 8 used to generate the value for 'Kcount meas sel', according to some embodiments described herein. As shown in FIG. 9, count measurement logic circuitry 805 can include modules 91 1 and 912, and an adder 923 to generate 'Kcount meas sel' based on error information pos error code and neg error code, and signals nl mode en and nl exit. As described above, 'Kcount meas sel' corresponds to 'count'. The value of 'Kcount meas sel' determines how many clock edges (positive and negative) occur from the time (e.g., time T2 in FIG. 7) that VOUT is outside zero error zone 710 to time (e.g., time T2) that the value reaches the non-linear entry threshold (e.g., the time at which VOUT is outside target value range 714 in FIG. 7). In FIG. 9, module 911 can include a positive edge counting logic 91 la to count the number of the positive edges of clock signal Fclk. Module 912 can include a negative edge counting logic 912a to count the number of the negative edges of clock signal Fclk. Adder 923 can operate to add the count values from modules 911 and 912 to generate 'Kcount meas sel'.

[00140] In operation, based on error codes pos error code and neg error code and ADC error levels (e.g., FIG. 7), count measurement logic circuitry 805 of FIG. 9 can start counting when VOUT is outside zero error zone (e.g., zero error zone 710 in FIG. 7) and stop counting, and then reset the count, when VOUT is inside the zero error. For example, using the example of FIG. 7, count measurement logic circuitry 805 can set (or reset) the 'count' (e.g., at time TRSO such that count = 0 when the value of VOUT is within zero error zone 710. Count measurement logic circuitry 805 can start counting, count = 1, right after (e.g., at time Tc) the time that VOUT is outside zero error zone 710. Count measurement logic circuitry 805 can stop and reset the count (e.g., count = 0 at time TRS 2 in FIG. 7) when the value of VOUT is again within zero error zone 710 (e.g., a half cycle after the non-linear mode is exited). In FIG. 9, one or both of signals nl mode en and nl exit can also be used in addition to error codes pos error code and neg error code to generate 'Kcount meas sel'. For example, signal nl mode en can be used to start and stop the count, and signal nl exit can be used to reset the count.

[00141] Referring again to FIG. 8, after computation of correction information nl dlc step based on the multiplication of K fixed (a fixed value) with K count (one of reg Kcount valO through reg_Kount_val9 selected based on 'Kcount meas sel'), nl dlc step can be combined with (either added to or subtracted from) dlc out to provide nl out. This pre-computed nl out can be ready a half cycle before an error (e.g., a droop or an over-shoot) in VOUT is detected.

[00142] In FIG. 8, label "for Droop" indicates an operation to compute nl out to prepare to correct a droop in VOUT. Adder 822 can add nl dlc step to dlc out from a previous cycle. The result (nl out = dlc out + nl dlc step) can be available (e.g., stored in positive and negative edge-triggered flip-flops (+ve FF and -ve FF) 823 and 824) before entry of the non-linear mode.

[00143] The label "for Over-shoot" in FIG. 8 indicates an operation to compute nl out to prepare to correct an over-shoot in VOUT. Subtractor 832 can subtract nl dlc step from dlc out from a previous cycle. The result (nl out = dlc out - nl dlc step) can be available (e.g., stored in positive and negative edge-triggered flip-flops (+ve FF and -ve FF) 833 and 834) before entry of the non-linear mode.

[00144] Clock signal Fclk can be used to trigger flip-flops 823, 824, 833, and 834. Saturation monitors (SAT) 825 and 835 can be used to keep the values of pre-computed nl out (nl out = 'dlc out' + 'nl dlc step', and nl out = 'dlc out' - 'nl dlc step', respectively), within saturation limits. The pre- computed nl out can be used to adjust control code during the initial stage (e.g., between times T3 and T4 in FIG. 7) of correcting VOUT.

[00145] In the above description, count information Kcount meas sel (which is 'count') used to select count values reg Kcount valO through reg_Kount_val9 is available a half cycle earlier than non-linear entry, which enables 'nl dlc step' after multiplication of K count to K fixed. Thus, at the time (e.g., time T3) 'nl out' is applied in the correction of VOUT (after non-linear entry is detected), 'nl out' is a pre-computed value in which nl out = dlc_out_prev +/- nl dlc step (where dlc_out_prev is the previous value of dlc out (e.g., at time T2)). This pre-computed value can be propagated as soon as non-linear entry threshold crossing is detected (e.g., at time T2 in FIG. 7) and 'nl mode en' is activated (e.g., changed to a logic one level). Along with threshold crossing, non-linear controller 140 can select the appropriate pre- computed nl out (either nl out = dlc out + nl dlc step or nl out = dlc out - nl dlc step) based on the sign of the error at entry represented by signal 'entry error sign bit' (to control multiplexer 842), non-linear entry clock edge signal 'entry_pos_or_neg_edge' (to control multiplexers 826 and 836), and non- linear error at entry (e.g., nl error at entry = 4 or 6). The structure of non-linear controller 140 is configured such that insignificant logic delay is added in the path besides the propagation delay from non-linear controller 140 to transistor bank 113 (FIG. 1).

[00146] As shown in FIG. 8, non-linear controller 140 can include a bubble correction 851 to improve the accuracy of error_code_p, and a thermo-to- binary converter 852 to perform a thermometric-to-binary conversion to convert bits [7:0] of information error_code_p into positive ADC error levels

pos error code (e.g., 5 bits [4:0]). Non-linear controller 140 can include a bubble correction 861 to improve the accuracy of error code n, and a thermo-to- binary converter 862 to perform a thermometric-to-binary conversion to convert bits [7:0] of information error code n into positive ADC error levels

neg error code (e.g., 5 bits [4:0]). Count measurement logic circuitry 805 (also shown in FIG. 9) to generate count information 'Kcount meas sel' (e.g., 4 bits [3:0]) that is used to select count values reg Kcount valO through

reg_Kount_val9.

[00147] As shown in FIG. 8, non-linear controller 140 can include an error threshold detector 872 to generate signal nl mode en (the non-linear mode enable signal) and nl exit (non-linear exit signal) based one ADC error levels 'pos error code' and neg error code and nl entry threshold. Error threshold detector 872 can activate (e.g., provide a logic one level to) signal nl mode en when the value of VOUT crosses nl entry threshold (e.g., at time T2 in FIG. 7), which is when the value of VOUT is outside target value range 714 (FIG. 7). Error threshold detector 872 can activate (e.g., provide a logic one level to) signal nl exit when the value of VOUT returns (e.g., at time T3 in FIG. 7) to target value range 714.

[00148] As shown in FIG. 8, the value of information pos error code can be multiplied by a scaling factor K2 and can be added (by adder 874) to the value of nl out from the previous cycle. Non-linear controller 140 can include saturation monitors (SAT) 875 to keep the value of pos error code (after being multiplied by scaling factor K2) within saturation limits. Scaling factor K2 can be a factor smaller than 'nl dlc step' in order to apply fine steps and to avoid an over-shoot during recovery of VOUT. Linear code nl out is provided back to digital linear controller 130 (FIG. 1) to ensure smooth switching between modes at nl exit before digital linear controller 130 settles to new 'dlc out' code to maintain zero error in steady- state.

[00149] As shown in FIG. 8, non-linear controller 140 can include a multiplexer 876, which can be controlled by a signal State, to select the value for nl out during the initial stage (e.g., an initial portion) and the subsequent stage (e.g., a subsequent portion) of the non-linear correction (described above. Signal State can be generated by a state machine (not shown) of voltage regulator 110. Signal State can be controlled such that it can have a signal level corresponding to logic zero (e.g., State = 0) during the linear mode, and a signal level corresponding to logic one (e.g., State = 1) at some time (e.g., at time T4 in FIG. 7) after entry of the non-linear mode. The value of nl out relative to the value of signal State after entry of the non-linear mode (e.g., after time T2 in FIG. 7) is as follows.

[00150] State = 0 (e.g., before time T3 in FIG. 7)

[00151] nl out = dlc out + nl dlc step (if error in VOUT is a droop), or

[00152] nl out = dlc out - nl dlc step (if error in VOUT is an over-shoot)

[00153] State = 1 (e.g., after time T3 in FIG. 7)

[00154] nl out = nl_out_prev + K2*pos_error_code

[00155] where pos error code is based on error_code_p.

[00156] Thus, after entry of the non-linear mode and before signal State is activated to State = 1, nl out = dlc out + nl dlc step (if error in VOUT is a droop), or nl out = dlc out - nl dlc step (if error in VOUT is an over-shoot). After State = 1 (e.g., after time T4), 'nl out' can be computed at each cycle of clock signal Fclk using the dynamic error code on positive edge

(pos error code). After State = 1, 'nl out' code can be increments/decrements by K2*pos_error_code at each cycle until the value ofVOUT returns (e.g., at time T5 in FIG. 7) to target value range 714. Error threshold detector 872 (FIG. 8) can activate signal nl exit (e.g., provide a logic one level to) signal nl exit to exit the non-linear mode after VOUT returns to target value range 714. Digital linear controller 130 (FIG. 1) can take over operation of controlling VOUT. The process of linear and non-linear operations described repeats in order to keep VOUT in zero error zone 710 and within target value range 714.

[00157] The above description with reference to FIG. 7 through FIG. 9 shows that correction information nl dlc step can be dynamically pre-computed accurately by digitally extracting the rate of change in load current relative to time (di/dt) digitally. Thus, output information nl out = dlc_out_prev +/- nl dlc step (at the time nl out is applied (e.g., within half cycle) after detection of non-linear entry) is based on the pre-computed correction information nl dlc step, which is computed while VOUT is within the target value range and before an error (e.g., droop) is detected. As soon as error output crosses a programmable threshold (e.g., nl entry threshold in FIG. 7) at either the positive edge or negative edge of the sampling clock signal (clock signal Fclk) edge (due to dual-edge (positive-negative) operation), the pre-computed non-linear code nl out is selected as control code at output port 126 (FIG. 1). The control code can adjust the number of turned-on legs (e.g., turned on additional legs) in transistor bank 113 with a relatively small propagation delay in the path (e.g., a delay of hundreds of pico-seconds in a worst case). Therefore, worst-case response time from output droop crossing a threshold (e.g., VOUT - 40mV) to turning-on of additional legs can be relatively small.

[00158] Thus, as described above with reference to FIG. 7 through FIG. 9, during fast load transients, voltage regulator 1 10 enters the non-linear mode autonomously and switches back to the linear mode after the output voltage (VOUT) recovers. The non-linear control techniques described herein digitally compute (e.g., pre-compute) the loss of charge or voltage droop that would happen if non-linear correction is not applied and the load current continued to rise at the same average rate. Then, the described techniques use the pre-computed information to determine the digital nonlinear step that controls the transistors of transistor bank 113. This allows voltage regulator 110 to turn on enough legs to source an amount of current sufficient to add charge in the immediate next cycle. Applying the amount of current this way allows droop to recover instantaneously even if load current continues to increase for the next cycle at the same rate. This also prevents over-correcting, thereby avoiding over-shoots and oscillations. All of these factors allow the described non-linear control techniques to have improvements over some conventional techniques.

[00159] For example, as mentioned above, some conventional techniques apply fixed compensation to correct error caused by a droop, regardless of load variations. This can lead to over-correction and under-correction for a relatively wider range of load current and large current variation rate across an output voltage range.

[00160] In the non-linear techniques described herein, voltage regulator 110 provides a single modular reconfigurable solution to cover applications with a relatively wide range of load current and widely varying di/dt. This can be particularly useful for loads that have multiple functional units (e.g., processor cores in a multicore processor). The non-linear step gain can be programmable based on output load and power transistors (e.g., power FETs) that provide the output voltage. Further, the step is adaptive to the load di/dt because the load di/dt is digitally computed internally in the non-linear controller 140, thereby avoiding over-shoots or oscillations in non-linear response. The described techniques can also be used for varying specifications of the plant by fuse options apart from the internal adaptive control of a non-linear step without adding a significant delay.

[00161] FIG. 10 shows an apparatus in the form of a system (e.g., electronic system) 1000, according to some embodiments described herein. System 1000 can include or be included in a computer, a tablet, or other electronic systems. As shown in FIG. 10, system 1000 can include a processor 1005, a memory device 1020, a memory controller 1030, a graphics controller 1040, an input/output (I/O) controller 1050, a display 1052, a keyboard 1054, a pointing device 1056, at least one antenna 1058, a connector 1015, and a bus 1060 (e.g., conductive lines formed on a circuit board (not shown) of system 1000).

[00162] Each of processor 1005, memory device 1020, memory controller 1030, graphics controller 1040, and I/O controller 1050 can include an IC chip.

[00163] In some arrangements, system 1000 does not have to include a display. Thus, display 1052 can be omitted from system 1000. In some arrangements, system 1000 does not have to include any antenna. Thus, antenna 1058 can be omitted from system 1000.

[00164] Processor 1005 can include a general-purpose processor or an ASIC. Processor 1005 can include a central processing unit (CPU).

[00165] Memory device 1020 can include a dynamic random access memory (DRAM) device, a static random access memory (SRAM) device, a flash memory device, phase change memory, a combination of these memory devices, or other types of memory. FIG. 10 shows an example where memory device 1020 is a stand-alone memory device separated from processor 1005. In an alternative arrangement, memory device 1020 and processor 1005 can be located on the same die. In such an alternative arrangement, memory device 1020 is an embedded memory in processor 1005, such as embedded DRAM (eDRAM), embedded SRAM (eSRAM), embedded flash memory, or another type of embedded memory.

[00166] Display 1052 can include a liquid crystal display (LCD), a touchscreen (e.g., capacitive or resistive touchscreen), or another type of display. Pointing device 1056 can include a mouse, a stylus, or another type of pointing device.

[00167] I/O controller 1050 can include a communication module for wired or wireless communication (e.g., communication through one or more antennas 1058). Such wireless communication may include communication in accordance with WiFi communication technique, Long Term Evolution

Advanced (LTE-A) communication technique, or other communication techniques.

[00168] I/O controller 1050 can also include a module to allow system 1000 to communicate with other devices or systems in accordance with one or more of the following standards or specifications (e.g., I/O standards or specifications), including Universal Serial Bus (USB), DisplayPort (DP), High- Definition Multimedia Interface (HDMI), Thunderbolt, Peripheral Component Interconnect Express (PCIe), Ethernet, and other specifications.

[00169] Connector 1015 can be arranged (e.g., can include terminals, such as pins) to allow system 1000 to be coupled to an external device (or system). This may allow system 1000 to communicate (e.g., exchange information) with such a device (or system) through connector 1015. Connector 1015 may be coupled to I/O controller 1050 through a connection 1016 (e.g., a bus).

[00170] Connector 1015, connection 1016, and at least a portion of bus 1060 can include elements (e.g., conductive terminals, conductive lines, or other conductive elements) that conform to at least one of USB, DP, HDMI,

Thunderbolt, PCIe, Ethernet, and other specifications.

[00171] FIG. 10 shows the elements (e.g., devices and controllers) of system 1000 arranged separately from each other as an example. For example, each of processor 1005, memory device 1020, memory controller 1030, graphics controller 1040, and I/O controller 1050 can be located on a separate IC chip (e.g., separate semiconductor dies). In some arrangements, two or more elements (e.g., processor 1005, memory device 1020, graphics controller 1040, and I/O controller 1050) of system 1000 can be located on the same die (e.g., same IC chip) that can form a system-on-chip (SoC).

[00172] As shown in FIG. 10, each of processor 1005, memory device 1020, memory controller 1030, graphics controller 1040, and I/O controller 1050 can include a voltage regulator 1010. Voltage regulator 1010 can include voltage regulator 110. Thus, voltage regulator 1010 can employ linear and non- linear control techniques described above with reference to FIG. 1 through FIG. 9.

[00173] FIG. 11 is a flowchart showing a method 1100 of operating an apparatus, according to some embodiments described herein. The apparatus used in method 1100 can include any of the apparatuses (e.g., apparatus 100 and system 1000, including voltage regulators 110 and 1010) described above with reference to FIG. 1 through FIG. 10. Some of the activities in method 1100 may be performed by hardware, software, firmware, or any combination of hardware, software, and firmware. For example, some of the activities in method 1100 may be performed by hardware, software, firmware, or any combination of hardware, software, and firmware implemented in any of the apparatuses (e.g., apparatus 100 and system 1000, including voltage regulators 110 and 1010) described above with reference to FIG. 1 through FIG. 10.

[00174] As shown in FIG. 11 , activity 1110 of method 1100 can include generating control information at a first controller of a voltage regulator to control a voltage at a node. Activity 1120 can include computing a gain of a forward path in the first controller to adjust a first value of the control information during a first mode of the voltage regulator when the voltage has a first value within a target value range. Activity 1130 can include generating correction information at a second controller of the voltage regulator during the first mode. Activity 1140 can include adjusting a second value of the control information, based on the correction information, during a second mode of the voltage regulator when the voltage has a second value outside the target value range.

[00175] Method 1100 can include fewer or more activities relative to activities 1110, 1120, 1130, and 1 140 shown in FIG. 11. For example, method 1100 can include activities and operations of apparatus 100 and system 1000, including operations of voltage regulators 110 and 1010 described above with reference to FIG. 1 through FIG. 10.

[00176] The illustrations of the apparatuses and methods described above are intended to provide a general understanding of the structure of different embodiments and are not intended to provide a complete description of all the elements and features of an apparatus that might make use of the structures described herein.

[00177] The apparatuses and methods described above can include or be included in high-speed computers, communication and signal processing circuitry, single-processor modules or multi-processor modules, single embedded processors or multiple embedded processors, multi-core processors, message information switches, and application- specific modules including multilayer or multi-chip modules. Such apparatuses may further be included as sub-components within a variety of other apparatuses (e.g., electronic systems), such as televisions, cellular telephones, personal computers (e.g., laptop computers, desktop computers, handheld computers, etc.), tablets (e.g., tablet computers), workstations, radios, video players, audio players (e.g., MP3 (Motion Picture Experts Group, Audio Layer 3) players), vehicles, medical devices (e.g., heart monitors, blood pressure monitors, etc.), set top boxes, and others.

Additional Notes and Examples

[00178] Example 1 includes subject matter (such as a device, an electronic apparatus (e.g., circuit, electronic system, or both), or a machine) including an output to provide output information to control transistors of a power switching unit, a node to receive a feedback voltage based on an output voltage generated by the power switching unit, and a control circuitry to generate error information based on a value of the feedback voltage generated from the output voltage, generate the output information based on the error information provided to a forward path coupled to the output, and adjust a gain of the forward path based on a gain factor computed based at least in part on a first value of the output information during a first time interval in order to cause the output information to have a second value during a second time interval.

[00179] In Example 2, the subject matter of Example 1 may optionally include, wherein the control circuitry is to cause the output information to have the first and second values when the output voltage is within a target value range.

[00180] In Example 3, the subject matter of Example 1 may optionally include, wherein the control circuitry includes a linear controller, the linear controller includes a multiplier, the multiplier including a first input to receive input information based on the first value of the output information, a second input to receive information from a memory circuit in the control circuitry, and an output to provide the gain factor.

[00181] In Example 4, the subject matter of Example 1 may optionally include, wherein the control circuitry is to receive a clock signal and generate the error information based on timing of the clock signal, and the control circuitry is to adjust the gain of the forward path in each cycle of the clock signal. [00182] In Example 5, the subject matter of Example 1 may optionally include, wherein the control circuitry is to generate the output information based on the error information provided to an addition forward path coupled to the output, and adjust a gain of the additional forward path based on an additional gain factor computed based at least in part on the first value of the output information during the first time interval in order to cause the output information to have the second value during the second time interval.

[00183] In Example 6, the subject matter of any of Examples 1-5 may optionally include, further comprising an analog-to-digital converter to generate the error information based on the feedback voltage and a range of reference voltages.

[00184] In Example 7, the subject matter of any of Examples 1- may optionally include, wherein the control circuitry includes a first forward path to receive the error information, the first forward path including a first adaptive gain circuitry to generate the gain factor to adjust the gain of the first forward path, a second forward path to receive the error information, the second forward path including a second adaptive gain circuitry to generate an additional gain factor to adjust a gain of the second forward path based on the additional gain factor, and a feedback path coupled to the output and the first and second forward paths.

[00185] Example 8 includes subject matter (such as a device, an electronic apparatus (e.g., circuit, electronic system, or both), or a machine) including an output port to provide control information to control transistors of a power switching unit, and a control circuitry to generate the control information such that a value of an output voltage generated by the power switching unit is less than a value of an input voltage provided to the power switching unit, compute a value of correction information during a first time interval when the output voltage has a first value within a target value range, and adjust a value of the control information, based on the correction information, during a second time interval when the output voltage has a second value outside the target value range.

[00186] In Example 9, the subject matter of Example 8 may optionally include, wherein the control circuitry is to compute the value of the correction information based on a rate of change of a current at a node where the output voltage is provided.

[00187] In Example 10, the subject matter of Example 8 may optionally include, wherein the correction information indicates an amount of current to be adjusted at the node during the second time interval.

[00188] In Example 11, the subject matter of any of Examples 8-10 may optionally include, wherein the control circuitry is to receive a clock signal, and the control circuitry is to adjust the value of the control information at a time less than one cycle of the clock signal from a time the second value of the output voltage is detected to be outside the target value range.

[00189] In Example 12, the subject matter of any of Examples 8-10 may optionally include, wherein the control circuitry is to receive a clock signal, and wherein the second value of the output voltage is detected to be outside the target value range at a first edge of the clock signal, and the control circuitry is to start to adjust the value of the control information at a second edge of the clock signal, the second edge occurring in less than one cycle of the clock signal from an occurrence of the first edge.

[00190] In Example 13, the subject matter of any of Examples 8-10 may optionally include, wherein the control circuitry is to receive a clock signal, and the control circuitry is to compute the correction information during a time interval between two consecutive edges of the clock signal.

[00191] In Example 14, the subject matter of any of Examples 8-10 may optionally include, wherein the control circuitry is to receive a clock signal, the control circuitry is to compute the correction information based on a count value, and the count value corresponds to a number of rising and falling edges of the clock signal.

[00192] In Example 15, the subject matter of any of Examples 8-10 may optionally include, wherein the control circuitry is to compute the value of the correction information based on a rate of change of a current from a time the second value of the output voltage is detected to be outside the target value range to a time a half cycle after the time the second value of the output voltage is detected to be outside the target value range. [00193] In Example 16, the subject matter of any of Examples 8-10 may optionally include, wherein the control circuitry is to adjust the value of the control information during a first portion of the second time interval based on the correction information, and the control circuitry is to adjust the value of the control information during a second portion of the second time interval based on error information generated from a comparison of a range of reference voltages with a feedback voltage generated from the output voltage.

[00194] In Example 17, the subject matter of Example 16 may optionally include, further comprising an analog-to-digital converter to perform the comparison.

[00195] Example 18 includes subject matter (such as a device, an electronic apparatus (e.g., circuit, electronic system, or both), or a machine) including a power switching unit to receive an input voltage to provide an output voltage having a value less than a value of the input voltage, an error code generator to generate first error correction information and second error correction information based on errors in the output voltage, a first controller to generate first output information to control the power switching unit during a first mode when the output voltage has a first value within a target value range, the first controller to compute a gain of a forward path during the first mode in order to cause the first output information to have a second value during the first mode, and a second controller to compute a value of correction information during the first mode, and to control the power switching unit during a second mode, based on the correction information, when the output voltage has a second value outside the target value range.

[00196] In Example 19, the subject matter of Example 18 may optionally include, wherein the first controller includes forward paths implemented based on a single set of coefficients.

[00197] In Example 20, the subject matter of any of Examples 15-19 may optionally include, wherein the first controller includes a memory circuit to store information to compute the gain.

[00198] In Example 21, the subject matter of any of Examples 15-19 may optionally include, wherein the second controller is to compute the value of the correction information based on a rate of change of a current at a node where the output voltage is provided.

[00199] In Example 22, the subject matter of any of Examples 15-19 may optionally include, wherein the second controller is to control the power switching unit in an initial stage of the second mode, and the second controller is to control the power switching unit in a second stage of the second mode based on error information different from the correction information.

[00200] Example 23 includes subject matter (such as a device, an electronic apparatus (e.g., circuit, electronic system, or both), or a machine) including a semiconductor die, a processing unit located on the semiconductor die, and a voltage regulator located on the semiconductor die and coupled to the processing unit, the voltage regulator including a power switching unit to receive an input voltage to provide an output voltage having a value less than a value of the input voltage, an error code generator to generate first error correction information and second error correction information based on errors in the output voltage, a first controller to generate first output information to control the power switching unit during a first mode when the output voltage has a first value within a target value range, the first controller to compute a gain of a forward path during the first mode in order to cause the output information to have a second value during the first mode, and a second controller to compute a value of correction information during the first mode, and to control the power switching unit during a second mode, based on the correction information, when output voltage has a second value outside the target value range.

[00201] In Example 24, the subject matter of Example 23 may optionally include, wherein the first mode includes a linear mode, and the second mode includes a non-linear mode.

[00202] In Example 25, the subject matter of Example 23 or 24 may optionally include, wherein the semiconductor die, the processing unit, and the voltage regulator are parts of a system-on-chip (SoC).

[00203] Example 26 includes subject matter (such as a method of operating a device, an electronic apparatus (e.g., circuit, electronic system, or both), or a machine) including generating control information at a first controller of a voltage regulator to control a voltage at a node, computing a gain of a forward path in the first controller to adjust a first value of the control information during a first mode of the voltage regulator when the voltage has a first value within a target value range, generating correction information at a second controller of the voltage regulator during the first mode, and adjusting a second value of the control information, based on the correction information, during a second mode of the voltage regulator when the voltage has a second value outside the target value range.

[00204] In Example 27, the subject matter of Example 26 may optionally include, wherein the forward path is part of multiple forward paths of the first controller, and the multiple paths are implemented using a single set of coefficients.

[00205] In Example 28, the subject matter of Example 26 or 27 may optionally include, wherein generating the correction information includes computing a value of the correction information based on a rate of change of a current at the node.

[00206] In Example 29, the subject matter of Example 26 or 27 may optionally include, wherein adjusting the value of the control information includes applying correction information to the voltage in less than one cycle of a clock signal in the voltage regulator after the second value of the voltage is detected to be outside the target value range.

[00207] Example 30 includes subject matter (such as a device, an electronic apparatus (e.g., circuit, electronic system, or both), or machine) including means for performing any of the subject matter of Example 26 through Example 29.

[00208] The subject matter of Example 1 through Example 30 may be combined in any combination.

[00209] The above description and the drawings illustrate some embodiments to enable those skilled in the art to practice the embodiments of the invention. Other embodiments may incorporate structural, logical, electrical, process, and other changes. Examples merely typify possible variations.

Portions and features of some embodiments may be included in, or substituted for, those of other embodiments. Many other embodiments will be apparent to those of skill in the art upon reading and understanding the above description. Therefore, the scope of various embodiments is determined by the appended claims, along with the full range of equivalents to which such claims are entitled.

[00210] In the detailed description and the claims, a list of items joined by the term "at least one of can mean any combination of the listed items. For example, if items A and B are listed, then the phrase "at least one of A and B" can mean A only; B only; or A and B. In another example, if items A, B, and C are listed, then the phrase "at least one of A, B and C" can mean A only; B only; C only; A and B (excluding C); A and C (excluding B); B and C (excluding A); or all of A, B, and C. Item A can include a single element or multiple elements. Item B can include a single element or multiple elements. Item C can include a single element or multiple elements.

[00211] In the detailed description and the claims, a list of items joined by the term "one of can mean only one of the list items. For example, if items A and B are listed, then the phrase "one of A and B" can mean A only (excluding B), or B only (excluding A). In another example, if items A, B, and C are listed, then the phrase "one of A, B and C" can mean A only; B only; or C only. Item A can include a single element or multiple elements. Item B can include a single element or multiple elements. Item C can include a single element or a multiple elements.

[00212] The Abstract is provided to allow the reader to ascertain the nature and gist of the technical disclosure. It is submitted with the understanding that it will not be used to limit or interpret the scope or meaning of the claims. The following claims are hereby incorporated into the detailed description, with each claim standing on its own as a separate embodiment.