

-Create your own copy with **File > Make a Copy**, or download the file with **File > Download**.

521404A Digital Techniques 2

# Laboratory Exercises Report 2025

Name and student number: Arafat Miah (2512200)

Other contributors (if done in cooperation):

In this whole lab, I have done all by myself, but as my english is not professional because I haven't came from an English speaking country, I sometimes use AI to furnish my writing, except that everything is done by myself

[Lab 1: Data Types](#)

[Lab 2: Structural Modeling](#)

[Lab 3: Combinational Logic Modeling](#)

[Lab 4: Logic Synthesis](#)

[Lab 5: Digital Arithmetic](#)

[Lab 6: Flip-Flops and Registers](#)

[Lab 7: Timing Analysis and Optimization](#)

[Lab 8: Finite State Machine Design](#)

[Lab 9: Testbench Techniques](#)

[Lab 10: Gate-Level Verification](#)

[Lab 11: Finite-State Machine - Datapath Interaction](#)

[Lab 12: FPGA Memories](#)

## Lab 1: Data Types

---

Q1. What is the meaning of the following values of the SystemVerilog data type logic.

```
0= logical 0  
1= logical 1  
X= unknown  
Z= high-impedance
```

Q2. What is the value of variable **one\_byte** or **word32** after execution of the following statements in **binary** and **hexadecimal** format:

a)

```
logic [7:0] one_byte;  
one_byte = 8'b11111111;  
one_byte = '0;
```

b)

```
logic [7:0] one_byte;  
one_byte = 8'b11111110;  
one_byte = 1;
```

c)

```
logic [3:0] [7:0] four_bytes;  
logic [31:0] word32;  
four_bytes = c1;  
four_bytes[3] = '0;  
word32 = four_bytes;
```

a) one\_byte = 8'b00000000; and in hexa decimal= 8'h00

b) one\_byte = 8'b00000001; and in hexa decimal= 8'h01

c) word32 = 32'b00000000\_11111111\_11111111\_11111111 and in hex=32'h00ffff

Q3. With how many bits would variable **colors** be represented in SystemVerilog, if the definition logic [1:0] were removed from the following variable declaration?

```
enum logic [1:0] { RED = 2'b00, GREEN = 2'b01, BLUE = 2'b10, WHITE = 2'b11 } colors;
```

32 bits

Q4. Assume the following variable definition and initializations, and answer the questions presented in the text box. (tip: edit test Q4 in input/datatypes\_tb.sv to check).

```
logic [3:0] a = 4'b0101;  
logic [3:0] b = 4'hc;  
logic [3:0] c;
```

- a) After the operation `c = a & b`; the value of `c` is ‘h4 and ‘b100
- b) After the operation `c = a && b`; the value of `c` is ‘h1 and ‘b0001
- c) After the operation `c = |a`; the value of `c` is ‘h1 and ‘b0001
- d) After the operation `c = a >> 2`; the value of `c` is ‘h1 and ‘b0001
- e) After the operation `c = { 2'b01 2'b11 }`; the value of `c` is ‘h7 and ‘b0111

I did the hand calculation by myself.

## Lab 2: Structural Modeling

---

### Q1. Design Hierarchy Exploration (Ex 3.2)

| Design Hierarchy View                                                             | Source Code                                                                                                                                                                                                                                                                                                                                                                                         |
|-----------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|  | <p>Name the file(s), and paste code that defines the selected top-level module (effreg_tb) and the items in the Object window.</p> <p>Example:</p> <pre>File X.sv:<br/>/homedir01/amiah25/DT2_2025/labs/lab2_effreg/<br/>input/effreg_tb.sv (/effreg_tb)<br/>pasted code here: module effreg_tb;<br/>    logic clk, rst_n, enable;<br/>    logic [3:0] data_in;<br/>    logic [3:0] data_out;</pre> |

| Design Hierarchy View                                                              | Source Code                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|  | <p>Name the file(s), and paste code that creates the selected module instance, the respective module and the items in the Object window.</p> <p>File X.sv:<br/>/homedir01/amiah25/DT2_2025/labs/lab2_effreg/<br/>input/effreg.sv (/effreg_tb/DUT)<br/>pasted code here: effreg #(NBITS(4)) DUT<br/>    (.clk(clk),<br/>     .rst_n(rst_n),<br/>     .din(data_in),<br/>     .enable(enable),<br/>     .dout(data_out));</p> |

| Design Hierarchy View                                                               | Source Code                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|  | <p>Name the file(s), paste code that defines the selected object in the Sim window, and explain the purpose of the variable I shown in the Objects window.</p> <p>File X.sv:<br/>/homedir01/amiah25/DT2_2025/labs/lab2_effreg/<br/>input/effreg.sv<br/>(/effreg_tb/DUT/eff_generate[3])<br/>pasted code here: generate<br/>    for (genvar I = 0; I &lt; NBITS; ++I)<br/>begin : eff_generate<br/>    eff eff_inst (.clk(clk),<br/>     .rst_n(rst_n), .din(din[I]), .enable(enable),<br/>     .q(dout[I]));<br/>end</p> |

|  |                                                                                                                                   |
|--|-----------------------------------------------------------------------------------------------------------------------------------|
|  | <pre>endgenerate</pre> <p>Purpose of I: It is used to generate the multiple instances of the main module which is effreg here</p> |
|--|-----------------------------------------------------------------------------------------------------------------------------------|

| Design Hierarchy View | Source Code                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|-----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                       | <p>Name the file(s), and paste code that creates the selected module instance, the respective module and the items in the Object window.</p> <p>File X.sv:</p> <pre>/homemdir01/amiah25/DT2_2025/labs/lab2_effreg/ input/effreg.sv (/effreg_tb/DUT/eff_generate[3]/eff_inst) pasted code here: module eff (input logic clk, rst_n, din, enable, output logic q);  logic n1, n2, n3, n4, n5, n6, n7;  assign n1 = enable; assign n2 = din; assign q = n7;  dff U1 (.clk(clk), .rst_n(rst_n), .din(n6), .q(n7)); or2 U2 (.in1(n4), .in2(n5), .out1(n6)); and2 U3 (.in1(n1), .in2(n2), .out1(n4)); and2 U4 (.in1(n3), .in2(n7), .out1(n5)); inv U5 (.in1(n1), .out1(n3));  endmodule</pre> |

## Q2. Schematic Generation (Ex 3.3)

| Schematic View                               |
|----------------------------------------------|
| <p>Insert reports/eff_inst_schematic.png</p> |



**Source Code:**

Name the file(s), and paste code that declares the interconnect wires and creates the module instances U1 - U2.

File X.sv: /homedir01/amiah25/DT2\_2025/labs/lab2\_effreg/input/effreg.sv  
(/effreg\_tb/DUT/eff\_generate[0]/eff\_inst/U1)

Source code: dff U1 (.clk(clk), .rst\_n(rst\_n), .din(n6), .q(n7));  
or2 U2 (.in1(n4), .in2(n5), .out1(n6));

### Q3. Wave Window Usage (Ex 3.4)

**Wave View**

Insert reports/add\_wave.png

Source Code: /homedir01/amiah25/DT2\_2025/labs/lab2\_effreg/input/effreg.sv  
(/effreg\_tb/DUT/eff\_generate[0]/eff\_inst)

Paste the TCL (tool command language) statement from wave.do that added the net to the Wave window.  
gedit workdir/wave.do &

### Q4. Simulation - Debug (Ex 4)

**Wave View with \$info Message**

Insert reports/wave\_with\_info.png

```
[Transcript] + [E]
#
# if { [info exists RTL_FILES ] } {
#     eval vlog -work work ${RTL_FILES}
# }
# QuestaSim-64 vlog 2022.4_1 Compiler 2022.11 Nov 11 2022
# Start time: 16:00:27 on Sep 15,2025
# vlog -reportprogress 300 -work work input/effreg.sv
# -- Compiling module and2
# -- Compiling module or2
# -- Compiling module inv
# -- Compiling module dff
# -- Compiling module eff
# -- Compiling module effreg
#
# Top level modules:
#     effreg
# End time: 16:00:27 on Sep 15,2025, Elapsed time: 0:00:00
# Errors: 0, Warnings: 0
# eval vlog -timescale 1ns/1ps -work work ${TESTBENCH_FILES}
# QuestaSim-64 vlog 2022.4_1 Compiler 2022.11 Nov 11 2022
# Start time: 16:00:27 on Sep 15,2025
# vlog -reportprogress 300 -timescale 1ns/1ps -work work input/effreg_tb.sv
# -- Compiling module effreg_tb
# ** Error: (vlog-13069) input/effreg_tb.sv(43): near "#": syntax error, unexpected '#', expecting ';'.
# End time: 16:00:27 on Sep 15,2025, Elapsed time: 0:00:00
# Errors: 1, Warnings: 0
# ** Error: /sw/rhel7/siemens/questa_sim-2022.4_1/questasim/linux_x86_64/vlog failed.
# Error in macro ./scripts/vsim_rtlsim.tcl line 34
# /sw/rhel7/siemens/questa_sim-2022.4_1/questasim/linux_x86_64/vlog failed.
#     while executing
# "vlog -timescale 1ns/1ps -work work input/effreg_tb.sv"
#     ("eval" body line 1)
#     invoked from within
# "eval vlog -timescale 1ns/1ps -work work ${TESTBENCH_FILES}"
QuestaSim>|
```

**Message Viewer:** # \*\* Error: (vlog-13069) input/effreg\_tb.sv(43): near "#": syntax error, unexpected '#', expecting ';'.

Insert reports/message\_viewer.png



## Lab 3. Combinational Logic Modeling

---

### Ex1. Combinational Process Execution in Simulation

Q1. Explain why the process muxa, muxb and add **was** or **was not** executed at the time instances 0, 100, 200 and 300 ns in the simulation.

| Time       | muxa        | muxb     | add      | Explanation                                                                                                                                                                                                                                                                                                                                                                            |
|------------|-------------|----------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>0</b>   | executed    | executed | executed | <pre>sel_in = '0; a1_in = 1; a2_in = 2; b1_in = 3; b2_in = 4; #100ns;</pre> <p>The above part is taken from muxadd_test and we can see that at the start selection pin is set to zero and mux a and mux b is executed, and the adder takes the the input coming from the muxa and muxb , as the input of adder is changed, so the adder is also operate and we will get an output.</p> |
| <b>100</b> | Execute     | Execute  | Execute  | <pre>sel_in = '1; a1_in = 1; a2_in = 2; b1_in = 3; b2_in = 4; #100ns;</pre> <p>Now, this part means that the second part of the test will execute after 100ns. We see that the selection pin has changed, so muxa and muxb will be executed. As the muxes change their outputs, the adder will also execute.</p>                                                                       |
| <b>200</b> | Not execute | execute  | execute  | <pre>sel_in = '1; a1_in = 1; a2_in = 2; b1_in = 3; b2_in = 5; #100ns;</pre> <p>After another 100ns, this part will execute, where we can see that the selection pin remains unchanged, so MUX A will not be executed since its input has not changed. However, MUX B has changed its input, so it will execute, and as a result, the adder will also execute.</p>                      |
| <b>300</b> | execute     | execute  | execute  | <pre>sel_in = '0; #100ns; //all of them execute as the overall selection pin value changes</pre>                                                                                                                                                                                                                                                                                       |

## Ex2. Synthesis Results Examination

Q2. Insert annotated schematic form logic synthesis showing logic gates for the **muxa** procedure.



## Ex 3. Synthesizability Checking and Fixing

Q3. Present the evidence that the combinational logic model was incorrect.

## Gate-Level Schematic

Insert reports/mux with latch.png



## Reference Report

Insert component reference listing from reports/mux.gatelevel.reference.txt and highlight the latch.

The references are:

1. AO21X1\_HVT
2. INVX0\_HVT
3. LATCHX1\_HVT LATCHX1\_HVT (This is the reference for latch)
4. NAND2X0\_HVT
5. NAND3X0\_HVT

## Synthesis Log Warning

Present the latch warning and explain how the tool knew that a latch should not have been synthesized.

Warning: ./input/mux.sv:8: Netlist for always\_comb block contains a latch. (ELAB-974)

The tool knew that because all the inputs have not been assigned a value in all possible situations.

**Q4. Explain what is a latch, and why did the synthesis program generate a latch in the mux logic, and why the incorrect code did not produce wrong simulation results.**

A latch can store the previous data as it has two stable states. In this mux circuit, the latch is generated because in this combination block, all inputs have not been assigned under all possible conditions in the test bench.

The wrong code did not produce a wrong simulation because, from the Verilog language rule, if a variable is not assigned a new value in any procedural block, it will hold its earlier value.

**Q5. What are some of the common coding principles for avoiding accidentally creating latches?**

1. Always use always\_comb
2. Assign all the possible new value for every procedural block
3. For all the output, Assign a default value

**Q6. Present the fixed code.**

```
module mux
  (input logic [1:0] sel_in,
   input logic      a_in,
   input logic      b_in,
   input logic      c_in,
   output logic     mux_out);

  always_comb
    begin : mux_logic
      case (sel_in)
        2'b00: mux_out = a_in;
        2'b01: mux_out = b_in;
        2'b10: mux_out = c_in;
        2'b11: mux_out = c_in;
      endcase
    end : mux_logic
endmodule
```

**Note:** I also modified the test bench to see if my code is working perfectly in the simulation or not.

```
program mux_test
  (output logic [1:0] sel_in,
   output logic a_in,
   output logic b_in,
   output logic c_in,
   input logic     mux_out);

  initial
    begin
      sel_in = 2'b00;
      a_in = '0;
      b_in = '0;
      c_in = '0;

      #10ns;
      sel_in = 2'b01;
      a_in = '1;
      b_in = '1;
      c_in = '0;

      #10ns;
      sel_in = 2'b10;
      a_in = '0;
      b_in = '0;
      c_in = '1;
```

```
#10ns;  
sel_in = 2'b11;  
  
#10ns;  
  
$finish;  
  
end  
endprogram
```

Q7. Present the reference report for the synthesized fixed code.

1. INVX0\_HVT
2. INVX1\_HVT
3. NAND2X0\_HVT
4. NAND3X0\_HVT
5. OR2X1\_HVT

## Lab 4. Logic Synthesis

---

Q1. Insert your area-vs-delay graph for the **acs** design optimized with different timing constraints





Q2. Explain the results!

A **low area** circuit is typically slow but low-power. To make a circuit **faster**, we must increase the area and power by using more complex, higher-performance gates.

Q3. How many components are on the critical path in the final (fastest) case?

Ans: 27



## Lab 5. Digital Arithmetic

### Ex1. Datapath Sizing

Q1. Present your parameter settings for the **dotp** exercise and justify them!

- a) localparam MB =16; as we know Multiply bit= Bits in DB+Bits in SB
- b) localparam SB = 19; as My last 3<sup>rd</sup> digit is 0 so my L=0 and parameter NTAPS= 6  
So, as we can see from the dataflow graph of the algorithm, there will be 6 blocks, and each block's result is added to the next stage block. So, as we know from the hardware adding formula, the Result bit length is,  
Result bit length= max(bit in DB, bits in CB)+1;  
So after the first iteration of addition, my result will be,  
 $S[0]= \max (16,16)+1=17$
