KEMBAR78
Physical Design For Block Level Implementation: Project Report | PDF | Electronic Engineering | Electronics
0% found this document useful (0 votes)
699 views20 pages

Physical Design For Block Level Implementation: Project Report

The document is a project report for physical design and block level implementation of an integrated circuit. It discusses implementing the layout from a given netlist to meet timing constraints without violations while ensuring a design rule check free layout. The report outlines the automatic place and route flow involving steps like floorplanning, placement, routing, timing analysis and layout verification using Cadence tools like Encounter and Caliber. The goal is to complete all physical design steps and fix any timing or design rule violations.
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
0% found this document useful (0 votes)
699 views20 pages

Physical Design For Block Level Implementation: Project Report

The document is a project report for physical design and block level implementation of an integrated circuit. It discusses implementing the layout from a given netlist to meet timing constraints without violations while ensuring a design rule check free layout. The report outlines the automatic place and route flow involving steps like floorplanning, placement, routing, timing analysis and layout verification using Cadence tools like Encounter and Caliber. The goal is to complete all physical design steps and fix any timing or design rule violations.
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
You are on page 1/ 20

Project report

on

Physical Design for Block level implementation

Inernal Guide:
Kalplana Bhat.G

By
B.Hema Naga Babu(14VL06F)

Industrial Guide:
Ramanathan Sornavalli

DEPARTMENT OF
ELECTRONICS AND COMMUNICATIONS
NATIONAL INSTITUTE OF TECHNOLOGY KARNATAKA
SURATHKAL

OVERVIEW
The purpose of this project is to implement the layout of an integrated circuit
for a given netlist and also to improve the efficiency of the ASIC design flow
with emphasis on APR timing closure.We will do all the physical design steps
on the given netlist to meet all timing constraints and DRC free design.After
completion of all designing steps we will fix the violations like setup, max transition, max fan out, max capacitance and at any cost hold violations should be
zero. In addition we will do design as DRC free.

Introduction
Advances in semiconductor technology and in the integration level of integrated circuits have enhanced many features,increased the performance improved reliability of electronic equipment,and at the same time reduced the
cost,power consumption and system size.As size and complexity of digital system has increased,more computer aided design tools are introduced into hardware design processes. Here mainly we are doing 3 steps 1. APR (Automatic
Place and Route). 2. STA (Static Timing Analysis). 3. LV (Layout Verification). For APR we are using a cadence tool known as EDI (Encounter Digital
Interface) And for STA we are using a cadence tool known as TEMPUS. For
LV checks we are using a tool known as CALIBER.
In APR flow we will use all steps and we will analyse timing analysis. Timing
violation should be as less as possible in EDI.If it is giving violation with most
slack then change floorplan and we will try again to get less violating paths.
In Tempus we will do static timing analysis.This is the tool used for signoff
on the timing.If it is showing violated paths to zero we can close block even we
have violated paths in EDI.
By using caliber we will analyse Design Rule Checks.To manufacture the chip
these DRC errors should be zero,so we will make design as aDRC free.

Department of ECE , NITK

APR FLOW
In this APR (Automatic Place and Route) we will design physical layout for
the given netlist through following steps.
Import design
Floorplan
Placement
Pre CTS
CTS
PostCTS
Post CTS hold
Route
PostRoute
Post Route hold
Signoff

Department of ECE , NITK

IMPORT DESIGN
This is the first step of the flow that initializes the design. From thedesign
input input it will read netlist, constraints, library setup (pvts, corners, views
etc) and we will give block setup file. IN the netlist we will get all the information
of the design. In the constraints we can find all the information regarding clocks
like time periods , delay max fall, delay max rise, delay min rise ,delay min fall
,type of clocks (generated or propagated) ,max capacitance,max transition.
In library setup we will give which library cells we should use and all the PVT
corners list.
Process : either slow or fast.
Voltage : low voltage corner or high voltage corner
Temperature : depends on application we will mention temperature generally
these will be -40 and 110 .
Ex: max psss 0.94v -40C SISF.
sss represent slow corner. If it is fff it is fast corner.
0.94 is the voltage we are using in this corner.
-40C is the temperature we are using in this corner.
In SISF last two letters represent resistance and capacitance respectively. If it
is S then slow and F is fast so in this example resistance is slow and capacitance
is fast.
In block setup file we will mention which type of cells we should use for clock
cells and standard cells. Like ln, nn, wn, yn These four cells having different
drive strength according to our requirement we will choose cell type. Yn cells
are having more drive strength or less delay followed by wn, nn and ln.In this
block setup we will mention the type Vt cells we wnt
LVT : lower vt cells.

