# **Project 2**

• Code:

```
module SPI_Slave (
    MOSI,
   MISO,
    SS n,
    SCK,
    rst n,
    rx data,
   rx_valid,
   tx data,
   tx valid
);
  parameter IDLE = 3'b000;
 parameter CHK_CMD = 3'b001;
  parameter READ ADD = 3'b010;
  parameter READ DATA = 3'b011;
  parameter WRITE = 3'b100;
 input MOSI, SS_n;
 input SCK, rst_n;
  output reg MISO;
 input [7:0] tx_data;
 input tx valid;
 output reg [9:0] rx_data;
 output reg rx_valid;
  reg [3:0] wr_counter;
 reg [2:0] rd_counter;
 reg read_addr_received;
 wire invalid_wr, invalid_rd_addr, invalid_rd_data;
```

```
(* fsm encoding = "gray"*)
 reg [2:0] cs, ns;
  //handle invalid cases
 assign invalid wr = (cs == WRITE) && (wr_counter == 7) &&
(rx_data[9:8] != 2'b00) && (rx_data[9:8] != 2'b01);
 assign invalid rd addr = (cs == READ ADD) && (wr counter ==
7) && (rx data[9:8] != 2'b10);
 assign invalid_rd_data = (cs == READ_DATA) && (wr_counter ==
7) && (rx data[9:8] != 2'b11);
  // next state logic
  always @(*) begin
    case (cs)
      IDLE: begin
        if (~SS_n) begin
         ns = CHK_CMD;
        end else begin
         ns = IDLE;
        end
      end
      CHK CMD: begin
        if (~SS_n && MOSI && read_addr_received) begin
          ns = READ DATA;
        end else if (~SS n && MOSI && ~read addr received)
begin
          ns = READ_ADD;
        end else if (~SS_n && ~MOSI) begin
         ns = WRITE;
        end else begin
          ns = IDLE;
        end
      end
      WRITE: begin
        if (SS n || wr counter == 0 || invalid wr) begin
```

```
ns = IDLE;
      end else begin
        ns = WRITE;
      end
    end
    READ_ADD: begin
      if (SS_n || wr_counter == 0 || invalid_rd_addr) begin
        ns = IDLE;
      end else begin
        ns = READ_ADD;
      end
    end
    READ_DATA: begin
      if (SS_n || rd_counter == 0 || invalid_rd_data) begin
        ns = IDLE;
      end else begin
        ns = READ_DATA;
      end
    end
    default: ns = IDLE;
  endcase
end
// state memory
always @(posedge SCK) begin
  if (~rst_n) begin
    cs <= IDLE;</pre>
  end else begin
    cs <= ns;
  end
end
// output logic
always @(posedge SCK) begin
 if (~rst_n) begin
    wr counter <= 0;</pre>
```

```
rd counter <= 0;
      rx data <= 0;</pre>
      read addr received <= 0;</pre>
      MISO <= 0;
      rx valid <= 0;</pre>
    end else begin
      case (cs)
        IDLE: begin
          wr counter <= 9;
          rd counter <= 7;
          rx_data <= 0;</pre>
          rx valid <= 0;</pre>
          MISO <= 0;
        end
        WRITE: begin
          // drive rx data bus with parallel write address /
data
          rx_data[wr_counter] <= MOSI;</pre>
          wr_counter <= (wr_counter > 0) ? wr_counter - 1 : 0;
          // check data is valid or not
          rx_valid <= (wr_counter == 0) ? 1 : 0;</pre>
        end
        READ ADD: begin
          // drive rx data bus with parallel read address
          rx data[wr counter] <= MOSI;</pre>
          wr_counter <= (wr_counter > 0) ? wr_counter - 1 : 0;
          // check data is valid or not
          rx valid <= (wr counter == 0) ? 1 : 0;
          // indicate address is received
          read_addr_received <= (wr_counter == 0) ? 1 : 0;</pre>
        end
        READ DATA: begin
          // indicate received address is used and waiting for
new address
          read addr received <= 0;</pre>
          // check data is valid or not
```

```
rx valid <= (wr counter == 0) ? 1 : 0;</pre>
          if (wr counter != 0) begin
            // drive rx_data bus with parallel read command &
dummy data
            rx_data[wr_counter] <= MOSI;</pre>
            wr_counter <= (wr_counter > 0) ? wr_counter - 1 :
0;
          end else if (tx_valid) begin
            // receive parallel data and convert it to serial
on MISO port
            MISO <= tx_data[rd_counter];</pre>
            rd counter <= rd counter - 1;
          end
        end
      endcase
    end
  end
endmodule
```

```
module RAM (
    din,
    clk,
    rst_n,
    rx_valid,
    dout,
    tx_valid
);

parameter MEM_DEPTH = 256;
parameter ADDR_SIZE = 8;

input [9:0] din;
input clk, rst_n, rx_valid;
output reg [7:0] dout;
```

```
output reg tx_valid;
reg [7:0] mem[MEM_DEPTH-1:0];
reg [ADDR_SIZE-1:0] addr;
// memory read and write operations
always @(posedge clk) begin
  if (~rst_n) begin
    dout <= 0;</pre>
    addr <= 0;
    tx_valid <= 0;</pre>
  end else begin
    casex ({
      din[9:8], rx_valid
    })
      3'b001: begin
         addr <= din[7:0];
      end
      3'b011: begin
         mem[addr] <= din[7:0];</pre>
      end
      3'b101: begin
         addr <= din[7:0];
      end
      3'b111: begin
         dout <= mem[addr];</pre>
        tx_valid <= 1;</pre>
      end
      default: begin
        dout <= 0;</pre>
        tx_valid <= 0;</pre>
      end
    endcase
  end
end
```

