

# Vellore Institute of Technology, Chennai

## BECE407P - ASIC Design

### Lab-3

#### ***Running the Basic Synthesis Flow using Cadence® Genus***

Name of the Student: [REDACTED]

Roll Number: [REDACTED]

Date of the Lab. Class: 1/08/24

1. **Aim:** To design , verify and to synthesize 4 bit ALU .

2. **EDA Tools Used:**

Cadence® Genus and Cadence® Naunch

3. **Details of the Synthesis Flow:** (with clear snapshots)

(a) Method of writing a script file (.g) for input *Timing Constraints*:

1.) Create a file with .g extension in the synthesis folder.

2.) Open it and write the following commands and save it:

```
create_clock -name clk -period 10 -waveform {0 5} [get_ports "clk"]
set_clock_transition -rise 0.1 [get_clocks "clk"]
set_clock_transition -fall 0.1 [get_clocks "clk"]
set_clock_uncertainty 0.01 [get_ports "clk"]
```

```
set_input_delay -max 1.0 [get_ports "A"] -clock [get_clocks "clk"]
set_input_delay -max 1.0 [get_ports "B"] -clock [get_clocks "clk"]
set_input_delay -max 1.0 [get_ports "opcode"] -clock [get_clocks "clk"]
set_input_delay -max 1.0 [get_ports "rst"] -clock [get_clocks "clk"]
set_output_delay -max 1.0 [get_ports "result"] -clock [get_clocks "clk"]
```



The screenshot shows a terminal window titled "alu\_constraints\_top.g". The window contains a script for setting up timing constraints. The script includes commands to create a clock named "clk" with a period of 10 units, set clock transitions for rise and fall times, and specify input and output delays for ports "A", "B", "opcode", "rst", and "result". The window also displays status information at the bottom: "Ln 3, Col 42", "563 characters", "100%", "Unix (LF)", and "UTF-8".

```
create_clock -name clk -period 10 -waveform {0 5} [get_ports "clk"]
set_clock_transition -rise 0.1 [get_clocks "clk"]
set_clock_transition -fall 0.1 [get_clocks "clk"]
set_clock_uncertainty 0.01 [get_ports "clk"]

set_input_delay -max 1.0 [get_ports "A"] -clock [get_clocks "clk"]
set_input_delay -max 1.0 [get_ports "B"] -clock [get_clocks "clk"]
set_input_delay -max 1.0 [get_ports "opcode"] -clock [get_clocks "clk"]
set_input_delay -max 1.0 [get_ports "rst"] -clock [get_clocks "clk"]
set_output_delay -max 1.0 [get_ports "result"] -clock [get_clocks "clk"]
```

(b) Steps to start *Cadence® Genus*:

- 1.) Open the synthesis folder terminal .
- 2.) run the following commands : 'csh' , 'source /home/install/cshrc' , 'genus -legacy -ui' .

(c) Steps to “load the required libraries, designs and synthesizing those designs”:

- 1.) After opening the genus set the library and rtl folder path by using the commands :

```
'set_attribute init_lib_search_path /home/student/Desktop/21BEC1033/lib/'  
'set_attribute init_rtl_search_path /home/student/Desktop/21BEC1033/rtl/'
```

- 2.) Now load the library using the command :

```
'set_attribute library slow_vdd1v0_basicCells.lib'
```

- 3.) Now read the counter.v file by using the command : 'read\_hdl alu\_4bit.v'
- 4.) Elaborate the design by using the command: 'elaborate'.
- 5.) Now read the timing constraints file by using the command :

```
'read_sdc alu_constraints_top.g'
```

- 6.) To synthesize the design run the command:

```
'set_attribute syn_generic_effort medium'  
'syn_generic'  
'set_attribute syn_map_effort high'  
'set_attribute syn_opt_effort high'
```

```
'syn_map'  
'syn_opt'
```

