# MICROPROCESSEUR 16 BITS (LE 8086 DE INTEL)

# **Objectifs**

- Architecture généraleCycle d'accès au bus
- Organisation de la mémoire
- Modes d'adressages

# Caractéristiques générales du 8086

- Microprocesseur 16 bits avec une architecture issue de celle du 8080.
- Il présente une capacité d'adressage étendue (24 modes).
- Jeu d'instructions très puissant (multiplication et division câblées).
- Il utilise pour l'adressage des segments spécialisés (transportabilité).
- II peut fonctionner soit en mode minimum, soit en mode maximum.
- La mémoire de un Mo est vu comme un bloc de 512 Kilo-mots.
- les bus d'adresses et de données sont multiplexés.
- L'espace mémoires des E/S est séparé du reste de la mémoire.
- Il est totalement compatible avec le microprocesseur 8088.
  Il présente 1 entrée d'interruption logicielle et 2 entrées matérielles.
- Il dispose de circuits d'interface ou de traitements spécialisés.
- Peut reprendre les circuits périphériques des microprocesseurs 8 bits.



La première machine: de traitement (unité d'instruction et le micro et les exécute. La file d'interface de bus) qui

Le travail pr de les mettre dans la fi

Le premier accès mémoire. Elle de

Le second c jmp / call ...). Le conte réinitialisation à partir

La file d'att toujours par mots de réinitialisation est impa

Le but recherché est des instructions de n justifiée par le fait que

Lorsque l'El transfert au BIU en no dans le segment. Le demandé

Les instructi octets d'instructions p de la file d'attente dès

- L'EU ne prioritaire sur la lecture

- Il existe d par au moins un cycle une lecture des octets

En résumé , le BIU occupe ce d'attente. Quand la file dans la file d'attente. contenu de la file d'att

Cela peut ég plus rapide que le rem

| 4                                                                                                                                       |   |
|-----------------------------------------------------------------------------------------------------------------------------------------|---|
|                                                                                                                                         |   |
|                                                                                                                                         |   |
|                                                                                                                                         |   |
|                                                                                                                                         |   |
|                                                                                                                                         |   |
|                                                                                                                                         |   |
| E.U. et B.I.U.?                                                                                                                         |   |
| E.O. & D.I.O.!                                                                                                                          |   |
| L'EU ( Execution Unit, unité d'exécution) regroupe les fonctions                                                                        |   |
| arithmétique et logique), les registres généraux, le décodeur pocode associé. Elle lit les codes opération dans une file d'attente      |   |
| e d'attente est alimentée par le <b>BIU</b> (Bus Interface Unit, unité constitue la deuxième machine.                                   |   |
| incipal de <b>l'UIB</b> , est de chercher les instructions en mémoire et                                                                | - |
| île d'attente. Ce travail est rompu dans deux cas particuliers.<br>cas est celui où l'UE, exécute une instruction nécessitant un        |   |
| emande alors à l'IUB de lire ou d'écrire une valeur en mémoire. cas est celui où l'UE rencontre un déroutement de programme (           |   |
| enu de la file d'attente n'est plus à jour et l'UE doit demander une de l'adresse de branchement.                                       |   |
| ente des instructions a une taille de 6 octets, l'accès se fait<br>e 16 bits sauf dans le seul cas particulier où l'adresse de          |   |
| ire.                                                                                                                                    |   |
|                                                                                                                                         |   |
|                                                                                                                                         |   |
| 5                                                                                                                                       |   |
|                                                                                                                                         |   |
|                                                                                                                                         |   |
|                                                                                                                                         |   |
|                                                                                                                                         |   |
|                                                                                                                                         | 1 |
|                                                                                                                                         |   |
| la parallélisation des deux tâches d'acquisition et d'exécution nanière à optimiser l'occupation du bus . Cette distinction est         |   |
| ces deux blocs travaillent en partie indépendamment .  J a besoin d'accéder à une donnée en mémoire , il demande le                     |   |
| ommant le segment concerné, et en fournissant le déplacement                                                                            |   |
| BIU calcule l'adresse physique sur 20 bits et réalise le transfert                                                                      |   |
| ions exécutées par l'EU sont issues d'une file d'attente de six<br>our le 8086. Le BIU présente les octets d'instructions à l'entrée    |   |
| que les deux conditions suivantes sont remplies : demande pas de transfert de données; cet évènement est                                |   |
| e des instructions.<br>es places libres dans la file d'attente qui peuvent être remplies                                                |   |
| e de lecture du bus . Le 8086 a un bus de données de 16 bits:<br>d'instructions se fait dès qu'il y a au moins deux places libres .     |   |
| pendant que l'EU ne demande pas de transfert avec la mémoire temps libre du bus pour amener les instructions dans la file               |   |
| e d'attente est vide , l'EU attend que le BIU place une instruction<br>Ceci arrive lorsque l'EU effectue un saut dans le programme : le |   |
| ente est alors effacé (« flush » ou vidage)<br>galement arriver, lorsque l'exécution d'une suite d'instructions est                     |   |
| plissage de la file d'attente par les cycles lecture du bus .                                                                           |   |
|                                                                                                                                         |   |
|                                                                                                                                         | · |



<u>Les registres de travail</u>:
Ce sont les registres avec lesquels peuvent être effectuées les additions , soustractions et opérations logiques , la deuxième opérande étant obtenue par l'un des modes d'adressages du microprocesseur . Chacun de ces registres a des fonctions particulières :

Les registres de base et d'index : BX , BP , SI , DI Le contenu de ces registres peut être utilisé comme adresse mémoire ( voir modes d'adressage du

8086). Les deux index permettent la gestion de suite de mots; il s'agit de l'index de destination (DI) et de l'index de source (SI). Le registre BP (base pointer) sert à la génération des adresses des données Le pointeur de pile : SP Le 8086/8088 gère une pile utilisée pour les sous programmes et servant à sauvegarder les données de l'utilisateur.

Les registres généraux : AX , BX , CX , DX

Ils sont au nombre de 4 et peuvent travailler par moitié (8 bits). Ils ont pour appellation :

- L'accumulateur : AX composé de AH et de AL. Les multiplications, les divisions, les traitements de chaînes, les transferts entrées-sorties, la conversion en BCD du résultat d'une opération arithmétique se font tous par son intermédiaire .

- Base : BX composé de BH et de BL. Ce registre sert à l'adressage en mémoire-

Le compteur : CX composé de CH et de CL, est utilisé en compteur lors des

instructions de boucles , dont les traitements de chaînes. Le registre CL est utilisé en compteur lors des instructions de décalages et de rotations multiples (sur plusieurs bits) . - Le registre de données : DX composé de DH et de DL. Ce registre à des utilisations

- particulières, par exemples :

  \* extension 32 bits pour les multiplications et les divisions de mots .
  - \* reste d'une division de mots ( AX contient le quotient ) .
  - \* en registre d'adresses d'entrées sorties

| Les registres de contrôle du programme :  - Le pointeur d'instruction "IP" : Ce registre est mis à jour par le BIU afin qu'il pointe vers l'adresse de l'instruction suivante. Les programmes n'ont pas d'accès direct au pointeur d'instruction, mais au cours de l'exécution d'un programme, ce registre peut être modifié ou bien sauvegardé, puis restauré par la pile.  - Le registre d'état "FLAGS" : Le 8086 dispose de neuf indicateurs d'état à un bits, (voir figure suivante). (Les indicateurs TF, DF et IF ont un usage particulier). Les indicateurs d'état sont mis à jour par I'EU suite au résultat d'une opération arithmétique ou logique. |  |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Indicateurs d'état  IT DR IF OF SF ZF AF PF CF  CF: RETENUE PF: PARITE PF: PARITE PF: ZF CF  CF: SIGNE OF: DEGORDEMENT IF: VALIDATION D'INTERRUPTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |
| TF: PIEGE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |

| • |  |  |
|---|--|--|
| • |  |  |
|   |  |  |
|   |  |  |
|   |  |  |
| • |  |  |
|   |  |  |
|   |  |  |
|   |  |  |
| • |  |  |
| • |  |  |
|   |  |  |
| • |  |  |
| • |  |  |
|   |  |  |
| • |  |  |
|   |  |  |
|   |  |  |
|   |  |  |
| • |  |  |
|   |  |  |
|   |  |  |
|   |  |  |
|   |  |  |
|   |  |  |
|   |  |  |

CF ( carry flag ) : indicateur de retenue PF ( parity flag ) : indicateur de parité .

AF ( auxiliary flag ) : indicateur de retenue auxiliaire . La retenue auxiliaire est la retenue générée par les 4 bits de poids faible du résultat d'une opération arithmétique. Elle permet de coder le résultat sous forme BCD ZF ( zéro flag ) : indicateur de zéro . SF ( sign flag ) : indicateur de signe. TF ( trap flag ) :indicateur de mode pas à pas . Si TF=1 une interruption est générée après exécution de chaque instruction du programme . Il permet la mise au point du logiciel sans gestion externe. Chaque instruction est interrompue par une exception de type pas à pas afin d'aller exécuter , à la fin de chaque instruction un sous programme d'aide à la mise au point ( debug exception ). Ce bit ne peut être modifié que par l'intermédiaire de la pile . Lorsqu'on entre dans le programme de pas à pas, le registre des indicateurs est sauvegardé et le bit TF est automatiquement remis à zéro afin d'empêcher le programme pas à pas d'être effectué lui même en mode pas à pas. Au retour, le registre des indicateurs est restitué et ainsi le bit TF se retrouve de nouveau positionné. IF (interrupt flag) : indicateur d'autorisation d'interruption . Cet indicateur autorise (IF=1) ou interdit (IF=0) les interruptions externes demandées sur la broche INTR du circuit . DF (direction flag) : indicateur de direction . C'est le sens de progression des registres d'index SI et DI lors des instructions de traitements de chaînes . DF=1 adresses décroissantes, DF=0 adresses

OF (overflow flag) : Le flag d'overflow est nécessaire en arithmétique signée (complément A 2), dans ce cas le bit de plus fort poids (le huitième ou le seizième) est le bit de signe et OF indique un dépassement de calculs.



Les lignes adresses et données du 8086 sont multiplexées de manière à économiser le nombre de broches. Ce bus peut être utilisé directement en tant que bus local sur des petits systèmes

En règle générale le bus sera démultiplexé pour fournir des bus de données et d'adresses indépendants. Ceci est réalisé par de simples « latchs » commandés par le signal ALE (adress Latch Enable). De plus cela offre l'intérêt de bufferiser les lignes adresses et données (la sortance du 8086 étant limitée). Le signal ALE est généré directement par le 8086 en mode minimum, et par son contrôleur de bus 8288 en mode maximum.

Chaque cycle d'accès au bus comporte 4 périodes d'horloge (T1 à T4) auxquelles peuvent s'ajouter des périodes d'attente Tw (wait states) insérées entre T3

et T4. La figure suivante donne le cycle de base du 8086. Pendant T1 , le processeur émet l'adresse sur le bus. Les transferts de données ont lieu pendant les cycles T3 et T4. Le cycle T2 permet essentiellement les changements de direction de bus pour les opérations de lecture. Des états Wait sont rajoutés entre T3 et T4 tant que le signal READY est à 0

La régularité des accès au bus est due à l'indépendance entre BIU et EU. Le processeur utilise 3 cycles pour son organisation interne; ainsi le bus n'est pas constamment utilisé par le 8086. Les périodes situées entre deux cycles d'accès au bus sont appelées inactives ou idle.



# Modes de fonctionnement du 8086

#### Mode minimum:

le 8086 génère lui même les 3 bus, données, adresses et contrôle. Le bus de contrôle est un bus simplifié convenant à un environnement monoprocesseur. Ce mode ne permet pas l'utilisation de co-processeurs ou de processeurs spécialisés. Il n'est pas adapté à des architectures multiprocesseurs.

# Mode maximum :

le 8086 génère les signaux d'état. Le contrôleur de bus décode ces signaux pour générer un bus de contrôle compatible avec les spécifications multibus. Les signaux S0, S1 et S2 sont utilisés pour identifier le type d'accès. S3 et S4 indiquent quel registre segment est utilisé pour la génération de l'adresse physique. S5 est l'image du bit d'interruption, S6 est toujours à 0 et S7 est un bit réservé.

# Mode maximum / segment

| <b>S4</b> | S3 | Registre de segment concerné                                                                        |    |
|-----------|----|-----------------------------------------------------------------------------------------------------|----|
| 0         | 0  | ES (Extra segment)                                                                                  | ]. |
| 0         | 1  | SS (Stack segment)                                                                                  | ]  |
| 1         | 0  | CS (Code segment) ou transfert avec les entrées-sorties, ou<br>lecture d'un vecteur d'interruption. |    |
| 1         | 1  | DS (Data segment)                                                                                   |    |

