

## ΠΟΛΥΤΕΧΝΕΙΟ ΚΡΗΤΗΣ ΕΡΓΑΣΤΗΡΙΟ ΜΙΚΡΟΕΠΕΞΕΡΓΑΣΤΩΝ & ΥΛΙΚΟΥ ΕΡΓΑΣΤΗΡΙΑΚΕΣ ΑΣΚΗΣΕΙΣ ΓΙΑ ΤΟ ΜΑΘΗΜΑ:

# Οργάνωση Υπολογιστών HPY 302

http://www.mhl.tuc.gr EAPINO EEAMHNO 2024

## Αναφορά Εργαστηριακής Άσκσησης 1

Αριθμός Ομάδας:66

Λαμπράχης Μιχάλης Δήμας Χρήστος  $2020030077 \\ 2021030183$ 

### 1. Σκοπός της Άσκησης

Ο σκοπός της Άσκησης αυτής είναι η σχεδίαση ενός πλήρους λειτουργικού επεξεργαστή μονο κύκλου με την χρήση της γλώσσας VHDL. Η σχεδίαση χωρίστηκε σε 3 φάσεις με σκοπό την πλήρης κατανόηση της λειτουργίας του επεξεργαστή.

Στην  $1^{\eta}$  φάση σχεδιάστηκε μια μονάδα αριθμιτικών και λογικών πράξεων (ALU) καθώς και ένα αρχείο καταχωρητών(Register File).

Στην 2η σχεδιάστηκαν οι βασικές βαθμίδες του Datapath του επεξαργαστή. Αυτές είναι βαθμίδα ανάκλησης εντολών(IFSTAGE), αποκωδηκοποίησης εντολών(DECSTAGE), εκτέλεσης εντολών(EXSTAGE) και πρόσβασης μνήμης (MEMSTAGE). Για την σχεδίαση χρειάστηκαν η (ALU) και ο (Register file) από την προηγούμενη φάση καθώς και με την χρήση του εργαλείου Xillinx Core Generator υλοποιήθηκαν 2 μνήμες, μια ROM 1024x32 για την αποθήκευση των βασικών εντολών και μια κύρια μνήμη RAM 1024x32.

Τέλος, στην  $3^{\eta}$  φάση συνδέθηκαν τα επιμέρους στοιχεία για να κατασκευαστεί το ενιαίο DATAPATH καθώς και υλοποιήθηκε το CONTROL του επεξεραστή το οποίο παράγει τα σωστά σήματα ελέγχου για την κάθε εντολή.

# 2. Περιγραφή της Σχεδίασης

#### 1η φάση

Στην 1η φάση αρχικά σχεδιάστηκε η μονάδα αριθμιτικών και λογικών πράξεων (ALU) η οποιά παίρνει σαν είσοδο δύο 32bit τελεστέους και έναν 4bit κωδικό πράξης. Ανάλογα με τον κωδικό, η ALU βγάζει στην έξοδο το αποτέλεσμα της πράξης καθώς και 3 διαφορετικά flags που επισημαίνουν αν το αποτέλεμσα της πράξης είναι α) 0, β)έχει κρατούμενο εξόδου 1, γ)έχει υπερχείληση. Όσον αφορά την υπερχείληση, μπορεί να προκύψει μόνο στην πρόσθεση και στην αφαίρεση. Στην πρόσθεση, υπάρχει υπερχείληση αν και οι δύο προσθετέοι είναι ομόσιμοι μεταξύ τους και ετερόσημοι με το αποτέλεσμα, ενώ στην αφαίρεση έχουμε άν ο μειώτέος είναι είναι θετικός και ο αφαιρετέος αρνητικός και η διαφορά αρνητική η το ανάποδο. Για την υλοποίηση των πράξεων χρησιμοποιήθηκαν οι βιβλιοθήκες ΙΕΕΕ.Νυμεπίζ. Std. και ΙΕΕΕ.STD.LOGIC\_SIGNED.ALL ώστε να μην χρειαστεί να υλοποιηθούν από την αρχή τα κυκλώματα για τις πράξεις.

Στη συνέχεια σχεδιάστηκαν τα component τα οποία αποτελούν το αρχείο καταχωρητών (register file). Αρχικά σχεδιάστηκε ένας σύγχρονος καταχωρητς 32bit με Reset και WriteEnable. Στη συνέχεια ένας πολυπλέκτης ο οποίος ανάλογα με το σήμα sel (5bit) επιλέγει ποιά απο τις 32 εισόδος θα περάσει στην έξοδο και τέλος ένας αποκωδικοποιητής που ανάλογα με το σήμα εισόδου awr (5bit) επιλέγει ποιό απο τα 32bit της εξόδου θα είναι 1.

Το αρχείο καταχωρητών περίεχει 2 εισόδους ασύγχρονης ανάγνωσης που ελέγχουν 2 πολυπλέκτές και καθορίζουν τις εξόδους που θα διαβαστούν, 1 είσοδο σύγχρονης εγγραφής που μέσω του αποκωδικοποιητή καθορίζει σε ποιόν καταχυρητή θα γράψουμε, την είσοδο των δεδομένων, τα σήματα ελέγχου Reset και WriteEnable και το ρολόι. Χρειάστηκαν 32 καταχωρητές οι οποίοι δημιουργήθηκαν μέσω for-generate. Από αυτούς η τιμή του R0 είναι πάντα 0.

### $2^η$ φάση

Η  $2^{\eta}$  φάση αποτελείται από 4 στάδια. Αρχικά το  $1^{\circ}$  στάδιο είναι η βαθμίδα ανάκληση εντολων (IF Stage). Σε αυτό το στάδιο διαβάζεται μια εντολή από την μνήμη (χρησιμοιόυμε μια Distributed ROM) και την φορτώνουμε σε έναν καταχωρητή, τον Program Counter, ο οποίος σε κάθε κύκλο περιέχει την εντολή που εκτελείται την συγκεκριμένη χρονική στιγμή. Στον επόμενο κύκλο ο PC προχωράει στην επόμενη εντολή και παίρνει την τιμή (PC+4) εκτός αν η εντολή είναι brunch, brunch equal ή brunch not equal όπου τότε ο PC παίρνει την τιμή (PC+4+Immediate) και τότε η εκτέλεση του προγράμματος μεταφέρεται στην διεύθυνση αυτή. Η μνήμη λαμβάνει ως είσοδο τα [11:2] bits της εξόδου του καταχυρητή αφού αυτή είναι οργανωμένη σε words. Έτσι όσο αυξάνεται ο PC κατά 4 η μνήμη θα αυξάνεται κατά 1.

Το 2° στάδιο αποτελεί η βαθμίδα αποχωδιχοποίησης εντολών (DEC Stage). Σε αυτό το στάδιο η εντολή που φορτώνεται από την μνήμη αποχωδιχοποιείται, με σχοπό την εγγραφή και προσπέλαση της στο αρχείο καταχωρητών. Επιπλέον, γίνεται και η κατάλληλη επεξεργασία της τιμής Immediate. Ο καταχωρητής ανάγνωσης 1 είναι πάντα ο τε ενώ ο καταχωρητής 2 είναι είτε ο ττ είτε ο ττ. Ένα πολυπλέχτης καθορίζει ποιός από τους 2 θα περάσει, όπου εχεί πραχτικά γίνεται και ο διαχορισμός των R-Type από τις I-Type εντολές. Ο καταχωρητής εγγραφής είναι πάντα ο ττ. Αχόμη η επεξεργασία του Immediate γίνεται στην μονάδα "Cloud" όπου ανάλογα με την τιμή του σήματος CloudControl γίνεται 1.Zero Fill, 2.Sign Extend, 3.Zero Fill & Shift και 4.Sign Extend & Shift 2. Τέλος, η είσαγωγή των δεδομένων προς εγγραφή στο Register File επιλέγεται μέσω ενός άλλου πολυπλέχτη να είναι είτε από την μνήμη RAM σε περίπτωση των εντολών load και store είτε απο την έξοδο της ΑLU στις υπόλοιπες εντολές.