4. Cadence® Genus Legacy terminal after Synthesis: [Terminal](#)  
(click the link for viewing entire terminal)

File Edit View  
File Processing Tools Scripts Help

```
#@ Processing -files option
@genus 1> source alu.tcl
Setting attribute of root '/': 'init_lib_search_path' = /home/student/Desktop/21BEC1033/lib/
Setting attribute of root '/': 'init_hdl_search_path' = /home/student/Desktop/21BEC1033/rtl/

Threads Configured:3

Message Summary for Library slow_vddiv0_basiccells.lib:
*****
Missing a function attribute in the output pin definition. [LBR-518]: 1
*****
```

Info : Created nominal operating condition. [LBR-412]  
: Operating condition 'nominal' was created for the PVT values (1.000000, 0.900000, 125.000000) in library 'slow\_vddiv0\_basiccells.lib'.  
: The nominal operating condition is represented, either by the nominal PVT values specified in the library source (via nom\_process,nom\_voltage and nom\_temperature respectively), or by the default PVT values (1.0,1.0,1.0).  
Warning : Library cell has no output pins defined. [LBR-9]  
: Library cell 'ANTENNA' must have an output pin.  
: Add the missing output pin(s), then reload the library. Else the library cell will be marked as timing model i.e. unusable. Timing model means that the cell does not have any defined function. If there is no output pin, Genus will mark library cell as unusable i.e. the attribute 'usable' will be marked to 'false' on the libcell. Therefore, the cell is not used for mapping and it will not be picked up from the library for synthesis. If you query the attribute 'unusable\_reason' on the libcell; result will be: 'Library cell has no output pins.' Note: The message LBR-9 is only for the logical pins and not for the power\_ground pins. Genus will depend upon the output function defined in the pin group (output pin) of the cell, to use it for mapping. The pg\_pin will not have any function defined.  
Warning : Library cell has no output pins defined. [LBR-9]  
: Library cell 'ANTENNA' must have an output pin.  
Warning : Library cell has no output pins defined. [LBR-9]  
: Library cell 'DECAP10' must have an output pin.  
Warning : Library cell has no output pins defined. [LBR-9]  
: Library cell 'DECAP10' must have an output pin.  
Warning : Library cell has no output pins defined. [LBR-9]  
: Library cell 'DECAP2' must have an output pin.  
Warning : Library cell has no output pins defined. [LBR-9]  
: Library cell 'DECAP2' must have an output pin.  
Warning : Library cell has no output pins defined. [LBR-9]  
: Library cell 'DECAP3' must have an output pin.  
Warning : Library cell has no output pins defined. [LBR-9]  
: Library cell 'DECAP3' must have an output pin.  
Warning : Library cell has no output pins defined. [LBR-9]  
: Library cell 'DECAP4' must have an output pin.

```

alu_terminal X +
File Edit View
Setting attribute of root '/': 'library' = slow_vddiv0_basicCells.lib
Library has 324 usable logic and 128 usable sequential lib-cells.
Info : Elaborating Design. [ELAB-1]
: Elaborating top-level block 'alu_4bit' from file '/home/student/Desktop/21BEC1033/rtl/alu_4bit.v'.
Warning : Unreachable statements for case item. [CFG-472]
: Case item 'default' in module 'alu_4bit' in file '/home/student/Desktop/21BEC1033/rtl/alu_4bit.v' on line 14.
Info : Done Elaborating Design. [ELAB-3]
: Done elaborating 'alu_4bit'.
Checking for analog nets...
Check completed for analog nets.
Checking for source RTL...
Check completed for source RTL.
Running Unified Mux Engine Tricks...
Completed Unified Mux Engine Tricks

Stage: post_elab
| Trick | Accepts | Rejects | Runtime (ms) |
| _ume_constant_bmux | 0 | 0 | 0.00 |

Starting clip mux common data inputs [v1.0] (stage: post_elab, startdef: alu_4bit, recur: true)
Completed clip mux common data inputs (accepts: 0, rejects: 0, runtime: 0.000s)
Starting clip the non-user hierarchies [v2.0] (stage: post_elab, startdef: alu_4bit, recur: true)
Completed clip the non-user hierarchies (accepts: 0, rejects: 0, runtime: 0.000s)

Stage: post_elab
| Transform | Accepts | Rejects | Runtime (ms) |
| hlo_clip_mux_input | 0 | 0 | 1.00 |
| hlo_clip | 0 | 0 | 0.00 |

Statistics for commands executed by read_sdc:
"create_clock" - successful 1 , failed 0 (runtime 0.00)
"get_clocks" - successful 7 , failed 0 (runtime 0.00)
"get_ports" - successful 7 , failed 0 (runtime 0.00)
"set_clock_transition" - successful 2 , failed 0 (runtime 0.00)
"set_clock_uncertainty" - successful 1 , failed 0 (runtime 0.00)
"set_input_delay" - successful 4 , failed 0 (runtime 0.00)
Ln 1, Col 1 90.000 characters
100% Unix (LF) UTF-8

```

```

alu_terminal X +
File Edit View
read_sdc completed in 00:00:00 (hh:mm:ss)
Setting attribute of root '/': 'syn_generic_effort' = medium
Setting attribute of root '/': 'syn_map_effort' = medium
Setting attribute of root '/': 'syn_opt_effort' = medium

Stage: pre_early_cg
| Transform | Accepts | Rejects | Runtime (ms) |

## Generic Timing Info for library domain: _default_ typical gate delay: 127.6 ps std_slew: 17.9 ps std_load: 1.0 fF
Starting mux data reorder optimization [v1.0] (stage: pre_to_gen_setup, startdef: alu_4bit, recur: true)
Completed mux data reorder optimization (accepts: 0, rejects: 0, runtime: 0.000s)

Stage: pre_to_gen_setup
| Transform | Accepts | Rejects | Runtime (ms) |
| hlo_mux_reorder | 0 | 0 | 0.00 |

Info : Synthesizing. [SYNTH-1]
: Synthesizing 'alu_4bit' to generic gates using 'medium' effort.
PBS_Generic_Start - Elapsed Time 0, CPU Time 0.0
stamps 'PBS_Generic_Start' being created for table 'pbs_debug'

Total Time (Wall) | Stage Time (Wall) | % (Wall) | Date - Time | Memory | Stage
00:00:04(00:00:02) | 00:00:00(00:00:00) | 0.0( 0.0) | 11:59:08 (Aug02) | 236.9 MB | PBS_Generic_Start
Number of threads: 8 * 1 (id: pbs.debug, time_info v1.57)
Info: (*) indicates data that was populated from previously saved time_info database
Info: CPU time includes time of parent + longest thread
Ths Restructuring config: no_value at stage generic applied.
Info : Partition Based Synthesis execution skipped. [PHYS-752]
: Design size is less than the partition size '100000' for distributed generic optimization to kick in.
Starting mux data reorder optimization [v1.0] (stage: pre_to_gen_setup, startdef: alu_4bit, recur: true)
Completed mux data reorder optimization (accepts: 0, rejects: 0, runtime: 0.000s)
Ln 1, Col 1 90.000 characters
100% Unix (LF) UTF-8

```

```

alu_terminal X +
File Edit View
CPI-506 [Warning] 1 | Command 'commit_power_intent' cannot proceed as
| there is no power intent loaded.
| PA-7 [Info] 4 | Resetting power analysis results.
| | All computed switching activities are removed.
| SYNTH-5 [Info] 1 | Done mapping.
| SYNTH-7 [Info] 1 | Incrementally optimizing.

Info : Done incrementally optimizing. [SYNTH-8]
: Done incrementally optimizing 'alu_4bit'.
Finished SOC export (command execution time mmiss (real) = 00:00).
Info : Joules engine is used. [PDT-16]
: Joules engine is being used for the command report_power.
Info : ACTP-0001 [ACTPInfo] Activity propagation started for stim#0 netlist
: alu_4bit
Info : ACTP-0009 [ACTPInfo] Activity Propagation Progress Report : 100%
Info : ACTP-0001 Activity propagation ended for stim#0
Info : PWA-0001 [PwrInfo] compute_power effective options
: -mode : vectorless
: -skip_propagation : 1
: -frequency_scaling_factor : 1.0
: -use_clock_freq : stim
: -stim :/stim#0
: -fromGenus : 1
Info : ACTP-0001 Timing initialization started
Info : ACTP-0001 Timing initialization ended
Info : PWA-0002 [PwrInfo] Skipping activity propagation due to -skip_ap
: option...
Warning: PWA-0032 [PwrWarn] Frequency scaling is not applicable for vectorless
: flow. Ignoring frequency scaling.
Warning: PWA-0034 [PwrWarn] -stim option is not applicable with vectorless mode
: of power analysis, ignored this option.
Info : PWA-0002 Started 'vectorless' power computation.
Info : PWA-0009 [PwrInfo] Power Computation Progress Report : 100%
Info : PWA-0002 Finished power computation.
Info : PWA-0007 [PwrInfo] Completed successfully.
Info : Info=6, Warn=2, Error=0, Fatal=0
Output file: alu_power.rep
WARNING: This version of the tool is 770 days old.
legacy_genus:/>
Ln 1, Col 1 90.000 characters
100% Unix (LF) UTF-8

```

## 5. Generate & Read the Reports: (with clear snapshots)

For generating the report run the following commands:

```
report_timing > alu_timing.rep
```

```
report_area > alu_area.rep
```

```
report_power > alu_power.rep
```

The screenshot shows three terminal windows side-by-side:

- alu\_area.rep**: Displays synthesis area reports. It includes header information and a table of instance/module counts and areas.
- alu\_timing.rep**: Displays synthesis timing reports. It includes header information and a detailed table of timing constraints and delays.
- alu\_power.rep**: Displays synthesis power reports. It includes header information and a detailed table of leakage, internal, switching, and total power consumption across various categories like memory, register, latch, logic, bbox, clock, pad, and pin.

A callout box highlights the following summary data from the power report:

|                             |
|-----------------------------|
| Cell Count=166              |
| Cell Area=303.696 sq. units |
| Power dissipated=6.9 nW     |

## 6. Writing the Output files: (with clear snapshots)

Run the following commands to write the output files:

```
write_netlist > alu_netlist.v (alu\_netlist--link)
```

```
write_sdc > alu.sdc
```



The screenshot shows a terminal window titled "alu.sdc" with the following content:

```
# #####  
# Created by Genus(TM) Synthesis Solution 21.14-s082_1 on Thu Aug 01 14:39:16 IST 2024  
# #####  
  
set sdc_version 2.0  
  
set_units -capacitance 1000ff  
set_units -time 1000ps  
  
# Set the current design  
current_design alu_4bit  
  
create_clock -name "clk" -period 10.0 -waveform {0.0 5.0} [get_ports clk]  
set_clock_transition 0.1 [get_clocks clk]  
set_clock_gating_check -setup 0.0  
set_input_delay -clock [get_clocks clk] -add_delay -max 1.0 [get_ports {A[3]}]  
set_input_delay -clock [get_clocks clk] -add_delay -max 1.0 [get_ports {A[2]}]  
set_input_delay -clock [get_clocks clk] -add_delay -max 1.0 [get_ports {A[1]}]  
set_input_delay -clock [get_clocks clk] -add_delay -max 1.0 [get_ports {A[0]}]  
set_input_delay -clock [get_clocks clk] -add_delay -max 1.0 [get_ports {B[3]}]  
set_input_delay -clock [get_clocks clk] -add_delay -max 1.0 [get_ports {B[2]}]  
set_input_delay -clock [get_clocks clk] -add_delay -max 1.0 [get_ports {B[1]}]  
set_input_delay -clock [get_clocks clk] -add_delay -max 1.0 [get_ports {B[0]}]  
set_input_delay -clock [get_clocks clk] -add_delay -max 1.0 [get_ports {opcode[2]}]  
set_input_delay -clock [get_clocks clk] -add_delay -max 1.0 [get_ports {opcode[1]}]  
set_input_delay -clock [get_clocks clk] -add_delay -max 1.0 [get_ports {opcode[0]}]  
set_input_delay -clock [get_clocks clk] -add_delay -max 1.0 [get_ports {rst}]  
set_output_delay -clock [get_clocks clk] -add_delay -max 1.0 [get_ports {result[7]}]  
set_output_delay -clock [get_clocks clk] -add_delay -max 1.0 [get_ports {result[6]}]  
set_output_delay -clock [get_clocks clk] -add_delay -max 1.0 [get_ports {result[5]}]  
set_output_delay -clock [get_clocks clk] -add_delay -max 1.0 [get_ports {result[4]}]  
set_output_delay -clock [get_clocks clk] -add_delay -max 1.0 [get_ports {result[3]}]  
set_output_delay -clock [get_clocks clk] -add_delay -max 1.0 [get_ports {result[2]}]  
set_output_delay -clock [get_clocks clk] -add_delay -max 1.0 [get_ports {result[1]}]  
set_output_delay -clock [get_clocks clk] -add_delay -max 1.0 [get_ports {result[0]}]  
set_wire_load_mode "enclosed"  
set_clock_uncertainty -setup 0.01 [get_ports clk]  
set_clock_uncertainty -hold 0.01 [get_ports clk]
```

// Generated by Cadence Genus(TM) Synthesis Solution 21.14-s082.1  
// Generated on: Aug 1 2024 14:39:16 IST (Aug 1 2024 09:09:16 UTC)

// Verification Directory fv/alu\_6bit

module alu\_6bit(A, B, opcode, clk, rst, result);  
input [3:0] A, B;  
input [2:0] opcode;  
input clk, rst;  
output [7:0] result;  
wire [3:0] A, B;  
wire [2:0] opcode;  
wire clk, rst;  
wire [7:0] result;  
wire n\_0, n\_1, n\_2, n\_3, n\_4, n\_5, n\_6, n\_7;  
wire n\_8, n\_9, n\_10, n\_11, n\_12, n\_14, n\_15, n\_16;  
wire n\_17, n\_18, n\_21, n\_22, n\_23, n\_24, n\_25, n\_26;  
wire n\_27, n\_28, n\_29, n\_30, n\_31, n\_32, n\_33, n\_34;  
wire n\_35, n\_36, n\_37, n\_39, n\_40, n\_41, n\_42, n\_43;  
wire n\_44, n\_45, n\_46, n\_47, n\_48, n\_49, n\_50, n\_51;  
wire n\_52, n\_53, n\_54, n\_55, n\_56, n\_58, n\_59, n\_60;  
wire n\_61, n\_62, n\_63, n\_65, n\_66, n\_67, n\_68, n\_69;  
wire n\_70, n\_71, n\_72, n\_73, n\_74, n\_75, n\_76, n\_77;  
wire n\_78, n\_79, n\_80, n\_81, n\_82, n\_83, n\_84, n\_85;  
wire n\_86, n\_87, n\_88, n\_89, n\_90, n\_91, n\_92, n\_93;  
wire n\_94, n\_95, n\_96, n\_97, n\_99, n\_101, n\_102, n\_103;  
wire n\_104, n\_105, n\_106, n\_107, n\_108, n\_109, n\_110, n\_111;  
wire n\_112, n\_113, n\_114, n\_115, n\_116, n\_118, n\_119, n\_120;  
wire n\_121, n\_122, n\_123, n\_124, n\_125, n\_126, n\_127, n\_128;  
wire n\_129, n\_130, n\_131, n\_132, n\_133, n\_134, n\_135, n\_136;  
wire n\_138, n\_139, n\_140, n\_141, n\_142, n\_143, n\_144, n\_145;  
wire n\_146, n\_148, n\_149, n\_150, n\_151, n\_152, n\_153, n\_154;  
wire n\_155, n\_156, n\_157, n\_158, n\_159, n\_160, n\_161, n\_162;  
wire n\_164, n\_165, n\_166, n\_167, n\_168, n\_169, n\_170, n\_184;  
wire n\_185, n\_186, n\_187, n\_188, n\_189;  
DFFRQX1 [result\_reg[3]] (.RN(n\_169), .CK(clk), .D(n\_170), .Q(result[3]));  
OAI221X1 g35743\_2398(.A0\_(n\_28), .A1\_(n\_158), .B0\_(n\_66), .B1\_(n\_15), .C0\_(n\_167), .Y\_(n\_170));  
DFFRQX1 [result\_reg[4]] (.RN(n\_169), .CK(clk), .D(n\_168), .Q(result[4]));  
OAI221X1 g35722\_5107(.A0\_(n\_165), .A1\_(n\_132), .B0\_(n\_138), .B1\_(n\_157), .C0\_(n\_161), .Y\_(n\_168));  
NOR2X1 g35728\_6260(.A0\_(n\_70), .B\_(n\_162), .Y\_(n\_167));  
DFFRQX1 [result\_reg[7]] (.RN(n\_169), .CK(clk), .D(n\_164), .Q(result[7]));  
DFFRQX1 [result\_reg[6]] (.RN(n\_169), .CK(clk), .D(n\_166), .Q(result[6]));  
DFFRQX1 [result\_reg[5]] (.RN(n\_169), .CK(clk), .D(n\_160), .Q(result[5]));  
OAI21X1 g35726\_4319(.A0\_(n\_165), .A1\_(n\_145), .B0\_(n\_186), .Y\_(n\_166));  
OAI21X1 g35723\_8428(.A0\_(n\_165), .A1\_(n\_136), .B0\_(n\_186), .Y\_(n\_164));  
OAI21X1 g35730\_5526(.A0\_(A[3]), .A1\_(n\_161), .B0\_(n\_126), .C0\_(n\_153), .Y\_(n\_162));  
DFFRQX1 [result\_reg[2]] (.RN(n\_169), .CK(clk), .D(n\_159), .Q(result[2]));  
OAI2B8X1 g35725\_6783(.A0N\_(n\_189), .A1N\_(n\_155), .B0\_(n\_186), .Y\_(n\_160));  
DFFRQX1 [result\_reg[0]] (.RN(n\_169), .CK(clk), .D(n\_154), .Q(result[0]));  
OAI21X1 g35731\_3680(.A0\_(n\_1), .A1\_(n\_158), .B0\_(n\_52), .C0\_(n\_148), .Y\_(n\_159));  
DFFRQX1 [result\_reg[1]] (.RN(n\_169), .CK(clk), .D(n\_152), .Q(result[1]));  
OAI21X1 g35732\_2802(.A0\_(n\_151), .A1\_(n\_150), .B0\_(n\_156), .Y\_(n\_157));  
XOR2X1 g35731\_1705(.A\_(n\_124), .B\_(n\_143), .Y\_(n\_155));  
OAI221X1 g35744\_5122(.A0\_(n\_3), .A1\_(n\_158), .B0\_(A[0]), .B1\_(n\_161), .C0\_(n\_149), .Y\_(n\_154));  
OAI221X1 g35733\_8246(.A0\_(n\_141), .A1\_(n\_146), .B0\_(n\_51), .B1\_(n\_188), .Y\_(n\_153));  
OAI21X1 g35749\_7098(.A0\_(n\_5), .A1\_(n\_158), .B0\_(n\_48), .C0\_(n\_142), .Y\_(n\_152));  
NOR2X1 g35737\_6131(.A\_(n\_151), .B\_(n\_150), .Y\_(n\_156));  
INX1 g35748\_0041(.A\_(n\_144), .Y\_(n\_149));  
OAI221X1 g35739\_1881(.A0\_(n\_189), .A1\_(n\_182), .B0\_(n\_140), .B1\_(n\_53), .C0\_(n\_139), .Y\_(n\_148));  
ADDFX1 g35741\_5115(.A\_(A[3]), .B\_(n\_73), .C1\_(n\_121), .C0\_(n\_150), .S\_(n\_146));  
XOR2X1 g35735\_7482(.A\_(n\_94), .B\_(n\_134), .Y\_(n\_145));  
OAI222X1 g35751\_4733(.A0\_(n\_61), .A1\_(n\_60), .B0\_(n\_130), .B1\_(n\_135), .C0\_(n\_25), .C1\_(n\_47), .Y\_(n\_144));  
XOR2X1 g35740\_6161(.A\_(n\_123), .B\_(n\_184), .Y\_(n\_143));  
OAI221X1 g35753\_9315(.A0\_(n\_141), .A1\_(n\_106), .B0\_(n\_140), .B1\_(n\_101), .C0\_(n\_131), .Y\_(n\_142));  
DFFRQX1 [result\_reg[6]] (.RN(n\_169), .CK(clk), .D(n\_166), .Q(result[6]));  
DFFRQX1 [result\_reg[5]] (.RN(n\_169), .CK(clk), .D(n\_160), .Q(result[5]));  
DFFRQX1 [result\_reg[4]] (.RN(n\_169), .CK(clk), .D(n\_154), .Q(result[4]));  
DFFRQX1 [result\_reg[3]] (.RN(n\_169), .CK(clk), .D(n\_150), .Q(result[3]));  
DFFRQX1 [result\_reg[2]] (.RN(n\_169), .CK(clk), .D(n\_144), .Q(result[2]));  
DFFRQX1 [result\_reg[1]] (.RN(n\_169), .CK(clk), .D(n\_138), .Q(result[1]));  
DFFRQX1 [result\_reg[0]] (.RN(n\_169), .CK(clk), .D(n\_132), .Q(result[0]));  
OAI222X1 g35745\_9945(.A0\_(n\_69), .A1\_(n\_81), .B0\_(n\_138), .B1\_(n\_127), .C0\_(A[2]), .C1\_(n\_161), .Y\_(n\_139));  
OAI2B8X1L g35738\_3426(.A0N\_(n\_92), .A1N\_(n\_133), .B0\_(n\_93), .Y\_(n\_136));  
OAI221X1 g35761\_1666(.A0\_(A[0]), .A1\_(n\_87), .B0\_(n\_21), .B1\_(n\_77), .C0\_(n\_120), .Y\_(n\_135));  
NAND2X1 g35743\_7410(.A\_(n\_125), .B\_(n\_133), .Y\_(n\_134));  
XOR2X1 g35750\_6417(.A\_(n\_128), .B\_(n\_115), .Y\_(n\_131));  
OAI222X1 g35758\_5477(.A0\_(n\_165), .A1\_(n\_46), .B0\_(n\_130), .B1\_(n\_118), .C1\_(A[1]), .CI\_(n\_161), .Y\_(n\_131));  
OAI22XL g35752\_2398(.A0\_(n\_114), .A1\_(n\_113), .B0\_(n\_128), .Y\_(n\_129));  
INW1 g35754\_5(A\_(n\_122), .Y\_(n\_127));  
NAND2X1 g35759\_5187(.A\_(n\_189), .B\_(n\_119), .Y\_(n\_126));  
OAI221X1 g35760\_6260(.A0\_(n\_124), .A1\_(n\_123), .B0\_(n\_128), .Y\_(n\_125));  
ADDFX1 g35756\_4319(.A\_(A[2]), .B\_(n\_74), .CI\_(n\_105), .C0\_(n\_121), .S\_(n\_122));  
OAI221X1 g35747\_8428(.A0\_(n\_123), .A1\_(n\_116), .B0\_(n\_124), .Y\_(n\_133));  
OAI221X1 g35763\_5526(.A0\_(B[1]), .A1\_(n\_112), .B0\_(n\_103), .C0\_(n\_111), .Y\_(n\_120));  
ADDFX1 g35762\_6783(.A\_(n\_33), .B\_(n\_83), .CI\_(n\_104), .C0\_(n\_128), .S\_(n\_119));  
AOI221X1 g35765\_3680(.A0\_(n\_110), .A1\_(n\_68), .B0\_(n\_107), .B1\_(n\_109), .C0\_(n\_59), .Y\_(n\_118));  
ADDHX1 g35757\_1617(.A\_(n\_114), .B\_(n\_113), .C0\_(n\_116), .S\_(n\_115));  
NOR2X1 g35768\_2802(.A\_(n\_99), .B\_(n\_108), .Y\_(n\_112));  
AOI22XL g35769\_1705(.A0\_(n\_110), .A1\_(n\_185), .B0\_(B[1]), .B1\_(n\_89), .Y\_(n\_111));  
AOI32X1 g35769\_5122(.A\_(n\_2), .A1\_(n\_187), .A2\_(n\_96), .B0\_(B[1]), .B1\_(n\_97), .Y\_(n\_189));  
OAI21X1 g35770\_8246(.A0\_(n\_107), .A1\_(n\_90), .B0\_(n\_86), .C0\_(n\_95), .Y\_(n\_108));  
ADDFX1 g35767\_7998(.A\_(A[1]), .B\_(n\_62), .CI\_(n\_63), .C0\_(n\_105), .S\_(n\_106));  
ADDFX1 g35764\_6131(.A\_(n\_37), .B\_(n\_31), .CI\_(n\_55), .C0\_(n\_123), .S\_(n\_113));  
ADDFX1 g35775\_1881(.A\_(n\_10), .B\_(n\_11), .CI\_(n\_58), .C0\_(n\_114), .S\_(n\_104));  
AOI32X1 g35777\_5115(.A0\_(B[3]), .A1\_(n\_85), .A2\_(n\_84), .B0\_(A[0]), .B1\_(n\_91), .Y\_(n\_103));  
XOR2X1 g35772\_7482(.A\_(n\_101), .B\_(n\_80), .Y\_(n\_102));  
NAND2X1 g35773\_6161(.A\_(n\_96), .B\_(n\_88), .Y\_(n\_97));  
OAI2B8X1L g35780\_9315(.A0N\_(n\_45), .A1N\_(n\_75), .B0\_(A[0]), .Y\_(n\_95));  
NOR2X1 g35771\_9945(.A\_(n\_93), .B\_(n\_92), .Y\_(n\_94));  
OAI221X1 g35784\_2883(.A0\_(A[2]), .A1\_(n\_187), .B0\_(n\_90), .C0\_(n\_56), .Y\_(n\_91));

Three screenshots of a terminal window showing Verilog code for an ALU. The code defines various logic functions and their implementations using different logic gates (AND, OR, NOT, etc.). The code is highly repetitive, showing multiple instances of similar logic blocks with different variable names.

```

alu_netlist.v
File Edit View
File Edit View
alu_netlist.v
File Edit View
NAND2X1 g35836_4319(.A (A[3]), .A1 (A[1]), .A2 (n_43), .B0 (n_88),
.B1 (n_110), .B2 (n_67), .Y (n_89));
INVX1 g35789_(A (n_86), .Y (n_87));
OAI22X1 g35787_1666(.A0 (B[2]), .A1 (n_71), .B0 (n_85), .B1 (n_84),
.Y (n_96));
OAI21X1 g35779_7410(.A (n_17), .A1 (n_78), .B0 (n_79), .Y (n_83));
OAI22BX1 g35785_6417(.A0 (B[1]), .A1N (n_90), .B0 (n_50), .Y (n_82));
OAI21X1 g35790_5477(.A0 (A[3]), .A1 (n_22), .B0 (n_76), .C0 (n_42),
.Y (n_71));
XNOR2X1 g35781_2398(.A (n_79), .B (n_78), .Y (n_80));
XNOR2X1 g35774_5107(.A (n_65), .B (n_44), .Y (n_124));
OAI22X1 g35793_6260(.A0 (n_76), .A1 (n_39), .B0 (n_0), .B1 (n_27),
.Y (n_77));
OAI22X1 g35792_8428(.B[2]), .A1 (n_151), .B0 (n_85), .B1 (n_72),
.Y (n_74));
OAI22X1 g35799_5526(.B[3]), .A1 (n_151), .B0 (n_107), .B1 (n_27),
.Y (n_73));
NAND2X1 g35793_6783(.A (B[2]), .B (n_71), .D (n_86));
NOR4X1 g35783_3680(.A (B[1]), .B (n_56), .C (n_69), .D (n_130), .Y (n_70));
OAI22X1 g35796_1617(.A0 (B[1]), .A1 (n_67), .B0 (n_26), .B1 (n_65),
.C0 (B[3]), .C1 (n_49), .Y (n_68));
NOR2BX1 g35801_2882(.A (n_60), .B (n_55), .Y (n_92));
XNOR2X1 g35790_1705(.A (n_61), .B (n_15), .Y (n_65));
OAI21X1 g35800_5122(.A0 (B[1]), .A1 (n_151), .B0 (n_61), .Y (n_62));
NOR2X1 g35805_8246(.A (n_48), .B (n_54), .C (n_76), .Y (n_59));
NOR3X1 g35806_7098(.A (n_54), .B (n_69), .C (n_8), .Y (n_58));
XNOR2X1 g35811_6131(.A (n_4), .B (n_19), .C (n_76), .Y (n_59));
INVX1 g35827_(A (n_56), .Y (n_99));
INVX1 g35815_(A (n_189), .Y (n_165));
XNOR2X1 g35798_7482(.A (n_51), .B (n_34), .Y (n_55));
NAND2X1 g35790_4733(.A (n_51), .B (n_34), .Y (n_52));
NAND4X1 g35791_6161(.A (n_49), .B (n_69), .C (n_9), .D (n_35), .Y (n_50));
NAND2X1 g35792_9315(.A (n_51), .B (n_23), .Y (n_48));
NOR2X1 g35807_9945(.A (n_141), .B (n_51), .Y (n_47));
NAND2BX1 g35782_2883(.AN (n_14), .B (n_79), .Y (n_46));
NAND2X1 g35888_2346(.A (n_36), .B (n_45), .Y (n_71));
XNOR2X1 g35810_1666(.A (n_29), .B (n_38), .Y (n_44));
OAI22X1 g35812_7098(.A (n_41), .B (n_69), .Y (n_43));
INVX1 g35813_7098(.A (n_38), .Y (n_42));
INVX1 g35816_(A (n_151), .Y (n_72));
XNOR2X1 g35812_6417(.A (n_32), .B (n_41), .Y (n_78));
NOR2X1 g35831_2398(.A (B[2]), .B (n_18), .Y (n_40));
OAI21X1 g35834_5107(.A0 (A[1]), .A1 (n_24), .B0 (n_88), .Y (n_39));
NOR2BX1 g35794_6260(.AN (n_53), .B (n_54), .Y (n_65));

```

Ln 186, Col 58 12,949 characters Ln 235, Col 57 12,949 characters Ln 235, Col 57 12,949 characters

80% Unix (LF) 80% Unix (LF) 80% Unix (LF)

Unix (LF) Unix (LF) Unix (LF)

UTF-8 UTF-8 UTF-8

09:51 04-08-2024 ENG IN 28°C Mostly cloudy

## 7. Method of writing a script file (.tcl) for synthesis:

1.) Create a file with .tcl extension in synthesis folder and type the following commands and save it:

```

set_attribute init_lib_search_path /home/student/Desktop/21BEC1033/lib/
set_attribute init_hdl_search_path /home/student/Desktop/21BEC1033/rtl/

set_attribute library slow_vdd1v0_basicCells.lib
read_hdl {alu_4bit.v}

elaborate
read_sdc alu_constraints_top.g

set_attribute syn_generic_effort medium
set_attribute syn_map_effort medium
set_attribute syn_opt_effort medium

syn_generic
syn_map
syn_opt

write_netlist > alu_netlist.v
write_sdc > alu.sdc
gui_show

report_timing > alu_timing.rep
report_area > alu_area.rep
report_power > alu_power.rep

```

2.) After creating the .g and .tcl file open the terminal of synthesis folder and run the following commands:

```
'csh'  
'source /home/install/cshrc'  
'genus -legacy -ui -f alu.tcl'
```



```
File Edit View  
  
set_attribute init_lib_search_path /home/student/Desktop/21BEC1033/lib/  
set_attribute init_hdl_search_path /home/student/Desktop/21BEC1033/rtl/  
  
set_attribute library slow_vdd1v0_basicCells.lib  
read_hdl {alu_4bit.v}  
  
elaborate  
read_sdc alu_constraints_top.sdc  
  
set_attribute syn_generic_effort medium  
set_attribute syn_map_effort medium  
set_attribute syn_opt_effort medium  
  
syn_generic  
syn_map  
syn_opt  
  
write_netlist > alu_netlist.v  
write_sdc > alu.sdc  
gui_show  
  
report_timing > alu_timing.rep  
report_area > alu_area.rep  
report_power > alu_power.rep  
  
Ln 14, Col 12 549 characters 100% Windows (CRLF) UTF-8
```