| ſ     |                                |      |     |     |                                       |                                  | 1  |  |  |
|-------|--------------------------------|------|-----|-----|---------------------------------------|----------------------------------|----|--|--|
|       | Mode maximum / bus de contrôle |      |     |     |                                       |                                  |    |  |  |
|       |                                | /\$2 | /S1 | /S0 | Action du microprocesseur             | Sortie du 8288<br>correspondante |    |  |  |
|       |                                | 0    | 0   | 0   | Acquittement d'interruption masquable | /INTA                            |    |  |  |
|       |                                | 0    | 0   | 1   | Lecture d'une donnée entrées-sorties  | /IORC                            |    |  |  |
| 7     |                                | 0    | 1   | 0   | Ecriture d'une donnée entrées-sorties | /IOWC                            | -  |  |  |
| 1     |                                | 0    | 1   | 1   | Arrêt par une instruction HLT         | aucune                           | ١  |  |  |
|       |                                | 1    | 0   | 0   | Lecture d'instruction                 | /MRDC                            | П  |  |  |
|       |                                | 1    | 0   | 1   | Lecture d'une donnée mémoire          | /MRDC                            | П  |  |  |
|       |                                | 1    | 1   | 0   | Ecriture d'une donnée mémoire         | /MWTC                            |    |  |  |
|       |                                | 1    | 1   | 1   | inactif                               | aucune                           |    |  |  |
|       | ľ                              |      |     |     |                                       |                                  |    |  |  |
| R. GR | ISEL                           |      |     |     |                                       |                                  | 16 |  |  |



R. GRI

|     | 1       | 1 0              | Ecriture d'une donnée mémoire                                                                             | /MWTC                     |
|-----|---------|------------------|-----------------------------------------------------------------------------------------------------------|---------------------------|
|     | 1       | 1 1              | inactif                                                                                                   | aucune                    |
|     |         |                  |                                                                                                           |                           |
| SEL |         |                  |                                                                                                           |                           |
|     |         |                  |                                                                                                           |                           |
|     |         |                  |                                                                                                           |                           |
|     |         |                  |                                                                                                           |                           |
|     |         |                  |                                                                                                           |                           |
|     |         |                  |                                                                                                           |                           |
|     |         |                  |                                                                                                           |                           |
|     |         | Ma               | de maximum / file d 'instruct                                                                             | ion                       |
|     |         | IVIO             | ue maximum / me u mstruct                                                                                 | 1011                      |
|     |         |                  |                                                                                                           |                           |
|     | QS1     | QS0              | Etat de la file d'attente ou action de l'unité d'exécutio                                                 | ١.                        |
|     | 0       | 0                | Etat inchangé. Aucun octet n'est lu dans la file d'atter                                                  | ite.                      |
|     | 0       | 1                | Décodage du premier octet d'une instruction dans la                                                       | file d'attente            |
|     | L"      | $\vdash$         | -                                                                                                         |                           |
|     | 1       |                  | File d'attente vide, suite à un saut dans le programmou au décodage de tous les octets s'y trouvant, avan |                           |
|     |         |                  | que l'unité d'interface bus ne lise les instructions suivantes.                                           |                           |
|     | 1       | 1                | Décodage de l'octet suivant d'une instruction (autre d                                                    | ue le premier).           |
|     |         |                  |                                                                                                           |                           |
|     |         |                  |                                                                                                           |                           |
| SEL |         |                  |                                                                                                           |                           |
|     |         |                  |                                                                                                           |                           |
|     |         |                  |                                                                                                           |                           |
|     |         |                  |                                                                                                           |                           |
|     |         |                  |                                                                                                           |                           |
|     |         |                  |                                                                                                           |                           |
|     |         |                  |                                                                                                           |                           |
|     | 0       | rgar             | nisation logique de la méi                                                                                | noire                     |
|     |         |                  | émoire est organisée en 512 K-mots de 16 bits                                                             |                           |
|     | l'octet |                  | s fort à l'adresse la plus haute de la manière su                                                         |                           |
|     |         |                  |                                                                                                           | <del></del>               |
|     |         |                  | FFFFFH                                                                                                    |                           |
|     |         |                  |                                                                                                           |                           |
|     | Oct     | tet de_          | <b>.</b>                                                                                                  |                           |
|     | poid    | ls fort<br>et de | Mot de XXXXXH adr                                                                                         | e 16 bits<br>resse du mot |
|     | poids   | s faible         |                                                                                                           |                           |
|     |         |                  |                                                                                                           |                           |
|     |         |                  | 00000Н                                                                                                    |                           |
|     |         |                  |                                                                                                           |                           |
| SEL |         |                  |                                                                                                           |                           |
| -   |         |                  |                                                                                                           |                           |



