Copyright Agrawal, 2007ELEC5270/6270 Spring 13, Lecture 81 ELEC 5270/6270 Spring 2013 Low-Power Design of Electronic Circuits Power Aware Microprocessors Vishwani D. Agrawal James J. Danaher Professor Dept. of Electrical and Computer Engineering Auburn University, Auburn, AL
Copyright Agrawal, 2007ELEC5270/6270 Spring 13, Lecture 82 SIA Roadmap for Processors (1999) Year Feature size (nm) Logic transistors/cm 2 6.2M18M39M84M180M390M Clock (GHz) Chip size (mm 2 ) Power supply (V) High-perf. Power (W) Source: Untrue predictions.
Copyright Agrawal, 2007ELEC5270/6270 Spring 13, Lecture 83 Power Reduction in Processors Hardware methods: Hardware methods: Voltage reduction for dynamic power Voltage reduction for dynamic power Dual-threshold devices for leakage reduction Dual-threshold devices for leakage reduction Clock gating, frequency reduction Clock gating, frequency reduction Sleep mode Sleep mode Architecture: Architecture: Instruction set Instruction set hardware organization hardware organization Software methods Software methods
Performance Criteria Throughput – computations per unit time. Throughput – computations per unit time. Performance is inverse of time – increasing CPU time indicates lower performance. Performance is inverse of time – increasing CPU time indicates lower performance. Power – computations per watt. Power – computations per watt. Energy efficiency – performance/joule. Energy efficiency – performance/joule. Copyright Agrawal, 2007ELEC5270/6270 Spring 13, Lecture 84
Copyright Agrawal, 2007ELEC5270/6270 Spring 13, Lecture 85 SPEC CPU2006 Benchmarks Standard Performance Evaluation Corporation (SPEC) Standard Performance Evaluation Corporation (SPEC) Twelve integer and 17 floating point programs, CINT2006 and CFP2006. Twelve integer and 17 floating point programs, CINT2006 and CFP2006. Each program run time is normalized to obtain a SPEC ratio with respect to the run time of Sun Ultra Enterprise 2 system with a 296 MHz UltraSPARC II processor. Each program run time is normalized to obtain a SPEC ratio with respect to the run time of Sun Ultra Enterprise 2 system with a 296 MHz UltraSPARC II processor. It takes about 12 days to run all benchmarks on reference system. It takes about 12 days to run all benchmarks on reference system. CINT2006 and CFP2006 metrics are the geometric means of SPEC ratios: CINT2006 and CFP2006 metrics are the geometric means of SPEC ratios: Peak metric – each program is individually optimized (aggressive compilation). Peak metric – each program is individually optimized (aggressive compilation). Base metric – common optimization for all programs. Base metric – common optimization for all programs.
SPEC CINT2006 Results Dell Inc., PowerEdge R610 Dell Inc., PowerEdge R610 CPU: Intel Xeon X5670, 2.93 GHz CPU: Intel Xeon X5670, 2.93 GHz Number of chips 2, cores 12, threads/core 2 Number of chips 2, cores 12, threads/core 2 Performance metric 36.6 base, 39.4 peak Performance metric 36.6 base, 39.4 peak Dell Inc. PowerEdge M905 Dell Inc. PowerEdge M905 CPU: AMD Opteron 8381 HE, 2.50 GHz CPU: AMD Opteron 8381 HE, 2.50 GHz Number of chips 4, cores 16, threads/core 1 Number of chips 4, cores 16, threads/core 1 Performance metric 15.8 base, 19.1 peak Performance metric 15.8 base, 19.1 peak Copyright Agrawal, 2007ELEC5270/6270 Spring 13, Lecture 86
SPEC CFP2006 Results Dell Inc., PowerEdge R610 Dell Inc., PowerEdge R610 CPU: Intel Xeon X5670, 2.93 GHz CPU: Intel Xeon X5670, 2.93 GHz Number of chips 2, cores 12, threads/core 2 Number of chips 2, cores 12, threads/core 2 Performance metric 42.5 base, 45.8 peak Performance metric 42.5 base, 45.8 peak Dell Inc. PowerEdge M905 Dell Inc. PowerEdge M905 CPU: AMD Opteron 8381 HE, 2.50 GHz CPU: AMD Opteron 8381 HE, 2.50 GHz Number of chips 4, cores 16, threads/core 1 Number of chips 4, cores 16, threads/core 1 Performance metric 17.4 base, 21.5 peak Performance metric 17.4 base, 21.5 peak Copyright Agrawal, 2007ELEC5270/6270 Spring 13, Lecture 87
Copyright Agrawal, 2007ELEC5270/6270 Spring 13, Lecture 88 Other Benchmarks LINPACK is numerically intensive floating point linear system (Ax = b) program used for benchmarking supercomputers. LINPACK is numerically intensive floating point linear system (Ax = b) program used for benchmarking supercomputers. SPECPOWER_ssj2008 measures power and performance of a computer system. SPECPOWER_ssj2008 measures power and performance of a computer system. The initial benchmark addresses the performance of server-side Java; additional workloads are planned. The initial benchmark addresses the performance of server-side Java; additional workloads are planned
Second Quarter 2010 SPECpower_ssj2008 Results Apr 7, 2010: Hewlett-Packard ProLiant DL385 G7 Apr 7, 2010: Hewlett-Packard ProLiant DL385 G7 CPU: AMD Opteron 6174, 2.2GHz CPU: AMD Opteron 6174, 2.2GHz Number of chips 2, cores 12, threads/core 2 Number of chips 2, cores 12, threads/core 2 Total memory 16GB Total memory 16GB ssj 100% 888,819 ssj 100% 888,819 Average 100% 271 W Average 100% 271 W Average active idle 101 W Average active idle 101 W Overall ssj operations per watt 2,355 Overall ssj operations per watt 2,355 Copyright Agrawal, 2007ELEC5270/6270 Spring 13, Lecture 89
Second Quarter 2010 SPECpower_ssj2008 Results May 19, 2010: Dell Inc., PowerEdge R610 May 19, 2010: Dell Inc., PowerEdge R610 CPU: Intel Xeon X5670, 2.93 GHz CPU: Intel Xeon X5670, 2.93 GHz Number of chips 2, cores 12, threads 2 Number of chips 2, cores 12, threads 2 Total memory 12GB Total memory 12GB ssj 100% 914,076 ssj 100% 914,076 Average 100% 244 W Average 100% 244 W Average active idle 62.3 W Average active idle 62.3 W Overall ssj operations per watt 2,938 Overall ssj operations per watt 2,938 Copyright Agrawal, 2007ELEC5270/6270 Spring 13, Lecture 810
Copyright Agrawal, 2007ELEC5270/6270 Spring 13, Lecture 811 Energy SPEC Benchmarks Energy efficiency mode: Besides the execution time, energy efficiency of SPEC benchmark programs is also measured. Energy efficiency of a benchmark program is given by: Energy efficiency mode: Besides the execution time, energy efficiency of SPEC benchmark programs is also measured. Energy efficiency of a benchmark program is given by: 1/(Execution time) Energy efficiency = ──────────── Average power Average power D. A. Patterson and J. L. Hennessy, Computer Organization & Design: The Hardware/Software Interface, 4 th Edition, Morgan Kaufmann Publishers (Elsevier), 2009,
Copyright Agrawal, 2007ELEC5270/6270 Spring 13, Lecture 812 Energy Efficiency Efficiency averaged on n benchmark programs: Efficiency averaged on n benchmark programs: n n Efficiency= ( Π Efficiency i ) 1/n i=1 i=1 where Efficiency i is the efficiency for program i. Relative efficiency: Relative efficiency: Efficiency of a computer Efficiency of a computer Relative efficiency = ───────────────── Eff. of reference computer Eff. of reference computer
Copyright Agrawal, 2007ELEC5270/6270 Spring 13, Lecture 813 SPEC2000 Relative Energy Efficiency Always max. clock Laptop adaptive clk. Min. power min. clock
Copyright Agrawal, 2007ELEC5270/6270 Spring 13, Lecture 814 Voltage Scaling Dynamic: Reduce voltage and frequency during idle or low activity periods. Dynamic: Reduce voltage and frequency during idle or low activity periods. Static: Clustered voltage scaling Static: Clustered voltage scaling Logic on non-critical paths given lower voltage. Logic on non-critical paths given lower voltage. 47% power reduction with 10% area increase reported. 47% power reduction with 10% area increase reported. M. Igarashi et al., “Clustered Voltage Scaling Techniques for Low-Power Design,” Proc. IEEE Symp. Low Power Design, M. Igarashi et al., “Clustered Voltage Scaling Techniques for Low-Power Design,” Proc. IEEE Symp. Low Power Design, 1997.
Copyright Agrawal, 2007ELEC5270/6270 Spring 13, Lecture 815 Processor Utilization Throughput = Operations / second Throughput Time Compute-intensive processes System idle Low throughput (background) processes Maximum throughput
Copyright Agrawal, 2007ELEC5270/6270 Spring 13, Lecture 816 Examples of Processes Compute-intensive: spreadsheet, spelling check, video decoding, scientific computing. Compute-intensive: spreadsheet, spelling check, video decoding, scientific computing. Low throughput: data entry, screen updates, low bandwidth I/O data transfer. Low throughput: data entry, screen updates, low bandwidth I/O data transfer. Idle: no computation, no expected output. Idle: no computation, no expected output.
Copyright Agrawal, 2007ELEC5270/6270 Spring 13, Lecture 817 Effects of Voltage Reduction Voltage reduction increases delay, decreases throughput: Voltage reduction increases delay, decreases throughput: Slow reduction in throughput at first Slow reduction in throughput at first Rapid reduction in throughput for V ≤ V Rapid reduction in throughput for V DD ≤ V th Time per operation (TPO) increases Time per operation (TPO) increases Voltage reduction continues to reduce power consumption: Voltage reduction continues to reduce power consumption: Energy per operation (EPO) = Power × TPO Energy per operation (EPO) = Power × TPO
Copyright Agrawal, 2007ELEC5270/6270 Spring 13, Lecture 818 Energy per Operation (EPO) V / V V DD / V th Power TPO EPO
Copyright Agrawal, 2007ELEC5270/6270 Spring 13, Lecture 819 Dynamic Voltage and Clock Throughput Time spent in: Battery life Fast mode Slow mode Idle mode Always full speed 10%0%90% 1 hr Sometimes full speed 1%90%9% 5.3 hrs Rarely full speed 0.1%99%0.9% 9.2 hrs T. D. Burd and R. W. Brodersen, Energy Efficient Microprocessors, Springer, 2002, pp
Example: Find Minimum Energy Mode Processor data (rated operation): Processor data (rated operation): 2 GHz clock 2 GHz clock 1.5 volt supply voltage 1.5 volt supply voltage 0.5 volt threshold voltage 0.5 volt threshold voltage Power consumption Power consumption 50 watts dynamic power 50 watts dynamic power 50 watts static power 50 watts static power Maximum clock frequency for V volt supply (alpha-power law): fα(V – V TH )/V Maximum clock frequency for V volt supply (alpha-power law): fα(V – V TH )/V Copyright Agrawal, 2007ELEC5270/6270 Spring 13, Lecture 820
Alpha-Power Law Model Variation of delay with supply voltage: Variation of delay with supply voltage: delay α V DD /(V DD – V TH ) α V TH = Threshold voltage V TH = Threshold voltage α = 1 for short-channel devices, ≈ 2 for long-channel devices T. Sakurai and A. R. Newton, “Delay analysis of series-connected MOSFET circuits,” IEEE Journal of Solid-State Circuits, Vol. 26, pp.122–131, Feb T. Sakurai and A. R. Newton, “A simple MOSFET model for circuit analysis,” IEEE Transaction on Electron Devices, Vol. 38, No. 4, pp.887–894, Apr T. Sakurai, “High-speed circuit design with scaled-down MOSFETs and low supply voltage (invited),” Proc. IEEE ISCAS, pp.1487–1490, Chicago, May T. Sakurai, “Alpha-Power Law MOS Model,” IEEE Solid-State Circuits Society Newsletter, Vol. 9, No. 4, pp. 4–5, Oct Copyright Agrawal, 2007ELEC5270/6270 Spring 13, Lecture 821
Example Cont. Dynamic power: Dynamic power: P d = CV 2 f = C(1.5) 2 × 2 × 10 9 = 50W C = nF, capacitance switching/cycle P d = V 2 f Dynamic energy per cycle: Dynamic energy per cycle: E d = P d /f = V 2 Copyright Agrawal, 2007ELEC5270/6270 Spring 13, Lecture 822
Example Cont. Clock frequency: Clock frequency: f = k (V – V TH )/V = k (1.5 – 0.5)/1.5 = 2 GHz k = 3 GHz, a proportionality constant f = 3(V – 0.5)/VGHz Copyright Agrawal, 2007ELEC5270/6270 Spring 13, Lecture 823
Example Cont. Static power: Static power: P s = k’ V 2 = k’ (1.5) 2 = 50W k’ = mho, total leakage conductance P s = V 2 Static energy per cycle: Static energy per cycle: E s = P s /f = V 3 /[3(V – 0.5)] = 7.41 V 3 /(V – 0.5) Copyright Agrawal, 2007ELEC5270/6270 Spring 13, Lecture 824
Example Cont. Total energy per cycle: Total energy per cycle: E = E d + E s = V V 3 /(V – 0.5) To minimize E, ∂E/∂V = 0, or To minimize E, ∂E/∂V = 0, or 5V 2 – 4.6V = 0 Solutions of quadratic equation: Solutions of quadratic equation: V = volt, volt Discard second solution, which is lower than the threshold voltage of 0.5 volt. Discard second solution, which is lower than the threshold voltage of 0.5 volt. Copyright Agrawal, 2007ELEC5270/6270 Spring 13, Lecture 825
Example: Result Copyright Agrawal, 2007ELEC5270/6270 Spring 13, Lecture 826 Rated mode Low energy mode Reduction (%) Voltage1.5 V0.679 V54.7% Clock frequency2 GHz791 MHz60% Dynamic energy/cycle25.00 nJ5.12 nJ79.52% Static energy/cycle25.00 nJ12.96 nJ48.16% Total energy/cycle50.0 nJ18.08 nJ63.84% Dynamic power50.0 W4.05 W91.90% Static power50.0 W10.25 W79.50% Total power100.0 W14.20 W85.80%
Cycle Efficiency Cycle efficiency is a rating similar to the maximum clock frequency rating. Cycle efficiency is a rating similar to the maximum clock frequency rating. Analogy: Analogy: Cycle efficiency is similar to miles per gallon (mpg) Cycle efficiency is similar to miles per gallon (mpg) Maximum clock frequency is similar to miles per hour (mph) Maximum clock frequency is similar to miles per hour (mph) Reference: A. Shinde and V. D. Agrawal, “Managing Performance and Efficiency of a Processor,” Proc. 45 th IEEE Southeastern Symp. System Theory, March Reference: A. Shinde and V. D. Agrawal, “Managing Performance and Efficiency of a Processor,” Proc. 45 th IEEE Southeastern Symp. System Theory, March Copyright Agrawal, 2007ELEC5270/6270 Spring 13, Lecture 827
Performance in Time Performance is measured with respect to a program. Performance = D. A. Patterson and J. L. Hennessy, Computer Organization & Design, the hardware/Software Interface, Fourth Edition, San Francisco, California: Morgan Kaufman Publishers, Inc., Copyright Agrawal, 2007ELEC5270/6270 Spring 13, Lecture 82828
Performance in Energy (Efficiency) Efficiency is measured with respect to a program. Performance D. A. Patterson and J. L. Hennessy, Computer Organization & Design, the Hardware/Software Interface, Fourth Edition, San Francisco, California: Morgan Kaufman Publishers, Inc., Copyright Agrawal, 2007ELEC5270/6270 Spring 13, Lecture 82929
Two Performances Time performance Energy performance D. A. Patterson and J. L. Hennessy, Computer Organization & Design, the Hardware/Software Interface, Fourth Edition, San Francisco, California: Morgan Kaufman Publishers, Inc., Copyright Agrawal, 2007ELEC5270/6270 Spring 13, Lecture 83030
Time Performance or Clock Speed of a processor is measured in cycles per second or clock frequency (f). Speed of a processor is measured in cycles per second or clock frequency (f). Execution time of a program using C clock cycles = C/f Execution time of a program using C clock cycles = C/f Time performance = f/C Time performance = f/C Clock period (1/f) is the time per cycle. Clock period (1/f) is the time per cycle. Copyright Agrawal, 2007ELEC5270/6270 Spring 13, Lecture 831
Energy Performance Energy efficiency of a processor may be measured in cycles per joule or cycle efficiency (η). Energy efficiency of a processor may be measured in cycles per joule or cycle efficiency (η). Energy dissipated by a program using C clock cycles = C/η Energy dissipated by a program using C clock cycles = C/η Energy performance = η/C Energy performance = η/C 1/η is energy per cycle (EPC) 1/η is energy per cycle (EPC) Copyright Agrawal, 2007ELEC5270/6270 Spring 13, Lecture 832
Characterizing Device Technology Speed and Efficiency Consider 90nm CMOS technology. Consider 90nm CMOS technology. Use predictive technology model (PTM). Use predictive technology model (PTM). Example circuit: Eight-bit ripple carry adder. Example circuit: Eight-bit ripple carry adder. Nominal voltage = 1.2 volts. Nominal voltage = 1.2 volts. Simulation for varying operating conditions (VDD = 100mV through 1.2V) using Spice: Simulation for varying operating conditions (VDD = 100mV through 1.2V) using Spice: With random vectors for energy per cycle (EPC = 1/η). With random vectors for energy per cycle (EPC = 1/η). With critical path vectors for clock period (1/f). With critical path vectors for clock period (1/f). Reference: W. Zhao and Y. Cao, “New Generation of Predictive Technology Model for Sub-45nm Early Design Exploration,“ IEEE Trans. Electron Devices, vol. 53, no. 11, pp. 2816–2823, Reference: W. Zhao and Y. Cao, “New Generation of Predictive Technology Model for Sub-45nm Early Design Exploration,“ IEEE Trans. Electron Devices, vol. 53, no. 11, pp. 2816–2823, Copyright Agrawal, 2007ELEC5270/6270 Spring 13, Lecture 833
Energy per Cycle of 8-Bit Adder K. Kim, “Ultra Low Power CMOS Design,” PhD Dissertation, Auburn University, Dept. of ECE, Auburn, Alabama, May K. Kim, “Ultra Low Power CMOS Design,” PhD Dissertation, Auburn University, Dept. of ECE, Auburn, Alabama, May Copyright Agrawal, 2007ELEC5270/6270 Spring 13, Lecture 8 34
Cycle Time of 8-Bit Adder K. Kim, “Ultra Low Power CMOS Design,” PhD Dissertation, Auburn University, Dept. of ECE, Auburn, Alabama, May K. Kim, “Ultra Low Power CMOS Design,” PhD Dissertation, Auburn University, Dept. of ECE, Auburn, Alabama, May Copyright Agrawal, 2007ELEC5270/6270 Spring 13, Lecture 8 35
Pentium M processor Published data: H. Hanson, K. Rajamani, S. Keckler, F. Rawson, S. Ghiasi, J. Rubio, “Thermal Response to DVFS: Analysis with an Intel Pentium M,” Proc. International Symp. Low Power Electronics and Design, 2007, pp Published data: H. Hanson, K. Rajamani, S. Keckler, F. Rawson, S. Ghiasi, J. Rubio, “Thermal Response to DVFS: Analysis with an Intel Pentium M,” Proc. International Symp. Low Power Electronics and Design, 2007, pp VDD = 1.2V VDD = 1.2V Maximum clock rate = 1.8GHz Maximum clock rate = 1.8GHz Critical path delay, td = 1/1.8GHz = ps Critical path delay, td = 1/1.8GHz = ps Power consumption = 120W Power consumption = 120W EPC = 120/(1.8GHz) = 66.67nJ EPC = 120/(1.8GHz) = 66.67nJ Copyright Agrawal, 2007ELEC5270/6270 Spring 13, Lecture 836
Cycle Efficiency and Frequency Copyright Agrawal, 2007ELEC5270/6270 Spring 13, Lecture 8 37
Example For a program that executes in 1.8 billion clock cycles. Voltage VDD Frequency f MHz Cycle Efficiency, η Execution Time second Total Energy Consumed Power f/η 1.2 V 1800 megacycles/s 15 megacycles/joule Joules120W 0.6 V 277 megacycles/s 70 megacycles/joule Joules39.6W 200 mV 54.5 megacycles/s 660 megacycles/joule Joules0.083W Copyright Agrawal, 2007ELEC5270/6270 Spring 13, Lecture 8 38
Cycle Efficiency New performance rating: Cycle efficiency η unit is cycles per joule. Clock frequency f in cycles per second is a similar rating with respect to time. Similarity to other popular ratings: η → mpg f → mph Two ratings allow effective time and energy management of an electronic system. Copyright Agrawal, 2007ELEC5270/6270 Spring 13, Lecture 8 39
Copyright Agrawal, 2007ELEC5270/6270 Spring 13, Lecture 840 Problem of Process Variation in Nanometer Technologies Lower V th V th Higher V th Number of chips Power specification Clock specification From a presentation: Power Reduction using LongRun2 in Transmeta’s Efficon Processor, by D. Ditzel May 17, 2006 Yield loss due to high leakage Yield loss due to slow speed Higher voltage operation Lower voltage operation Nominal voltage
Copyright Agrawal, 2007ELEC5270/6270 Spring 13, Lecture 841 Clock Distribution H-Tree clock Fanout, λ = 4 Tree depth, s = log λ N No. of flip-flops = N
Copyright Agrawal, 2007ELEC5270/6270 Spring 13, Lecture 842 Clock Power P clk = C L V DD 2 f + C L V DD 2 f / λ + C L V DD 2 f / λ stages – 1 1 = C L V DD 2 f Σ─ n = 0λ n where C L =total load capacitance of N flip-flops λ =constant fanout at each stage in distribution network Clock consumes about 40% of total processor power, because (1)Clock is always active (2)Makes two transitions per cycle, (α = 2) (3)Clock gating is useful; inhibit clock to unused blocks
Properties of H-Tree Balanced clock skew. Balanced clock skew. Small delay and power consumption. Small delay and power consumption. Requires fine-tuning for complex layout. Requires fine-tuning for complex layout. Copyright Agrawal, 2007ELEC5270/6270 Spring 13, Lecture 843
Clock Power and Delay Unit size buffer or inverter delay = d Unit size buffer or inverter delay = d Total dynamic power supplied to N flip- flops, P = C L V DD 2 f Total dynamic power supplied to N flip- flops, P = C L V DD 2 f Total power consumption of clock network: Total power consumption of clock network: Copyright Agrawal, 2007ELEC5270/6270 Spring 13, Lecture 844 Flip-flps, NClock power per flip-flopClock delay 1Pd 4P4d P8d P12d P16d
Copyright Agrawal, 2007ELEC5270/6270 Spring 13, Lecture 845 Clock Network Examples Alpha Alpha Alpha Technology 0.75μ CMOS 0.5μ CMOS 0.35μ CMOS Frequency (MHz) Total capacitance 12.5nF Clock gating used. Total power W Clock load 3.25nF3.75nF Clock power 40% 40% (20W) Max. clock skew 200ps (<10%) 90ps D. W. Bailey and B. J. Benschneider, “Clocking Design and Analysis for a 600-MHz Alpha Microprocessor,” IEEE J. Solid-State Circuits, vol. 33, no. 11, pp , Nov
Copyright Agrawal, 2007ELEC5270/6270 Spring 13, Lecture 846 Architecture Level: Pipeline Gating A pipeline processor uses speculative execution. A pipeline processor uses speculative execution. Incorrect branch prediction results in pipeline stalls and wasted energy. Incorrect branch prediction results in pipeline stalls and wasted energy. Idea: Stop fetching instructions if a branch hazard is expected: Idea: Stop fetching instructions if a branch hazard is expected: If the count (M) of incorrect predictions exceeds a pre- specified number (N), then suspend fetching instruction for some k cycles. If the count (M) of incorrect predictions exceeds a pre- specified number (N), then suspend fetching instruction for some k cycles. Ref.: S. Manne, A. Klauser and D. Grunwald, “Pipeline Gating: Speculation Control for Energy Reduction,” Proc. 25 th Annual International Symp. Computer Architecture, June Ref.: S. Manne, A. Klauser and D. Grunwald, “Pipeline Gating: Speculation Control for Energy Reduction,” Proc. 25 th Annual International Symp. Computer Architecture, June 1998.
Copyright Agrawal, 2007ELEC5270/6270 Spring 13, Lecture 847 Slack Scheduling Application: Superscalar, out-of-order execution: Application: Superscalar, out-of-order execution: An instruction is executed as soon as the required data and resources become available. An instruction is executed as soon as the required data and resources become available. A commit unit reorders the results. A commit unit reorders the results. Delay the completion of instructions whose result is not immediately needed. Delay the completion of instructions whose result is not immediately needed. Example of RISC instructions: Example of RISC instructions: addr0, r1, r2;(A) addr0, r1, r2;(A) sub r3, r4, r5;(B) sub r3, r4, r5;(B) and r9, r1, r9;(C) and r9, r1, r9;(C) or r5, r9, r10;(D) or r5, r9, r10;(D) xor r2, r10, r11;(E) xor r2, r10, r11;(E) J. Casmira and D. Grunwald, “Dynamic Instruction Scheduling Slack,” Proc. ACM Kool Chips Workshop, Dec
Copyright Agrawal, 2007ELEC5270/6270 Spring 13, Lecture 848 Slack Scheduling Example Slack scheduling A BC D E Standard scheduling ABC D E
Copyright Agrawal, 2007ELEC5270/6270 Spring 13, Lecture 849 Slack Scheduling Slack bit Low-power execution units Re-order buffer Scheduling logic
Copyright Agrawal, 2007ELEC5270/6270 Spring 13, Lecture 850 Power Reduction Example Alpha 21064: 3.45V, power dissipation = Alpha 21064: 3.45V, power dissipation = 26W Reduce voltage to 1.5V, power (5.3x) = Reduce voltage to 1.5V, power (5.3x) = 4.9W Eliminate FP, power (3x) = Eliminate FP, power (3x) = 1.6W Scale 0.75μ → 0.35μ, power (2x) = Scale 0.75μ → 0.35μ, power (2x) = 0.8W Reduce clock load, power (1.3x) = Reduce clock load, power (1.3x) = 0.6W Reduce frequency 200 →160MHz, power (1.25x) = Reduce frequency 200 →160MHz, power (1.25x) = 0.5W J. Montanaro et al., “A 160-MHz, 32-b, 0.5-W CMOS RISC Microprocessor,” IEEE J. Solid-State Circuits, vol. 31, no. 11, pp , Nov J. Montanaro et al., “A 160-MHz, 32-b, 0.5-W CMOS RISC Microprocessor,” IEEE J. Solid-State Circuits, vol. 31, no. 11, pp , Nov
Copyright Agrawal, 2007ELEC5270/6270 Spring 13, Lecture 851 For More on Microprocessors T. D. Burd and R. W. Brodersen, Energy Efficient Microprocessor Design, Springer, T. D. Burd and R. W. Brodersen, Energy Efficient Microprocessor Design, Springer, R. Graybill and R. Melhem, Power Aware Computing, New York: Plenum Publishers, R. Graybill and R. Melhem, Power Aware Computing, New York: Plenum Publishers, 2002.