AΘHNA 5 - 4 - 2019

## 2η ΟΜΑΔΑ ΑΣΚΗΣΕΩΝ ΓΙΑ ΤΟ ΜΑΘΗΜΑ "Συστήματα Μικροϋπολογιστών"

## Παράδοση 2/5/2019

**Ασκήσεις προσομοίωσης** (να υλοποιηθούν και να δοκιμαστούν στο πρόγραμμα προσομοίωσης του εκπαιδευτικού συστήματος μLAB)

1 ΑΣΚΗΣΗ: Σε ένα μΥ-Σ 8085 να γραφεί σε assembly που να επιτελεί τις παρακάτω λειτουργίες:

- (α) Να αποθηκευθούν οι αριθμοί 0-255 με αύξουσα σειρά στις διαδοχικές θέσεις της μνήμης με αρχή τη διεύθυνση 0900 Η (να απενεργοποιηθεί η προστασία μνήμης— εκτέλεση της εντολής ΙΝ 10Η). Οι αριθμοί να αποθηκευθούν όχι χειροκίνητα αλλά μέσω προγράμματος και να ελέγξετε αν έγινε η ζητούμενη λειτουργία σωστά.
- (β) Υπολογίστε τον αριθμό των μονάδων (δυαδικών ψηφίων 1) των παραπάνω δεδομένων. Το αποτέλεσμα να αποθηκευθεί στον διπλό καταχωρητή BC.
- (γ) Υπολογίστε το πλήθος από τους παραπάνω αριθμούς (0-255) που είναι μεταξύ των αριθμών 10H και 60H περιλαμβανομένων ( $10H \le x_n \le 60H$ ) και φυλάξτε το αποτέλεσμα στον καταχωρητή D. Σημείωση: Τα αποτελέσματα για τα (β) και (γ) είναι από πριν γνωστά. Έτσι διευκολύνεται η επιβεβαίωση της ορθότητας των αντίστοιχων προγραμμάτων σας.
- **2<sup>η</sup> ΑΣΚΗΣΗ:** Δίνεται ένα μΥ-Σ 8085 που ελέγχει τα LED της πόρτας εξόδου (3000 Hex) εξομοιώνοντας με αυτά τα φώτα ενός χώρου. Να γραφεί πρόγραμμα Assembly, που όταν το MSB της θύρας εισόδου dip switch (θέση μνήμης 2000 Hex) από OFF γίνει ON και ξανά OFF τότε να ανάβει όλα τα LED της πόρτας εξόδου. Αυτό να παραμένει ανοιχτό για περίπου 30 sec και μετά να σβήνει. Αν όμως ενδιάμεσα ξαναενεργοποιηθεί το pushbutton (OFF ON OFF το MSB των dip switch) να ανανεώνεται ο χρόνος των 30 sec.

Να γίνει χρήση των ρουτινών χρονοκαθυστέρησης του εκπαιδευτικού συστήματος μLAB. Θεωρήστε ότι το σύστημα παρακολουθεί με διακριτική ικανότητα όχι μικρότερη του 1/5 sec.

**3<sup>η</sup> ΑΣΚΗΣΗ:** Να γραφούν σε assembly 8085 και να εκτελεστούν στο μLAB, 4 προγράμματα με τις εξής λειτουργίες:

- i. Διαβάζει την πόρτα εισόδου των dip switches και με βάση το 1° δεξιότερο ΟΝ, ανάβει το αντίστοιχης τάξης led και όλα τα υψηλότερης τάξης led μετά από αυτό (π.χ. για 1011 0100 => XXXX XXOO). Το πρόγραμμα να είναι συνεχούς λειτουργίας.
- ii. Να αναμένει το πάτημα του δεκαεξαδικού πληκτρολογίου και μόνο των αριθμών 1 έως 8. Κάθε φορά να ανάβει το led της αντίστοιχης θέσης (1=>LSB, 8=>MSB). Να γίνει χρήση της ρουτίνας ΚΙΝD που υπάρχει στο παράρτημα 1 των σημειώσεων του μLAB. Το πρόγραμμα να είναι συνεχούς λειτουργίας.
- iii. Με βάση την ύλη των σελ. 76 79 (των σημειώσεων του μLAB) να γίνει απευθείας ανάγνωση του πληκτρολογίου χωρίς τη χρήση της ρουτίνας KIND. Το αποτέλεσμα του κωδικού (βάσει του πίνακα 1 της σελ. 74) να εμφανίζεται στα 2 αριστερότερα 7-segment display με βάση τις ρουτίνες DCD (Display Character Decoder) και STDM (Store Display Message), σελ. 80-82.

Σημ.: Δεν χρειάζεται η εύρεση μόνο του κωδικού του πλήκτρου HDWR STEP λόγω της μη υλοποίησης της λειτουργίας του στον προσομοιωτή.