# Accès à la mémoire Pour un accès par octet un seul des bancs est validé et pour un accès par mot, les deux bancs sont utilisés simultanément. Un seul accès ou successivement deux accès suivant que l'adresse du mot est paire ou impaire. Les bits A0 et BHE sont utilisés pour de telles opérations. /BHE Α0 Donnée sélectionnée. Le mot de 16 bits (adresse paire). 0 L'octet sur le bus D8-D15 (adresse impaire). 0 0 L'octet sur le bus D0-D7 (adresse paire). 1 aucune.











| Exemple n | umária | une . |        |        |       |          | _   |                         | _  |
|-----------|--------|-------|--------|--------|-------|----------|-----|-------------------------|----|
|           | segme  |       | ∙00H € | et dép | lacem | ent 1010 | )H. | L'adresse physique sera |    |
|           | +      | 0     | 1      | 0      | 1     | 0        |     | Déplacement             |    |
|           |        | Α     | 4      | 0      | 0     | 0        |     | Segment                 |    |
|           | = _    | Α     | 5      | 0      | 1     | 0        |     |                         |    |
|           |        |       |        |        |       |          |     |                         |    |
|           |        |       |        |        |       |          |     |                         |    |
|           |        |       |        |        |       |          |     |                         |    |
| SEL SEL   |        |       |        |        | 17    |          |     |                         | 27 |

# Les modes d'adressages

Le code exécutable d'un programme est toujours pointés par le contenu du registre IP par rapport au contenu du registre CS (CS:IP).

Les données stockées en pile de sauvegarde sont toujours pointées par le contenu du registre SP par rapport au contenu du registre SS (SS:SP)

Les positions mémoires représentant des données sont pointées par une adresse effective AE par rapport au contenu d'un segment qui dépend de la composition de l'adresse effective.

Les données à manipuler peuvent être dans des registres, dans la mémoire, dans la pile ou spécifiées immédiatement dans l'instruction (modes d'adressage des données).

# Les modes d'adressages

## 1) Adressage des registres

Concerne tout transfert ou toute opération, entre deux registres de même taille, ou sur un registre.

MOV SI, CX (CX) vers (SI) (16 bits) ADD DH,AL Transfert de (DH) + (AL) vers (DH) (8 bits)

2) Adressage de la mémoire II y a 24 possibilités en tout. C'est ce qui permet le calcul du déplacement

dans le segment (encore nommé AE) et le segment concerné par défaut par le mode d'adressage. Adressage direct

Le déplacement est donné directement par le programme, et se fait dans le segment DS ( par défaut ) . Déplacement = mot de 16 bits

Soit le registre de segment DS = 1200H et le déplacement = 0081H (= VARIABLE). l'instruction : MOV BP . VARIABLE

réalise le transfert de VARIABLE (dans le segment DS) vers (BP).

# Adressage immédiat

La donnée opérande d'une opération avec un registre ou une mémoire est directement donnée par le programme. Cette donnée peut être un octet ou un mot, le registre ou la mémoire destinataire étant de la même taille

#### MOV WORD PTR[SI],1

réalise le chargement de ((SI) dans le segment DS) par 0001H.

