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

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

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

Αρχιτεκτονική x86(-64) 32-bit και 64-bit λειτουργία. Αρχιτεκτονική x86(-64) Αρχιτεκτονική επεξεργαστών x86(-64) Αρχιτεκτονικές Συνόλου Εντολών (ΙΙ)

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

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


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

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

Εντολές γλώσσας μηχανής

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

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

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

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

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

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

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

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

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

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

Εισαγωγή στην πληροφορική -4

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

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

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

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

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

ΜΥΥ- 402 Αρχιτεκτονική Υπολογιστών ARM και x86

Εργαστήριο ΙΑΧΕΙΡΙΣΗ ΜΝΗΜΗΣ

Προηγμένοι Μικροεπεξεργαστές. Έλεγχος Ροής Προγράμματος

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

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

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

ΗΥ 232 Οργάνωση και Σχεδίαση Υπολογιστών. Intel x86 ISA. Νίκος Μπέλλας Τμήμα Ηλεκτρολόγων Μηχανικών και Μηχανικών ΗΥ

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

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

ΕΦΑΡΜΟΓΕΣ ΠΛΗΡΟΦΟΡΙΚΗΣ. Α Γενικού Λυκείου (Μάθημα Επιλογής)

ΠΛΕ- 074 Αρχιτεκτονική Υπολογιστών 2

Αναπαράσταση Μη Αριθμητικών Δεδομένων

! Δεδομένα: ανεξάρτητα από τύπο και προέλευση, στον υπολογιστή υπάρχουν σε μία μορφή: 0 και 1

Εισαγωγή στην Επιστήμη των Υπολογιστών

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

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

Ερωτήσεις θεωρίας MY. Μέρος Α. Υλικό.

Μεταγλωττιστές. Γιώργος Δημητρίου. Μάθημα 11 ο. Πανεπιστήμιο Θεσσαλίας - Τμήμα Ηλεκτρολόγων Μηχανικών & Μηχανικών Υπολογιστών

Παραλληλισμός σε επίπεδο εντολών

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

ΠΕΡΙΕΧΟΜΕΝΑ Υλικό και Λογισμικό Αρχιτεκτονική Υπολογιστών Δομή, Οργάνωση και Λειτουργία Υπολογιστών 6

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

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

-Επεξεργαστής: datapath (δίοδος δεδοµένων) (1) και control (2) -Μνήµη (3) -Συσκευές Εισόδου (4), Εξόδου (5) (Μεγάλη ποικιλία!!)

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

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

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

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

Ιεραρχία Μνήμης. Εικονική μνήμη (virtual memory) Επεκτείνοντας την Ιεραρχία Μνήμης. Εικονική Μνήμη. Μ.Στεφανιδάκης

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

ΑΡΧΙΤΕΚΤΟΝΙΚΗ ΥΠΟΛΟΓΙΣΤΩΝ II. χειμερινό εξάμηνο & εαρινό εξάμηνο (σε κίτρινο υπόβαθρο)

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

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

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

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

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

ΟΡΓΑΝΩΣΗ ΚΑΙ ΣΧΕΔΙΑΣΗ Η/Υ

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

Υλικό Υπολογιστών (Hardware) ΜΥΥ-106 Εισαγωγή στους Η/Υ και Πληροφορική

2. Τεχνολογία επεξεργαστών

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

με έμφαση στο MIPS R2000

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

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

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

Ελληνική Δημοκρατία Τεχνολογικό Εκπαιδευτικό Ίδρυμα Ηπείρου. Πληροφορική Ι. Ενότητα 6 : Εκτέλεση πράξεων, Αρχιτεκτονική Η/Υ. Δρ.

Εισαγωγή στους Η/Υ. Γιώργος Δημητρίου. Μάθημα 1 ο

Αρχιτεκτονική Υπολογιστών. Αρχιτεκτονική Συνόλου Εντολών (Instruction Set Architecture)

i Στα σύγχρονα συστήματα η κύρια μνήμη δεν συνδέεται απευθείας με τον επεξεργαστή

Οργάνωση Η/Υ. Γλώσσα Assembly. Τμήμα Εφαρμσμένης Πληροφορικής Πανεπιστήμιο Μακεδονίας Α. Χατζηγεωργίου-Η. Σακελλαρίου

