Electronic Design Automation (EDA) tool development: Performance enhancements to circuit extraction

Rithvik Bhogavilli January 10, 2021

Mr. R. Tim Edwards

# Background

- Very Large Scale Integration (VLSI) Layout Tool
- Open source
  - Used by universities and open source developers
- Composed of design viewer and console



| tkcon 2.3 Main                                                                                                                                                                                                                                                                                                                | 2            |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|
| <u>F</u> ile <u>C</u> onsole <u>E</u> dit <u>I</u> nterp <u>P</u> refs <u>H</u> istory                                                                                                                                                                                                                                        | <u>H</u> elp |
| microns: 0.09 x 0.09 (0.00, 0.00), (0.09, 0.09) 0.01   lambda: 1 x 1 (0, 0), (1, 1) 1   Main console display active (Tcl8.4.8 / Tk8.4.8) adc_allring: 10000 rects   adc_allring: 20000 rects adc_allring: 30000 rects   adc_allring: 30000 rects adc_allring: 50000 rects   adc_allring: 50000 rects adc_allring: 50000 rects |              |
| adc_aliing: Duou Fects<br>adc_aliing: TOBOD Fects<br>adc_aliing: BODOD Fects<br>dc_aliing: BODOD Fects<br>Status and Status and Status and Status<br>add Status and Status and Status and Status<br>Processing timestamp mismatches: bump_bond_pur.                                                                           | -            |

#### Caesar or KIC2:

- Minimal support in routing features
- Hard to change a design once loaded

Magic:

- Increased design knowledge
- Easier to modify designs

#### Issues

- Magic is built for smaller designs
  - Moore's Law
- Labels
  - Store information on their associated cell
  - Must be referenced by name or location
- Labels are stored in a linked list



### **Linked Lists**

- Each node keeps reference to next
- Time complexity:
  - Search:  $\mathcal{O}(n)$
  - Insertion:  $\mathcal{O}(1)$
  - Deletion:  $\mathcal{O}(n)$



# Solution

### Hash Table

- Hash algorithm sorts items by index
  - Collisions resolved through chaining
- Time complexity:
  - Search: *O*(1)
  - Insertion:  $\mathcal{O}(1)$
  - Deletion:  $\mathcal{O}(1)$



### Binned Plane (bplane)

- 2D hash table
- Cells track information about labels in the region
- Labels have near equal size and spatial distribution



## Methods

- Linux Perf tool used
  - Sampling rate of 100 per second
  - Generates time spent per function
- Flame graph generated
  - Gives proportion of time spent on given function

|        | Extraction Baseline                                  | Search | ic |
|--------|------------------------------------------------------|--------|----|
|        |                                                      |        |    |
|        | sotHis.<br>SetHis/Conset/Funct<br>DSSrPanitAres      |        |    |
|        | ExtFreeLabRegions ExtLabelRegions extHierConnections |        |    |
|        | extSubtreeFunc                                       |        |    |
| 0      | IbCellSrFunc                                         |        |    |
|        | JBSTCellPlaneArea                                    |        |    |
|        | JBCellSrArea                                         |        |    |
| e      | XCSubtreeinteraction                                 |        |    |
| e      | (Subtree                                             |        |    |
| e      |                                                      |        |    |
|        | KLCEI                                                |        |    |
| e)     |                                                      |        |    |
|        | KUAII<br>wa di sukasat                               |        |    |
|        | IndExecute                                           |        |    |
|        | Recompande                                           |        |    |
|        | United Send Command                                  |        |    |
|        | TriDisnatch                                          |        |    |
|        | in dispatch                                          |        |    |
| Т      | InvokeStringCommand                                  | -      |    |
| - Du   | inknown)                                             |        |    |
| [ [uni | known                                                |        |    |
| magicd | Inull É                                              |        |    |
| _      |                                                      |        |    |
|        |                                                      |        |    |

- 1. striVe chip loaded into Magic
- 2. Command of interest is run
- 3. Performance measured at 100 samples per second
- 4. Magic is recompiled with optimizations
- 5. Performance measured at 100 samples per second
- 6. Flame graph generated for analysis

Based on previous experience in loading large designs Chosen Areas:

- Extraction
- Net Selection
- Label Search by Content

## Areas of Optimization

- extract all command extracts into .ext file
- Functions were found to be searching all labels
- plane added to CellDef
  - Properties for the cell, includes label storage
- extSubtreeFunc and extHierConnections found to be of concern

- select clear used to analyze
- DBTreeSrLabels found to take most time
- TF\_LABEL\_ATTACH and TF\_LABEL\_DISPLAY flags for labels
  - Requires use of bplane and linked list

- select short command used for profiling
  - Used because it relies on label names
- Hash table added to CellDef
- Hash table iteration implemented in DBCheckLabelsByContent

## Results

#### Extraction



### Extraction



### **Net Selection**



### **Net Selection**



- Perf did not detect content searching function
  - Sampling rate of 30,000 samples per second
- Confirmed to run using gdb
- Original complexity was  $\mathcal{O}(n)$ 
  - Likely to not detect \$\mathcal{O}(1)\$

### Conclusions

- General decrease in time spent on functions
- Added overhead in extraction
  - Added class initialization for bplane
- Net selection may not have been fully tested with striVe

- Use a wider variety of chips
  - Designs used might not test all cases
- Improve profiling
  - Profiling is manually stopped

Thank you to Mr. Edwards for pointing me in the right direction for optimizations and providing feedback.

Thank you to my teachers and friends.