- c) localparam QB = 8;



### Ex2. Datapath bit-width optimization

Q1. Present your parameter settings for the **dotp** exercise and justify them!

- a) localparam MB = 28;
- b) localparam SB = 32;
- c) localparam QB = 14;
- d) localparam logic signed [QB-1:0] rmax = **14'b0111\_1111\_1111\_11**;

e) localparam logic signed [QB-1:0] rmin = 14'b1000\_0000\_0000\_00;



## Lab 6: Flip-Flops and Registers

### Ex 1. Flip-flop modeling

Q1. Explain the kind of reset defined for each flip-flop.

| Flip-flop | Reset or Set? | Asynch or Synch? | Active Low or High? |
|-----------|---------------|------------------|---------------------|
| ff1       | Set           | Asynch           | High                |
| ff2       | Reset         | Asynch           | High                |
| ff3       | Set           | Asynch           | High                |

Q2. Present the gate-level schematic and explain how the reset was implemented

**Gate-Level Schematic**

Insert reports/lab6\_reset\_schematic.png

The screenshot shows a Design Vision software interface with a schematic editor. The main window displays a gate-level schematic for three D flip-flops (ff1, ff2, ff3). Each flip-flop has its data input (d\_in), clock input (clk), and reset input (reset). The reset input for each flip-flop is connected to the output of a NOT gate (B4). The outputs of the flip-flops (ff1\_out, ff2\_out, ff3\_out) are also connected to the reset inputs of the other flip-flops via inverter gates. The console window at the bottom left shows the command history for creating the schematic.