### endmodule

• Testbench:

```
module tb ();
  reg MOSI, SS_n, clk, rst_n;
  wire MISO;
  SPI_wrapper wrapper (
      MOSI,
      MISO,
      SS_n,
      clk,
      rst_n
  );
  initial begin
    clk = 0;
    forever begin
      #20 clk = ~clk;
    end
  end
  initial begin
    // Test reset and memory initialization
    rst_n = 0;
    $readmemb("mem.dat", wrapper.ram.mem, 0, 255);
    repeat (5) begin
      MOSI = $random;
      SS n = $random;
      @(negedge clk);
    end
    // Test writing
```

```
// deactivate reset & activate slave select
rst_n = 1;
SS_n = 0;
// test write-address command
MOSI = 0;
@(negedge clk);
MOSI = 0;
@(negedge clk);
MOSI = 0;
@(negedge clk);
repeat (9) begin
 MOSI = $random;
 @(negedge clk);
end
// test write data
MOSI = $random;
@(negedge clk);
MOSI = 0;
@(negedge clk);
MOSI = 0;
@(negedge clk);
MOSI = 1;
@(negedge clk);
repeat (8) begin
 MOSI = $random;
 @(negedge clk);
end
// Test memory read functionality
// test read-address holding command
MOSI = $random;
```

```
@(negedge clk);
MOSI = 1;
@(negedge clk);
MOSI = 1;
@(negedge clk);
MOSI = 0;
@(negedge clk);
repeat (8) begin
 MOSI = $random;
 @(negedge clk);
end
// test read data
MOSI = $random;
@(negedge clk);
MOSI = 1;
@(negedge clk);
MOSI = 1;
@(negedge clk);
MOSI = 1;
repeat (20) begin
 MOSI = $random;
 @(negedge clk);
end
// Test invalid cases
// test write-address command
MOSI = 0;
@(negedge clk);
MOSI = 1;
@(negedge clk);
MOSI = 0;
@(negedge clk);
repeat (9) begin
```

```
MOSI = $random;
 @(negedge clk);
end
// test write data
MOSI = $random;
@(negedge clk);
MOSI = 0;
@(negedge clk);
MOSI = 0;
@(negedge clk);
MOSI = 1;
@(negedge clk);
repeat (8) begin
  MOSI = $random;
 @(negedge clk);
end
// test invalid read-address holding command
MOSI = $random;
@(negedge clk);
MOSI = 1;
@(negedge clk);
MOSI = 1;
@(negedge clk);
MOSI = 1;
@(negedge clk);
repeat (8) begin
  MOSI = $random;
 @(negedge clk);
end
// test read-address holding command
MOSI = $random;
@(negedge clk);
MOSI = 1;
```

```
@(negedge clk);
    MOSI = 1;
   @(negedge clk);
   MOSI = 0;
   @(negedge clk);
    repeat (8) begin
     MOSI = $random;
     @(negedge clk);
    end
    // test read data
   MOSI = $random;
   @(negedge clk);
    MOSI = 1;
   @(negedge clk);
   MOSI = 1;
   @(negedge clk);
   MOSI = 0;
    repeat (30) begin
     MOSI = $random;
     @(negedge clk);
    end
    // test randomized data/address writing & reading
    // randomized slave select
    repeat (50) begin
      MOSI = $random;
      SS_n = $random;
     @(negedge clk);
    end
    $stop;
  end
endmodule
```

### • Do file:

```
vlib work
vlog ram.v spi_slave.v wrapper.v spi_tb.v
vsim -voptargs=+acc work.tb
add wave -position insertpoint \
sim:/tb/wrapper/rst n \
sim:/tb/wrapper/clk \
sim:/tb/wrapper/SS_n \
sim:/tb/wrapper/rx_data \
sim:/tb/wrapper/rx valid \
sim:/tb/wrapper/tx data \
sim:/tb/wrapper/tx_valid \
sim:/tb/wrapper/MISO \
sim:/tb/wrapper/MOSI
add wave -position insertpoint \
sim:/tb/wrapper/slave/cs \
sim:/tb/wrapper/slave/ns \
sim:/tb/wrapper/slave/read_addr_received \
sim:/tb/wrapper/slave/rd_counter \
sim:/tb/wrapper/slave/wr counter \
sim:/tb/wrapper/slave/invalid rd addr \
sim:/tb/wrapper/slave/invalid rd data \
sim:/tb/wrapper/slave/invalid_wr
add wave -position insertpoint \
sim:/tb/wrapper/ram/addr \
sim:/tb/wrapper/ram/mem
run -all
#quit -sim
```

### • Waveform:

















### • Elaboration



# • Synthesis:



# 1. Gray:

| State                                             | New Enc | oding                                   | Previous Encoding               |
|---------------------------------------------------|---------|-----------------------------------------|---------------------------------|
| IDLE<br>CHK_CMD<br>READ_DATA<br>READ_ADD<br>WRITE |         | 000  <br>001  <br>011  <br>010  <br>111 | 000<br>001<br>011<br>010<br>100 |

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