( l'expression WORD PTR ou BYTE PTR indique la taille de l'emplacement mémoire considéré, quand elle n'est pas implicitement connue . comme dans cet exemple ).

Les registres segments ne peuvent pas être chargés par adressage immédiat .

Adressage basé ( registre de base : BX et BP ) L'adresse est déterminée par base BX : le contenu de BX, auquel est éventuellement ajouté un décalage sur 8 ou 16 bits signé, représente le déplacement dans le segment DS ( par défaut ) .  $\emph{base BP}$  : le contenu de BP, auquel est ajouté ( toujours ) un décalage sur 8 bits ou 16 bits signé, représente le déplacement dans le segment SS ( par défaut ) . d'où les cinq possibilités : déplacement = (BX) déplacement = (BX) + octet de décalage déplacement = (BX) + mot de décalage déplacement = ( BP ) + octet de décalage déplacement = (BP) + mot de décalage MOV ES, TABLE [BP] réalise le transfert de ((BP) + TABLE) vers (ES) dans le segment SS. Les modes d'adressages avec index Adressage indexé (registre d'index : SI et DI) Le contenu du registre d'index ( SI ou DI ) , auquel est éventuellement ajouté un décalage sur 8 ou 16 bits **signé** , représente le déplacement dans le segment DS ( par défaut ), d'où les six possibilités suivantes déplacement = (SI) déplacement = (SI) + octet de décalage déplacement = (SI) + mot de décalage déplacement = ( DI ) déplacement = ( DI ) + octet de décalage déplacement = ( DI ) + mot de décalage MOV VECTEUR[SI], AL réalise le transfert de (AL) vers ((SI) + VECTEUR dans le segment DS). Adressage basé indexé Le déplacement est déterminé par la somme du contenu du registre BX ou BP et d'un des registres d'index SI ou DI, auguel est éventuellement, ajouté un décalage sur 8 ou 16 bits signé. DS et SS sont pris par défaut. Base BX: la somme des contenus du registre BX et d'un des registres d'index (SI ou DI), à laquelle est éventuellement ajouté un décalage sur 8 ou 16 bits signé, représente le déplacement dans le segment DS ( par défaut ) . Base BP : la somme des contenus du registre BP et d'un des registres d'index (SI ou DI), à laquelle est éventuellement ajouté un décalage sur 8 ou 16 bits signé, représente le déplacement dans le segment SS (par défaut) . D'où 12 les possibilités suivantes : déplacement = (BX) + (SI), déplacement = ( BX ) + ( SI ) + octet de décalage déplacement = (BX)+(SI)+ mot de décalage, déplacement = (BX)+(DI) déplacement = (BX)+(DI)+ octet de décalage, déplacement = (BX)+(DI)+ mot de décalage déplacement = (BP) + (SI), déplacement = (BP) + (SI) + octet de décalage déplacement = ( BP ) + ( SI ) + mot de décalage, déplacement = ( BP ) + ( DI ) déplacement = (BP) + (DI) + octet de décalage, déplacement = (BP) + (DI) +mot de décalage XCH SP , TABLE[BP][SI] réalise le transfert de (SP) vers ((BP)+(SI) + TABLE dans le segment SS), et le transfert de ((BP)+(SI) + TABLE dans le segment SS) vers (SP)

REMARQUE : Dans tout ce qui précède, les segments concernés sont ceux par défaut . Le programmeur peut léférencer les déplacements à d'autre segments en les citant explicitement dans les instructions. Les codages de ces demières occupent alors un octet supplémentaire . MOV AX , [BX] réalise (AX) <-- ((BX) dans le segment DS ) Le segment DS est concerné par défaut . Alors que : MOV AX , ES:[BX] réalise (AX) <-- ((BX) dans le segment ES ) Le segment ES est cité explicitement . Les contenus des registres de segments (CS, DS, SS, ES) peuvent être transférés dans un registre de travail, ou en mémoire adressée par l'un des modes décrits. L'inverse n'est possible que sur DS, SS et ES. CS ne peut être modifié que par un saut inter segment du programme. Le tableau suivant donne une récapitulation des modes d'adressage cités.

# Les modes d'adressages

| Type<br>d'adressage | Obtention du déplacement dans le segment                                                                                                                                                                      | Segment concerné<br>par défaut         |
|---------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------|
| Direct              | donné directement par le programme                                                                                                                                                                            | DS                                     |
| Basé                | (BX)<br>(BX) + décalage (octet ou mot)<br>(BP) + décalage (octet ou mot)                                                                                                                                      | DS<br>DS<br>SS                         |
| Indexé              | (SI)<br>(SI) + décalage (octet ou mot)<br>(DI)<br>(DI) + décalage (octet ou mot)                                                                                                                              | DS<br>DS<br>DS<br>DS                   |
| Basé indexé         | (BX) + (SI)<br>(BX) + (SI) + décalage (octet ou mot)<br>(BX) + (DI)<br>(BX) + (DI) + décalage (octet ou mot)<br>(BP) + (SI)<br>(BP) + (SI) + décalage (octet ou mot)<br>(BP) + (DI) + décalage (octet ou mot) | DS<br>DS<br>DS<br>DS<br>SS<br>SS<br>SS |

