300 likes | 479 Views
FA-STAC : A framework for fast and accurate static timing analysis with coupling. Debasish Das Electrical Engineering and Computer Science Northwestern University Evanston, IL 60208 International Conference on Computer Design, San Jose, CA October 2 nd , 2006. Co-authors.
E N D
FA-STAC : A framework for fast and accurate static timing analysis with coupling Debasish Das Electrical Engineering and Computer Science Northwestern University Evanston, IL 60208 International Conference on Computer Design, San Jose, CA October 2nd , 2006
Co-authors • Ahmed Shebaita, EECS, Northwestern University • Hai Zhou, EECS, Northwestern University • Yehea Ismail, EECS, Northwestern University • Kip Killpack, Strategic CAD Lab, Intel Corporation Industry Support Cell Library Provider
Outline • Previous Research • Accurate Coupling Delay Computation • Efficient Iteration Mechanism • Experimental Setup • Conclusions and future work
Previous Research (Coupling Model) • Coupling cap dominates interconnect parasitics • Miller coupling factor (MCF): switching dependent • Step transitions : (0,2) Sapatnekar et.al, ICCAD 2000 • Ramp Models : (-1,3) Kahng et.al, DAC 2000 Chen et.al, ICCAD 2000 • Exponetial Models : (-1.885,3.885) Ghoneima et.al, ISCAS 2005 • Coupling Model Issues: • Models not extended to Timing Analysis
Previous Research (Static Timing) • Timing Analysis with x-cap iterative • Iterative analysis with continous models: Chen et.al ICCAD 2000 • Iterative analysis with discrete models: Sapatnekar et.al ICCAD 2000, Chen et.al ICCAD 2000, Arunachalam et.al DAC 2000 • Iterative analysis issues • Circuit/Coupling structure Ignored • No detailed study of convergence
NuCAD Presents: • Salient features • Waveform based accurate coupling model • Efficient iteration scheme (Chaotic Iteration) • Circuit and Coupling structure exploration • Speeding up iteration scheme using structure FA-STAC
Outline • Previous Research • Accurate Coupling Delay Computation • Efficient Iteration Mechanism • Experimental Setup • Conclusions and future work
Circuit Model N1 NAND • Rise/Fall-Delay-Window : (rdl,rdh)/(fdl,fdh) • Rise/Fall-Slew-Window : (rsl,rsh)/(fsl,fsh) • Associated nodes with coupling edge : N1 and N2 CC CC CC N3 NAND NAND N2 Coupling Edge Rise Arc NAND I1 N1 Fall Arc I2
Motivational Example Rise Window : [2.6,5.3] Rise Slew : [0.5,0.7] • Input Delay Rise I1 : [2,4] I2: [3,5] • Input Delay Fall I1 : [2.5,3.5] I2: [3.5,4.5] • Input Slew Rise/Fall I1: [0.2,0.6] I2 : [0.4,0.8] • Average input slew Rise/Fall I1 : 0.4 I2 : 0.6 • Compute initial switching windows: MCF = 1.0 MCF = 1.8 Rise Window : [3.0,5.8] Rise Slew : [0.6,0.8]
Coupling Factor Computation • Associated Nodes with coupling edge • Victim Node (V) • Aggressor Node (A) • Static timing seeks for worst bounds • Waveform generation on V and A • Overlap ratio (k) computation • Overlap ratio is defined as the ratio of aggressor output waveform that overlap with victim threshold voltage • Choose waveforms to generate worst possible k • Effective coupling cap : (1+/- 2k)xCC
Waveform selection Aggressor Aggressor Doa Doa+tas t Doa Doa+tas t Victim Victim t t Dov Dov+0.5tvs Dov+tvs Dov Dov+0.5tvs Dov+tvs K = 1.0 K = (Doa+tas-tvs)/tas
Waveform selection Aggressor Aggressor Doa Doa+tas t Doa Doa+tas t Victim Victim t t Dov Dov+0.5tvs Dov+tvs Dov Dov+0.5tvs Dov+tvs K = (Doa+0.5tvs-Dov)/tas K = (0.5tvs)/tas
Waveform Selection Aggressor Aggressor Doa Doa+tas t Doa Doa+tas t Victim Victim Dov Dov+0.5tvs Dov+tvs t Dov Dov+0.5tvs Dov+tvs t K = 0 K = 0
Accurate Coupling Delay Computation The idea is ! Compute D and ts from Windows To get bounds (best/worst) on K
Outline • Previous Research • Accurate Coupling Delay Computation • Efficient Iteration Mechanism • Experimental Setup • Conclusions and future work
Iteration basics • Traditional static timing analysis • Topological order of the circuit • Static timing analysis with coupling is ITERATIVE • Iterative timing analysis converges to FixPoint • Under a given coupling model (Zhou, ICCAD 2003) • Node ordering is important • How to make Static Timing Analysis efficient ? • Explore circuit structure for node ordering • Decrease iterations
Clustering • Problems in analysis based on topological order • Any update at d Propagate to e, f, g, h • If update at d not permanent Calculation wasted • Solution: Clustering • Local cluster (B) : Change in e Changes f • Global cluster (A) : Two interacting local clusters • Timing Analysis Convergence on clusters • Clustering Issues: • With coupling whole circuit can be one global cluster
How to use Clustering ideas ? • Coupling edges are bidirectional on Timing Graph • Select coupling edges Timing Graph Acyclic G3 G1 G6 G4 G8 CC1 G7 G2 G5 CC2 • Such coupling edges are called Feedback Edges • Example : Coupling edge with fan-out relation • Carry out iterations based on feedback edges
Feedback Edge Identification Coupling Edges with no fan-out relation (Local Coupling Edges) G3 G1 G6 • Local Coupling Edge • Any change on aggressor should be updated to victim • Update does not occur by fan-out • Observation: • Choosing CC1 as local coupling edge • Force CC2 to become feedback edge • Choosing CC2 as feedback edge • Force CC1 related by fan-out • Metric to identify local coupling edge • Coupling Weight = Overlap ratio (K) with 1xCC timing windows CC1 G4 G8 G7 G2 CC2 G5
Coupling Partitioning Algorithm • Coupling edges are partitioned into: • Feedback edges (Global Coupling Edges) • Local Coupling Edges • Algorithm: • Using BFS identify “Easy” Global Edges • Sort remaining coupling edges by coupling weight • Do • Identify highest weighted edge (e) as local • Find global edges generated by e (ge) • Remove ge from sorted coupling edges • While (no more coupling edges left)
Coupling Partitioning Algorithm (Illustration) G3 G3 G1 G6 G1 G6 CC1 G4 G8 CC1 G4 G8 G7 G2 CC2 G7 G2 CC2 G5 G5 kCC1 = 0.6 , kCC2 = 0.8 Local Coupling Edge= CC2 CC1 identified as Global Edge Super-Node formation G3 G3 G1 G1 G6 G6 CC1 G4 CC1 G8 G4 G8 G7 G2 G7 G2 G5 G5
Coupling Structure Aware Iteration Algorithm • Initialization • Add topological sorted nodes in queue • Update coupling capacitance with MCF = 1.0 • Update windows on each node • Modified Chaotic Iterations • While (queue is not empty) • u Pop a node from queue • Update coupling capacitance with new MCFs • Update timing windows on u • If ( | uold – unew | > ε ) • Add fan-out nodes of u to queue • Add nodes to queue coupled by local coupling edges
Outline • Previous Research • Accurate Coupling Delay Computation • Efficient Iteration Mechanism • Experimental Setup • Conclusions and future work
Circuit Modeling • Experiments done on ISCAS85 benchmarks • Circuit modeled as DAG (Timing Graph) • Nodes in Timing Graph are Gates • Edges represent interconnect • Nodes are mapped to ASIC logic gates • Faraday 90 nm experimental tech library used • Delay tables are used : f( output load, input slew ) • Coupling graph generation • Extracted coupling capacitance values are used • Coupling graph is superimposed on timing graph • Each net is assumed to couple with 4 aggressors
Model Accuracy Results • CE denotes number of coupling edges • RT : Runtime in seconds, TA : Cell Table Lookup • (rdl,rdh) : Rise delay window • 012 Model can be non-conservative !
Performance Enhancement Results • CI : Iterative algorithm proposed by Chen et.al • Fast-CI : Coupling structure aware algorithm • Global : Number of global edges identified • P-RT : Coupling partitioning runtime Min = 5.7% Max = 62.1% Average = 26.8%
Outline • Previous Research • Accurate Coupling Delay Computation • Efficient Iteration Mechanism • Experimental Setup • Conclusions and future work
Conclusions and future work • We present FA-STAC • Accurate static timing analysis with coupling • Efficient iteration mechanism to converge faster • Novel coupling delay model developed • Coupling structure exploited for fast iterations • Experimental results on ISCAS benchmarks • Our algorithm give average speed-up of 26.8% • Negligible error in timing windows • Future directions • Complex coupling model for local coupling edges • Submitted to DATE 2007
THANK YOU Q & A