An Algorithm to Minimize Leakage through Simultaneous Input Vector Control and Circuit Modification Nikhil Jayakumar Sunil P. Khatri Presented by Ayodeji Coker Texas A&M University, College Station, TX, USA
Contribution of Leakage Power Leakage is a major contributor to total power consumption. “Standby / Sleep” leakage reduction is crucial for portable electronics. Some popular techniques are: MTCMOS / sleep transistor Body biasing Input Vector Control (IVC)
Intuition Behind Input Vector Control Stack Effect : As many series cut-off transistors as possible reduces leakage. Leakage can be about 2 orders of magnitude lower than maximum. Cannot set all gates to minimum leakage state due to logical interdependencies NAND3 : min leakage state = 000 NOR3 : min leakage state = 111 InputLeakage (A) E E E E E E E E-08 Leakage of a NAND3 gate
Traditional Input Vector Control Find the Minimum Leakage Vector (MLV) at the primary inputs. NP-hard problem. Several heuristics to find an optimal MLV. Apply inputs through scan-chain or through MUXes at primary inputs (flip-flop outputs) during standby / sleep. Can we do more? Why restrict ourselves to only primary inputs?
Previous Approaches “Leakage Current Reduction in CMOS VLSI Circuits by Input Vector Control” (TVLSI ‘04) – Abdollahi et.al. Similar to our approach – use control points and IVC. Our choice of gate variants allows greater flexibility at control points. “Enhanced Leakage Reduction by Gate Replacement” (DAC ‘05) – Yuan et.al. “A Fast Simultaneous Input Vector Generation and Gate Replacement Algorithm for Leakage Power Reduction” (DAC ’06) – Cheng et.al. Use gate replacement like we do, but a gate G is replaced by a gate G’ to reduce leakage of gate G not control internal nodes. Previous approaches have an associated delay penalty to get a reasonable leakage reduction. We get a significant leakage reduction with no expected delay penalty.
Our Approach - Overview Modify the circuit such that we control internal nodes of the circuit. Create variants of each gate that replaces the original. Traverse a circuit from inputs to output and replace gates in the circuit Reduce leakage through stack effect for the gates in the fanout of a gate. Do not necessarily reduce leakage of the gate being replaced. Perform gate replacement such that leakage is reduced but circuit delay is not increased.
Variants of a Gate Regular NAND2
sngl1out 0 : Used when output of gate is 1 in standby, but all the fanout gates required an output of 0. Variants of a Gate
sngl1out 1 : Used when output of gate is 0 in standby, but all the fanout gates required an output of 1. Variants of a Gate
snglmx 0 : Used when output of gate is 1 in standby, but some fanout gates require an output of 0. Variants of a Gate
snglmx 1 : Used when output of gate is 0 in standby, but some fanout gates require an output of 1. Variants of a Gate
dbl variants : Larger counterparts of the sngl variants (devices sized < 2X) Adds more flexibility to choices for replacement. Variants of a Gate
The Gate Replacement Algorithm Assume inputs of gates at first level can be set independently Gates at first level can all be set to their minimum leakage state. Pick a gate G from the first level. Let g be its output signal. Find what value all gates in the fanout of G require. Try to replace gate if there is a net savings in leakage and there is no timing violation.
Example G H J First set gate G to lowest leakage state - 00 Next look at fanout of gate G – gate J is in its fanout. If output of G = 1 (the current value) – best state at J possible is 10. Choose from 10,11 Best state possible for J is 00. Choose from 00,01,10,11. Leakage improvement possible = (Leakage of J at state 00 – Leakage of J at state 10 – Leakage cost of replacing gate G with a sngl1out 0 variant).
First set gate G to lowest leakage state - 00 Next look at fanout of gate G – gate J is in its fanout. If output of G = 1 (the current value) – best state at J possible is 10. Choose from 10,11 Best state possible for J is 00. Choose from 00,01,10,11. Leakage improvement possible = (Leakage of J at state 00 – Leakage of J at state 10 – Leakage cost of replacing gate G with a sngl1out 0 variant). G H J Example
Next set gate H to its lowest leakage state - 00 Then look at fanout of gate H – gate J is in its fanout. If output of H = 1 (the current value) – best state at J possible is is only choice. Best state possible for J is 00 Choose from 00,01. Leakage improvement possible = (Leakage of J at state 00 – Leakage of J at state 01 – Leakage cost of replacing gate H with a sngl1out 0 variant). G H J Example
…Replacement Algorithm If both logic 0 and logic 1 are required at some node – then try snglmx variants. If sngl variants cause timing violations – try dbl variants. Use dbl variants only if leakage improvement is positive. Traverse circuit from inputs to output in levelized order.
Experimental Results Cell library characterization done in SPICE. bsim100 Berkeley Predictive Technology Model (BPTM) cards, 1.2V VDD Algorithm implemented in PERL Run on 3GHz Pentium 4, 2GB RAM, Fedora Core 3.
On average 30% improvement in leakage over applying MLV at primary inputs alone. Existing approaches that use IVC and control points to get a similar leakage improvement have a delay penalty of 10 to 15%. Ckt.Min Lkg Original(nA)New min. Lkg(nA)% Lkg Decr alu alu apex apex C C C C C C dalu des i i i i i i i i t too_large Avg29.18 Experimental Results
There is never a delay increase. Delay decreases in some instances due to use of dbl variants. sngl1out variants improve delay in one transition. Runtime is low. Current implementation is in PERL – expected to speed up when implemented in C/C++. Ckt.Original Delay (ps)New Delay (ps) % Delay ImprovementRuntime(s) alu alu apex apex C C C C C C dalu des i i i i i i i i t too_large Avg Experimental Results
Ckt. Original Active Area(μ2) New Active Area(μ2) Active Area Ovh (%) Sleep Cut-off transistor Active Area (μ2) Active Area excluding sleep cut-off transistors (μ2) Active Area Ovh excluding sleep cut-off transistors (%) alu alu apex apex C C C C C C dalu des i i i i i i i i t too_large Avg Total Active area overhead on average = 24%. Real area overhead would be lower after layout, place and route. A lot of the area is used by sleep cut- off transistors. These can be shared – would reduce area, delay and leakage. Experimental Results
dblmx variants did not get used. sngl1out variants used the most. Ckt.#sngl1out#dbl1out#snglmxTotal # replacementsTotal # gates alu alu apex apex C C C C C C dalu des i i i i i i i i t too_large Avg Experimental Results
Conclusion We extended input vector control to control internal nodes – not just primary inputs. 30% leakage decrease with no delay penalty Leakage decrease is over MLV at primary inputs alone. Delay improvement in many cases. Active area increase = 24%, but this is mostly sleep cut-off transistor area Placed and routed area is expected to be much lower. Dynamic power estimated to increase by 1.5% on average.
Thank you Contact info of authors: nikhil_AT_ece_DOT_tamu_DOT_edu sunilkhatri_AT_tamu_DOT_edu