

# SPI REPORT



Muhammad Wael El-Sayed

# Code of Design



```
module SPRAM #(parameter MEM_DEPTH = 256)(
    input clk, rst_n,
    input [9:0] D_in, // 10 Bits 2:8 , 2 -> for Control , 8 -> address Bus
    input rx_valid,
    output reg [7:0] D_out,
    output reg tx_valid
);
    reg [7:0] SP_RAM [MEM_DEPTH-1:0];

    reg [7:0] W_address;      // to Hold write address
    reg [7:0] R_address;      // to Hold read address

    always @(posedge clk) begin
        if (~rst_n) begin
            W_address <= 8'd0;
            R_address <= 8'd0;
            tx_valid <= 1'b0;
            D_out <= 8'd0;
        end
        else begin
            if (D_in[9:8] == 2'b00 && rx_valid) begin
                W_address <= D_in[7:0];
                tx_valid <= 1'b0;
            end
            else if (D_in[9:8] == 2'b01 && rx_valid) begin
                SP_RAM[W_address] <= D_in[7:0];
                tx_valid <= 1'b0;
            end
            else if (D_in[9:8] == 2'b10 && rx_valid) begin
                R_address <= D_in[7:0];
                tx_valid <= 1'b0;
            end
            else if (D_in[9:8] == 2'b11) begin
                D_out <= SP_RAM[R_address];
                tx_valid <= 1'b1;
            end
        end
    end
end

endmodule
```

# Code of Design

```
module SPC_Euler #(
    parameter int N = 8,
    parameter int C_N = 1,
    parameter int P_N = 1,
    parameter int R_N = 1,
    parameter int R_N_C_N = 1,
    parameter int R_N_P_N = 1,
    initialparam int SPC_NAT = 4'000
)();

input CLK;
input RST;
input [1:1] R_N_R_N;
input [1:1] R_N_P_N;
input [1:1] R_N_C_N;
input R_N;
output reg R_N;
output reg [R_N_C_N-1:0] R_N_R_N;
output reg [R_N_P_N-1:0] R_N_P_N;

// state memory
always @(*)
begin
    if (R_N_R_N == 1'b1)
        R_N <= R_N_C_N;
    else
        R_N <= R_N_P_N;
end

// next state block
always @(*)
begin
    case (R_N)
        0: begin
            if (R_N_C_N == 1'b0)
                R_N <= C_N;
            else
                R_N <= P_N;
        end
        1: begin
            if (R_N_C_N == 1'b0)
                R_N <= C_N;
            else
                R_N <= P_N;
        end
        2: begin
            if (R_N_C_N == 1'b0)
                R_N <= C_N;
            else
                R_N <= P_N;
        end
        3: begin
            if (R_N_C_N == 1'b0)
                R_N <= C_N;
            else
                R_N <= P_N;
        end
        4: begin
            if (R_N_C_N == 1'b0)
                R_N <= C_N;
            else
                R_N <= P_N;
        end
        5: begin
            if (R_N_C_N == 1'b0)
                R_N <= C_N;
            else
                R_N <= P_N;
        end
        6: begin
            if (R_N_C_N == 1'b0)
                R_N <= C_N;
            else
                R_N <= P_N;
        end
        7: begin
            if (R_N_C_N == 1'b0)
                R_N <= C_N;
            else
                R_N <= P_N;
        end
    endcase
end

// output block
always @(*)
begin
    if (R_N_R_N == 1'b1 & (counter_1 == SPC_NAT || R_N == R_N_C_N))
        counter_1 <= 4'000;
    else
        counter_1 <= counter_1 + 1'b1;
end

always @(*)
begin
    if (R_N_R_N == 1'b1 & (R_N == R_N_C_N))
        counter_2 <= 1'b0;
    else
        counter_2 <= counter_2 + 1'b1;
end

always @(*)
begin
    if (R_N == R_N_C_N & R_N_R_N == 1'b0)
        R_N_R_N <= R_N_C_N;
    else
        R_N_R_N <= R_N_P_N;
end

// R_N flag
always @(*)
begin
    if (R_N_R_N == 1'b1 & (R_N == R_N_C_N))
        R_N_R_N <= 1'b0;
    else
        R_N_R_N <= R_N_P_N;
end

always @(*)
begin
    if (R_N_R_N == 1'b1 & (R_N == R_N_C_N))
        R_N_P_N <= R_N_C_N;
    else
        R_N_P_N <= R_N_P_N;
end

always @(*)
begin
    if (R_N_R_N == 1'b1 & (R_N == R_N_P_N))
        R_N_P_N <= R_N_C_N;
    else
        R_N_P_N <= R_N_P_N;
end

endmodule

module SPC_Euler_wrapper #(
    input CLK,
    input RST,
    input [1:1] R_N_R_N,
    input [1:1] R_N_P_N,
    input R_N
)();

wire [R_N_C_N-1:0] R_N_R_N_Wire;
wire [R_N_P_N-1:0] R_N_P_N_Wire;
wire [1:1] R_N_Wire;

SPC_Euler SPC_Euler_0(.CLK(CLK), .RST(RST), .R_N_R_N(R_N_R_N_Wire), .R_N_P_N(R_N_P_N_Wire), .R_N(R_N_Wire));
endmodule
```

