```
# DESIGN COMPILER: Logic Synthesis Tool
remove_design -all
# Add search paths for our technology libs.
set search_path "$search_path . ./verilog /w/apps2/public.2/tech/synopsys/32-
28nm/SAED32 EDK/lib/stdcell rvt/db nldm"
set target_library "saed32rvt_ff1p16vn40c.db saed32rvt_ss0p95v125c.db"
set link_library "* saed32rvt_ff1p16vn40c.db saed32rvt_ss0p95v125c.db dw_foundation.sldb"
set synthetic_library "dw_foundation.sldb"
# Define work path (note: The work path must exist, so you need to create a folder WORK first)
define design lib WORK -path ./WORK
set alib_library_analysis_path "./alib-52/"
# Read the gate-level verilog files
analyze -format verilog {alu.v}
set DESIGN NAME alu
elaborate $DESIGN NAME
current_design $DESIGN_NAME
link
set_operating_conditions -min ff1p16vn40c -max ss0p95v125c
# Describe the clock waveform & setup operating conditions
set Tclk 8.0
set TCU 0.1
set IN DEL 0.6
set IN DEL MIN 0.3
set OUT_DEL 0.6
set OUT_DEL_MIN 0.3
set ALL_IN_BUT_CLK [remove_from_collection [all_inputs] "clk_p_i"]
create_clock -name "clk_p_i" -period $Tclk [get_ports "clk_p_i"]
set_fix_hold clk_p_i
set_dont_touch_network [get_clocks "clk_p_i"]
set_clock_uncertainty $TCU [get_clocks "clk_p_i"]
set_input_delay $IN_DEL -clock "clk_p_i" $ALL_IN_BUT_CLK
set_input_delay -min $IN_DEL_MIN -clock "clk_p_i" $ALL_IN_BUT_CLK
set_output_delay $OUT_DEL -clock "clk_p_i" [all_outputs]
set_output_delay -min $OUT_DEL_MIN -clock "clk_p_i" [all_outputs]
set_max_area 0.0
ungroup -flatten -all
uniquify
compile -only_design_rule
compile -map high
compile -boundary_optimization
compile -only_hold_time
report_timing -path full -delay min -max_paths 10 -nworst 2 > Design.holdtiming
report_timing -path full -delay max -max_paths 10 -nworst 2 > Design.setuptiming
report_area -hierarchy > Design.area
```

Technology files:

No not change

Path to project work library:
Same folder ModelSim uses

List all your Verilog files

Analyze -format Verilog {file.v}

Sets design name:

Aka top level Verilog module

PVT conditions:

No not change

Sets interface timing constraints E.g. clock period

Sets the clock net:

Compiler treats the clock path differently from everything else

Design synthesis settings

Reports to generate

report\_power -hier -hier\_level 2 > Design.power report\_resources > Design.resources report\_constraint -verbose > Design.constraint check\_design > Design.check\_design check\_timing > Design.check\_timing

write -hierarchy -format verilog -output \$DESIGN\_NAME.vg write\_sdf -version 1.0 -context verilog \$DESIGN\_NAME.sdf set\_propagated\_clock [all\_clocks] write\_sdc \$DESIGN\_NAME.sdc

Generate synthesized design files

| Version | Changes       | Date       |
|---------|---------------|------------|
| 0.1     | Initial draft | 25/11/2020 |