Department of ECE , NITK

SVT : standard vt cells.


HVT : high vt cells.
After invoking Encounter the first step is import design so it will read netlist,constraints
and libray setup.
encounter: runADF start import design stop import design.
The above command will run the entire import design step and the output
we can see in GUI by giving command as given below
Encounter:win
Here we can see all cells will be placed at the origin and no cells will be
present in the core area. The pictorial representation of GUI after import design
shown below.

Fig1:GUI after import design

Department of ECE , NITK

FLOORPLAN
Floorplanning a chip or block is an important task of physical design in which
the location, Size, and shape of soft modules, and the placement of hard macros
are decided. Depending On the design style or purpose, floorplanning can also
include row creation, I/O pad or pin Placement, bump assignment (flip chip),
power planning, and more. Floor planning control parameters like aspect ratio,
core utilization are defined as follows:
Aspect Ratio= Horizontal Routing Resources / Vertical Routing Resources
Core Utilization= Standard Cell Area / (Row Area + Channel Area)
Floorplanning is the process of identifying structures that should be placed
close together, and allocating space for them in such a manner as to meet the
sometimes conflicting goals of available space (cost of the chip), required performance, and the desire to have everything close to everything else.Floorplanning
is very important when preparing the design for timing closure and Detailed
routing. Floorplanning, in conjunction with placement and trial routing, can
be an Iterative design process.Based on the area of the design and the hierarchy, a suitable floorplan is decided upon. Floorplanning takes into account the
macros used in the design, memory, other IP cores and their placement needs,
the routing possibilities and also the area of the entire design. Floorplanning
also decides the IO structure, aspect ratio of the design. A bad floorplan will
lead to waste-age of die area and routing congestion.
In many design methodologies, Area and Speed are considered to be things
that should be traded off against each other. The reason this is so is probably because there are limited routing resources, and the more routing resources
that are used, the slower the design will operate. Optimizing for minimum
area allows the design to use fewer resources, but also allows the sections of
the design to be closer together. This leads to shorter interconnect distances,
less routing resources to be used, faster end-to-end signal paths, and even faster

Department of ECE , NITK

and more consistent place and route times. Done correctly, there are no negatives to floorplanning.There are commands for creating an initial floorplan
automatically, or, resize a finished floorplan while keeping relative placement
of objects.Floorplanning usually starts by preplacing blocks, modules, and submodules according to the prepared floorplan. All other modules or blocks not
in the prepared floorplan are left outside the chip area. the following steps are
main in floorplan :
initial floorplan
Creating row sites
Adding halo cells
Blockages
Pg insertion
I/O placement
Adding fiducials
Adding spare cells

Initial Floorplan
Macros are the preplaced cells which we will place before placement. These
macros have some Pre-defined functionality. Generally these macros will be
memories ,PLL,muxes and IPs. Generally these macros will connected to PDE(Programmable
Delay Elements). With the given input Encounter will try to find efficient and
random macro and PDE placement.First all macros will be placed in the die
area and all the PDEs related to that macro will be placed near to that macro.
For better timing we should change the place of PDEs .The PDE of q msb
should place near to msb q pin of macro and lasb q pin shold be near to lsb q
pin of macro.In the same way we need to place msb and lsb pins of PDE and
macro should be as near as possible this will reduce the net delay and increase
the timing efficiency.
7

Department of ECE , NITK

Creatini Row Sites


IN this step we will create row site for entire core area. This row site will be
used in placement for placing the standard cells. All the standard cells should be
placed in between these rows only. Mainly we have two types of cells regarding
this row these are small cells and tall cells Small cells will take only one row
where as tall cells will take more than one row. These rows will be created with
same Width.

Adding Halo Cells


Halo is the region around the boundary of fixed macro in the design in which no
other macro or standard cells can be placed. Halo allows placement of buffers
and inverters in its area.These halo cells mainly used to avoid DRC errors every
macro has halo cell of width half DRC as boundary so even two macros are
placed near we can maintain distance of DRC.Halos of two adjacent macros can
be overlap. If macro are moved from one place to another place, halos will also
be moved. But in case of blockages if the macros are moved from one place to
another place the blockages cant be moved.

