Ενσωματωμένα Συστήματα



Σχετικά έγγραφα
Ενσωματωμένα Συστήματα

Εγχειρίδιο Χρήσης ΑΤ91

Ενσωματωμένα Συστήματα

Βασικά σημεία διάλεξης

Bυζαντινοί Ιστορικοί και Χρονογράφοι Ενότητα 3: Ιστοριογραφία Πρωτοβυζαντινής περιόδου Εκκλησιαστική ιστορία. Σωκράτης ο Σχολαστικός: Βίος και Έργο

Τίτλος Ειδικού Θεματικού Προγράμματος: «Διοίκηση, Οργάνωση και Πληροφορική για Μικρο-μεσαίες Επιχειρήσεις»

Παιδαγωγική ή Εκπαίδευση ΙΙ

ΔΙΑΔΟΣΗ ΘΕΡΜΟΤΗΤΑΣ Φυσική Β' Γυμνασίου. Επιμέλεια: Ιωάννης Γιαμνιαδάκης

Συνεταιριστική Οικονομία

Σειρά Ασκήσεων 3: Προσπελάσεις Μνήµης στον MIPS

ΠΑΡΟΥΣΙΑΣΗ ΤΩΝ ΓΕΝΙΚΩΝ ΚΑΙ ΕΙΔΙΚΩΝ ΟΡΩΝ ΤΟΥ ΠΡΟΓΡΑΜΜΑΤΟΣ «ΑΣΦΑΛΩΣ ΚΑΤΟΙΚΕΙΝ» ΚΟΙΝΟΧΡΗΣΤΟΙ ΧΩΡΟΙ

ΣΥΣΤΗΜΑ ΔΙΑΓΝΩΣΗΣ ΑΝΑΓΚΩΝ ΑΓΟΡΑΣ ΕΡΓΑΣΙΑΣ ΔΙΑΓΝΩΣΗ ΑΝΑΓΚΩΝ ΣΕ ΠΕΡΙΦΕΡΕΙΑΚΟ ΕΠΙΠΕΔΟ

ΗΥ 232 Οργάνωση και Σχεδίαση Υπολογιστών. Διάλεξη 2 Οργάνωση μνήμης Καταχωρητές του MIPS Εντολές του MIPS 1

Δασικά Οικοσυστήματα και Τεχνικά Έργα

ΦΙΛΟΣΟΦΙΑ ΤΟΥ ΔΙΚΑΙΟΥ. Ενότητα 7: Σχέση δικαίου-ηθικής-πολιτικής. Παρούσης Μιχαήλ. Τμήμα Φιλοσοφίας

Σεμινάριο με θέμα : Εθελοντισμός & Δικαιώματα Παιδιού

Ελληνική Δημοκρατία Τεχνολογικό Εκπαιδευτικό Ίδρυμα Ηπείρου

ΕΛΛΗΝΙΚΗ ΔΗΜΟΚΡΑΤΙΑ ΑΡΙΘΜΟΣ ΜΕΛΕΤΗΣ: 58/ 2014 ΝΟΜΟΣ ΘΕΣΠΡΩΤΙΑΣ ΔΗΜΟΣ ΗΓΟΥΜΕΝΙΤΣΑΣ Δ/ΝΣΗ ΤΕΧΝΙΚΩΝ ΥΠΗΡΕΣΙΩΝ ΜΕΛΕΤΗ

1 Επιμέλεια: Γράβαλος Βασίλειος, Χρυσανθάκης Ιωάννης

Χρηματοδότηση των Συλλόγων στην εποχή της κρίσης

Η Αγορά Ηλεκτρικής Ενέργειας στην Κύπρο έχει οργανωθεί σε τομείς που υπόκεινται στις ακόλουθες ρυθμίσεις:

Πρόγραμμα Σπουδών για το "Νέο Σχολείο"

Συνοπτική Παρουσίαση. Ελλάδα

Το Βαρόμετρο του Παρατηρητηρίου: Ποιότητα των Δημόσιων Υπηρεσιών προς Επιχειρήσεις

ΑΝΑΠΤΥΞΗ ΕΦΑΡΜΟΓΩΝ Κεφάλαιο 3 ο

ΕΦΑΡΜΟΣΜΕΝΗ ΗΘΙΚΗ. Ενότητα 3: Το παράδειγμα της Τρέισι Λάτιμερ (συνέχεια) Παρούσης Μιχαήλ. Τμήμα Φιλοσοφίας

Σηµειώσεις στο ταξινοµούµε

ΕΜΠΕΔΩΣΗ ΒΑΣΙΚΕΣ ΑΡΧΕΣ ΚΑΛΕΣ ΠΡΑΚΤΙΚΕΣ. Δρ Μάριος Στυλιανίδης, ΕΔΕ

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

Θεματική Ενότητα: ΠΑΙΔΕΙΑ ΠΟΛΙΤΙΣΜΟΣ - ΑΘΛΗΤΙΣΜΟΣ

Ο αθλητισμός εμπνέεται από την ειρήνη. Η ειρήνη εμπνέεται από τον αθλητισμό.

ΕΦΑΡΜΟΣΜΕΝΗ ΗΘΙΚΗ. Ενότητα 10: Φιλοσοφική Συμβουλευτική. Παρούσης Μιχαήλ. Τμήμα Φιλοσοφίας

ΚΩΔΙΚΑΣ ΔΕΟΝΤΟΛΟΓΙΑΣ

ΟΡΓΑΝΩΣΗ ΕΝΟΤΗΤΩΝ Α ΤΑΞΗΣ ΕΝΟΤΗΤΑ 3

Πρακτικό 6/2012 της συνεδρίασης της Επιτροπής Ποιότητας Ζωής, του Δήμου Λήμνου, της 4ης Μαΐου 2012.

Τεχνικό Τοπογραφικό Σχέδιο

Ευρετήριο πινάκων. Ασκήσεις και υπομνήματα

