

Ομάδα Α10:

Γεώργιος Παγώνης : 03117030

Δημήτριος - Σταμάτιος Μπούρας : 03117072

8ο εξάμηνο - ΨΗΦΙΑΚΑ ΣΥΣΤΗΜΑΤΑ VLSI

ΣΗΜΜΥ

## 2η σειρά ασκήσεων

Όλα τα κυκλώματα περιέχονται σε ξεχωριστά αρχεία vhd στο zip που αποστείλαμε. Παρακάτω για κάθε ερώτημα της άσκησης ξεχωριστά θα αναφέρουμε ποιο testbench αντιστοιχεί σε ποιο ερώτημα καθώς και τα υπόλοιπα αρχεία που απαιτούνται να βρίσκονται στο ίδιο vivado project με αυτό , για να εξασφαλιστεί η ορθή λειτουργεία του.

Μια γρήγορη λύση αποτελεί και η προσθήκη όλων των vhd αρχείων του zip σε ένα vivado project και η εκτέλεση όλων των κυκλωμάτων μέσα σε αυτό το project θέτοντας ως "top" κάθε φορά το κατάλληλο.

1)

Testbench: half\_adder\_tb

Λοιπά απαραίτητα αρχεία : half\_adder

#### RTL schematic





Critical path: Path 1 = a to carry

Time Delay: 5.377

## **Resource Utilization:**



2)

a)

#### **Combinational:**

Testbench: full\_adder\_tb

Λοιπά απαραίτητα αρχεία : full\_adder , half\_adder

## **RTL** schematic



## Critical Path and Time Delay:

| Q   -     | Q = H   Slack ^1 Levels Routes High Fanout From To Total Delay Logic Delay Net Delay Requirement Source Clock Destination Clock Exception |        |        |             |      |       |             |             |           |             |                  |                   |           |
|-----------|-------------------------------------------------------------------------------------------------------------------------------------------|--------|--------|-------------|------|-------|-------------|-------------|-----------|-------------|------------------|-------------------|-----------|
| Name      | Slack ^1                                                                                                                                  | Levels | Routes | High Fanout | From | То    | Total Delay | Logic Delay | Net Delay | Requirement | Source Clock     | Destination Clock | Exception |
| 4 Path 1  | 00                                                                                                                                        | 3      | 4      | 2           | b    | carry | 5.377       | 3.778       | 1.599     | ∞           | input port clock |                   |           |
| ¹₄ Path 2 | 00                                                                                                                                        | 3      | 4      | 2           | b    | sum   | 5.351       | 3.752       | 1.599     | 00          | input port clock |                   |           |

Critical path: Path 1 = b to carry

Time Delay: 5.377

#### **Resource Utilization:**



## Sequential:

Testbench:full\_adder\_seq\_tb

Λοιπά απαραίτητα αρχεία : full\_adder\_seq , half\_adder

# **RTL schematic**



# **Critical Path and Time Delay:**

| Q   -    | Q   -   🔄   🚸   🔝   🌑   Unconstrained Paths - NONE - Setup |        |        |             |             |             |             |             |           |             |                  |                   |           |  |
|----------|------------------------------------------------------------|--------|--------|-------------|-------------|-------------|-------------|-------------|-----------|-------------|------------------|-------------------|-----------|--|
| Name     | Slack ^1                                                   | Levels | Routes | High Fanout | From        | То          | Total Delay | Logic Delay | Net Delay | Requirement | Source Clock     | Destination Clock | Exception |  |
| Դ Path 1 | 00                                                         | 2      | 2      | 1           | carry_reg/C | carry       | 4.076       | 3.276       | 0.800     | 00          |                  |                   |           |  |
| ₄ Path 2 | 00                                                         | 2      | 2      | 1           | sum_reg/C   | sum         | 4.076       | 3.276       | 0.800     | 00          |                  |                   |           |  |
| ₄ Path 3 | 00                                                         | 2      | 3      | 2           | b           | carry_reg/D | 1.932       | 1.132       | 0.800     | 00          | input port clock |                   |           |  |
| Դ Path 4 | 00                                                         | 2      | 3      | 2           | b           | sum_reg/D   | 1.906       | 1.106       | 0.800     | 00          | input port clock |                   |           |  |
| Դ Path 5 | 00                                                         | 1      | 2      | 2           | reset       | carry_reg/R | 1.782       | 0.982       | 0.800     | 00          | input port clock |                   |           |  |
| Դ Path 6 | 00                                                         | 1      | 2      | 2           | reset       | sum_reg/R   | 1.782       | 0.982       | 0.800     | 00          | input port clock |                   |           |  |

Critical path : Path 1 = carry\_reg/C to carry

Time Delay: 4.076

## **Resource Utilization:**

| ilization |             |   | Post-Synt | hesis   Post-Implementation |
|-----------|-------------|---|-----------|-----------------------------|
|           |             |   |           | Graph   <b>Table</b>        |
| Resource  | Utilization | A | vailable  | Utilization %               |
| LUT       |             | 1 | 17600     | 0.01                        |
| FF        |             | 2 | 35200     | 0.01                        |
| 10        |             | 7 | 100       | 7.00                        |
| BUFG      |             | 1 | 32        | 3.13                        |

2)

β)

#### **Combinational:**

Testbench: full\_adder\_numeric\_tb

Λοιπά απαραίτητα αρχεία : full\_adder\_numeric

## **RTL schematic**



# **Critical Path and Time Delay:**

| Q —       | Ħ   ⊗   I | Ш      | Unconst | trained Paths | - NONE | - NONE | - Setup     |             |           |             |                  |                   |           |
|-----------|-----------|--------|---------|---------------|--------|--------|-------------|-------------|-----------|-------------|------------------|-------------------|-----------|
| Name      | Slack ^1  | Levels | Routes  | High Fanout   | From   | То     | Total Delay | Logic Delay | Net Delay | Requirement | Source Clock     | Destination Clock | Exception |
| 4 Path 1  | 00        | 3      | 4       | 2             | cin[0] | carry  | 5.377       | 3.778       | 1.599     | ∞           | input port clock |                   |           |
| ¹₄ Path 2 | 00        | 3      | 4       | 2             | cin[0] | sum    | 5.351       | 3.752       | 1.599     | 00          | input port clock |                   |           |

Critical path : Path 1 = cin[0] to carry

Time Delay: 5.377

## **Resource Utilization:**

| Resource | Utilization | Available | Utilizatio | n %  |
|----------|-------------|-----------|------------|------|
| LUT      |             | 1         | 17600      | 0.01 |
| 10       |             | 5         | 100        | 5.00 |

## Sequential:

Testbench:full\_adder\_numeric\_seq\_tb

Λοιπά απαραίτητα αρχεία : full\_adder\_numeric\_seq

**RTL schematic** 



# Critical Path and Time Delay:

| Q   -     | H ⊗ H    | П 💮    | Unconst | trained Paths | - NONE - NO | NE - Setup  |             |             |           |             |                  |                   |           |
|-----------|----------|--------|---------|---------------|-------------|-------------|-------------|-------------|-----------|-------------|------------------|-------------------|-----------|
| Name      | Slack ^1 | Levels | Routes  | High Fanout   | From        | То          | Total Delay | Logic Delay | Net Delay | Requirement | Source Clock     | Destination Clock | Exception |
| 1 Path 1  | 00       | 2      | 2       | 1             | carry_reg/C | carry       | 4.076       | 3.276       | 0.800     | 00          |                  |                   |           |
| ¹₄ Path 2 | 00       | 2      | 2       | 1             | sum_reg/C   | sum         | 4.076       | 3.276       | 0.800     | 00          |                  |                   |           |
| ¹₄ Path 3 | 00       | 2      | 3       | 2             | cin[0]      | carry_reg/D | 1.932       | 1.132       | 0.800     | 00          | input port clock |                   |           |
| ¹₄ Path 4 | 00       | 2      | 3       | 2             | cin[0]      | sum_reg/D   | 1.906       | 1.106       | 0.800     | 00          | input port clock |                   |           |
| 3 Path 5  | 00       | 1      | 2       | 2             | reset       | carry_reg/R | 1.782       | 0.982       | 0.800     | 00          | input port clock |                   |           |
| ¹₄ Path 6 | 00       | 1      | 2       | 2             | reset       | sum_reg/R   | 1.782       | 0.982       | 0.800     | 00          | input port clock |                   |           |

Critical path : Path 1 = carry\_reg/C to carry

Time Delay: 4.076

# **Resource Utilization:**

| lization |             |   |           | Post-Synt | hesis   Post-Im | plementation |
|----------|-------------|---|-----------|-----------|-----------------|--------------|
|          |             |   |           |           | Gi              | raph   Table |
| Resource | Utilization |   | Available |           | Utilization %   |              |
| LUT      |             | 1 |           | 17600     |                 | 0.01         |
| FF       |             | 2 |           | 35200     |                 | 0.01         |
| 10       |             | 7 |           | 100       |                 | 7.00         |
| BUFG     |             | 1 |           | 32        |                 | 3.13         |