Blockages
Blockages are specified locations where placing cells are prevented or blocked.
These act as guidelines for placing standard cells and macros in the design.
Blockages will not be guiding the placement tool to place standard cell at some
particular area, but it wont allow placement tool to place standard cell at
specified locations. This way blockages are act as guidelines to placement tool.
There are mainly two types of blockages,
Soft (Non-buffer) blockage: Soft blockage specifies a region where only buffer
can be placed. That means standard cells cannot be placed in this region. It

Department of ECE , NITK

blocks (prevents) the placement tool from placing non-buffer cells such as std.
cell in this region.
Hard blockage: Hard blockage specifies a region where all standard cells and
buffers cannot be placed. It prevents the placement tool from placing standard
cells and buffers in this region. Hard blockage are mostly used to Block standard
cells to certain regions in the design Avoid routing congestion at macro canners
Control power rail generations at macro cores.
Partial blockage: The blockage factor for any blockage is 100 percent by default.
So no cells can be placed in that region, but the flexibility of blockages can be
chosen by partial blockages.
Placement blockage: Placement blockage prevent the placement tool from placing cells at specified regions. Placement blockages are created at floor planning stage.Placement blockage are used to Define standard cells and macro
area,Reserve channels for buffer insertion,Prevent cells from being placed nearer
to macros, Prevent congestion near macros.
Routing blockage: Routing blockages block routing resources on one or more
layers. It can be created at any point in the design.

PG insertion
In this step we will create power grid. IT will create one vdd and one vss for
each and every row so that we can get power and ground connection to every
standard cell. For this Power grid we will use layers from tm1 to m2 and all
layers will internally connect to its previous layer by via .Generally for vdd and
vss we will use higher layers because it will have less resistance and we will get
less delay. All remaining layers will connect to each other and we will connect
to standard cells as per requirement. All odd number of layers will be placed
vertically and all even layers will be placed horizontally. The layers which will
be using for pg was different from the routing layers. Each and every layer

Department of ECE , NITK

have different widths and higher layers have higher widths so that we have less
resistance and delay.

I/O placement
In this input and output pins will be placed. Initially tool will place this I/O
placement randomly. If we are doing design for timing critical blocks it is better
to place pins which is connected to macro should place near to that macro,
because of this wire delay and total delay will decrease.

Adding Fiducial Cells


These are the special type of physical cells which will be used in the design.
We will place these fiducial cells at particular places in the design to know the
orientation of the chip at that place. So we dont have these cells in all blocks
where ever we require these cells we will place in that blocks only.

Adding Spare Cells


Spare cells are just that they are extra cells placed in your layout in anticipation
of a future ECO. When I say future, after you taped out and got your silicon
back. After silicon tests complete, it might become necessary to have some
changes to the design. There might be a bug, or a very easy feature that will
make the chip more valuable. This is where you try to use the existing spare
cells in your design to incorporate the design change. For example, if you need
a logic change that requires addition of an AND cell, you can use an existing
spare AND to make this change. This way, you are ensuring that the base layer
masks need no regeneration. The metal connections have changed, and hence
only metal masks are regenerated for the next fabrication.

10

Department of ECE , NITK

The designer adds separate modules with the required cells. You start your
PnR with spare cells included, and must make sure that the tool hasnt optimized
them away. There can be more than one such spare modules, and they will be
typically named spare or some such combination. You need to give some thought
as to where to place your spare cells in layout. They are not timing critical, and if
you do not give any constraints, PnR tool will place them all together. However,
you do not know which area of the layout will eventually require a connection
to the spares. You can have two placement approaches.Sprinkle the individual
spare cells in your layout, so from any point you may have a reasonably close
library cell.Group the spare cells in multiple groups and sprinkle/place each
group in the layout.If the spare cells are included in the netlist, you need to set
an attribute spare cell so that the PnR tool does no optimize these. If you do
not set them as spare cells set a dont touch, you will find that after placement
all spare cells are gone. There are two types of spare cells
Combinational: They are generally added by PNR tools and can be added using
scripts in the floorplan or placement stages.
Sequential: They are generally added in the RTL itself so that they can be
stitched in the scan chain for testability purpose The pictorial representation of
GUI after import design shown below.

Fig2:GUI after floorplan

11

Department of ECE , NITK

