# **Chapter 2: ASIC Synthesis**

- ASIC Design Flow
- Chip Synthesis Process
- Levels of Synthesis



## **ASIC Design Flow**



#### What is an ASIC?



- An ASIC is an application-specific integrated circuit.
  - Most of ASICs use a library of pre-designed and pre-characterized logic cells. In fact, we could define an ASIC as a design style that uses a cell library rather than in terms of what an ASIC is or what an ASIC does.

## **Types of ASIC**



- Full-Custom : Analog/digital with all customized mask layers and some logic cells.
- Semi-custom :
  - Cell-based all customized mask layers
  - Masked gate array some customized mask layers
- Programmable :
  - Field-programmable gate array (FPGA) no customized mask layers
  - Programmable logic device (PLD) no customized mask layers

#### **Cell-Based Design Flow**

- Spec Development
- HDL (RTL) Coding; Simulation;
- Preliminary Synthesis
- Preliminary Floorplanning; Synthesis
- Design for testability; Test Pattern Generation
- Pre-layout Simulation
- Layout (Floorplanning, Placement, Routing)
- Post-layout Simulation; Static Timing Analysis
- ECO
- Layout Verification
- DRC, ERC, LVS, Antenna, Metal Density

## **Acronyms**



- HDL- Hardware Description Language
- RTL- Register Transfer Level
- ECO Engineering Change Order
- DRC Design Rule Checking
- ERC Electrical Rule Checking
- LVS Layout versus Schematic
- More can be found at :

http://www.ee.pdx.edu/~mperkows/IC\_LAB/glossary.html





- Design entry. Enter the design into an ASIC design system, either using a hardware description language (HDL) or schematic entry.
- Logic synthesis. Use an HDL (VHDL or Verilog) and a logic synthesis tool,e.g. Design Compiler from Synopsys, to produce a netlist —a description of the logic cells and their connections.
- System partitioning. Divide a large system into ASIC-sized pieces.
- Prelayout simulation. Check to see if the design functions correctly.
- 5. Floorplanning. Arrange the blocks of the netlist on the chip.
- 6. Placement. Decide the locations of cells in a block.
- 7. Routing. Make the connections between cells and blocks.
- Extraction. Determine the resistance and capacitance of the interconnect.
- Postlayout simulation. Check to see the design still works with the added loads of the interconnect.
- Steps 1–4 are part of logical design, and steps 5–9 are part of physical design. There is some overlap. For example, system partitioning might be considered as either logical or physical design. To put it another way, when we are performing system partitioning we have to consider both logical and physical factors.



Silicon

## **Logic Design Approaches**



- Capture-and-Simulation
  - Draw gates and flip-flops
  - Debug by simulation
- Describe-and-Synthesis
  - Write Boolean equations, FSM or HDL
  - · Transformation and compilation by synthesizer

#### **Behavioral Level Simulation**



- Purposes
  - Functionality

HDL and simulation language

- Algorithmic Correctness
- Ways to do it
  - System Studio(Synopsys SystemC); MatLab; SDL(Specification and Description Language)
  - C/C++/Java
  - SystemVerilog/Verilog/VHDL
- Drawback No Cycle-Accuracy

#### **RTL-Level Simulation**

- Purposes
  - · Validation model for structural code
  - Full functionality
- Register transfer operations
- Contains complete functional description
- Cycle accurate



### **Logic Synthesis**



- Logic synthesis provides a link between an HDL (Verilog or VHDL) and a netlist
- Synthesis techniques
  - Two-level and multi-level logic minimization
  - FSM encoding
  - A lot of heuristics
- Synthesis tools Design Compiler from Synopsys, BuildGates from Cadence



