3)

α)

Testbench: rca\_4bit\_combinational\_tb

Λοιπά απαραίτητα αρχεία : rca\_4bit\_combinationa ,full\_adder\_numeric

## RTL schematic



#### Critical Path and Time Delay:



Critical path: Path 1 = a[1] to s[2]

Time Delay: 5.942

## **Resource Utilization:**

| lization |             |    |           | Post-Synt | thesis   Post | -Implementation |
|----------|-------------|----|-----------|-----------|---------------|-----------------|
|          |             |    |           |           |               | Graph   Table   |
| Resource | Utilization |    | Available |           | Utilization % |                 |
| LUT      |             | 4  |           | 17600     |               | 0.02            |
| 10       |             | 14 |           | 100       |               | 14.00           |

β)

Testbench: rca\_4bit\_pipeline \_tb

Λοιπά απαραίτητα αρχεία : rca\_4bit\_pipeline ,full\_adder\_numeric

## **RTL schematic**



## Critical Path and Time Delay:

| Name                  | Slack ^1 | Levels | Routes | High Fanout | From         | То              | Total Delay | Logic Delay | Net Delay | Requirement | Source Clock     | Destination Clock | Exception |
|-----------------------|----------|--------|--------|-------------|--------------|-----------------|-------------|-------------|-----------|-------------|------------------|-------------------|-----------|
| <mark>Դ</mark> Path 1 | 00       | 3      | 3      | 2           | s3_2_a_reg/C | s[3]            | 4.974       | 3.422       | 1.552     | 00          |                  |                   |           |
| Դ Path 2              | 00       | 3      | 3      | 2           | s3_2_a_reg/C | cout            | 4.948       | 3.396       | 1.552     | 00          |                  |                   |           |
| Դ Path 3              | 00       | 2      | 2      | 1           | s_reg[1]/C   | s[1]            | 4.076       | 3.276       | 0.800     | 00          |                  |                   |           |
| <mark>Դ</mark> Path 4 | 00       | 2      | 2      | 1           | s_reg[2]/C   | s[2]            | 4.076       | 3.276       | 0.800     | 00          |                  |                   |           |
| Դ Path 5              | 00       | 2      | 2      | 1           | s_reg[0]/C   | s[0]            | 4.058       | 3.258       | 0.800     | 00          |                  |                   |           |
| <mark>Դ</mark> Path 6 | 00       | 2      | 3      | 2           | cin          | s0_2_reg_srl2/D | 2.239       | 1.106       | 1.133     | 00          | input port clock |                   |           |
| <mark>Դ</mark> Path 7 | 00       | 2      | 3      | 2           | cin          | cl_reg_reg/D    | 1.932       | 1.132       | 0.800     | 00          | input port clock |                   |           |
| <mark>Դ</mark> Path 8 | 00       | 1      | 2      | 1           | a[1]         | s1_0_a_reg/D    | 1.782       | 0.982       | 0.800     | ∞           | input port clock |                   |           |
| <mark>Դ</mark> Path 9 | 00       | 1      | 2      | 1           | b[1]         | s1_0_b_reg/D    | 1.782       | 0.982       | 0.800     | ∞           | input port clock |                   |           |
| 1 Path 10             | 00       | 1      | 2      | 1           | a[2]         | s2 0 a reg/D    | 1.782       | 0.982       | 0.800     | 00          | input port clock |                   |           |

Critical path : Path  $1 = s3_2_a reg/c$  to s[3]

Time Delay: 4.974

## **Resource Utilization:**

| Utilization |             |    |           | Post-Synth | nesis   Po    | st-Implementation |
|-------------|-------------|----|-----------|------------|---------------|-------------------|
|             |             |    |           |            |               | Graph   Table     |
| Resource    | Utilization |    | Available |            | Utilization % |                   |
| LUT         |             | 5  |           | 17600      |               | 0.03              |
| LUTRAM      |             | 1  |           | 6000       |               | 0.02              |
| FF          |             | 19 |           | 35200      |               | 0.05              |
| 10          |             | 15 |           | 100        |               | 15.00             |
| BUFG        |             | 1  |           | 32         |               | 3.13              |
|             |             |    |           |            |               |                   |

## 4)

Testbench: bcd\_full\_adder\_tb

Λοιπά απαραίτητα αρχεία : bcd\_full\_adder, rca\_4bit\_combinational ,full\_adder\_numeric

## **RTL schematic**



## Critical Path and Time Delay:



Critical path : Path 1 = A[0] to s[3]

Time Delay: 5.976

## **Resource Utilization:**

| lization |             |    |           | Post-Synt | hesis   Post-Implementatio |
|----------|-------------|----|-----------|-----------|----------------------------|
|          |             |    |           |           | Graph   Table              |
| Resource | Utilization |    | Available |           | Utilization %              |
| LUT      |             | 6  |           | 17600     | 0.03                       |
| 10       |             | 14 |           | 100       | 14.00                      |

Testbench: bcd\_paraller\_adder\_4bit\_tb

Λοιπά απαραίτητα αρχεία : bcd\_paraller\_adder\_4bit, bcd\_full\_adder, rca\_4bit\_combinational ,full\_adder\_numeric

## **RTL schematic**



## Critical Path and Time Delay:

| Q -                   | M   ♦   H | 1   •  | Unconstr | ained Paths . | NONE | - NONE - | - Setup     |             |           |             |                  |                   |           |
|-----------------------|-----------|--------|----------|---------------|------|----------|-------------|-------------|-----------|-------------|------------------|-------------------|-----------|
| Name                  | Slack ^1  | Levels | Routes   | High Fanout   | From | То       | Total Delay | Logic Delay | Net Delay | Requirement | Source Clock     | Destination Clock | Exception |
| <mark>Դ</mark> Path 1 | 00        | 10     | 11       | 7             | B[1] | S[15]    | 9.533       | 4.636       | 4.897     | 00          | input port clock |                   |           |
| Դ Path 2              | 00        | 10     | 11       | 7             | B[1] | Cout     | 9.527       | 4.630       | 4.897     | 00          | input port clock |                   |           |
| ₄ Path 3              | 00        | 10     | 11       | 7             | B[1] | S[13]    | 9.527       | 4.630       | 4.897     | 00          | input port clock |                   |           |
| → Path 4              | 00        | 10     | 11       | 7             | B[1] | S[14]    | 9.527       | 4.630       | 4.897     | 00          | input port clock |                   |           |
| ∿ Path 5              | 00        | 9      | 10       | 7             | B[1] | S[10]    | 8.936       | 4.512       | 4.424     | 00          | input port clock |                   |           |
| ₄ Path 6              | 00        | 9      | 10       | 7             | B[1] | S[12]    | 8.936       | 4.512       | 4.424     | 00          | input port clock |                   |           |
| ₄ Path 7              | 00        | 9      | 10       | 7             | B[1] | S[9]     | 8.936       | 4.512       | 4.424     | 00          | input port clock |                   |           |
| ₄ Path 8              | 00        | 8      | 9        | 7             | B[1] | S[11]    | 8.341       | 4.394       | 3.947     | 00          | input port clock |                   |           |
| ¹→ Path 9             | ∞         | 7      | 8        | 7             | B[1] | S[5]     | 7.757       | 4.270       | 3.487     | ∞           | input port clock |                   |           |
| → Path 10             | 00        | 7      | 8        | 7             | B[1] | S[6]     | 7.757       | 4.270       | 3.487     | 00          | input port clock |                   |           |

Critical path : Path 1 = B[1] to s[15]

Time Delay: 9.533

### **Resource Utilization:**



6)

Testbench: multiplier\_4bit\_pipeline\_tb

Λοιπά απαραίτητα αρχεία : multiplier\_4bit\_pipeline , ,full\_adder\_numeric

#### RTL schematic



### Critical Path and Time Delay:



Critical path : Path 1 = c var reg[4]/C to s[7]

Time Delay: 4.666

#### **Resource Utilization:**

| ization  |             |         | Post-Synthe | esis   Post-Implementation |
|----------|-------------|---------|-------------|----------------------------|
|          |             |         |             | Graph   <b>Table</b>       |
| Resource | Utilization | Availab | le          | Utilization %              |
| LUT      |             | 33      | 17600       | 0.19                       |
| LUTRAM   |             | 15      | 6000        | 0.25                       |
| FF       |             | 47      | 35200       | 0.13                       |
| 10       |             | 17      | 100         | 17.00                      |
| BUFG     |             | 1       | 32          | 3.13                       |

#### Ερωτήματα θεωρίας:

<u>i)</u>

Στα ακολουθιακά κυκλώματα με σύγχρονα σήματα ελέγχου, οι αλλαγές στα περιεχόμενα των flip-flops και κατ'επέκταση στων εξόδων, λαμβάνουν χώρα μόνο όταν προκληθεί ένας παλμός ρολογιού, όχι όταν αλλάξουν οι είσοδοι. Έτσι οι αλλαγές στα λογικά σήματα μέσα στο κύκλωμα ξεκινούν όλες, τις ίδιες στιγμές, σε τακτικά διαστήματα, συγχρονισμένες με το ρολόι.

Στα ακολουθιακά κυκλώματα με ασύγχρονα σήματα ελέγχου, οι αλλαγές στα περιεχόμενα των εξόδων, λαμβάνουν χώρα απευθείας αντιδρώντας σε αλλαγές στις εισόδους. Δηλαδή για την επεξεργασία των ασύγχρονων σημάτων ελέγχου δεν απαιτείται αναμονή για ακμή ρολογιού.

Ο χρήστης όταν υλοποιήσει το κύκλωμα του με VHDL και έχει ελέγξει τη ορθή λειτουργία του με χρήση testbench, είναι σίγουρος πως το κύκλωμα που έχει σχεδιάσει λειτουργεί ορθά, δηλαδή λαμβάνοντας συγκεκριμένες εισόδους παράγει μετά από κάποιο χρόνο τις αναμενόμενες εξόδους.

Πραγματοποιώντας μάλιστα και την RTL Analysis μπορεί να δεί μια γενική αναπαράσταση του κυκλώματος του με την χρήση γενικών συμβόλων, όπως αθροιστές, πολλαπλασιαστές, πολυπλέκτες, μετρητές, AND gates, OR gates κτλ.

Στην συνέχεια με είσοδο αυτό το RTL design πραγματοποιώντας σύνθεση του κυκλώματος ,ο χρήστης μπορεί να δει μια βελτιστοποιημένη σχεδίαση του κυκλώματος του για το επιλεγμένο board πάνω στο οποίο επιθυμεί να την υλοποιήσει . Έτσι μπορεί να παρατηρήσει ακριβώς το ποσό και ποσοστό του hardware που χρησιμοποιεί (resource utilization) και το critical path καθώς και την χρονκή καθυστέρηση του κυκλώματος του αλλά και να βρεί και πιθανά λάθη σχεδίασης που προκύπτουν από την επιλογή αρχιτεκτονικής του (δηλαδή το board που επέλεξε).

iii)

Σε ένα testbench ενός συνδιαστικού κυκλώματος , αλλάζουμε τις τιμές των εισόδων περιμένοντας για κάποια χρονική καθυστέρηση ανάμεσα στις αλλαγές ώστε να παρατηρήσουμε τα δεδομένα εξόδου που παράγονται ανάλογα με κάθε είσοδο.

Σε ένα testbench ενός ακολουθιακού κυκλώματος , επιπρόσθετα δημιουργούμε μια process για το ρολόι , όπως για παράδειγμα :

```
generate_clock : process begin
clock <= '0';
wait for CLOCK_PERIOD/2;
clock <= '1';
wait for CLOCK_PERIOD/2;
end process;</pre>
```

με σκοπό να δημιουργηθεί μια παλμοσειρά ρολογιού η οποία θα πυροδοτεί τις αλλαγές στα σήματα του κυκλώματος μας. Χωρίς αυτήν την παλμοσειρά οι αλλαγές στις εισόδους τις οποίες πραγματοποιούμε δεν θα προκαλούν αλλαγές στις εξόδους και έτσι δεν θα είμαστε σε θέση να πιστοποιήσουμε την ορθή λειτουργεία του κυκλώματος μας, ο οποίος είναι άλλωστε και ο σκοπός του testbench.

iv)

Στο συνδιαστικό rca χρησιμοποιούμε λιγότερα από τα resources του fpga σε σχέση με το αντίστοιχο Pipelined κύκλωμα, καθώς η pipelined υλοποίηση προϋποθέτει περισσότερα εσωτερικά σήματα και registers.

Από την άλλη όμως, το critical path και το time delay βελτιώνονται καθώς δεν χρειάζεται κάθε φορά που δίνουμε κάποιοα είσοδο να περιμένουμε τον υπολογισμό του αποτελέσματος για να δώσουμε νέα είσοδο, αρκεί μόνο ένας κύκλος ρολογιού.