Αρχιτεκτονική Επεξεργαστών Ψ.Ε.Σ



Σχετικά έγγραφα
Εισαγωγή στα Συστήματα Ψηφιακής Επεξεργασίας Σήματος

Αρχιτεκτονική Μνήµης

Αρχιτεκτονική Μνήμης

ΕΣ 08 Επεξεργαστές Ψηφιακών Σηµάτων. Βιβλιογραφία Ενότητας

Παραλληλισµός Εντολών (Pipelining)

Κεφάλαιο 3 Αρχιτεκτονική Ηλεκτρονικού Τμήματος (hardware) των Υπολογιστικών Συστημάτων ΕΡΩΤΗΣΕΙΣ ΑΣΚΗΣΕΙΣ

Μηχανοτρονική. Τμήμα Μηχανικών Παραγωγής και Διοίκησης 7 ο Εξάμηνο,

ΕΙΔΙΚΟΤΗΤΑ: ΤΕΧΝΙΚΟΣ ΕΦΑΡΜΟΓΩΝ ΠΛΗΡΟΦΟΡΙΚΗΣ ΜΑΘΗΜΑ: ΕΙΣΑΓΩΓΗ ΣΤΗΝ ΠΛΗΡΟΦΟΡΙΚΗ

Μάθημα 3: Αρχιτεκτονική Υπολογιστών

ΑΡΧΙΤΕΚΤΟΝΙΚΗ HARDWARE ΥΠΟΛΟΓΙΣΤΙΚΩΝ ΣΥΣΤΗΜΑΤΩΝ

Αρχιτεκτονική υπολογιστών

Μάθημα 4: Κεντρική Μονάδα Επεξεργασίας

Ενότητα 4. Εισαγωγή στην Πληροφορική. Αναπαράσταση δεδοµένων. Αναπαράσταση πληροφορίας. υαδικοί αριθµοί. Χειµερινό Εξάµηνο

1. Οργάνωση της CPU 2. Εκτέλεση εντολών 3. Παραλληλία στο επίπεδο των εντολών 4. Γραμμές διοχέτευσης 5. Παραλληλία στο επίπεδο των επεξεργαστών

Τμήμα Λογιστικής. Εισαγωγή στους Ηλεκτρονικούς Υπολογιστές. Μάθημα 8. 1 Στέργιος Παλαμάς

Γενική οργάνωση υπολογιστή «ΑΒΑΚΑ»

Μάθημα 3.2: Κεντρική Μονάδα Επεξεργασίας

ΚΕΦΑΛΑΙΟ 2: Χειρισµός εδοµένων

Κεντρική Μονάδα Επεξεργασίας

ΤΕΧΝΙΚΕΣ ΑΥΞΗΣΗΣ ΤΗΣ ΑΠΟΔΟΣΗΣ ΤΩΝ ΥΠΟΛΟΓΙΣΤΩΝ I

Βασική δοµή και Λειτουργία Υπολογιστή

και η µονάδα ελέγχου (control) O επεξεργαστής: Η δίοδος δεδοµένων (datapath) Εντολές διακλάδωσης (branch beq, bne) I Type Σχεδίαση datapath

Chapter 5. Ο επεξεργαστής: διαδρομή δεδομένων και μονάδα ελέγχου. Ενδέκατη (11 η ) δίωρη διάλεξη.

Σελίδα 1 από 12. Απαντήσεις στο φυλλάδιο 55. Ερώτηση 1 η : Ένα υπολογιστικό σύστηµα αποτελείται από:

O επεξεργαστής: Η δίοδος δεδομένων (datapath) και η μονάδα ελέγχου (control)

Το ολοκληρωμένο κύκλωμα μιας ΚΜΕ. «Φέτα» ημιαγωγών (wafer) από τη διαδικασία παραγωγής ΚΜΕ

Η διασύνδεση Υλικού και λογισμικού David A. Patterson και John L. Hennessy. Chapter 5. Ο επεξεργαστής: διαδρομή δεδομένων και μονάδα ελέγχου

Ιόνιο Πανεπιστήμιο Τμήμα Πληροφορικής Αρχιτεκτονική Υπολογιστών Απόδοση ΚΜΕ. (Μέτρηση και τεχνικές βελτίωσης απόδοσης)

Ακαδημαϊκό Έτος , Εαρινό Εξάμηνο Διδάσκων Καθ.: Νίκος Τσαπατσούλης

Αρχιτεκτονικη υπολογιστων

i Όλες οι σύγχρονες ΚΜΕ είναι πολυπλοκότερες!

Εργαστήριο 3 ΟΡΓΑΝΩΣΗ ΤΗΣ ΚΜΕ. Εισαγωγή

Στοιχεία αρχιτεκτονικής μικροεπεξεργαστή

Οργάνωση επεξεργαστή (1 ο μέρος) ΜΥΥ-106 Εισαγωγή στους Η/Υ και στην Πληροφορική

Είναι το «μυαλό» του υπολογιστή μας. Αυτός κάνει όλους τους υπολογισμούς και τις πράξεις. Έχει δική του ενσωματωμένη μνήμη, τη λεγόμενη κρυφή

Στοιχεία από την αρχιτεκτονική των μικροϋπολογιστών

(Ιούνιος 2001 ΤΕΕ Ηµερήσιο) Σε κάθε µία από τις παρακάτω περιπτώσεις, να

Μικροεπεξεργαστές - Μικροελεγκτές Ψηφιακά Συστήματα

Κάθε functional unit χρησιμοποιείται μια φορά σε κάθε κύκλο: ανάγκη για πολλαπλό hardware = κόστος υλοποίησης!

ΥΠΟΥΡΓΕΙΟ ΠΑΙΔΕΙΑΣ ΚΑΙ ΠΟΛΙΤΙΣΜΟΥ ΔΙΕΥΘΥΝΣΗ ΑΝΩΤΕΡΗΣ ΚΑΙ ΑΝΩΤΑΤΗΣ ΕΚΠΑΙΔΕΥΣΗΣ ΥΠΗΡΕΣΙΑ ΕΞΕΤΑΣΕΩΝ ΠΑΓΚΥΠΡΙΕΣ ΕΞΕΤΑΣΕΙΣ 2015

Μάθημα 5: Χαρακτηριστικά της Κ.Μ.Ε.

Αρχιτεκτονική Eckert-von Neumann. Πως λειτουργεί η ΚΜΕ; Κεντρική μονάδα επεξεργασίας [3] ΕΠΛ 031: ΕΙΣΑΓΩΓΗ ΣΤΟΝ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟ

O επεξεργαστής: Η δίοδος δεδομένων (datapath) και η μονάδα ελέγχου (control)

ΕΙΣΑΓΩΓΗ ΣΤΟΥΣ ΥΠΟΛΟΓΙΣΤΕΣ

ΠΑΝΕΠΙΣΤΗΜΙΟ ΘΕΣΣΑΛΙΑΣ ΠΟΛΥΤΕΧΝΙΚΗ ΣΧΟΛΗ ΔΕΥΤΕΡΗ ΠΡΟΟΔΟΣ ΣΤΗΝ ΟΡΓΑΝΩΣΗ ΣΤΟΥΣ Η/Y (ΗΥ232)

Κεντρική Μονάδα Επεξεργασίας (ΚΜΕ) Τμήματα ΚΜΕ (CPU) Ένα τυπικό υπολογιστικό σύστημα σήμερα. Οργάνωση Υπολογιστών (Ι)

Οργάνωση Υπολογιστών (Ι)

i Throughput: Ο ρυθμός ολοκλήρωσης έργου σε συγκεκριμένο χρόνο