# Code of Test Bench

```
● ○ ●
module SPI_Wrapper_tb();
    localparam TESTS = 20;
    localparam MEM_DEPTH = 256;
    integer i;

    reg clk, rst_n;
    reg SS_n;
    reg MOSI_tb;
    wire MISO_tb;

    reg [7:0] address_tb;      // Address wrote in W_address reg
    reg [7:0] dataWrite_tb;    // Data wrote into memory
    reg [7:0] dataRead_tb;    // Data Read from memory

    // DUT Instantiation
    SPI_Wrapper dut (.clk(clk), .rst_n(rst_n), .SS_n(SS_n), .MOSI(MOSI_tb), .MISO(MISO_tb));

    initial begin
        clk = 0;
        forever begin
            #5 clk = ~clk;
        end
    end

    initial begin
        for (i = 0; i < MEM_DEPTH; i = i + 1)
            dut.SRAM.SP_RAM[i] = 0;
    end

    initial begin
        i = 0;
        address_tb = 0;
        dataWrite_tb = 0;
        dataRead_tb = 0;
        SS_n = 1;
        MOSI_tb = 0;
        rst_n = 0;
        @(negedge clk);
        rst_n = 1;

        repeat (TESTS) begin
            // Write Mode (Address)
            SS_n = 0;
            MOSI_tb = 1'b0;
            repeat(2) @(negedge clk);

            MOSI_tb = 1'b0;
            @(negedge clk);
            MOSI_tb = 1'b0;
            @(negedge clk);

            repeat(8) begin
                MOSI_tb = $random;
                address_tb = {address_tb[6:0], MOSI_tb};
                @(negedge clk);
            end

            SS_n = 1;
            @(negedge clk);

            // Write Mode (Data)
            SS_n = 0;
            @(negedge clk);
            MOSI_tb = 1'b0;
            @(negedge clk);

            MOSI_tb = 1'b0;
            @(negedge clk);
            MOSI_tb = 1'b1;
            @(negedge clk);

            repeat(8) begin
                MOSI_tb = $random;
                dataWrite_tb = {dataWrite_tb[6:0], MOSI_tb};
                @(negedge clk);
            end

            SS_n = 1;
            @(negedge clk);
        end
    end
endmodule
```

# Code of Test Bench

```
// Read Mode (Adress)
SS_n = 0;
@(negedge clk);
MOSI_tb = 1'b1;
@(negedge clk);

MOSI_tb = 1'b1;
@(negedge clk);
MOSI_tb = 1'b0;
@(negedge clk);

for (i = 7; i >= 0; i = i - 1) begin
    MOSI_tb = address_tb[i];
    @(negedge clk);
end

SS_n = 1;
@(negedge clk);

// Read Mode (Data)
SS_n = 0;
@(negedge clk);
MOSI_tb = 1'b1;
@(negedge clk);

MOSI_tb = 1'b1;
@(negedge clk);
MOSI_tb = 1'b1;
@(negedge clk);

repeat(8) begin // wait for data to propagate through MISO
    MOSI_tb = $random; // Dummy bits
    @(negedge clk);
end

repeat(8) begin // wait for data to propagate through MISO
    dataRead_tb = {dataRead_tb[6:0], MISO_tb};
    @(negedge clk);
end

dataRead_tb = {dataRead_tb[6:0], MISO_tb};
SS_n = 1;
@(negedge clk);

if (dataRead_tb !== dataWrite_tb) begin
    $display("(!) Error in SPI function\n");
    $stop;
end
$display("(OK) Everything is good\n");
$stop;
end

endmodule
```

