The objective is to take a simple counter design from the RTL (Register Transfer Level) stage to the GDSII format using Cadence tools with a 90nm Process Design Kit (PDK). The tools used in this process include Xcelium for simulation and coverage analysis, Genus for synthesis, Innovus for physical design, and Pegasus/PVS for physical verification.
Verilog code for the counter module
`timescale 1ns/1ns
module counter(clk,m,rst,count);
input clk,m,rst;
output reg[7:0]count;
always@(posedge clk or negedge rst)
begin
if(!rst)
count=0;
else if(m)
count = count+1;
else
count = count-1;
end
endmodule
Testbench code for the counter module
`timescale 1ns/1ns
module counter_test;
reg clk,rst,m;
wire[7:0]count;
initial
begin
clk=0; rst=0;
#5; rst=1;
end
initial
begin
m=1;
#160; m=0; //till #160ns - up_counter after it will be down_counter
end
counter counter1(clk,m,rst,count);
always #5 clk = ~clk;
initial $monitor("Time=%t rst=%b clk=%b m=%b count=%b", $time,rst,clk,m,count);
//$monitor will display the simulation results on the screen
initial
#320 $finish;
endmodule
To run simulations for the module, use the Xcelium tool with the following command:
irun/xrun module_name.v module_test_name.v -access +rwc -gui
irun counter.v counter_test.v -access +rwc -gui
data:image/s3,"s3://crabby-images/10c9e/10c9e32e9456792f5c05e1ebae9f90e47cd9ec04" alt="1"
The simulation output and waveform results were generated as shown below:
data:image/s3,"s3://crabby-images/59d81/59d812cbf55a49fd793d0999cf021deb69046f4c" alt="3"
data:image/s3,"s3://crabby-images/572b0/572b0c67f3358ac70d816a9c2ef2bd9a9ba48ecd" alt="4-waveform"
The process of converting rtl code into gate-level netlist. It involves 3 stages - translation, mapping, and optimization.
Inputs - 1. verilog file (counter.v) 2. constraints.sdc file 3. library file (.lib)
Outputs - 1. Gate-level netlist 2. Tool constraints file 3. Reports - gates, power, timing, cells...
to run the script file invoke the genus synthesis tool by using the command:
genus
source run.tcl
set_db init_lib_search_path /cad/FOUNDRY/digital/90nm/dig/lib
#set_attribute lef_library /cad/FOUNDRY/digital/90nm/dig/lef/gsclib090_tech.lef
set_db library slow.lib
read_hdl {./counter.v}
elaborate
read_sdc ./constraints_input.sdc
set_db syn_generic_effort medium
set_db syn_map_effort medium
set_db syn_opt_effort medium
syn_generic
syn_map
syn_opt
write_hdl > counter_netlist.vconsta
write_sdc > counter_tool.sdc
gui_show
report timing > counter_timing.rpt
report power > counter_power.rpt
report area > counter_cell.rpt
report gates > counter_gates.rpt
data:image/s3,"s3://crabby-images/f6f2f/f6f2ff69afc4e624f674a4a5811a768b2018ffd9" alt="schematic"
Invoke the innovus tool using the command
innovus
Creating the Multi-Mode Multi-Corner (MMMC) scenarios for the timing analysis
data:image/s3,"s3://crabby-images/e17a5/e17a512435ebd1e213f655aef3d9fb79a3366143" alt="M-2"
data:image/s3,"s3://crabby-images/ffcb3/ffcb3843467baad8e1dd29756ecf9d6e7bc5ba80" alt="m-3"
data:image/s3,"s3://crabby-images/0f3f9/0f3f99299364d3537e6a585354edfe26c40a8f62" alt="M-4"
data:image/s3,"s3://crabby-images/3618a/3618a2724d45a1f88fc623502b0e7e8f759d109b" alt="M-5"
data:image/s3,"s3://crabby-images/4d0fe/4d0fe5ad827532a6babb470fca77abef9beb914a" alt="M-6"
data:image/s3,"s3://crabby-images/5c23d/5c23db92e6ea04087ec998cc2156ca1307ee8c4e" alt="M-7"
data:image/s3,"s3://crabby-images/30172/30172768e534ca4b3b6a98781496b31c5f461aca" alt="1"
data:image/s3,"s3://crabby-images/57b57/57b57d008fc03f25c4f3c51c3bfba08d072b21c4" alt="FP-1"
data:image/s3,"s3://crabby-images/8ffcc/8ffcc742c5720fadcd90cab7b310eacfd3e1c418" alt="fp-2"
data:image/s3,"s3://crabby-images/d7ccb/d7ccba08bcdfa9d9120bd3bd78e7488bab6ea68d" alt="pp-1"
data:image/s3,"s3://crabby-images/3e999/3e999608267c49e475c5e9bc2f0aedf29963aca2" alt="pp-2"
data:image/s3,"s3://crabby-images/86a55/86a55aaf45694f0866d509e3f1cd92fbf0b7cbc9" alt="pp-3"
data:image/s3,"s3://crabby-images/4aebe/4aebe7260909fa1c92fc221c7b5f589b54f612e3" alt="pp-4"
data:image/s3,"s3://crabby-images/24a19/24a199b1204925207107bae9cc2786f7de2acab0" alt="pp-5"
data:image/s3,"s3://crabby-images/6beac/6beac252bfd9fb25c1ac05e03c88bb391d81f947" alt="pp-6"
data:image/s3,"s3://crabby-images/bd68e/bd68e2cd636bc4c692fdef60f505a7299c455148" alt="pp-7"
data:image/s3,"s3://crabby-images/8f381/8f381c0db51fb28b1968e2acc64d4a8797fbf8cc" alt="place-1"
data:image/s3,"s3://crabby-images/fa418/fa41893e2406a77910b095bf37a51537a374d024" alt="place-2"
data:image/s3,"s3://crabby-images/61bb3/61bb3ad7f2b758d7e4544f0aa26d2b95c5c2a47e" alt="place-4"
#90nm technology
#clock tree constraints used for building and balancing the clock tree in cts stage
##creating_NDR rules:
add_ndr -width {Metal1 0.24 Metal2 0.28 Metal3 0.28 Metal4 0.28 Metal5 0.28 Metal6 0.28 Metal7 0.28 Metal8 0.88 Metal9 0.88} -spacing {Metal1 0.24 Metal2 0.28 Metal3 0.28 Metal4 0.28 Metal5 0.28 Metal6 0.28 Metal7 0.28 Metal8 0.88 Metal9 0.88} -name 2w2s
#create a route type to define the NDR & layers to use for routing the clock tree:
create_route_type -name clkroute -non_default_rule 2w2s -bottom_preferred_layer Metal5 -top_preferred_layer Metal6
##specify this route type should be used for trunk and leaf nets:
set_ccopt_property route_type clkroute -net_type trunk
set_ccopt_property route_type clkroute -net_type leaf
##specify the clock buffer, clock inverter & clock gating cells to use
set_ccopt_property buffer_cells {CLKBUFX6 CLKBUFX8 CLKBUFX12}
set_ccopt_property inverter_cells {CLKINVX6 CLKINVX8 CLKINVX12}
set_ccopt_property clock_gating_cells TLATNTSCA*
##generate the ccopt spec file & source it
create_ccopt_clock_tree_spec -file ccopt.spec
source ccopt.spec
#run ccopt-cts
ccopt_design -cts
##generate reports for clock tree and skew groups
report_ccopt_clock_trees -file clk_trees.rpt
report_ccopt_skew_groups -file skew_groups.rpt
#save the design
saveDesign DBS/cts.enc
data:image/s3,"s3://crabby-images/b2c91/b2c915dadbbf8b498cb5aa5a42c2f2f2874a4bd2" alt="cts-1"
data:image/s3,"s3://crabby-images/9e8d1/9e8d1abbe65b1f9197d3a801ebd6ae9fee3a6dfe" alt="cts-2"
data:image/s3,"s3://crabby-images/60e9b/60e9be441507a1a5eae159e949caecffb2e2a210" alt="route"
data:image/s3,"s3://crabby-images/7d210/7d210cbce764f18c7f35a14798067c7d290f7fd7" alt="route-1"
data:image/s3,"s3://crabby-images/b4637/b46372de2c39791ae3900cb90d6dcdb3bf63a7cb" alt="route-3"