**Explanations**

Asynchronous Reset: when reset and RSTB occur (active-low) the code instantly clear ff1\_out\_reg, ff2\_out\_reg, and ff3\_out\_reg and that is independent of clk.

### Ex 2. Variable assignments in a sequential process

Q3. Present a gate-level schematic of the bad design and explain why flip-flops were generated or not generated for these variables/ports assigned inside an always procedure?

**Gate-Level Schematic**

Insert reports/lab6\_syncvar\_bad.png



Q4. Present a gate-level schematic of the fixed design and explain the fix?

#### Gate-Level Schematic

Insert reports/lab6\_syncvar\_good.png



## Explanation

The overall operation turns into a synchronous operation with terms to rising edge of the clk and it avoids glitches with using non blocking assignments and ensures accurate flip flop for ab\_r and xor\_out

## Lab 7: Timing Analysis and Optimization

### Ex 1. Sequential Circuit Synthesis

Q1) Show and explain the register inference report from the synthesis log (also available as reports/dc.log)

| Register Inference Report |           |       |     |    |    |    |    |    |    |  |
|---------------------------|-----------|-------|-----|----|----|----|----|----|----|--|
| Register Name             | Type      | Width | Bus | MB | AR | AS | SR | SS | ST |  |
| state_r_reg               | Flip-flop | 4     | Y   | N  | N  | N  | Y  | N  | N  |  |