# L'adressage

Les entrées sorties so indépendant de la mémoire. Iles possibilités sont utilisées.

### Adressage direct :

l'adresse du port est do n'accède qu'aux 256 premiers d sorties.

О

# Adressage par registre :

l'adresse du port est con aux 64 Ko, 32 K-mots, d'entrées

|                                                                                                                                                                                                        | DS                                                                   |    |  |      |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------|----|--|------|
| calage (octet ou mot)<br>calage (octet ou mot)                                                                                                                                                         | DS<br>SS                                                             |    |  |      |
| alage (octet ou mot)                                                                                                                                                                                   | DS<br>DS                                                             |    |  |      |
| alage (octet ou mot)                                                                                                                                                                                   | DS<br>DS<br>DS<br>DS                                                 |    |  |      |
| décalage (octet ou mot)                                                                                                                                                                                | DS<br>DS                                                             |    |  |      |
| décalage (octet ou mot)                                                                                                                                                                                | DS<br>DS<br>DS<br>SS<br>SS<br>SS<br>SS                               |    |  |      |
| décalage (octet ou mot)                                                                                                                                                                                | SS<br>SS                                                             |    |  |      |
| décalage (octet ou mot)                                                                                                                                                                                | SS                                                                   |    |  |      |
|                                                                                                                                                                                                        |                                                                      | 35 |  |      |
|                                                                                                                                                                                                        |                                                                      |    |  |      |
|                                                                                                                                                                                                        |                                                                      |    |  |      |
|                                                                                                                                                                                                        |                                                                      |    |  |      |
|                                                                                                                                                                                                        |                                                                      |    |  |      |
|                                                                                                                                                                                                        |                                                                      |    |  |      |
|                                                                                                                                                                                                        |                                                                      |    |  |      |
|                                                                                                                                                                                                        |                                                                      |    |  |      |
| dos entrées sort                                                                                                                                                                                       | ioo                                                                  |    |  |      |
| des entrées-sort                                                                                                                                                                                       | ies                                                                  |    |  | <br> |
| ont situées dans un espac                                                                                                                                                                              | ce d'adressage                                                       |    |  |      |
|                                                                                                                                                                                                        | ce d'adressage                                                       |    |  |      |
| ont situées dans un espac                                                                                                                                                                              | ce d'adressage                                                       |    |  |      |
| ont situées dans un espar<br>ne font l'objet d'aucune segr<br>onnée directement par le p                                                                                                               | ce d'adressage<br>mentation. Deux<br>programme. On                   |    |  |      |
| ont situées dans un espac<br>ne font l'objet d'aucune segr<br>onnée directement par le p<br>octets, ou aux 128 premiers                                                                                | ce d'adressage<br>mentation. Deux<br>programme. On                   |    |  |      |
| ont situées dans un espar<br>ne font l'objet d'aucune segr<br>onnée directement par le p                                                                                                               | ce d'adressage<br>mentation. Deux<br>programme. On                   |    |  |      |
| ont situées dans un espar<br>ne font l'objet d'aucune segr<br>onnée directement par le p<br>octets, ou aux 128 premiers<br>N AX, 0A8H                                                                  | ce d'adressage<br>mentation. Deux<br>programme. On                   |    |  |      |
| ont situées dans un espac<br>ne font l'objet d'aucune segr<br>onnée directement par le p<br>octets, ou aux 128 premiers<br>N AX , 0A8H<br>DUT 0A8H , AL                                                | ce d'adressage<br>mentation. Deux<br>programme. On<br>mots d'entrées |    |  |      |
| ont situées dans un espac<br>ne font l'objet d'aucune segr<br>onnée directement par le p<br>octets, ou aux 128 premiers<br>N AX , 0A8H<br>DUT 0A8H , AL                                                | ce d'adressage<br>mentation. Deux<br>programme. On<br>mots d'entrées |    |  |      |
| ont situées dans un espac<br>ne font l'objet d'aucune segr<br>onnée directement par le p<br>octets, ou aux 128 premiers<br>N AX , 0A8H<br>DUT 0A8H , AL<br>ottenue dans le registre DX. C<br>sorties . | ce d'adressage<br>mentation. Deux<br>programme. On<br>mots d'entrées |    |  |      |
| ont situées dans un espac<br>ne font l'objet d'aucune segr<br>onnée directement par le p<br>octets, ou aux 128 premiers<br>N AX , 0A8H<br>DUT 0A8H , AL                                                | ce d'adressage<br>mentation. Deux<br>programme. On<br>mots d'entrées |    |  |      |
| ont situées dans un espac<br>ne font l'objet d'aucune segr<br>onnée directement par le p<br>octets, ou aux 128 premiers<br>N AX , 0A8H<br>DUT 0A8H , AL<br>ottenue dans le registre DX. C<br>sorties . | ce d'adressage<br>mentation. Deux<br>programme. On<br>mots d'entrées | 36 |  |      |



