

# Συστήματα Μικρούπολογιστών

Προγραμματισμός μΕ σε  
Συμβολική Γλώσσα



# Εισαγωγή

---

Η ανάπτυξη ενσωματωμένου λογισμικού διαφέρει από την ανάπτυξη λογισμικού σε ένα workstation ή ένα PC γιατί πρέπει:

- Να λειτουργεί σε συγκεκριμένους ρυθμούς για να ικανοποιεί χρονικούς περιορισμούς
- Να χωράει σε συγκεκριμένο μέγεθος μνήμης
- Να ικανοποιεί συγκεκριμένες προδιαγραφές κατανάλωσης ισχύος

2

# SNPD (Smart Negative Pressure Device)

- ❑ Software stack from drivers up to user application
- ❑ No RTOS (Real Time Operating System)
- ❑ C and assembly programming

## SNPD real case: Pump control



Verification in complex lab tubing system with pressure meter and on healthy volunteer



3

# Αντιστοιχία γλώσσας υψηλού επιπέδου με συμβολική και με γλώσσα μηχανής

| Γλώσσα Υψηλού Επιπέδου | Συμβολική Γλώσσα | HEX Κώδικας | Δυαδικός Κώδικας |
|------------------------|------------------|-------------|------------------|
| A = A + K              | LDA SUMA         | 3A          | 0011 1010        |
|                        |                  | 22          | 0010 0010        |
|                        |                  | 00          | 0000 0000        |
|                        | MOV C,A          | 4F          | 0100 1111        |
|                        | LDA SUMK         | 3A          | 0011 1010        |
|                        |                  | 23          | 0010 0011        |
|                        |                  | 00          | 0000 0000        |
|                        | ADD C            | 81          | 1000 0001        |
|                        | STA SUMA         | 32          | 0011 0010        |
|                        |                  | 22          | 0010 0010        |
|                        |                  | 00          | 0000 0000        |
|                        | HLT              | 76          | 0111 0110        |

Variable instruction width  
Intel CPU characteristic feature

4

# Περιπτώσεις που απαιτείται η χρήση της Συμβολικής Γλώσσας

- Όταν ο προγραμματιστής χρειάζεται πρόσβαση σε καταχωρητές του επεξεργαστή.
- Στην εφαρμογή απαιτείται να πάρουμε την μέγιστη απόδοση από τον επεξεργαστή και το υλικό του υπολογιστή (π.χ. υψηλότερη ταχύτητα λειτουργίας, χαμηλή κατανάλωση ισχύος κλπ.).
- Χρειάζεται ο χειρισμός χρονικά κρίσιμων λειτουργιών καθώς και η επικοινωνία με τις συσκευές I/O.
- Επίσης ο χειρισμός των διακοπών απαιτεί assembly.
- Περαιτέρω, η κωδικοποίηση απευθείας στην Assembly μπορεί μερικές φορές (αλλά όχι πάντα) να οδηγήσει σε μικρότερου μεγέθους κώδικα.
- Ο μΕ ή ο μικροελεγκτής μπορεί να μη διαθέτει μεταγλωτιστή (ή και να διαθέτει δεν είναι καθόλου αποδοτικός και να μην χρησιμοποιείται).

5



# Modern use cases of Assembly-Level (Binary) Optimization

Meta

Research   Publications   Programs ▾   Datasets   Careers

## BOLT: A Practical Binary Optimizer for Data Centers and Beyond

International Symposium on Code Generation and Optimization (CGO)

Google Research

Who we are ▾   Research areas ▾   Our work ▾   Programs & events ▾   Careers   Blog