**Explanation**

This indicates a **4-bit synchronous flip-flop** used for state control

### Ex 2. Timing Analysis

Q2. Present a gate-level schematic with the critical path highlighted



Q3) Show the timing report (starting from the path listing), and explain its meaning.

| Timing Report               |      |      |  |
|-----------------------------|------|------|--|
| Point                       | Incr | Path |  |
| clock clk (rise edge)       | 0.00 | 0.00 |  |
| clock network delay (ideal) | 0.00 | 0.00 |  |

|                                |       |         |
|--------------------------------|-------|---------|
| state_r_reg_0_/CLK (DFFX1_HVT) | 0.00  | 0.00 r  |
| state_r_reg_0_/Q (DFFX1_HVT)   | 0.14  | 0.14 r  |
| U29/Y (NAND2X0_HVT)            | 0.13  | 0.27 f  |
| U31/Y (INVX0_HVT)              | 0.08  | 0.35 r  |
| U34/Y (AND3X1_HVT)             | 0.12  | 0.47 r  |
| U38/Y (OA221X1_HVT)            | 0.13  | 0.60 r  |
| state_r_reg_3_/D (DFFX1_HVT)   | 0.01  | 0.61 r  |
| data arrival time              |       | 0.61    |
| <hr/>                          |       |         |
| clock clk (rise edge)          | 10.00 | 10.00   |
| clock network delay (ideal)    | 0.00  | 10.00   |
| state_r_reg_3_/CLK (DFFX1_HVT) | 0.00  | 10.00 r |
| library setup time             | -0.07 | 9.93    |
| data required time             |       | 9.93    |
| <hr/>                          |       |         |
| data required time             |       | 9.93    |
| data arrival time              |       | -0.61   |
| <hr/>                          |       |         |
| slack (MET)                    |       | 9.32    |

