# **Tutorial Number 7 & 8**

# Routing & Checkers

## **LEARNING OUTCOMES:**

At the end of this lab, participants will be able to:

- 1. How to run routing
- 2. Differentiate between global and detailed routing
- 3. How to tackle routing violations
- 4. Stream out the final GDSII Layout
- 5. How to run magic
- 6. How to view GDS on Klayout
- 7. Check DRC and LVS and Antenna violation error

For this lab we will be exploring the design picorv32a.

**LabTask:** Create a copy of the design picorv32a with your name in the designs directory as follows **picorv32a <your name>**.

#### Step 1:

#### Routing in interactive mode:

- ./flow.tcl -interactive
- prep –design apm <your name> -tag first run
- run synthesis
- run floorplan
- run\_placement
- run cts
- run routing
- write powered verilog followed by set netlist \$::env(lvs result file tag).powered.v
- run magic
- run\_magic\_spice\_export
- run magic drc

- run\_lvs
- run\_antenna\_check

### HomeTasks:

1. Observe the effect of varying GLB\_RT\_ADJUSTMENT parameters on routing violations for picorv32a.

(Vary the value of ::env(GLB\_RT\_ADJUSTMENT) in design config.tcl file)

2. Run the whole flow of any design from synthesis to checkers.