| Setup                               |              | Hold                         |          | Pulse Width                              |          |
|-------------------------------------|--------------|------------------------------|----------|------------------------------------------|----------|
| Worst Negative Slack (WNS):         | 6.443 ns     | Worst Hold Slack (WHS):      | 0.077 ns | Worst Pulse Width Slack (WPWS):          | 3.750 ns |
| Total Negative Slack (TNS):         | 0.000 ns     | Total Hold Slack (THS):      | 0.000 ns | Total Pulse Width Negative Slack (TPWS): | 0.000 ns |
| Number of Failing Endpoints:        | 0            | Number of Failing Endpoints: | 0        | Number of Failing Endpoints:             | 0        |
| Total Number of Endpoints:          | 382          | Total Number of Endpoints:   | 382      | Total Number of Endpoints:               | 73       |
| All user specified timing constrain | ints are met |                              |          | Activate                                 | Windov   |



### 2. One-hot:

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

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

| Setup                                        | Hold                         |          | Pulse Width                              |          |  |  |  |
|----------------------------------------------|------------------------------|----------|------------------------------------------|----------|--|--|--|
| Worst Negative Slack (WNS): 6.654 ns         | Worst Hold Slack (WHS):      | 0.077 ns | Worst Pulse Width Slack (WPWS):          | 3.750 ns |  |  |  |
| Total Negative Slack (TNS): 0.000 ns         | Total Hold Slack (THS):      | 0.000 ns | Total Pulse Width Negative Slack (TPWS): | 0.000 ns |  |  |  |
| Number of Failing Endpoints: 0               | Number of Failing Endpoints: | 0        | Number of Failing Endpoints:             | 0        |  |  |  |
| Total Number of Endpoints: 384               | Total Number of Endpoints:   | 384      | Total Number of Endpoints:               | 75       |  |  |  |
| All user specified timing constraints are mo | et.                          |          | Activate                                 | Windows  |  |  |  |



### 3. Binary (chosen):

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

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

| Setup                              |              | Hold                         |          | Pulse Width                              |          |
|------------------------------------|--------------|------------------------------|----------|------------------------------------------|----------|
| Worst Negative Slack (WNS):        | 6.936 ns     | Worst Hold Slack (WHS):      | 0.077 ns | Worst Pulse Width Slack (WPWS):          | 3.750 ns |
| Total Negative Slack (TNS):        | 0.000 ns     | Total Hold Slack (THS):      | 0.000 ns | Total Pulse Width Negative Slack (TPWS): | 0.000 ns |
| Number of Failing Endpoints:       | 0            | Number of Failing Endpoints: | 0        | Number of Failing Endpoints:             | 0        |
| Total Number of Endpoints:         | 382          | Total Number of Endpoints:   | 382      | Total Number of Endpoints:               | 73       |
| All user specified timing constrai | ints are met |                              |          | Activate                                 | Windows  |



## • Implementation:

o Without debug core:



| Setup                        |          |
|------------------------------|----------|
| Worst Negative Slack (WNS):  | 5.928 ns |
| Total Negative Slack (TNS):  | 0.000 ns |
| Number of Failing Endpoints: | 0        |
| Total Number of Endpoints:   | 382      |

All user specified timing constraints are met.

| Worst Hold Slack (WHS):      | 0.052 ns |
|------------------------------|----------|
| Total Hold Slack (THS):      | 0.000 ns |
| Number of Failing Endpoints: | 0        |
| Total Number of Endpoints:   | 382      |

Hold

| Worst Pulse Width Slack (WPWS):          |
|------------------------------------------|
| Total Pulse Width Negative Slack (TPWS): |
| Number of Failing Endpoints:             |
| Total Number of Endpoints:               |

**Pulse Width** 

Activate Windows

3.750 ns 0.000 ns 0 73

| Name 1              | Slice LUTs<br>(20800) | Slice Registers<br>(41600) | F7<br>Muxes<br>(16300) | F8<br>Muxes<br>(8150) | Slice<br>(815<br>0) | LUT as Logic<br>(20800) | LUT as Memory<br>(9600) | LUT Flip Flop Pairs<br>(20800) | Bonded IOB<br>(106) | BUFGCTRL<br>(32) |
|---------------------|-----------------------|----------------------------|------------------------|-----------------------|---------------------|-------------------------|-------------------------|--------------------------------|---------------------|------------------|
| ∨ N SPI_wrapper     | 89                    | 40                         | 16                     | 8                     | 26                  | 57                      | 32                      | 27                             | 5                   | 1                |
| I ram (RAM)         | 32                    | 17                         | 16                     | 8                     | 13                  | 0                       | 32                      | 0                              | 0                   | 0                |
| ■ slave (SPI_Slave) | 57                    | 23                         | 0                      | 0                     | 16                  | 57                      | 0                       | 23                             | 0                   | 0                |

# • With debug core:



#### **Design Timing Summary**

