193 lines
9.8 KiB
Tcl
193 lines
9.8 KiB
Tcl
### This is a sample RUN TCL file describing each step of the PaR.
|
|
### We are using RTL Compiler (synthesis) and Encounter (PaR) from the the Cadence Inc.
|
|
### The current technology is XFAB 180nm
|
|
|
|
|
|
|
|
### ================= INITIAL SETTINGS =================
|
|
if {$PaR_INIT eq "TRUE"} {
|
|
set init_pwr_net VDD; # Define supply VDD net
|
|
set init_gnd_net VSS; # Define supply VSS net
|
|
set init_lef_file ${PAR_INIT_LEF_FILESET}; # Physical libraries - LEF fileset from XFAB 180nm
|
|
set init_design_settop 0;
|
|
|
|
set init_verilog ${NETLIST_PATH}/${NETLIST_TOP_NAME}; # SYN netlist file
|
|
set init_mmmc_file ${PAR_MMMC_FILE}; # Techmological file for multi-mode multi-corner PaR
|
|
set init_io_file ${PAR_NETLIST_TOP_PORT_FILE}; # File with location of the TOP level ports on the floorplan
|
|
|
|
init_design
|
|
}
|
|
### ================= END of INITIAL SETTINGS =========
|
|
|
|
|
|
|
|
### ================= FLOORPLANNING ====================
|
|
if {$PaR_FP eq "TRUE"} {
|
|
floorPlan -site core_hd -s "${FLOORPLAN_DIMENSIONS} ${FLOORPLAN_MARGINS}";
|
|
floorPlan -coreMarginsBy die -site core_hd -s "${FLOORPLAN_DIMENSIONS} ${FLOORPLAN_MARGINS}";
|
|
}
|
|
### ================= END of FLOORPLANNING ============
|
|
|
|
|
|
|
|
### ================= POWER DELIVERY SYSTEM ====================
|
|
if {$PaR_PWR eq "TRUE"} {
|
|
#GLOBAL CONNECTIONS
|
|
clearGlobalNets
|
|
globalNetConnect VDD -type pgpin -pin vdd -inst * -module {}
|
|
globalNetConnect VSS -type pgpin -pin gnd -inst * -module {}
|
|
globalNetConnect VDD -type tiehi -pin vdd -inst * -module {}
|
|
globalNetConnect VSS -type tielo -pin gnd -inst * -module {}
|
|
# POWER RING
|
|
addRing -skip_via_on_wire_shape Noshape -skip_via_on_pin Standardcell -stacked_via_top_layer METTPL -type core_rings -jog_distance 3.15 -threshold 3.15 -nets {VDD VSS} -follow core -stacked_via_bottom_layer MET1 -layer {bottom METTP top METTP right METTPL left METTPL} -width 10 -spacing 5 -offset 3.15
|
|
# POWER STRAPS
|
|
addStripe -skip_via_on_wire_shape Noshape -block_ring_top_layer_limit MET3 -max_same_layer_jog_length 6 -padcore_ring_bottom_layer_limit MET1 -set_to_set_distance 85 -skip_via_on_pin Standardcell -stacked_via_top_layer METTPL -padcore_ring_top_layer_limit MET3 -spacing 5 -merge_stripes_value 3.15 -layer METTPL -block_ring_bottom_layer_limit MET1 -width 10 -nets {VSS VDD} -stacked_via_bottom_layer MET1
|
|
# REMOVE UNUNSED
|
|
#selectWire 39.6900 6.5100 59.6900 5073.6900 2 VSS ; #TODO
|
|
#deleteSelectedFromFPlan; #TODO
|
|
#selectWire 64.6900 22.1100 84.6900 5058.0900 2 VDD ; #TODO
|
|
#deleteSelectedFromFPlan; #TODO
|
|
# MAKE A PG CONNECTIONS
|
|
sroute -connect { blockPin padPin padRing corePin floatingStripe } -layerChangeRange { MET1 METTPL } -blockPinTarget { nearestTarget } -padPinPortConnect { allPort oneGeom } -padPinTarget { nearestTarget } -corePinTarget { firstAfterRowEnd } -floatingStripeTarget { blockring padring ring stripe ringpin blockpin followpin } -allowJogging 1 -crossoverViaLayerRange { MET1 METTPL } -allowLayerChange 1 -nets { VDD VSS } -blockPin useLef -targetViaLayerRange { MET1 METTPL }
|
|
editPowerVia -skip_via_on_pin Standardcell -bottom_layer MET1 -add_vias 1 -top_layer METTPL
|
|
|
|
|
|
# AFTER-STAGE STA
|
|
timeDesign -prePlace -idealClock -pathReports -drvReports -slackReports -numPaths 50 -prefix ${NETLIST_TOP_NAME}_FP_PG_SETUP -outDir ${PAR_REPORTS_FOLDER}; # SETUP STA
|
|
}
|
|
### ================= END of POWER DELIVERY SYSTEM ============
|
|
|
|
|
|
|
|
### ================= PLACEMENT ====================
|
|
if {$PaR_PLACE eq "TRUE"} {
|
|
# GENERAL SETTINGS - CPU num etc.
|
|
setMultiCpuUsage -localCpu 8 -cpuPerRemoteHost 1 -remoteHost 0 -keepLicense true
|
|
setDistributeHost -local
|
|
setPlaceMode -fp false
|
|
### PLACE
|
|
placeDesign -inPlaceOpt
|
|
|
|
|
|
# POST-PLACE STA
|
|
timeDesign -preCTS -idealClock -pathReports -drvReports -slackReports -numPaths 50 -prefix ${NETLIST_TOP_NAME}_PLACE_SETUP -outDir ${PAR_REPORTS_FOLDER}; # SETUP STA
|
|
timeDesign -preCTS -hold -idealClock -pathReports -slackReports -numPaths 50 -prefix ${NETLIST_TOP_NAME}_PLACE_HOLD -outDir ${PAR_REPORTS_FOLDER}; # HOLD STA
|
|
|
|
# OPTIMIZATION
|
|
setOptMode -fixCap true -fixTran true -fixFanoutLoad true
|
|
optDesign -preCTS
|
|
|
|
# POST-OPTIMIZATION STA
|
|
timeDesign -preCTS -hold -idealClock -pathReports -slackReports -numPaths 50 -prefix ${NETLIST_TOP_NAME}_PLACE_HOLD_OPT -outDir ${PAR_REPORTS_FOLDER}; # HOLD STA
|
|
}
|
|
### ================= END of PLACEMENT =============
|
|
|
|
|
|
|
|
### ================= CTS ====================
|
|
if {$PaR_CTS eq "TRUE"} {
|
|
# BUFFER SORTING
|
|
createClockTreeSpec -bufferList {BUHDX0 BUHDX1 BUHDX12 BUHDX2 BUHDX3 BUHDX4 BUHDX6 BUHDX8 DLY1HDX0 DLY1HDX1 DLY2HDX0 DLY2HDX1 DLY4HDX0 DLY4HDX1 DLY8HDX0 DLY8HDX1 INHDX0 INHDX1 INHDX12 INHDX2 INHDX3 INHDX4 INHDX6 INHDX8 STEHDX0 STEHDX1 STEHDX2 STEHDX4} -file Clock.ctstch
|
|
# CTS
|
|
setCTSMode -engine ck
|
|
clockDesign -specFile Clock.ctstch -outDir ${PAR_REPORTS_FOLDER} -fixedInstBeforeCTS
|
|
# POST-CTS STA
|
|
timeDesign -postCTS -pathReports -drvReports -slackReports -numPaths 50 -prefix ${NETLIST_TOP_NAME}_CTS_SETUP -outDir ${PAR_REPORTS_FOLDER}; # SETUP STA
|
|
timeDesign -postCTS -hold -pathReports -slackReports -numPaths 50 -prefix ${NETLIST_TOP_NAME}_CTS_HOLD -outDir ${PAR_REPORTS_FOLDER}; # HOLD STA
|
|
|
|
### OPTIMIZATION
|
|
setOptMode -fixCap true -fixTran true -fixFanoutLoad true
|
|
optDesign -postCTS
|
|
optDesign -postCTS -hold
|
|
# POST-OPT STA
|
|
timeDesign -postCTS -hold -pathReports -slackReports -numPaths 50 -prefix ${NETLIST_TOP_NAME}_CTS_HOLD_OPT -outDir ${PAR_REPORTS_FOLDER}; # HOLD STA
|
|
|
|
# INCREMENTAL OPT
|
|
optDesign -postCTS -hold -incr
|
|
# POST-INCR STA
|
|
timeDesign -postCTS -hold -pathReports -slackReports -numPaths 50 -prefix ${NETLIST_TOP_NAME}_CTS_HOLD_INCR_OPT -outDir ${PAR_REPORTS_FOLDER}; # HOLD STA
|
|
}
|
|
### ================= END of CTS =============
|
|
|
|
|
|
|
|
### ================= ROUTE ====================
|
|
if {$PaR_ROUTE eq "TRUE"} {
|
|
# GENERAL SETTINGS
|
|
setNanoRouteMode -quiet -timingEngine {}
|
|
setNanoRouteMode -quiet -routeWithSiPostRouteFix 0
|
|
setNanoRouteMode -quiet -routeTopRoutingLayer default
|
|
setNanoRouteMode -quiet -routeBottomRoutingLayer default
|
|
setNanoRouteMode -quiet -drouteEndIteration default
|
|
setNanoRouteMode -quiet -routeWithTimingDriven false
|
|
setNanoRouteMode -quiet -routeWithSiDriven false
|
|
# ANTENNA VILOATION FIX - BRIDGE
|
|
setNanoRouteMode -quiet -drouteFixAntenna true
|
|
# ANTENNA VILOATION FIX - DIODES
|
|
setNanoRouteMode -quiet -routeInsertAntennaDiode true
|
|
|
|
# ROUTE
|
|
routeDesign -globalDetail
|
|
|
|
# POST-ROUTE STA
|
|
setAnalysisMode -analysisType onChipVariation -skew true -clockPropagation sdcControl
|
|
timeDesign -postRoute -pathReports -drvReports -slackReports -numPaths 50 -prefix ${NETLIST_TOP_NAME}_ROUTE_SETUP -outDir ${PAR_REPORTS_FOLDER}; # SETUP STA
|
|
timeDesign -postRoute -hold -pathReports -slackReports -numPaths 50 -prefix ${NETLIST_TOP_NAME}_ROUTE_HOLD -outDir ${PAR_REPORTS_FOLDER}; # HOLD STA
|
|
|
|
# OPTIMIZATION
|
|
setOptMode -fixCap true -fixTran true -fixFanoutLoad true
|
|
optDesign -postRoute
|
|
optDesign -postRoute -hold
|
|
# POST-OPT STA
|
|
timeDesign -postRoute -hold -pathReports -slackReports -numPaths 50 -prefix ${NETLIST_TOP_NAME}_ROUTE_HOLD_OPT -outDir ${PAR_REPORTS_FOLDER}; # HOLD STA
|
|
|
|
# INCREMENTAL OPT
|
|
optDesign -postRoute -incr
|
|
optDesign -postRoute -hold -incr
|
|
# POST-INCR STA
|
|
timeDesign -postRoute -hold -pathReports -slackReports -numPaths 50 -prefix ${NETLIST_TOP_NAME}_ROUTE_HOLD_INCR_OPT -outDir ${PAR_REPORTS_FOLDER}; # HOLD STA
|
|
}
|
|
### ================= END of ROUTE ====================
|
|
|
|
|
|
|
|
### ================= FINALIZATION ====================
|
|
if {$PaR_FINAL eq "TRUE"} {
|
|
# FILLER CELLS
|
|
getFillerMode -quiet
|
|
addFiller -cell FEED7HD FEED5HD FEED3HD FEED2HD FEED25HD FEED1HD FEED15HD FEED10HD -prefix FILLER
|
|
|
|
# CHECK SIMPLE DRC
|
|
setVerifyGeometryMode -area { 0 0 0 0 } -minWidth true -minSpacing true -minArea true -sameNet true -short true -overlap true -offRGrid false -offMGrid true -mergedMGridCheck true -minHole true -implantCheck true -minimumCut true -minStep true -viaEnclosure true -antenna false -insuffMetalOverlap true -pinInBlkg true -diffCellViol false -sameCellViol true -padFillerCellsOverlap false -routingBlkgPinOverlap false -routingCellBlkgOverlap false -regRoutingOnly false -stackedViasOnRegNet false -wireExt true -useNonDefaultSpacing false -maxWidth true -maxNonPrefLength -1 -error 1000
|
|
verifyGeometry -report ${PAR_REPORTS_FOLDER}/${NETLIST_TOP_NAME}_GEOMETRY.rpt
|
|
setVerifyGeometryMode -area { 0 0 0 0 }
|
|
verify_drc -report ${PAR_REPORTS_FOLDER}/${NETLIST_TOP_NAME}_DRC.rpt -limit 1000
|
|
verifyConnectivity -type all -error 1000 -warning 50 -report ${PAR_REPORTS_FOLDER}/${NETLIST_TOP_NAME}_CONNECTIVITY.rpt
|
|
|
|
# EXTRACT RC
|
|
setExtractRCMode -engine postRoute -effortLevel signoff
|
|
extractRC
|
|
}
|
|
### ================= END of FINALIZATION ====================
|
|
|
|
|
|
|
|
### ================= OUTPUT ====================
|
|
if {$PaR_OUT eq "TRUE"} {
|
|
# STA
|
|
timeDesign -signoff -pathReports -drvReports -slackReports -numPaths 50 -prefix ${NETLIST_TOP_NAME}_SIGNOFF_SETUP -outDir ${PAR_REPORTS_FOLDER}; # "-signoff" SETUP STA
|
|
timeDesign -signoff -hold -pathReports -slackReports -numPaths 50 -prefix ${NETLIST_TOP_NAME}_SIGNOFF_HOLD -outDir ${PAR_REPORTS_FOLDER}; # "-signoff" HOLD STA
|
|
|
|
all_hold_analysis_views
|
|
all_setup_analysis_views
|
|
|
|
# Drop file extenstion
|
|
set FILENAME [string trimright ${NETLIST_TOP_NAME} .v]
|
|
|
|
# EXPORT RESULTS of the PaR stage
|
|
write_sdf -view TYPview ${PAR_RESULTS_FOLDER}/${FILENAME}.sdf
|
|
saveNetlist ${PAR_RESULTS_FOLDER}/${FILENAME}.v -includePhysicalCell {FEED7HD FEED10HD FEED15HD FEED1HD FEED25HD FEED2HD FEED3HD FEED5HD}
|
|
defOut -floorplan -netlist -routing ${PAR_RESULTS_FOLDER}/${FILENAME}.def
|
|
}
|
|
### ================= END of OUTPUT ====================
|