### Explanation

Startpoint: Output Q

Endpoint: Input D

Data arrival time: Together

Library setup time: Explain flip-flop setup time

Data required time: Why is data required to arrive at this time?

Slack: What does this figure tell?

Q4) In gate-level simulation with the shortened clock period, timing violations (probably) occurred. Present the waveforms and explain the first timing error reported.

### Gate Level Simulation Waveforms

reports/lab7\_glsim\_bad.png.



### Error Message and Its Explanation

```
# ** Error: $setup( posedge D:3769 ps, posedge CLK:3821 ps, 72 ps );
#   Time: 3821 ps Iteration: 1 Process: /ctrdivn_tb/DUT/state_r_reg_1_/#Setuphold# File:
/research/cas/public/DT2_2025/lib/verilog/saed32nm_hvt.v Line: 6422
# ** Error: $setup( posedge D:3769 ps, posedge CLK && D_DEFCHK:3821 ps, 72 ps );
#   Time: 3821 ps Iteration: 1 Process: /ctrdivn_tb/DUT/state_r_reg_1_/#Setuphold# File:
/research/cas/public/DT2_2025/lib/verilog/saed32nm_hvt.v Line: 6432
```

The error message reports a **setup time violation** of for flip-flop `state_r_reg_1`. The data () arrived at , which is **too late** to meet the setup requirement before the rising clock edge () at .

### Ex 3. Timing Optimization

Q5) Present the timing optimization constraints you defined

#### Timing Constraints File

```
New clock setting from input/constraints.sdc

create_clock -name clk -period 0.48    clk

set_input_delay -clock clk 0.0 srst
set_input_delay -clock clk 0.0 enable_in
set_output_delay -clock clk 0.0 divn_out

set_driving_cell -lib_cell INVX1_HVT -library saed32hvt_tt1p05v25c { enable_in }
set_load 0.1 divn_out

#Prevent usage of flip-flops with sync reset. This will add
```

```
#one extra AND-gate in the critical path :-)
set_dont_use [get_lib_cell saed32hvt_tt1p05v25c/DFFSSRX*]
```

Q6) Present the timing report following synthesis with the new constraints

| Timing Report                  |       |        |
|--------------------------------|-------|--------|
| Point                          | Incr  | Path   |
| clock clk (rise edge)          | 0.00  | 0.00   |
| clock network delay (ideal)    | 0.00  | 0.00   |
| state_r_reg[1]/CLK (DFFX1_HVT) | 0.00  | 0.00 r |
| state_r_reg[1]/QN (DFFX1_HVT)  | 0.13  | 0.13 f |
| U28/Y (OR2X1_HVT)              | 0.09  | 0.22 f |
| U35/Y (NOR2X0_HVT)             | 0.09  | 0.32 r |
| U36/Y (OR2X1_HVT)              | 0.07  | 0.38 r |
| U40/Y (AND3X1_HVT)             | 0.08  | 0.47 r |
| state_r_reg[3]/D (DFFX1_HVT)   | 0.01  | 0.48 r |
| data arrival time              |       | 0.48   |
|                                |       |        |
| clock clk (rise edge)          | 0.55  | 0.55   |
| clock network delay (ideal)    | 0.00  | 0.55   |
| state_r_reg[3]/CLK (DFFX1_HVT) | 0.00  | 0.55 r |
| library setup time             | -0.07 | 0.48   |
| data required time             |       | 0.48   |
|                                |       |        |
| data required time             |       | 0.48   |
| data arrival time              |       | -0.48  |
|                                |       |        |
| slack (MET)                    |       | 0.00   |