PLACEMENT
This placement step is to place standard cells in core area. This step will do
placement of standard cells according to logic. This placement mainly depend
on 3 factors of design
1. Timing critical
2. Area critical
3. Power critical
Timing critical: In this it will try to place all standard cells as close as possible
according to netlist, because to get less net delay and total delay. At the same
time it will check for congestion according to what we mentioned.
Area Critical: In this it will mainly concentrate on area it will try to place cells
as close as possible without checking for timing. So we can achieve less area by
compromising on timing and power.
Power Critical: In this it will place cells around the core area to get less power.
Here it should not place as close as possible. It dont check for area or timing
violations.
In this step we will decide which type of cells we should use. We have
ln,nn,wn,yn type of cells as standard cells where yn is having higher drive
strength and less delay followed by wn ,nn and ln so we will use these cells
according to our requirement.We have different types of vt cells like LVT, SVT,
HVT.Where LVT cells are the low vt cells ,SVT cells are standard vt and HVT
cells are the high vt cells . According to our requirements we will choose these
cells.

Adding TIE cells


Tie-high and Tie-Low cells are used to connect the gate of the transistor to
either power or ground. In Lower technology nodes, if the gate is connected

12

Department of ECE , NITK

to power/ground the transistor might be turned on/off due to power or ground


bounce these cells are part of standard-cell library the cells which require Vdd
(Typically constant signals tied to 1) connect to Tie high cells. The cells which
require Vss/Gnd (Typically constant signals tied to 0) connect to Tie Low cells
Tie-high and tie-lo cells are used to avoid direct gate connection to the power or
ground network. In your design, some cell inputs may require a logic0 or logic1
value. The spare cell inputs are also connected to ground or power nets, as you
cannot leave them unconnected. Instead of connecting these to the VDD/VSS
rails/rings, you connect them to special cells available in your library called TIE
cells.(Note: All libraries may not have them). We require these cells because
Gate oxide is thin and sensitive to voltage surges. Some processes does not
let you connect the gates directly to power rails since any surge in voltage,
like an ESD event, can damage the gate oxide. Hence tie cells, which are
diode connected n-type or p-type devices are used instead. The gates wont
be connected to either power or ground directly.After this placement step we
should concentrate on Congestion .This congestion should be less than 0.01. If
it is more than this we should do floorplan again with placing macros at other
positions. The pictorial representation of placement shown in below.

Fig2:placement with standard cells

13

Department of ECE , NITK

PRECTS
This is the step where it will optimize the placement step. It will delete or add
buffers or replace buffers. In other words here we will do refine place.

CTS
After CTS step hold slack should improve. Clock tree begins at sdc file defined clock source and ends at stop pins of flop. There are two types of stop
pins known as ignore pins and sync pins. Dont touch circuits and pins in front
end (logic synthesis) are treated as ignore circuits or pins at back end (physical synthesis). Ignore pins are ignored for timing analysis. If clock is divided
then separate skew analysis is necessary. Global skew achieves zero skew between two synchronous pins without considering logic relationship. Local skew
achieves zero skew between two synchronous pins while considering logic relationship. If clock is skewed intentionally to improve setup slack then it is known
as useful skew. We have different types of methods to build CTS. All are mainly
concentrated to minimize skew.
H-Model: In this we will generate clock tree in a H shape tree as shown in
below figure.Here skew will be zero because all clocks will reach all flops at a
time.clock can be shielded so that noise is not coupled to other signals. But
shielding increases area by 12 to 15 percent. Since the clock signal is global in
nature the same metal layer used for power routing is used for clock also. CTO
is achieved by buffer sizing, gate sizing, buffer relocation, level adjustment and
HFN synthesis. We try to improve setup slack in pre-placement, in placement
and post placement optimization before CTS stages while neglecting hold slack.
In post placement optimization after CTS hold slack is improved. As a result of
CTS lot of buffers are added. Generally for 100k gates around 650 buffers are
added.The goal of clock tree synthesis (CTS) is to minimize skew and insertion
delay. Clock is not propagated before CTS as shown in the picture. After CTS

14

Department of ECE , NITK

hold slack should improve. Clock tree begins at .sdc defined clock source and
ends at stop pins of flop. There are two types of stop pins known as ignore pins
and sync pins. Dont touch circuits and pins in front end (logic synthesis) are
treated as ignore circuits or pins at back end (physical synthesis). Ignore pins
are ignored for timing analysis. If clock is divided then separate skew analysis
is necessary.

Fig3:H-tree type of CTS

POST CTS
In this step it will do all necessary steps to minimize the setup slack of the
design.It will achieve this by replacing cells which are taking more delay with
lesser delay cells. There are some buffers are not needed in some paths those
will be deleted by tool at this stage.