ΑΣΚΗΣΕΙΣ ΠΟΛΛΑΠΛΗΣ ΕΠΙΛΟΓΗΣ ΓΙΑ ΤΗ ΘΕΩΡΙΑ

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

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

Μνήμη Διευθύνσεις Δείκτες. Προγραμματισμός II 1

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

Εισαγωγή στην Πληροφορική

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

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

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

Τεχνολογίες Κύριας Μνήμης

ΤΕΧΝΟΛΟΓΙΚΟ ΕΚΠΑΙΔΕΥΤΙΚΟ ΙΔΡΥΜΑ ΛΑΜΙΑΣ. A. Μετατροπή αριθμών 1. Μετατροπή αριθμών από δεκαδικό σε δυαδικό σύστημα αρίθμησης

Α. Δίνονται οι. (i) στη. πρέπει να. πιο. (ii) $a0. $s0 θα πρέπει να. αποθήκευση. αυξάνει τον. f: sub sll add sub jr. h: addi sw sw.

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

Σημειώσεις για τον 80x86

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

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

Εικονική Μνήμη (Virtual Μemory)

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

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

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

ΜΥΥ- 402 Αρχιτεκτονική Υπολογιστών Φροντιστήριο: MIPS assembly

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

*Ένας υπολογιστής είναι στην πραγματικότητα ένα σύστημα πολλών μερών που συνεργάζονται μεταξύ τους.

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

Διαδικασίες Ι. ΗΥ 134 Εισαγωγή στην Οργάνωση και στον Σχεδιασμό Υπολογιστών Ι. Διάλεξη 4

Transcript:

Ιόνιο Πανεπιστήμιο Τμήμα Πληροφορικής Αρχιτεκτονική Υπολογιστών 2015-16 Αρχιτεκτονικές Συνόλου Εντολών (ΙΙ) (Δομή Εντολών και Παραδείγματα) http://di.ionio.gr/~mistral/tp/comparch/ Μ.Στεφανιδάκης Αρχιτεκτονική Συνόλου Εντολών Τι περιγράφει Διαθέσιμες πράξεις/λειτουργίες Κωδικοποίηση λειτουργιών Μορφή των εισόδου-εξόδου Operands Μέθοδοι προσπέλασης των Χώροι προσωρινής αποθήκευσης Καταχωρητές Διακοπές και καταστάσεις σφάλματος Ποια η αντίδραση του επεξεργαστή Αρχιτεκτονική Υπολογιστών Αρχιτεκτονικές Συνόλου Εντολών (ΙΙ) 2 Σχεδιασμός Συνόλου Εντολών Κωδικοποίηση Εντολών Μηχανής Συμβιβασμός μεταξύ: Κόστους και απόδοσης υλικού opcode operand1 operand2.. operandn Βαθμού υποστήριξης λογισμικού Άλλων παραγόντων όπως η κατανάλωση ενέργειας Το υλικό καταναλώνει ενέργεια, υπό τον έλεγχο του λογισμικού όμως! Μη επικάλυψης λειτουργιών (orthogonality) Γιατί είναι ταχύτερη η λήψη και αποκωδικοποίηση των σταθερού μήκους Σειρά δυαδικών ψηφίων Μεταβλητού μήκους Περισσότερο συμπαγή προγράμματα Πολυπλοκότερο υλικό! Σταθερού μήκους Απλούστερη και ταχύτερη λήψη-αποκωδικοποίηση Μεγαλύτερα προγράμματα Μέθοδοι συμπίεσης Αρχιτεκτονική Υπολογιστών Αρχιτεκτονικές Συνόλου Εντολών (ΙΙ) 3 Αρχιτεκτονική Υπολογιστών Αρχιτεκτονικές Συνόλου Εντολών (ΙΙ) 4