# QUESTA-SIM

## Do File



```
vlib work
vlog SPI.v SPI_tb.v
vsim -voptargs=+acc work.SPI_Wrapper_tb
add wave -position insertpoint \
sim:/SPI_Wrapper_tb/clk \
sim:/SPI_Wrapper_tb/rst_n \
sim:/SPI_Wrapper_tb/SS_n \
sim:/SPI_Wrapper_tb/dut/SS1/cs \
sim:/SPI_Wrapper_tb/dut/SS1/ns \
sim:/SPI_Wrapper_tb/dut/SS1/counter_1 \
sim:/SPI_Wrapper_tb/dut/SS1/counter_2 \
sim:/SPI_Wrapper_tb/dut/SS1/ADD_SAVED \
sim:/SPI_Wrapper_tb/MOSI_tb \
sim:/SPI_Wrapper_tb/MISO_tb \
sim:/SPI_Wrapper_tb/address_tb \
sim:/SPI_Wrapper_tb/dataWrite_tb \
sim:/SPI_Wrapper_tb/dataRead_tb \
sim:/SPI_Wrapper_tb/dut/SS1/tx_data \
sim:/SPI_Wrapper_tb/dut/SS1/tx_valid \
sim:/SPI_Wrapper_tb/dut/SRAM/D_out \
sim:/SPI_Wrapper_tb/dut/SRAM/R_address \
sim:/SPI_Wrapper_tb/dut/SS1/rx_data \
sim:/SPI_Wrapper_tb/dut/SS1/rx_valid \
sim:/SPI_Wrapper_tb/dut/SRAM/D_in \
sim:/SPI_Wrapper_tb/dut/SRAM/W_address \
sim:/SPI_Wrapper_tb/dut/SRAM/SP_RAM
run -all
#quit
```

# QUESTA-SIM

# Wave



# Output

```
# [OK] Everything is good
#
# ** Note: $stop      : SPI_tb.v(131)
#   Time: 12010 ns  Iteration: 1  Instance: /SPI_Wrapper_tb
# Break in Module SPI_Wrapper_tb at SPI_tb.v line 131
```

# QUESTA-LINT

## Lint Score



## Lint Output

### SPRAM module

| Name                              | Count |
|-----------------------------------|-------|
| Resolved(verified, fixed, waived) | 1     |
| Info                              | 1     |
| • multi_ports_in_single_line      | 1     |

### SPI Slave module

| Name                              | Count |
|-----------------------------------|-------|
| Resolved(verified, fixed, waived) | 1     |
| Info                              | 1     |
| • multi_ports_in_single_line      | 1     |

### SPI Wrapper module

| Name                              | Count |
|-----------------------------------|-------|
| Resolved(verified, fixed, waived) | 4     |
| Info                              | 4     |
| • line_char_large                 | 1     |
| • multi_ports_in_single_line      | 3     |

# VIVADO

## One-Hot Encoding

### Elaborated Schematic

#### SPI Wrapper module



#### SPI Slave module



# VIVADO

## One-Hot Encoding

### Elaborated Schematic

#### SPI Slave module



#### SPRAM module



# VIVADO

## One-Hot Encoding

## Elaborated Message



## Synthesis Schematic

### SPI Wrapper module



### SPI Slave module



# VIVADO

## SPRAM module



# VIVADO

# SPRAM module



# Synthesis Timing Report



# Synthesis Utilization Report



# VIVADO

## Critical Path



## Synthesis Message

The screenshot shows the 'Messages' tab of the Vivado interface. The window title bar includes 'Tcl Console', 'Messages', 'Log', 'Reports', 'Design Runs', and 'Debug'. The 'Messages' tab is active, indicated by a bold font. Below the tabs is a toolbar with icons for search, filter, and message levels: 'Warning (1)', 'Info (42)', and 'Status (25)'. A 'Show All' button is also present. The main area displays a hierarchical tree view of synthesis messages:

- Synthesis (1 warning, 33 infos)**
  - [Common 17-349] Got license for feature 'Synthesis' and/or device 'xc7a35t'
  - [Synth 8-6157] synthesizing module 'SPI\_Wrapper' [SPI.v:174] (2 more like this)
  - [Synth 8-5534] Detected attribute (\* fsm\_encoding = "one-hot") [SPI.v:61]
  - [Synth 8-6155] done synthesizing module 'SPI\_Slave' (1#1) [SPI.v:44] (2 more like this)
  - [Device 21-403] Loading part xc7a35tcpg236-1L
  - [Project 1-236] Implementation specific constraints were found while reading constraint file [Z:/github/DigitalDesignVerification/Project/SPI/Constraints.xdc]. These constraints will be ignored for synthesis but will be used in implementation. Impacted constraints are listed in the file [Xil/SPI\_Wrapper\_propImpl.xdc].  
Resolution: To avoid this warning, move constraints listed in [Undefined] to another XDC file and exclude this new file from synthesis with the used\_in\_synthesis property (File Properties dialog in GUI) and re-run elaboration/synthesis.
  - [Synth 8-802] inferred FSM for state register 'cs\_reg' in module 'SPI\_Slave'
  - [Synth 8-5544] ROM "rx\_valid" won't be mapped to Block RAM because address size (4) smaller than threshold (5) (6 more like this)
  - [Synth 8-3354] encoded FSM with state register 'cs\_reg' using encoding 'one-hot' in module 'SPI\_Slave'
  - [Synth 8-4480] The timing for the instance I\_0/SRAM/SP\_RAM\_reg (implemented as a block RAM) might be sub-optimal as no optional output register could be merged into the block ram. Providing additional output register may help in improving timing. (1 more like this)
  - [Project 1-571] Translating synthesized netlist
  - [Netlist 29-17] Analyzing 5 Unisim elements for replacement
  - [Netlist 29-28] Unisim Transformation completed in 0 CPU seconds
  - [Project 1-570] Preparing netlist for logic optimization (1 more like this)
  - [Opt 31-138] Pushed 0 inverter(s) to 0 load pin(s).
  - [Project 1-111] Unisim Transformation Summary:  
No Unisim elements were transformed. (1 more like this)
  - [Common 17-83] Releasing license: Synthesis
  - [Constraints 18-5210] No constraint will be written out.
  - [Common 17-1381] The checkpoint 'C:/Users/muhammadwael/Vivado/SPI\_project/SPI\_project.runs/synth\_1/SPI\_Wrapper.dcp' has been generated.
  - [runcl-4] Executing : report\_utilization -file SPI\_Wrapper\_utilization\_synth.rpt -pb SPI\_Wrapper\_utilization\_synth.pb
  - [Common 17-206] Exiting Vivado at Tue Aug 5 16:14:55 2025...- Synthesized Design (6 infos)**
  - [Netlist 29-17] Analyzing 5 Unisim elements for replacement
  - [Netlist 29-28] Unisim Transformation completed in 0 CPU seconds
- General Messages (6 infos)**
  - [Netlist 29-17] Analyzing 5 Unisim elements for replacement
  - [Netlist 29-28] Unisim Transformation completed in 0 CPU seconds

# VIVADO

## Synthesis Report

```
INFO: [Synth 8-802] inferred FSM for state register 'cs_reg' in module 'SPI_Slave'  
INFO: [Synth 8-5544] ROM "ADD_SAVED" won't be mapped to Block RAM because address size (3) smaller than threshold (5)  
INFO: [Synth 8-5544] ROM "ns" won't be mapped to Block RAM because address size (1) smaller than threshold (5)  
INFO: [Synth 8-5544] ROM "ns" won't be mapped to Block RAM because address size (1) smaller than threshold (5)  
INFO: [Synth 8-5544] ROM "ns" won't be mapped to Block RAM because address size (1) smaller than threshold (5)  
INFO: [Synth 8-5544] ROM "ns" won't be mapped to Block RAM because address size (1) smaller than threshold (5)  
INFO: [Synth 8-5544] ROM "tx_valid" won't be mapped to Block RAM because address size (2) smaller than threshold (5)
```

| State     | New Encoding | Previous Encoding |
|-----------|--------------|-------------------|
| IDLE      | 00001        | 000               |
| CHK_CMD   | 10000        | 001               |
| READ_ADD  | 00010        | 011               |
| READ_DATA | 00100        | 100               |
| WRITE     | 01000        | 010               |

```
INFO: [Synth 8-3354] encoded FSM with state register 'cs_reg' using encoding 'one-hot' in module 'SPI_Slave'
```

## Implementation Utilization Report

| Name            | Slice LUTs (20800) | Slice Registers (41600) | Slice (8150) | LUT as Logic (20800) | LUT Flip Flop Pairs (20800) | Block RAM Tile (50) | Bonded IOB (106) | BUFGCTRL (32) |
|-----------------|--------------------|-------------------------|--------------|----------------------|-----------------------------|---------------------|------------------|---------------|
| SPI_Wrapper     | 24                 | 40                      | 10           | 24                   | 13                          | 0.5                 | 5                | 1             |
| SRAM (SPRAM)    | 4                  | 17                      | 4            | 4                    | 0                           | 0.5                 | 0                | 0             |
| SS1 (SPI_Slave) | 20                 | 23                      | 9            | 20                   | 11                          | 0                   | 0                | 0             |

## Implementation Message

| Implementation (99 infos)        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|----------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Design Initialization (11 infos) | <ul style="list-style-type: none"><li>● [Netlist 29-17] Analyzing 5 Unisim elements for replacement</li><li>● [Netlist 29-28] Unisim Transformation completed in 0 CPU seconds</li><li>● [Project 1-479] Netlist was created with Vivado 2018.2</li><li>● [Device 21-403] Loading part xc7a35tci236-1L</li><li>● [Project 1-570] Preparing netlist for logic optimization</li><li>● [Timing 38-478] Restoring timing data from binary archive.</li><li>● [Timing 38-479] Binary timing data restore complete.</li><li>● [Project 1-856] Restoring constraints from binary archive.</li><li>● [Project 1-853] Binary constraint restore complete.</li><li>● [Project 1-111] Unisim Transformation Summary:<br/>No Unisim elements were transformed.</li><li>● [Project 1-604] Checkpoint was created with Vivado v2018.2 (64-bit) build 2258646</li></ul> |
| Opt Design (30 infos)            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| Place Design (23 infos)          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| Route Design (35 infos)          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| Implemented Design (9 infos)     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| General Messages (9 infos)       | <ul style="list-style-type: none"><li>● [Netlist 29-17] Analyzing 5 Unisim elements for replacement</li><li>● [Netlist 29-28] Unisim Transformation completed in 0 CPU seconds</li><li>● [Project 1-479] Netlist was created with Vivado 2018.2</li><li>● [Project 1-570] Preparing netlist for logic optimization</li><li>● [Timing 38-478] Restoring timing data from binary archive.</li><li>● [Timing 38-479] Binary timing data restore complete.</li><li>● [Project 1-856] Restoring constraints from binary archive.</li><li>● [Project 1-853] Binary constraint restore complete.</li><li>● [Project 1-111] Unisim Transformation Summary:<br/>No Unisim elements were transformed.</li></ul>                                                                                                                                                    |

# VIVADO

## Implementation Timing Report



## Device



# VIVADO

## Gray Encoding

### Elaborated Schematic

#### SPI Wrapper module



#### SPI Slave module



# VIVADO

## One-Hot Encoding

### Elaborated Schematic

#### SPI Slave module



#### SPRAM module



# VIVADO

## One-Hot Encoding

## Elaborated Message



## Synthesis Schematic

### SPI Wrapper module



### SPI Slave module



# VIVADO

## SPRAM module



# VIVADO

## SPRAM module



## Synthesis Timing Report



## Synthesis Utilization Report



# VIVADO

## Critical Path



## Synthesis Message

```
Tcl Console Messages Log Reports Design Runs Utilization Timing Debug
? - > Show All
Synthesis (1 warning, 32 infos)
  [Common 17-349] Got license for feature 'Synthesis' and/or device 'xc7a35t'
> [Synth 8-6157] synthesizing module 'SPI_Wrapper' [SPI.v.174] (2 more like this)
  [Synth 8-5534] Detected attribute (* fsm_encoding = "gray" *) [SPI.v.61]
> [Synth 8-6155] done synthesizing module 'SPI_Slave' (1#1) [SPI.v.44] (2 more like this)
  [Device 21-403] Loading part xc7a35tcpg236-1L
  [Project 1-236] Implementation specific constraints were found while reading constraint file [Z:/github/DigitalDesignVerification/Project/SPI/Constraints.xdc]. These constraints will be ignored for synthesis but will be used in implementation. Impacted constraints are listed in the file [Xil/SPI_Wrapper_propImpl.xdc].
  Resolution: To avoid this warning, move constraints listed in [Undefined] to another XDC file and exclude this new file from synthesis with the used_in_synthesis property (File Properties dialog in GUI) and re-run elaboration/synthesis.
  [Synth 8-802] inferred FSM for state register 'cs_reg' in module 'SPI_Slave'
> [Synth 8-5544] ROM "ADD_SAVED" won't be mapped to Block RAM because address size (3) smaller than threshold (5) (5 more like this)
  [Synth 8-3354] encoded FSM with state register 'cs_reg' using encoding 'gray' in module 'SPI_Slave'
> [Synth 8-4480] The timing for the instance I_0/DRAM/SP_RAM_reg (implemented as a block RAM) might be sub-optimal as no optional output register could be merged into the block ram. Providing additional output register may help in improving timing. (1 more like this)
  [Project 1-571] Translating synthesized netlist
  [Netlist 29-17] Analyzing 5 Unisim elements for replacement
  [Netlist 29-28] Unisim Transformation completed in 0 CPU seconds
> [Project 1-570] Preparing netlist for logic optimization (1 more like this)
  [Opt 31-138] Pushed 0 inverter(s) to 0 load pin(s).
> [Project 1-111] Unisim Transformation Summary
  No Unisim elements were transformed. (1 more like this)
  [Common 17-83] Releasing license: Synthesis
  [Constraints 18-5210] No constraint will be written out.
  [Common 17-1381] The checkpoint 'C:/Users/muhammadwael/Vivado/SPI_project/SPI_project.runs/synth_1/SPI_Wrapper.dcp' has been generated.
  [runtd-4] Executing : report_utilization -file SPI_Wrapper_utilization_synth.rpt -pb SPI_Wrapper_utilization_synth.pb
  [Common 17-206] Exiting Vivado at Tue Aug 5 21:05:35 2025...
Synthesized Design (9 infos)
  General Messages (9 infos)
    [Netlist 29-17] Analyzing 5 Unisim elements for replacement
    [Netlist 29-28] Unisim Transformation completed in 0 CPU seconds
```

# VIVADO

# Synthesis Report

```

Finished applying 'set_property' XDC Constraints : Time (s): cpu = 00:00:31 ; elapsed = 00:00:39 . Memory (MB): peak = 791.410 ; gain = 506.445
-----
INFO: [Synth 8-802] inferred FSM for state register 'cs_reg' in module 'SPI_Slave'
INFO: [Synth 8-5544] ROM "ADD_SAVED" won't be mapped to Block RAM because address size (3) smaller than threshold (5)
INFO: [Synth 8-5544] ROM "ns" won't be mapped to Block RAM because address size (1) smaller than threshold (5)
INFO: [Synth 8-5544] ROM "ns" won't be mapped to Block RAM because address size (1) smaller than threshold (5)
INFO: [Synth 8-5544] ROM "ns" won't be mapped to Block RAM because address size (1) smaller than threshold (5)
INFO: [Synth 8-5544] ROM "ns" won't be mapped to Block RAM because address size (1) smaller than threshold (5)
INFO: [Synth 8-5544] ROM "tx_valid" won't be mapped to Block RAM because address size (2) smaller than threshold (5)
-----

```

| State     | New Encoding | Previous Encoding |
|-----------|--------------|-------------------|
| IDLE      | 000          | 000               |
| CHK_CMD   | 111          | 001               |
| READ_ADD  | 001          | 011               |
| READ_DATA | 011          | 100               |
| WRITE     | 010          | 010               |

INFO: [Synth 8-3354] encoded FSM with state register 'cs\_reg' using encoding 'gray' in module 'SPI\_Slave'

# Implementation Utilization Report

| Hierarchy   | Name            | Slice LUTs<br>(20800) | Slice Registers<br>(41600) | Slice<br>(8150) | LUT as Logic<br>(20800) | LUT Flip Flop Pairs<br>(20800) | Block RAM Tile<br>(50) | Bonded IOB<br>(106) | BUFGCTRL<br>(32) |
|-------------|-----------------|-----------------------|----------------------------|-----------------|-------------------------|--------------------------------|------------------------|---------------------|------------------|
| Slice Logic | N SPI_Wrapper   | 26                    | 38                         | 12              | 26                      | 13                             | 0.5                    | 5                   | 1                |
|             | SRAM (SPRAM)    | 4                     | 17                         | 6               | 4                       | 0                              | 0.5                    | 0                   | 0                |
|             | SS1 (SPI_Slave) | 22                    | 21                         | 8               | 22                      | 11                             | 0                      | 0                   | 0                |

# Implementation Message

# VIVADO

## Implementation Timing Report



## Device



# VIVADO

## Sequential Encoding

### Elaborated Schematic

#### SPI Wrapper module



#### SPI Slave module



# VIVADO

## One-Hot Encoding

### Elaborated Schematic

#### SPI Slave module



#### SPRAM module



# VIVADO

## One-Hot Encoding

## Elaborated Message



## Synthesis Schematic

### SPI Wrapper module



### SPI Slave module



# VIVADO

## SPRAM module



# VIVADO

## SPRAM module



## Synthesis Timing Report



## Synthesis Utilization Report



# VIVADO

## Critical Path



## Synthesis Message

```
Tcl Console Messages Log Reports Design Runs Utilization Debug ? < > Show All
Search Filter Show All
Synthesis (1 warning, 32 infos)
  ① [Common 17-349] Got license for feature 'Synthesis' and/or device 'xc7a35t'
  > ① [Synth 8-6157] synthesizing module 'SPI_Wrapper' [SPI.v:174] (2 more like this)
  ① [Synth 8-5534] Detected attribute (* fsm_encoding = "sequential") [SPI.v:61]
  > ① [Synth 8-6155] done synthesizing module 'SPI_Slave' (1#1) [SPI.v:44] (2 more like this)
  ① [Device 21-403] Loading part xc7a35tcpg236-1L
  ① [Project 1-236] Implementation specific constraints were found while reading constraint file [Z:/github/DigitalDesignVerification/Project/SPI/Constraints.xdc]. These constraints will be ignored for synthesis but will be used in implementation. Impacted constraints are listed in the file [XIL/SPI_Wrapper_propImpl.xdc].
    Resolution: To avoid this warning, move constraints listed in [Undefined] to another XDC file and exclude this new file from synthesis with the used_in_synthesis property (File Properties dialog in GUI) and re-run elaboration/synthesis.
  ① [Synth 8-802] inferred FSM for state register 'cs_reg' in module 'SPI_Slave'
  > ① [Synth 8-5544] ROM 'ADD_SAVED' won't be mapped to Block RAM because address size (3) smaller than threshold (5) (5 more like this)
  ① [Synth 8-3354] encoded FSM with state register 'cs_reg' using encoding 'sequential' in module 'SPI_Slave'
  > ① [Synth 8-4480] The timing for the instance I_0/SRAM/SP_RAM_reg (implemented as a block RAM) might be sub-optimal as no optional output register could be merged into the block ram. Providing additional output register may help in improving timing. (1 more like this)
  ① [Project 1-571] Translating synthesized netlist
  ① [Netlist 29-17] Analyzing 5 Unisim elements for replacement
  ① [Netlist 29-28] Unisim Transformation completed in 0 CPU seconds
  > ① [Project 1-570] Preparing netlist for logic optimization (1 more like this)
  ① [Opt 31-138] Pushed 0 inverter(s) to 0 load pin(s).
  > ① [Project 1-111] Unisim Transformation Summary:
    No Unisim elements were transformed. (1 more like this)
  ① [Common 17-83] Releasing license: Synthesis
  ① [Constraints 18-5210] No constraint will be written out.
  ① [Common 17-1381] The checkpoint 'C:/Users/muhammadwael/Vivado/SPI_project/SPI_project.runs/synth_1/SPI_Wrapper.dcp' has been generated.
  ① [runcl-4] Executing : report_utilization -file SPI_Wrapper_utilization_synth.rpt -pb SPI_Wrapper_utilization_synth.pb
  ① [Common 17-206] Exiting Vivado at Tue Aug 5 22:35:43 2025...
Synthesized Design (9 infos)
  General Messages (9 infos)
    ① [Netlist 29-17] Analyzing 5 Unisim elements for replacement
```

# VIVADO

## Synthesis Report

```
INFO: [Synth 8-802] inferred FSM for state register 'cs_reg' in module 'SPI_Slave'  
INFO: [Synth 8-5544] ROM "ADD_SAVED" won't be mapped to Block RAM because address size (3) smaller than threshold (5)  
INFO: [Synth 8-5544] ROM "ns" won't be mapped to Block RAM because address size (1) smaller than threshold (5)  
INFO: [Synth 8-5544] ROM "ns" won't be mapped to Block RAM because address size (1) smaller than threshold (5)  
INFO: [Synth 8-5544] ROM "ns" won't be mapped to Block RAM because address size (1) smaller than threshold (5)  
INFO: [Synth 8-5544] ROM "ns" won't be mapped to Block RAM because address size (1) smaller than threshold (5)  
INFO: [Synth 8-5544] ROM "tx_valid" won't be mapped to Block RAM because address size (2) smaller than threshold (5)
```

| State     | New Encoding | Previous Encoding |
|-----------|--------------|-------------------|
| IDLE      | 000          | 000               |
| CHK_CMD   | 100          | 001               |
| READ_ADD  | 001          | 011               |
| READ_DATA | 010          | 100               |
| WRITE     | 011          | 010               |

```
INFO: [Synth 8-3354] encoded FSM with state register 'cs_reg' using encoding 'sequential' in module 'SPI_Slave'
```

## Implementation Utilization Report

The screenshot shows the Vivado Utilization Report window. The left sidebar displays a hierarchical tree with 'Hierarchy' selected at the top. Under 'Slice Logic', there are entries for 'Slice LUTs (<1%)', 'LUT as Logic (<1%)', 'Slice Registers (<1%)', and 'Register as Flip Flop'. The main table lists resources for the 'SPI\_Wrapper' component, which contains 'SRAM (SPRAM)' and 'SS1 (SPI\_Slave)' sub-components. The columns represent Slice LUTs, Slice Registers, Slice (8150), LUT as Logic, LUT Flip Flop Pairs, Block RAM Tile, Bonded IOB, and BUFCTRL.

| Name            | Slice LUTs (20800) | Slice Registers (41600) | Slice (8150) | LUT as Logic (20800) | LUT Flip Flop Pairs (20800) | Block RAM Tile (50) | Bonded IOB (106) | BUFCTRL (32) |
|-----------------|--------------------|-------------------------|--------------|----------------------|-----------------------------|---------------------|------------------|--------------|
| N SPI_Wrapper   | 25                 | 38                      | 13           | 25                   | 12                          | 0.5                 | 5                | 1            |
| SRAM (SPRAM)    | 4                  | 17                      | 7            | 4                    | 0                           | 0.5                 | 0                | 0            |
| SS1 (SPI_Slave) | 21                 | 21                      | 9            | 21                   | 11                          | 0                   | 0                | 0            |

## Implementation Message

The screenshot shows the Vivado Messages window. The left sidebar displays a hierarchical tree with 'Implementation (99 infos)' expanded. It contains sections for 'Design Initialization', 'Opt Design', 'Place Design', 'Route Design', and 'Implemented Design'. Each section lists various informational messages from the Vivado log. The top bar includes filters for 'Warning (1)', 'Info (244)', and 'Status (508)'.

# VIVADO

## Implementation Timing Report



## Device



# VIVADO

## Bit-Stream Generation



## FSM Best Encoding

In order to operate at the highest frequency you should use sequential encoding