15

Department of ECE , NITK

POST CTS HOLD


In this step it will do optimization on the hold without effect the setup. To
avoid hold the best way is to place buffers in the data path so it will try to find
where it is suitable to place buffers without effect the setup. In this step Filler
cells will be added to fill the remaining area in the chip.

Adding Filler cells


Filler cells are used to establish the continuity of the N- well and the implant
layers on the standard cell rows. This is one of the Fab constraints, for ease in
the generation of the masks. Filling 100 percent of the area with regular cells
is generally impossible. We need spaces to improve the placement and routing.
Once we complete the routing achieve the timing closure, we may need to fill the
empty spaces with filler cells.They are inserted into the flow after your timing,
placement opt and DRC cleanup.
They are inserted to meet your utilization targets so as to avoid sagging of
layers after fab and to ensure n-well continuity.Once the placement is done (after
meeting timing in P and R)you need to run command to add filler cells and
tool will automatically add filler cells where ever there is empty space between
standard cells As you ask the SoC-encounter tool to place the filler cells, it fills
the gaps in the design in std cell rows with different variety of filler cells as per the
gaps availabilty, however there will be overlaps, you can delete the overlapping
ones.Basically filler cells will make power/ground and nwell continuity.There
will be power/ground open between the standard cells(empty space) and also
may be nwell spacing DRC error.Filler Cells dont have functionality. They
have power rails, Nwell, PPlus and NPlus layers only. If we want to do any
Engineering Change Order (ECO)s, then the filler cells can be deleted and the
empty spaces can be utilized.They can also be used to cope with setup or hold
violations.
16

Department of ECE , NITK

ROUTE
In this step routing are logical connection happen.so all the cells will be connected logically according to the netlist. There are two types of routing in the
physical design process, global routing and detailed routing. Global routing allocates routing resources that are used for connections. Detailed routing assigns
routes to specific metal layers and routing tracks within the global routing resources. Routing is the process of creating physical connections based on logical
connectivity. Signal pins are connected by routing metal interconnects. Routed
metal paths must meet timing, clock skew, max trans/cap requirements and
also physical DRC requirements. In grid based routing system each metal layer
has its own tracks and preferred routing direction which are defined in a unified
cell in the standard cell library. There are four steps of routing operations:
1. Global routing
2. Track assignment
3. Detail routing
4. Search and repair
Global Route:It assigns nets to specific metal layers and global routing cells.
Global route tries to avoid congested global cells while minimizing detours.
Global route also avoids pre-routed P/G, placement blockages and routing
blockages.
Track Assignment (TA): it assigns each net to a specific track and actual metal
traces are laid down by it. It tries to make long, straight traces to avoid the
number of vias. DRC is not followed in TA stage. TA operates on the entire
design at once.
Detail Routing:It tries to fix all DRC violations after track assignment using a
fixed size small area known as SBox. Detail route traverses the whole design
box by box until entire routing pass is complete.

17

Department of ECE , NITK

Search and Repair:It fixes remaining DRC violations through multiple iterative
loops using progressively larger SBox sizes.

POST ROUTE
IN this step it will do all necessary steps to minimize the setup slack of the
design. It will achieve this by replacing cells which are taking more delay with
lesser delay cells. There are some buffers are not needed in some paths those
will be deleted by tool at this stage. This step is replica of post cts but before
this we have to remove all filler cells in the design to do optimization.

POST ROUTE HOLD


In this step it will do optimization on the hold without effect the setup. To
avoid hold the best way is to place buffers in the data path so it will try to find
where it is suitable to place buffers without effect the setup. This is replica of
post ct hold. After this optimization again we have to fill the entire chip with
filler cells.

SIGNOFF
In this step metal Fill will happen. And in the output folder it will generate a
Verilog file this Verilog should be same as the netlist Verilog file. If it changed
then our design was not correct and we have to check again where we did
mistake.

18

Department of ECE , NITK

CONCLUSION
This entire APR flow is the key to meet the desired frequency.Generating good
floorplan is the biggest task in this APR flow once we design good floorplan
it is easy to get desired frequency.This finding best floorplan is the iterative
process.This is the step wher we will take cre of placcing macros and PDE
which we will use frequently. After this APR flow we should make this design
as DRC free and frequency met design in signoff tooll like tempus.

REFERENCES
1. Encounter user guide.

2. Encounter user manual.

3. www.wikipedia.org

19

Department of ECE , NITK

You might also like