1 / 90

Design Automation for Asynchronous Circuits

Explore optimization strategies, technical implications, and tools for asynchronous circuit design collaboration with industry experts. Gain insights on metrics, modeling, and variability for efficient circuit design.

golson
Download Presentation

Design Automation for Asynchronous Circuits

An Image/Link below is provided (as is) to download presentation Download Policy: Content on the Website is provided to you AS IS for your information and personal use and may not be sold / licensed / shared on other websites without getting consent from its author. Content is provided to you AS IS for your information and personal use only. Download presentation by click this link. While downloading, if for some reason you are not able to download a presentation, the publisher may have deleted the file from their server. During download, if you can't get a presentation, the file might be deleted by the publisher.

E N D

Presentation Transcript


  1. Design Automation for Asynchronous Circuits Alex Kondratyev Cadence Berkeley Labs,Berkeley, CA, USA In collaboration with Jordi Cortadella, Luciano Lavagno Kelvin Lwin and Christos Sotiriou

  2. Outline Outline • What do we optimize? • End of deterministic design • Technical and business implications • Asynchronous design with commercial tools • Desynchronization • Delay-insensitive datapath

  3. Optimization metrics • Late 70-s: • Literals • nodes of a Boolean network • Levels of a Boolean network Area Speed • Nowadays: • Literals • nodes of a Boolean network • Levels of a Boolean network • Wire length Area Speed Tools are optimizing for area and speed!

  4. ? small P = P + P + P avg dyn short leak 2 P = a * f * C * V dd dyn clk P P P leak short dyn Universal metrics Power: C

  5. P = P + P + P avg dyn short leak 2 t = Q / I = C * V / k(V - V ) I c dd d t ds dd ds Universal metrics Power ? small 2 C P = a * f * C * V dd dyn clk Delay:  , delay Supply voltage Power    Speed can be taken as a universal metrics

  6. Outline Outline • What do we optimize? • End of deterministic design • Technical and business implications • Asynchronous design with commercial tools • Desynchronization • Delay-insensitive datapath • Fine-grain pipelining

  7. Timing margins • Algorithms/tools (approximations) • Modeling (process corners e.g.) • Architecture (unbalanced computation)

  8. Algorithms/tools False paths (< 5%) Common path pessimism removal Hierarchy hurts!!! 10-35% gain from floorplan flattening (Reshape) Bad news: we do not know how far we are from optimum  Good news: optimum is not possible to find 

  9. 0.25 , Vdd=2.510%, T=0, 125C 0.13 , Vdd=1.010%, T=- 40, 125C INVX2 (fall) INVX2 (fall) slow slow typical typical fast fast Fast  0.76 Typical Fast  0.73 Typical Slow  1.47 Typical Slow  1.55 Typical Modeling Why to panic? New BIG players: signal integrity and process variability

  10. Variability sources • Environment (T, Vdd) + signal integrity • Within-die only • Process variations • (gate length L, wire width W, threshold voltage Vt) • Die-to-die (design independent) • Within-die (design dependent)

  11. Environment + SI Temperature: -40C to 125 C Supply voltage: ± 10% VDD V’DD IR drop – decrease in the current from Vdd Bad news: Good news: 7 6 Field solvers can handle 10 variables 10 gates x 8metal layers Abstraction, model reduction, IP reuse help further 9  10 RC elements in VDD grid Tools make IR drop sign off at 5%Vdd (still  10% delay penalty)

  12. aggressor aggressor Pruning by coupling victim victim delay pulse Worst coupling estimation H-Spice simulation Tc (%) Compute switching windows Pruning by timing Environment + SI Crosstalk Conservative analysis: up to 20% delay penalty (post-layout fixes)

  13. within-die die-to-die Process variations • Within-die • design dependent, • systematic and random!! • Die-to-die • design independent, well • modeled via worst-case files Lgate Wwire Tt Nassif’01

  14. Measuring variability % chips Microprocessor at-speed functional testing frequency Bin1 Bin2 Bin3 ASIC no delay testing, no binning Strategically placed oscillators: Problem: Up to 15% delay variation in RO (Nassif’03) Vertical/horizontal (4%), spacing poli-SI (7%), distance (5%)

  15. d =  env +  device +  wire var var var var Modeling variability Model for gate delay (linear wrt variability sources) Independence of sources (within a group - model reduction (PCA or SVD)) For a single variability source: L = L + L random spatial var (is modeled by random normally distributed variables N(0,)) Variation of path delay: D =  d (L ) var var var

  16. Statistical timing analysis ? Reconvergence needs some care • Numerical computation of a distribution • Approximate convolution (5% accuracy) • Use upper and lower bounds (10% diff. Blaauw’03) Algorithms have linear complexity!

  17. Confidence margin WC confidence margin must be big (chips work) But it is fully unknown worst What it buys? Trading yield STA helps to quantify risk (reduce margin and be structure specific) STA might help to trade off confidence margin and yield (testing???) • Open issues: • why normal? • how to derive ? • how to derive sensitivity coefficients?

  18. Outline Outline • What do we optimize? • End of deterministic design • Technical and business implications • Asynchronous design with commercial tools • Desynchronization • Delay-insensitive datapath • Fine-grain pipelining

  19. Non-balanced stages 20% Clock skew SI 10% Summing this up Clock overhead Cycle time Real Computation Time Worst- average Variability 25% 30% 45% Some designs work twice faster than needed by spec! Everything boils down to$$$ Synchronous design is turning out to become a costly proposition

  20. Is asynchronous an option? It is about time but … “must” requirements to asynchronous CAD tool: • Competitive - added value with minimal (or no) penalty - scalable (capable of handling large designs) • Simple - minimal knowledge of asynchronous design - RTL input • Risk-free - does not change sign-off (STA) - complete solution in verification and testing - backup options (synchronous implementation)

  21. Outline Outline • What do we optimize? • End of deterministic design • Technical and business implications • Asynchronous design with commercial tools • Desynchronization • Delay-insensitive datapath • Fine-grain pipelining

  22. Design options QDI approach Bundled approach Dual-rail logic Single-rail logic done C • • • • • • • • • • • • delay start done

  23. Sliding the trade-off curve Automation efforts QDI datapath NCL, phased logic Penalties? Bundled data desynchronization EMI, skew penalty Variability Average speed gates blocks

  24. Desyncronization flow • Think synchronous • Design synchronous:one clock and edge-triggered flip-flops • De-synchronize (automatically) • Run it asynchronously Asynchronous for dummies

  25. MS flip-flop Synchronous circuit L L L L 0 1 0 1 CLK 0 0 L L

  26. C C C C C C De-synchronization L L L L 0 1 0 1 0 0 L L

  27. De-synchronization Distributed controllers substitute the clock network C C C C C C The data path remains intact !

  28. A B C D A+ B- C+ D- A- B+ C- D+ Non-overlapping handshake protocol A B C D

  29. A B C D A B C D A+ B+ C+ D+ A- B- C- D- Overlapping is also acceptable

  30. bubble A B C data • + and – must alternate A+ B+ C+ • data available at the previous latch • next latch must be closed before receiving new data A- B- C- Concurrent model

  31. For any netlist

  32. Synchronization layer

  33. Synchronization layer

  34. Synchronization layer This This is a circuit marked graph (CMG)

  35. Properties of CMGs • Any CMG is live and safe • Safeness: no data overwriting • Liveness: no deadlock A+ B+ C+ A- B- C-

  36. Behavioral equivalence

  37. Synchronous flow

  38. De-synchronized flow

  39. +

More Related