ΝΕΑ ΧΡΗΜΑΤΟΟΙΚΟΝΟΜΙΚΑ ΠΡΟΪΟΝΤΑ- ΕΦΑΡΜΟΓΗ ΣΕ ΑΣΦΑΛΙΣΤΙΚΗ ΕΠΙΧΕΙΡΗΣΗ

«Αναδιάρθρωση της καλλιέργειας του καπνού µε άλλες ανταγωνιστικές καλλιέργειες»

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

Το ολοκαύτωμα της Κάσου

Προδημοσιεύτηκαν τα τέσσερις πρώτα προγράμματα του νέου ΕΣΠΑ που αφορούν

Οι ιοί και οι ιογενείς λοιμώξεις του αναπνευστικού συστήματος στα παιδιά

1. Εισαγωγή. 2. Καταπολέμηση της φοροδιαφυγής

ΠΡΟΒΛΗΜΑΤΑ ΤΗΣ ΔΗΜΟΣΙΑΣ ΖΩΗΣ, ΜΙΑ ΨΥΧΑΝΑΛΥΤΙΚΗ ΠΡΟΣΕΓΓΙΣΗ

ΣΥΝΤΟΝΙΣΤΕΣ ΟΜΑΔΑΣ PROJECT ΑΝΘΡΩΠΙΣΤΙΚΕΣ ΕΠΙΣΤΗΜΕΣ: ΟΜΑΔΑ PROJECT ΑΝΘΡΩΠΙΣΤΙΚΕΣ ΕΠΙΣΤΗΜΕΣ:

Εσωτερικοί Κανονισμοί Τοπικής Αυτοδιοίκησης

ΕΙΣΑΓΩΓΗ ΣΤΗΝ ΚΟΣΤΟΛΟΓΗΣΗ ΚΑΙ ΤΗΝ ΑΝΑΛΥΤΙΚΗ ΛΟΓΙΣΤΙΚΗ

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

ΚΕΦ. 1 Η ΛΟΓΙΣΤΙΚΗ ΚΑΙ Η ΣΗΜΑΣΙΑ ΤΗΣ ΣΤΙΣ ΕΠΙΧΕΙΡΗΣΕΙΣ

"ΤΟ ΞΥΛΟ ΣΤΙΣ ΔΟΜΙΚΕΣ ΚΑΤΑΣΚΕΥΕΣ: ΘΕΜΑΤΑ ΥΓΡΑΣΙΑΣ ΚΑΙ ΑΝΙΣΟΤΡΟΠΙΑΣ, ΒΕΛΤΙΣΤΗ ΧΡΗΣΗ ΚΑΙ ΜΕΤΡΑ ΠΡΟΣΤΑΣΙΑΣ ΤΩΝ ΞΥΛΙΝΩΝ ΚΑΤΑΣΚΕΥΩΝ A

ΣΤΗΝ ΤΡΟΙΖΗΝΙΑ ΑΠΟ ΑΓ.ΕΛΕΝΗ ΕΩΣ ΤΟΝ ΚΟΜΒΟ ΚΑΛΛΟΝΗΣ ΚΑΙ ΣΤΗΝ ΠΑΡΑΛΙΑ ΤΟΥ ΑΡΤΙΜΟΥ. ΤΙΜΟΛΟΓΙΟ ΜΕΛΕΤΗΣ Τιμαριθμική 2012Α


ΤΙΜΟΛΟΓΙΟ ΜΕΛΕΤΗΣ ΓΕΝΙΚΟΙ ΟΡΟΙ

ΑΝΟΙΚΤΗ ΠΡΟΣΚΛΗΣΗ ΓΙΑ ΤΗ ΣΥΓΓΡΑΦΗ ΑΚΑΔΗΜΑΪΚΩΝ ΗΛΕΚΤΡΟΝΙΚΩΝ ΣΥΓΓΡΑΜΜΑΤΩΝ ΚΑΙ ΒΟΗΘΗΜΑΤΩΝ

Η ΔΙΑΘΕΜΑΤΙΚΗ ΤΗΣ ΔΙΑΘΕΜΑΤΙΚΗΣ

ΚΩ ΙΚΑΣ ΕΟΝΤΟΛΟΓΙΑΣ ΤΗΣ ΕΤΑΙΡΕΙΑΣ ΜΕ ΤΗΝ ΕΠΩΝΥΜΙΑ «ΠΑΠΟΥΤΣΑΝΗΣ ΑΝΩΝΥΜΗ ΒΙΟΜΗΧΑΝΙΚΗ ΚΑΙ ΕΜΠΟΡΙΚΗ ΕΤΑΙΡΕΙΑ ΚΑΤΑΝΑΛΩΤΙΚΩΝ ΑΓΑΘΩΝ»

Χημεία Β Γυμνασίου Τμήμα Β3. Γρηγόρης Μαγουλάς Φανή Μανούσου Κύρος Μαλλαμίδης Ελίνα Μάλλιαρη Μάγδα Μαντά

Ατομικό ιστορικό νηπίου

03-00: Βιομάζα για παραγωγή ενέργειας Γενικά ζητήματα εφοδιαστικών αλυσίδων

11. Προϋπολογισμός Προϋπολογισμός και αποδοτικότητα δημοσίων υπηρεσιών: υφιστάμενη κατάσταση

ΒΑΣΙΚΗ ΕΚΠΑΙΔΕΥΣΗ. Οδηγός Οργάνωσης και Λειτουργίας ΕΚΔΟΣΗ 1.0

Εθνικό και Καποδιστριακό Πανεπιστήμιο Αθηνών

Σχολικός εκφοβισµός και γονείς

«ΑΝΩ ΛΙΟΣΙΑ: ΤΟΠΙΚΗ ΙΣΤΟΡΙΑ, ΠΕΡΙΒΑΛΛΟΝ, ΠΡΟΚΛΗΣΕΙΣ, ΠΡΟΟΠΤΙΚΕΣ»

