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 32-bits / 64-bits Assembleur Discussion :

Explication Programme sur Nasm


Sujet :

x86 32-bits / 64-bits Assembleur

  1. #1
    Candidat au Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Janvier 2014
    Messages
    4
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Matériel informatique

    Informations forums :
    Inscription : Janvier 2014
    Messages : 4
    Points : 2
    Points
    2
    Par défaut Explication Programme sur Nasm
    Bonjour,

    j'ai appris à programmer quelques trucs basiques sur assembleur Yasm (qui est similaire au Nasm je crois) par contre j'ai pas du tout assimilé la notion des pointeurs en assembleur (EBP/ESP surtout), j'ai un exemple de programme ici dont je ne comprends pas le fonctionnement et je compte sur vous pour m’éclaircir un peu

    ......
    asm_main:
    enter 0,0
    pusha

    mov eax,5
    push eax
    call fonct
    add esp,4

    popa
    mov eax,0
    leave
    ret

    fonct :

    push ebp
    mov ebp,esp
    mov eax,[ebp+8]
    cmp eax,1
    je term_cond
    dec eax
    push eax
    call fonct
    add esp,4
    add eax,[ebp+8]
    jmp short end_fonct


    term_fonct:
    mov eax,2

    end_fonct:

    call print_int
    call print_nl

    pop ebp
    ret
    voila, j'ai mis en gras ce que je n'ai pas compris.
    Merci

  2. #2
    Membre confirmé Avatar de bifur
    passe le balais et l'aspirateur
    Inscrit en
    Mars 2008
    Messages
    314
    Détails du profil
    Informations personnelles :
    Âge : 38

    Informations professionnelles :
    Activité : passe le balais et l'aspirateur

    Informations forums :
    Inscription : Mars 2008
    Messages : 314
    Points : 550
    Points
    550
    Par défaut
    ebp et esp sont deux registre réservé en général a la gestion de la pile (esp ne sert quasiment qu'a ça d'ailleur)

    mov [542],ax met le contenu de ax a l'adresse 542
    mov [ebp],ax fait la même chose mais l'adresse de destination est contenu dans le registre ebp

    "push eax" revient a faire
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    mov [esp],eax
    sub esp,4


    quant a "call print_int" et "call print_nl" je ne sait pas ce que ça fait sauf que ça apelle les fonction print_int (affichage d'un entienr vu le nom) et print_nl

  3. #3
    Membre averti
    Profil pro
    Inscrit en
    Mars 2013
    Messages
    397
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2013
    Messages : 397
    Points : 424
    Points
    424
    Par défaut
    Si tu ne comprends pas, utilise un debugger, genre "Immunity debugger" sous win32, et "edb debugger" sous Linux 32/64.

    "push ebp":
    Sauvegarde l'adresse courante d'ebp sur la pile.

    "mov ebp,esp":
    Sauvegarde l'adresse courante de la pile dans ebp.

    "mov eax,dword [ebp+8]":
    Met le 1er argument empilé avant le "call" de la fonction dans le registre "eax".
    Cet argument étant "5", cette valeur sera remise dans eax, sachant qu'elle y est déjà.

    Donc en gros, ces deux lignes sont utile lorsqu'il y a un "call" avec des arguments, afin de retrouver les arguments facilement.
    Le 1er argument se trouvera toujours à [ebp+8], le deuxième à [ebp+12], etc..

    "add esp,4" sert à nettoyer la pile de l'argument passé.
    Pour deux arguments, "add esp,8" après le call, etc..

    Dans ton code, tu peux aussi faire nettoyer la pile par la fonction appelée, via un:
    a+

Discussions similaires

  1. Besoin d'explication programme trouvé sur internet
    Par djgll01 dans le forum Débuter avec Java
    Réponses: 3
    Dernier message: 21/04/2015, 20h39
  2. [Eclipse] Programmer sur un fond noir
    Par raj dans le forum Eclipse Java
    Réponses: 2
    Dernier message: 27/12/2004, 10h15
  3. [Reseau] Execution de programmes sur un autre PC
    Par el3gans dans le forum Général Java
    Réponses: 5
    Dernier message: 18/11/2004, 11h20
  4. Methode de programmation sur des gros projets
    Par dynobremo dans le forum EDI
    Réponses: 10
    Dernier message: 08/06/2004, 02h59
  5. Déclenchement Programme sur Virtual Key
    Par Tom-G dans le forum API, COM et SDKs
    Réponses: 9
    Dernier message: 09/05/2003, 12h58

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