[Home](#) > [Publications](#) >

### AutoFDO: Automatic Feedback-Directed Optimization for Warehouse-Scale Applications

Dehao Chen · [David Xinliang Li](#) · [Tipp Moseley](#) ·

CGO 2016 Proceedings of the 2016 International Symposium on Code Generation and Optimization, ACM, New York, NY, USA, pp. 12-23

[Google Scholar](#)

[Copy Bibtex](#)

MAΘ

# Ανάπτυξη Λογισμικού

## Σχεδίαση

- Αλγόριθμος

## Κώδικας

- Εντολές

## Μετάφραση

- Πηγαίος → Αντικειμενικός κώδικας

## Έλεγχος – Διόρθωση

- Το τελικό αποτέλεσμα είναι σωστό;

11

# Διαδικασία Μετάφρασης



12

# Assembly και Linking

Η μετάφραση assembly και το Linking είναι τα τελευταία βήματα στην διαδικασία μεταγλώττισης του λογισμικού.

Μετατρέπουν μια λίστα εντολών σε έναν πίνακα από bits που θα αποθηκευτούν στην μνήμη του ενσωματωμένου συστήματος.



13

# Προγράμματα Πολλαπλών Αρχείων

---

Το λογισμικό μπορεί να αποτελείται από πολλά αρχεία  
Οι διευθύνσεις γίνονται πιο συγκεκριμένες κατά τη διάρκεια της επεξεργασίας:

- Οι σχετικές διευθύνσεις μετρούνται σε σχέση με την αρχή (στην μνήμη) του προγράμματος που την χρησιμοποιεί
- Οι απόλυτες διευθύνσεις μετρούνται από την αρχή του χώρου μνήμης της CPU

14

# Assemblers

---

**Οι βασικές λειτουργίες των assemblers:**

- Παραγωγή δυαδικών από τις συμβολικές εντολές
- Μετάφραση των ετικετών (labels) σε διευθύνσεις
- Επεξεργασία ψευδοεντολών

**Η ύπαρξη των ετικετών επιβάλλει την επεξεργασία 2 περασμάτων**

- Στο πρώτο πέρασμα καθορίζεται η διεύθυνση κάθε ετικέτας
- Στο δεύτερο πέρασμα μετατρέπονται οι συμβολικές εντολές σε δυαδικές χρησιμοποιώντας τις διευθύνσεις από το πρώτο πέρασμα

15

# Παραγωγή Symbol Table

Καθώς ο assembler μεταφράζει ένα πρόγραμμα, διατηρεί έναν πίνακα συμβόλων (symbol table)

- < ετικέτα, διεύθυνση >
- Όταν ορίζεται μια ετικέτα, αυτή η ετικέτα, μαζί με την τρέχουσα τιμή του Μετρητή Θέσης (Program Location Counter, PLC), αποθηκεύονται στον πίνακα συμβόλων
- Όταν χρησιμοποιείται μια ετικέτα, ο assembler αναζητά στον πίνακα συμβόλων για να βρει την αντίστοιχη διεύθυνση Μετρητής Θέσης (PLC) — παρακολουθεί τη διεύθυνση της τρέχουσας εντολής κατά τη διαδικασία παραγωγής του κώδικα assembly
- **Ο Program Location Counter δεν είναι ο μετρητής προγράμματος (PC).** Ο μετρητής τοποθεσίας είναι μια μεταβλητή που χρησιμοποιείται κατά τη μετάφραση του προγράμματος. Ο PC είναι ένας καταχωρητής που χρησιμοποιείται κατά την εκτέλεση του προγράμματος

# Παραγωγή Symbol Table (cont.)

Χρήση του Program Location Counter (PLC) για τον καθορισμό της διεύθυνσης κάθε θέσης.

Στο πρώτο πέρασμα μετράει ο PLC και αποθηκεύει τις ετικέτες στο Symbol Table.



# Linking

Το ενσωματωμένο λογισμικό αναπτύσσεται σε πολλά αρχεία. Κάθε ένα από αυτά μετατρέπεται σε «γλώσσα μηχανής».

Ο Linker συνδέει όλα αυτά τα μεταφρασμένα αρχεία σε ένα μεγάλο κάνοντας τις αντίστοιχες μετατροπές στα αρχεία αυτά.

Ο Linker λειτουργεί σε 2 φάσεις:

- Αφού τοποθετήσει όλα τα αρχεία στη σειρά όπως θα μπουν στην μνήμη (user defined) καθορίζει την απόλυτη διεύθυνση που θα αρχίζει κάθε αρχείο.
- Έπειτα, συνενώνει όλα τα Symbol Tables σε ένα μεγάλο και μετατρέπει τις σχετικές διευθύνσεις κάθε αρχείου σε απόλυτες.

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

- Κώδικας που επεξεργάζεται interrupts πρέπει να είναι σε συγκεκριμένη θέση μνήμης για να μπορεί να τον χρησιμοποιήσει ο μικροεπεξεργαστής.

19

# Loader

- Ο Loader φορτώνει το ολοκληρωμένο πρόγραμμα στη μνήμη όπου μπορεί να εκτελεστεί
  - Φορτώνει τμήματα κειμένου και δεδομένων στη μνήμη σε καθορισμένη θέση
  - Επιστρέφει την τιμή της διεύθυνσης έναρξης στο λειτουργικό σύστημα (— τη διεύθυνση της πρώτης εντολής που θα εκτελεστεί)
- Εναλλακτικές λύσεις στη φόρτωση
  - Απόλυτος φορτωτής (Absolute Loader) — φορτώνει το εκτελέσιμο αρχείο σε σταθερή θέση
  - Relocatable Loader — μπορεί να φορτώσει το πρόγραμμα σε μια αυθαίρετη θέση μνήμης
    - Ο assembler και ο linker υποθέτουν ότι το πρόγραμμα θα ξεκινήσει στη θέση 0
    - Όταν το πρόγραμμα διαβάζεται από τον Loader, ο Loader τροποποιεί όλες τις διευθύνσεις προσθέτοντας την πραγματική θέση έναρξης σε αυτές τις διευθύνσεις

20

# Address space after Loading (obj code architecture) for x86



# Γλώσσα Assembly (Συμβολική)

Μνημονικές συντμήσεις των εντολών  
Συμβολικά ονόματα ρουτίνων, διευθύνσεων  
Γενικός τύπος Εντολής Assembly

| <i>label (:)</i> | <i>Mnemonic</i> | <i>Operand(s)</i>   | <i>; Comments</i> |
|------------------|-----------------|---------------------|-------------------|
|                  | LDA             | Label-1             |                   |
| Label-2:         | ADD             | oper                |                   |
|                  | MOV             | destination, source |                   |
|                  | MVI             | destination, data   |                   |
|                  | ADI             | data                |                   |
|                  | JMP             | Label-2             |                   |

Μακροεντολές και Υποπρογράμματα

24

# Οδηγίες Συμβολομεταφραστή

---

Οι οδηγίες συντάσσονται όπως και οι εντολές, αλλά έχουν σημαντικές διαφορές από αυτές. Πρώτον, δεν ανήκουν στο σύνολο των εντολών του μΕ, (μικροεπεξεργαστή) και δεύτερον, δεν μεταφράζονται σε κώδικα. Η χρησιμότητά τους έγκειται στο να δίνουν κάποιες πληροφορίες προς τον assembler, όταν αυτός δημιουργεί τον κώδικα.

25

# Οδηγίες του Assembler (Ψευδο-εντολές)

ORG (Origin)

Διεύθυνση επόμενης εντολής

END

Τέλος κώδικα

DB (1 byte), DW (2 byte), DD (4 byte)

Π.χ. DB 084H → 84

EQU    Symbol = Constant

Π.χ. LOOP EQU 0100H

SET: ίδια με την **EQU** μόνο που μπορεί να αλλάξει η τιμή του συμβολικού ονόματος

DS (define storage): Φυλάσσεται ένας αριθμός από θέσεις μνήμης για αποθήκευση δεδομένων

26

# ORG (origin)

## Σύνταξη: ORG έκφραση

Η ψευδοεντολή αυτή ακολουθείται από έναν αριθμό που δείχνει την απόλυτη θέση μνήμης όπου πρέπει να τοποθετηθεί η πρώτη εκτελέσιμη εντολή του προγράμματος. Αν δεν υπάρχει η ψευδοεντολή **ORG** πριν την πρώτη εντολή του προγράμματος, τότε η εντολή τοποθετείται στη θέση 0 της μνήμης. Μπορούμε να έχουμε περισσότερες από μία ψευδοεντολές **ORG**, οι οποίες θα δείχνουν τη θέση της μνήμης για την πρώτη εκτελέσιμη εντολή που τις ακολουθεί. Για παράδειγμα, στις παρακάτω εντολές ενός προγράμματος έχουμε:

ORG 0100H ; Ο κώδικας των εντολών αυτών αρχίζει από τη θέση μνήμης 0100H

ΕΝΤΟΛΕΣ ASSEMBLY

ORG 0200 ; Ο κώδικας των εντολών αυτών αρχίζει από τη θέση μνήμης 0200H

ΕΝΤΟΛΕΣ ASSEMBLY

27

# END

---

## Σύνταξη: END

Η ψευδοεντολή αυτή δηλώνει το φυσικό τέλος του προγράμματος και πρέπει να είναι μοναδική για κάθε πρόγραμμα. Όταν ο assembler αναγνωρίσει το φυσικό τέλος του προγράμματος, αρχίζει τη δημιουργία του κώδικα και (πιθανώς) της λίστας του πηγαίου προγράμματος.

28

# DB, DW, DD

## DB, DW, DD

define byte, define word, define double word

Σύνταξη: <επιγραφή:> **DB** λίστα

<επιγραφή:> **DW** λίστα

<επιγραφή:> **DD** λίστα

Με τον όρο λίστα εννοούμε τιμές δεδομένων ή εκφράσεις.

Οι ψευδοεντολές αυτές έχουν σαν αποτέλεσμα να αποθηκεύει ο assembler σε μία ή περισσότερες θέσεις μνήμης τις συγκεκριμένες τιμές αρχίζοντας από τη διεύθυνση της επιγραφής. Οι θέσεις αυτές μπορεί να είναι ομάδες από bytes (8 bits), λέξεις (16 bits) ή διπλές λέξεις (32 bits). Ο όρος έκφραση εδώ αναφέρεται σε μια ή περισσότερες αριθμητικές ή λογικές εκφράσεις. Επίσης στην περίπτωση της ψευδοεντολής DB μπορούμε στη λίστα να περιλάβουμε και χαρακτήρες σε εισαγωγικά. Ο assembler αναλαμβάνει την αντικατάστασή τους σε ASCII μορφή.

Δημιουργία στατικών μεταβλητών κώδικα, π.χ. πίνακες, ακέραιοι κτλ  
με αρχικοποίηση 29

# DS (define storage)

Σύνταξη: <επιγραφή:> **DS** έκφραση

Με την ψευδοεντολή αυτή φυλάσσεται ένας αριθμός από θέσεις μνήμης για αποθήκευση δεδομένων. Η πρώτη από τις θέσεις μπορεί να αναφερθεί με τη συμβολική επιγραφή. Προσοχή πρέπει να δώσουμε στις δύο τελείες μετά την επιγραφή. Ο αριθμός των bytes που δεσμεύονται είναι ίσος με την τιμή της έκφρασης.

Για παράδειγμα αν θέλουμε να κρατήσουμε δέκα bytes για αποθήκευση δεδομένων με το όνομα DEKA δηλώνουμε:

DEKA: DS 10

**Δημιουργία στατικών μεταβλητών κώδικα, π.χ. πίνακες,  
ακέραιοι κτλ χωρίς αρχικοποίηση**

30

# EQU (equate)

Σύνταξη: όνομα **EQU** έκφραση

Με την ψευδοεντολή αυτή ένα συμβολικό όνομα αντιστοιχείται με μια σταθερά ή διεύθυνση ή γενικότερα έκφραση. Η εντολή αυτή είναι ισοδύναμη με την εντολή const της Pascal ή #define της C και έχει σαν αποτέλεσμα όποτε συναντάται το συμβολικό όνομα στο πρόγραμμα να χρησιμοποιείται η έκφραση στην οποίαν ισοδυναμεί. Πρέπει να σημειώσουμε πως εδώ το όνομα δεν είναι επιγραφή και δεν ακολουθείται από δύο τελείες (:) αν και βρίσκεται στο πεδίο της επιγραφής. Επίσης η τιμή του ονόματος δεν μπορεί να αλλάξει με το πρόγραμμα.

Sunday EQU 1

Monday EQU Sunday + 1 <-> Monday EQU 2

31

# SET

---

Σύνταξη: όνομα **SET** έκφραση

Έχει τα ίδια αποτελέσματα με την **EQU**. Η διαφορά της βρίσκεται στο ότι μπορεί η τιμή του συμβολικού ονόματος να αλλάξει μέσα στο πηγαίο πρόγραμμα. Έτσι πολλές **SET** μπορεί να αναφέρονται στο ίδιο συμβολικό όνομα μέσα στο ίδιο πρόγραμμα.

Sunday EQU 1

Monday SET Sunday + 1

Tuesday EQU Sunday + 2

...

Monday SET Tuesday - 1

32

# IF, ENDIF

Σύνταξη:      **IF** έκφραση  
                        εντολές assembly  
**ENDIF**

Εάν η τιμή της έκφρασης είναι 0 οι εντολές έως την **ENDIF αγνοούνται** ενώ εάν είναι 1 οι εντολές μεταφράζονται από τον assembler.

- Υπάρχει ακόμη ένας σημαντικός αριθμός από ψευδοεντολές/οδηγίες που όμως αλλάζουν από υλοποίηση σε υλοποίηση. Μπορούμε να αναφέρουμε ενδεικτικά γιά τον MASM 8086 τις **SEGMENT/ENDS, ASSUME, GROUP, LABEL** και **PROC/ENDP**, που θα αναφερθούν και στο κεφάλαιο 9 του παρόντος βιβλίου.
  
- *Τελειώνοντας αναφέρουμε πως τις ψευδοεντολές (pseudo instructions) μπορούμε να συναντήσουμε στην βιβλιογραφία και ως assembler directives, nongenerative instructions ή declaratives.*

33

# Πολλαπλασιασμός – Διάγραμμα Ροής

|              |                       |                                             |
|--------------|-----------------------|---------------------------------------------|
| Multiplicand | 1011                  | 11                                          |
| Multiplier   | $\frac{1101}{1011}$   | 13                                          |
|              | 0000<br>1011          | } Partial Products<br><br>$\overline{1011}$ |
| Product      | $\overline{10001111}$ |                                             |

Mul  $N \times N \rightarrow$  Product  $2N$



34

Table 6. Instruction Set Summary

| Mnemonic                     | Instruction Code |                |                |                |                |                |                | Operations Description    |
|------------------------------|------------------|----------------|----------------|----------------|----------------|----------------|----------------|---------------------------|
|                              | D <sub>7</sub>   | D <sub>6</sub> | D <sub>5</sub> | D <sub>4</sub> | D <sub>3</sub> | D <sub>2</sub> | D <sub>1</sub> | D <sub>0</sub>            |
| <b>MOVE, LOAD, AND STORE</b> |                  |                |                |                |                |                |                |                           |
| MOV r2                       | 0                | 1              | D              | D              | D              | S              | S              | Move register to register |
| MOV M.r                      | 0                | 1              | 1              | 1              | 0              | S              | S              | Move register to memory   |
| MOV r.M                      | 0                | 1              | D              | D              | D              | 1              | 1              | 0                         |
| MVI r                        | 0                | 0              | D              | D              | D              | 1              | 1              | 0                         |
| MVI M                        | 0                | 0              | 1              | 1              | 0              | 1              | 1              | 0                         |
| LXI B                        | 0                | 0              | 0              | 0              | 0              | 0              | 1              | Load immediate register   |
| LXI D                        | 0                | 0              | 0              | 1              | 0              | 0              | 0              | 1                         |
| LXI H                        | 0                | 0              | 1              | 0              | 0              | 0              | 0              | 1                         |
| STAX B                       | 0                | 0              | 0              | 0              | 0              | 0              | 1              | 0                         |
| STAX D                       | 0                | 0              | 0              | 1              | 0              | 0              | 1              | 0                         |
| LDAX B                       | 0                | 0              | 0              | 0              | 1              | 0              | 1              | 0                         |
| LDAX D                       | 0                | 0              | 0              | 1              | 1              | 0              | 1              | 0                         |
| STA                          | 0                | 0              | 1              | 1              | 0              | 0              | 1              | 0                         |
| LDA                          | 0                | 0              | 1              | 1              | 1              | 0              | 1              | 0                         |
| SHLD                         | 0                | 0              | 1              | 0              | 0              | 0              | 1              | 0                         |
| LHLD                         | 0                | 0              | 1              | 0              | 1              | 0              | 1              | 0                         |
| XCHG                         | 1                | 1              | 1              | 0              | 1              | 0              | 1              | 1                         |
| <b>STACK OPS</b>             |                  |                |                |                |                |                |                |                           |
| PUSH B                       | 1                | 1              | 0              | 0              | 0              | 1              | 0              | 1                         |
| PUSH D                       | 1                | 1              | 0              | 1              | 0              | 1              | 0              | 1                         |
| PUSH H                       | 1                | 1              | 1              | 0              | 0              | 1              | 0              | 1                         |
| PUSH PSW                     | 1                | 1              | 1              | 1              | 0              | 1              | 0              | 1                         |
| POP B                        | 1                | 1              | 0              | 0              | 0              | 0              | 1              | 1                         |
| POP D                        | 1                | 1              | 0              | 1              | 0              | 0              | 0              | 1                         |
| POP H                        | 1                | 1              | 1              | 0              | 0              | 0              | 0              | 1                         |
| POP PSW                      | 1                | 1              | 1              | 1              | 0              | 0              | 0              | 1                         |
| XTHL                         | 1                | 1              | 1              | 0              | 0              | 0              | 1              | 1                         |
| SPHL                         | 1                | 1              | 1              | 1              | 1              | 0              | 0              | 1                         |
| LXI SP                       | 0                | 0              | 1              | 1              | 0              | 0              | 1              | 1                         |
| INX SP                       | 0                | 0              | 1              | 1              | 1              | 0              | 1              | 1                         |
| DCX SP                       | 0                | 0              | 1              | 1              | 1              | 0              | 1              | 1                         |
| <b>JUMP</b>                  |                  |                |                |                |                |                |                |                           |
| JMP                          | 1                | 1              | 0              | 0              | 0              | 0              | 1              | 1                         |
| JC                           | 1                | 1              | 0              | 1              | 1              | 0              | 1              | 0                         |
| JNC                          | 1                | 1              | 0              | 1              | 0              | 0              | 1              | 0                         |
| JZ                           | 1                | 1              | 0              | 0              | 1              | 0              | 1              | 0                         |
| JNZ                          | 1                | 1              | 0              | 0              | 0              | 0              | 1              | 0                         |
| JP                           | 1                | 1              | 1              | 1              | 0              | 0              | 1              | 0                         |
| JM                           | 1                | 1              | 1              | 1              | 1              | 0              | 1              | 0                         |
| JPE                          | 1                | 1              | 1              | 0              | 1              | 0              | 1              | 0                         |
| JPO                          | 1                | 1              | 1              | 0              | 0              | 1              | 0              | 0                         |
| PCHL                         | 1                | 1              | 1              | 0              | 1              | 0              | 0              | 1                         |
| <b>CALL</b>                  |                  |                |                |                |                |                |                |                           |
| CALL                         | 1                | 1              | 0              | 0              | 1              | 1              | 0              | 1                         |
| CC                           | 1                | 1              | 0              | 1              | 1              | 1              | 0              | 0                         |
| CNC                          | 1                | 1              | 0              | 1              | 0              | 1              | 0              | 0                         |

| Mnemonic                       | Instruction Code |                |                |                |                |                |                | Operations Description |
|--------------------------------|------------------|----------------|----------------|----------------|----------------|----------------|----------------|------------------------|
|                                | D <sub>7</sub>   | D <sub>6</sub> | D <sub>5</sub> | D <sub>4</sub> | D <sub>3</sub> | D <sub>2</sub> | D <sub>1</sub> | D <sub>0</sub>         |
| <b>RETURN</b>                  |                  |                |                |                |                |                |                |                        |
| CZ                             | 1                | 1              | 0              | 0              | 1              | 1              | 0              | 0                      |
| CNZ                            | 1                | 1              | 0              | 0              | 0              | 1              | 0              | 0                      |
| CP                             | 1                | 1              | 1              | 1              | 0              | 1              | 0              | 0                      |
| CM                             | 1                | 1              | 1              | 1              | 1              | 1              | 0              | 0                      |
| CPE                            | 1                | 1              | 1              | 0              | 1              | 1              | 0              | 0                      |
| CPO                            | 1                | 1              | 1              | 0              | 0              | 1              | 0              | 0                      |
| <b>RESTART</b>                 |                  |                |                |                |                |                |                |                        |
| RST                            | 1                | 1              | A              | A              | A              | 1              | 1              | 1                      |
| <b>INPUT/OUTPUT</b>            |                  |                |                |                |                |                |                |                        |
| IN                             | 1                | 1              | 0              | 1              | 1              | 0              | 1              | 1                      |
| OUT                            | 1                | 1              | 0              | 1              | 0              | 0              | 1              | 1                      |
| <b>INCREMENT AND DECREMENT</b> |                  |                |                |                |                |                |                |                        |
| INR r                          | 0                | 0              | D              | D              | D              | 1              | 0              | 0                      |
| DCR r                          | 0                | 0              | D              | D              | D              | 1              | 0              | 1                      |
| INR M                          | 0                | 0              | 1              | 1              | 0              | 1              | 0              | 0                      |
| DCR M                          | 0                | 0              | 1              | 1              | 0              | 1              | 0              | 1                      |
| INX B                          | 0                | 0              | 0              | 0              | 0              | 0              | 1              | 1                      |
| INX D                          | 0                | 0              | 0              | 1              | 0              | 0              | 1              | 1                      |
| INX H                          | 0                | 0              | 1              | 0              | 0              | 0              | 1              | 1                      |
| DCX B                          | 0                | 0              | 0              | 0              | 1              | 0              | 1              | 1                      |
| DCX D                          | 0                | 0              | 0              | 1              | 1              | 0              | 1              | 1                      |
| DCX H                          | 0                | 0              | 1              | 0              | 1              | 0              | 1              | 1                      |
| <b>ADD</b>                     |                  |                |                |                |                |                |                |                        |
| ADD r                          | 1                | 0              | 0              | 0              | 0              | S              | S              | S                      |
| ADC r                          | 1                | 0              | 0              | 0              | 1              | S              | S              | S                      |
| ADD M                          | 1                | 0              | C              | 0              | 0              | 1              | 1              | 0                      |
| ADC M                          | 1                | 0              | 0              | 0              | 1              | 1              | 1              | 0                      |
| ADI                            | 1                | 1              | 0              | 0              | 0              | 1              | 1              | 0                      |
| ACI                            | 1                | 1              | 0              | 0              | 1              | 1              | 1              | 0                      |
| <b>DAD</b>                     |                  |                |                |                |                |                |                |                        |
| DAD B                          | 0                | 0              | 0              | 0              | 1              | 0              | 0              | 1                      |
| DAD D                          | 0                | 0              | 0              | 1              | 1              | 0              | 0              | 1                      |
| DAD H                          | 0                | 0              | 1              | 0              | 1              | 0              | 0              | 1                      |
| DAD SP                         | 0                | 0              | 1              | 1              | 1              | 0              | 0              | 1                      |
| <b>SUBTRACT</b>                |                  |                |                |                |                |                |                |                        |
| SUB r                          | 1                | 0              | 0              | 1              | 0              | S              | S              | S                      |
| SBB r                          | 1                | 0              | 0              | 1              | 1              | S              | S              | S                      |
| SUB M                          | 1                | 0              | 0              | 1              | 0              | 1              | 1              | 0                      |
| SBB M                          | 1                | 0              | 0              | 1              | 1              | 1              | 1              | 0                      |
| SUI                            | 1                | 1              | 0              | 1              | 0              | 1              | 1              | 0                      |
| SBI                            | 1                | 1              | 0              | 1              | 1              | 1              | 1              | 0                      |

. ΚΑΘΗΓΗΤΗΣ: Σ. ΞΥΔΗΣ

|        |   |   |   |   |   |   |   |   |                            |
|--------|---|---|---|---|---|---|---|---|----------------------------|
| DAD B  | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 1 | Add B & C to H &           |
| DAD D  | 0 | 0 | 0 | 1 | 1 | 0 | 0 | 1 | Add D & E to H &           |
| DAD H  | 0 | 0 | 1 | 0 | 1 | 0 | 0 | 1 | Add H & L to H &           |
| DAD SP | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 1 | Add stack pointer<br>H & L |



# Πολλαπλασιασμός – Κώδικας

| Διεύθυνση   | Obj. Code       | Πηγαίο πρόγρ. | Σχόλια                                |
|-------------|-----------------|---------------|---------------------------------------|
|             |                 | ORG 0100H     |                                       |
| 0100        | 16 00           | MVI D,0       | ; (DE) = X                            |
| 0102        | 21 00 00        | LXI H,0       |                                       |
| 0105        | 06 08           | MVI B,8       | ; B = Μετρητής                        |
| <b>0107</b> | 29              | MULT: DAD H   | ; Γινόμενο * 2                        |
| 0108        | 17              | RAL           | ; Ολίσθηση ←                          |
| 0109        | D2 <b>0D 01</b> | JNC SKIP      | ; CY=1?                               |
| 010C        | 19              | DAD D         | ; Πρόσθεσέ των X<<Bit <sub>Rank</sub> |
| <b>010D</b> | 05              | SKIP: DCR B   | ; Άλλιώς μόνο B-1                     |
| 010E        | C2 <b>07 01</b> | JNZ MULT      | ; Τελείωσαν τα 8 bits                 |
| 0111        | 76              | HLT           | ; Τέλος                               |

# Παράδειγμα: Ενδείκτης Στάθμης Υγρού

Ζητείται η σχεδίαση ενός ενδείκτη στάθμης υγρού με φωτεινές στιγμές. Δίδεται ότι ο πλωτήρας με τον μετατροπέα παράγουν τάση ανάλογη της στάθμης. Επίσης δίδεται A/D των 4-bit που συνδέεται στην πόρτα εισόδου IN1. Τέλος 8 φωτεινές στιγμές από LEDs οδηγούνται από την πόρτα εξόδου OUT1.

37

# Ενδείκτης Στάθμης Υγρού: Διάγραμμα Συστήματος



38

# Ενδείκτης Στάθμης Υγρού: Κώδικας (1)

| Διεύθυνση | Obj. Code | line | Label | Mnemonic     |  |                        |
|-----------|-----------|------|-------|--------------|--|------------------------|
| 0000      |           | 1    | IN1   | EQU 10H      |  |                        |
| 0000      |           | 2    | OUT1  | EQU 20H      |  | Why no obj. code here? |
| 0000      |           | 3    |       | ORG 0000H    |  |                        |
| 0000      | DB 10     | 4    | LOOP: | IN IN1       |  |                        |
| 0002      | E6 0F     | 5    |       | ANI 0FH      |  |                        |
| 0004      | 5F        | 6    |       | MOV E,A      |  |                        |
| 0005      | 16 00     | 7    |       | MVI D,0      |  | DE <- Data             |
| 0007      | 21 11 00  | 8    |       | LXI H, TABLE |  |                        |
| 000A      | 19        | 9    |       | DAD D        |  |                        |
| 000B      | 7E        | 10   |       | MOV A,M      |  |                        |
| 000C      | D3 20     | 11   |       | OUT OUT1     |  |                        |
| 000E      | C3 00 00  | 12   |       | JMP LOOP     |  |                        |

39

# Ενδείκτης Στάθμης Υγρού: Κώδικας (2)

| Διεύθ. | Obj. Code | line | Label  | Mnemonic                                   |
|--------|-----------|------|--------|--------------------------------------------|
| 0011   | 00        | 15   | TABLE: | DB 00H, 01H, 01H, 03H, 03H, 07H, 07H, 0FH  |
| 0012   | 01        |      |        |                                            |
| 0013   | 01        |      |        |                                            |
| 0014   | 03        |      |        |                                            |
| 0015   | 03        |      |        |                                            |
| 0016   | 07        |      |        |                                            |
| 0017   | 07        |      |        |                                            |
| 0018   | 0F        |      |        |                                            |
| 0019   | 0F        | 16   |        | DB 0FH, 1FH, 1FH, 3FH, 3FH, 7FH, 7FH, OFFH |
| 001A   | 1F        |      |        |                                            |
| 001B   | 1F        |      |        |                                            |
| 001C   | 3F        |      |        |                                            |
| 001D   | 3F        |      |        |                                            |
| 001E   | 7F        |      |        |                                            |
| 001F   | 7F        |      |        |                                            |
| 0020   | FF        | 17   | END    |                                            |

40

# Μακροεντολές



42

# Παράδειγμα Μακροεντολής

Υλοποιήστε μια μακροεντολή, SWAP Q,R που εναλλάσσει τα περιεχόμενα οποιονδήποτε δύο καταχωρητών γενικού σκοπού B, C, D, E, H και L. Η εκτέλεση της μακροεντολής δεν πρέπει να επηρεάζει τα περιεχόμενα των υπολοίπων καταχωρητών που δεν μετέχουν στην εναλλαγή.

43

# SWAP MACRO

---

SWAP MACRO Q,R

```
PUSH PSW      ; στοίβα←A, F  
MOV A,Q  
MOV Q,R  
MOV R,A  
POP PSW      ; A, F←στοίβα  
ENDM
```

Για παράδειγμα η εντολή SWAP H,B αντικαθίσταται από το παρακάτω σύνολο εντολών:

```
PUSH PSW  
MOV A,H  
MOV H,B  
MOV B,A  
POP PSW
```

44

# Εντολές στοίβας - PUSH

## PUSH Reg Pair

$((SP) - 1) \leftarrow (Reg\ H)$   
 $((SP) - 2) \leftarrow (Reg\ L)$   
 $(SP) \leftarrow (SP) - 2$

|          | Reg H | Reg L |
|----------|-------|-------|
| PUSH B   | B     | C     |
| PUSH D   | D     | E     |
| PUSH H   | H     | L     |
| PUSH PSW | A     | Flags |



45

# Εντολές στοίβας - POP

## POP Reg Pair

$(\text{Reg L}) \leftarrow ((\text{SP}))$   
 $(\text{Reg H}) \leftarrow ((\text{SP}) + 1)$   
 $(\text{SP}) \leftarrow (\text{SP}) + 2$

|         | Reg H | Reg L |
|---------|-------|-------|
| POP B   | B     | C     |
| POP D   | D     | E     |
| POP H   | H     | L     |
| POP PSW | A     | Flags |



# Address space after Loading (obj code architecture) for x86



# Υπορουτίνες

## CALL Address

$((SP) - 1) \leftarrow (PCH)$   
 $((SP) - 2) \leftarrow (PCL)$   
 $(SP) \leftarrow (SP) - 2$   
 $(PC) \leftarrow Address$

PC of next 8085 instruction

## Συνθήκη Address

Αν ισχύει η συνθήκη  
(NZ, Z, NC, C, PO,  
PE, P, M) τότε:

$((SP) - 1) \leftarrow (PCH)$   
 $((SP) - 2) \leftarrow (PCL)$   
 $(SP) \leftarrow (SP) - 2$   
 $(PC) \leftarrow Address$

## RET

$(PCL) \leftarrow (SP)$   
 $(PCH) \leftarrow ((SP)+1)$   
 $(SP) \leftarrow (SP) + 2$



48

# Φωλιασμένη Κλήση Υπορουτινών

```
0000 LXI SP,610H
    Κύριο Πρόγραμμα
    .....
0180 CALL SUBR_A
0183 (επόμενη εντολή)
    Υπόλοιπο Κυρίου Προγρ.
    .....
    END

;Υπορουτίνα A
0400 SUBR_A: PUSH H
0401           PUSH D
0402           PUSH B
0403           PUSH PSW
    Κύριο Σώμα Υπορ. A
    .....
0420           CALL SUBR_B
0423       Υπόλοιπες Εντολές Υπορ. A
    .....
```

```
0436          POP PSW
0437          POP B
0438          POP D
0439          POP H
0440          RET

;Υπορουτίνα B
0510 SUBR_B: PUSH H
0511           PUSH D
0512           PUSH B
0513           PUSH PSW
    Κύριο Σώμα Υπορ. B
    .....
0536          POP PSW
0537          POP B
0538          POP D
0539          POP H
0540          RET
```

# Φωλιασμένη Κλήση Υπορουτινών (cont.)



50

# Στοίβα σε Φωλιασμένες Κλήσεις Υπορουτινών



51

# Λογισμικές Διακοπές (Software Interrupts)

RST n

$((SP)-1) \leftarrow (PCH)$   
 $((SP)-2) \leftarrow (PCL)$   
 $(SP) \leftarrow (SP)-2$   
 $(PC) \leftarrow 8n$

Η ροή του προγράμματος  
μεταπηδά σε  
προκαθορισμένη διεύθυνση

|       |      |
|-------|------|
| RST 0 | 0000 |
| RST 1 | 0008 |
| RST 2 | 0010 |
| RST 3 | 0018 |
| RST 4 | 0020 |
| RST 5 | 0028 |
| RST 6 | 0030 |
| RST 7 | 0038 |

52

# Παράδειγμα: Έλεγχος RAM



58

# Έλεγχος RAM: Κώδικας Υπορουτίνας (1)

```
REG16_FLAG MACRO ; Ενεργοποίηση σημαίας Z όταν ο διπλός καταχωρητής DE=0
    MOV B,A      ; Φυλάσσεται ο καταχωρητής A
    MOV A,E      ; Όταν και οι δύο καταχωρητές E και D είναι 0,
    ORA D        ; τότε η σημαία Z γίνεται 1.
    MOV A,B
ENDM          ; Μπορεί να γραφεί και σε παραμετρική μορφή για
              ; το διπλό καταχωρητή X-Y (D-E, H-L)

; Υπορουτίνα ελέγχου μνήμης
    MVI A,10101010B   ; Φόρτωση του byte ελέγχου
    PUSH D            ; Σώσιμο του πλήθους των bytes

WRITE:
    MOV M,A          ; Εγγραφή στη μνήμη
    CMA              ; Δημιουργία συμπληρωματικού byte ελέγχου
    INX H            ; Αύξηση του δείκτη της διεύθυνσης μνήμης
    DCX D            ; Μείωση του μετρητή των bytes
    REG16_FLAG       ; Έλεγχος μηδενισμού καταχωρητή DE
    JNZ WRITE        ; Αν δεν είναι 0 ξαναγράψε
    POP D            ; Φόρτωση του πλήθους των bytes
```

# Έλεγχος RAM: Κώδικας Υπορουτίνας (2)

```
; Αντίστροφη ανάγνωση και έλεγχος της μνήμης
DCX H ; Μείωση του δείκτη διεύθυνσης μνήμης
READ:
CMA ; Επαναφορά του byte ελέγχου
CMP M ; Έλεγχος ορθής εγγραφής
JNZ ERROR ; Σε περίπτωση λάθους τερματισμός
DCX H ; Μείωση του δείκτη διεύθυνσης μνήμης
DCX D ; Μείωση του μετρητή των bytes
REG16_FLAG ; Έλεγχος μηδενισμού καταχωρητή DE
JNZ READ ; Αν δεν είναι 0 ξαναδιάβασε

OK:
MVI A,0 ; Δε βρέθηκε σφάλμα, επιστρέφεται το 0
RET

ERROR:
MVI A,1 ; Βρέθηκε σφάλμα, επιστρέφεται το 1
RET
```

60

# Σχεδιάζοντας με μικροεπεξεργαστές

---

Η αρχιτεκτονική ενός ενσωματωμένου συστήματος είναι συνισταμένη του:

- Hardware
- Software

Το Hardware περιλαμβάνει πολλά συστατικά:

- CPU
- Bus
- Μνήμες
- Συσκευές Εισόδου-Εξόδου (κάρτες δικτύου, αισθητήρες, κτλ)

Ποιά είναι η σωστή επιλογή για κάθε ένα από τα παραπάνω συστατικά του συστήματος;

# Αναπτυξιακά Συστήματα για Κατασκευή Μικρούπολογιστών

---

## Hardware Εργαλεία

- Αναπτυξιακές κάρτες
- Real-time (In-Circuit) emulators
- Logic Analyzers

## Software Εργαλεία

- Monitor
- Assemblers
- Cross Compilers
- Cross Debuggers

64

# Σχεδιασμός του Hardware

---

Η Πολυπλοκότητα του HW σχεδιασμού μπορεί να ποικίλλει από ένα έτοιμο απλό σύστημα μέχρι ένα Full-custom σύστημα.

Αφού γίνει επιλογή του μικροεπεξεργαστή, το πρώτο βήμα είναι η χρήση **αναπτυξιακής κάρτας**. Πρόκειται για μια κάρτα με τον επεξεργαστή, μνήμη και αρκετά Interfaces ενώ συνοδεύεται από το απαραίτητο SW για τον προγραμματισμό και τον έλεγχο του μικροεπεξεργαστή. Η αναπτυξιακή κάρτα είναι διαθέσιμη από την εταιρεία κατασκευής του μικροεπεξεργαστή.

Το δεύτερο βήμα είναι η επιλογή των συσκευών εισόδου/εξόδου και των μνημών. Πρέπει να μελετηθούν τα **datasheets** των ολοκληρωμένων προσεκτικά για να γίνει κατανοητός τόσο ο τρόπος λειτουργίας τους όσο και ο τρόπος ελέγχου και επικοινωνίας.

Το τρίτο βήμα είναι να εξεταστεί η ανάγκη ύπαρξης **glue logic** (FPGAs, CPLDs) για να επιτευχθεί επικοινωνία μεταξύ κάποιων ολοκληρωμένων, ή για να υλοποιηθεί κάποια λογική που απαιτείται (π.χ. Address decoding).

# Αρχιτεκτονική Software

---

Συνήθως οι σχεδιαστές SW Ενσωματωμένων Συστημάτων προσπαθούν να αναπτύξουν μεγάλο μέρος του SW σε μια γνωστή πλατφόρμα γιατί

- Το περιβάλλον προγραμματισμού είναι πιο φιλικό
- Είναι πιο εύκολος ο έλεγχος του SW

Πολλές versions του SW πρέπει να φτιάχνονται ενδιάμεσα για να υλοποιούν τμήματα της συνολικής λειτουργίας και να δοκιμάζονται στην πλατφόρμα του Ενσωματωμένου Συστήματος.

67

# Εργαλεία ανάπτυξης στον Host

---

Cross Compiler: Πρόκειται για έναν Compiler που τρέχει σε έναν τύπο μηχανής (στο PC) αλλά παράγει κώδικα για έναν άλλο τύπο μηχανής (τον μικροεπεξεργαστή στο Ενσωματωμένο Σύστημα). Ο παραγόμενος κώδικας μπορεί να γίνει download μέσω του σειριακού link στο πραγματικό σύστημα.

Cross Debugger: Πρόκειται για απεικόνιση σε SW στον Host, της κατάστασης του Target σε πραγματικό χρόνο. Επίσης, επιτρέπει τον απόλυτο έλεγχο του μικροεπεξεργαστή και των περιφερειακών του μέσω της σειριακής επικοινωνίας Host και Target.

# Εργαλεία ελέγχου του Target

In-Circuit Emulators: Πρόκειται για έναν ειδικό μικροεπεξεργαστή που επιτρέπει την πρόσβαση στους καταχωρητές του όταν είναι σταματημένος → deprecated & replaced by JTAG tech.

Το βασικό πρόβλημα είναι το γεγονός ότι το μηχάνημα λειτουργεί μόνο με έναν συγκεκριμένο μικροεπεξεργαστή

Logic Analyzers: Πρόκειται για ένα πλήθος χαμηλού κόστους παλμογράφων. Χρησιμοποιείται για να απεικονίζεται η ψηφιακή στάθμη σημάτων του συστήματος



# Ανάπτυξη και Έλεγχος

Για την ανάπτυξη του SW και τον έλεγχο τόσο του HW όσο και του SW χρησιμοποιείται η συνδεσμολογία **Host-Target**, όπου Host είναι ένα PC και Target το Ενσωματωμένο Σύστημα που αναπτύσσουμε. Η επικοινωνία γίνεται συνήθως μέσω ενός σειριακού Link (JTAG).



70