## 8. Genus Schematic:



## 9. Functional verification:



# Vellore Institute of Technology, Chennai

## BECE407P - ASIC Design

### Lab-3

#### ***Running the Basic Synthesis Flow using Cadence® Genus***

Name of the Student: PRANAV.G

Roll Number: 21BEC1033

Date of the Lab. Class: 1/08/24

1. **Aim:** To design , verify and to synthesize 4 bit ripple carry adder .

2. **EDA Tools Used:**

Cadence® Genus and Cadence® Naunch

3. **Details of the Synthesis Flow:** (with clear snapshots)

(a) Method of writing a script file (.g) for input *Timing Constraints*:

1.) Create a file with .g extension in the synthesis folder.

2.) Open it and write the following commands and save it:

```
create_clock -name clk -period 10 -waveform {0 5} [get_ports "clk"]
set_clock_transition -rise 0.1 [get_clocks "clk"]
set_clock_transition -fall 0.1 [get_clocks "clk"]
set_clock_uncertainty 0.01 [get_ports "clk"]

set_input_delay -max 1.0 [get_ports "a"] -clock [get_clocks "clk"]
set_input_delay -max 1.0 [get_ports "b"] -clock [get_clocks "clk"]
set_output_delay -max 1.0 [get_ports "s"] -clock [get_clocks "clk"]
set_output_delay -max 1.0 [get_ports "c_out"] -clock [get_clocks "clk"]
```