| Setup                          |          | Hold                         |           | Pulse Width                              |          |  |  |
|--------------------------------|----------|------------------------------|-----------|------------------------------------------|----------|--|--|
| Worst Negative Slack (WNS):    | 3.216 ns | Worst Hold Slack (WHS):      | -0.353 ns | Worst Pulse Width Slack (WPWS):          | 3.750 ns |  |  |
| Total Negative Slack (TNS):    | 0.000 ns | Total Hold Slack (THS):      | -0.625 ns | Total Pulse Width Negative Slack (TPWS): | 0.000 ns |  |  |
| Number of Failing Endpoints:   | 0        | Number of Failing Endpoints: | 2         | Number of Failing Endpoints:             | 0        |  |  |
| Total Number of Endpoints:     | 4167     | Total Number of Endpoints:   | 4151      | Total Number of Endpoints:               | 2173     |  |  |
| Timing constraints are not mot |          |                              |           | A 12 1                                   | VAZ: I   |  |  |

#### Timing constraints are not met. Activate Windows

| Name                  | 1 | Slice LUTs<br>(20800) | Slice Registers<br>(41600) | F7<br>Muxes<br>(16300) | F8<br>Muxes<br>(8150) | Slice<br>(815<br>0) | LUT as Logic<br>(20800) | LUT as Memory<br>(9600) | LUT Flip Flop Pairs<br>(20800) | Block RAM Tile<br>(50) | Bonded IOB<br>(106) | BUFGCTRL<br>(32) | BSCANE2<br>(4) |
|-----------------------|---|-----------------------|----------------------------|------------------------|-----------------------|---------------------|-------------------------|-------------------------|--------------------------------|------------------------|---------------------|------------------|----------------|
| ∨ N SPI_wrapper       |   | 1328                  | 1956                       | 26                     | 8                     | 642                 | 1188                    | 140                     | 762                            | 0.5                    | 5                   | 2                | 1              |
| > I dbg_hub (dbg_hub) |   | 475                   | 727                        | 0                      | 0                     | 242                 | 451                     | 24                      | 316                            | 0                      | 0                   | 1                | 1              |
| ram (RAM)             |   | 32                    | 17                         | 16                     | 8                     | 12                  | 0                       | 32                      | 0                              | 0                      | 0                   | 0                | 0              |
| slave (SPI_Slave)     |   | 57                    | 23                         | 0                      | 0                     | 18                  | 57                      | 0                       | 23                             | 0                      | 0                   | 0                | 0              |
| > 1 u_ila_0 (u_ila_0) |   | 764                   | 1189                       | 10                     | 0                     | 375                 | 680                     | 84                      | 418                            | 0.5                    | 0                   | 0                | 0              |

#### • Bitstream Generation:



### • Messages:

### o Without debug core:

→ 

□ Vivado Commands (3 infos, 36 status messages)

- ✓ ☐ General Messages (3 infos, 36 status messages)
  - > (1) Scanning sources... (35 more like this)
  - 1 [IP\_Flow 19-234] Refreshing IP repositories
  - 1 [IP\_Flow 19-1704] No user IP repositories specified
  - [IP\_Flow 19-2313] Loaded Vivado IP repository 'E:/Vivado/2018.2/data/ip'.
