Ch1

Télécharger au format pdf ou txt
Télécharger au format pdf ou txt
Vous êtes sur la page 1sur 28

Architecture des Ordinateurs (AO)

Akli ABBAS

Université Akli Mohand Oulhadj - Bouira


Département d’Informatique
2ème année - Licence informatique
2016 - 2017
Email: [email protected]
Disponible sur:
https://sites.google.com/a/esi.dz/a-abbas/

1/28
Contenu de la matière

1 Chapitre 1 : Organisation générale de l’unité centrale d’un Ordinateur


Généralités sur l’Ordinateur
Architecture de Base :
Le modèle de Harvard et de Von Neumann, Processeur, Mémoire
et Bus
2 Chapitre 2 : Architecture Interne des Processeurs
Introduction
Les Registres
Unité Arithmétique et Logique (UAL)
Unité de Commande (U.C)
Jeu d’instruction
Mode d’adressage
Étapes d’exécution d’un instruction
3 Chapitre 3 : Étude des cas : Processeur 80x86
4 Chapitre 4 : Architectures des processeurs récents

2/28
Objectifs

Comprendre l’architecture d’une machine von newman.

Comprendre les étapes de déroulement de l’exécution d’une


instruction.

Comprendre le principe des différents modes d’adressage.

3/28
Les prérequis

1 Représentation des nombres


Système de numérique (base 10, base 2, base 8, Base 16)
Le système binaire
Organisation des donnée (Bit, octets, Mot)
Système hexadécimal
Opération arithmétique sur le bit
Opération logique sur les bit
2 Algèbre de Boole
Fonction booléenne et table de vérité
Manipulation algébrique et expression booléenne
Formes canonique
Simplification des fonctions booléenne
...

4/28
Chapitre 1

Organisation générale de l’unité centrale d’un


Ordinateur
Généralités sur l’Ordinateur
Architecture de Base :
- Le modèle de Harvard et de Von Neumann, Processeur, Mémoire et Bus

5/28
Généralités sur l’Ordinateur

Qu’est ce qu’un ordinateur ?


1 Un ordinateur est une machine de traitement de l’information.
2 Il est capable de :
Acquérir de l’information de l’extérieur ;
Stocker en son sein ces informations ;
Combiner (transformer) entre elles les informations à sa disposition ;
Restituer ces informations à l’extérieur.

Qu’est ce qu’un système Informatique ?


Un système informatique est un ensemble de composants de type logiciel
(software) et matériel (hardware), mis ensemble pour collaborer dans
l’exécution d’une application.

6/28
Généralités sur l’Ordinateur

Qu’est ce qu’un programme ?


Un programme est un ensemble d’instructions exécutées dans un ordre
bien déterminé.
Un programme est exécuté par un processeur (machine).
Un programme est généralement écrit dans un langage évolué (Pascal,
C, VB, Java, etc.).
Les instructions qui constituent un programme peuvent être classifiées en
4 catégories :
– Les Instructions d’affectations : permet de faire le transfert des
données
– Les instructions arithmétiques et logiques.
– Les Instructions de branchement (conditionnelle et inconditionnelle)
– Les Instructions d’entrées sorties.

7/28
Généralités sur l’Ordinateur

Pour exécuter un programme par une machine, on passe par les étapes
suivantes :
1 Édition : on utilise généralement un éditeur de texte pour écrire un
programme et le sauvegarder dans un fichier.
2 Compilation : un compilateur est un programme qui convertit le code
source (programme écrit dans un langage donné) en un programme écrit
dans un langage machine (binaire).
Remarque : Une instruction en langage évolué peut être traduite en
plusieurs instructions machine.
3 Chargement et exécution : charger le programme en langage machine
dans mémoire afin de l’exécuter.

8/28
Généralités sur l’Ordinateur

• Un programme écrit dans un langage de haut niveau (Pascal, C...) doit


être traduit dans le langage de la machine pour d’être exécuté par le
processeur.
• Langage machine :
Est la suite de bits qui est interprétée (compréhensible) par le processeur.
C’est le seul langage que le processeur puisse traiter. Il est composé
d’instructions et de données codées en binaire. (Ex. 10110000 01100001)

Problème : le langage machine est difficile à comprendre par l’humain.

9/28
Généralités sur l’Ordinateur

Idée : trouver un langage compréhensible par l’homme qui sera ensuite


converti en langage machine 7→ Langage d’assemblage
langage assembleur :exprimer les instructions élémentaires (binaire) de
façon symbolique. Il représente le langage machine sous une forme lisible par
un humain. (Ex. mov 61)

Une instruction assembleur = une instruction machine

Exemple : 10110000 01100001 (instruction machine) = mov 61 (instruction


assembleur)

10/28
Généralités sur l’Ordinateur

Comment s’exécute un programme dans la machine ?


Pour comprendre le mécanisme d’exécution d’un programme ⇒ il faut
comprendre le mécanisme de l’exécution d’une instruction .

Pour comprendre le mécanisme de l’exécution d’une instruction ⇒ il faut


connaı̂tre l’architecture de la machine (processeur) sur la quelle va
s’exécuter cette instruction.

11/28
Généralités sur l’Ordinateur

que veut-on dire par architecture ?


L’architecture d’un système représente l’organisation de ses différentes
composantes et de leurs interconnexions.

Deux types d’architecture d’ordinateur :


1 Le Modèle de Harvard
2 Le Modèle de Von Neumann

12/28
Architecture de Base

Le Modèle de Harvard (1944)


L’architecture de type Harvard est une conception qui sépare physiquement
la mémoire de données et la mémoire programme. L’accès à chacune des
deux mémoires s’effectue via deux bus distincts.

1 Séparation des mémoires programme et données


Un bus de données programme,
Un bus de données pour les données,
Un bus d’adresse programme,
Un bus d’adresse pour les données.
2 Meilleure utilisation du CPU :
3 Chargement du programme et des données en parallèle
13/28
Architecture de Base

Le Modèle de Von Neumann (1946)

L’architecture Von Neumann est la base des architectures des ordinateurs et


elle est composée : d’un processeur (CPU), d’une mémoire principale et
d’un dispositifs d’entrées sorties pour communiquer avec l’extérieur.

1 Un seul chemin (bus) d’accès à la mémoire ;


Un bus de données (programme et données),
Un bus d’adresse (programme et données)
2 Limite l’accès à la mémoire.
3 Architecture des processeurs d’usage général ;
14/28
Architecture de Base

Le processeur

Le processeur, parfois appelé CPU (Central Processing Unit) est un


circuit électronique qui est divisé en deux parties :
1 Unité de commande (U.C) est responsable de la lecture en mémoire et
du décodage des instructions machine ;

2 Unité de traitement, appelée aussi Unité Arithmétique et Logique


(U.A.L.), exécute les instructions machine qui manipulent les données.

Pour chaque instruction machine, le processeur effectue


schématiquement les opérations suivantes :
1 lire en mémoire l’instruction à exécuter ;
2 effectuer le traitement correspondant ;
3 passer à l’instruction suivante.

15/28
Architecture de Base

La mémoire principale

La mémoire principale (MP) permet de stocker les informations


(instructions et données).
Les différentes informations que l’on trouve dans la mémoire principale :

Toute information manipulée par le processeur est sous forme binaire.


16/28
Architecture de Base

Structure de la mémoire principale

La mémoire est divisée en emplacements de taille fixe (en général 1 octet


= 8 bits) utilisés pour stocker instructions et données.

Dans une mémoire de taille N, on a N emplacements mémoires,


numérotés de 0 à N-1. Chaque emplacement est repéré par son numéro,
appelé adresse.
17/28
Architecture de Base

Structure de la mémoire principale (2)

La capacité (taille) de la mémoire est le nombre d’emplacements,


exprimé en général en kilo-octets ou en méga-octets, voire plus.

Deux opérations sont possibles sur la mémoire :


1 Écriture : le processeur fournit une valeur et une adresse, et la mémoire
range la valeur à l’emplacement indiqué par l’adresse ;
2 Lecture : le processeur demande à la mémoire la valeur contenue à
l’emplacement dont il indique l’adresse. Le contenu de l’emplacement lu
reste inchangé.

18/28
Architecture de Base

Unité de transfere entre la mémoire et le processeur

Les opérations de lecture et d’écriture portent en général sur plusieurs


octets contigus en mémoire : un mot mémoire.
La taille d’un mot mémoire dépend du type de processeur :
• 1 octet dans les processeurs 8 bits (ex. Motorola 6502) ;
• 2 octets dans les processeurs 16 bits (ex. Intel 8086) ;
• 4 octets dans les processeurs 32 bits (ex. Intel 80486 ou Motorola 68030).
• 8 octets dans les processeurs 64 bits (ex. Les Itanium d’Intel, AMD64 de
AMD ou Intel 64 d’Intel)

19/28
Architecture de Base

Les différents type de mémoire


SRAM : Static Random Access Memory. Mémoire statique à accés
aléatoire, à base de bascules à semi-conducteurs à deux états .
Avantage : très rapide, simple d’utilisation. Inconvénient : compliqué à
réaliser.
DRAM : Dynamic RAM. Basée sur la charge de condensateurs :
condensateur chargé = 1, déchargé = 0. Avantage : intégration élevée,
faible coût. Inconvénient : nécessite un rafraı̂chissement périodique à
cause du courant de fuite des condensateurs. Application : réalisation
de la mémoire vive des ordinateurs (barettes mémoire SIMM : Single
In-line Memory module).

20/28
Architecture de Base

Bus

• Les informations échangées entre composants de l’ordinateur circulent


sur des bus.
• Bus : est un ensembles de n fils parallèles servant à relier un ou plusieurs
composants de l’ordinateur et à transporter n signaux binaires.
• Objectif : réduire le nombre de voies nécessaires à la communication des
différents composants.

21/28
Architecture de Base

Bus

Caractéristiques :
• Largeur : nombre de lignes physiques sur lesquelles les données sont
envoyées = nombre de bits transmis en parallèle.
• Fréquence (en Hz) : nombre de paquets de données envoyés ou reçus
par seconde.
• Débit maximal (ou taux de transfert maximal, bande passante) :
quantité de données transportées par unité de temps :
Débit maximal (en Mo/s) = largeur du bus (en octets) x fréquence (en
Hz).
Exemple
Largeur 2 octets et fréquence 133 MHz =⇒ 266 Mo/s

22/28
Architecture de Base

Bus
Type : Il existe trois types de bus : de données, d’adresses et de
commande (ou de contrôle).

23/28
Architecture de Base

Bus de données

• Le bus de données est un bus bidirectionnel(←→) permettant de


transférer l’information entre les différents composants (Ex. entre la
mémoire et le CPU).
• L’information peut être :
Une instruction à exécuter par le processeur (mémoire −→ CPU)
Donnée stockée en mémoire (mémoire −→ CPU)
Donnée produite par un traitement du processeur (CPU −→ mémoire).
La largeur de bus de données détermine la taille des mots mémoires
auxquels on peut accéder.
Exemple
Le bus de données a une largeur de 16 fils ⇒ les mots mémoires accessibles
(ou modifiables) ont 16 bits.

24/28
Architecture de Base

Bus d’adresses

• Le bus d’adresse est un bus unidirectionnel (7→) ; seul le processeur


envoie des adresses.
• La largeur de bus d’adresses détermine la taille de la mémoires (le
nombre d’emplacements). S’il est compose de n fils ⇒ On utilise donc
des adresses de n bits ⇒ La mémoire peut posséder au maximum 2n
emplacements (adresses 0 à 2n−1 ).

25/28
Architecture de Base

Bus d’adresses

Exercice
Quel est le nombre minimal
des fils nécessaire pour
adresser cette mémoire ?

Solution
0 à 7 emplacements ⇒ 8 emplacements
8 = 23 ⇒ 3 fils sont nécessaires

26/28
Architecture de Base

Bus d’adresses
Exercice
Supposant que le processeur veut lire le 5ème emplacement (12), Quel sera le
contenu du bus d’adresse ainsi que le bus de données ?

Solution
Bus d’adresses=00000100
Bus de données=00001100

27/28
Architecture de Base

Bus de commande

• Le bus de commande (ou de contrôle) est un bus unidirectionnel (7−→).


Seul le processeur envoie des commandes pour contrôler le
fonctionnement des autres composants.
• C’est par ce bus que le microprocesseur indique la nature des opérations
qu’il veut effectuer.
• Dans notre exemple il a une largeur d’un fil et donc le microprocesseur
ne peut passer que deux commandes (la lecture et l’écriture)

28/28

Vous aimerez peut-être aussi