ΤΕΙ ΚΕΝΤΡΙΚΗΣ ΜΑΚΕΔΟΝΙΑΣ ΣΧΟΛΗ ΔΙΟΙΚΗΣΗΣ ΚΑΙ ΟΙΚΟΝΟΜΙΑΣ ΤΜΗΜΑ ΛΟΓΙΣΤΙΚΗΣ ΚΑΙ ΧΡΗΜΑΤΟΟΙΚΟΝΟΜΙΚΗΣ

ΙΕΘΝΗΣ ΣΥΜΒΑΣΗ ΕΡΓΑΣΙΑΣ 183 «για την αναθεώρηση της (αναθεωρηµένης) σύµβασης για την προστασία της µητρότητας,»

Τεχνολογική Οικονομική & Μεθοδολογία Εκπόνησης Οικονομοτεχνικών Μελετών. 1. Εισαγωγή στην Τεχνολογική Οικονομική & τη. Δρ.

ΓΙΑ ΤΗΝ ΕΞΟΔΟ ΑΠΟ ΤΗΝ ΕΥΡΩΖΩΝΗ ΣΤΟ ΔΗΜΟΨΗΦΙΣΜΑ ΨΗΦΙΖΟΥΜΕ ΕΡΩΤΗΣΕΙΣ & ΑΠΑΝΤΗΣΕΙΣ ΟΧΙ ΜΕΧΡΙ ΤΕΛΟΥΣ. Αριστερή Αντικαπιταλιστική Συσπείρωση (ΑΡ.Α.Σ.

1.1 ΓΡΑΜΜΙΚΑ ΣΥΣΤΗΜΑΤΑ

Αξιολόγηση Προγράμματος Αλφαβητισμού στο Γυμνάσιο Τρίτο Έτος Αξιολόγησης

ΠΕΡΙΦΕΡΕΙΑΚΗ ΕΦΟΡΕΙΑ ΑΘΗΝΩΝ. Αθήνα, 19 Ιανουαρίου 2015 Α ΝΑΚΟΙΝΩΣΗ 3/15. ΠΡΟΣ : Όλους τους Βαθμοφόρους της Αθήνας ΚΟΙΝΟΠΟΙΗΣΗ :

Ιστορία του Αραβοϊσλαμικού Πολιτισμού

ΠΤΥΧΙΑΚΗ ΕΡΓΑΣΙΑ Πρώτες βοήθειες και αντιλήψεις του πληθυσμού στους Νομούς Χανίων, Ηρακλείου, Λασιθίου και Μεσσηνίας

Γνωρίζω, Αγαπώ & Φροντίζω το Σώμα μου

Βασικές Έννοιες και Μέθοδοι της Οικονομικής Επιστήμης - Οικονομία (< οίκος + νέμω): Διαχείριση των Υποθέσεων ενός Νοικοκυριού - Γενικός Ορισμός: Μια

3o ΓΕΝΙΚΟ ΛΥΚΕΙΟ ΗΡΑΚΛΕΙΟΥ σχολ. Έτος

Πρώτη διδακτική πρόταση Χρωματίζοντας ένα σκίτσο

ΔΕΛΤΙΟ ΤΥΠΟΥ ΥΠΟΥΡΓΕΙΟ ΟΙΚΟΝΟΜΙΚΩΝ. ΟΔΙΚΑ ΤΡΟΧΑΙΑ ΑΤΥΧΗΜΑΤΑ: Οκτώβριος 2009 ΕΛΛΗΝΙΚΗ ΔΗΜΟΚΡΑΤΙΑ. Μείωση των Οδικών Τροχαίων ατυχημάτων κατά 14,3%

ΠΕΡΙΛΗΨΗ ΤΟΥ ΠΑΙΧΝΙΔΙΟΥ

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

στήλη υγιεινολόγων στόματος

Αρχαίο ελληνικό δράμα: Ευριπίδης

αρχαιολόγος- μουσειολόγος- ξεναγός, ΜΑ

Α. Πολιτιστικοί φορείς Πλήθος φορέων Έδρα Γεωγραφική κατανομή φορέων Νομική μορφή Έτος ίδρυσης...

Έρευνα Καταναλωτικής Εμπιστοσύνης

«Ειρήνη» Σημειώσεις για εκπαιδευτικούς

Συνωμοσία Πυρήνων της Φωτιάς - Πυρήνας Αντάρτικου Πόλης

ΠΕΡΙΕΧΟΜΕΝΑ ΕΙΣΑΓΩΓΙΚΟ ΣΗΜΕΙΩΜΑ 13 Α' ΜΕΡΟΣ ΑΠΟ ΤΟΝ ΠΟΛΕΜΟ ΤΟΥ 1897 ΣΤΟ ΓΟΥΔΙ

Δημήτρης Αγοραστός Ψυχολόγος

ΟΜΙΛΙΑ ΠΡΟΕΔΡΟΥ Ο.Κ.Ε. κ. Χ. ΠΟΛΥΖΩΓΟΠΟΥΛΟΥ

Συνδυάζοντας λογικές προτάσεις

«ΧΡΗΣΕΙΣ ΒΙΟΜΑΖΑΣ ΓΙΑ ΘΕΡΜΑΝΣΗ»

Δρ.ΠΟΛΥΚΑΡΠΟΣ ΕΥΡΙΠΙΔΟΥ

Σε ποιες κατηγορίες μειώνεται η σύνταξη από 1/1/2009 (σε εφαρμογή του Ν.3655/2008)

Τα πέντε κριτήρια που πρέπει να ικανοποιεί ένας αλγόριθμος είναι:

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

ΟΣΤΑ & ΣΚΕΛΕΤΙΚΟ ΣΥΣΤΗΜΑ

Κεφάλαιο Πέμπτο Εθνοπολιτισμική Ζωή και Εμπειρίες Ελληνικότητας των Ελληνοαυστραλών Εφήβων

Transcript:

Τµήµα Μηχανικών Πληροφορικής & Τηλεπικοινωνιών Ενσωματωμένα Συστήματα Ενότητα4:Επεξεργαστές & Σύνολα Εντολών. Κεντρικές Μονάδες Επεξεργασίας. Εισαγωγή στην αρχιτεκτονική ARM. Δρ. Μηνάς Δασυγένης mdasyg@ieee.org Εργαστήριο Ψηφιακών Συστημάτων και Αρχιτεκτονικής Υπολογιστών http://arch.icte.uowm.gr/mdasyg

Άδειες Χρήσης Το παρόν εκπαιδευτικό υλικό υπόκειται σεάδειες χρήσης Creative Commons. Για εκπαιδευτικό υλικό, όπως εικόνες, που υπόκειται σε άλλου τύπου άδειας χρήσης, η άδεια χρήσης αναφέρεται ρητώς. 2

Χρηματοδότηση Το παρόν εκπαιδευτικό υλικό έχει αναπτυχθεί στα πλαίσια του εκπαιδευτικού έργου του διδάσκοντα. Το έργο «Ανοικτά Ψηφιακά Μαθήματα στο Πανεπιστήμιο Δυτικής Μακεδονίας» έχει χρηματοδοτήσει μόνο τη αναδιαμόρφωση του εκπαιδευτικού υλικού. Το έργο υλοποιείται στο πλαίσιο του Επιχειρησιακού Προγράμματος «Εκπαίδευση και Δια Βίου Μάθηση» και συγχρηματοδοτείται από την Ευρωπαϊκή Ένωση (Ευρωπαϊκό Κοινωνικό Ταμείο) και από εθνικούς πόρους. 3

Σκοπός ενότητας Η παρουσίαση της δημοφιλούς αρχιτεκτονικής ΑΡΜ. Η εισαγωγική περιγραφή της ARM ISA. 4

Σύνολα εντολών (ISA) Χρησιμοποιούνται για την ταξινόμηση στην Αρχιτεκτονική Υπολογιστών. Σημαντικό στοιχείο: Γλώσσα Assembly. ISA: Διασύνδεση (interface) του προγραμματιστή με το υλικό. Αν και ο προγραμματισμός γίνεται σε υψηλού επιπέδου γλώσσες, το σύνολο εντολών είναι το κλειδί στην ανάλυση της απόδοσης. 5

Αρχιτεκτονική von Neumann(1) H μνήμη διατηρεί τα δεδομένα & τις οδηγίες. Κεντρική μονάδα επεξεργασίας (CPU) ανακαλεί εντολές από τη μνήμη. Ξεχωριστή CPU και μνήμη: ξεχωρίζει έναν υπολογιστή που μπορούμε να προγραμματίσουμε. Οι CPU καταχωρητές υποστηρίζουν: μετρητή προγράμματος (PC), καταχωρητή εντολών (IR), γενικού σκοπού καταχωρητές, κ.α.. Von Neuman: Η ίδια μνήμη φυλάσσει και δεδομένα και εντολές. 6

Αρχιτεκτονική von Neumann(2) Βασικό στοιχείο της αρχιτεκτονικής von neumann είναι ένας καταχωρητής, που ονομάζεται Μετρητής Προγράμματος (Program Counter). Ο μετρητής προγράμματος δεν καθορίζει άμεσα τι κάνει η μηχανή, αλλά έμμεσα με την κατάδειξη μιας εντολής στη μνήμη. Αυτός είναι ο διαχωρισμός ενός υπολογιστή αποθηκευμένου προγράμματος (stored program computer) από μια γενική μηχανή πεπερασμένων καταστάσεων (finite state machine). 7

CPU + memory(1) 8

CPU + memory(2) 9

CPU + memory(3) 10

Αρχιτεκτονική Harvard Εναλλακτικό στυλ του Von Neuman. Δυο ξεχωριστές μνήμες, μια για τις εντολές και μια για τα δεδομένα. Είναι δύσκολη η εγγραφή αυτοτροποποιούμενων προγραμμάτων. 11

von Neumann vs. Harvard Η Harvard δεν μπορεί να χρησιμοποιήσει αυτότροποποιούμενο κώδικα. Η Harvard επιτρέπει δύο ταυτόχρονες προσκομίσεις από τη μνήμη. Οι περισσότερες DSPs χρησιμοποιούν Harvard αρχιτεκτονική για συνεχή ροή δεδομένων : μεγαλύτερο εύρος ζώνης της μνήμης. πιο προβλέψιμο εύρος ζώνης (μετακίνηση δεδομένων στους κατάλληλους συγχρονισμένους χρόνους). 12

RISC vs. CISC Πολύπλοκο σετ εντολών υπολογιστή (CISC): Πρώιμες αρχιτεκτονικές. Πολλοί τρόποι διευθυνσιοδότησης. Πολλές λειτουργίες (π.χ. Αναζήτηση συμβολοσειράς). Μειωμένο σετ εντολών υπολογιστή (RISC): Εξέλιξη στην αρχιτεκτονική υπολογιστών. Φόρτωση /αποθήκευση. Διασωληνωμένες οδηγίες. Αρχικά οι RISC είχαν πολύ μεγαλύτερη ταχύτητα από CISC. Χρησιμοποιήθηκαν τεχνικές RISC σε CISC, οπότε το χάσμα απόδοσης έχει μικρύνει. 13

Χαρακτηριστικά των εντολών Σταθερού ή μεταβλητού μήκους. Τρόποι Διευθυνσιοδότησης. Αριθμός τελεστών. Τύποι τελεστών. 14

Μοντέλο προγραμματισμού Μοντέλο προγραμματισμού: καταχωρητές ορατοί στον προγραμματιστή. Ορισμένοι καταχωρητές δεν είναι ορατοί (π.χ. IR). Ένας επεξεργαστής έχει πληθώρα καταχωρητών. Κάποιοι καταχωρητές είναι ορατοί στο χρήστη και κάποιοι είναι αόρατοι. 15

Πολλαπλές υλοποιήσεις Επιτυχείς αρχιτεκτονικές έχουν αρκετές υλοποιήσεις, ως προς: ποικίλες ταχύτητες ρολογιού, διαφορετικό πλάτος διαύλου, διαφορετικά μεγέθη μνήμης cache, κ.α. Η ίδια αρχιτεκτονική επεξεργαστή μπορεί να υλοποιηθεί με αρκετές διαφοροποιήσεις! 16

Γλώσσα Assembly Συμβολικά ονόματα assembly-προς-μια-εντολή που εκτελείται. Βασικά χαρακτηριστικά: Μία εντολή ανά γραμμή. Οι ετικέτες παρέχουν τα ονόματα για τις διευθύνσεις (συνήθως στην πρώτη στήλη). Οι οδηγίες συχνά ξεκινούν στις μετέπειτα στήλες. 17

Παράδειγμα ARM assembly Label1 ADR r4,c LDR r0,[r4] ; a comment ADR r4,d LDR r1,[r4] SUB r0,r0,r1 ; comment Ο τρόπος που γράφεται η συμβολική γλώσσα οφείλεται στους πρώτους συμβολομετραφραστές που και αυτοί είχαν γραφτεί στη συμβολική γλώσσα και έπρεπε να χωρούν σε μια πολύ μικρή ποσότητα μνήμης. 18

Ψευδό-λειτουργίες Ορισμένες οδηγίες assembler δεν αντιστοιχούν άμεσα σε οδηγίες. Παραδείγματα: Ορισμός τρέχουσας διεύθυνσης. Κράτηση θέσης μνήμης για μεταβλητές. Σταθερές. Ψευδολειτουργίες που βοηθούν τους προγραμματιστές να δημιουργούν ολοκληρωμένα προγράμματα συμβολικής γλώσσας. 19

Επεξεργαστές ARM 20

Ο πρώτος 64bit επεξεργαστής ARM -ATLAS (@2014) 21

Η χρήση του ARM στις φορητές συσκευές 22

Η αποδοτικότητα του ARM 64bit 23

Η δημοφιλής αρχιτεκτονική Texas Instruments OMAP 4(1/3) 24

Η δημοφιλής αρχιτεκτονική Texas Instruments OMAP 4(2/3) Σχεδιασμένο για να χρησιμοποιηθεί σε smartphones, ταμπλέτες και άλλες κινητές συσκευές πλούσιες σε πολυμέσα. Οι επιταχυντές υλικού IVA 3 επιτρέπουν την πλήρη προβολή HD 1080p, πολυ-πρότυπων βίντεο (κωδικοποίηση / αποκωδικοποίηση). Ταχύτερη, υψηλότερη ποιότητα εικόνας και καταγραφής βίντεο με την ψηφιακή φωτογραφική μηχανή SLR απεικόνισης έως και 20 megapixels. 25

Η δημοφιλής αρχιτεκτονική Texas Instruments OMAP 4(3/3) Dual-core ARM Cortex -A9 MPCore με συμμετρική πολυεπεξεργασία (SMP). Ο ενσωματωμένος PowerVR SGX540 επιταχυντής γραφικών πραγματοποιεί 3D gaming και 3D user διασυνδέσεις. Ιδιαίτερα βελτιστοποιημένη κινητή πλατφόρμα εφαρμογών. H OMAP4430 λειτουργεί μέχρι και 1 Ghz. H OMAP4460 λειτουργεί μέχρι και 1.5 Ghz. 26

Γενικά Στοιχεία Ο ARM είναι RISC επεξεργαστής. Χρησιμοποιείται για μικρές σε μέγεθος και υψηλής σε απόδοση, εφαρμογές. Η αρχιτεκτονική του είναι απλή και οδηγεί σε μικρές υλοποιήσεις με χαμηλή κατανάλωση ισχύος. 27

Ιστορικά Στοιχεία (1/2) 28

Ιστορικά Στοιχεία (2/2) 29

Ιστορία της αρχιτεκτονικής ARM(1) 30

Ιστορία της αρχιτεκτονικής ARM(2) "Application" profile: Cortex-A series. "Real-time" profile: Cortex-R series. "Microcontroller" profile: Cortex-M series. 31

Η εταιρία ARM ARM (UK Company): Επιχειρηματικό Μοντέλο: Έκδοση αδειών για την χρήση της αρχιτεκτονικής ARM IP. Άδεια υλοποίησης: Soft core (μπορεί να χρησιμοποιηθεί για οποιαδήποτε διαδικασία, αλλά όχι βελτιστοποιημένη). Hard core (βελτιστοποιημένη για ειδική παραγωγική διαδικασία). Άδεια Αρχιτεκτονικής: Άλλες εταιρίες παράγουν πυρήνες συμβατούς με ARM ISA. 95% των ενσωματωμένων επεξεργαστών που πωλούνται είναι ARM! Windows RT (~windows 8) supports ARM 32

Η ARM προσπάθησε να σχεδιάσει Acorn Archimedes. Περιορισμένη επιτυχία. Ακόμα κι αν ήταν ταχύτερο από τη Motorola 68000, απέτυχε εξαιτίας του IBM PC. κάποτε το δικό της PC.. 33

Η ARM κυριαρχεί στην αγορά ολοκληρωμένων συστημάτων Από το 2009, οι επεξεργαστές ARM αντιπροσωπεύουν περίπου το 90% του συνόλου ενσωματωμένων 32-bit επεξεργαστών RISC και χρησιμοποιούνται ευρέως στα καταναλωτικά ηλεκτρονικά προϊόντα, συμπεριλαμβανομένων των : personal digital assistants (PDAs), tablets, κινητά τηλέφωνα, ψηφιακών πολυμέσων και συσκευές αναπαραγωγής μουσικής, φορητές κονσόλες παιχνιδιών, αριθμομηχανές και περιφερειακά υπολογιστών, όπως σκληρούς δίσκους και δρομολογητές. 34

Γενικά για τον ARM (1/2) 35

Ένα τυπικό τσιπ ARM αποτελείται από: Ελεγκτές Περιφερειακών. Ψηφιακό επεξεργαστή σήματος. Ενσωματωμένο chip μνήμης. Επεξεργαστή ARM. 36

Γενικά (2/2) 37

Πλεονεκτήματα ARM Μικρό μέγεθος (# τρανζίστορ). Ελάχιστη κατανάλωση ενέργειας. Εξαιρετικά αρθρωτή αρχιτεκτονική (εύκολο να οικοδομηθούν υλοποιήσεις που βασίζονται σε συγκεκριμένους ARM επεξεργαστές, το μόνο υποχρεωτικό στοιχείο είναι σταθερή διασωλήνωση MMU, cache, FPU είναι προαιρετικά). High Performance (e.g. PXA255 Xscale @ 400Mhz ίδια απόδοση με Pentium 2@300Mhz, με το 1/50 της κατανάλωσης ενέργειας). 38

Εκδόσεις ARM Η ARM αρχιτεκτονική έχει επεκταθεί σε διάφορες εκδόσεις. Θα επικεντρωθούμε στην ARM7. Οικογένεια επεξεργαστών RISC. Η ΑRM δεν κατασκευάζει τα τσιπ (fabless). Χορηγεί άδειες για την αρχιτεκτονική σε άλλες εταιρίες. 32bit word length. ARM7 Von Neumann. ARM9 Harvard. H διαφορά είναι: 39

ARM είναι μια RISC CPU RISC CPU. Load-store αρχιτεκτονική (λειτουργίες μόνο από και προς τους καταχωρητές). Δεν υπάρχει υποστήριξη για μη ευθυγραμμισμένες προσπελάσεις μνήμης. Ενιαίο 16 Χ 32-bit αρχείο καταχωρητών. Οδηγίες: 32bit (οι περισσότερες με 3 τελεστές κωδικοποίησης), για να διευκολύνει την αποκωδικοποίηση και τη διασωλήνωση, με το κόστος της μειωμένης πυκνότητας κώδικα. Κυρίως εκτέλεση μονού κύκλου. Πολύ καλή διασωλήνωση. 40

ARM is a RISC CPU Απλός σχεδιασμός: Δεν χρησιμοποιεί τους καταχωρητές παραθύρου / μετονομασίας όπως οι άλλοι RISC. Αυτόματη δεικτοδότηση (αυτόματη αύξηση/μείωση σε 2 κύκλους πρόσβασης μνήμης). Πολλαπλές οδηγίες μεταφοράς καταχωρητών (φόρτωση / αποθήκευση έως και 16 καταχωρητές ταυτόχρονα ---όχι 1 κύκλο/εντολή). Υπό όρους εκτέλεση των περισσότερων εντολών, μείωση της επιβάρυνσης διακλάδωσης και την αντιστάθμιση για την έλλειψη πρόβλεψης διακλαδώσεων. 32-bit ολισθητής βαρελιού ( ολισθαίνει μια λέξη δεδομένων κατά ένα συγκεκριμένο αριθμό bits σε ένα κύκλο ρολογιού). 41

Γλώσσα assembly στους ARM Αρκετά τυπική συμβολική γλώσσα: LDR r0,[r8] ; a comment Label ADD r4,r0,r1 42

Καταχωρητές 32 καταχωρητές γενικής χρήσης. Ο ARM μπορεί να λειτουργήσει σε διάφορές καταστάσεις λειτουργίας. Σε κάθε λειτουργία είναι ορατοί διαφορετικοί καταχωρητές. 43

Οι ορατοί καταχωρητές στον ARM 44

Μοντέλο προγραμματισμού σε ARM 45

Οργάνωση μνήμης 46

Endianness Η σχέση μεταξύ bit και byte/word ordering προσδιορίζει το endianness: 47

Οι τύποι δεδομένων του ARM Η λέξη έχει μήκος 32 bit. Η λέξη μπορεί να διαιρεθεί σε τέσσερα 8-bit (bytes). Οι ARM διευθύνσεις έχουν 32bits μέγεθος. Η διεύθυνση αναφέρεται σε byte. π.χ. η διεύθυνση 4 αρχίζει στο byte 4. Μπορεί να διαμορφωθεί στην έναρξη, είτε ως bigείτε ως little-endian. 48

Τα bit κατάστασης του ARM Κάθε αριθμητική, λογική, ή αλλαγή λειτουργίας καθορίζει τα CPSR bits: N (αρνητικό), Z (μηδέν), C (carry), V (overflow). Παράδειγμα: -1 + 1 = 0: NZCV = 0110. 2 31-1+1 = -2 31 : NZCV = 0101. 49

Οι εντολές δεδομένων του ARM Βασική μορφή: ADD r0,r1,r2 Computes r1+r2, stores in r0. Άμεσος τελεστής(άμεσοι τελεστέοι): ADD r0,r1,#2 r1+2 και αποθήκευση στο r0. 50

Εντολές Τρεις κατηγορίες εντολών Επεξεργασία δεδομένων. Μεταφορά δεδομένων. Ροή ελέγχου. 51

Λειτουργία επιτήρησης Στο user mode τις διαδικασίες έξω από αυτό τις αναλαμβάνει αποκλειστικά το λειτουργικό σύστημα. Με supervisor calls, ο χρήστης περνά στο system level έχοντας τη δυνατότητα να επηρεάζει λειτουργίες του συστήματος. 52

I/O System Ο ARM χειρίζεται τα περιφερειακά ως συσκευές αντιστοιχισμένες στη μνήμη με support καταχωρητές. Καταχωρητές: IRQ : Απλοί καταχωρητές. FIQ : Γρήγοροι καταχωρητές. 53

Εξαιρέσεις Εξαιρέσεις: Καταχωρητές. Κλήση supervisor. Παγίδες. Όταν συμβαίνει εξαίρεση: Ο PC αντιγράφεται στον r14_exc. Αλλάζει τον τρόπο λειτουργίας στην αντίστοιχη λειτουργία εξαίρεσης. O PC παίρνει την τιμή vector address, οι οποία περιέχει τη διεύθυνση του handler. 54

Εντολές Επεξεργασίας Δεδομένων (1/2) Αριθμητικές λειτουργίες: ADD r0, r1, r2 ; r0 := r1 + r2. Λογικές Λειτουργίες: AND r0, r1, r2 ; r0 := r1 AND r2. Μετακίνηση Καταχωρητών: MOV r0, r2. Σύγκριση: CMP r1, r2. 55

Τελεστές: Εντολές Επεξεργασίας Δεδομένων (2/2) Άμεσοι τελεστές: ADD r3, r3, #1. Τελεστές μητρώου με ολίσθηση: ADD r3, r2, r1, LSL #3. Άλλες οδηγίες επεξεργασίας δεδομένων. Πολλαπλασιασμός: MUL r4, r3, r2. 56

ARM Εντολές δεδομένων ADD, ADC : add (w. carry). SUB, SBC : subtract (w. carry). RSB, RSC : reverse subtract (w. carry). MUL, MLA : multiply (and accumulate). AND, ORR, EOR. BIC : bit clear. LSL, LSR : logical shift left/right. ASL, ASR : arithmetic shift left/right. ROR : rotate right. RRX : rotate right extended with C. 57

Διάφορες Λειτουργίες Δεδομένων Λογική ολίσθηση: Συμπληρώνει με 0. Αριθμητική ολίσθηση: Συμπληρώνει με 1. RRX εκτελεί 33-bit περιστροφή, περιλαμβάνει το C bit από CPSR πάνω μετά το sign bit. 58

Εντολές για τη μεταφορά δεδομένων Φόρτωσε και αποθήκευσε: LDRr0,[r1]. STRr0,[r1]. Offset:LDRr0,[r1,#4] Pre-indexed: LDR r0,[r1],#16 Auto-indexed: LDR r0,[r1,#16]! Πολλαπλές μεταφορές δεδομένων: LDMIAr1,{r0,r2,r5}. 2 modes:(a) Single Register Transfer(b) Multiple register transfer. 59

Εντολές για τον έλεγχο της ροής Εντολές Διακλάδωσης: Β <ετικέτα>. Υπό όρους διακλάδωση: ΒΝΕ <ετικέτα>. Διακλάδωση και Σύνδεση: ΒL <ετικέτα>. 60

ARM εντολές σύγκρισης CMP: σύγκριση. CMN: αρνητική σύγκριση. TST: λογική επεξεργασία δοκιμής. TEQ: λογική επεξεργασία αρνητικής δοκιμής. Οι οδηγίες αυτές καθορίζουν τα NZCV bits του CPSR. 61

ARM μετακίνηση εντολών MOV, MVN : move (negated): MOV r0, r1 ; sets r0 to r1. 62

ARM οδηγίες load/store LDR, LDRH, LDRB: load (half-word, byte). STR, STRH, STRB: store (half-word, byte). Τρόποι διευθυνσιοδότησης: Άμεσος καταχωρητής: LDR r0, [r1]. Με δεύτερο καταχωρητή: LDR r0, [r1,-r2]. Με σταθερά: LDR r0, [r1,#4]. 63

ARM ADR ψευδό-πράξεις Δεν μπορούν να αναφερθούν σε μια διεύθυνση άμεσα μέσα σε εντολές. Δημιουργία της νέας τιμής με την εκτέλεση αριθμητικών πράξεων στο PC. Οι ADR ψευδό-πράξεις δημιουργούν εντολές που απαιτούνται για τον υπολογισμό διεύθυνσης: ADR r1,foo. 64

C: Παράδειγμα: C αναθέσεις (1/2) x = (a + b) -c; Assembler: ADR r4,a ; get address for a LDR r0,[r4] ; get value of a ADR r4,b ; get address for b, reusing r4 LDR r1,[r4] ; get value of b ADD r3,r0,r1 ; compute a+b ADR r4,c ; get address for c LDR r2,[r4] ; get value of c 65

C αναθέσεις, συνέχεια SUB r3,r3,r2 ; complete computation of x ADR r4,x STR r3,[r4] ; get address for x ; store value of x 66

C: Παράδειγμα: C αναθέσεις (2/2) y = a*(b+c); Assembler: ADR r4,b ; get address for b LDR r0,[r4] ; get value of b ADR r4,c ; get address for c LDR r1,[r4] ; get value of c ADD r2,r0,r1 ; compute partial result ADR r4,a ; get address for a LDR r0,[r4] ; get value of a 67

C αναθέσεις συνέχεια.. MUL r2,r2,r0 ; compute final value for y ADR r4,y ; get address for y STR r2,[r4] ; store y 68

C: Παράδειγμα: C αναθέσεις z = (a << 2) (b & 15); Assembler: ADR r4,a ; get address for a LDR r0,[r4] ; get value of a MOV r0,r0,lsl 2 ; perform shift ADR r4,b ; get address for b LDR r1,[r4] ; get value of b AND r1,r1,#15 ; perform AND ORR r1,r0,r1 ; perform OR 69

C αναθέσεις, συνέχεια (3) ADR r4,z ; get address for z STR r1,[r4] ; store value for z 70

Περισσότεροι τρόποι για την αντιμετώπιση Base-plus-offset διευθυνσιοδότησης: LDR r0,[r1,#16]. Φορτώνει από την περιοχή r1+16. Auto-indexing προσαυξήσεις βάση καταχωρητή: LDR r0,[r1,#16]! Post-indexing προσκομίζει, στη συνέχεια, μπορεί να αντισταθμίσει: LDR r0,[r1],#16. Φορτώνει το r0 από r1, μετά προσθέτει16 στο r1. 71

ARM ροή του ελέγχου Όλες οι λειτουργίες μπορούν να εκτελεστούν υπό όρους, (έλεγχος bit του CPSR): EQ, NE, CS, CC, MI, PL, VS, VC, HI, LS, GE, LT, GT, LE. Λειτουργία διακλάδωσης: B #100 Μπορεί να γίνει υπό όρους. 72

Εκτέλεση υπό όρους 73

Παράδειγμα: δήλωση if C: if (a > b) { x = 5; y = c + d; } else x = c -d; Assembler: ; compute and test condition ADR r4,a ; get address for a LDR r0,[r4] ; get value of a ADR r4,b ; get address for b LDR r1,[r4] ; get value for b CMP r0,r1 ; compare a < b BGE fblock ; if a >= b, branch to false block 74

Παράδειγμα: δήλωση if, συνέχεια. ; true block MOV r0,#5 ; generate value for x ADR r4,x ; get address for x STR r0,[r4] ; store x ADR r4,c ; get address for c LDR r0,[r4] ; get value of c ADR r4,d ; get address for d LDR r1,[r4] ; get value of d ADD r0,r0,r1 ; compute y ADR r4,y ; get address for y STR r0,[r4] ; store y B after ; branch around false block 75

Παράδειγμα: δήλωση if, συνέχεια ; false block fblock ADR r4,c ; get address for c LDR r0,[r4] ; get value of c ADR r4,d ; get address for d LDR r1,[r4] ; get value for d SUB r0,r0,r1 ; compute a-b ADR r4,x ; get address for x STR r0,[r4] ; store value of x after... 76

Παράδειγμα: υπό όρους εκτέλεση εντολών ; true block MOVLT r0,#5 ; generate value for x ADRLT r4,x ; get address for x STRLT r0,[r4] ; store x ADRLT r4,c ; get address for c LDRLT r0,[r4] ; get value of c ADRLT r4,d ; get address for d LDRLT r1,[r4] ; get value of d ADDLT r0,r0,r1 ; compute y ADRLT r4,y ; get address for y STRLT r0,[r4] ; store y 77

Παράδειγμα: υπό όρους εκτέλεση εντολών, συνέχεια ; false block ADRGE r4,c ; get address for c LDRGE r0,[r4] ; get value of c ADRGE r4,d ; get address for d LDRGE r1,[r4] ; get value for d SUBGE r0,r0,r1 ; compute a-b ADRGE r4,x ; get address for x STRGE r0,[r4] ; store value of x 78

Αλλαγές/περιστροφές στην επεξεργασία δεδομένων 79

Παράδειγμα: δήλωση switch C: switch (test) { case 0: break; case 1: } Assembler: ADR r2,test ; get address for test LDR r0,[r2] ; load value for test ADR r1,switchtab ; load address for switch table LDR r1,[r1,r0,lsl #2] ; index switch table switchtab DCD case0 DCD case1... 80

Παράδειγμα: FIR φίλτρου C: for (i=0, f=0; i<n; i++) f = f + c[i]*x[i]; Assembler: ; loop initiation code MOV r0,#0 ; use r0 for I MOV r8,#0 ; use separate index for arrays ADR r2,n ; get address for N LDR r1,[r2] ; get value of N MOV r2,#0 ; use r2 for f 81

FIR φίλτρο, συνέχεια ADR r3,c ; load r3 with base of c ADR r5,x ; load r5 with base of x ; loop body loop LDR r4,[r3,r8] ; get c[i] LDR r6,[r5,r8] ; get x[i] MUL r4,r4,r6 ; compute c[i]*x[i] ADD r2,r2,r4 ; add into running sum ADD r8,r8,#4 ; add one word offset to array index ADD r0,r0,#1 ; add 1 to i CMP r0,r1 ; exit? BLT loop ; if i < N, continue 82

ARM σύνδεση υπορουτίνων Εντολές branch-and-link: BL foo. Αντιγραφή του PC στο r14. Για επιστροφή από τη ρουτίνα: MOV r15,r14. Ο παραπάνω μηχανισμός μας αφήνει να καλέσουμε διαδικασίες με βάθος ενός επιπέδου. Για ένθετες διαδικασίες απαιτείται η κατασκευή στοίβας όπως παρακάτω. Χρησιμοποιείται ο r13 για να δείχνει την κορυφή της στοίβας. 83

Ένθετες κλήσεις υπορουτίνων Ένθεση / αναδρομή απαιτεί τη χρήση συγκεκριμένων μοτίβων κωδικοποίησης: F1LDR r0,[r13] ; load arg into r0 from stack ; call f2() STR r13!,[r14] ; store f1 s return adrs STR r13!,[r0] ; store arg to f2 on stack BL f2 ; branch and link to f2 ; return from f1() SUB r13,#4 ; pop f2 s arg off stack LDR r13!,r15 ; restore register and return 84

Περίληψη Οι ARM είναι Load/store αρχιτεκτονική. Οι περισσότερες οδηγίες είναι RISC, λειτουργούν σε ενιαίο κύκλο. Μερικές σύνθετες εντολές διαρκούν περισσότερο. Όλες οι οδηγίες μπορούν να εκτελεστούν υπό όρους. 85

Αναφορές Χρησιμοποιήθηκε υλικό από παρουσιάσεις των: Dimitrios Soudris, NTUA, 2012. Wayne Wolf, Computers as Components Overheads, 2008. Leonid Ryzhyk, The ARM Architecture, 2006. 86

Τέλος Ενότητας 87