The screenshot shows a terminal window titled "rca\_constraints\_top.g". The window contains a script for setting up timing constraints. The script includes commands to create a clock named "clk" with a period of 10 units, set clock transition times for rise and fall, and specify input and output delays for ports "a", "b", "s", and "c\_out". The bottom status bar indicates the file is at line 11, column 1, with 489 characters, at 100% zoom, in Unix (LF) mode, and using UTF-8 encoding.

```
create_clock -name clk -period 10 -waveform {0 5} [get_ports "clk"]
set_clock_transition -rise 0.1 [get_clocks "clk"]
set_clock_transition -fall 0.1 [get_clocks "clk"]
set_clock_uncertainty 0.01 [get_ports "clk"]

set_input_delay -max 1.0 [get_ports "a"] -clock [get_clocks "clk"]
set_input_delay -max 1.0 [get_ports "b"] -clock [get_clocks "clk"]
set_output_delay -max 1.0 [get_ports "s"] -clock [get_clocks "clk"]
set_output_delay -max 1.0 [get_ports "c_out"] -clock [get_clocks "clk"]
```

Ln 11, Col 1 | 489 characters | 100% | Unix (LF) | UTF-8

(b) Steps to start *Cadence® Genus*:

- 1.) Open the synthesis folder terminal .
- 2.) run the following commands : 'csh' , 'source /home/install/cshrc' , 'genus -legacy -ui' .

(c) Steps to “load the required libraries, designs and synthesizing those designs”:

- 1.) After opening the genus set the library and rtl folder path by using the commands :

```
'set_attribute init_lib_search_path /home/student/Desktop/21BEC1033/lib/ '
'set_attribute init_rtl_search_path /home/student/Desktop/21BEC1033/rtl/ '
```

- 2.) Now load the library using the command :

```
'set_attribute library slow_vdd1v0_basicCells.lib '
```

- 3.) Now read the counter.v file by using the command :'

```
read_hdl ripple_carry_adder_4bit.v'
```

- 4.) Elaborate the design by using the command: 'elaborate'.

- 5.) Now read the timing constraints file by using the command :

```
'read_sdc rca_constraints_top.g'
```

- 6.) To synthesize the design run the command:

```
'set_attribute syn_generic_effort medium'
'syn_generic'
iset_attribute syn_map_effort high'
iset_attribute syn_opt_effort high'
```

```
'syn_map'
'syn_opt'
```

## 4. Cadence® Genus Legacy terminal after Synthesis: [Terminal](#) (click the link for viewing entire terminal)



```

Normal exit.
[student@cad21 synthesis]$ csh
[student@cad21 synthesis]$ source /home/install/cshrc

Welcome to Cadence tools Suite

[student@cad21 synthesis]$ genus -legacy_ui -f ripple.tcl
2024/08/02 12:32:26 WARNING This OS does not appear to be a Cadence supported Linux configuration.
2024/08/02 12:32:26 For more info, please run checkSysConf in <cdsRoot/tools.lnx86/bin/checkSysConf <productId>
TMPDIR is being set to /tmp/genus_temp_7058_cad21_student_FDP3Yr
Cadence Genus(TM) Synthesis Solution.
Copyright 2022 Cadence Design Systems, Inc. All rights reserved worldwide.
Cadence and the Cadence logo are registered trademarks and Genus is a trademark
of Cadence Design Systems, Inc. in the United States and other countries.

[12:32:26.095617] Configured lic search path (21.01-s002): 5280@cadence

Version: 21.14-s002_1, built Thu Jun 23 02:02:08 PDT 2022
Options: -legacy_ui -files ripple.tcl
Date: Fri Aug 02 12:32:26 2024
Host: cad21 (x86_64 w/Linux 4.18.0-425.19.2.el8_7.x86_64) (12cores*20cpus*1physical cpu*12th Gen Intel(R) Core(TM) i7-12700 25600KB) (32402340KB)
PID: 7058
OS: Red Hat Enterprise Linux release 8.8 (osptpa)

[12:32:26.385730] Periodic lic check successful
[12:32:26.385730] Feature usage summary:
[12:32:26.385731] Genus_Synthesis
Checking out license: Genus_Synthesis

*****
***** Loading tool scripts...
Finished loading tool scripts (3 seconds elapsed).

Ln 1, Col 1 73.631 characters
100% Unix (LF) UTF-8
Wi - SA Live
Search
L W
ENG IN 07:16 08-08-2024

```



```

# Processing -files option
@genus 1> source ripple.tcl
Setting attribute of root '/': 'init_lib_search_path' = /home/student/Desktop/21BEC1033/lib/
Setting attribute of root '/': 'init_hdl_search_path' = /home/student/Desktop/21BEC1033/rtl/
Threads Configured:

Message Summary for Library slow_vddiv0_basicCells.lib:
*****
Missing a function attribute in the output pin definition. [LBR-518]: 1
*****
Info : Created nominal operating condition. [LBR-412]
: Operating condition 'nominal' was created for the PVT values (1.000000, 0.900000, 125.000000) in library 'slow_vddiv0_basiccells.lib'.
: The nominal operating condition is represented, either by the nominal PVT values specified in the library source (via nom_process.nom_voltage and nom_temperature respectively), or by the default PVT values (1.0,1.0,1.0).
Warning : Library cell has no output pins defined. [LBR-9]
: Library cell 'ANTENNA' must have an output pin.
: Add the missing output pin(s), then reload the library. Else the library cell will be marked as timing model i.e. unusable. Timing model means that the cell does not have any defined function. If there is no output pin, Genus will mark library cell as unusable i.e. the attribute 'usable' will be marked to 'false' on the libcell. Therefore, the cell is not used for mapping and will not be picked up from the library for synthesis. If you query the attribute 'unusable_reason' on the libcell; result will be: 'Library cell has no output pins.' Note: The message LBR-9 is only for the logical pins and not for the power_ground pins. Genus will depend upon the output function defined in the pin group (output pin) of the cell, to use it for mapping. The pg_pin will not have any function defined.
Warning : Library cell has no output pins defined. [LBR-9]
: Library cell 'ANTENNA' must have an output pin.
Warning : Library cell has no output pins defined. [LBR-9]
: Library cell 'DECAP10' must have an output pin.
Warning : Library cell has no output pins defined. [LBR-9]
: Library cell 'DECAP10' must have an output pin.
Warning : Library cell has no output pins defined. [LBR-9]
: Library cell 'DECAP2' must have an output pin.
Warning : Library cell has no output pins defined. [LBR-9]
: Library cell 'DECAP2' must have an output pin.
Warning : Library cell has no output pins defined. [LBR-9]
: Library cell 'DECAP3' must have an output pin.
Warning : Library cell has no output pins defined. [LBR-9]
: Library cell 'DECAP3' must have an output pin.
Warning : Library cell has no output pins defined. [LBR-9]
: Library cell 'DECAP4' must have an output pin.
Warning : Library cell has no output pins defined. [LBR-9]
: Library cell 'DECAP4' must have an output pin.

Ln 35, Col 1 73.631 characters
100% Unix (LF) UTF-8
26°C Mostly cloudy
Search
L W
ENG IN 07:16 08-08-2024

```

```

ripple_terminal x +
File Edit View
Info : Done Elaborating Design. [ELAB-3]
      : Done elaborating 'ripple_carry_adder_4bit'.
Warning : Black-boxes are represented as unresolved references in the design. [TUI-273]
      : Cannot resolve reference to 'full_adder'.
      : Run check_design to get all unresolved instance. To resolve the reference, either load a technology library containing the cell by appending to the 'library' attribute, or read in the hdl file containing the module before performing elaboration. As the design is incomplete, synthesis results may not correspond to the entire design.
Checking for analog nets...
Check completed for analog nets...
Checking for source RTL...
Check completed for source RTL...
Running Unified Mux Engine Tricks...
Completed Unified Mux Engine Tricks...

Stage: post_elab
| Trick | Accepts | Rejects | Runtime (ms) |
| ume_constant_mux | 0 | 0 | 0.00 |

Starting clip mux common data inputs [v1.0] (stage: post_elab, startdef: ripple_carry_adder_4bit, recur: true)
Completed clip mux common data inputs (accepts: 0, rejects: 0, runtime: 0.000s)
Starting clip the non-user hierarchies [v2.0] (stage: post_elab, startdef: ripple_carry_adder_4bit, recur: true)
Completed clip the non-user hierarchies (accepts: 0, rejects: 0, runtime: 0.000s)

Stage: post_elab
| Transform | Accepts | Rejects | Runtime (ms) |
| hlo_clip_mux_input | 0 | 0 | 0.00 |
| hlo_clip | 0 | 0 | 0.00 |

Statistics for commands executed by read_sdc:
"create_clock" - successful 1 , failed 0 (runtime 0.00)
"get_clocks" - successful 6 , failed 0 (runtime 0.00)
"get_ports" - successful 6 , failed 0 (runtime 0.00)
"set_clock_transition" - successful 2 , failed 0 (runtime 0.00)
"set_clock_uncertainty" - successful 1 , failed 0 (runtime 0.00)
"set_input_delay" - successful 2 , failed 0 (runtime 0.00)
"set_output_delay" - successful 2 , failed 0 (runtime 0.00)
read_sdc completed in 00:00:00 (hh:mm:ss)
Setting attribute of root '/' : 'svn_generic_effort' = medium
Ln 151, Col 59 73.631 characters

```

```

26°C Desktop - OneDrive
ripple_terminal x +
File Edit View
| PA-7 | Info | 4 | there is no power intent loaded. |
| PA-7 | Info | 4 | All computed switching activities are removed. |
| SYNTH-5 | Info | 1 | Done mapping. |
| SYNTH-7 | Info | 1 | Incrementally optimizing. |

Info : Done incrementally optimizing. [SYNTH-8]
      : Done incrementally optimizing 'ripple_carry_adder_4bit'.
Finished SDC export (command execution time rmmiss (real) = 0:00:00).
Warning : The details given in report might be incorrect or incomplete. [RPT-80]
      : The design ./designs/ripple_carry_adder_4bit should be mapped to get accurate area details.
      : Map the design using syn_map before using the '-detail' option of the 'report_area' command.
Info : Joules engine is used. [RPT-16]
      : Joules engine is being used for the command report_power.
Info : ACTP-0001 [ACTPInfo] Activity propagation started for stim#0 netlist
      : ripple_carry_adder_4bit
Info : ACTP-0001 Activity propagation ended for stim#0
Info : PWRA-0001 [PwriInfo] compute_power effective options
      : mode : vectorless
      : -skip_propagation : 1
      : -frequency_scaling_factor : 1.0
      : -use_clock_freq : stim
      : stim : /stim#0
      : -fromGates : 1
Info : ACTP-0001 Timing initialization started
Info : ACTP-0001 Timing initialization ended
Info : PWRA-0002 [PwriInfo] Skipping activity propagation due to _skip_ap
      : option...
Warning : PWRA-0302 [PwriWarn] Frequency scaling is not applicable for vectorless
      : flow. Ignoring frequency scaling.
Warning : PWRA-0304 [PwriWarn] -stim option is not applicable with vectorless mode
      : of power analysis, ignored this option.
Info : PWRA-0002 Started 'vectorless' power computation.
Info : PWRA-0002 Finished power computation.
Info : PWRA-0007 [PwriInfo] completed successfully.
      : Info=6, Warn=2, Error=0, Fatal=0
Output file: rca_power.rep
WARNING: This version of the tool is 770 days old.
legacy_genus:/>

Ln 319, Col 53 73.631 characters

```

```

Humid Now
ripple_terminal x +
File Edit View
| ume_runtime | 0 | 0 | 0.00 |

Number of big b'muxes before = 0
Info : Pre-processed datapath logic. [DPOPT-6]
      : No pre-processing optimizations applied to datapath logic in 'ripple_carry_adder_4bit'.
Info : Skipping datapath optimization. [DPOPT-5]
      : There is no datapath logic in 'ripple_carry_adder_4bit'.
Number of big b'muxes after = 0
Starting logic reduction [v1.0] (stage: post_rlopt, startdef: ripple_carry_adder_4bit, recur: true)
Completed logic reduction (accepts: 0, rejects: 0, runtime: 0.000s)
Starting mux data reorder optimization [v1.0] (stage: post_rlopt, startdef: ripple_carry_adder_4bit, recur: true)
Completed mux data reorder optimization (accepts: 0, rejects: 0, runtime: 0.000s)

Stage: post_rlopt
| Transform | Accepts | Rejects | Runtime (ms) |
| hlo_logic_reduction | 0 | 0 | 0.00 |
| hlo_mux_reorder | 0 | 0 | 0.00 |

Starting mux speculation [v1.0] (stage: post_muxopt, startdef: ripple_carry_adder_4bit, recur: true)
Starting speculation optimization
Completed speculation optimization (accepts:0)
Completed mux speculation (accepts: 0, rejects: 0, runtime: 0.001s)

Stage: post_muxopt
| Transform | Accepts | Rejects | Runtime (ms) |
| hlo_speculation | 0 | 0 | 1.00 |

=====
Stage : to_generic
=====
Message Summary
=====

| Id | Sev | Count | Message Text |
| --- | --- | --- | --- |
| 1 | INFO | 1 | Warning! In legacy mode, Genius creates a blank hw.acf file.

Ln 164, Col 36 73.631 characters

```

## 5. Generate & Read the Reports: (with clear snapshots)

For generating the report run the following commands:

```
report_timing > rca_timing.rep
```

```
report_area > rca_area.rep
```

```
report_power > rca_power.rep
```

The screenshot shows three terminal windows side-by-side, each displaying a synthesis report for a ripple carry adder.

- rca\_power.rep:** Displays power consumption details. It includes a table for leakage power by category (memory, register, latch, logic, bbox, clock, pad, pm) and a summary table for total power consumption.
- rca\_timing.rep:** Displays timing constraints. It shows generated by information (Genus(TM) Synthesis Solution 21.14-s082\_1, Aug 02 2024 12:32:31 pm), module (ripple\_carry\_adder\_4bit), technology library (slow\_vddlv0 1.0), operating conditions (PVT\_0P9V\_125C (balanced\_tree)), wireload mode (enclosed), and area mode (timing library). It also lists pins, types, fanout, load, slew, delay, and arrival times.
- rca\_area.rep:** Displays area usage. It includes a table for total area by instance and a note that wireload is default in the technology library.

## 6. Writing the Output files: (with clear snapshots)

Run the following commands to write the output files:

```
write_netlist > rca_netlist.v (alu\_netlist--link)
```

```
write_sdc > rca.sdc
```

rca.sdc

File Edit View

```
# #####  
# Created by Genus(TM) Synthesis Solution 21.14-s082_1 on Fri Aug 02 12:32:31 IST 2024  
# #####  
  
set sdc_version 2.0  
  
set_units -capacitance 1000fF  
set_units -time 1000ps  
  
# Set the current design  
current_design ripple_carry_adder_4bit  
  
create_clock -name "clk" -period 10.0 -waveform {0.0 5.0} [get_ports clk]  
set_clock_transition 0.1 [get_clocks clk]  
set_clock_gating_check -setup 0.0  
set_input_delay -clock [get_clocks clk] -add_delay -max 1.0 [get_ports {a[3]}]  
set_input_delay -clock [get_clocks clk] -add_delay -max 1.0 [get_ports {a[2]}]  
set_input_delay -clock [get_clocks clk] -add_delay -max 1.0 [get_ports {a[1]}]  
set_input_delay -clock [get_clocks clk] -add_delay -max 1.0 [get_ports {a[0]}]  
set_input_delay -clock [get_clocks clk] -add_delay -max 1.0 [get_ports {b[3]}]  
set_input_delay -clock [get_clocks clk] -add_delay -max 1.0 [get_ports {b[2]}]  
set_input_delay -clock [get_clocks clk] -add_delay -max 1.0 [get_ports {b[1]}]  
set_input_delay -clock [get_clocks clk] -add_delay -max 1.0 [get_ports {b[0]}]  
set_output_delay -clock [get_clocks clk] -add_delay -max 1.0 [get_ports {s[3]}]  
set_output_delay -clock [get_clocks clk] -add_delay -max 1.0 [get_ports {s[2]}]  
set_output_delay -clock [get_clocks clk] -add_delay -max 1.0 [get_ports {s[1]}]  
set_output_delay -clock [get_clocks clk] -add_delay -max 1.0 [get_ports {s[0]}]  
set_output_delay -clock [get_clocks clk] -add_delay -max 1.0 [get_ports c_out]  
set_wire_load_mode "enclosed"  
set_clock_uncertainty -setup 0.01 [get_ports clk]  
set_clock_uncertainty -hold 0.01 [get_ports clk]
```

rca\_netlist.v

File Edit View

```
// Generated by Cadence Genus(TM) Synthesis Solution 21.14-s082_1  
// Generated on: Aug 2 2024 12:32:31 IST (Aug 2 2024 07:02:31 UTC)  
  
// Verification Directory fv/ripple_carry_adder_4bit  
  
module ripple_carry_adder_4bit(a, b, clk, s, c_out);  
    input [3:0] a, b;  
    input clk;  
    output [3:0] s;  
    output c_out;  
    wire [3:0] a, b;  
    wire clk;  
    wire [3:0] s;  
    wire c_out;  
    wire [3:0] carry;  
    full_adder fa0(.a (a[0]), .b (b[0]), .c (1'b0), .clk (clk), .s  
        (s[0]), .c_out (carry[0]));  
    full_adder fa1(.a (a[1]), .b (b[1]), .c (carry[0]), .clk (clk), .s  
        (s[1]), .c_out (carry[1]));  
    full_adder fa2(.a (a[2]), .b (b[2]), .c (carry[1]), .clk (clk), .s  
        (s[2]), .c_out (carry[2]));  
    full_adder fa3(.a (a[3]), .b (b[3]), .c (carry[2]), .clk (clk), .s  
        (s[3]), .c_out (c_out));  
endmodule
```

Ln 1, Col 1 | 813 characters | 100% | Unix (LF) | UTF-8

## **7. Method of writing a script file (.tcl) for synthesis:**

**1.)Create a file with .tcl extension in synthesis folder and type the following commands and save it:**

```
set_attribute init_lib_search_path /home/student/Desktop/21BEC1033/lib/  
set_attribute init_hdl_search_path /home/student/Desktop/21BEC1033/rtl/  
  
set_attribute library slow_vdd1v0_basicCells.lib  
read_hdl {ripple_carry_adder_4bit.v}  
  
elaborate  
read_sdc rca_constraints_top.g  
  
set_attribute syn_generic_effort medium  
set_attribute syn_map_effort medium  
set_attribute syn_opt_effort medium  
  
syn_generic  
syn_map  
syn_opt  
  
write_netlist > rca_netlist.v  
write_sdc > rca.sdc  
gui_show  
  
report_timing > rca_timing.rep  
report_area > rca_area.rep  
report_power > rca_power.rep
```

**2.)After creating the .g and .tcl file open the terminal of synthesis folder and the run the following commands:**

```
'csh'  
'source /home/install/cshrc'  
'genus -legacy -ui -f ripple.tcl'
```

ripple.tcl

```

File Edit View

set_attribute init_lib_search_path /home/student/Desktop/21BEC1033/lib/
set_attribute init_hdl_search_path /home/student/Desktop/21BEC1033/rtl/

set_attribute library slow_vdd1v0_basicCells.lib
read_hdl {ripple_carry_adder_4bit.v}

elaborate
read_sdc rca_constraints_top.g

set_attribute syn_generic_effort medium
set_attribute syn_map_effort medium
set_attribute syn_opt_effort medium

syn_generic
syn_map
syn_opt

write_netlist > rca_netlist.v
write_sdc > rca.sdc
gui_show

report_timing > rca_timing.rep
report_area > rca_area.rep
report_power > rca_power.rep

```

Ln 5, Col 37 | 564 characters | 100% | Windows (CRLF) | UTF-8

## 8. Genus Schematic:



## 9. Functional verification:

