

**ΣΧΕΔΙΑΣΜΟΣ ΣΥΣΤΗΜΑΤΩΝ  
VLSI**

Δεύτερη Εργαστηριακή Άσκηση

Γιώργος Ντάκος 1059569

26 Μαρτίου 2021

## Περίληψη

Στο παρακάτω κείμενο παραδίδεται η αναφορά της 2<sup>ης</sup> εργαστηριακής άσκησης του μαθήματος Σχεδιασμός Συστημάτων VLSI . Όλοι οι κώδικες έχουν συγγραφεί σε γλώσσα **VHDL** μέσω του **NotePad++** και έχουν μεταγλωτειστεί και επιβεβαιωθεί οι λειτουργίες τους μέσω του εργαλείου **ModelSim**.

## **Περιεχόμενα**

|                        |           |
|------------------------|-----------|
| <b>Ενότητα A</b>       | <b>4</b>  |
| <b>Ενότητα B</b>       | <b>7</b>  |
| <b>Κώδικες σε VHDL</b> | <b>10</b> |

## **Κατάλογος Σχημάτων**

|                                                                     |   |
|---------------------------------------------------------------------|---|
| 1 Πολυπλέκτης 4 σε 1 . . . . .                                      | 4 |
| 2 Simulation του πρώτου κώδικα του πολυπλέκτη . . . . .             | 5 |
| 3 Simulation του δεύτερου κώδικα του πολυπλέκτη . . . . .           | 6 |
| 4 Σχηματικό της λογικής συνάρτησης 1 . . . . .                      | 7 |
| 5 Simulation του πρώτου κώδικα της λογικής συνάρτησης 1 . . . . .   | 8 |
| 6 Simulation του δεύτερου κώδικα της λογικής συνάρτησης 1 . . . . . | 9 |

## **Κατάλογος Πινάκων**

|                                                       |   |
|-------------------------------------------------------|---|
| 1 Πίνακας αληθείας του πολυπλέκτη . . . . .           | 4 |
| 2 Πίνακας αληθείας της λογικής συνάρτησης 1 . . . . . | 7 |

## Ενότητα Α

### A.1,A.2

Στην εικόνα 1 παρατηρούμε ότι θέλουμε να φτιάξουμε τους κώδικες που να υλοποιούν 1 πολυπλέκτη 4 σε 1 των 8 bits η κάθε είσοδος και έξοδος με το σήμα sel να είναι των 2 bits . Η λειτουργία του κυκλώματος αυτού φαίνεται στον πίνακα αληθείας 1. Αφού κάνουμε compile και τους 2 κώδικες που μας ζητάει η áσκηση(διαφέρουν σε απλές βασικές εντολές) τους εξομοιώνουμε και πάρνουμε τα αποτελέσματα των εικόνων 2,3 όπου και διαπιστώνουν την ορθή λειτουργία τους.



Σχήμα 1: Πολυπλέκτης 4 σε 1

| sel  | x          |
|------|------------|
| '00' | '00000000' |
| '01' | a          |
| '10' | b          |
| '11' | "ZZZZZZZZ" |

Πίνακας 1: Πίνακας αληθείας του πολυπλέκτη



Σχήμα 2: Simulation του πρώτου κάδικα του πολυπλέκτη



Σχήμα 3: Simulation του δεύτερου κώδικα του πολυπλέκτη

## Ενότητα Β

### B.1,B.2

Η συγκεκριμένη άσκηση μας ζητάει να δημιουργήσουμε 2 κώδικες, ο πρώτος με προσέγγιση με βάση διεργασία ενώ ο δεύτερος με προσέγγιση structural δομής, για την παρακάτω λογική συνάρτηση:

$$Z = (A \wedge B \wedge \neg C) \vee (A \wedge B) \vee C \quad (1)$$

Η λογική συνάρτηση 1 σχηματικά φαίνεται στην εικόνα 4 και η λειτουργία της φαίνεται στον πίνακα αληθείας 2.



Σχήμα 4: Σχηματικό της λογικής συνάρτησης 1

| A   | B   | C   | Z   |
|-----|-----|-----|-----|
| '0' | '0' | '0' | '0' |
| '0' | '0' | '1' | '1' |
| '0' | '1' | '0' | '0' |
| '0' | '1' | '1' | '1' |
| '1' | '0' | '0' | '0' |
| '1' | '0' | '1' | '1' |
| '1' | '1' | '0' | '1' |
| '1' | '1' | '1' | '1' |

Πίνακας 2: Πίνακας αληθείας της λογικής συνάρτησης 1

### Γ.3

Αφού κάνουμε compile και τους 2 κώδικες που μας ζητάει η áσκηση τους εξομοιώνουμε και παίρνουμε τα αποτελέσματα των εικόνων 5,6 όπου και διαπιστώνουν την ορθή λειτουργία τους.



Σχήμα 5: Simulation του πρώτου κώδικα της λογικής συνάρτησης 1



Σχήμα 6: Simulation του δεύτερου κώδικα της λογικής συνάρτησης 1

## Γ.4

Σύμφωνα από τους δύο κώδικες προφανώς και θα υπάρξουν διαφορές. Πρώτα πόλλα στον πρώτο κώδικα της λογικής συνάρτησης 1 το μπλοκ κώδικα μέσα στην εντολή **PROCESS** εκτελείται με ακολουθιακό τρόπο δηλαδή σειριακά σε αντίθεση με το δεύτερο κώδικα όπου και εκτελείται όλος παράλληλα. Τώρα στο **Simulation** δεν υπάρχει κάποια διαφορά πέρα από τα ενδιάμεσα σήματα, στο **Simulation** του δεύτερου κώδικα, τα οποία θα μπορούσαν και να μην υπάρχουν στο παράνυρο των κυματομορφών. Και οι δύο περιγραφές οδηγούν συνήθως σε ισοδύναμο συνδυαστικό κύκλωμα. Η structural καθορίζει ρητά ενδιάμεσα σήματα/πύλες, ενώ η process-based περιγράφει συμπεριφορά και αφήνει μεγαλύτερο περιθώριο στο synthesizer για optimization. Και στις δύο περιπτώσεις το τελικό κύκλωμα υλοποιεί την ίδια λογική συνάρτηση.

## Κώδικες σε VHDL

Παρακάτω παρατίθονται οι κώδικες της εργασίας:

---

### Mux\_4\_x\_1

---

```
--Dhlwsh bibliothkhs kai tun paketun poy tha xrhsimopoiksoyme
LIBRARY IEEE;
USE IEEE.std_logic_1164.all;

ENTITY mux_4_x_1 IS
GENERIC(N: NATURAL :=8);
PORT (
-- Shma eisodoy poy lambanei mia akoloythia timwn.
a:IN std_logic_vector(N-1 downto 0);
-- Shma eisodoy poy lambanei mia akoloythia timwn.
sel:IN std_logic_vector(1 downto 0);
-- Shma eisodoy poy lambanei mia akoloythia timwn.
b :IN std_logic_vector(N-1 downto 0);
-- Shma ejodoy poy lambanei mia akoloythia timwn.
x :OUT std_logic_vector(N-1 downto 0));
END mux_4_x_1;

--Dhlwsh arxitektonikhs
ARCHITECTURE behavioral OF mux_4_x_1 IS

BEGIN
--Ylopoikhsh toy pinaka alhtheias
--dld analoga me thn timh toy sel
```

```

--pairnei kai antistoixh timh toy pinaka to shma ejodoy
x<= "00000000" WHEN sel = "00" ELSE
a WHEN sel = "01" ELSE
b WHEN sel = "10" ELSE
"ZZZZZZZZ" WHEN sel = "11" ELSE
(OTHERS => '-');

END behavioral;

```

---

### Second\_Mux\_4\_x\_1

---

```

--Dhlwsh bibliothkhs kai tun paketwn moy tha xrhsimopoikhsoyme
LIBRARY IEEE;
USE IEEE.std_logic_1164.all;

ENTITY second_mux_4_x_1 IS
GENERIC(N: NATURAL :=8);
PORT (
-- Shma eisodoy moy lambanei mia akoloythia timwn.
a:IN std_logic_vector(N-1 downto 0);
-- Shma eisodoy moy lambanei mia akoloythia timwn.
sel:IN std_logic_vector(1 downto 0);
-- Shma eisodoy moy lambanei mia akoloythia timwn.
b :IN std_logic_vector(N-1 downto 0);
-- Shma ejodoy moy lambanei mia akoloythia timwn.
x :OUT std_logic_vector(N-1 downto 0));
END second_mux_4_x_1;

--Dhlwsh arxitektonikhs
ARCHITECTURE behavioral OF second_mux_4_x_1 IS
BEGIN
--Ylopoikhsh toy pinaka alhtheias
--dld analoga me thn timh toy sel
--pairnei kai antistoixh timh toy pinaka to shma ejodoy
WITH (sel) SELECT
x <= "00000000" WHEN "00",
a WHEN "01",
b WHEN "10",
"ZZZZZZZZ" WHEN "11",
"-----" WHEN others;

END behavioral;

```

---

**NOT\_GATE**

---

```
--Dhlwsh bibliothkhs kai tun paketun poy tha xrhsimopoikhsoyme
LIBRARY IEEE;
USE IEEE.std_logic_1164.all;

--Dhlwsh ontotthas
ENTITY NOT_GATE IS
PORT (
    -- Shma eisodoy poy lambanei ena bit.
    A : IN BIT;
    -- Shma ejodoy poy lambanei ena bit.
    Y : OUT BIT
);
END NOT_GATE;

--Dhlwsh arxitektonikhs
ARCHITECTURE behavioral OF NOT_GATE IS

BEGIN

    --Logikh prajh NOT
    Y <= not A;

END behavioral;
```

---

**AND\_GATE**

---

```
--Dhlwsh bibliothkhs kai tun paketun poy tha xrhsimopoikhsoyme
LIBRARY IEEE;
USE IEEE.std_logic_1164.all;

--Dhlwsh ontotthas
ENTITY AND_GATE IS
PORT (
    -- Shma eisodoy poy lambanei ena bit.
    A : IN BIT;
    -- Shma eisodoy poy lambanei ena bit.
    B : IN BIT;
    -- Shma ejodo poy lambanei ena bit.
    Y : OUT BIT
);
END AND_GATE;
```

```
--Dhlwsh arxitektonikhs
ARCHITECTURE behavioral OF AND_GATE IS

BEGIN
--Logikh prajh AND
Y <= (A AND B);

END behavioral;
```

### OR\_GATE

---

```
--Dhlwsh bibliothkhs kai twn paketwn poy tha xrhsimopoiksoyme
LIBRARY IEEE;
USE IEEE.std_logic_1164.all;

--Dhlwsh ontotthas
ENTITY OR_GATE IS
PORT (
    -- Shma eisodoy poy lambanei ena bit.
    A : IN BIT;
    -- Shma eisodoy poy lambanei ena bit.
    B : IN BIT;
    -- Shma ejodo poy lambanei ena bit.
    Y : OUT BIT
);
END OR_GATE;

--Dhlwsh arxitektonikhs
ARCHITECTURE behavioral OF OR_GATE IS

BEGIN
--logikh prajh OR
Y <= (A OR B);

END behavioral;
```

---

## Circuit-A

---

```
--Dhlwsh bibliothkhs kai tun paketun poy tha xrhsimopoikhsoyme
LIBRARY IEEE;
USE IEEE.std_logic_1164.all;

--Dhlwsh ontotthas
ENTITY circuitA IS
PORT (
    -- Shma eisodoy poy lambanei ena bit.
    A : IN BIT;
    -- Shma eisodoy poy lambanei ena bit.
    B : IN BIT;
    -- Shma eisodo poy lambanei ena bit.
    C : IN BIT;
    -- Shma ejodo poy lambanei ena bit.
    Z : OUT BIT
);
END circuitA;

ARCHITECTURE behavioral OF circuitA IS

BEGIN
    --akoloythiakh ektelelesh toy parakatw blok kwdika
    PROCESS(A,B,C)

        BEGIN
            --ean isxuei mia apo tis dyo h kai oi dyo
            IF ((A AND B) = '1' OR C = '1') THEN
                --tote these to shma ejodoy iso me '1'
                Z<='1';
            ELSE
                --Se opoiadhpote allh periptwsh these to shma
                --ejodoy iso me '0'
                Z<='0';
            END IF;
        END PROCESS;
    END behavioral;
```

---

## Circuit-B

---

```
--Dhlwsh bibliothkhs kai tun paketwn poy tha xrhsimopoikhsoyme
LIBRARY IEEE;
USE IEEE.std_logic_1164.all;

--Dhlwsh ontothtas
ENTITY circuitB IS
PORT (
    -- Shma eisodoy poy lambanei ena bit.
    A : IN BIT;
    -- Shma eisodoy poy lambanei ena bit.
    B : IN BIT;
    -- Shma eisodoy poy lambanei ena bit.
    C : IN BIT;
    -- Shma ejodo poy lambanei ena bit.
    Z : OUT BIT
);
END circuitB;

--Dhlwsh arxitektonikhs
ARCHITECTURE structural OF circuitB IS

--Klhsh toy stoixeio NOT_GATE kai dhlwsh eisodwn ejodwn
COMPONENT NOT_GATE
    PORT(A : IN BIT; Y : OUT BIT);
END COMPONENT;

--Klhsh toy stoixeio AND_GATE kai dhlwsh eisodwn ejodwn
COMPONENT AND_GATE
    PORT(A,B : IN BIT; Y : OUT BIT);
END COMPONENT;

--Klhsh toy stoixeio OR_GATE kai dhlwsh eisodum ejodum
COMPONENT OR_GATE
    PORT(A,B : IN BIT; Y : OUT BIT);
END COMPONENT;

--Dhlwsh prosurinwn metablhtwn(endiamesa shmata)
SIGNAL x1,x2,x3,x4 : BIT;

--Dhmioyergria toy kyklwmatos me bash thn eikona 4 ths anaforas
--Xtizoyme to kykluma dhladh me endiamesa shmata kai eidh
--stoixeia ylikoy ta opoia exoyme sthn diathesh mas.
```

```
BEGIN
    GATE_1 : NOT_GATE PORT MAP (C,x2);--C eisodos,x2 ejodos
    GATE_2 : AND_GATE PORT MAP (A,B,x1);--A,B eisodoi,x1 ejodos
    GATE_3 : AND_GATE PORT MAP (x1,x2,x3);--x1,x2 eisodoi,x3 ejodos
    GATE_4 : OR_GATE PORT MAP (x1,x3,x4);--x1,x3 eisodos,x4 ejodos
    GATE_5 : OR_GATE PORT MAP (C,x4,Z);--C,x4 eisodos,Z ejodos
END structural;
```