Q7) Present and comment on the results of the final gate-level simulation.

| Gate Level Simulation Waveforms |
|---------------------------------|
| reports/lab7_glsim_good.png.    |



## Comments

The simulation confirms operation correctly and the timing constrain is in my case 0.55

## Lab 8: Finite State Machine Design

---

### Ex 1. ASM Chart Analysis

Q1) Present a state table for the functionality defined by the ASM chart presented in the assignment document.

| State Table   |        |      |            |       |       |
|---------------|--------|------|------------|-------|-------|
| INPUTS        |        |      | OUTPUTS    |       |       |
| Current State | enable | mode | Next State | ready | Pulse |
| Idle          | 0      | 0    | Idle       | 1     | 0     |
| Idle          | 0      | 0    | Idle       | 1     | 0     |
| Idle          | 1      | 0    | Hold       | 1     | 0     |
| Hold          | 1      | 1    | End        | 0     | 1     |
| End           | 1      | 1    | Idle       | 0     | 1     |
| Idle          | 1      | 1    | Hold       | 1     | 0     |
| Hold          | 0      | 1    | Idle       | 0     | 0     |
| Idle          | 0      | 1    | Idle       | 1     | 0     |

Q2) Present the states of outputs ready and pulse.

| Output Values by Clock Cycles |       |       |
|-------------------------------|-------|-------|
| Clock Edge                    | ready | pulse |
| 1                             | 1     | 0     |
| 2                             | 1     | 0     |
| 3                             | 1     | 0     |
| 4                             | 0     | 1     |
| 5                             | 0     | 1     |
| 6                             | 1     | 0     |
| 7                             | 0     | 0     |

|   |   |   |
|---|---|---|
| 8 | 1 | 0 |
|---|---|---|

## Ex 2. RTL Code for ASM

Q3. Describe the bug in the RTL code and how you fixed it.

### Bug Description

The code was correct and runs perfectly.

## Ex 3. FSM Simulation and Debug

Q4. Present the FSM state chart for the fixed version.

### State Chart

Insert reports/lab8\_fsm.png

The diagram seems blur, I don't know how this file lose it's resolution, but when I took the screenshot it was fine.



#### Ex 4. State Encoding

Q3. What kind of state encoding is used in the RTL design?

**Answer**

That was a mealy type encoding

## Lab 9: Testbench Techniques

---

### Ex 1. Testbench Organization

Q1: Explain how the design hierarchy used in RTL simulation was defined in the code.

| RTL Simulation Hierarchy |                |                  |                                                                                                                                                           |
|--------------------------|----------------|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|
| Instance                 | Design unit    | Design unit type | File Name:<br>Declaration (1-3 lines)<br>Explanation                                                                                                      |
| ctr_tb                   | ctr_tb(fast)   | Module           | module ctr_tb;<br>This is a top-level testbench which Instantiates DUT (ctr) and test program (ctr_test). In this part the clock and reset are generated. |
| #ALWAYS#34               | ctr_tb(fast)   | Process          | Inside ctr_tb;<br>This is the always block which will toggle the clk every 0.3ns.                                                                         |
| DUT                      | ctr(fast)      | Module           | module ctr;<br><b>The Design Under Test.</b> It implements the counter logic and has parameters with inputs, outputs, and a sequential always_ff block.   |
| TEST                     | ctr_test(fast) | Program          | program ctr_test;<br>The testbench stimulus generator. It sends data and mode signals, also observe data_out.                                             |
| #INITIAL#15              | ctr_test(fast) | Process          | Inside ctr_test<br>The initial block runs the test sequence (LOAD, UP/DOWN, etc.).                                                                        |
| cb                       | ctr_test(fast) | ClockingBlock    | Inside ctr_test:default clocking cb @(posedge clk);<br>It defines timing and synchronization for driving and sampling signals.                            |

### Ex 4. Simulation with a Reference Model

Q2. Explain how the design hierarchy used in Gate Level vs. RTLI simulation was defined in the code.

### Gate Level vs. RTL Simulation Hierarchy

| Instance     | Design unit        | Design unit type | File Name:<br>Declaration (1-3 lines)<br>Explanation                                                                                                   |
|--------------|--------------------|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|
| ctr_tb       | ctr_tb(fast)       | Module           | module ctr_tb;<br>Top-level testbench, same as RTL. Instantiates both DUT (gate-level) and REF (RTL) counters.                                         |
| DUT          | ctr(fast)          | Module           | module ctr;<br>This time, it is the <b>gate-level synthesized version</b> of the counter. Internally expanded into logic gates and flip-flops.         |
| ctr_r_reg_0_ | DFFARX1_HV T(fast) | Module           | From synthesized netlist<br>It represents one of the <b>flip-flops</b> implementing the register ctr_r[0]. Each bit of the counter becomes a DFF cell. |
| REF          | ctr(fast)          | Module           | module ctr;<br>The <b>reference RTL model</b> used for comparing results against the gate-level DUT.                                                   |

Q3. Explanation of Differences in Timing and Values and the Causes. On which data was the changed timing based on?

### Gate Level vs. RTL Simulation Waveforms

reports/lab9\_gates vs rtl waves.pnf.



Explanations: the RTL implementation considers ideal timing, but the gates have their own

delay, which is considered in gate-level implementation,

## Ex 5. Clocking block usage

Q4. Did the input skew setting have any effect on simulation timing? If timing errors appeared, what caused them?

Gate Level vs, RTL Simulation Waveforms with Input Skew

reports/lab9\_input\_skew\_waves.png.



## Explanations

We have given it very small amount of time with respect to how much it needed, and it could not complete all the data propagation within the given time, and before completing all the tasks next clk cycle arrives.

## Lab 10: Gate-Level Verification

---

Q1) What explains the differences in the operation of output comparators checker\_1 and checker\_2? Which of these would be more useful in practice?

### Answer

The difference occurs due to timing where, checker 1 compares outputs instantly on any change (including synthesis delays), while checker 2 compares them only synchronously at the clock edge when the sequential value is stable. I would suggest that checker 2 is more useful in practice, because it can verify the intended cycle-by-cycle functional correctness of the sequential logic.

Q2) Was the "self-inflicted" bug detected by Formality, and how was it reported? Also assess the ease of locating the reason for the verification failure from Formality's reports (including viewing logic cones).

### Answer

We can see and observe the code that the code and simulation log do not show Formality output; they demonstrate a dynamic, assertion-based functional verification using a reference model comparison. The self-inflicted bug was not detected by Formality. As we know that, Formality will tell us a Non-Equivalence (FAIL) if the buggy RTL and the correct netlist were compared, or if the netlist did not preserve the logic of the buggy RTL.

The self inflicted bug was detected by the tool identifying the mismatched output/register and providing a counter-example vector.

If we use formality then the bug can be found easily because Formality gives a precise counter-example and allows tracing the diverging logic.

Q3) Was the "self-inflicted" bug detected in simulation, and which of the tests T1 - T5 detected it, and why?

### Answer

Yes, the self-inflicted bug was detected in the simulation (I provide a figure to prove this). T1 and T4 load successfully, T1 finds the bug about T2 and T3, and then again T4 load successfully and it finds the T5 bug



## Lab 11: Finite-State Machine - Datapath Interaction

---

### Ex 1. RTL Code Analysis

Q1. Explains the actions of each module in state S4. For control logic, describe the purpose of the control output values. For datapath logic modules, explain how they are controlled and what function the control activates. Present the relevant lines of code.

| Activity in State S4 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                     |
|----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Module               | Actions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Executed Code                                                                                                                                                                                                                                                                       |
| <b>fsm</b>           | <p>Here, the FSm first calculates the result of R1+R2 and then it writes this result to R4. And the next state is set to S5.</p> <p>The purpose of the control output which is:<br/> <code>we_out='1;</code> enables one register and write:<br/> <code>rsel_out=R4;</code></p> <p><code>asel_out</code> and <code>bsel_out</code> select the R1 and R2 as ALU inputs.</p> <p><code>dsel_out</code> write the ALU output.</p> <p><code>fsel_out = ADD;</code> here it selects the addition function from ALU.</p> <p><code>done_out = '0;</code></p> | <p>I copied the code directly from the given example in linux:<br/> S4:</p> <pre> begin     next_state = S5;     we_out      = '1;     rsel_out    = R4;     asel_out    = R1;     bsel_out    = R2;     dsel_out    = ALU;     fsel_out    = ADD;     done_out    = '0; end </pre> |
| <b>rbank</b>         | <p>rbank is controlled by <code>we_in</code> (this is coming from <code>we_out</code>) and <code>rsel_in</code> (which is coming from R4).</p> <p>The functionality of this block is: in the next rising edge clk the value of R1+R2 will be written in register</p>                                                                                                                                                                                                                                                                                 | <pre> always_ff @(posedge clk) begin : rbank     if (srst)         rb_r &lt;= '0;     else         if (we_in)             rb_r[rsel_in] &lt;= busd; end : rbank </pre>                                                                                                              |
| <b>muxa</b>          | <p>It is controlled by <code>asel_in</code></p> <p>And the functionality is that, it will select the value of R1 and N1 and then place them on <code>busa</code></p>                                                                                                                                                                                                                                                                                                                                                                                 | <pre> always_comb begin : muxa     busa = rb_r[asel_in]; end : muxa </pre>                                                                                                                                                                                                          |
| <b>muxb</b>          | <p>Similarly like muxa ,muxb will place the value on <code>busb</code>, however here it will select the value of R2 and N2</p>                                                                                                                                                                                                                                                                                                                                                                                                                       | <pre> always_comb begin : muxb     busb = rb_r[bsel_in]; end : muxb </pre>                                                                                                                                                                                                          |
| <b>muxd</b>          | <p>It will select the value of alu and then place it on <code>busd</code></p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | <pre> always_comb begin : muxd     if (dsel_in == ALU)         busd = alu;     else         busd = \$signed(ext_in); end : muxd </pre>                                                                                                                                              |