Λογικός Σχεδιασµός και Σχεδιασµός Η/Υ. ΗΜΥ-210: Εαρινό Εξάµηνο Σκοπός του µαθήµατος. Ψηφιακά Συστήµατα. Περίληψη. Εύρος Τάσης (Voltage(

Θέµατα Φεβρουαρίου

Multi Cycle Datapath. Αρχιτεκτονική Υπολογιστών. 5ο εξάμηνο ΣΗΜΜΥ ακ. έτος: Νεκ. Κοζύρης

Το υλικό του υπολογιστή

ΥΠΟΥΡΓΕΙΟ ΠΑΙΔΕΙΑΣ ΚΑΙ ΠΟΛΙΤΙΣΜΟΥ ΔΙΕΥΘΥΝΣΗ ΑΝΩΤΕΡΗΣ ΚΑΙ ΑΝΩΤΑΤΗΣ ΕΚΠΑΙΔΕΥΣΗΣ ΥΠΗΡΕΣΙΑ ΕΞΕΤΑΣΕΩΝ ΠΑΓΚΥΠΡΙΕΣ ΕΞΕΤΑΣΕΙΣ 2012

ΗΜΥ 100 Εισαγωγή στην Τεχνολογία ιάλεξη 5

ΕΙΣΑΓΩΓΗ. Αρχιτεκτονική Η/Υ ΗΜΟΣ ΜΠΟΛΑΝΑΚΗΣ

Τεχνολογία Υπολογιστικών Συστηµάτων & Λειτουργικά Συστήµατα Κεφάλαιο 3

Σύγχρονες Αρχιτεκτονικές Υπολογιστών

30 min κάθε «φάση» Pipeline: Ένα παράδειγµα από.τη καθηµερινή ζωή. 1. Πλυντήριο. 2. Στεγνωτήριο. 3. ίπλωµα. 4. αποθήκευση. προσέγγιση για 4.

Βασικές Σχεδίασης Υπολογιστών Αριθμητική Μονάδα Επεξεργασίας Κεφάλαιο 10

Single Cycle Datapath. Αρχιτεκτονική Υπολογιστών. 5ο εξάμηνο ΣΗΜΜΥ ακ. έτος: Νεκ. Κοζύρης

Αρχιτεκτονική Υπολογιστών

Εφαρµογές Πληροφορικής Υπολογιστών. Κεφάλαιο 3 Το υλικό του υπολογιστή

ΑΡΧΙΤΕΚΤΟΝΙΚΗ ΥΠΟΛΟΓΙΣΤΩΝ MHXANIKO MHXANIK I O I Η/ Η Υ ΚΑΙ ΠΛΗΡΟΦΟΡΙΚΗΣ ΕΡΓΑΣΤΗΡΙΑΚΗ ΑΣΚΗΣΗ Γ. Τσιατούχας ΠΑΝΕΠΙΣΤΗΜΙΟ ΙΩΑΝΝΙΝΩΝ

Αρχιτεκτονικές Συνόλου Εντολών

; Γιατί είναι ταχύτερη η λήψη και αποκωδικοποίηση των εντολών σταθερού μήκους;

ΥΠΟΥΡΓΕΙΟ ΠΑΙΔΕΙΑΣ ΚΑΙ ΠΟΛΙΤΙΣΜΟΥ ΔΙΕΥΘΥΝΣΗ ΑΝΩΤΕΡΗΣ ΚΑΙ ΑΝΩΤΑΤΗΣ ΕΚΠΑΙΔΕΥΣΗΣ ΥΠΗΡΕΣΙΑ ΕΞΕΤΑΣΕΩΝ ΠΑΓΚΥΠΡΙΕΣ ΕΞΕΤΑΣΕΙΣ 2014

Αρχιτεκτονικές Συνόλου Εντολών (ΙΙ)

Μικροεπεξεργαστές ΑΣΚΗΣΕΙΣ ΘΕΩΡΙΑΣ. Υπεύθυνος: Δρ Άρης Παπακώστας

Ιόνιο Πανεπιστήμιο Τμήμα Πληροφορικής Αρχιτεκτονική Υπολογιστών Κρυφές Μνήμες. (οργάνωση, λειτουργία και απόδοση)

Διάλεξη 12 Καθυστερήσεις (Stalls) Εκκενώσεις Εντολών (Flushing)

Ψηφιακή Επεξεργασία Σήματος

ΗΜΥ 100 Εισαγωγή στην Τεχνολογία ιάλεξη 9

ΕΘΝΙΚΟ ΜΕΤΣΟΒΙΟ ΠΟΛΥΤΕΧΝΕΙΟ. ΑΡΧΙΤΕΚΤΟΝΙΚΗ ΥΠΟΛΟΓΙΣΤΩΝ, 5 ο εξάµηνο

Προχωρηµένα Θέµατα Αρχιτεκτονικής

Κεφάλαιο 5. Στόχοι Κεφαλάιου. Η αρχιτεκτονική von Neumann. Nell Dale John Lewis. Κεντρική Μονάδα Επεξεργασίας (ΚΜΕ/CPU)

Οργάνωση Υπολογιστών (ΙI)

ΥΠΟΥΡΓΕΙΟ ΠΑΙΔΕΙΑΣ ΚΑΙ ΠΟΛΙΤΙΣΜΟΥ ΔΙΕΥΘΥΝΣΗ ΑΝΩΤΕΡΗΣ ΚΑΙ ΑΝΩΤΑΤΗΣ ΕΚΠΑΙΔΕΥΣΗΣ ΥΠΗΡΕΣΙΑ ΕΞΕΤΑΣΕΩΝ ΠΑΓΚΥΠΡΙΕΣ ΕΞΕΤΑΣΕΙΣ 2009 ΑΠΑΝΤΗΣΕΙΣ

Chapter 2. Εντολές : Η γλώσσα του υπολογιστή. (συνέχεια) Η διασύνδεση Υλικού και λογισμικού David A. Patterson και John L.

Επεξεργαστής Υλοποίηση ενός κύκλου μηχανής

Κεφάλαιο 4 ο. Ο Προσωπικός Υπολογιστής

ΣΥΣΚΕΥΕΣ ΑΠΟΘΗΚΕΥΣΗΣ (ΜΝΗΜΗ)

ΥΠΟΥΡΓΕΙΟ ΠΑΙΔΕΙΑΣ ΚΑΙ ΠΟΛΙΤΙΣΜΟΥ ΔΙΕΥΘΥΝΣΗ ΑΝΩΤΕΡΗΣ ΚΑΙ ΑΝΩΤΑΤΗΣ ΕΚΠΑΙΔΕΥΣΗΣ ΥΠΗΡΕΣΙΑ ΕΞΕΤΑΣΕΩΝ ΠΑΓΚΥΠΡΙΕΣ ΕΞΕΤΑΣΕΙΣ 2006 ΑΠΑΝΤΗΣΕΙΣ

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

ΟΜΑΔΕΣ ΕΝΤΟΛΩΝ: ΙΔΙΟΤΗΤΕΣ ΚΑΙ ΛΕΙΤΟΥΡΓΙΕΣ

ΗΜΥ 100 Εισαγωγή στην Τεχνολογία ιάλεξη 9

Συστήματα σε Ολοκληρωμένα Κυκλώματα

Κεντρική Μονάδα Επεξεργασίας. Επανάληψη: Απόδοση ΚΜΕ. ΚΜΕ ενός κύκλου (single-cycle) Παραλληλισμός σε επίπεδο εντολών. Υπολογιστικό σύστημα

ΕΦΑΡΜΟΓΕΣ ΠΛΗΡΟΦΟΡΙΚΗΣ Α ΤΑΞΗ

ΗΛΕΚΤΡΟΝΙΚΟΙ ΥΠΟΛΟΓΙΣΤΕΣ

Βασικές Έννοιες της Πληροφορικής

Εισαγωγή στους Η/Υ και Εφαρμογές

Πληροφορική Ι. Μάθημα 6 ο Εκτέλεση πράξεων, Αρχιτεκτονική Η/Υ. Τμήμα Χρηματοοικονομικής & Ελεγκτικής ΤΕΙ Ηπείρου Παράρτημα Πρέβεζας

Εισαγωγή στους Η/Υ. Γιώργος Δημητρίου. Μάθημα 2 ο. Πανεπιστήμιο Θεσσαλίας - Τμήμα Πληροφορικής

Ειδική Επιστημονική Εργασία. Σχεδίαση και υλοποίηση Θέσεως Εργασίας ενός Εργαστηρίου DSPs από Απόσταση για Λήψη και Επεξεργασία Εικόνας

Αρχιτεκτονική υπολογιστών

Καταχωρητές & τμήματα μνήμης του Ματθές Δημήτριος Καθηγητής Πληροφορικής

ΗΜΥ 100 Εισαγωγή στην Τεχνολογία Διάλεξη 9

Ιεραρχία Μνήμης. Ιεραρχία μνήμης και τοπικότητα. Σκοπός της Ιεραρχίας Μνήμης. Κρυφές Μνήμες

ΠΑΝΕΠΙΣΤΗΜΙΟ ΚΥΠΡΟΥ ΤΜΗΜΑ ΠΛΗΡΟΦΟΡΙΚΗΣ

ΠΡΟΓΡΑΜΜΑ ΣΠΟΥ ΩΝ ΠΛΗΡΟΦΟΡΙΚΗΣ

Transcript:

ΕΣ 08 Επεξεργαστές Ψηφιακών Σηµάτων Αρχιτεκτονική Επεξεργαστών Ψ.Ε.Σ Βιβλιογραφία Ενότητας Kehtarnavaz [2005]: Chapter 3 Kuo [2005]: Chapters 1 & 4-5 Lapsley [2002]: Chapter 4 Hayes [2000]: Κεφάλαιo 8 TMS320C6000 CPU and Instruction Set Reference Guide 1

Εισαγωγή Η γενική δοµή της αρχιτεκτονικής Επεξεργαστών Ψ.Ε.Σ επιδεικνύεταιστο διπλανό σχήµα (το σχήµα αφορά τους επεξεργαστές C62x, C64x, C67x αλλά είναι ενδεικτικό): Η αρχιτεκτονική αυτή έχει σχεδιαστεί για βέλτιστη υλοποίηση της λειτουργίας FIR (Finite Impulse Response) filtering Περιλαµβάνει δύο (ένα για εντολές, ένα για δεδοµένα) ή τρεις (ένα για εντολές, δύο για δεδοµένα) διαδρόµους δεδοµένων (data buses) για εκτέλεση εντολών MAC (Multiply Accumulate) σε ένα κύκλο εντολής. Βασικά Χαρακτηριστικά Επεξεργαστών Ψ.Ε.Σ ΟιπερισσότεροιεπεξεργαστέςΨ.Ε.Σ έχουν κάποια ιδιαίτερα χαρακτηριστικά που τους καθιστούν κατάλληλους για την διεκπεραίωση αριθµητικά απαιτητικές εφαρµογές. Τα χαρακτηριστικά αυτά είναι: Υλοποίηση λειτουργιών MAC (Multiply-Accumulate) σε ένα κύκλο εντολής. Πολλοί αλγόριθµοι Ψ.Ε.Σ έχουντηδοµή FIR φιλτραρίσµατος δηλαδή υπολογίζουν ποσότητες y(n) της µορφής: x( n) y( n) = L 1 i i= 0 b x( n i) = [ b b. b ] Για την εκτέλεση MAC εντολών σε ένα κύκλο εντολής οι επεξεργαστές ακολουθούν την αρχιτεκτονική Harvard αντί την αρχιτεκτονική von Neumann που είναι περισσότερο διαδεδοµένη στους επεξεργαστές γενικού σκοπού. Στην αρχιτεκτονική αυτή υπάρχει ξεχωριστή µνήµη για το πρόγραµµα καιξεχωριστήµνήµη γιαταδεδοµένα o 1 L 1 x( n 1). x( n L + 1) 2

Βασικά Χαρακτηριστικά Επεξεργαστών Ψ.Ε.Σ (ΙΙ) Παραλληλισµός εκτέλεσης εντολών (pipelining). Εκτός από ξεχωριστή µνήµη γιαπρογράµµατα και δεδοµένα οι επεξεργαστές Ψ.Ε.Σ υποστηρίζουν και ξεχωριστούς διαδρόµους δεδοµένων για ανάκληση εντολών και δεδοµένων. Με τον τρόπο αυτό υπάρχει δυνατότητα ταυτόχρονης πρόσβασης στη µνήµη γιατηνλήψητωνδύοορισµάτων µιας αριθµητικής πράξης αλλά και την ανάκληση της επόµενης προς εκτέλεση εντολής. Modulo-N πρόσβαση στη µνήµη. Με τον τρόπο αυτό, για παράδειγµα, οι συντελεστές ενός FIR φίλτρου αποθηκεύονται σε διαδοχικά τµήµατα µνήµης και έτσι δεν χρειάζεται να υπολογίζεται κάθε φορά η διεύθυνση του επόµενου συντελεστή. Απλά έχουµε ακολουθιακή πρόσβαση. Ειδικό χειρισµός επαναληπτικών διαδικασιών (loops). Σε αρκετές περιπτώσεις υπάρχει υλοποίηση επαναληπτικών δοµών µε εξειδικευµένο υλικό. Απευθείας πρόσβαση στη µνήµη και στις περιφερειακές συσκευές. εν χρειάζεται η απασχόληση της CPU για πρόσβαση στη µνήµη καιτις συσκευές αυτές. Κύρια οµικά Στοιχεία External Memory -Sync -Async Addr Data Program RAM or Cache Internal Buses Regs (A0-A15).D1.D2.M1.M2.L1.L2.S1.S2 Control Regs CPU Data RAM Regs (B0-B15) DMA Serial Port Host Port Boot Load Timers Pwr Down 3

Κύρια οµικά Στοιχεία (ΙΙ) Κάθε εντολή απαρτίζεται από 32 bits. Ο διάδροµος προγράµµατος έχει εύρος 256 bits (32 bits διεύθυνση) Εποµένως µπορούν να µεταφερθούν και να εκτελεστούν 8 εντολές (σε συνεχόµενες διευθύνσεις µνήµης) σε ένα κύκλο ρολογιού (συχνότητα επεξεργαστή 225MHz, άρα 4.8ns διάρκεια κάθε κύκλος ρολογιού. Υπάρχουν 8 ανεξάρτητες µονάδες σε κάθε επεξεργαστή της σειράς TMS320C6xxx: -2 πολλαπλασιαστές -6 ALUs(Αριθµητική και Λογική Μονάδα) Αποδοτικός κώδικας σηµαίνει και οι 8 µονάδες να βρίσκονται διαρκώς σε εργασία. Υπάρχουν 32 συνολικά καταχωρητές στις δύο ΚΜΕ (Κεντρική Μονάδα Επεξεργασίας - Data path A and data path B) 16 σε κάθε µια (A0-A15, B0-B15) µε εύρος32 bits. Το µήκος λέξης δεδοµένων είναι 32 bit (εξαίρεση αποτελεί η σειρά επεξεργαστών C64xx στην οποία έχουµε µήκος λέξης 64 bit) ενώ πρόσβαση στη µνήµη δεδοµένων γίνεται µέσω διευθύνσεων από 32 bits (4GB συνολικός χώρος µνήµης). ιάδροµοι εδοµένων και Προγράµµατος Οι διάδροµοι δεδοµένων και προγράµµατος υποδιαιρούνται σε επιµέρους διαδρόµους ως εξής: ιάδροµος δεδοµένων ιάδροµος διεύθυνσης ανάγνωσης δεδοµένων (Data Read Address Bus), ο οποίος µεταφέρει τη διεύθυνση από την οποία θα διαβαστούν τα δεδοµένα ιάδροµος ανάγνωσης δεδοµένων (Data Read Bus), οοποίος µεταφέρει τα δεδοµένα από τη µνήµη στηκμε ιάδροµος διεύθυνσης εγγραφής δεδοµένων (Data Write Address Bus), οοποίος µεταφέρει τη διεύθυνση στην οποία θα εγγραφούν τα δεδοµένα ιάδροµος εγγραφής δεδοµένων (Data Write Address Bus), οοποίος µεταφέρει τα δεδοµένα που θα εγγραφούν στη µνήµη. ιάδροµος Προγράµµατος ιάδροµος διεύθυνσης ανάγνωσης προγράµµατος (Program Address Bus), ο οποίος µεταφέρει τη διεύθυνση από την οποία θα διαβαστούν τα δεδοµένα προγράµµατος (π.χ εντολές) ιάδροµος ανάγνωσης προγράµµατος (Program Read Bus), οοποίος µεταφέρει τα δεδοµένα προγράµµατος (π.χ εντολές) από τη µνήµη στηκμε 4

οµήεντολώνassembly Ένα πρόγραµµα σεκώδικαassembly είναι ένα αρχείο κειµένου (ASCII text file) τουοποίουκάθεγραµµή µπορεί να περιλαµβάνει έως και 7 στοιχεία: Ετικέτα (Label) Παράλληλες µπάρες (Parallel bars) Συνθήκη (Condition) Εντολή ή οδηγία (Instruction or Directive) Μονάδα εκτέλεσης (Functional unit) Ορίσµατα (Operands) Σχόλια (Comments). Ετικέτες Μια ετικέτα καθορίζει µια γραµµή κώδικα και αναπαριστά µια µεταβλητή ή διεύθυνση µνήµης η οποία περιέχει είτε µια εντολή είτε δεδοµένα Οιετικέτεςπρέπεινα ικανοποιούν τις επόµενες συνθήκες: Ο πρώτος χαρακτήρας µπορεί να είναι γράµµα ή κάτω παύλα (underscore _) ακολουθούµενη από γράµµα. Ο πρώτος χαρακτήρας πρέπει να βρίσκεται στην πρώτη στήλη του αρχείου (text file). Μπορούν να περιλαµβάνουν µέχρι 32 αλφααριθµητικούς χαρακτήρες. 5

Παράλληλες µπάρες Μια εντολή η οποία εκτελείται σε παραλληλία µε την προηγούµενη της δηλώνεται µε παράλληλες µπάρες ( ). Το σχετικό πεδίο παραµένει κενό αν η εν λόγω εντολή δεν εκτελείται παράλληλα µε την προηγούµενη της Στο συγκεκριµένο παράδειγµα οιεντολέςldh και SUB εκτελούνται παράλληλα Συνθήκη Πέντε καταχωρητές χρησιµοποιούνται για την εκτέλεση εντολών υπό συνθήκη: A1, A2, B0, B1, και B2. Αν δεν υπάρχει συνθήκη πριν από µια εντολή η εντολή εκτελείται πάντοτε. Στο συγκεκριµένο παράδειγµα ηεντολή branch (B) εκτελείται εφόσον ο καταχωρητής A2 είναι διάφορος του µηδέν 6

Εντολήήοδηγία Οι εντολές επεξεργαστή (processor mnemonics) είναι οι πραγµατικές εντολές που εκτελούνται από το πρόγραµµα. Οι οδηγίες (assembler directives) είναι εντολές προς τον συµβολοµεταφραστή (assembler) οι οποίες καθορίζουν τη διαδικασία µετατροπής σε κώδικα µηχανής και ορίζουν τις δοµές δεδοµένων (σταθερές και µεταβλητές) που χρησιµοποιούνται από το πρόγραµµα. Εντολήήοδηγία(ΙΙ) Στον επόµενο πίνακα δίνονται µερικά παραδείγµατα οδηγιών 7

Μονάδα εκτέλεσης ύο ΚΜΕ (Data Paths), 1->Α και2->β, µε τέσσερις µονάδες έκαστη: Πολλαπλασιασµός (.M1,.Μ2) Λογικές και Αριθµητικές πράξεις - ALU (.L1,.L2) ιακλάδωση, χειρισµός bit και αριθµητικές πράξεις (.S1,.S2) Ανάκληση και αποθήκευση δεδοµένων και εντολών καθώς και αριθµητικές πράξεις (.D1,.D2) Ορίσµατα Τα ορίσµατα των εντολών είναι θέσεις µνήµης ή καταχωρητές. Για τα ορίσµατα ισχύουν τα παρακάτω: Όλες οι εντολές απαιτούν ένα όρισµα προορισµού (destination operand) Οι περισσότερες εντολές έχουν ένα ή δύο ορίσµατα εισόδου Το όρισµα προορισµού πρέπει να ανήκει στην ίδια KME µε ένα τουλάχιστον από τα ορίσµατα εισόδου Ένα όρισµα εισόδου µπορεί να προέρχεται από διαφορετική ΚΜΕ στο πλαίσιο ενός µόνο Execution Packet (δηλαδή ενός συνόλου εντολών που εκτελούνται παράλληλα) 8

Assembly συναρτήσεις καλούµενες από C Τα ορίσµατα των συναρτήσεων µεταφέρονται µέσω των καταχωρητών A4, B4, A6, B6,... µε τη σειρά που δίνεται Το αποτέλεσµα της κλήσης της συνάρτησης επιστρέφεται µέσω του καταχωρητή A4. Η διεύθυνση επιστροφής από τον κώδικα στον οποίο έχει γίνει η κλήση της συνάρτησης δίνεται στον καταχωρητή B3. Οπότε πρέπει να δίνεται µεγάλη προσοχή να µην χρησιµοποιείται για άλλο σκοπό ο Β3 εντός της συνάρτησης ASSEMPLY Ονοµατολογία (βλέπε προηγ. διαφάνεια): Στον κώδικα C: label (η συνάρτηση δηλώνεται ως external) Στον κώδικα ASSEMBLY: _label (η συνάρτηση δηλώνεται ως global) Πρόσβαση σε global µεταβλητές εντός του κώδικα ASSEMBLY:.ref _variablename Σύνολο εντολών για τους επεξεργαστές TMS320C6xxx Στο διπλανό πίνακα φαίνονται οι εντολές (για αριθµητική σταθερής υποδιαστολής fixed point instructions) ASSEMBLY που µπορούν να εκτελεστούν σε κάθε µονάδα (.L,.M,.S,.D) της σειράς επεξεργαστών TMS320C6xxx. Μπορούµε να κατηγοριοποιήσουµε τις εντολές αυτές σε τρεις κατηγορίες: Αριθµητικές (Πρόσθεση / Αφαίρεση / Πολλαπλασιασµός) Παράδειγµα: ADD.L1 A3,A7,A7 ; A3+A7->A7 Ανάκλησης Αποθήκευσης Παράδειγµα: STW.D2 A1,*+A4[20] ; store A1->(A4+20) ιακλάδωσης Μετακίνησης Παράδειγµα: [A1] B.S2 Loop ; branch to Loop if A1 0 9

Floating Point Instructions Στο διπλανό πίνακα φαίνονται οι εντολές (για αριθµητική κινητής υποδιαστολής floating point instructions) ASSEMBLY που µπορούν να εκτελεστούν σε κάθε µονάδα (.L,.M,.S,.D) της σειράς επεξεργαστών TMS320C62xx και TMS320C67xx. Οι εντολές αυτές είναι κυρίως αριθµητικές δεδοµένου ότι δεν υπάρχει κάποια σηµαντική διαφορά ανάµεσα στις εντολές σταθερής και κινητής υποδιαστολής όσον αφορά την αποθήκευση και τη µετακίνηση διακλάδωση 10