## Fast, Accurate A Priori Routing Delay Estimation

J. Qiu S. Hassoun CS Department Tufts University Medford, MA 02139 S. Reda Division of Engineering Brown University Providence, RI 02912

SLIP'10, Anaheim, CA





#### **Objectives**



[image from wikipedia]

- 1. Detailed routing delay estimation
- 2. Accurate (at least better than delay from placement)
- 3. Fast look-up table based technique
- 4. Implement and verify within an industrial flow

#### Challenges in routing delay estimation



[image from wikipedia]



[image using Brown's FIB facility]

- 1. Metal layer assignment
- 2. Detours due to congestion and blockages
- 3. Cross talk from neighboring wires

#### **Computing wiring delays** sink source sink pin driver wire wire capacitance capacitance resistance resistance fitted Elmore delay [TVLSI Chu04] Hspice × FED SED 1200 delay 900 Delay (ps)

300

3000

6000

9000

Length (um)

12000

15000

18000

How to know the exact R, C, and delay for a routed net given only the placement of its nodes?

#### **Overview of proposed techniques**

- Available information after placement:
  - Net degree
  - Pin locations and capacitances
  - Steiner tree length

"A lack of information cannot be remedied by any mathematical trickery," C. Lanczos 1961.

#### > <u>Approach:</u>

- Build empirical models and look-up tablesto characterize the results of a router on known designs.
- Apply these models to placements of variant or new designs

#### Rationale

- Empirical models quantify common-sense physical design characteristics:
  - Long nets are likely to be routed on top metal layers
  - Nets with larger degrees are likely to encounter more congestion
- Router-specific sorting rules or tie breaking mechanisms lead to systematic routing delay characteristics that can be captured our method
- Some of the popular estimation methods, e.g., RISA (Cheng93) for FLUTE (Chu04) Rectilinear Minimum Steiner Tree are empirical and lookup-table driven.

- 1. Delay Sampling (DS)
  - Motivation: source-sink delays depend quadratically on the pin-pin placement length



 Construct quadratic formulas in the pin-pin length where the coefficients depend on the net degree

## 1. Delay Sampling (DS)



<u>Disadvantage</u>: DS does not differentiate between two wires of the same length belong to nets with the same degree but different Steiner length. empirical formulas



 Steiner-Aware Delay Sampling (SDS) technique improves over Delay Sampling by incorporating a net's total wire length into its post-route pin-to-pin delay estimations.

#### 2. Steiner-Aware Delay Sampling (SDS)

 Using a base design(s), sample the delay for each pin-to-pin wire, group and then average the delays according to net degree, pin-to-pin distance, and the Steiner-tree wirelength.



3. Steiner-Aware RC Sampling (SRCS)



The sink pin capacitance could be an important factor that differentiate wire delays

 To incorporate sink pin capacitance, it is necessary to estimate wire resistance and capacitance separately and then combine appropriate to estimate the wire delay

# 3. Steiner-Aware RC Sampling (SRCS): Table build-up



 Build resistance and capacitance LUTs that are function of net degree and Steiner lengtha

3. SRCS: Table lookup



## 4. Scaled SRCS

Motivation: What happens when a query does not match any of the entries in the LUTs?



adjustment to convert an M1 R & C to the true R & C



#### **Experimental Setup**

- Cadence Encounter v4.1 for placement, routing, and RC extraction
- Industrial 90 nm technology library
- Four benchmarks:

| Circuit        | #nets | #cells | Core area (um²) |
|----------------|-------|--------|-----------------|
| A (des)        | 27478 | 27104  | 285861          |
| B (aes cipher) | 15880 | 15265  | 160769          |
| C (s38417)     | 8558  | 8529   | 69713           |
| D (s13207)     | 2302  | 2240   | 21895           |

estimation error = $|\frac{\text{estimated delay} - \text{routing delay}}{\text{routing delay}}$ 

#### 1. Estimator Stability

- <u>Objective</u>: estimate the stability of our estimators against design variants
- Variants are created by introducing blockages in the metal layers



Post-routing delay (ns) before and after variations

## Stability Comparison of estimation techniques



original variant

- SRCS is best on the original design
- Scaled SCRS is best on the variant with an average estimation error of about 22% from the routing delay
- The relative estimation error of techniques is consistent with their capabilities

#### 2. Estimator Universality



- SRCS and scaled SCRS provide delay estimations with an average error of 31% and 16%
- Design A (biggest design) is best used for LUT buildup

#### Conclusions and future work

#### **Conclusions:**

- Provide a variety of techniques to handle delay estimation.
  Scaled Steiner RC sampling give very good delay estimations (16%) error.
- All techniques are based on lookup tables that are indexed by information available after placement.
- Techniques simple and they work

#### Future Work:

- Estimate the delay of critical paths
- Utilize the results of a fast global router to further improve the delay estimates
- Use in a design house or CAD tool where the LUTs are continuously improved as populated by routing results data

## Thank You for your Attention

## Summary of techniques

#### Inputs need to build LUTs:

|                | net<br>degree | route<br>length | net delay | route steiner<br>tree length | resistance | capacitance |
|----------------|---------------|-----------------|-----------|------------------------------|------------|-------------|
| DS             | X             | x               | x         |                              |            |             |
| SDS            | X             | X               | X         | Х                            |            |             |
| SRCS           | X             |                 |           | Х                            | Х          | Х           |
| Scaled<br>SRCS | X             | X               |           | Х                            | X          | Х           |

#### Inputs need to query LUTs and estimate delay:

|             | net degree | placement length | placement<br>steiner tree<br>length | C_sink |
|-------------|------------|------------------|-------------------------------------|--------|
| DS          | х          | x                |                                     |        |
| SDS         | х          | х                | Х                                   |        |
| SRCS        | Х          | х                | Х                                   | х      |
| Scaled SRCS | Х          | х                | Х                                   | х      |