**4<sup>η</sup> ΑΣΚΗΣΗ:** Να εξομοιωθεί η λειτουργία ενός υποθετικού Ι.С. που περιλαμβάνει 5 πύλες όπως φαίνεται στο σχήμα. Τα bits εισόδου πρέπει να αντιστοιχούν ακριβώς όπως φαίνονται στο σχήμα με τα dip switches της πόρτας εισόδου 2000 Hex, και οι έξοδοι με τα LEDs που πρέπει να είναι τα τέσσερα LSB της πόρτας εξόδου 3000 Hex. Οι πύλες, όπως φαίνεται στο σχήμα, είναι 2 AND, 2 OR και 1 XOR. Η αντιστοιχία των led με τις λογικές στάθμες έχει ως εξής: αναμμένο led => '1' και σβηστό led => '0'. Οι αδιάφορες θέσεις της εξόδου να έχουν μόνιμα σβηστά led.



Παρατήρηση: Τα προγράμματα να συνοδεύονται υποχρεωτικά στα κυριότερα σημεία τους από πολύ σύντομα σχόλια.

## Θεωρητικές Ασκήσεις

 $\mathbf{5}^{\eta}$  **ΑΣΚΗΣΗ:** Να δοθεί η εσωτερική οργάνωση μια μνήμη SRAM  $256\times4$  bit αντίστοιχης με αυτήν που φαίνεται στο σχ. 3.2 (βιβλίο θεωρίας). Να εξηγηθεί μέσω ενός παραδείγματος με ποιο τρόπο γίνεται η ανάγνωση και εγγραφή στη μνήμη αυτή (ποια σήματα ενεργοποιούνται, ποιοι διακόπτες και πύλες ανοίγουν ή κλείνουν κλπ.). Θεωρήστε ότι πέραν των  $\overline{CS}$  και  $\overline{WE}$  ότι διαθέτει ξεχωριστό σήμα για την ανάγνωση  $\overline{RD}$ .

**6**η **ΑΣΚΗΣΗ:** Να σχεδιασθεί ένα σύστημα μνήμης που να περιλαμβάνει χώρο μνήμης 10ΚΒytes ROM ακολουθούμενη χωρίς κενό διευθύνσεων από 6ΚΒytes RAM. Η ROM ξεκινά από τη διεύθυνση 0000Η και υλοποιείται χρησιμοποιώντας 2 ολοκληρωμένα μνήμης 4Κ×8 bit (ROM) και 1 ολοκληρωμένο μνήμης 2Κ×8 bit (ROM) -συνολικά 3 ICs. Θεωρήστε ότι οι ROMs έχουν δύο εισόδους ελέγχου  $\overline{CE}$  (chip enable) και  $\overline{OE}$  (output enable). Η RAM να υλοποιηθεί με χρήση μιας μνήμης 2Κ×8 και μιας 4Κ×8 SRAMs (2 ICs). Να κατασκευαστεί ο χάρτης μνήμης. Οι μνήμες SRAMs έχουν δύο τις εισόδους ελέγχου  $\overline{CE}$  (chip enable),  $\overline{OE}$  (output enable) και επιπλέον πρόσθετη γραμμή ελέγχου  $\overline{WE}$ . Η αποκωδικοποίηση να γίνει χρησιμοποιώντας ένα ή περισσότερα κυκλώματα επιλογής σας από τα παρακάτω: αποκωδικοποιητής 3:8 (74LS138) και λογικές πύλες (φυσικά και συνδυασμό τους). Να σχεδιασθεί το λογικό διάγραμμα της μνήμης και η συνδεσμολογία με τα απαιτούμενα σήματα από το system bus του 8085.

7η ΑΣΚΗΣΗ: Σχεδιάστε ένα μΥ-Σ 8085 που να έχει τον εξής χάρτη μνήμης:

 0000-1FFF Hex
 : ROM (8Kbytes)

 2000-4FFF Hex
 : RAM (12Kbytes)

 5000-6FFF Hex
 : ROM (8Kbytes)

7000 Hex
 70 Hex
 θύρα εξόδου (Memory map I/O)
 θύρα εισόδου (Standard I/O)

Παρέχονται ολοκληρωμένα κυκλώματα: ROMs των 16KBytes, RAMs 4KBytes, μΕ 8085, καταχωρητές και απομονωτές (απλής και διπλής κατεύθυνσης) των 8 bits, κωδικοποιητές 3 σε 8 και οι βασικές λογικές πύλες. Χρησιμοποιείστε μόνο όσα σας χρειάζονται και στην ποσότητα που θέλετε. Σχεδιάστε τα κυκλώματα διασύνδεσης. Τα βασικά σήματα ελέγχου του 8085 είναι  $\overline{\text{RD}}$ ,  $\overline{\text{WR}}$ ,  $\overline{\text{IO}}/\overline{\text{M}}$  και ALE.