Section courante

A propos

Section administrative du site

Assembleur 80x86

CALL

INTEL 8088+ CALL

Syntaxe

CALL adresse

Paramètres

Nom Description
adresse Ce paramètre permet d'indiquer l'adresse où est situé le sous-programme.

Description

Cette instruction force le microprocesseur à exécuter les instructions du sous-programme indiqué par l'adresse d'appel avant de continuer. Dès que la routine est terminé, l'exécution reprendra son cours à l'instruction suivant le CALL.

Algorithme

Appel long Appel court
PUSH CS
PUSH IP
CS:IP ← Destination
PUSH IP
IP ← Destination

Mnémonique

Instruction Opcode Description
CALL rel16off E8h iw Appel court avec une destination spécifié par une adresse 16 bits
CALL rel32off E8h id Appel court avec une destination spécifié par une adresse 32 bits
CALL reg/mem16 FFh /2 Appel court avec une destination spécifié par un registre/mémoire 16 bits
CALL reg/mem32 FFh /2 Appel court avec une destination spécifié par un registre/mémoire 32 bits. Il n'y a pas de préfixe pour l'encoder en mode 64 bits.
CALL reg/mem64 FFh /2 Appel court avec une destination spécifié par un registre/mémoire 64 bits
CALL FAR pntr16:16 9Ah cd Appel long direct, avec un destination spécifié par un pointeur long. Invalide en mode 64 bits.
CALL FAR pntr16:32 9Ah cp Appel long direct, avec un destination spécifié par un pointeur long. Invalide en mode 64 bits.
CALL FAR mem16:16 FFh /3 Appel long indirect, avec un destination spécifié par un pointeur long en mémoire.
CALL FAR mem16:32 FFh /3 Appel long indirect, avec un destination spécifié par un pointeur long en mémoire.

Exceptions

Message Mode réel Virtuel 8086 Mode protégé Description
#AC(Vérifie l'alignement)   X X Un désalignement de la référence mémoire est effectué quand une vérification d'alignement est activé
#GP(Protection général) X X X Une adresse mémoire dépasse la limite du segment de données ou n'est pas canonique
X X X L'opérande de destination dépasse la limite du segment de code ou n'est pas canonique.
    X Un segment de données nulle est utilisé comme référence mémoire
#GP(Sélecteur)     X Le sélecteur de segment de code de destination est un sélecteur nulle.
    X Un code, d'un appel de pont, de tâche de pont, ou un descripteur TSS dépasse la limite du descripteur de table.
    X Un sélecteur de segment de bit TI est fixer mais le sélecteur LDT est un sélecteur nulle.
    X Le descripteur de segment spécifié par l'instruction n'est pas un segment de code, une tâche de pont, un appel de pont, ou un TSS disponible en mode legacy, ou un segment de code n'étant en mode 64 bits ou un appel de pont 64 bits dans un mode long.
    X Le RPL de sélecteur de segment de code spécifié est non-conforme à une instruction plus grande que le CPL, ou le DPL n'est pas égale au CPL.
    X Le DPL du descripteur de segment de code spécifié est conforme au instruction plus grande que le CPL.
    X Le DPL de l'appel de pont, de tâche de pont, ou le descripteur TSS spécifié par l'instruction est inférieur au CPL ou RPL.
    X Le descripteur de segment spécifié par l'appel de pont ou la tâche de pont est un sélecteur nulle.
    X Le descripteur de segment spécifié par l'appel de pont n'est pas en segment de code en mode legacy pi n'est pas un segment de code 64 bits dans le mode long.
    X Le DPL du du descripteur de segment spécifié par l'appel de pont est plus grand que le CPL.
    X L'appel d'un pont 64 bits avec des bits d'attributs étendues n'est pas à 0.
    X Le TSS du descripteur est présent dans le LDT.
#NP(Segment non présent)     X L'accès au segment de code, appel d'un pont, tâche de pont, ou TSS n'est pas présent.
#PF(Faute de page)   X X Une faute de page résultat de l'exécution de l'instruction
#SS(Pile non-canonique) X X X Une adresse mémoire dépasse la limite du segment de pile ou n'est pas canonique
#SS(Pile) X X X Une adresse mémoire dépasse la limite du segment de pile ou n'est pas canonique, et n'est pas l'échange de pile spécifié.
#SS(Sélecteur)     X Après l'échange de pile, un accès mémoire dépasse la limite de segment de pile ou est non-canonique.
    X Après l'échange de pile, le registre SS n'est pas chargé avec un sélecteur de segment non-nulle et le segment est marqué comme non-présent.
#TS(Sélecteur TSS invalide)     X Lors d'une partie de l'échange entre la pile, la destination du segment de la pile ou du registre RSP dans le TSS est en dehors des limites TSS.
    X Lors d'une partie de l'échange entre la pile, la destination du segment de la pile ou du registre RSP dans le TSS est dans un sélecteur nulle.
    X Lors d'une partie de l'échange entre la pile, la destination du sélecteur de pile du bit TI est fixé, mais le sélecteur LDT n'est pas un sélecteur nulle.
    X Lors d'une partie de l'échange entre la pile, la destination du sélecteur de segment de pile dans le TSS est en dehors des limites de la table du descripteur GDT ou LDT.
    X Lors d'une partie de l'échange entre la pile, la destination du sélecteur de segment de pile dans le TSS contient un RPL n'est pas égale au DPL.
    X Lors d'une partie de l'échange entre la pile, la destination du sélecteur de segment de pile dans le TSS contient un DPL n'est pas égale au CPL du sélecteur de segment de code.
    X Lors d'une partie de l'échange entre la pile, la destination du sélecteur de segment de pile dans le TSS n'est pas dans un segment écrivable.
#UD(Opcode invalide) X X X L'appel long indirect avec le Opcode (FFh /3) est un opérande de registre.
    X L'appel long direct avec le Opcode (9Ah) est effectué en mode 64 bits.

Remarque

Exemple

Voici un exemple en Turbo Pascal montrant l'utilisation de cette instruction :

  1. Program AsmCallSamples;
  2.  
  3. Var _AX:Word;
  4.  
  5. BEGIN
  6.  ASM
  7.   CALL @SetValue
  8.   JMP @End
  9.   MOV AX,0002h
  10. @SetValue:
  11.   MOV AX,0001h
  12.   RETN
  13. @End:
  14.   MOV _AX,AX
  15.  END;
  16.  WriteLn('AX = ',_AX);
  17. END.

on obtiendra le résultat suivant :

AX = 1

Voir également

Langage de programmation - Assembleur 80x86 - Instruction RET
Langage de programmation - Assembleur 80x86 - Instruction RETF
Langage de programmation - Assembleur 80x86 - Instruction RETN
Langage de programmation - Structure de données - Structures récursives linéaires - Pile

Références

Le livre d'Or PC, Martin Althaus, 1992, ISBN: 2-7361-0934-1, page 806
Assembleur Facile, Philippe Mercier, 1990, ISBN: 2-501-01176-7, page 401
AMD64 Architecture Programmer's Manual Volume 3: General-Purpose and System Instructions, Edition Advanced Micro Devices, Revision 3.14, September 2007, Publication No. 24594, page 76 à 83.
Intel® 64 and IA-32 Architectures Software Developer’s Manual Volume 2A: Instruction Set Reference, A-M, Edition Intel, Mars 2010, Publication No. 253666-034US, page 168 à 185.

Dernière mise à jour : Lundi, le 1 septembre 2014