# L'adressage des sauts de programme

segment CS Deux catégories de saut sont à distinguer : - saut à l'intérieur du même segment , dit intra-segment : CS n'est pas modifié

Les instructions du programme sont pointées par le pointeur d'instruction IP dans le

- saut à l'extérieur du segment , dit inter-segment : CS est modifié.

# L'adressage des sauts de programme

## Saut intra-segment :

Saut conditionnel: L'adressage est dit relatif au pointeur d'instruction: cela consiste à ajouter au pointeur d'instruction IP un nombre de 8 bits , dont le signe est étendu sur 16 bits. Ce nombre est le déplacement dans le programme ( pas dans le segment ). Ce genre est limité à :
- 127 octets en avant ,

- 128 octets en arrière .

#### Exemple:

- JBE INF\_EGAL - JNA NON\_SUP - JE EQUAL

Saut inconditionnel : Le saut peut aussi être inconditionnel. Dans ce cas, l'adressage est soit relatif, soit indirect. Dans le cas du relatif, le nombre ajouté au pointeur d'instruction est un octet, ou un mot, qui permet alors de couvrir tout le segment.



| a pile |  |
|--------|--|
|--------|--|

La pile est implantée dans l'espace mémoire . Elle est pointée par le registre SP dans le segment SS exclusivement .

Les données à empiler ou à dépiler sont uniquement des mots . La provenance ou la destination est un registre ou un emplacement mémoire adressé par l'un des modes décrit précédemment . La pile se remplie par adresses décroissantes et se vide par adresses croissantes. L'instruction suivante : PUSH TABLE[DI], réalise :

(SP) <-- (SP)-2 , ((SP) dans le seg SS )<-- ((DI)+TABLE dans le seg DS)

POP TABLE[DI] (SP = SP + 2), réalise l'opération de récupération

La pile sera traitée avec plus de détails dans le chapitre réservé à la " PROGRAMMATION DU 8086".

# Les sous-programmes Les sous programmes

Les possibilités d'adressage des sous programmes sont les mêmes que celles des sauts inconditionnels intra-segments ou intersegments .

Lors de l'écriture d'un sous programme, le programmeur doit être attentif au point suivant : - sous programme intra-segment : le pointeur d'instruction IP est

placé dans la pile avant le saut. A la fin du sous programme l'instruction RET restaure IP .

- sous programme inter segment : le pointeur d'instruction IP, puis le registre de segment CS, sont placés dans la pile avant le saut . A la fin du sous programme, l'instruction RET, différente de la précédente bien qu'ayant le même nom, restaure IP et CS. Le programmeur doit déclarer un sous programme inter segment

ou intra segment, pour que l'assembleur puisse coder correctement l'instruction RET. (Voir chapitre Pragrammation du 8086).



# Instructions du 8086

## Transfert de données

- MOV
- POP

#### - OUT

- Instructions arithmétiques
  - ADD
  - DIV

#### - MUL

# Instructions logiques

- - OR
  - AND - DEC

## Décalages et rotations

- ROL
- RCL
- SAL

# Instructions de branchement

- JMP
- CALL
- JCXZ Manipulations de caractères
  - REP MOVS

  - REP MOVSB
  - REP MOVSW
- Instructions de commande
  - INT N
  - STI
  - CLI

#### Remarque

Un ou plusieurs indicateurs d'état peuvent être affectés par l'exécution de ces instructions.