# Basys3 vs VTR Earch comparison Design: 4 bit counter

Nanditha Rao

# Post implementation Timing

### With a clock period of 10ns or frequency of 100MHz

| Parameter                            | Slack with Basys3 | Slack with VTR Earch |
|--------------------------------------|-------------------|----------------------|
| Technology                           | 28nm              | 40nm [Earch]         |
| Worst Negative Slack<br>(WNS)- Setup | 5.77ns            | 8.54ns               |
| Worst Negative Slack<br>(WNS)- Hold  | 0.23ns            | 0.293ns              |

### **Clock frequency varied to get minimum slack**

| Parameter                            | with Basys3           | with VTR Earch        |
|--------------------------------------|-----------------------|-----------------------|
| Max freq                             | 285MHz (period 3.5ns) | 555MHz (period 1.8ns) |
| Worst Negative Slack<br>(WNS)- Setup | 0.41ns                | 0.34ns                |
| Worst Negative Slack<br>(WNS)- Hold  | 0.33ns                | 0.293ns               |

# VTR Earch: Worst case setup path Design: counter: 555MHz

| Startpoint: up_counter^out~0_FF.Q[0] (.latch clocked by Endpoint : up_counter^out~3_FF.D[0] (.latch clocked by Path Type : setup                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                                              |                                                                                                                            |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------|
| Point                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Incr                                                                                                                                         | Path                                                                                                                       |
| <pre>clock up_counter_clk (rise edge)  clock source latency up_counter_clk.inpad[0] (.input) up_counter^out~0_FF.clk[0] (.latch) up_counter^out~0_FF.Q[0] (.latch) [clock-to-output] up_counter^ADD~4-1[0].a[0] (adder) up_counter^ADD~4-1[0].cout[0] (adder) up_counter^ADD~4-2[0].cin[0] (adder) up_counter^ADD~4-3[0].cout[0] (adder) up_counter^ADD~4-3[0].cout[0] (adder) up_counter^ADD~4-4[0].cin[0] (adder) up_counter^ADD~4-4[0].sumout[0] (adder) up_counter^ADD~4-4[0].cin[0] (adder) up_counter^</pre> | 0.000<br>0.000<br>0.000<br>0.042<br>0.124<br>0.315<br>0.300<br>0.000<br>0.010<br>0.000<br>0.010<br>0.000<br>0.300<br>0.100<br>0.235<br>0.000 | 0.000<br>0.000<br>0.000<br>0.042<br>0.166<br>0.481<br>0.781<br>0.791<br>0.791<br>0.801<br>1.101<br>1.201<br>1.436<br>1.436 |
| <pre>clock up_counter_clk (rise edge) clock source latency up_counter_clk.inpad[0] (.input) up_counter^out~3_FF.clk[0] (.latch) clock uncertainty cell setup time data required time  data required time</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 1.800<br>0.000<br>0.000<br>0.042<br>0.000<br>-0.066                                                                                          | 1.800<br>1.800<br>1.842<br>1.842<br>1.776<br>1.776                                                                         |
| data required time<br>data arrival time                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                              | -1.436                                                                                                                     |
| slack (MET)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                              | 0.340                                                                                                                      |

#Path 1

# VTR Earch: Worst case hold path Design: counter: 555MHz

#Path 1

Startpoint: up\_counter^out~0\_FF.Q[0] (.latch clocked by up\_counter\_clk) Endpoint : up\_counter^out~0\_FF.D[0] (.latch clocked by up\_counter\_clk)

Path Type : hold

| Point                                                                                                                                                                                                                                                                                | Incr                                                                 | Path                                                                 |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------|----------------------------------------------------------------------|
| <pre>clock up_counter_clk (rise edge) clock source latency up_counter_clk.inpad[0] (.input) up_counter^out~0_FF.clk[0] (.latch) up_counter^out~0_FF.Q[0] (.latch) [clock-to-output] n22.in[0] (.names) n22.out[0] (.names) up_counter^out~0_FF.D[0] (.latch) data arrival time</pre> | 0.000<br>0.000<br>0.000<br>0.000<br>0.124<br>0.000<br>0.235<br>0.000 | 0.000<br>0.000<br>0.000<br>0.000<br>0.124<br>0.124<br>0.359<br>0.359 |
| <pre>clock up_counter_clk (rise edge) clock source latency up_counter_clk.inpad[0] (.input) up_counter^out~0_FF.clk[0] (.latch) clock uncertainty cell hold time data required time</pre>                                                                                            | 0.000<br>0.000<br>0.000<br>0.000<br>0.000<br>0.066                   |                                                                      |
| data required time<br>data arrival time<br>slack (MET)                                                                                                                                                                                                                               |                                                                      | -0.066<br>0.359<br>                                                  |

### Basys3: Worst case setup path

| Summary         | ,                                                                         |                         | • •       |           |                    |                              |
|-----------------|---------------------------------------------------------------------------|-------------------------|-----------|-----------|--------------------|------------------------------|
| Name            | ₁ Path 1                                                                  |                         |           |           |                    |                              |
| Slack           | 0.412ns                                                                   |                         |           |           |                    |                              |
| Source          | ■ delay_count_reg[3]/C (rising edge-triggered of the delay_count_reg[3]/C | ell FDRE clocked by clk |           |           |                    |                              |
| Destination     | ■ delay_count_reg[24]/D (rising edge-triggered                            | cell FDRE clocked by cl |           |           |                    |                              |
| Path Group      | clk                                                                       | Source Clock Path       |           |           |                    |                              |
| Path Type       | Setup (Max at Slow Process Corner)                                        | Delay Type              | Incr (ns) | Path (ns) | Location           | Netlist Resource(s)          |
| Requirement     | 3.500ns (clk rise@3.500ns - clk rise@0.000ns)                             | (clock clk rise edge)   | (r) 0.000 | 0.000     |                    |                              |
| Data Path Delay | 3.052ns (logic 2.115ns (69.290%) route 0.937ns                            |                         | (r) 0.000 | 0.000     | Site: W5           | D clk                        |
| Logic Levels    | 7 (CARRY4=6 LUT3=1)                                                       | net (fo=0)              | 0.000     | 0.000     |                    | ∕¹ clk                       |
| Clock Path Skew | -0.029ns                                                                  | IBUF (Prop_ibuf_I_0)    | (r) 1.458 | 1.458     | Site: W5           | <pre>d clk_IBUF_inst/0</pre> |
| Clock Unrtainty | 0.035ns                                                                   | net (fo=1, routed)      | 1.967     | 3.425     |                    | ∠ clk_IBUF                   |
|                 |                                                                           | BUFG (Prop_bufg_I_0)    | (r) 0.096 | 3.521     | Site: BURL_X0Y0    | clk_IBUF_BUFG_inst/0         |
|                 |                                                                           | net (fo=27, routed)     | 1.619     | 5.140     |                    | ∠ clk_IBUF_BUFG              |
| Data Path       |                                                                           | FDRE                    |           |           | Site: SLICE_X64Y65 | delay_count_reg[3]/C         |

| Delay Type                    | Incr (ns) | Path (ns) | Location           | Netlist Resource(s)                   |
|-------------------------------|-----------|-----------|--------------------|---------------------------------------|
| FDRE (Prop_fdre_C_Q)          | (r) 0.518 | 5.658     | Site: SLICE_X64Y65 | delay_count_reg[3]/Q                  |
| net (fo=2, routed)            | 0.540     | 6.198     |                    | → delay_count_reg_n_0_[3]             |
| CARRY4 (Prop_c4_S[2]_C0[3])   | (r) 0.522 | 6.720     | Site: SLICE_X65Y65 | delay_count_reg[4]_i_2/C0[3]          |
| net (fo=1, routed)            | 0.000     | 6.720     |                    | → delay_count_reg[4]_i_2_n_0          |
| CARRY4 (Prop_carry4_CI_CO[3]) | (r) 0.114 | 6.834     | Site: SLICE_X65Y66 | delay_count_reg[8]_i_2/C0[3]          |
| net (fo=1, routed)            | 0.000     | 6.834     |                    | <pre>delay_count_reg[8]_i_2_n_0</pre> |
| CARRY4 (Prop_carry4_CI_CO[3]) | (r) 0.114 | 6.948     | Site: SLICE_X65Y67 | delay_count_reg[12]_i_2/C0[3]         |
| net (fo=1, routed)            | 0.000     | 6.948     |                    | → delay_count_reg[12]_i_2_n_0         |
| CARRY4 (Prop_carry4_CI_CO[3]) | (r) 0.114 | 7.062     | Site: SLICE_X65Y68 | delay_count_reg[16]_i_2/C0[3]         |
| net (fo=1, routed)            | 0.000     | 7.062     |                    | → delay_count_reg[16]_i_2_n_0         |
| CARRY4 (Prop_carry4_CI_CO[3]) | (r) 0.114 | 7.176     | Site: SLICE_X65Y69 | delay_count_reg[20]_i_2/C0[3]         |
| net (fo=1, routed)            | 0.000     | 7.176     |                    | → delay_count_reg[20]_i_2_n_0         |
| CARRY4 (Prop_carry4_CI_0[3])  | (r) 0.313 | 7.489     | Site: SLICE_X65Y70 | delay_count_reg[24]_i_2/0[3]          |
| net (fo=1, routed)            | 0.398     | 7.886     |                    | → data0[24]                           |
| LUT3 (Prop_lut3_I2_0)         | (r) 0.306 | 8.192     | Site: SLICE_X63Y70 | delay_count[24]_i_1/0                 |
| net (fo=1, routed)            | 0.000     | 8.192     |                    | → delay_count[24]                     |
| FDRE                          |           |           | Site: SLICE_X63Y70 | delay_count_reg[24]/D                 |
| Arrival Time                  |           | 8.192     |                    |                                       |

### Basys3: Worst case setup path

### Path schematics



### Basys3: Worst case hold path

| Summary      |                      |                                                   |
|--------------|----------------------|---------------------------------------------------|
| Name         | 🧘 Path 11            |                                                   |
| Slack (Hold) | 0.334ns              |                                                   |
| Source       | div_clk_reg/C (ri    | sing edge-triggered cell FDRE clocked by clk {ri: |
| Destination  | div_clk_reg/D (ri    | sing edge-triggered cell FDRE clocked by clk {ri  |
| Path Group   | clk                  |                                                   |
| Path Type    | Hold (Min at Fast Pr | ocess Corner)                                     |
| Requirement  | 0.000ns (clk rise@0  | .000ns - clk rise@0.000ns)                        |
| Data PDelay  | 0.455ns (logic 0.20) | 9ns (45.985%) route 0.246ns (54.015%))            |
| Logic Levels | 1 (LUT3=1)           |                                                   |
| Clock Skew   | 0.000ns              | Source Clock Path                                 |

| Incr (ns) | Path (ns)                                                          | Location                                                                                               | Netlist Resource(s)                                                                                                                   |
|-----------|--------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------|
| (r) 0.000 | 0.000                                                              |                                                                                                        |                                                                                                                                       |
| (r) 0.000 | 0.000                                                              | Site: W5                                                                                               | D clk                                                                                                                                 |
| 0.000     | 0.000                                                              |                                                                                                        | ∕ clk                                                                                                                                 |
| (r) 0.226 | 0.226                                                              | Site: W5                                                                                               | ← clk_IBUF_inst/0                                                                                                                     |
| 0.631     | 0.858                                                              |                                                                                                        | ∠ clk_IBUF                                                                                                                            |
| (r) 0.026 | 0.884                                                              | Site: BURL_X0Y0                                                                                        | clk_IBUF_BUFG_inst/0                                                                                                                  |
| 0.586     | 1.469                                                              |                                                                                                        | → clk_IBUF_BUFG                                                                                                                       |
|           |                                                                    | Site: SLICE_X64Y68                                                                                     | div_clk_reg/C                                                                                                                         |
|           | (r) 0.000<br>(r) 0.000<br>0.000<br>(r) 0.226<br>0.631<br>(r) 0.026 | (r) 0.000 0.000<br>(r) 0.000 0.000<br>0.000 0.000<br>(r) 0.226 0.226<br>0.631 0.858<br>(r) 0.026 0.884 | (r) 0.000 0.000 (r) 0.000 0.000 Site: W5 0.000 0.000 (r) 0.226 0.226 Site: W5 0.631 0.858 (r) 0.026 0.884 Site: BURL_X0Y0 0.586 1.469 |



| Data Path          |           |           |                    |                              |
|--------------------|-----------|-----------|--------------------|------------------------------|
| Delay Type         | Incr (ns) | Path (ns) | Location           | Netlist Resource(s)          |
| FDRE (Prdre_C_Q)   | (r) 0.164 | 1.633     | Site: SLICE_X64Y68 | div_clk_reg/Q                |
| net (fo=5, routed) | 0.246     | 1.879     |                    | <pre>/ div_clk_reg_n_0</pre> |
| LUT3 (Prot3_I2_0)  | (r) 0.045 | 1.924     | Site: SLICE_X64Y68 | div_clk_i_1/0                |
| net (fo=1, routed) | 0.000     | 1.924     |                    | → div_clk_i_1_n_0            |
| FDRE               |           |           | Site: SLICE_X64Y68 | div_clk_reg/D                |
| Arrival Time       |           | 1.924     |                    |                              |

# Area and power

### Area

### Basys3

| Resource | Utilization | Available | Utilization % |
|----------|-------------|-----------|---------------|
| LUT      | 23          | 20800     | 0.11          |
| FF       | 31          | 41600     | 0.07          |
| 10       | 6           | 106       | 5.66          |



| Parameter  | Resources on<br>Basys3 | Resources with VTR |
|------------|------------------------|--------------------|
| LUTs       | 23                     | 18                 |
| I/O        | 6                      | 7                  |
| Flip-flops | 31                     | 4                  |

#### **VTR**

| Pb | types usage          |         |             |
|----|----------------------|---------|-------------|
| j  | .0                   | :       | 7           |
|    | inpad                | :       | 3           |
|    | outpad               | :       | 4           |
| (  | lb                   | :       | 1           |
|    | fle                  | :       | 6           |
|    | lut5inter            | :       | 6           |
|    |                      |         |             |
|    | ble5                 | :       | 11          |
|    | ble5<br>flut5        | :       | 11<br>6     |
|    |                      | :       |             |
|    | flut5                | :       | 6           |
|    | flut5<br>lut5        | : : : : | 6           |
|    | flut5<br>lut5<br>lut | •       | 6<br>6<br>6 |

### Circuit Statistics:

| Blocks: 2 | 2 |   |
|-----------|---|---|
| .input    | : | 3 |
| .latch    | : | 4 |
| .output   | : | 4 |
| 0-LUT     | : | 2 |
| 6-LUT     | : | 4 |
| adder     | : | 5 |

Nets: 21
Avg Fanout: 2.0
Max Fanout: 4.0
Min Fanout: 1.0

#### Basys3

### Power

Power analysis from Implemented netlist. Activity derived from constraints files, simulation files or vectorless analysis.

Total On-Chip Power: 0.084 W

Design Power Budget: Not Specified

Power Budget Margin: N/A

Junction Temperature: 25.4°C

Thermal Margin: 59.6°C (11.9 W)

Effective  $\theta$ JA: 5.0°C/W

Power supplied to off-chip devices: 0 W

Confidence level: Medium

<u>Launch Power Constraint Advisor</u> to find and fix

invalid switching activity



#### **VTR**

|                          | Power Break | down    |                  | - |
|--------------------------|-------------|---------|------------------|---|
| Component                | Power (W)   | %-Total | %-Dynamic Method |   |
| Total                    | 0.0003212   | 1       | 0.7689           |   |
| Routing                  | 0.0001066   | 0.3319  | 0.4223           |   |
| Switch Box               | 9.697e-05   | 0.3019  | 0.3837           |   |
| Connection Box           | 5.033e-06   | 0.01567 | 0.6368           |   |
| Global Wires             | 4.617e-06   | 0.01437 | 1                |   |
| PB Types                 | 8.287e-05   | 0.258   | 0.8582           |   |
| Primitives               | 6.158e-05   | 0.1917  | 0.9314           |   |
| Interc Structures        | 7.248e-06   | 0.02256 | 0.6487           |   |
| Buffers and Wires        | 1.404e-05   | 0.0437  | 0.6451           |   |
| Other Estimation Methods | 0           | 0       | -nan             |   |
| Clock                    | 0.0001317   | 0.4101  | 0.9932           |   |
|                          |             |         |                  |   |

## Power

| Parameter | Power with Basys3 (W) | Power with VTR (W) |
|-----------|-----------------------|--------------------|
| Clocks    | 0.001                 | 0.0001             |
| Signals   | 0.001                 | 1.4e-5             |
| Logic     | 0.001                 | 8.2e-5             |
| I/O       | 0.011                 | 0                  |
| Dynamic   | 0.012                 |                    |