- → Synthesis (1 warning, 33 infos, 11 status messages)
  - > ① Command: synth\_design -top SPI\_wrapper -part xc7a35ticpg236-1L (10 more like this)
  - 17-349] Got license for feature 'Synthesis' and/or device 'xc7a35ti'
  - > (in [Synth 8-6157] synthesizing module 'SPI\_wrapper' [wrapper.v.1] (2 more like this)
  - (Synth 8-5534] Detected attribute (\* fsm\_encoding = "sequential" \*) [spi\_slave.v:34]
  - (§ [Synth 8-155] case statement is not full and has no default [spi\_slave.v:107]
  - > ① [Synth 8-6155] done synthesizing module "SPL\_Slave" (1#1) [spi\_slave.v.1] (2 more like this)
    ① [Device 21-403] Loading part xc7a35ticpg236-1L
  - [Project 1-236] Implementation specific constraints were found while reading constraint file [D:/digital design/projects/project\_2/Constraints\_basys3.xdc]. These constraints will be ignored for synthesis but will be used in implementation. Impacted constraints are listed in the file [XII/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 "read\_addr\_received0" won't be mapped to Block RAM because address size (4) smaller than threshold (5) (7 more like this)
  - [Synth 8-3354] encoded FSM with state register 'cs\_reg' using encoding 'sequential' in module 'SPI\_Slave'
  - [Project 1-571] Translating synthesized netlist
  - 10 [Netlist 29-17] Analyzing 12 Unisim elements for replacement
  - [Netlist 29-28] Unisim Transformation completed in 0 CPU seconds
  - > (a) [Project 1-570] Preparing netlist for logic optimization (1 more like this)
  - (1) [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)

Activate Windows
Go to Settings to activate Windows.

- (1) [Common 17-83] Releasing license: Synthesis
- (1) [Constraints 18-5210] No constraint will be written out.
- 👩 [Common 17-1381] The checkpoint 'D:/digital design/projects/project\_2/SPI Project/SPI Project.runs/synth\_1/SPI\_wrapper.dcp' has been generated.
- 🐧 [runtcl-4] Executing : report\_utilization -file SPI\_wrapper\_utilization\_synth.rpt -pb SPI\_wrapper\_utilization\_synth.pb
- (1) [Common 17-206] Exiting Vivado at Thu Aug 22 03:53:23 2024...
- Implementation (112 infos, 239 status messages)
  - ✓ □ Design Initialization (11 infos, 7 status messages)
    - > ① Command: open\_checkpoint {D:/digital design/projects/project\_2/SPI Project/SPI Project.runs/impl\_1/SPI\_wrapper.dcp} (6 more like this)
      - (1) [Netlist 29-17] Analyzing 12 Unisim elements for replacement
      - (Netlist 29-28) Unisim Transformation completed in 0 CPU seconds
      - (Project 1-479) Netlist was created with Vivado 2018.2
      - (1) [Device 21-403] Loading part xc7a35ticpg236-1L
      - (Project 1-570) Preparing netlist for logic optimization
      - 1 [Timing 38-478] Restoring timing data from binary archive.
      - (Timing 38-479) Binary timing data restore complete.
      - (Project 1-856) Restoring constraints from binary archive.
      - (Project 1-853) Binary constraint restore complete.
      - [Project 1-111] Unisim Transformation Summary: A total of 8 instances were transformed. RAM256X1S => RAM256X1S (MUXF7, MUXF7, MUXF8, RAMS64E, RAMS64E, RAMS64E, RAMS64E): 8 instances
      - [Project 1-604] Checkpoint was created with Vivado v2018.2 (64-bit) build 2258646
  - ✓ □ Opt Design (24 infos, 45 status messages)
    - > (i) Command: opt\_design (44 more like this)
      - f) [Common 17-349] Got license for feature 'Implementation' and/or device 'xc7a35ti'
      - [Project 1-461] DRC finished with 0 Errors
      - 1 [Project 1-462] Please refer to the DRC report (report\_drc) for more information.
      - [Timing 38-35] Done setting XDC timing constraints.
      - [Opt 31-49] Retargeted 0 cell(s).
    - > 1 [Opt 31-138] Pushed 0 inverter(s) to 0 load pin(s). (1 more like this)
    - > (1) [Opt 31-389] Phase Retarget created 0 cells and removed 0 cells (4 more like this)
      - 1 [Opt 31-662] Phase BUFG optimization created 0 cells of which 0 are BUFGs and removed 0 cells.
      - (1) [Pwropt 34-132] Skipping clock gating for clocks with a period < 2.00 ns.</p>
      - (1) [Common 17-83] Releasing license: Implementation
      - (1) [Timing 38-480] Writing timing data to binary archive.
      - 🐧 [Common 17-1381] The checkpoint 'D:/digital design/projects/project\_2/SPI Project/SPI Project.runs/impl\_1/SPI\_wrapper\_opt.dcp' has been generated.
      - 🐧 [runtcl-4] Executing : report\_drc\_file SPI\_wrapper\_drc\_opted.rpt -pb SPI\_wrapper\_drc\_opted.pb -rpx SPI\_wrapper\_drc\_opted.rpx
      - 1 [IP\_Flow 19-234] Refreshing IP repositories
      - [IP\_Flow 19-1704] No user IP repositories specified
      - 19. [IP\_Flow 19-2313] Loaded Vivado IP repository 'E:/Vivado/2018.2/data/ip'.
    - > 1 [DRC 23-27] Running DRC with 2 threads (1 more like this)
      - [Coretcl 2-168] The results of DRC are in file SPI\_wrapper\_drc\_opted.rpt.

- → □ Place Design (21 infos, 90 status messages)
  - > (i) Command: place\_design (89 more like this)
    - (Common 17-349) Got license for feature 'Implementation' and/or device 'xc7a35ti'
  - > 1 [DRC 23-27] Running DRC with 2 threads (1 more like this)
  - > 1 [Vivado\_Tcl 4-198] DRC finished with 0 Errors (1 more like this)
  - > 1 [Vivado\_Tcl 4-199] Please refer to the DRC report (report\_drc) for more information. (1 more like this)
    - [Place 30-611] Multithreading enabled for place\_design using a maximum of 2 CPUs
    - (Physopt 32-65) No nets found for high-fanout optimization.
    - (Physopt 32-232) Optimized 0 net. Created 0 new instance.
  - 👩 [Physopt 32-775] End 1 Pass. Optimized 0 net or cell. Created 0 new cell, deleted 0 existing cell and moved 0 existing cell
  - > (1 more like this)
  - [Place 46-31] BUFG insertion identified 0 candidate nets, 0 success, 0 skipped for placement/routing, 0 skipped for timing, 0 skipped for netlist change reason.
  - [Place 30-746] Post Placement Timing Summary WNS=6.770. For the most accurate timing information please run report\_timing.
  - (1) [Common 17-83] Releasing license: Implementation
  - (1) [Timing 38-480] Writing timing data to binary archive.
  - 🚯 [Common 17-1381] The checkpoint 'D:/digital design/projects/project\_2/SPI Project/SPI Project.runs/impl\_1/SPI\_wrapper\_placed.dcp' has been generated.
  - > 1 [runtcl-4] Executing: report\_io -file SPI\_wrapper\_io\_placed.rpt (2 more like this)

#### ∨ □ Route Design (34 infos, 77 status messages)

- > (i) Command: route\_design (76 more like this)
- (Common 17-349) Got license for feature 'Implementation' and/or device 'xc7a35ti'
- [Vivado\_Tcl 4-198] DRC finished with 0 Errors
- (Vivado\_Tcl 4-199) Please refer to the DRC report (report\_drc) for more information.
- f) [Route 35-254] Multithreading enabled for route\_design using a maximum of 2 CPUs
- > () [Route 35-416] Intermediate Timing Summary | WNS=6.754 | TNS=0.000 | WHS=-0.203 | THS=-25.280 | (2 more like this)
- [Route 35-57] Estimated Timing Summary | WNS=5.892 | TNS=0.000 | WHS=0.049 | THS=0.000 |
- (a) [Route 35-327] The final timing numbers are based on the router estimated timing analysis. For a complete and accurate timing signoff, please run report\_timing\_summary
- (B) [Route 35-16] Router Completed Successfully
- (1) [Common 17-83] Releasing license: Implementation
- (Timing 38-480) Writing timing data to binary archive
- 🚯 [Common 17-1381] The checkpoint 'D:/digital design/projects/project\_2/SPI Project/SPI Project.runs/impl\_1/SPI\_wrapper\_routed.dcp' has been generated.
- > (1 more like this)
- (Coretcl 2-168) The results of DRC are in file SPI\_wrapper\_drc\_routed.rpt.
- > 1 [runtcl-4] Executing : report\_drc -file SPI\_wrapper\_drc\_routed.rpt -pb SPI\_wrapper\_drc\_routed.pb -rpx SPI\_wrapper\_drc\_routed.rpx (7 more like this)
- > 1 [Timing 38-35] Done setting XDC timing constraints. (2 more like this)
- (1) [DRC 23-133] Running Methodology with 2 threads
- [Coretcl 2-1520] The results of Report Methodology are in file SPI\_wrapper\_methodology\_drc\_routed.rpt.
- (i) [Vivado\_Tcl 4-545] No incremental reuse to report, no incremental placement and routing data was found.
- > 1 [Timing 38-91] UpdateTimingParams: Speed grade: -1L, Delay Type: min\_max, Timing Stage: Requireds. (1 more like this)
- > (1 Timing 38-191) Multithreading enabled for timing update using a maximum of 2 CPUs (1 more like this)

#### Write Bitstream (22 infos, 20 status messages)

- > (i) Command: open\_checkpoint SPI\_wrapper\_routed.dcp (19 more
- 10 [Netlist 29-17] Analyzing 12 Unisim elements for replacement
- (Netlist 29-28) Unisim Transformation completed in 0 CPU seconds
- Project 1-479 Netlist was created with Vivado 2018.2 (1) [Device 21-403] Loading part xc7a35ticpg236-1L
- [Project 1-570] Preparing netlist for logic optimization
- [Timing 38-478] Restoring timing data from binary archive.
- 1 [Timing 38-479] Binary timing data restore complete
- (Project 1-856) Restoring constraints from binary archive
- Project 1-853] Binary constraint restore complete.
- [Project 1-111] Unisim Transformation Summary:
   A total of 8 instances were transformed.
   RAM256X1S => RAM256X1S (MUXF7, MUXF7, MUXF8, RAMS64E, RAMS64E, RAMS64E, RAMS64E): 8 instances

Project 1-604] Checkpoint was created with Vivado v2018.2 (64-bit) build 2258646

- Common 17-3491 Got license for feature 'Implementation' and/or device 'xc7a35ti'
- [IP\_Flow 19-234] Refreshing IP repositories
- [IP\_Flow 19-1704] No user IP repositories specified
- [IP\_Flow 19-2313] Loaded Vivado IP repository 'E:/Vivado/2018.2/data/ip'.
- (1) [DRC 23-27] Running DRC with 2 threads
- (i) IVivado 12-31991 DRC finished with 0 Errors
- [Vivado 12-3200] Please refer to the DRC report (report\_drc) for more information
- ① [Designutils 20-2272] Running write\_bitstream with 2 threads.
- [Vivado 12-1842] Bitgen Completed Successfully.
- [Project 1-120] WebTalk data collection is mandatory when using a WebPACK part without a full Vivado license. To see the specific WebTalk data collected for your design, open the usage\_statistics\_webtalk.html or usage\_statistics\_webtalk.xml file in the implementation directory.
- (1) [Common 17-83] Releasing license: Implementation

- → Implemented Design (9 infos, 6 status messages)
  - ✓ ☐ General Messages (9 infos, 6 status messages)
    - (Netlist 29-17) Analyzing 12 Unisim elements for replacement
    - 1 [Netlist 29-28] Unisim Transformation completed in 0 CPU seconds
    - (Project 1-479) Netlist was created with Vivado 2018.2
    - (Project 1-570) Preparing netlist for logic optimization
    - [Timing 38-478] Restoring timing data from binary archive.
    - [Timing 38-479] Binary timing data restore complete.
    - (Project 1-856) Restoring constraints from binary archive.
    - (Project 1-853) Binary constraint restore complete.
    - > (i) Reading XDEF placement. (5 more like this)
      - [Project 1-111] Unisim Transformation Summary: A total of 8 instances were transformed. RAM256X1S => RAM256X1S (MUXF7, MUXF7, MUXF8, RAMS64E, RAMS64E, RAMS64E, RAMS64E): 8 instances

### o With debug core:

- ✓ Implementation (1 critical warning, 3 warnings, 108 infos, 249 status messages)
  - ∨ □ Design Initialization (11 infos, 7 status messages)
    - > ① Command: open\_checkpoint {D:/digital design/projects/project\_2/SPI Project/SPI Project.runs/impl\_1/SPI\_wrapper.dcp} (6 more like this)
      - (1) [Netlist 29-17] Analyzing 12 Unisim elements for replacement
      - (Netlist 29-28) Unisim Transformation completed in 0 CPU seconds
      - (Project 1-479) Netlist was created with Vivado 2018.2
      - (1) [Device 21-403] Loading part xc7a35ticpg236-1L
      - (Project 1-570) Preparing netlist for logic optimization
      - [Timing 38-478] Restoring timing data from binary archive.
      - (Timing 38-479) Binary timing data restore complete.
      - (Project 1-856) Restoring constraints from binary archive.
      - (Project 1-853) Binary constraint restore complete.
    - [Project 1-111] Unisim Transformation Summary: A total of 8 instances were transformed. RAM256X1S => RAM256X1S (MUXF7, MUXF7, MUXF8, RAMS64E, RAMS64E, RAMS64E): 8 instances
    - [Project 1-604] Checkpoint was created with Vivado v2018.2 (64-bit) build 2258646
  - Opt Design (35 infos, 54 status messages)
    - > (i) Command: opt\_design (53 more like this)
      - (i) [Common 17-349] Got license for feature 'Implementation' and/or device 'xc7a35ti'
      - (1) [Project 1-461] DRC finished with 0 Errors
      - 1 [Project 1-462] Please refer to the DRC report (report\_drc) for more information.
      - [IP\_Flow 19-234] Refreshing IP repositories
      - [IP\_Flow 19-1704] No user IP repositories specified
      - [IP\_Flow 19-2313] Loaded Vivado IP repository 'E:/Vivado/2018.2/data/ip'.
    - > (1) [Chipscope 16-329] Generating Script for core instance : dbg\_hub (1 more like this)
    - > 1 [IP\_Flow 19-3806] Processing IP xilinx.com:ip:xsdbm:3.0 for cell dbg\_hub\_CV. (1 more like this)
      - [Opt 31-49] Retargeted 0 cell(s).

- > 1 [Opt 31-138] Pushed 0 inverter(s) to 0 load pin(s). (1 more like this)
- > (1) [Opt 31-389] Phase Retarget created 0 cells and removed 0 cells (4 more like this)
  - Opt 31-662] Phase BUFG optimization created 0 cells of which 0 are BUFGs and removed 0 cells.
