IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

x86 16-bits Assembleur Discussion :

Dépôts sur la pile lors d'un call


Sujet :

x86 16-bits Assembleur

  1. #1
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Mai 2003
    Messages
    59
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations professionnelles :
    Secteur : Service public

    Informations forums :
    Inscription : Mai 2003
    Messages : 59
    Points : 39
    Points
    39
    Par défaut Dépôts sur la pile lors d'un call
    Bonjour,

    J'essaye de comprendre ce petit programme.
    Enfait il y a une erreur et pour la resoudre il faut utilise le registre bp

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
     
    ax = a
    bx = b
     
    nop
    push ax
    push bx
    call 130
    nop
     
    130 pop ax
    pop bx
    add ax , bx
    push ax
    ret
    Si j'ai bien compris ici on charge la valeur du registre ax qui est enfaite en dessous du registre bx d'où l'erreur, c'est pour ça qu'il faut utiliser le registre bp mais je vois pas comment faire.

    Merci

  2. #2
    Modérateur
    Avatar de Obsidian
    Homme Profil pro
    Développeur en systèmes embarqués
    Inscrit en
    Septembre 2007
    Messages
    7 371
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 47
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Développeur en systèmes embarqués
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2007
    Messages : 7 371
    Points : 23 626
    Points
    23 626
    Par défaut
    Sais-tu comment fonctionne CALL ? Le micro-processeur empile l'adresse de retour avant de sauter vers ta fonction. L'instruction symétrique RET dépile cette adresse dans le pointeur de programme. Elle est donc équivalente à « POP IP ».

    Donc, quand tu fais POP AX pour la première fois, en 130, tu récupères l'adresse de retour et pas la valeur du premier paramètre. À noter également qu'une pile est une structure LIFO (Last In First Out) : le premier élément entré est le dernier sorti. Il faut donc dépiler tes registres dans l'ordre inverse de celui dans lequel tu les as empilés : PUSH AX ; PUSH BX ; POP BX ; POP AX. Bon, en l'occurence, ça n'a pas d'importance parce qu'il n'y a pas de lien entre les deux routines.

    Quoi qu'il en soit, il faut commencer par dépiler l'adresse de retour et la mettre en sécurité avant de dépiler le reste, soit aller lire le contenu de la pile à la main (méthode préférée, en général). BP sert en général à émuler un cadre de pile, mais tu peux t'en servir à cette fin. Un JMP BP te permettra ensuite de ressortir.

  3. #3
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Mai 2003
    Messages
    59
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations professionnelles :
    Secteur : Service public

    Informations forums :
    Inscription : Mai 2003
    Messages : 59
    Points : 39
    Points
    39
    Par défaut
    Merci Obsidian,

    J'ai bien compris se que faisait le programme.
    Mais un jmp bp, va sauter sans résoudre le problème..

    Je suis perdu

  4. #4
    Modérateur
    Avatar de Obsidian
    Homme Profil pro
    Développeur en systèmes embarqués
    Inscrit en
    Septembre 2007
    Messages
    7 371
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 47
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Développeur en systèmes embarqués
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2007
    Messages : 7 371
    Points : 23 626
    Points
    23 626
    Par défaut
    Citation Envoyé par Mercenaire Voir le message
    J'ai bien compris se que faisait le programme.
    Non, je crois que tu n'as pas compris le problème et c'est pour cela que tu n'arrives pas à le résoudre. Le code que tu nous présentes est bugué et je t'ai expliqué pourquoi : à l'entrée dans ta fonction, tu as trois choses dans ta pile :

    Code text : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
         +-------------------+
      2  | Adresse de retour |
         +-------------------+
      1  |   Contenu de BX   |
         +-------------------+
      0  |   Contenu de AX   |
         +-------------------+

    Quand ta fonction en 130 fait « POP AX ; POP BX », elle récupère l'adresse de retour et le premier paramètre, pour les additionner ensemble. Le résultat n'a aucun sens. D'autre part, ADD stocke le résultat dans AX. Ton adresse de retour est écrasée. Le PUSH AX final que je soupçonne d'être destiné à restaurer cette adresse ne sert donc à rien.

    Il faut d'abord récupérer cette adresse avec un « POP BP », puis faire le reste.

    Mais un jmp bp, va sauter sans résoudre le problème..
    Non, justement. Ton PUSH AX final va devenir à la place un PUSH BP pour que ton RET puisse fonctionner. Seulement, il est idiot de rempiler un registre pour le re-dépiler juste après. Autant sauter directement vers l'adresse qu'il contient.

  5. #5
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Mai 2003
    Messages
    59
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations professionnelles :
    Secteur : Service public

    Informations forums :
    Inscription : Mai 2003
    Messages : 59
    Points : 39
    Points
    39
    Par défaut
    Merci, pour que ça fonctionne ça donnerai

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
     
    ax = a
    bx = b
     
    nop
    push bp
    push bx
    call 130
    nop
     
    130 pop bx
    pop ax
    add ax , bx
    push ax
    jmp bp
    ret

  6. #6
    Modérateur
    Avatar de Obsidian
    Homme Profil pro
    Développeur en systèmes embarqués
    Inscrit en
    Septembre 2007
    Messages
    7 371
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 47
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Développeur en systèmes embarqués
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2007
    Messages : 7 371
    Points : 23 626
    Points
    23 626
    Par défaut
    Citation Envoyé par Mercenaire Voir le message
    Merci, pour que ça fonctionne ça donnerai

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    ...
     
    jmp bp
    ret
    Oui, à condition de dépiler l'adresse de retour et de la mettre dans BP. Sinon, tu vas sauter n'importe où. Il faut mettre un POP BP au début de ta fonction.

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. [MySQL] Appliquer une fonction sur un champ lors d'une requête
    Par Jérémy197 dans le forum PHP & Base de données
    Réponses: 2
    Dernier message: 13/08/2006, 13h29
  2. Evènement sur le body lors de la fermeture d'une fenêtre
    Par Yaz dans le forum Général JavaScript
    Réponses: 5
    Dernier message: 23/09/2005, 17h54
  3. Réponses: 4
    Dernier message: 28/07/2005, 16h22
  4. Réponses: 2
    Dernier message: 12/07/2004, 11h43
  5. Créer des objets sur la pile ?
    Par Cornell dans le forum Langage
    Réponses: 8
    Dernier message: 03/03/2003, 11h47

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo