Microprocesseur - Guide rapide
Le microprocesseur est une unité de contrôle d'un micro-ordinateur, fabriquée sur une petite puce capable d'effectuer des opérations ALU (Arithmetic Logical Unit) et de communiquer avec les autres appareils qui y sont connectés.
Le microprocesseur se compose d'une ALU, d'un tableau de registres et d'une unité de contrôle. ALU effectue des opérations arithmétiques et logiques sur les données reçues de la mémoire ou d'un périphérique d'entrée. Le tableau de registres se compose de registres identifiés par des lettres telles que B, C, D, E, H, L et accumulateur. L'unité de contrôle contrôle le flux de données et d'instructions dans l'ordinateur.
Schéma fonctionnel d'un micro-ordinateur de base
Comment fonctionne un microprocesseur?
Le microprocesseur suit une séquence: Extraire, Décoder, puis Exécuter.
Au départ, les instructions sont stockées dans la mémoire dans un ordre séquentiel. Le microprocesseur récupère ces instructions dans la mémoire, puis les décode et exécute ces instructions jusqu'à ce que l'instruction STOP soit atteinte. Plus tard, il envoie le résultat en binaire au port de sortie. Entre ces processus, le registre stocke temporairement les données et ALU exécute les fonctions de calcul.
Liste des termes utilisés dans un microprocesseur
Voici une liste de certains des termes fréquemment utilisés dans un microprocesseur -
Instruction Set - C'est l'ensemble des instructions que le microprocesseur peut comprendre.
Bandwidth - C'est le nombre de bits traités dans une seule instruction.
Clock Speed- Il détermine le nombre d'opérations par seconde que le processeur peut effectuer. Il est exprimé en mégahertz (MHz) ou gigahertz (GHz). Il est également connu sous le nom de fréquence d'horloge.
Word Length- Cela dépend de la largeur du bus de données interne, des registres, de l'ALU, etc. Un microprocesseur 8 bits peut traiter des données 8 bits à la fois. La longueur du mot varie de 4 bits à 64 bits selon le type de micro-ordinateur.
Data Types - Le microprocesseur a plusieurs formats de type de données comme les nombres binaires, BCD, ASCII, signés et non signés.
Caractéristiques d'un microprocesseur
Voici une liste de certaines des caractéristiques les plus importantes de tout microprocesseur -
Cost-effective - Les puces de microprocesseur sont disponibles à bas prix et en résulte son faible coût.
Size - Le microprocesseur est une puce de petite taille, donc portable.
Low Power Consumption - Les microprocesseurs sont fabriqués en utilisant la technologie des semi-conducteurs oxyde de métal, qui a une faible consommation d'énergie.
Versatility - Les microprocesseurs sont polyvalents car nous pouvons utiliser la même puce dans un certain nombre d'applications en configurant le logiciel.
Reliability - Le taux de défaillance d'un circuit intégré dans les microprocesseurs est très faible, il est donc fiable.
Un microprocesseur peut être classé en trois catégories -
Processeur RISC
RISC signifie Reduced Instruction Set Computer. Il est conçu pour réduire le temps d'exécution en simplifiant le jeu d'instructions de l'ordinateur. En utilisant les processeurs RISC, chaque instruction ne nécessite qu'un seul cycle d'horloge pour exécuter les résultats dans un temps d'exécution uniforme. Cela réduit l'efficacité car il y a plus de lignes de code, donc plus de RAM est nécessaire pour stocker les instructions. Le compilateur doit également travailler davantage pour convertir les instructions de langage de haut niveau en code machine.
Certains des processeurs RISC sont -
- Power PC: 601, 604, 615, 620
- DEC Alpha: 210642, 211066, 21068, 21164
- MIPS: Processeur RISC TS (R10000)
- PA-RISC: HP 7100LC
Architecture du RISC
L'architecture de microprocesseur RISC utilise un ensemble d'instructions hautement optimisé. Il est utilisé dans les appareils portables comme Apple iPod en raison de son efficacité énergétique.
Caractéristiques du RISC
Les principales caractéristiques d'un processeur RISC sont les suivantes -
Il se compose d'instructions simples.
Il prend en charge divers formats de type de données.
Il utilise des modes d'adressage simples et des instructions de longueur fixe pour le pipelining.
Il prend en charge le registre à utiliser dans n'importe quel contexte.
Un temps d'exécution de cycle.
Les instructions «LOAD» et «STORE» sont utilisées pour accéder à l'emplacement mémoire.
Il se compose d'un plus grand nombre de registres.
Il se compose de moins de transistors.
Processeur CISC
CISC signifie Complex Instruction Set Computer. Il est conçu pour minimiser le nombre d'instructions par programme, en ignorant le nombre de cycles par instruction. L'accent est mis sur la création d'instructions complexes directement dans le matériel.
Le compilateur doit faire très peu de travail pour traduire un langage de haut niveau en langage d'assemblage / code machine car la longueur du code est relativement courte, donc très peu de RAM est nécessaire pour stocker les instructions.
Certains des processeurs de l'ICCA sont -
- IBM 370/168
- VAX 11/780
- Intel 80486
Architecture de l'ICCA
Son architecture est conçue pour réduire le coût de la mémoire, car plus de stockage est nécessaire dans les programmes plus volumineux, ce qui entraîne un coût de mémoire plus élevé. Pour résoudre ce problème, le nombre d'instructions par programme peut être réduit en intégrant le nombre d'opérations dans une seule instruction.
Caractéristiques du SCRC
- Variété de modes d'adressage.
- Un plus grand nombre d'instructions.
- Longueur variable des formats d'instructions.
- Plusieurs cycles peuvent être nécessaires pour exécuter une instruction.
- La logique de décodage des instructions est complexe.
- Une instruction est requise pour prendre en charge plusieurs modes d'adressage.
Processeurs spéciaux
Ce sont les processeurs qui sont conçus à des fins spéciales. Peu de processeurs spéciaux sont brièvement discutés -
Coprocesseur
Un coprocesseur est un microprocesseur spécialement conçu, qui peut gérer sa fonction particulière plusieurs fois plus rapidement que le microprocesseur ordinaire.
For example - Coprocesseur mathématique.
Certains coprocesseurs mathématiques Intel sont -
- 8087-utilisé avec 8086
- 80287-utilisé avec 80286
- 80387-utilisé avec 80386
Processeur d'entrée / sortie
Il s'agit d'un microprocesseur spécialement conçu ayant sa propre mémoire locale, qui est utilisé pour contrôler les périphériques d'E / S avec une implication minimale du processeur.
For example -
- Contrôleur DMA (Direct Memory Access)
- Contrôleur clavier / souris
- Contrôleur d'affichage graphique
- Contrôleur de port SCSI
Transputer (ordinateur à transistors)
Un transputer est un microprocesseur spécialement conçu avec sa propre mémoire locale et ayant des liens pour connecter un transputer à un autre transputer pour les communications inter-processeurs. Il a été conçu pour la première fois en 1980 par Inmos et est destiné à l'utilisation de la technologie VLSI.
Un transputer peut être utilisé comme un système à processeur unique ou peut être connecté à des liaisons externes, ce qui réduit le coût de construction et augmente les performances.
For example - Processeurs T212 16 bits, T425 32 bits, les processeurs à virgule flottante (T800, T805 et T9000).
DSP (processeur de signal numérique)
Ce processeur est spécialement conçu pour traiter les signaux analogiques sous une forme numérique. Cela se fait en échantillonnant le niveau de tension à des intervalles de temps réguliers et en convertissant la tension à cet instant en une forme numérique. Ce processus est effectué par un circuit appelé convertisseur analogique-numérique, convertisseur A-N ou ADC.
Un DSP contient les composants suivants -
Program Memory - Il stocke les programmes que DSP utilisera pour traiter les données.
Data Memory - Il stocke les informations à traiter.
Compute Engine - Il effectue le traitement mathématique en accédant au programme à partir de la mémoire programme et aux données de la mémoire de données.
Input/Output - Il se connecte au monde extérieur.
Ses applications sont -
- Synthèse sonore et musicale
- Compression audio et vidéo
- Traitement du signal vidéo
- Accélération graphique 2D et 3D.
For example - Série TMS 320 de Texas Instrument, par exemple TMS 320C40, TMS320C50.
8085 se prononce comme microprocesseur «quatre-vingt-quatre-vingt-cinq». Il s'agit d'un microprocesseur 8 bits conçu par Intel en 1977 en utilisant la technologie NMOS.
Il a la configuration suivante -
- Bus de données 8 bits
- Bus d'adresses 16 bits, pouvant adresser jusqu'à 64 Ko
- Un compteur de programme 16 bits
- Un pointeur de pile 16 bits
- Six registres 8 bits disposés par paires: BC, DE, HL
- Nécessite une alimentation + 5V pour fonctionner à une horloge monophasée de 3,2 MHZ
Il est utilisé dans les machines à laver, les fours à micro-ondes, les téléphones portables, etc.
Microprocesseur 8085 - Unités fonctionnelles
8085 comprend les unités fonctionnelles suivantes -
Accumulateur
C'est un registre 8 bits utilisé pour effectuer des opérations arithmétiques, logiques, E / S et LOAD / STORE. Il est connecté au bus de données interne et à l'ALU.
Unité arithmétique et logique
Comme son nom l'indique, il effectue des opérations arithmétiques et logiques telles que l'addition, la soustraction, ET, OU, etc. sur des données 8 bits.
Registre à usage général
Il y a 6 registres à usage général dans le processeur 8085, c'est-à-dire B, C, D, E, H et L. Chaque registre peut contenir des données de 8 bits.
Ces registres peuvent fonctionner en paire pour contenir des données 16 bits et leur combinaison d'appariement est comme BC, DE & HL.
Compteur de programme
Il s'agit d'un registre 16 bits utilisé pour stocker l'emplacement de l'adresse mémoire de la prochaine instruction à exécuter. Le microprocesseur incrémente le programme chaque fois qu'une instruction est en cours d'exécution, de sorte que le compteur de programme pointe vers l'adresse mémoire de l'instruction suivante qui va être exécutée.
Pointeur de pile
C'est aussi un registre 16 bits qui fonctionne comme une pile, qui est toujours incrémenté / décrémenté de 2 lors des opérations push & pop.
Registre temporaire
Il s'agit d'un registre de 8 bits, qui contient les données temporaires des opérations arithmétiques et logiques.
Registre des drapeaux
Il s'agit d'un registre à 8 bits comportant cinq bascules à 1 bit, qui contient 0 ou 1 selon le résultat stocké dans l'accumulateur.
Ce sont l'ensemble de 5 tongs -
- Panneaux)
- Zéro (Z)
- Transport auxiliaire (AC)
- Parité (P)
- Porter (C)
Sa position de bit est indiquée dans le tableau suivant -
D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 |
---|---|---|---|---|---|---|---|
S | Z | AC | P | CY |
Registre d'instructions et décodeur
C'est un registre 8 bits. Lorsqu'une instruction est extraite de la mémoire, elle est stockée dans le registre d'instructions. Le décodeur d'instructions décode les informations présentes dans le registre d'instructions.
Unité de chronométrage et de contrôle
Il fournit un signal de synchronisation et de commande au microprocesseur pour effectuer des opérations. Voici les signaux de synchronisation et de contrôle, qui contrôlent les circuits externes et internes -
- Signaux de contrôle: READY, RD ', WR', ALE
- Signaux d'état: S0, S1, IO / M '
- Signaux DMA: HOLD, HLDA
- Signaux RESET: RESET IN, RESET OUT
Contrôle d'interruption
Comme son nom l'indique, il contrôle les interruptions lors d'un processus. Lorsqu'un microprocesseur exécute un programme principal et chaque fois qu'une interruption se produit, le microprocesseur décale la commande du programme principal pour traiter la demande entrante. Une fois la demande terminée, le contrôle revient au programme principal.
Il y a 5 signaux d'interruption dans le microprocesseur 8085: INTR, RST 7.5, RST 6.5, RST 5.5, TRAP.
Contrôle d'entrée / sortie série
Il contrôle la communication de données série en utilisant ces deux instructions: SID (données d'entrée série) et SOD (données de sortie série).
Tampon d'adresse et tampon de données d'adresse
Le contenu stocké dans le pointeur de pile et le compteur de programme est chargé dans le tampon d'adresse et le tampon de données d'adresse pour communiquer avec la CPU. La mémoire et les puces d'E / S sont connectées à ces bus; le CPU peut échanger les données souhaitées avec la mémoire et les puces d'E / S.
Bus d'adresses et bus de données
Le bus de données transporte les données à stocker. Il est bidirectionnel, tandis que le bus d'adresses transporte l'emplacement vers l'endroit où il doit être stocké et il est unidirectionnel. Il est utilisé pour transférer les données et adresses des périphériques d'E / S.
8085 Architecture
Nous avons essayé de représenter l'architecture de 8085 avec cette image suivante -
L'image suivante représente le diagramme des broches du microprocesseur 8085 -
Les broches d'un microprocesseur 8085 peuvent être classées en sept groupes -
Bus d'adresse
A15-A8, il transporte les 8 bits les plus significatifs d'adresse mémoire / IO.
Bus de données
AD7-AD0, il transporte l'adresse 8 bits et le bus de données les moins significatifs.
Signaux de contrôle et d'état
Ces signaux sont utilisés pour identifier la nature du fonctionnement. Il y a 3 signaux de commande et 3 signaux d'état.
Trois signaux de commande sont RD, WR et ALE.
RD - Ce signal indique que l'E / S ou le dispositif mémoire sélectionné doit être lu et est prêt à accepter les données disponibles sur le bus de données.
WR - Ce signal indique que les données sur le bus de données doivent être écrites dans une mémoire ou un emplacement IO sélectionné.
ALE- C'est une impulsion positive générée lorsqu'une nouvelle opération est lancée par le microprocesseur. Lorsque l'impulsion devient élevée, cela indique l'adresse. Lorsque l'impulsion diminue, cela indique des données.
Trois signaux d'état sont IO / M, S0 et S1.
IO / M
Ce signal est utilisé pour différencier les opérations IO et mémoire, c'est-à-dire que lorsqu'il est haut, il indique un fonctionnement IO et lorsqu'il est bas, il indique un fonctionnement en mémoire.
S1 et S0
Ces signaux sont utilisés pour identifier le type d'opération en cours.
Source de courant
Il y a 2 signaux d'alimentation - VCC et VSS. VCC indique une alimentation + 5v et VSS indique un signal de masse.
Signaux d'horloge
Il y a 3 signaux d'horloge, à savoir X1, X2, CLK OUT.
X1, X2- Un cristal (RC, LC N / W) est connecté à ces deux broches et est utilisé pour régler la fréquence du générateur d'horloge interne. Cette fréquence est divisée en interne par 2.
CLK OUT - Ce signal est utilisé comme horloge système pour les appareils connectés au microprocesseur.
Interruptions et signaux déclenchés de l'extérieur
Les interruptions sont les signaux générés par des périphériques externes pour demander au microprocesseur d'exécuter une tâche. Il existe 5 signaux d'interruption, à savoir TRAP, RST 7.5, RST 6.5, RST 5.5 et INTR. Nous discuterons des interruptions en détail dans la section interruptions.
INTA - C'est un signal d'acquittement d'interruption.
RESET IN - Ce signal est utilisé pour remettre à zéro le microprocesseur en mettant le compteur de programme à zéro.
RESET OUT - Ce signal est utilisé pour réinitialiser tous les appareils connectés lorsque le microprocesseur est réinitialisé.
READY- Ce signal indique que l'appareil est prêt à envoyer ou à recevoir des données. Si READY est bas, alors le CPU doit attendre que READY passe au niveau haut.
HOLD - Ce signal indique qu'un autre maître demande l'utilisation des bus d'adresse et de données.
HLDA (HOLD Acknowledge)- Cela indique que la CPU a reçu la demande HOLD et qu'elle abandonnera le bus au prochain cycle d'horloge. HLDA est réglé sur bas après la suppression du signal HOLD.
Signaux d'E / S série
Il existe 2 signaux série, à savoir SID et SOD et ces signaux sont utilisés pour la communication série.
SOD (Ligne de données de sortie série) - Le SOD de sortie est défini / réinitialisé comme spécifié par l'instruction SIM.
SID (Ligne de données d'entrée série) - Les données de cette ligne sont chargées dans l'accumulateur chaque fois qu'une instruction RIM est exécutée.
Parlons maintenant des modes d'adressage dans le 8085 Microprocessor.
Modes d'adressage dans 8085
Ce sont les instructions utilisées pour transférer les données d'un registre à un autre registre, de la mémoire au registre, et du registre à la mémoire sans aucune altération du contenu. Les modes d'adressage du 8085 sont classés en 5 groupes -
Mode d'adressage immédiat
Dans ce mode, les données 8/16 bits sont spécifiées dans l'instruction elle-même comme l'un de ses opérandes. For example: MVI K, 20F: signifie que 20F est copié dans le registre K.
Enregistrer le mode d'adressage
Dans ce mode, les données sont copiées d'un registre à un autre. For example: MOV K, B: signifie que les données du registre B sont copiées dans le registre K.
Mode d'adressage direct
Dans ce mode, les données sont directement copiées de l'adresse donnée vers le registre. For example: LDB 5000K: signifie que les données à l'adresse 5000K sont copiées dans le registre B.
Mode d'adressage indirect
Dans ce mode, les données sont transférées d'un registre à un autre en utilisant l'adresse pointée par le registre. For example: MOV K, B: signifie que les données sont transférées de l'adresse mémoire pointée par le registre vers le registre K.
Mode d'adressage implicite
Ce mode ne nécessite aucun opérande; les données sont spécifiées par l'opcode lui-même.For example: CMP.
Interruptions dans 8085
Les interruptions sont les signaux générés par les périphériques externes pour demander au microprocesseur d'exécuter une tâche. Il existe 5 signaux d'interruption, à savoir TRAP, RST 7.5, RST 6.5, RST 5.5 et INTR.
Les interruptions sont classées dans les groupes suivants en fonction de leur paramètre -
Vector interrupt - Dans ce type d'interruption, l'adresse d'interruption est connue du processeur. For example: RST7.5, RST6.5, RST5.5, TRAP.
Non-Vector interrupt - Dans ce type d'interruption, l'adresse d'interruption n'est pas connue du processeur donc, l'adresse d'interruption doit être envoyée en externe par l'équipement pour effectuer des interruptions. For example: INTR.
Maskable interrupt - Dans ce type d'interruption, nous pouvons désactiver l'interruption en écrivant des instructions dans le programme. For example: RST7.5, RST6.5, RST5.5.
Non-Maskable interrupt - Dans ce type d'interruption, nous ne pouvons pas désactiver l'interruption en écrivant des instructions dans le programme. For example: PRENDRE AU PIÈGE.
Software interrupt- Dans ce type d'interruption, le programmeur doit ajouter les instructions dans le programme pour exécuter l'interruption. Il y a 8 interruptions logicielles dans 8085, c'est-à-dire RST0, RST1, RST2, RST3, RST4, RST5, RST6 et RST7.
Hardware interrupt - Il y a 5 broches d'interruption dans 8085 utilisées comme interruptions matérielles, c'est-à-dire TRAP, RST7.5, RST6.5, RST5.5, INTA.
Note- NTA n'est pas une interruption, il est utilisé par le microprocesseur pour l'envoi de l'acquittement. TRAP a la priorité la plus élevée, puis RST7.5 et ainsi de suite.
Routine de service d'interruption (ISR)
Un petit programme ou une routine qui, lorsqu'il est exécuté, dessert la source d'interruption correspondante est appelé un ISR.
PRENDRE AU PIÈGE
Il s'agit d'une interruption non masquable, ayant la priorité la plus élevée parmi toutes les interruptions. Par défaut, il est activé jusqu'à ce qu'il soit reconnu. En cas d'échec, il s'exécute comme ISR et envoie les données vers la mémoire de sauvegarde. Cette interruption transfère le contrôle à l'emplacement 0024H.
RST7.5
Il s'agit d'une interruption masquable, ayant la deuxième priorité la plus élevée parmi toutes les interruptions. Lorsque cette interruption est exécutée, le processeur sauvegarde le contenu du registre PC dans la pile et passe à l'adresse 003CH.
RST 6.5
Il s'agit d'une interruption masquable, ayant la troisième priorité la plus élevée parmi toutes les interruptions. Lorsque cette interruption est exécutée, le processeur sauvegarde le contenu du registre PC dans la pile et passe à l'adresse 0034H.
RST 5,5
C'est une interruption masquable. Lorsque cette interruption est exécutée, le processeur sauvegarde le contenu du registre PC dans la pile et passe à l'adresse 002CH.
INTR
Il s'agit d'une interruption masquable, ayant la priorité la plus basse parmi toutes les interruptions. Il peut être désactivé en réinitialisant le microprocesseur.
Quand INTR signal goes high, les événements suivants peuvent se produire -
Le microprocesseur vérifie l'état du signal INTR pendant l'exécution de chaque instruction.
Lorsque le signal INTR est haut, le microprocesseur termine son instruction en cours et envoie un signal d'acquittement d'interruption bas actif.
Lorsque des instructions sont reçues, alors le microprocesseur enregistre l'adresse de l'instruction suivante sur la pile et exécute l'instruction reçue.
Jetons un œil à la programmation du microprocesseur 8085.
Les jeux d'instructions sont des codes d'instructions pour effectuer certaines tâches. Il est classé en cinq catégories.
S.No. | Instruction et description |
---|---|
1 | Instructions de contrôle Le tableau suivant présente la liste des instructions de contrôle avec leur signification. |
2 | Instructions logiques Le tableau suivant présente la liste des instructions logiques avec leur signification. |
3 | Instructions de branchement Le tableau suivant présente la liste des instructions de branchement avec leur signification. |
4 | Instructions arithmétiques Le tableau suivant présente la liste des instructions arithmétiques avec leur signification. |
5 | Instructions de transfert de données Le tableau suivant présente la liste des instructions de transfert de données avec leur signification. |
8085 - Programmes de démonstration
Maintenant, jetons un œil à quelques démonstrations de programmes en utilisant les instructions ci-dessus -
Ajout de deux nombres 8 bits
Écrivez un programme pour ajouter des données à l'emplacement de mémoire 3005H et 3006H et stocker le résultat dans l'emplacement de mémoire 3007H.
Problem demo -
(3005H) = 14H
(3006H) = 89H
Result -
14H + 89H = 9DH
Le code du programme peut être écrit comme ceci -
LXI H 3005H : "HL points 3005H"
MOV A, M : "Getting first operand"
INX H : "HL points 3006H"
ADD M : "Add second operand"
INX H : "HL points 3007H"
MOV M, A : "Store result at 3007H"
HLT : "Exit program"
Échange des emplacements de mémoire
Écrivez un programme pour échanger les données à l'emplacement mémoire de 5000M et 6000M.
LDA 5000M : "Getting the contents at5000M location into accumulator"
MOV B, A : "Save the contents into B register"
LDA 6000M : "Getting the contents at 6000M location into accumulator"
STA 5000M : "Store the contents of accumulator at address 5000M"
MOV A, B : "Get the saved contents back into A register"
STA 6000M : "Store the contents of accumulator at address 6000M"
Organiser les nombres dans un ordre croissant
Écrivez un programme pour organiser les 10 premiers nombres de l'adresse mémoire 3000H dans un ordre croissant.
MVI B, 09 :"Initialize counter"
START :"LXI H, 3000H: Initialize memory pointer"
MVI C, 09H :"Initialize counter 2"
BACK: MOV A, M :"Get the number"
INX H :"Increment memory pointer"
CMP M :"Compare number with next number"
JC SKIP :"If less, don’t interchange"
JZ SKIP :"If equal, don’t interchange"
MOV D, M
MOV M, A
DCX H
MOV M, D
INX H :"Interchange two numbers"
SKIP:DCR C :"Decrement counter 2"
JNZ BACK :"If not zero, repeat"
DCR B :"Decrement counter 1"
JNZ START
HLT :"Terminate program execution"
Le microprocesseur 8086 est une version améliorée du microprocesseur 8085 qui a été conçu par Intel en 1976. Il s'agit d'un microprocesseur 16 bits ayant 20 lignes d'adresse et 16 lignes de données qui fournit jusqu'à 1 Mo de stockage. Il se compose d'un jeu d'instructions puissant, qui fournit facilement des opérations telles que la multiplication et la division.
Il prend en charge deux modes de fonctionnement, à savoir le mode maximum et le mode minimum. Le mode maximum convient aux systèmes ayant plusieurs processeurs et le mode minimum convient aux systèmes ayant un seul processeur.
Caractéristiques du 8086
Les caractéristiques les plus importantes d'un microprocesseur 8086 sont les suivantes:
Il dispose d'une file d'attente d'instructions, capable de stocker six octets d'instructions à partir de la mémoire, ce qui accélère le traitement.
Il s'agissait du premier processeur 16 bits doté d'une ALU 16 bits, de registres 16 bits, d'un bus de données interne et d'un bus de données externe 16 bits, ce qui accéléra le traitement.
Il est disponible en 3 versions en fonction de la fréquence de fonctionnement -
8086 à 5 MHz
8086-2 → 8 MHz
(c) 8086-1 → 10 MHz
Il utilise deux étapes de pipelining, à savoir Fetch Stage et Execute Stage, ce qui améliore les performances.
L'étape de récupération peut pré-extraire jusqu'à 6 octets d'instructions et les stocke dans la file d'attente.
La phase d'exécution exécute ces instructions.
Il a 256 interruptions vectorisées.
Il se compose de 29 000 transistors.
Comparaison entre les microprocesseurs 8085 et 8086
Size - 8085 est un microprocesseur 8 bits, tandis que 8086 est un microprocesseur 16 bits.
Address Bus - 8085 a un bus d'adresse 16 bits tandis que 8086 a un bus d'adresse 20 bits.
Memory - 8085 peut accéder jusqu'à 64 Ko, tandis que 8086 peut accéder jusqu'à 1 Mo de mémoire.
Instruction - 8085 n'a pas de file d'attente d'instructions, alors que 8086 a une file d'attente d'instructions.
Pipelining - 8085 ne prend pas en charge une architecture en pipeline tandis que 8086 prend en charge une architecture en pipeline.
I/O - 8085 peut adresser 2 ^ 8 = 256 E / S, tandis que 8086 peut accéder à 2 ^ 16 = 65 536 E / S.
Cost - Le coût du 8085 est faible alors que celui du 8086 est élevé.
Architecture de 8086
Le schéma suivant illustre l'architecture d'un microprocesseur 8086 -
Le microprocesseur 8086 est divisé en deux unités fonctionnelles, à savoir, EU (Unité d'exécution) et BIU (Unité d'interface de bus).
UE (unité d'exécution)
L'unité d'exécution donne des instructions à la BIU indiquant où récupérer les données, puis décoder et exécuter ces instructions. Sa fonction est de contrôler les opérations sur les données à l'aide du décodeur d'instructions et de l'ALU. EU n'a pas de connexion directe avec les bus système comme le montre la figure ci-dessus, il effectue des opérations sur les données via BIU.
Parlons maintenant des parties fonctionnelles des microprocesseurs 8086.
ALU
Il gère toutes les opérations arithmétiques et logiques, comme les opérations +, -, ×, /, OR, AND, NOT.
Registre du drapeau
C'est un registre 16 bits qui se comporte comme une bascule, c'est-à-dire qu'il change d'état en fonction du résultat stocké dans l'accumulateur. Il a 9 drapeaux et ils sont divisés en 2 groupes - les drapeaux conditionnels et les drapeaux de contrôle.
Drapeaux conditionnels
Il représente le résultat de la dernière instruction arithmétique ou logique exécutée. Voici la liste des indicateurs conditionnels -
Carry flag - Cet indicateur indique une condition de débordement pour les opérations arithmétiques.
Auxiliary flag- Lorsqu'une opération est effectuée à ALU, il en résulte un report / barrow du quartet inférieur (c'est-à-dire D0 - D3) au quartet supérieur (c'est-à-dire D4 - D7), alors ce drapeau est mis, c'est-à-dire que le report donné par le bit D3 à D4 est Drapeau AF. Le processeur utilise cet indicateur pour effectuer une conversion binaire en BCD.
Parity flag- Ce drapeau est utilisé pour indiquer la parité du résultat, c'est-à-dire lorsque les 8 bits d'ordre inférieur du résultat contiennent un nombre pair de 1, alors le drapeau de parité est positionné. Pour un nombre impair de 1, l'indicateur de parité est réinitialisé.
Zero flag - Cet indicateur est mis à 1 lorsque le résultat d'une opération arithmétique ou logique est égal à zéro, sinon il est mis à 0.
Sign flag - Ce drapeau contient le signe du résultat, c'est-à-dire que lorsque le résultat de l'opération est négatif, alors le drapeau de signe est mis à 1 sinon mis à 0.
Overflow flag - Cet indicateur représente le résultat lorsque la capacité du système est dépassée.
Drapeaux de contrôle
Les drapeaux de contrôle contrôlent les opérations de l'unité d'exécution. Voici la liste des indicateurs de contrôle -
Trap flag- Il est utilisé pour le contrôle en une seule étape et permet à l'utilisateur d'exécuter une instruction à la fois pour le débogage. S'il est défini, le programme peut être exécuté en une seule étape.
Interrupt flag- C'est un drapeau d'activation / désactivation d'interruption, c'est-à-dire utilisé pour autoriser / interdire l'interruption d'un programme. Il est défini sur 1 pour une condition d'interruption activée et sur 0 pour une condition d'interruption désactivée.
Direction flag- Il est utilisé dans le fonctionnement des chaînes. Comme son nom l'indique lorsqu'il est défini, les octets de chaîne sont accessibles de l'adresse mémoire supérieure à l'adresse mémoire inférieure et vice-versa.
Registre à usage général
Il existe 8 registres à usage général, c'est-à-dire AH, AL, BH, BL, CH, CL, DH et DL. Ces registres peuvent être utilisés individuellement pour stocker des données 8 bits et peuvent être utilisés par paires pour stocker des données 16 bits. Les paires de registres valides sont AH et AL, BH et BL, CH et CL, et DH et DL. Il se réfère respectivement à AX, BX, CX et DX.
AX register- Il est également connu sous le nom de registre d'accumulateur. Il est utilisé pour stocker les opérandes pour les opérations arithmétiques.
BX register- Il est utilisé comme registre de base. Il est utilisé pour stocker l'adresse de base de départ de la zone de mémoire dans le segment de données.
CX register- Il est appelé compteur. Il est utilisé dans les instructions de boucle pour stocker le compteur de boucle.
DX register - Ce registre est utilisé pour contenir l'adresse du port d'E / S pour l'instruction d'E / S.
Registre de pointeur de pile
Il s'agit d'un registre 16 bits, qui contient l'adresse du début du segment à l'emplacement mémoire, où un mot a été le plus récemment stocké sur la pile.
BIU (unité d'interface de bus)
BIU prend en charge tous les transferts de données et d'adresses sur les bus pour l'UE, tels que l'envoi d'adresses, la récupération des instructions de la mémoire, la lecture des données des ports et de la mémoire ainsi que l'écriture de données sur les ports et la mémoire. EU n'a pas de connexion directionnelle avec les bus système, c'est donc possible avec la BIU. EU et BIU sont connectés au bus interne.
Il comprend les éléments fonctionnels suivants -
Instruction queue- BIU contient la file d'attente d'instructions. BIU obtient jusqu'à 6 octets d'instructions suivantes et les stocke dans la file d'attente d'instructions. Lorsque EU exécute des instructions et est prêt pour sa prochaine instruction, il lit simplement l'instruction à partir de cette file d'attente d'instructions, ce qui augmente la vitesse d'exécution.
La récupération de l'instruction suivante pendant l'exécution de l'instruction en cours est appelée pipelining.
Segment register- BIU dispose de 4 bus de segment, à savoir CS, DS, SS et ES. Il contient les adresses des instructions et des données en mémoire, qui sont utilisées par le processeur pour accéder aux emplacements mémoire. Il contient également 1 registre de pointeur IP, qui contient l'adresse de la prochaine instruction à exécuter par l'UE.
CS- Cela signifie segment de code. Il est utilisé pour adresser un emplacement mémoire dans le segment de code de la mémoire, où le programme exécutable est stocké.
DS- Il signifie segment de données. Il se compose de données utilisées par le programme et est accédé dans le segment de données par une adresse de décalage ou le contenu d'un autre registre qui contient l'adresse de décalage.
SS- Il signifie Stack Segment. Il gère la mémoire pour stocker les données et les adresses pendant l'exécution.
ES- Il signifie Extra Segment. ES est un segment de données supplémentaire, qui est utilisé par la chaîne pour contenir les données de destination supplémentaires.
Instruction pointer - C'est un registre 16 bits utilisé pour contenir l'adresse de la prochaine instruction à exécuter.
8086 était le premier microprocesseur 16 bits disponible en puce DIP (Dual Inline Package) à 40 broches. Voyons maintenant en détail la configuration des broches d'un microprocesseur 8086.
Schéma des broches 8086
Voici le schéma des broches du microprocesseur 8086 -
Parlons maintenant des signaux en détail -
Power supply and frequency signals
Il utilise une alimentation 5 V CC sur la broche 40 de V CC et la masse sur les broches 1 et 20 de V SS pour son fonctionnement.
Clock signal
Le signal d'horloge est fourni via la broche 19. Il fournit au processeur la synchronisation des opérations. Sa fréquence est différente selon les versions, à savoir 5MHz, 8MHz et 10MHz.
Address/data bus
AD0-AD15. Il s'agit de 16 bus d'adresses / de données. AD0-AD7 transporte des données d'octet d'ordre inférieur et AD8AD15 transporte des données d'octet d'ordre supérieur. Pendant le premier cycle d'horloge, il transporte une adresse de 16 bits et après cela, il transporte des données de 16 bits.
Address/status bus
A16-A19 / S3-S6. Ce sont les 4 bus d'adresse / état. Pendant le premier cycle d'horloge, il transporte une adresse de 4 bits et plus tard il transporte des signaux d'état.
S7/BHE
BHE signifie Bus High Enable. Il est disponible sur la broche 34 et utilisé pour indiquer le transfert de données à l'aide du bus de données D8-D15. Ce signal est faible pendant le premier cycle d'horloge, par la suite il est actif.
Read($\overline{RD}$)
Il est disponible sur la broche 32 et est utilisé pour lire le signal pour l'opération de lecture.
Ready
Il est disponible sur la broche 22. C'est un signal d'acquittement des périphériques d'E / S que les données sont transférées. C'est un signal haut actif. Lorsqu'il est élevé, cela indique que l'appareil est prêt à transférer des données. Lorsqu'il est bas, il indique l'état d'attente.
RESET
Il est disponible sur la broche 21 et permet de redémarrer l'exécution. Cela oblige le processeur à mettre immédiatement fin à son activité actuelle. Ce signal est actif haut pendant les 4 premiers cycles d'horloge pour RÉINITIALISER le microprocesseur.
INTR
Il est disponible sur la broche 18. Il s'agit d'un signal de demande d'interruption, qui est échantillonné pendant le dernier cycle d'horloge de chaque instruction pour déterminer si le processeur l'a considéré comme une interruption ou non.
NMI
Il signifie interruption non masquable et est disponible sur la broche 17. Il s'agit d'une entrée déclenchée par front, qui provoque une demande d'interruption au microprocesseur.
$\overline{TEST}$
Ce signal est comme l'état d'attente et est disponible sur la broche 23. Lorsque ce signal est haut, le processeur doit attendre l'état IDLE, sinon l'exécution continue.
MN/$\overline{MX}$
Il signifie Minimum / Maximum et est disponible sur la broche 33. Il indique dans quel mode le processeur doit fonctionner; quand il est élevé, il fonctionne en mode minimum et vice-aversa.
INTA
Il s'agit d'un signal d'acquittement d'interruption et d'un identifiant disponible sur la broche 24. Lorsque le microprocesseur reçoit ce signal, il acquitte l'interruption.
ALE
Il signifie verrouillage de validation d'adresse et est disponible sur la broche 25. Une impulsion positive est générée chaque fois que le processeur commence une opération. Ce signal indique la disponibilité d'une adresse valide sur les lignes d'adresse / de données.
DEN
Il signifie Data Enable et est disponible sur la broche 26. Il est utilisé pour activer le Transreceiver 8286. Le Transreceiver est un appareil utilisé pour séparer les données du bus d'adresse / de données.
DT/R
Il représente le signal de transmission / réception de données et est disponible sur la broche 27. Il décide de la direction du flux de données à travers l'émetteur-récepteur. Lorsqu'il est élevé, les données sont transmises et vice-versa.
M/IO
Ce signal est utilisé pour faire la distinction entre les opérations de mémoire et d'E / S. Lorsqu'il est élevé, il indique le fonctionnement des E / S et lorsqu'il est bas, il indique le fonctionnement de la mémoire. Il est disponible à la broche 28.
WR
Il représente le signal d'écriture et est disponible sur la broche 29. Il est utilisé pour écrire les données dans la mémoire ou le périphérique de sortie en fonction de l'état du signal M / IO.
HLDA
Il représente le signal d'accusé de réception Hold et est disponible sur la broche 30. Ce signal acquitte le signal HOLD.
HOLD
Ce signal indique au processeur que des périphériques externes demandent à accéder aux bus d'adresse / de données. Il est disponible à la broche 31.
QS1 and QS0
Ce sont des signaux d'état de la file d'attente et sont disponibles aux broches 24 et 25. Ces signaux fournissent l'état de la file d'attente d'instructions. Leurs conditions sont indiquées dans le tableau suivant -
QS 0 | QS 1 | Statut |
---|---|---|
0 | 0 | Pas d'opération |
0 | 1 | Premier octet de l'opcode de la file d'attente |
1 | 0 | Vider la file d'attente |
1 | 1 | Octet suivant de la file d'attente |
S0, S1, S2
Ce sont les signaux d'état qui fournissent l'état de fonctionnement, qui est utilisé par le contrôleur de bus 8288 pour générer des signaux de commande de mémoire et d'E / S. Ceux-ci sont disponibles aux broches 26, 27 et 28. Le tableau suivant montre leur état -
S 2 | S 1 | S 0 | Statut |
---|---|---|---|
0 | 0 | 0 | Acquittement d'interruption |
0 | 0 | 1 | Lecture d'E / S |
0 | 1 | 0 | E / S écriture |
0 | 1 | 1 | Arrêt |
1 | 0 | 0 | Récupération de l'opcode |
1 | 0 | 1 | Lecture de la mémoire |
1 | 1 | 0 | Écriture en mémoire |
1 | 1 | 1 | Passif |
LOCK
Lorsque ce signal est actif, il indique aux autres processeurs de ne pas demander à la CPU de quitter le bus système. Il est activé en utilisant le préfixe LOCK sur n'importe quelle instruction et est disponible à la broche 29.
RQ/GT1 and RQ/GT0
Ce sont les signaux Request / Grant utilisés par les autres processeurs demandant à la CPU de libérer le bus système. Lorsque le signal est reçu par la CPU, il envoie un accusé de réception. RQ / GT 0 a une priorité plus élevée que RQ / GT 1 .
Le microprocesseur 8086 prend en charge 8 types d'instructions -
- Instructions de transfert de données
- Instructions arithmétiques
- Instructions de manipulation de bits
- Instructions de chaîne
- Instructions de transfert d'exécution de programme (instructions de branche et de boucle)
- Instructions de contrôle du processeur
- Instructions de contrôle d'itération
- Instructions d'interruption
Parlons maintenant de ces jeux d'instructions en détail.
Instructions de transfert de données
Ces instructions sont utilisées pour transférer les données de l'opérande source vers l'opérande de destination. Voici la liste des instructions sous ce groupe -
Instruction pour transférer un mot
MOV - Utilisé pour copier l'octet ou le mot de la source fournie vers la destination fournie.
PPUSH - Utilisé pour mettre un mot en haut de la pile.
POP - Utilisé pour obtenir un mot du haut de la pile à l'emplacement indiqué.
PUSHA - Utilisé pour mettre tous les registres dans la pile.
POPA - Utilisé pour obtenir des mots de la pile vers tous les registres.
XCHG - Utilisé pour échanger les données de deux endroits.
XLAT - Utilisé pour traduire un octet en AL en utilisant une table en mémoire.
Instructions pour le transfert des ports d'entrée et de sortie
IN - Utilisé pour lire un octet ou un mot du port fourni vers l'accumulateur.
OUT - Utilisé pour envoyer un octet ou un mot de l'accumulateur vers le port fourni.
Instructions pour transférer l'adresse
LEA - Utilisé pour charger l'adresse de l'opérande dans le registre fourni.
LDS - Utilisé pour charger le registre DS et d'autres registres fournis à partir de la mémoire
LES - Utilisé pour charger le registre ES et d'autres registres fournis à partir de la mémoire.
Instructions pour transférer les registres d'indicateurs
LAHF - Utilisé pour charger AH avec l'octet de poids faible du registre d'indicateur.
SAHF - Utilisé pour stocker le registre AH dans l'octet de poids faible du registre d'indicateur.
PUSHF - Utilisé pour copier le registre des drapeaux en haut de la pile.
POPF - Utilisé pour copier un mot en haut de la pile dans le registre des indicateurs.
Instructions arithmétiques
Ces instructions sont utilisées pour effectuer des opérations arithmétiques telles que l'addition, la soustraction, la multiplication, la division, etc.
Voici la liste des instructions sous ce groupe -
Instructions pour effectuer l'ajout
ADD - Utilisé pour ajouter l'octet fourni à l'octet / mot au mot.
ADC - Utilisé pour ajouter avec carry.
INC - Utilisé pour incrémenter l'octet / mot fourni de 1.
AAA - Utilisé pour ajuster ASCII après l'addition.
DAA - Utilisé pour ajuster la décimale après l'opération d'addition / soustraction.
Instructions pour effectuer une soustraction
SUB - Utilisé pour soustraire l'octet de l'octet / mot du mot.
SBB - Utilisé pour effectuer une soustraction avec emprunt.
DEC - Utilisé pour décrémenter l'octet / mot fourni de 1.
NPG - Utilisé pour annuler chaque bit de l'octet / mot fourni et ajouter le complément 1/2.
CMP - Utilisé pour comparer 2 octets / mot fournis.
AAS - Utilisé pour ajuster les codes ASCII après la soustraction.
DAS - Utilisé pour ajuster la décimale après la soustraction.
Instruction pour effectuer la multiplication
MUL - Utilisé pour multiplier l'octet non signé par octet / mot par mot.
IMUL - Utilisé pour multiplier l'octet signé par octet / mot par mot.
AAM - Utilisé pour ajuster les codes ASCII après la multiplication.
Instructions pour effectuer la division
DIV - Utilisé pour diviser le mot non signé par octet ou mot double non signé par mot.
IDIV - Utilisé pour diviser le mot signé par octet ou double mot signé par mot.
AAD - Utilisé pour ajuster les codes ASCII après la division.
CBW - Utilisé pour remplir l'octet supérieur du mot avec les copies du bit de signe de l'octet inférieur.
CWD - Utilisé pour remplir le mot supérieur du mot double avec le bit de signe du mot inférieur.
Instructions de manipulation de bits
Ces instructions sont utilisées pour effectuer des opérations impliquant des bits de données, c'est-à-dire des opérations telles que logique, décalage, etc.
Voici la liste des instructions sous ce groupe -
Instructions pour effectuer une opération logique
NOT - Utilisé pour inverser chaque bit d'un octet ou d'un mot.
AND - Utilisé pour ajouter chaque bit dans un octet / mot avec le bit correspondant dans un autre octet / mot.
OR - Utilisé pour multiplier chaque bit dans un octet / mot avec le bit correspondant dans un autre octet / mot.
XOR - Utilisé pour effectuer une opération OU exclusif sur chaque bit dans un octet / mot avec le bit correspondant dans un autre octet / mot.
TEST - Utilisé pour ajouter des opérandes pour mettre à jour les indicateurs, sans affecter les opérandes.
Instructions pour effectuer les opérations de quart
SHL/SAL - Utilisé pour décaler les bits d'un octet / mot vers la gauche et mettre zéro (S) dans les LSB.
SHR - Utilisé pour décaler les bits d'un octet / mot vers la droite et mettre zéro (S) dans les MSB.
SAR - Utilisé pour décaler les bits d'un octet / mot vers la droite et copier l'ancien MSB dans le nouveau MSB.
Instructions pour effectuer des opérations de rotation
ROL - Utilisé pour faire pivoter les bits d'octet / mot vers la gauche, c'est-à-dire MSB vers LSB et vers Carry Flag [CF].
ROR - Utilisé pour faire pivoter les bits d'octet / mot vers la droite, c'est-à-dire LSB vers MSB et Carry Flag [CF].
RCR - Utilisé pour faire pivoter les bits d'octet / mot vers la droite, c'est-à-dire LSB vers CF et CF vers MSB.
RCL - Utilisé pour faire pivoter les bits d'octet / mot vers la gauche, c'est-à-dire MSB vers CF et CF vers LSB.
Instructions de chaîne
String est un groupe d'octets / mots et leur mémoire est toujours allouée dans un ordre séquentiel.
Voici la liste des instructions sous ce groupe -
REP - Utilisé pour répéter l'instruction donnée jusqu'à CX ≠ 0.
REPE/REPZ - Utilisé pour répéter l'instruction donnée jusqu'à ce que CX = 0 ou zéro drapeau ZF = 1.
REPNE/REPNZ - Utilisé pour répéter l'instruction donnée jusqu'à ce que CX = 0 ou zéro drapeau ZF = 1.
MOVS/MOVSB/MOVSW - Utilisé pour déplacer l'octet / mot d'une chaîne à une autre.
COMS/COMPSB/COMPSW - Utilisé pour comparer deux octets / mots de chaîne.
INS/INSB/INSW - Utilisé comme chaîne / octet / mot d'entrée du port d'E / S à l'emplacement de mémoire fourni.
OUTS/OUTSB/OUTSW - Utilisé comme chaîne / octet / mot de sortie de l'emplacement de mémoire fourni vers le port d'E / S.
SCAS/SCASB/SCASW - Utilisé pour scanner une chaîne et comparer son octet avec un octet dans AL ou un mot de chaîne avec un mot dans AX.
LODS/LODSB/LODSW - Utilisé pour stocker l'octet de chaîne dans AL ou le mot de chaîne dans AX.
Instructions de transfert d'exécution du programme (instructions de branchement et de boucle)
Ces instructions sont utilisées pour transférer / dériver les instructions lors d'une exécution. Il comprend les instructions suivantes -
Instructions pour transférer l'instruction lors d'une exécution sans aucune condition -
CALL - Utilisé pour appeler une procédure et enregistrer son adresse de retour dans la pile.
RET - Utilisé pour revenir de la procédure au programme principal.
JMP - Utilisé pour sauter à l'adresse fournie pour passer à l'instruction suivante.
Instructions pour transférer l'instruction lors d'une exécution avec certaines conditions -
JA/JNBE - Utilisé pour sauter si l'instruction supérieure / non inférieure / égale satisfait.
JAE/JNB - Utilisé pour sauter si l'instruction supérieure / non inférieure satisfait.
JBE/JNA - Utilisé pour sauter si une instruction inférieure / égale / non supérieure satisfait.
JC - Utilisé pour sauter si porter le drapeau CF = 1
JE/JZ - Utilisé pour sauter si drapeau égal / zéro ZF = 1
JG/JNLE - Utilisé pour sauter si une instruction supérieure / non inférieure à / égale satisfait.
JGE/JNL - Utilisé pour sauter si supérieur / égal / non inférieur à l'instruction satisfait.
JL/JNGE - Utilisé pour sauter si l'instruction inférieure / non supérieure à / égale satisfait.
JLE/JNG - Utilisé pour sauter si inférieur / égal / sinon supérieur à l'instruction satisfait.
JNC - Utilisé pour sauter si aucun drapeau de report (CF = 0)
JNE/JNZ - Utilisé pour sauter sinon égal / zéro flag ZF = 0
JNO - Utilisé pour sauter si aucun drapeau de débordement OF = 0
JNP/JPO - Utilisé pour sauter sinon parité / parité impaire PF = 0
JNS - Utilisé pour sauter sinon signer SF = 0
JO - Utilisé pour sauter si le drapeau de débordement OF = 1
JP/JPE - Utilisé pour sauter si parité / parité même PF = 1
JS - Utilisé pour sauter si le drapeau de signe SF = 1
Instructions de contrôle du processeur
Ces instructions sont utilisées pour contrôler l'action du processeur en définissant / réinitialisant les valeurs d'indicateur.
Voici les instructions sous ce groupe -
STC - Utilisé pour définir le drapeau de retenue CF sur 1
CLC - Utilisé pour effacer / remettre le drapeau de report CF à 0
CMC - Utilisé pour mettre le complément à l'état de carry flag CF.
STD - Utilisé pour mettre le drapeau de direction DF à 1
CLD - Utilisé pour effacer / remettre le drapeau de direction DF à 0
STI - Utilisé pour mettre l'indicateur d'activation d'interruption à 1, c'est-à-dire activer l'entrée INTR.
CLI - Utilisé pour effacer l'indicateur d'activation d'interruption à 0, c'est-à-dire désactiver l'entrée INTR.
Instructions de contrôle d'itération
Ces instructions sont utilisées pour exécuter les instructions données plusieurs fois. Voici la liste des instructions sous ce groupe -
LOOP - Utilisé pour boucler un groupe d'instructions jusqu'à ce que la condition soit satisfaite, c'est-à-dire CX = 0
LOOPE/LOOPZ - Utilisé pour boucler un groupe d'instructions jusqu'à ce qu'il satisfasse ZF = 1 & CX = 0
LOOPNE/LOOPNZ - Utilisé pour boucler un groupe d'instructions jusqu'à ce qu'il satisfasse ZF = 0 & CX = 0
JCXZ - Utilisé pour sauter à l'adresse fournie si CX = 0
Instructions d'interruption
Ces instructions sont utilisées pour appeler l'interruption pendant l'exécution du programme.
INT - Utilisé pour interrompre le programme pendant l'exécution et l'appel du service spécifié.
INTO - Utilisé pour interrompre le programme pendant l'exécution si OF = 1
IRET - Utilisé pour revenir du service d'interruption au programme principal
Interruptest la méthode de création d'un arrêt temporaire pendant l'exécution du programme et permet aux périphériques d'accéder au microprocesseur. Le microprocesseur répond à cette interruption par unISR (Routine de service d'interruption), qui est un programme court pour indiquer au microprocesseur comment gérer l'interruption.
L'image suivante montre les types d'interruptions que nous avons dans un microprocesseur 8086 -
Interruptions matérielles
L'interruption matérielle est provoquée par n'importe quel périphérique en envoyant un signal via une broche spécifiée au microprocesseur.
Le 8086 a deux broches d'interruption matérielle, à savoir NMI et INTR. NMI est une interruption non masquable et INTR est une interruption masquable de priorité inférieure. Une autre broche d'interruption associée est INTA appelée accusé de réception d'interruption.
NMI
Il s'agit d'une seule broche d'interruption non masquable (NMI) ayant une priorité plus élevée que la broche de demande d'interruption masquable (INTR) et elle est d'interruption de type 2.
Lorsque cette interruption est activée, ces actions ont lieu -
Termine l'instruction en cours en cours.
Pousse les valeurs du registre d'indicateur sur la pile.
Pousse la valeur CS (segment de code) et la valeur IP (pointeur d'instruction) de l'adresse de retour sur la pile.
IP est chargé à partir du contenu de l'emplacement de mot 00008H.
CS est chargé à partir du contenu de l'emplacement de mot suivant 0000AH.
L'indicateur d'interruption et l'indicateur d'interruption sont remis à 0.
INTR
L'INTR est une interruption masquable car le microprocesseur ne sera interrompu que si les interruptions sont activées à l'aide de l'instruction set interruption flag. Il ne doit pas être activé à l'aide de l'instruction Clear interruption Flag.
L'interruption INTR est activée par un port d'E / S. Si l'interruption est activée et que NMI est désactivé, le microprocesseur termine d'abord l'exécution en cours et envoie deux fois «0» sur la broche INTA. Le premier «0» signifie que INTA informe le dispositif externe de se préparer et pendant le second «0», le microprocesseur reçoit le 8 bits, disons X, du contrôleur d'interruption programmable.
Ces actions sont effectuées par le microprocesseur -
Termine d'abord l'instruction en cours.
Active la sortie INTA et reçoit le type d'interruption, disons X.
La valeur du registre d'indicateur, la valeur CS de l'adresse de retour et la valeur IP de l'adresse de retour sont poussées vers la pile.
La valeur IP est chargée à partir du contenu de l'emplacement de mot X × 4
CS est chargé à partir du contenu de l'emplacement de mot suivant.
L'indicateur d'interruption et l'indicateur d'interruption sont réinitialisés à 0
Interruptions de logiciel
Certaines instructions sont insérées à la position souhaitée dans le programme pour créer des interruptions. Ces instructions d'interruption peuvent être utilisées pour tester le fonctionnement de divers gestionnaires d'interruption. Il comprend -
INT- Instruction d'interruption avec numéro de type
C'est une instruction sur 2 octets. Le premier octet fournit le code opération et le second octet le numéro du type d'interruption. Il existe 256 types d'interruption dans ce groupe.
Son exécution comprend les étapes suivantes -
La valeur du registre d'indicateur est poussée sur la pile.
La valeur CS de l'adresse de retour et la valeur IP de l'adresse de retour sont transmises à la pile.
IP est chargé à partir du contenu du mot emplacement 'numéro de type' × 4
CS est chargé à partir du contenu de l'emplacement de mot suivant.
L'indicateur d'interruption et l'indicateur d'interruption sont remis à 0
L'adresse de départ pour l'interruption de type0 est 000000H, pour l'interruption de type1 est 00004H de même pour le type2 est 00008H et …… ainsi de suite. Les cinq premiers pointeurs sont des pointeurs d'interruption dédiés. c'est-à-dire -
TYPE 0 interruption représente une situation de division par zéro.
TYPE 1 interruption représente une exécution en une seule étape pendant le débogage d'un programme.
TYPE 2 interruption représente une interruption NMI non masquable.
TYPE 3 interruption représente l'interruption du point de rupture.
TYPE 4 interruption représente l'interruption de débordement.
Les interruptions du type 5 au type 31 sont réservées à d'autres microprocesseurs avancés, et les interruptions du type 32 au type 255 sont disponibles pour les interruptions matérielles et logicielles.
Instruction d'interruption à 3 points de rupture INT
C'est une instruction de 1 octet dont le code opération est CCH. Ces instructions sont insérées dans le programme de sorte que lorsque le processeur y parvient, il arrête l'exécution normale du programme et suit la procédure de point d'arrêt.
Son exécution comprend les étapes suivantes -
La valeur du registre d'indicateur est poussée sur la pile.
La valeur CS de l'adresse de retour et la valeur IP de l'adresse de retour sont transmises à la pile.
IP est chargé à partir du contenu de l'emplacement de mot 3 × 4 = 0000CH
CS est chargé à partir du contenu de l'emplacement de mot suivant.
L'indicateur d'interruption et l'indicateur d'interruption sont remis à 0
INTO - Interruption sur instruction de débordement
C'est une instruction de 1 octet et leur mnémonique INTO. Le code opération pour cette instruction est CEH. Comme son nom l'indique, il s'agit d'une instruction d'interruption conditionnelle, c'est-à-dire qu'elle n'est active que lorsque l'indicateur de débordement est mis à 1 et se branche sur le gestionnaire d'interruption dont le numéro de type d'interruption est 4. Si l'indicateur de débordement est réinitialisé, l'exécution se poursuit au instruction suivante.
Son exécution comprend les étapes suivantes -
Les valeurs du registre d'indicateur sont transmises à la pile.
La valeur CS de l'adresse de retour et la valeur IP de l'adresse de retour sont transmises à la pile.
IP est chargé à partir du contenu de l'emplacement de mot 4 × 4 = 00010H
CS est chargé à partir du contenu de l'emplacement de mot suivant.
L'indicateur d'interruption et l'indicateur d'interruption sont réinitialisés à 0
Les différentes manières dont un opérande source est indiqué dans une instruction sont appelées addressing modes. Il existe 8 modes d'adressage différents dans la programmation du 8086 -
Mode d'adressage immédiat
Le mode d'adressage dans lequel l'opérande de données fait partie de l'instruction elle-même est appelé mode d'adressage immédiat.
Exemple
MOV CX, 4929 H, ADD AX, 2387 H, MOV AL, FFH
Enregistrer le mode d'adressage
Cela signifie que le registre est la source d'un opérande pour une instruction.
Exemple
MOV CX, AX ; copies the contents of the 16-bit AX register into
; the 16-bit CX register),
ADD BX, AX
Mode d'adressage direct
Le mode d'adressage dans lequel l'adresse effective de l'emplacement mémoire est écrite directement dans l'instruction.
Exemple
MOV AX, [1592H], MOV AL, [0300H]
Enregistrer le mode d'adressage indirect
Ce mode d'adressage permet aux données d'être adressées à n'importe quel emplacement de mémoire via une adresse offset conservée dans l'un des registres suivants: BP, BX, DI & SI.
Exemple
MOV AX, [BX] ; Suppose the register BX contains 4895H, then the contents
; 4895H are moved to AX
ADD CX, {BX}
Mode d'adressage basé
Dans ce mode d'adressage, l'adresse d'offset de l'opérande est donnée par la somme des contenus des registres BX / BP et du déplacement 8 bits / 16 bits.
Exemple
MOV DX, [BX+04], ADD CL, [BX+08]
Mode d'adressage indexé
Dans ce mode d'adressage, l'adresse de décalage des opérandes est trouvée en ajoutant le contenu du registre SI ou DI et des déplacements 8 bits / 16 bits.
Exemple
MOV BX, [SI+16], ADD AL, [DI+16]
Mode d'adressage basé sur l'index
Dans ce mode d'adressage, l'adresse de décalage de l'opérande est calculée en additionnant le registre de base au contenu d'un registre d'index.
Exemple
ADD CX, [AX+SI], MOV AX, [AX+DI]
Basé indexé avec le mode de déplacement
Dans ce mode d'adressage, le décalage des opérandes est calculé en ajoutant le contenu du registre de base. Un index enregistre le contenu et le déplacement de 8 ou 16 bits.
Exemple
MOV AX, [BX+DI+08], ADD CX, [BX+SI+16]
Multiprocesseur signifie un ensemble multiple de processeurs qui exécute des instructions simultanément. Il existe trois configurations multiprocesseurs de base.
- Configuration du coprocesseur
- Configuration étroitement couplée
- Configuration faiblement couplée
Configuration du coprocesseur
Un coprocesseur est un circuit spécialement conçu sur puce de microprocesseur qui peut effectuer très rapidement la même tâche que le microprocesseur effectue. Cela réduit la charge de travail du processeur principal. Le coprocesseur partage la même mémoire, le même système IO, le bus, la logique de commande et le générateur d'horloge. Le coprocesseur gère des tâches spécialisées telles que les calculs mathématiques, l'affichage graphique à l'écran, etc.
Les 8086 et 8088 peuvent effectuer la plupart des opérations, mais leur jeu d'instructions n'est pas capable d'effectuer des opérations mathématiques complexes, donc dans ces cas, le microprocesseur nécessite le coprocesseur mathématique comme le coprocesseur mathématique Intel 8087, qui peut facilement effectuer ces opérations très rapidement.
Schéma fonctionnel de la configuration du coprocesseur
Comment le coprocesseur et le processeur sont-ils connectés?
Le coprocesseur et le processeur sont connectés via les signaux TEST, RQ- / GT- et QS 0 & QS 1 .
Le signal TEST est connecté à la broche BUSY du coprocesseur et les 3 broches restantes sont connectées aux 3 broches du coprocesseur du même nom.
Le signal TEST prend en charge l'activité du coprocesseur, c'est-à-dire que le coprocesseur est occupé ou inactif.
Le RT- / GT-est utilisé pour l'arbitrage de bus.
Le coprocesseur utilise QS 0 et QS 1 pour suivre l'état de la file d'attente du processeur hôte.
Configuration étroitement couplée
La configuration étroitement couplée est similaire à la configuration du coprocesseur, c'est-à-dire que les deux partagent la même mémoire, le même bus système d'E / S, la logique de commande et le générateur de commande avec le processeur hôte. Cependant, le coprocesseur et le processeur hôte récupèrent et exécutent leurs propres instructions. Le bus système est contrôlé indépendamment par le coprocesseur et le processeur hôte.
Schéma fonctionnel d'une configuration étroitement couplée
Comment le processeur et le processeur indépendant sont-ils connectés?
La communication entre l'hôte et le processeur indépendant se fait via l'espace mémoire.
Aucune des instructions n'est utilisée pour la communication, comme WAIT, ESC, etc.
Le processeur hôte gère la mémoire et réveille le processeur indépendant en envoyant des commandes à l'un de ses ports.
Ensuite, le processeur indépendant accède à la mémoire pour exécuter la tâche.
Une fois la tâche terminée, il envoie un accusé de réception au processeur hôte en utilisant le signal d'état ou une demande d'interruption.
Configuration faiblement couplée
La configuration faiblement couplée comprend le nombre de modules des systèmes à microprocesseur, qui sont connectés via un bus système commun. Chaque module se compose de son propre générateur d'horloge, de sa mémoire, de ses périphériques d'E / S et est connecté via un bus local.
Schéma fonctionnel d'une configuration faiblement couplée
Avantages
Le fait d'avoir plus d'un processeur entraîne une efficacité accrue.
Chacun des processeurs a son propre bus local pour accéder à la mémoire locale / aux périphériques d'E / S. Cela facilite la réalisation d'un traitement parallèle.
La structure du système est flexible, c'est-à-dire que la défaillance d'un module n'affecte pas la défaillance du système dans son ensemble; le module défectueux peut être remplacé ultérieurement.
Le processeur de données numériques 8087 est également connu sous le nom de Math co-processor, Numeric processor extension et Floating point unit. Il s'agissait du premier coprocesseur mathématique conçu par Intel à s'associer au 8086/8088, ce qui permettait un calcul plus facile et plus rapide.
Une fois les instructions identifiées par le processeur 8086/8088, elles sont attribuées au coprocesseur 8087 pour une exécution ultérieure.
Les types de données pris en charge par 8087 sont -
- Entiers binaires
- Nombres décimaux emballés
- Nombres réels
- Format réel temporaire
Les caractéristiques les plus importantes du processeur de données numériques 8087 sont les suivantes:
Il prend en charge les données de type entier, flottant et réel allant de 2 à 10 octets.
La vitesse de traitement est si élevée qu'il peut calculer la multiplication de deux nombres réels 64 bits en ~ 27 µs et peut également calculer la racine carrée en ~ 35 µs.
Il suit les normes de virgule flottante IEEE.
8087 Architecture
8087 L'architecture est divisée en deux groupes, à savoir, Control Unit (CU) et Numeric Extension Unit (NEU).
le control unit gère toutes les communications entre le processeur et la mémoire comme il reçoit et décode les instructions, lit et écrit les opérandes de la mémoire, maintient la file d'attente parallèle, etc. Toutes les instructions du coprocesseur sont des instructions ESC, c'est-à-dire qu'elles commencent par 'F', le coprocesseur uniquement exécute les instructions ESC tandis que d'autres instructions sont exécutées par le microprocesseur.
le numeric extension unitgère toutes les instructions du processeur numérique telles que les instructions arithmétiques, logiques, transcendantales et de transfert de données. Il a 8 pile de registres, qui contient les opérandes pour les instructions et leurs résultats.
L'architecture du coprocesseur 8087 est la suivante -
Description de la broche 8087
Jetons d'abord un coup d'œil au diagramme des broches de 8087 -
La liste suivante fournit la description des broches du 8087 -
AD0 – AD15 - Ce sont les lignes d'adresse / de données multiplexées dans le temps, qui transportent des adresses pendant le premier cycle d'horloge et des données à partir du deuxième cycle d'horloge.
A19 / S6 – A16/S- Ces lignes sont les lignes d'adresse / d'état multiplexées dans le temps. Il fonctionne de manière similaire aux broches correspondantes du 8086. Les S 6 , S 4 et S3 sont en permanence au niveau haut, tandis que le S 5 est en permanence au niveau bas.
$\overline{BHE}$/S7 - Pendant le premier cycle d'horloge, le $\overline{BHE}$/ S 7 est utilisé pour activer les données sur l'octet supérieur du bus de données 8086 et fonctionne ensuite comme ligne d'état S 7 .
QS1, QS0 - Ce sont des signaux d'entrée d'état de la file d'attente qui fournissent l'état de la file d'attente d'instructions, leurs conditions comme indiqué dans le tableau suivant -
QS 0 | QS 1 | Statut |
---|---|---|
0 | 0 | Pas d'opération |
0 | 1 | Premier octet de l'opcode de la file d'attente |
1 | 0 | Vider la file d'attente |
1 | 1 | Octet suivant de la file d'attente |
INT - Il s'agit d'un signal d'interruption, qui passe à l'état haut lorsqu'une exception non masquée a été reçue pendant l'exécution.
BUSY - C'est un signal de sortie, lorsqu'il est haut, il indique un état occupé à la CPU.
READY - C'est un signal d'entrée utilisé pour informer le coprocesseur si le bus est prêt à recevoir des données ou non.
RESET - Il s'agit d'un signal d'entrée utilisé pour rejeter les activités internes du coprocesseur et le préparer pour une exécution ultérieure chaque fois que la CPU l'exige.
CLK - L'entrée CLK fournit les horaires de base pour le fonctionnement du processeur.
VCC - C'est un signal d'alimentation, qui nécessite une alimentation + 5V pour le fonctionnement du circuit.
S0, S1, S2- Ce sont les signaux d'état qui fournissent l'état de l'opération qui est utilisé par le contrôleur de bus 8087 pour générer des signaux de commande de mémoire et d'E / S. Ces signaux sont actifs pendant le quatrième cycle d'horloge.
S 2 | S 1 | S 0 | État de la file d'attente |
---|---|---|---|
0 | X | X | Inutilisé |
1 | 0 | 0 | Inutilisé |
1 | 0 | 1 | Lecture de la mémoire |
1 | 1 | 0 | Écriture en mémoire |
1 | 1 | 1 | Passif |
RQ/GT1 & RQ/GT0 - Ce sont les Request/Grant signaux utilisés par les processeurs 8087 pour obtenir le contrôle du bus à partir du processeur hôte 8086/8088 pour les transferts d'opérandes.
Dans ce chapitre, nous aborderons l'interface mémoire et l'interface IO avec le 8085.
Interfaceest le chemin de communication entre deux composants. L'interface est de deux types, l'interfaçage mémoire et l'interfaçage E / S.
Interfaçage de la mémoire
Lorsque nous exécutons une instruction, nous avons besoin du microprocesseur pour accéder à la mémoire pour lire les codes d'instructions et les données stockées dans la mémoire. Pour cela, la mémoire et le microprocesseur ont besoin de certains signaux pour lire et écrire dans les registres.
Le processus d'interfaçage comprend certains facteurs clés pour correspondre aux besoins en mémoire et aux signaux du microprocesseur. Le circuit d'interface doit donc être conçu de telle manière qu'il corresponde aux exigences de signal de mémoire avec les signaux du microprocesseur.
Interfaçage IO
Il existe divers appareils de communication comme le clavier, la souris, l'imprimante, etc. Nous devons donc interfacer le clavier et d'autres appareils avec le microprocesseur en utilisant des verrous et des tampons. Ce type d'interface est appelé interface E / S.
Schéma fonctionnel de l'interface mémoire et E / S
8085 Broches d'interfaçage
Voici la liste des 8085 broches utilisées pour l'interfaçage avec d'autres appareils -
- A 15 - A 8 (bus d'adresse supérieure)
- AD 7 - AD 0 (adresse inférieure / bus de données)
- ALE
- RD
- WR
- READY
Moyens de communication - Microprocesseur avec le monde extérieur?
Le microprocesseur peut se connecter avec le monde extérieur de deux manières.
- Interface de communication série
- Interface de communication parallèle
Serial Communication Interface - Dans ce type de communication, l'interface récupère un seul octet de données du microprocesseur et l'envoie bit à bit à l'autre système en série et vice-versa.
Parallel Communication Interface - Dans ce type de communication, l'interface récupère un octet de données du microprocesseur et l'envoie bit à bit aux autres systèmes de façon simultanée (ou) parallèle et vice-versa.
Le contrôleur de clavier / affichage programmable 8279 est conçu par Intel qui interface un clavier avec le processeur. Le clavier scanne d'abord le clavier et identifie si une touche a été enfoncée. Il envoie alors leur réponse relative de la touche enfoncée au CPU et vice-versa.
De combien de façons le clavier est-il interfacé avec le processeur?
Le clavier peut être interfacé soit en mode interruption, soit en mode interrogé. dans leInterrupt mode, le processeur ne reçoit une demande de service que si une touche est enfoncée, sinon le CPU continuera sa tâche principale.
dans le Polled mode, la CPU lit périodiquement un drapeau interne de 8279 pour vérifier si une touche est enfoncée ou non avec une pression de touche.
Comment fonctionne le clavier 8279?
Le clavier se compose de 64 touches au maximum, qui sont interfacées avec le CPU en utilisant les codes de touches. Ces codes-clés sont annulés et stockés dans une FIFORAM de 8 octets, accessible par le CPU. Si plus de 8 caractères sont entrés dans la FIFO, cela signifie que plus de huit touches sont enfoncées à la fois. C'est à ce moment que l'état de dépassement est défini.
Si un FIFO contient une entrée de clé valide, alors la CPU est interrompue dans un mode d'interruption sinon la CPU vérifie l'état dans l'interrogation pour lire l'entrée. Une fois que la CPU lit une entrée de clé, la FIFO est mise à jour et l'entrée de clé est poussée hors de la FIFO pour générer de l'espace pour les nouvelles entrées.
Architecture et description
Contrôle E / S et tampon de données
Cette unité contrôle le flux de données à travers le microprocesseur. Il n'est activé que lorsque D est faible. Son tampon de données interface le bus externe du système avec le bus interne du microprocesseur. Les broches A0, RD et WR sont utilisées pour les opérations de commande, d'état ou de lecture / écriture de données.
Contrôle et registre de synchronisation et contrôle de synchronisation
Cet appareil contient des registres pour stocker le clavier, les modes d'affichage et d'autres opérations programmées par l'UC. L'unité de chronométrage et de commande gère les minutages pour le fonctionnement du circuit.
Compteur de scan
Il a deux modes ie Encoded modeet mode décodé. Dans le mode codé, le compteur fournit le compte binaire qui doit être décodé de manière externe pour fournir les lignes de balayage pour le clavier et l'affichage.
dans le decoded scan mode, le compteur décode en interne les 2 bits les moins significatifs et fournit un balayage décodé 1 sur 4 sur SL 0 -SL 3 .
Tampons de retour, anti-rebond du clavier et contrôle
Cette unité scanne d'abord la fermeture de clé par ligne, si elle est trouvée, l'unité anti-rebond du clavier résout l'entrée de clé. Dans le cas où la même clé est détectée, le code de cette clé est directement transféré dans la RAM du capteur avec l'état de la touche SHIFT & CONTROL.
RAM FIFO / capteur et logique d'état
Cette unité agit comme une mémoire RAM FIFO (first-in-first-out) de 8 octets où le code de chaque touche enfoncée est entré dans la RAM selon leur séquence. La logique d'état génère une demande d'interruption après chaque opération de lecture FIFO jusqu'à ce que la FIFO soit vide.
En mode matrice de capteurs scannés, cette unité agit comme une RAM de capteur où chaque rangée est chargée avec l'état de leur rangée correspondante de capteurs dans la matrice. Lorsque le capteur change d'état, la ligne IRQ passe à l'état haut et interrompt le processeur.
Afficher les registres d'adresses et afficher la RAM
Cette unité se compose de registres d'adresses d'affichage qui contiennent les adresses du mot actuellement lu / écrit par la CPU vers / depuis la RAM d'affichage.
8279 - Description des broches
La figure suivante montre le schéma des broches du 8279 -
Lignes de bus de données, DB 0 - DB 7
Il s'agit de 8 lignes de bus de données bidirectionnelles utilisées pour transférer les données vers / depuis la CPU.
CLK
L'entrée d'horloge est utilisée pour générer les synchronisations internes requises par le microprocesseur.
RÉINITIALISER
Comme son nom l'indique, cette broche est utilisée pour réinitialiser le microprocesseur.
CS Chip Select
Lorsque cette broche est réglée sur bas, elle permet les opérations de lecture / écriture, sinon cette broche doit être réglée sur haut.
A 0
Cette broche indique le transfert des informations de commande / état. Lorsqu'il est bas, cela indique le transfert de données.
RD, WR
Cette broche de lecture / écriture permet au tampon de données d'envoyer / de recevoir des données sur le bus de données.
IRQ
Cette ligne de sortie d'interruption passe à l'état haut lorsqu'il y a des données dans la RAM du capteur FIFO. La ligne d'interruption passe au niveau bas à chaque opération de lecture de la RAM FIFO. Cependant, si la RAM FIFO contient en outre une entrée de code clé à lire par la CPU, cette broche devient à nouveau haut pour générer une interruption vers la CPU.
V ss , V cc
Ce sont les lignes de masse et d'alimentation du microprocesseur.
SL 0 à SL 3
Ce sont les lignes de balayage utilisées pour balayer la matrice du clavier et afficher les chiffres. Ces lignes peuvent être programmées comme codées ou décodées, en utilisant le registre de contrôle de mode.
RL 0 - RL 7
Ce sont les lignes de retour qui sont connectées à un terminal de touches, tandis que l'autre terminal de touches est connecté aux lignes de balayage décodées. Ces lignes sont mises à 0 lorsqu'une touche est enfoncée.
DÉCALAGE
L'état de la ligne d'entrée Shift est stocké avec chaque code de touche dans FIFO en mode clavier scanné. Jusqu'à ce qu'il soit tiré bas avec une fermeture à clé, il est tiré vers le haut pour le maintenir haut
CNTL / STB - Mode CONTROL / STROBED I / P
En mode clavier, cette ligne est utilisée comme entrée de commande et stockée dans FIFO lors d'une fermeture de touche. La ligne est une ligne stroboscopique qui entre les données dans la RAM FIFO, en mode d'entrée stroboscopique. Il a une traction interne. La ligne est tirée vers le bas avec une fermeture à clé.
BD
Il signifie affichage vierge. Il est utilisé pour masquer l'affichage pendant la commutation de chiffres.
OUTA 0 - OUTA 3 et OUTB 0 - OUTB 3
Ce sont les ports de sortie pour deux registres de rafraîchissement d'affichage interne 16x4 ou un 16x8. Les données de ces lignes sont synchronisées avec les lignes de balayage pour balayer l'écran et le clavier.
Modes de fonctionnement du 8279
Il existe deux modes de fonctionnement sur 8279 - Input Mode et Output Mode.
Mode d'entrée
Ce mode traite de l'entrée donnée par le clavier et ce mode est en outre classé en 3 modes.
Scanned Keyboard Mode- Dans ce mode, la matrice de touches peut être interfacée à l'aide de balayages codés ou décodés. Dans le scan encodé, un clavier 8 × 8 ou dans le scan décodé, un clavier 4 × 8 peut être interfacé. Le code de la touche enfoncée avec l'état SHIFT et CONTROL est stocké dans la RAM FIFO.
Scanned Sensor Matrix- Dans ce mode, un réseau de capteurs peut être interfacé avec le processeur en utilisant des balayages d'encodeur ou de décodeur. Dans le balayage de l'encodeur, une matrice de capteurs 8 × 8 ou avec une matrice de capteurs 4 × 8 à balayage de décodeur peut être interfacée.
Strobed Input - Dans ce mode, lorsque la ligne de contrôle est mise à 0, les données sur les lignes de retour sont stockées dans la FIFO octet par octet.
Mode de sortie
Ce mode traite des opérations liées à l'affichage. Ce mode est en outre classé en deux modes de sortie.
Display Scan - Ce mode permet aux affichages multiplexés 8/16 caractères d'être organisés en deux unités d'affichage 4 bits / 8 bits simples.
Display Entry - Ce mode permet de saisir les données pour les afficher depuis le côté droit / gauche.
DMA signifie Direct Memory Access. Il est conçu par Intel pour transférer des données au rythme le plus rapide. Il permet à l'appareil de transférer les données directement vers / depuis la mémoire sans aucune interférence du CPU.
À l'aide d'un contrôleur DMA, l'appareil demande au CPU de conserver ses données, son adresse et son bus de contrôle, de sorte que l'appareil est libre de transférer des données directement vers / depuis la mémoire. Le transfert de données DMA est lancé uniquement après réception du signal HLDA de la CPU.
Comment les opérations DMA sont-elles effectuées?
Voici la séquence des opérations effectuées par un DMA -
Au départ, lorsqu'un appareil doit envoyer des données entre l'appareil et la mémoire, l'appareil doit envoyer une requête DMA (DRQ) au contrôleur DMA.
Le contrôleur DMA envoie une demande de maintien (HRQ) à la CPU et attend que la CPU confirme le HLDA.
Ensuite, le microprocesseur tri-états tous les bus de données, bus d'adresses et bus de contrôle. La CPU quitte le contrôle sur le bus et acquitte la demande HOLD via le signal HLDA.
Le CPU est maintenant à l'état HOLD et le contrôleur DMA doit gérer les opérations sur les bus entre le CPU, la mémoire et les périphériques d'E / S.
Caractéristiques du 8257
Voici une liste de quelques-unes des principales caractéristiques du 8257 -
Il dispose de quatre canaux qui peuvent être utilisés sur quatre périphériques d'E / S.
Chaque canal a une adresse 16 bits et un compteur 14 bits.
Chaque canal peut transférer des données jusqu'à 64 Ko.
Chaque canal peut être programmé indépendamment.
Chaque canal peut effectuer un transfert en lecture, un transfert en écriture et vérifier les opérations de transfert.
Il génère un signal MARK vers le périphérique indiquant que 128 octets ont été transférés.
Il nécessite une horloge monophasée.
Sa fréquence varie de 250 Hz à 3 MHz.
Il fonctionne en 2 modes, à savoir, Master mode et Slave mode.
8257 Architecture
L'image suivante montre l'architecture du 8257 -
8257 Description des broches
L'image suivante montre le schéma des broches d'un contrôleur DMA 8257 -
DRQ 0 −DRQ3
Ce sont les quatre entrées de demande DMA de canal individuel, qui sont utilisées par les périphériques pour utiliser les services DMA. Lorsque le mode de priorité fixe est sélectionné, alors DRQ 0 a la priorité la plus élevée et DRQ 3 a la priorité la plus basse parmi eux.
DACK o - DACK 3
Ce sont les lignes d'accusé de réception DMA actif-bas, qui mettent à jour le périphérique demandeur sur l'état de sa demande par la CPU. Ces lignes peuvent également servir de lignes stroboscopiques pour les appareils demandeurs.
D o - D 7
Ce sont des lignes de données bidirectionnelles qui sont utilisées pour interfacer le bus système avec le bus de données interne du contrôleur DMA. En mode Esclave, il porte les mots de commande à 8257 et le mot d'état à 8257. En mode maître, ces lignes sont utilisées pour envoyer l'octet supérieur de l'adresse générée à la bascule. Cette adresse est en outre verrouillée à l'aide du signal ADSTB.
IOR
Il s'agit d'une ligne d'entrée à trois états bidirectionnelle active-low, qui est utilisée par la CPU pour lire les registres internes de 8257 en mode esclave. En mode maître, il est utilisé pour lire les données des périphériques pendant un cycle d'écriture mémoire.
IOW
Il s'agit d'une ligne active à trois états bidirectionnelle basse, qui est utilisée pour charger le contenu du bus de données dans le registre de mode 8 bits ou l'octet supérieur / inférieur d'un registre d'adresse DMA 16 bits ou d'un registre de comptage de terminaux. En mode maître, il est utilisé pour charger les données sur les périphériques pendant le cycle de lecture de la mémoire DMA.
CLK
Il s'agit d'un signal de fréquence d'horloge nécessaire au fonctionnement interne du 8257.
RÉINITIALISER
Ce signal est utilisé pour RÉINITIALISER le contrôleur DMA en désactivant tous les canaux DMA.
A o - A 3
Ce sont les quatre lignes d'adresse les moins significatives. En mode esclave, ils agissent comme une entrée, qui sélectionne l'un des registres à lire ou à écrire. En mode maître, ce sont les quatre lignes de sortie d'adresse mémoire les moins significatives générées par 8257.
CS
Il s'agit d'une ligne de sélection de puce active-low. En mode esclave, il active les opérations de lecture / écriture vers / depuis 8257. En mode maître, il désactive les opérations de lecture / écriture vers / depuis 8257.
A 4 - A 7
Il s'agit du quartet le plus élevé de l'adresse d'octet inférieur généré par DMA en mode maître.
PRÊT
Il s'agit d'un signal d'entrée asynchrone actif-haut, qui prépare le DMA en insérant des états d'attente.
HRQ
Ce signal est utilisé pour recevoir le signal de demande de maintien du périphérique de sortie. En mode esclave, il est connecté à une ligne d'entrée DRQ 8257. En mode maître, il est connecté à l'entrée HOLD de la CPU.
HLDA
C'est le signal d'acquittement de maintien qui indique au contrôleur DMA que le bus a été accordé au périphérique demandeur par la CPU lorsqu'il est mis à 1.
MEMR
C'est le signal de lecture de mémoire faible, qui est utilisé pour lire les données à partir des emplacements de mémoire adressés pendant les cycles de lecture DMA.
MEMW
C'est le signal à trois états actif-bas qui est utilisé pour écrire les données dans l'emplacement de mémoire adressé pendant l'opération d'écriture DMA.
ADST
Ce signal est utilisé pour convertir l'octet supérieur de l'adresse mémoire générée par le contrôleur DMA en verrous.
AEN
Ce signal est utilisé pour désactiver le bus d'adresse / bus de données.
TC
Il signifie «Terminal Count», qui indique le cycle DMA actuel vers les périphériques actuels.
MARQUE
La marque sera activée après chaque 128 cycles ou des multiples entiers de celui-ci depuis le début. Il indique que le cycle DMA actuel est le 128e cycle depuis la sortie MARK précédente vers le périphérique sélectionné.
V cc
C'est le signal de puissance qui est nécessaire au fonctionnement du circuit.
UNE microcontroller est un micro-ordinateur petit et peu coûteux, conçu pour effectuer les tâches spécifiques des systèmes embarqués comme l'affichage des informations sur les micro-ondes, la réception de signaux à distance, etc.
Le microcontrôleur général se compose du processeur, de la mémoire (RAM, ROM, EPROM), des ports série, des périphériques (minuteries, compteurs), etc.
Différence entre microprocesseur et microcontrôleur
Le tableau suivant met en évidence les différences entre un microprocesseur et un microcontrôleur -
Microcontrôleur | Microprocesseur |
---|---|
Les microcontrôleurs sont utilisés pour exécuter une seule tâche dans une application. | Les microprocesseurs sont utilisés pour les grandes applications. |
Son coût de conception et de matériel est faible. | Son coût de conception et de matériel est élevé. |
Facile à remplacer. | Pas si facile à remplacer. |
Il est construit avec la technologie CMOS, qui nécessite moins d'énergie pour fonctionner. | Sa consommation électrique est élevée car il doit contrôler l'ensemble du système. |
Il se compose de ports CPU, RAM, ROM et E / S. | Il ne se compose pas de RAM, ROM, ports d'E / S. Il utilise ses broches pour s'interfacer avec des périphériques. |
Types de microcontrôleurs
Les microcontrôleurs sont divisés en différentes catégories basées sur la mémoire, l'architecture, les bits et les jeux d'instructions. Voici la liste de leurs types -
Bit
Sur la base de la configuration des bits, le microcontrôleur est divisé en trois catégories.
8-bit microcontroller - Ce type de microcontrôleur est utilisé pour exécuter des opérations arithmétiques et logiques comme l'addition, la soustraction, la division de multiplication, etc. Par exemple, les Intel 8031 et 8051 sont des microcontrôleurs 8 bits.
16-bit microcontroller- Ce type de microcontrôleur est utilisé pour effectuer des opérations arithmétiques et logiques où une précision et des performances plus élevées sont requises. Par exemple, Intel 8096 est un microcontrôleur 16 bits.
32-bit microcontroller - Ce type de microcontrôleur est généralement utilisé dans les appareils à commande automatique comme les machines opérationnelles automatiques, les appareils médicaux, etc.
Mémoire
Sur la base de la configuration de la mémoire, le microcontrôleur est divisé en deux catégories.
External memory microcontroller- Ce type de microcontrôleur est conçu de manière à ne pas avoir de mémoire programme sur la puce. Par conséquent, il est nommé microcontrôleur de mémoire externe. Par exemple: microcontrôleur Intel 8031.
Embedded memory microcontroller- Ce type de microcontrôleur est conçu de telle manière que le microcontrôleur dispose de tous les programmes et de la mémoire de données, des compteurs et des minuteries, des interruptions, des ports d'E / S sont intégrés sur la puce. Par exemple: microcontrôleur Intel 8051.
Jeu d'instructions
Sur la base de la configuration du jeu d'instructions, le microcontrôleur est divisé en deux catégories.
CISC- CISC signifie ordinateur à jeu d'instructions complexe. Il permet à l'utilisateur d'insérer une seule instruction comme alternative à de nombreuses instructions simples.
RISC- RISC signifie Reduced Instruction Set Computers. Il réduit le temps de fonctionnement en raccourcissant le cycle d'horloge par instruction.
Applications des microcontrôleurs
Les microcontrôleurs sont largement utilisés dans divers appareils tels que -
Dispositifs de détection et de contrôle de la lumière comme les LED.
Dispositifs de détection et de contrôle de la température comme le four à micro-ondes, les cheminées.
Détection d'incendie et dispositifs de sécurité comme l'alarme incendie.
Appareils de mesure comme le voltmètre.
Le microcontrôleur 8051 est conçu par Intel en 1981. Il s'agit d'un microcontrôleur 8 bits. Il est construit avec 40 broches DIP (double paquet en ligne), 4 Ko de stockage ROM et 128 octets de stockage RAM, 2 minuteries 16 bits. Il se compose de quatre ports 8 bits parallèles, programmables et adressables selon les besoins. Un oscillateur à cristal sur puce est intégré dans le microcontrôleur ayant une fréquence de cristal de 12 MHz.
Parlons maintenant de l'architecture du 8051 Microcontroller.
Dans le schéma suivant, le bus système relie tous les appareils de support à la CPU. Le bus système se compose d'un bus de données 8 bits, d'un bus d'adresse 16 bits et de signaux de commande de bus. Tous les autres périphériques tels que la mémoire programme, les ports, la mémoire de données, l'interface série, le contrôle d'interruption, les minuteries et le processeur sont tous interfacés ensemble via le bus système.
Le diagramme des broches du microcontrôleur 8051 se présente comme suit:
Pins 1 to 8- Ces broches sont connues sous le nom de Port 1. Ce port ne remplit aucune autre fonction. Il s'agit d'un port d'E / S bidirectionnel tiré en interne.
Pin 9 - C'est une broche RESET, qui est utilisée pour réinitialiser le microcontrôleur à ses valeurs initiales.
Pins 10 to 17 - Ces broches sont connues sous le nom de Port 3. Ce port remplit certaines fonctions telles que les interruptions, l'entrée de minuterie, les signaux de commande, les signaux de communication série RxD et TxD, etc.
Pins 18 & 19 - Ces broches sont utilisées pour interfacer un cristal externe pour obtenir l'horloge du système.
Pin 20 - Cette broche fournit l'alimentation électrique du circuit.
Pins 21 to 28- Ces broches sont appelées Port 2. Il sert de port E / S. Les signaux de bus d'adresse d'ordre supérieur sont également multiplexés à l'aide de ce port.
Pin 29- Il s'agit de la broche PSEN qui signifie Program Store Enable. Il est utilisé pour lire un signal de la mémoire programme externe.
Pin 30- Il s'agit de la broche EA qui correspond à l'entrée d'accès externe. Il est utilisé pour activer / désactiver l'interfaçage de la mémoire externe.
Pin 31- Ceci est la broche ALE qui signifie Address Latch Enable. Il est utilisé pour démultiplexer le signal de données d'adresse du port.
Pins 32 to 39- Ces broches sont appelées Port 0. Il sert de port E / S. Les signaux d'adresse et de bus de données d'ordre inférieur sont multiplexés à l'aide de ce port.
Pin 40 - Cette broche est utilisée pour alimenter le circuit.
Les microcontrôleurs 8051 ont 4 ports E / S chacun de 8 bits, qui peuvent être configurés comme entrée ou sortie. Par conséquent, un total de 32 broches d'entrée / sortie permet au microcontrôleur d'être connecté aux périphériques.
Pin configuration, c'est-à-dire que la broche peut être configurée comme 1 pour l'entrée et 0 pour la sortie selon l'état logique.
Input/Output (I/O) pin - Tous les circuits du microcontrôleur doivent être connectés à l'une de ses broches à l'exception du port P0 car il n'a pas de résistances de rappel intégrées.
Input pin- La logique 1 est appliquée à un bit du registre P. Le transistor FE de sortie est bloqué et l'autre broche reste connectée à la tension d'alimentation via une résistance pull-up de haute résistance.
Port 0 - Le port P0 (zéro) est caractérisé par deux fonctions -
Lorsque la mémoire externe est utilisée, l'octet d'adresse inférieur (adresses A0A7) y est appliqué, sinon tous les bits de ce port sont configurés en entrée / sortie.
Lorsque le port P0 est configuré en tant que sortie, puis d'autres ports constitués de broches avec une résistance de rappel intégrée connectée par son extrémité à une alimentation 5V, les broches de ce port ont cette résistance laissée de côté.
Configuration d'entrée
Si une broche de ce port est configurée comme entrée, elle agit comme si elle «flottait», c'est-à-dire que l'entrée a une résistance d'entrée illimitée et un potentiel indéterminé.
Configuration de sortie
Lorsque la broche est configurée comme sortie, elle agit comme un «drain ouvert». En appliquant la logique 0 à un bit de port, la broche appropriée sera connectée à la masse (0V), et en appliquant la logique 1, la sortie externe restera «flottante».
Afin d'appliquer la logique 1 (5 V) sur cette broche de sortie, il est nécessaire de construire une résistance de tirage externe.
Port 1
P1 est un vrai port d'E / S car il n'a pas de fonctions alternatives comme dans P0, mais ce port peut être configuré comme E / S générale uniquement. Il a une résistance de pull-up intégrée et est entièrement compatible avec les circuits TTL.
Port 2
P2 est similaire à P0 lorsque la mémoire externe est utilisée. Les broches de ce port occupent des adresses destinées à la puce de mémoire externe. Ce port peut être utilisé pour l'octet d'adresse supérieur avec les adresses A8-A15. Lorsqu'aucune mémoire n'est ajoutée, ce port peut être utilisé comme port d'entrée / sortie général similaire au port 1.
Port 3
Dans ce port, les fonctions sont similaires aux autres ports, sauf que le 1 logique doit être appliqué au bit approprié du registre P3.
Limitations actuelles des broches
Lorsque les broches sont configurées en tant que sortie (c.-à-d. Logique 0), les broches à port unique peuvent recevoir un courant de 10 mA.
Lorsque ces broches sont configurées en tant qu'entrées (c'est-à-dire logique 1), les résistances de rappel intégrées fournissent un courant très faible, mais peuvent activer jusqu'à 4 entrées TTL de la série LS.
Si les 8 bits d'un port sont actifs, le courant total doit être limité à 15 mA (port P0: 26 mA).
Si tous les ports (32 bits) sont actifs, le courant maximal total doit être limité à 71 mA.
Les interruptions sont les événements qui suspendent temporairement le programme principal, passent le contrôle aux sources externes et exécutent leur tâche. Il passe ensuite le contrôle au programme principal là où il s'était arrêté.
8051 a 5 signaux d'interruption, à savoir INT0, TFO, INT1, TF1, RI / TI. Chaque interruption peut être activée ou désactivée en définissant des bits du registre IE et l'ensemble du système d'interruption peut être désactivé en effaçant le bit EA du même registre.
Registre IE (Interruption Enable)
Ce registre est responsable de l'activation et de la désactivation de l'interruption. Le registre EA est défini sur un pour activer les interruptions et sur 0 pour désactiver les interruptions. Sa séquence de bits et leur signification sont illustrées dans la figure suivante.
EA | IE.7 | Il désactive toutes les interruptions. Lorsque EA = 0, aucune interruption n'est acquittée et EA = 1 active l'interruption individuellement. |
- | IE.6 | Réservé pour une utilisation future. |
- | IE.5 | Réservé pour une utilisation future. |
ES | IE.4 | Active / désactive l'interruption du port série. |
ET1 | IE.3 | Active / désactive l'interruption de dépassement du timer1. |
EX1 | IE.2 | Active / désactive l'interruption externe 1. |
ET0 | IE.1 | Active / désactive l'interruption de débordement timer0. |
EX0 | IE.0 | Active / désactive l'interruption externe 0. |
Registre IP (priorité d'interruption)
Nous pouvons changer les niveaux de priorité des interruptions en changeant le bit correspondant dans le registre de priorité d'interruption (IP) comme indiqué dans la figure suivante.
Une interruption de faible priorité ne peut être interrompue que par l'interruption de priorité élevée, mais pas par une autre interruption de faible priorité.
Si deux interruptions de niveaux de priorité différents sont reçues simultanément, la demande de niveau de priorité supérieur est servie.
Si les demandes des mêmes niveaux de priorité sont reçues simultanément, alors la séquence d'interrogation interne détermine quelle demande doit être traitée.
- | IP.6 | Réservé pour une utilisation future. |
- | IP.5 | Réservé pour une utilisation future. |
PS | IP.4 | Il définit le niveau de priorité d'interruption du port série. |
PT1 | IP.3 | Il définit l'interruption du temporisateur de 1 priorité. |
PX1 | IP.2 | Il définit le niveau de priorité d'interruption externe. |
PT0 | IP.1 | Il définit le niveau de priorité d'interruption timer0. |
PX0 | IP.0 | Il définit l'interruption externe de niveau de priorité 0. |
Registre TCON
Le registre TCON spécifie le type d'interruption externe au microcontrôleur.
Le 8255A est un dispositif d'E / S programmables à usage général conçu pour transférer les données d'E / S pour interrompre les E / S dans certaines conditions selon les besoins. Il peut être utilisé avec presque tous les microprocesseurs.
Il se compose de trois ports E / S bidirectionnels 8 bits (lignes 24 E / S) qui peuvent être configurés selon les besoins.
Ports de 8255A
8255A dispose de trois ports, à savoir, PORT A, PORT B et PORT C.
Port A contient un verrou / tampon de sortie 8 bits et un tampon d'entrée 8 bits.
Port B est similaire à PORT A.
Port C peut être divisé en deux parties, à savoir le PORT C inférieur (PC0-PC3) et le PORT C supérieur (PC7-PC4) par le mot de contrôle.
Ces trois ports sont en outre divisés en deux groupes, c'est-à-dire que le groupe A comprend le PORT A et le PORT supérieur C. Le groupe B comprend le PORT B et le PORT inférieur C. Ces deux groupes peuvent être programmés dans trois modes différents, c'est-à-dire que le premier mode est appelé mode 0, le deuxième mode est nommé Mode 1 et le troisième mode est nommé Mode 2.
Modes de fonctionnement
8255A a trois modes de fonctionnement différents -
Mode 0- Dans ce mode, les ports A et B sont utilisés comme deux ports 8 bits et le port C comme deux ports 4 bits. Chaque port peut être programmé en mode d'entrée ou en mode de sortie où les sorties sont verrouillées et les entrées ne sont pas verrouillées. Les ports n'ont pas de capacité d'interruption.
Mode 1- Dans ce mode, les ports A et B sont utilisés comme ports d'E / S 8 bits. Ils peuvent être configurés comme ports d'entrée ou de sortie. Chaque port utilise trois lignes du port C comme signaux de prise de contact. Les entrées et sorties sont verrouillées.
Mode 2- Dans ce mode, le port A peut être configuré comme port bidirectionnel et le port B en mode 0 ou en mode 1. Le port A utilise cinq signaux du port C comme signaux de prise de contact pour le transfert de données. Les trois signaux restants du port C peuvent être utilisés soit comme de simples E / S, soit comme établissement de liaison pour le port B.
Caractéristiques du 8255A
Les principales caractéristiques du 8255A sont les suivantes:
Il se compose de 3 ports IO 8 bits, c'est-à-dire PA, PB et PC.
L'adresse / le bus de données doit être démultiplexé en externe.
Il est compatible TTL.
Il a amélioré la capacité de conduite CC.
8255 Architecture
La figure suivante montre l'architecture du 8255A -
Jetons d'abord un coup d'œil au diagramme des broches d'Intel 8255A -
Parlons maintenant de la description fonctionnelle des broches du 8255A.
Tampon de bus de données
Il s'agit d'un tampon à 8 bits à trois états, utilisé pour interfacer le microprocesseur avec le bus de données système. Les données sont transmises ou reçues par le tampon selon les instructions de la CPU. Les mots de commande et les informations d'état sont également transférés via ce bus.
Logique de contrôle de lecture / écriture
Ce bloc est chargé de contrôler le transfert interne / externe des données / commande / mot d'état. Il accepte l'entrée de l'adresse CPU et des bus de contrôle, et envoie à son tour la commande aux deux groupes de contrôle.
CS
Il signifie Chip Select. Un BAS sur cette entrée sélectionne la puce et active la communication entre le 8255A et le CPU. Il est connecté à l'adresse décodée, et A 0 & A 1 sont connectés aux lignes d'adresse du microprocesseur.
Leur résultat dépend des conditions suivantes -
CS | A 1 | A 0 | Résultat |
---|---|---|---|
0 | 0 | 0 | PORT A |
0 | 0 | 1 | PORT B |
0 | 1 | 0 | PORT C |
0 | 1 | 1 | Registre de contrôle |
1 | X | X | Pas de choix |
WR
Cela signifie écrire. Ce signal de commande active l'opération d'écriture. Lorsque ce signal devient faible, le microprocesseur écrit dans un port E / S sélectionné ou un registre de contrôle.
RÉINITIALISER
C'est un signal haut actif. Il efface le registre de contrôle et définit tous les ports en mode d'entrée.
RD
Il signifie Read. Ce signal de commande active l'opération de lecture. Lorsque le signal est bas, le microprocesseur lit les données à partir du port E / S sélectionné du 8255.
A 0 et A 1
Ces signaux d'entrée fonctionnent avec RD, WR et l'un des signaux de commande. Voici le tableau montrant leurs différents signaux avec leur résultat.
A 1 | A 0 | RD | WR | CS | Résultat |
---|---|---|---|---|---|
0 | 0 | 0 | 1 | 0 | Input Operation PORT A → Bus de données |
0 | 1 | 0 | 1 | 0 | PORT B → Bus de données |
1 | 0 | 0 | 1 | 0 | PORT C → Bus de données |
0 | 0 | 1 | 0 | 0 | Output Operation Bus de données → PORT A |
0 | 1 | 1 | 0 | 0 | Bus de données → PORT A |
1 | 0 | 1 | 0 | 0 | Bus de données → PORT B |
1 | 1 | 1 | 0 | 0 | Bus de données → PORT D |
Les processeurs Intel 8253 et 8254 sont des minuteries d'intervalle programmables (PTI) conçues pour que les microprocesseurs exécutent des fonctions de synchronisation et de comptage à l'aide de trois registres 16 bits. Chaque compteur a 2 broches d'entrée, c'est-à-dire Clock & Gate, et 1 broche pour la sortie «OUT». Pour faire fonctionner un compteur, un compte de 16 bits est chargé dans son registre. Sur commande, il commence à décrémenter le comptage jusqu'à ce qu'il atteigne 0, puis il génère une impulsion qui peut être utilisée pour interrompre le CPU.
Différence entre 8253 et 8254
Le tableau suivant différencie les caractéristiques du 8253 et du 8254 -
8253 | 8254 |
---|---|
Sa fréquence de fonctionnement est de 0 à 2,6 MHz | Sa fréquence de fonctionnement est de 0 à 10 MHz |
Il utilise la technologie N-MOS | Il utilise la technologie H-MOS |
La commande de lecture arrière n'est pas disponible | La commande Read-Back est disponible |
Les lectures et écritures du même compteur ne peuvent pas être entrelacées. | Les lectures et les écritures du même compteur peuvent être entrelacées. |
Caractéristiques du 8253/54
Les caractéristiques les plus importantes du 8253/54 sont les suivantes:
Il dispose de trois décompteurs 16 bits indépendants.
Il peut gérer des entrées de DC à 10 MHz.
Ces trois compteurs peuvent être programmés pour un comptage binaire ou BCD.
Il est compatible avec presque tous les microprocesseurs.
8254 a une commande puissante appelée commande READ BACK, qui permet à l'utilisateur de vérifier la valeur de comptage, le mode programmé, le mode actuel et l'état actuel du compteur.
8254 Architecture
L'architecture du 8254 se présente comme suit -
8254 Description des broches
Voici le schéma des broches du 8254 -
Dans la figure ci-dessus, il y a trois compteurs, un tampon de bus de données, une logique de commande de lecture / écriture et un registre de commande. Chaque compteur a deux signaux d'entrée - CLOCK & GATE, et un signal de sortie - OUT.
Tampon de bus de données
Il s'agit d'un tampon 8 bits bidirectionnel à trois états, utilisé pour connecter le 8253/54 au bus de données système. Il a trois fonctions de base -
- Programmation des modes de 8253/54.
- Chargement des registres de comptage.
- Lecture des valeurs de comptage.
Logique de lecture / écriture
Il comprend 5 signaux, à savoir RD, WR, CS et les lignes d'adresse A 0 et A 1 . En mode E / S périphérique, les signaux RD et WR sont respectivement connectés à IOR et IOW. En mode E / S mappées en mémoire, celles-ci sont connectées à MEMR et MEMW.
Les lignes d'adresse A 0 et A 1 de la CPU sont connectées aux lignes A 0 et A 1 du 8253/54, et CS est liée à une adresse décodée. Le registre de mot de contrôle et les compteurs sont sélectionnés en fonction des signaux sur les lignes A 0 et A 1 .
A 1 | A 0 | Résultat |
---|---|---|
0 | 0 | Compteur 0 |
0 | 1 | Compteur 1 |
1 | 0 | Compteur 2 |
1 | 1 | Registre des mots de contrôle |
X | X | Pas de choix |
Registre des mots de contrôle
Ce registre est accessible lorsque les lignes A 0 et A 1 sont à la logique 1. Il est utilisé pour écrire un mot de commande, qui spécifie le compteur à utiliser, son mode, et une opération de lecture ou d'écriture. Le tableau suivant montre le résultat pour différentes entrées de commande.
A 1 | A 0 | RD | WR | CS | Résultat |
---|---|---|---|---|---|
0 | 0 | 1 | 0 | 0 | Compteur d'écriture 0 |
0 | 1 | 1 | 0 | 0 | Écriture du compteur 1 |
1 | 0 | 1 | 0 | 0 | Compteur d'écriture 2 |
1 | 1 | 1 | 0 | 0 | Écrire le mot de contrôle |
0 | 0 | 0 | 1 | 0 | Lire le compteur 0 |
0 | 1 | 0 | 1 | 0 | Lire le compteur 1 |
1 | 0 | 0 | 1 | 0 | Lire le compteur 2 |
1 | 1 | 0 | 1 | 0 | Pas d'opération |
X | X | 1 | 1 | 0 | Pas d'opération |
X | X | X | X | 1 | Pas d'opération |
Compteurs
Chaque compteur se compose d'un seul compteur descendant de 16 bits, qui peut être utilisé en binaire ou en BCD. Son entrée et sa sortie sont configurées par la sélection des modes mémorisés dans le registre de mot de contrôle. Le programmeur peut lire le contenu de l'un des trois compteurs sans perturber le comptage réel en cours.
8253/54 peut être utilisé dans 6 modes différents. Dans ce chapitre, nous aborderons ces modes de fonctionnement.
Mode 0 ─ Interruption sur le nombre de terminaux
Il est utilisé pour générer une interruption du microprocesseur après un certain intervalle.
Au départ, la sortie est faible une fois le mode défini. La sortie reste LOW après le chargement de la valeur de comptage dans le compteur.
Le processus de décrémentation du compteur continue jusqu'à ce que le décompte terminal soit atteint, c'est-à-dire que le décompte devient zéro et que la sortie passe à HAUT et restera haut jusqu'à ce qu'il recharge un nouveau décompte.
Le signal GATE est élevé pour un comptage normal. Lorsque GATE passe au niveau bas, le comptage est terminé et le compte actuel est verrouillé jusqu'à ce que le GATE redevienne haut.
Mode 1 - One Shot programmable
Il peut être utilisé comme multi-vibrateur mono stable.
L'entrée de porte est utilisée comme entrée de déclenchement dans ce mode.
La sortie reste élevée jusqu'à ce que le décompte soit chargé et qu'un déclencheur soit appliqué.
Mode 2 - Générateur de taux
La sortie est normalement élevée après l'initialisation.
Chaque fois que le compte devient nul, une autre impulsion basse est générée à la sortie et le compteur est rechargé.
Mode 3 - Générateur d'ondes carrées
Ce mode est similaire au mode 2 sauf que la sortie reste faible pendant la moitié de la période de la minuterie et élevée pendant l'autre moitié de la période.
Mode 4 - Mode déclenché par logiciel
Dans ce mode, la sortie restera élevée jusqu'à ce que la minuterie ait compté à zéro, à quel point la sortie impulsera au niveau bas puis redeviendra haute.
Le compte est verrouillé lorsque le signal GATE passe à BAS.
Sur le nombre de bornes, la sortie passe au niveau bas pendant un cycle d'horloge puis passe au niveau haut. Cette impulsion basse peut être utilisée comme un stroboscope.
Mode 5 - Mode déclenché par le matériel
Ce mode génère un stroboscope en réponse à un signal généré extérieurement.
Ce mode est similaire au mode 4 sauf que le comptage est initié par un signal à l'entrée de la porte, ce qui signifie qu'il est déclenché par le matériel au lieu du déclenchement par le logiciel.
Après avoir été initialisé, la sortie devient élevée.
Lorsque le nombre de bornes est atteint, la sortie devient faible pendant un cycle d'horloge.