- (1) [Pwropt 34-132] Skipping clock gating for clocks with a period < 2.00 ns.
- [Pwropt 34-9] Applying IDT optimizations
- > (1 more like this)
- (1) [Pwropt 34-10] Applying ODC optimizations ...
- (Physopt 32-619) Estimated Timing Summary | WNS=4.856 | TNS=0.000 |
- (Pwropt 34-162) WRITE\_MODE attribute of 0 BRAM(s) out of a total of 1 has been updated to save power. Run report\_power\_opt to get a complete listing of the BRAMs updated.
- [Pwropt 34-201] Structural ODC has moved 0 WE to EN ports
- () [Common 17-83] Releasing license: Implementation
- (Timing 38-480) Writing timing data to binary archive.
- (5) [Common 17-1381] The checkpoint 'D:/digital design/projects/project\_2/SPI Project/SPI Project.runs/impl\_1/SPI\_wrapper\_opt.dcp' has been generated.
- [runtcl-4] Executing : report\_drc\_file SPI\_wrapper\_drc\_opted.rpt -pb SPI\_wrapper\_drc\_opted.pb -rpx SPI\_wrapper\_drc\_opted.rpx
- (IP Flow 19-1839) IP Catalog is up to date
- > 1 [DRC 23-27] Running DRC with 2 threads (1 more like this)
  - (Coretcl 2-168) The results of DRC are in file SPI\_wrapper\_drc\_opted.rpt.
- → Place Design (24 infos, 90 status messages)
  - (1) [Chipscope 16-240] Debug cores have already been implemented
  - > (i) Command: place\_design (89 more like this)
  - (1) [Common 17-349] Got license for feature 'Implementation' and/or device 'xc7a35ti'
  - > (1) [DRC 23-27] Running DRC with 2 threads (1 more like this)
  - > 1 [Vivado\_Tcl 4-198] DRC finished with 0 Errors (1 more like this)
  - > (1 [Vivado\_Tcl 4-199] Please refer to the DRC report (report\_drc) for more information. (1 more like this)
  - 1 [Place 30-611] Multithreading enabled for place\_design using a maximum of 2 CPUs

Go to Se

- > 1 [Vivado\_I cl 4-198] DRC tinished with 0 Errors (1 more like this)
- > 1 [Vivado\_Tcl 4-199] Please refer to the DRC report (report\_drc) for more information. (1 more like this)
  - [Place 30-611] Multithreading enabled for place\_design using a maximum of 2 CPUs
  - (3) [Opt 31-138] Pushed 0 inverter(s) to 0 load pin(s).
- > 1 [Timing 38-35] Done setting XDC timing constraints. (2 more like this)
  - (Physopt 32-65) No nets found for high-fanout optimization.
  - (1) [Physopt 32-232] Optimized 0 net. Created 0 new instance.
  - [Physopt 32-775] End 1 Pass. Optimized 0 net or cell. Created 0 new cell, deleted 0 existing cell and moved 0 existing cell
  - [Place 46-31] BUFG insertion identified 0 candidate nets, 0 success, 0 skipped for placement/routing, 0 skipped for timing, 0 skipped for netlist change reason.
  - Place 30-746] Post Placement Timing Summary WNS=4.358. For the most accurate timing information please run report\_timing.
  - (1) [Common 17-83] Releasing license: Implementation
  - (1) [Timing 38-480] Writing timing data to binary archive.
  - [Common 17-1381] The checkpoint 'D:/digital design/projects/project\_2/SPI Project/SPI Project.runs/impl\_1/SPI\_wrapper\_placed.dcp' has been generated.
