blob: 86c1f321dfad09c44e7804d21dec9b3913690911 [file] [log] [blame]
# Copyright lowRISC contributors.
# Licensed under the Apache License, Version 2.0, see LICENSE for details.
# SPDX-License-Identifier: Apache-2.0
#
# Simple tcl script for DC to do some wire-load-model-based test syntheses.
#####################
## PREPARE FLOW ##
#####################
# tool setup
set CONFIG_PATH "./"
source ${CONFIG_PATH}/setup.tcl
# if in interactive mode, do not exit at the end of the script
if { [info exists ::env(INTERACTIVE)] } {
set RUN_INTERACTIVE 1
} else {
set RUN_INTERACTIVE 0
}
# path to directory containing the source list file
set SV_FLIST $::env(SV_FLIST)
set BUILD_DIR $::env(BUILD_DIR)
# just compile the "core" toplevel at the moment
# might want to switch to top_earlgrey_asic later on (with pads)
set DUT $::env(DUT)
set CONSTRAINT $::env(CONSTRAINT)
# paths
set WORKLIB "${BUILD_DIR}/WORK"
set REPDIR "${BUILD_DIR}/REPORTS"
set DDCDIR "${BUILD_DIR}/DDC"
set RESULTDIR "${BUILD_DIR}/results"
set VLOGDIR "${BUILD_DIR}/NETLISTS"
exec mkdir -p ${REPDIR} ${DDCDIR} ${VLOGDIR} ${WORKLIB} ${RESULTDIR}
# define work lib path
define_design_lib WORK -path $WORKLIB
#######################
## CONFIGURATIONS ###
#######################
# Define the verification setup file for Formality
set_svf ${RESULTDIR}/${DUT}.svf
# Setup SAIF Name Mapping Database
saif_map -start
###The following variable helps verification when there are differences between DC and FM while inferring logical hierarchies
set_app_var hdlin_enable_hier_map true
#######################
## DESIGN SOURCES ###
#######################
# this PRIM_DEFAULT_IMPL selects the appropriate technology by defining
# PRIM_DEFAULT_IMPL=prim_pkg::Impl<tech identifier>
# PRIM_DEFAULT_IMPL is set inside the library setup script
set DEFINE "PRIM_DEFAULT_IMPL=${PRIM_DEFAULT_IMPL}+${PRIM_STD_CELL_VARIANT}"
# additional parameters
set PARAMS ""
###########################
## ELABORATE DESIGN ##
###########################
# delete previous designs.
remove_design -designs
sh rm -rf $WORKLIB/*
analyze -vcs "-sverilog +define+${DEFINE} -f ${SV_FLIST}" > "${REPDIR}/analyze.rpt"
elaborate ${DUT} -parameters ${PARAMS} > "${REPDIR}/elab.rpt"
link > "${REPDIR}/link.rpt"
check_design > "${REPDIR}/check.rpt"
set_verification_top
write_file -format ddc -hierarchy -output "${DDCDIR}/elab.ddc"
#write_file -format verilog -hierarchy -output "${DDCDIR}/elab.v"
#############################
## CLOCK GATING SETUP ##
#############################
# be more specific if defaults do not suffice
# set_clock_gating_style -num_stages 1 \
# -positive_edge_logic integrated \
# -control_point before \
# -control_signal scan_enable
###########################
## APPLY CONSTRAINTS ##
###########################
source ${CONSTRAINT}
# If hold time should be fixed
# set_fix_hold ${CLK_PIN}
######################
## MAP DESIGN ##
######################
# TODO: we may have to disable a couple of optimizations in order
# to prevent the tool from optimizing away dummy logic or logic from blocks
# that are only half-finished
# preserve hierarchy for reports
compile_ultra -gate_clock -scan -no_autoungroup > "${REPDIR}/compile.rpt"
#################
## REPORTS ##
#################
# write NAND2 equivalent to file for the reporting scripts
sh echo ${NAND2_GATE_EQUIVALENT} > "${REPDIR}/gate_equiv.rpt"
report_clocks > "${REPDIR}/clocks.rpt"
report_clock -groups > "${REPDIR}/clock.groups.rpt"
report_path_group > "${REPDIR}/path_group.rpt"
report_clock_gating -multi_stage -nosplit > "${REPDIR}/clock_gating.rpt"
report_timing -nosplit -slack_lesser_than 0.0 > "${REPDIR}/timing.rpt"
report_area -hier -nosplit > "${REPDIR}/area.rpt"
report_power -hier -nosplit > "${REPDIR}/power.rpt"
report_constraints -all_violators > "${REPDIR}/constraints.rpt"
report_timing -nosplit -nworst 1000 -input -net -trans -cap > "${REPDIR}/timing_long.rpt"
#################
## NETLIST ##
#################
change_names -rules verilog -hierarchy
define_name_rules fixbackslashes -allowed "A-Za-z0-9_" -first_restricted "\\" -remove_chars
change_names -rule fixbackslashes -h
write_file -format ddc -hierarchy -output "${DDCDIR}/mapped.ddc"
write_file -format verilog -hierarchy -output "${VLOGDIR}/mapped.v"
# Write final SDC
write_sdc -nosplit ${RESULTDIR}/${DUT}.final.sdc
# If SAIF is used, write out SAIF name mapping file for PrimeTime-PX
saif_map -type ptpx -write_map ${RESULTDIR}/${DUT}.mapped.SAIF.namemap
# ##############################
# ## INCREMENTAL FLATTENING ##
# ##############################
# compile_ultra -inc
# #################
# ## REPORTS ##
# #################
# report_timing -nosplit -nworst 100 > "${REPDIR}/flat_timing.rpt"
# report_timing -nosplit -nworst 1000 -input -net -trans -cap > "${REPDIR}/flat_timing_long.rpt"
# report_area -hier -nosplit > "${REPDIR}/flat_area.rpt"
# report_power -hier -nosplit > "${REPDIR}/flat_power.rpt"
# report_constraints -all_violators > "${REPDIR}/flat_constraints.rpt"
# #################
# ## NETLIST ##
# #################
# write_file -format ddc -hierarchy -output "${DDCDIR}/flat.ddc"
# write_file -format verilog -hierarchy -output "${VLOGDIR}/flat.v"
if { $RUN_INTERACTIVE == 0 } {
exit
}