Κωδικοποίηση Εντολών Μηχανής Εντολές Μηχανής και Assembly opcode operand1 operand2.. operandn Εντολές μηχανής Σειρές από bits (ομάδες bytes ανά εντολή) Περιγράφει το είδος της πράξης που θα εκτελεστεί Περιγράφουν την προέλευση των εισόδου (αριθμό καταχωρητή, διεύθυνση κλπ) και τον προορισμό των εξόδου (αποτέλεσμα πράξης) Το είδος της πράξης προσδιορίζει τον τύπο, την προέλευση και τον αριθμό των που συμμετέχουν στην πράξη!! Κάθε διαφορετική αρχιτεκτονική επεξεργαστών έχει διαφορετική γλώσσα assembly! Τα bits αυτά κωδικοποιούν όλα τα χαρακτηριστικά κάθε εντολής Assembly Μνημονικός τρόπος αναπαράστασης Ευκολότερη κατανόηση από τον άνθρωπο Προσοχή: MOV R1,R2 // π.χ. R1 => R2 MOV R1,#100 // π.χ. R1 => mem[100] παρόλο που το μνημονικό MOV είναι ίδιο, δεν πρόκειται για την ίδια εντολή! Αρχιτεκτονική Υπολογιστών Αρχιτεκτονικές Συνόλου Εντολών (ΙΙ) 5 Αρχιτεκτονική Υπολογιστών Αρχιτεκτονικές Συνόλου Εντολών (ΙΙ) 6 Τα παραδείγματά μας: Intel IA-32 (64) Τα παραδείγματά μας: Intel IA-32 (64) i Και η ανταγωνίστρια εταιρία AMD παράγει επεξεργαστές συμβατούς με την αρχιτεκτονική αυτή Αρχιτεκτονική επεξεργαστών Intel IA-32 Μία πολύπλοκη αρχιτεκτονική επεξεργαστών με σύνθετο σετ διατήρηση συμβατότητας με παλαιότερους επεξεργαστές της Intel (legacy compatibility) Με πολύ μεγάλη εγκατεστημένη βάση Συστήματα PCs Όχι η βέλτιστη αρχιτεκτονική αλλά: Το μεγάλο μερίδιο που κατέχει στην αγορά επιτρέπει στην Intel έρευνα και ανάπτυξη για διαρκείς βελτιώσεις απόδοσης Τελικά η αρχιτεκτονική αυτή είναι βέλτιστη μέσα στην τεράστια πολυπλοκότητά της Οικογένειες επεξεργαστών Pentium P6 Pentium Pro, II, III Netburst Pentium 4, D (IA-32 σε νεώτερες εκδόσεις και 64) Pentium M Intel Core, Core Duo Intel Core (IA-32-64) Intel Core 2 Duo...νεώτερες αρχιτεκτονικές Intel 64 and IA-32 Architectures Software Developer's Manuals http://www.intel.com/products/processor/manuals/index.htm Αρχιτεκτονική Υπολογιστών Αρχιτεκτονικές Συνόλου Εντολών (ΙΙ) 7 Αρχιτεκτονική Υπολογιστών Αρχιτεκτονικές Συνόλου Εντολών (ΙΙ) 8

Intel IA-32: η γενική μορφή των Προέλευση και αποθήκευση Μεταβλητός αριθμός bytes ανά εντολή (1-17)! αποθήκευση αποτελεσμάτων μιας πράξης Operand addressing Εξαρτάται από την αρχιτεκτονική του επεξεργαστή Στους πρώτους επεξεργαστές Stack (σωρός-στοίβα) Accumulator (συσσωρευτής) Μεταγενέστεροι υπολογιστές Καταχωρητές Μνήμη (register-memory) Κυρίως (register-register ή load-store) μόνο ανάγνωση και εγγραφή Αρχιτεκτονική Υπολογιστών Αρχιτεκτονικές Συνόλου Εντολών (ΙΙ) 9 Αρχιτεκτονική Υπολογιστών Αρχιτεκτονικές Συνόλου Εντολών (ΙΙ) 10 Αρχιτεκτονική σωρού (stack) Αρχιτεκτονική συσσωρευτή (accumulator) TOS push A push B accumulator (A) μνήμη add X (A = A + X) add pop A Πηγή-προορισμός προσδιορίζονται έμμεσα Δεν περιγράφονται στην εντολή! 0-address architecture Δημοφιλές σχήμα κατά τη δεκαετία του 60 Δύσκολη προσπέλαση σωρού, απαιτούνται πολλαπλές αντιμεταθέσεις και αντιγραφές Το σχήμα επιζεί στην αρχιτεκτονική της Java VM Μία πηγή - θέση αποθήκευσης του αποτελέσματος είναι πάντα ο συσσωρευτής 1-address architecture Αρχιτεκτονική των πρώτων υπολογιστών! Αρχιτεκτονική Υπολογιστών Αρχιτεκτονικές Συνόλου Εντολών (ΙΙ) 11 Αρχιτεκτονική Υπολογιστών Αρχιτεκτονικές Συνόλου Εντολών (ΙΙ) 12

Αρχιτεκτονικές με (1) Αρχιτεκτονικές με (2) μνήμη add R2, R1,mem(100) (R2 <= R1 + mem[100]) add R1, R2,R3 (R1 <= R2 + R3)! Καταχωρητές: προσωρινές θέσεις αποθήκευσης αποτελεσμάτων, η γενίκευση της ιδέας του συσσωρευτή. Memory-register Οποιαδήποτε εντολή μπορεί να προσπελάσει τη μνήμη Όμως: Πολλαπλές προσπελάσεις Λήψη εντολής Λήψη εντολής Πολύπλοκη εκτέλεση εντολής σε στάδια Συνωστισμός στον δίαυλο επικοινωνίας με μνήμη Είναι επιθυμητός ένα πολύ μεγάλος αριθμός καταχωρητών Register-register (load-store) Μόνο εντολές load-store μπορούν να προσπελάσουν τη μνήμη Η αρχιτεκτονική των σύγχρονων επεξεργαστών Οι προσπελαύνονται πολύ γρήγορα Χρειάζονται λιγότερα bits για να επιλεγούν Οι μεταγλωττιστές αναθέτουν μεταβλητές σε Αρχιτεκτονική Υπολογιστών Αρχιτεκτονικές Συνόλου Εντολών (ΙΙ) 13 Αρχιτεκτονική Υπολογιστών Αρχιτεκτονικές Συνόλου Εντολών (ΙΙ) 14 Η εξέλιξη της αρχιτεκτονικής Η εξέλιξη της αρχιτεκτονικής Οι πρώτοι υπολογιστές (.. - 60) Αρχιτεκτονική συσσωρευτή και αργότερα σωρού Ικανοποιητική λύση λόγω της απλής τεχνολογίας των μεταγλωττιστών Πολύπλοκες αρχιτεκτονικές ( 70 -..) Ενσωμάτωση σύνθετων μορφών και μεθόδων προσπέλασης Προσπάθεια υποστήριξης υψηλών γλωσσών προγραμματισμού μείωσης κόστους λογισμικού Πολλά χαρακτηριστικά μένουν αχρησιμοποίητα! Complex Instruction Set Computers (CISC) Reduced Instruction Set Computers (RISC) ( 80 - ) Απλούστερες και φθηνότερες load-store αρχιτεκτονικές με σταθερό μήκος Μεγαλύτερη απόδοση ταχύτερη εκτέλεση Ευνοείται από την αφθονία υλικού χαμηλού κόστους και την προηγμένη τεχνολογία των μεταγλωττιστών Ακόμα και ο μοναδικός επιζών επεξεργαστής με εντολές CISC (αρχιτεκτονική x86), μεταφράζει εσωτερικά σε εντολές RISC Αρχιτεκτονική Υπολογιστών Αρχιτεκτονικές Συνόλου Εντολών (ΙΙ) 15 Αρχιτεκτονική Υπολογιστών Αρχιτεκτονικές Συνόλου Εντολών (ΙΙ) 16