- > 1 [runtcl-4] Executing: report\_io -file SPI\_wrapper\_io\_placed.rpt (2 more like this)
- → Route Design (1 critical warning, 3 warnings, 38 infos, 98 status messages)
  - > (i) Command: route\_design (97 more like this)
  - (Common 17-349) Got license for feature 'Implementation' and/or device 'xc7a35ti'
  - () [Vivado\_Tcl 4-198] DRC finished with 0 Errors
  - [Vivado\_Tcl 4-199] Please refer to the DRC report (report\_drc) for more information.
  - 1 [Route 35-254] Multithreading enabled for route\_design using a maximum of 2 CPUs
  - > (1) [Route 35-416] Intermediate Timing Summary | WNS=4.398 | TNS=0.000 | WHS=-1.088 | THS=-103.818 | (6) more like this)
  - [Route 35-459] Router was unable to fix hold violation on 2 pins. This could be due to a combination of congestion, blockages and run-time limitations. Such pins are: u\_ila\_0/inst/ila\_core\_inst/probeDelay1[0]\_i\_1/l2 u\_ila\_0/inst/ila\_core\_inst/shifted\_data\_in\_reg[7][0]\_srl8/D

Resolution: You may try high effort hold fixing by turning on param route.enableGlobalHoldIter.

- [Route 35-328] Router estimated timing not met. Resolution: For a complete and accurate timing signoff, report\_timing\_summary must be run after route\_design. Alternatively, route\_design can be run with the -timing\_summary option to enable a complete timing signoff at the end of route\_design.
- (1) [Route 35-16] Router Completed Successfully
- (1) [Common 17-83] Releasing license: Implementation
- (1) [Timing 38-480] Writing timing data to binary archive
- (Common 17-1381) The checkpoint 'D'/digital design/projects/project\_2/SPI Project/SPI Project.runs/impl\_1/SPI\_wrapper\_routed.dcp' has been generated.
- [IP\_Flow 19-1839] IP Catalog is up to date.
- > (1 more like this)
- [Coretcl 2-168] The results of DRC are in file SPI\_wrapper\_drc\_routed.rpt.
- > ① [runtcl-4] Executing : report\_drc\_file SPI\_wrapper\_drc\_routed.rpt -pb SPI\_wrapper\_drc\_routed.pb -rpx SPI\_wrapper\_drc\_routed.rpx (7 more like this)
- > (1) [Timing 38-35] Done setting XDC timing constraints. (2 more like this)
  - (1) [DRC 23-133] Running Methodology with 2 threads
  - [Coretcl 2-1520] The results of Report Methodology are in file SPI\_wrapper\_methodology\_drc\_routed.rpt.
  - o [Timing 38-282] The design failed to meet the timing requirements. Please see the timing summary report for details on the timing violations.
  - [Timing 38-436] There are set\_bus\_skew constraint(s) in this design. Please run report\_bus\_skew to ensure that bus skew requirements are met.
  - [Vivado\_Tcl 4-545] No incremental reuse to report, no incremental placement and routing data was found.
- > 1 [Timing 38-91] UpdateTimingParams: Speed grade: -1L, Delay Type: min\_max, Timing Stage: Requireds. (1 more like this)
- > 1 [Timing 38-191] Multithreading enabled for timing update using a maximum of 2 CPUs (1 more like this)
- → The Implemented Design (1 critical warning, 1 warning, 10 infos, 7 status messages)
  - General Messages (1 critical warning, 1 warning, 10 infos, 7 status messages)
    - (1) [Netlist 29-17] Analyzing 110 Unisim elements for replacement
    - (Netlist 29-28) Unisim Transformation completed in 0 CPU seconds
    - (Project 1-479) Netlist was created with Vivado 2018.2
    - (Project 1-570) Preparing netlist for logic optimization
    - [Chipscope 16-324] Core: u\_ila\_0 UUID: 23e7d65a-79bc-59f7-bc47-406c1714dfae
    - [Timing 38-478] Restoring timing data from binary archive.
    - Timing 38-479] Binary timing data restore complete.
    - (Project 1-856) Restoring constraints from binary archive.
    - (Project 1-853) Binary constraint restore complete.
    - > (i) Reading XDEF placement. (6 more like this)
      - (Project 1-111) Unisim Transformation Summary:

A total of 62 instances were transformed.

CFGLUT5 => CFGLUT5 (SRLC32E, SRL16E): 48 instances

RAM256X1S => RAM256X1S (MUXF7, MUXF7, MUXF8, RAMS64E, RAMS64E, RAMS64E): 8 instances

- RAM32M => RAM32M (RAMD32, RAMD32, RAMD32, RAMD32, RAMD32, RAMD32, RAMS32): 6 instances
- 🚯 [Timing 38-282] The design failed to meet the timing requirements. Please see the timing summary report for details on the timing violations. 👵 [Timing 38-436] There are set\_bus\_skew constraint(s) in this design. Please run report\_bus\_skew to ensure that bus skew requirements are met.