|            |                                                                                                                                                           |                            |
|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------|
|            |                                                                                                                                                           | end : muxd                 |
| <b>ALU</b> | ALU original functionality can be seen in the dp.sv file where it operate different kind of operations, however for S4 operation it just operating adding | ADD:<br>alu = busa + busb; |

## Ex 2. Simulation

Q2. Present annotated waveform image.



Q3. Explain the variable state changes and their order-

Events in State S4 at time 55ns

| Step | Variable(s) | Old Value | New Value |
|------|-------------|-----------|-----------|
| 0    | state_r     | S3        | S4        |
| 1    | asel        | R0        | R1        |
| 2    | bsel        | R0        | R2        |
| 2    | rsel        | R3        | R4        |
| 2    | bus         | 0         | 1         |
| 2    | Busb        | 1         | 2         |
| 2    | busd        | 3         | 2         |

|   |      |   |   |
|---|------|---|---|
| 3 | alu  | 2 | 3 |
| 3 | busd | 2 | 3 |

## Lab 12: FPGA Memories

---

### Ex 1. Storage Resource Requirements Analysis

Q1. Present storage resource requirements as the number of bits for the variables in the RTL design.

| Module     | Variable    | Bits Per Variable                                                                |
|------------|-------------|----------------------------------------------------------------------------------|
| echo       | addr_ctrl_r | 18                                                                               |
|            | attn_in_r   | 12                                                                               |
|            | audio_in_r  | 16                                                                               |
|            | audio_out_r | 16                                                                               |
|            | clkdiv_r    | 11                                                                               |
|            | dtime_in_r  | 18                                                                               |
|            | full_r      | 1                                                                                |
|            | read_data   | Wire, so no bit required.                                                        |
|            | tick        | Wire, so no bit required.                                                        |
| mem        | mem_r       | Here, the bit is calculated with the NBITS*<br>Delay_max_length= 24*8192= 196608 |
|            | rdata_r     | 24                                                                               |
| Total Bits |             | 196724                                                                           |

Q2. Present the storage resources that are available of XCA50T FPGA chips and comment on the feasibility of implementing the design using this specific chip type.

| XC7A50T Storage Resources    |                               |                                  |                                                              |
|------------------------------|-------------------------------|----------------------------------|--------------------------------------------------------------|
| Resource                     | Number of Resources Available | Number of Storage Bits Available | Is the Design Feasible with This Resource Type Only (YES/NO) |
| CLB Flip-Flops               | -                             | 65,200                           | No                                                           |
| Maximum Distributed RAM (Kb) | 600                           | 600000                           | Yes                                                          |
| Total Block RAM (Kb)         | 2,700                         | 2700000                          | Yes                                                          |

### Ex 2: FPGA Implementation with User-Defined RAM Style

Q3. Present run status (success, fail ... reason), Storage resource utilization and timing results.

| FPGA Implementation Results |              |             |                                   |          |
|-----------------------------|--------------|-------------|-----------------------------------|----------|
| Run #                       | RAM Style    | Status      | Utilization % of Storage Resource | Slack    |
| 1                           | registers    | fail        | -                                 |          |
| 2                           | distribut ed | success ful | 0.20%                             | 0.139ns  |
| 3                           | block        | success ful | 8%                                | -1.195ns |

Q4. Present path schematic

| Critical Path Schematics |           |
|--------------------------|-----------|
| Run #                    | Schematic |
| 1                        | -         |



Q5. Compare the timing properties of the designs.

#### Comparison of Timing Properties of Different RAM Implementation Styles

We can observe that the timing slack for worst case for block RAM implementation is negative whereas the distributed RAM implementation has timing slack of positive, which clearly indicate that the distributed RAM implementation meets the timing requirements and block RAM implementation fails to meet the requirements.

The relevant text reports are:

`echo_timing_summary_routed.rpt`  
`echo_utilization_placed.rpt`