ΙΑ-32 (64): memory-register ΙΑ-32: Πολλές εντολές γενικού σκοπού πέρα από τις load και store έχουν ως πηγή ή προορισμό τη μνήμη AND Logical AND Opcode Instruction... 81 /4 iw AND r/m16, imm16 81 /4 id AND r/m32, imm32... 21 /r AND r/m16, r16 21 /r AND r/m32, r32 REX.W + 21 /r AND r/m64, r64 22 /r AND r8, r/m8... 23 /r AND r32, r/m32 REX.W + 23 /r AND r64, r/m64...κλπ.. i Εκτός από τους γενικού σκοπού, οι επεξεργαστές ΙΑ- 32 έχουν πρόσθετους για πράξεις κινητής υποδιαστολής και πράξεις streaming και multimedia. γενικού σκοπού και σχηματισμός διευθύνσεων τμηματοποίηση (σε επόμενα μαθηματα) καταχωρητής κατάστασης program counter Αρχιτεκτονική Υπολογιστών Αρχιτεκτονικές Συνόλου Εντολών (ΙΙ) 17 Αρχιτεκτονική Υπολογιστών Αρχιτεκτονικές Συνόλου Εντολών (ΙΙ) 18 Μέθοδοι προσπέλασης Μέθοδοι προσπέλασης Τουλάχιστον κάποιες εντολές προσπελαύνουν τη μνήμη για ανάγνωση ή εγγραφή Πώς σχηματίζεται η διεύθυνση προσπέλασης Η γενική ιδέα: υποβοήθηση του λογισμικού Διαφορετικός σχηματισμός διεύθυνσης για Τοπικές μεταβλητές Δείκτες (έμμεση προσπέλαση) Στατικά δεδομένα Διάσχιση πινάκων (Σταθερές τιμές) Υποστήριξη ανάλογα με αρχιτεκτονική Πώς κωδικοποιούνται οι μέθοδοι προσπέλασης μέσα στην εντολή Στο σχηματισμό της διεύθυνσης μπορούν να συμμετέχουν: Απόλυτες τιμές διεύθυνσης Καταχωρητές πιθανή Σταθερές τιμές μετατόπισης (offsets) χρήση displacement register indirect indexed direct memory indirect auto-increment scaled mem[offs+reg] mem[reg] mem[reg1+reg2] mem[addr] mem[mem[reg]] mem[reg++] mem[offs+reg1+reg2*d] τοπικές δείκτες πίνακες στατικές *δείκτες πίνακες πίνακες Αρχιτεκτονική Υπολογιστών Αρχιτεκτονικές Συνόλου Εντολών (ΙΙ) 19 Αρχιτεκτονική Υπολογιστών Αρχιτεκτονικές Συνόλου Εντολών (ΙΙ) 20

ΙΑ-32 (64): Σχηματισμός διευθύνσεων Εντολές: κατηγορίες λειτουργιών Κατηγορίες Βασικές κατηγορίες Αριθμητικές και λογικές πράξεις Μεταφορά Από-πρός Καταχωρητές και Μνήμη Έλεγχος ροής εκτέλεσης Διακλαδώσεις και κλήσεις ρουτινών Άλλες κατηγορίες Ειδικές εντολές συστήματος ΛΣ, ιδεατή μνήμη Επεξεργασία πολλαπλών Χρήσιμο για γραφικά, σειρές χαρακτήρων, multimedia Αρχιτεκτονική Υπολογιστών Αρχιτεκτονικές Συνόλου Εντολών (ΙΙ) 21 Αρχιτεκτονική Υπολογιστών Αρχιτεκτονικές Συνόλου Εντολών (ΙΙ) 22 ΙΑ-32: εντολές μεταφοράς IA-32: Εντολές διακλάδωσης Κατηγορίες Με ή χωρίς συνθήκη Σε απόλυτη ή σχετική διεύθυνση 16 ή 32 bits απόλυτη διεύθυνση πιθανώς σε μνήμη ή καταχωρητή 8, 16 ή 32 bits σχετική διεύθυνση Συνθήκη: καταχωρητής κατάστασης EFLAGS Μεταξύ τμημάτων κώδικα της ίδιας ή διαφορετικής διεργασίας Κλήση συναρτήσεων Όπως η διακλάδωση με αποθήκευση πρόσθετης πληροφορίας (program stack) για επιστροφή από συνάρτηση στο σημείο μετά την κλήση Αρχιτεκτονική Υπολογιστών Αρχιτεκτονικές Συνόλου Εντολών (ΙΙ) 23 Αρχιτεκτονική Υπολογιστών Αρχιτεκτονικές Συνόλου Εντολών (ΙΙ) 24

Εντολές διακλάδωσης Κατηγορίες Κλήση συναρτήσεων και επιστροφή Αποθήκευση της τρέχουσας διεύθυνσης εκτέλεσης (καταχωρητή PC) Πριν τη μετάβαση στη συνάρτηση Χρήση αποθηκευμένης τιμής Κατά την επιστροφή (return) Πού θα μπορούσε να αποθηκευτεί η διεύθυνση επιστροφής μετά από κλήση συνάρτησης frame pointer Παράμετροι εισόδου Χώρος για επιστρεφόμενη τιμή Διεύθυνση επιστροφής Προηγούμενη τιμή frame pointer Τοπικές μεταβλητές Προσωρινές θέσεις αποθήκευσης Αρχιτεκτονική Υπολογιστών Αρχιτεκτονικές Συνόλου Εντολών (ΙΙ) 25