Το 3° στάδιο είναι η βαθμίδα εχτέλεσης εντολών (EX Stage). Σε αυτό το στάδιο γίνεται η εχτέλεση της εντολής και ο υπολογισμός του αποτελέσματος της ALU. Το 1° σήμα εισόδου της αποτελούν τα δεδομένα ανάγνωσης του καταχωρητή 1(έξοδος απο Register File) και το 2° μέσω ενός πολυπλέχτη είναι είτε τα δεδομένα ανάγνωσης του καταχωρητή 2 είτε το επεξεργασμένο Immediate.

Το  $4^{\circ}$  και τελευταίο στάδιο αποτελεί η βαθμίδα πρόσβασης μνήμης (MEM Stage). Σε αυτό το στάδιο υλοποιήθηκε μια μνήμη RAM 1024 θέσεων των 32bit. Η μνήμη είναι Read First και έχει μια θύρα ανάγνωσης και εγγραφής.

Τέλος για την υλοποίηση της εντολής load byte έχει δημιουργήθεί ένα LS Stage το οποίο παίρνει σαν είσοδο την έξοδο της μνήμης RAM και μέσω ενός πολυπλέκτη επιλέγει εάν θα βγει αυτούσια στην έξοδο είτε αν ,στην περίπτωση της εντολής load byte, γίνει Zero Fill στα bit [31:8].

#### 3η φάση

Στην  $3^{\eta}$  φάση ενώθηκαν τα 4 στάδια και υλοποιήθηκε το DATAPATH το οποίο πρακτικά είναι υπεύθυνο για να πραγματοποιήσει όλες τις λειτουργίες του επεξεργστή, ανάλογα με τις εντολές που εισάγονται.



Στην συνέχεια δημιουργήθηκε το CONTROL το οποίο είναι υπεύθυνο να στέλνει τα κατάλληλα σήματα ελέγχου στο DATAPATH ανάλογα με την εντολή που εκτελείται. Παίρνει σαν εισόδους ένα ασύγχρονο Reset καθώς και το flag Zero της ALU το οποίο χρησιμοποιείται στις εντολές διακλαδώσεων brunch και παράγει εξόδους για όλα τα σήματα εισόδου του DATAPATH.

Το DATAPATH και το CONTROL ενώθηκαν σε ένα Τορ Level αρχείο PROCESSOR το οποίο τρέχει και επιβεβαιώνει την ορθή λειτουργία του επεξεργστή. Δεν έχει εισόδους και εξόδους πέρα από το Reset και το ρολόι.



# 4. Συμπεράσματα

Αυτή η άσχηση είναι μια πολύ χαλή εξάσχηση για την χατανόηση της λειτουργίας ενός επεξεργαστή ενός χύχλου. Εντρυφήσαμε στην VHDL, την κατανοήσαμε και μάθαμε να χειριζόμαστε τις βιβλιοθήχες της για την διευχόλυση της υλοποίησης των χυχλωμάτων. Μέσω εξαντλητιχών δοχιμών (testbenches) χαταφέραμε να επιβεβαιώσουμε την λειτουργία του επεξεργαστή και κατανοήσαμε πόσο σημαντιχή είναι αυτή η διαδιχασία για την αποφυγή λαθών και την εξοιχονόμηση χρόνου. Τέλος, μάθαμε πως να χάνουμε ιεραρχιχή σχεδίαση, να χωρίζουμε τα sub modules και να τα συνδέουμε σε ένα Top Level αρχείο.