1 / 10

Système d’exploitation : Assembleur

Système d’exploitation : Assembleur. Semaine 12 Les procédures. Les procédures (1/9). Blocs d’instructions permettant de réaliser un traitement spécifique.

ashanti
Download Presentation

Système d’exploitation : Assembleur

An Image/Link below is provided (as is) to download presentation Download Policy: Content on the Website is provided to you AS IS for your information and personal use and may not be sold / licensed / shared on other websites without getting consent from its author. Content is provided to you AS IS for your information and personal use only. Download presentation by click this link. While downloading, if for some reason you are not able to download a presentation, the publisher may have deleted the file from their server. During download, if you can't get a presentation, the file might be deleted by the publisher.

E N D

Presentation Transcript


  1. Système d’exploitation : Assembleur Semaine 12 Les procédures

  2. Les procédures (1/9) • Blocs d’instructions permettant de réaliser un traitement spécifique. • Les procédures permettent de découper un programme en modules distincts qui pourront être appelés depuis n’importe quel point du programme. • 2 étapes dans l’écriture d’une procédure :la DECLARATION et l’APPEL • DECLARATION d’une procédure : Forme générale : nom PROC …… RET nom ENDP ; end of procedure où nom est le label (c’est le nom de la procédure) PROC est l’instruction qui indique le début de la procédure nom ENDP est l’instruction qui indique la fin de la procédure nom RET est l’instruction qui rend la main au programme appelant

  3. avant après A A B B SP IP SP avant après A A B B SP CS IP SP Les procédures (2/9) • APPEL d’une procédure • Forme générale : CALL nom où CALL est l’instruction qui permet d’exécuter une procédure nom est le nom de la procédure CALL va réaliser : 1) un PUSH 2) une modification de IP • FONCTIONNEMENT • L’instruction CALL provoque le dépôt automatique sur la pile (c.à.d. un PUSH) de l’adresse de retour, c.à.d. l’adresse de l’instruction qui suit CALL en mémoire. • Appel intra-segment : seul IP est empilé : • Appel inter-segment : CS et IP sont empilés :

  4. Les procédures (3/9) • FONCTIONNEMENT (suite) • L’instruction RET met fin à l’exécution de la procédure et provoque l’exécution de l’instruction dont l’adresse se trouve sur la pile (c.à.d. l’adresse de retour qui fut empilée par le CALL). • RET effectue donc un POP qui vient charger IP (cas d’un appel intra-segment) ou CS et IP (cas d‘un appel inter-segment). • Rem importante : Etant donné que l’utilisation des procédures nécessite le passage par la pile, ne pas oublier d’utiliser la directive .STACK !! • TYPE D’UNE PROCEDURE • Le type de la procédure (NEAR ou FAR) est donné en argument de PROC Exemple : nom PROC NEAR • Si le type n’est pas indiqué, le type est en accord avec le .model NEAR pour “small” et “compact” ;FAR pour “medium”, ”large” et “huge”.Avec NEAR, seul IP est empilé.Avec FAR, CS et IP sont empilés. • Si le type par défaut ne convient pas, utiliser NEAR ou FAR

  5. Les procédures (4/9) • PASSAGE DE PARAMETRES A UNE PROCEDURE • Il existe plusieurs manières de passer des paramètres à une procédure : • par les registres Le plus rapide, mais nombre limité de registres. • par la pile : il suffit d’empiler avant le CALL. le paramètre peut être une valeur ou une adresse (= un pointeur). La procédure peut alors faire varier la valeur de la variable en utilisant le pointeur. Le registre BP (Base Pointer - lié à SS) sera utilisé pour accéder aux paramètres situés dans la pile. • PASSAGE DES PARAMETRES EN LANGAGE C • Lors de l’appel à une fonction, le programme appelant empile lui-même les paramètres à passer à la fonction et dépile les paramètres de retour.

  6. Les procédures (5/9) • REGLE DE BONNE PRATIQUE • La procédure commencera par une zone de commentaires : • nom PROC ;==================================================; ; Indiquer brièvement ici ce que fait la procédure ; ; ; ; Paramètres d’entrée : ; ; Paramètres de sortie : ; ;==================================================; • EXEMPLE 1 : procédure qui met à FFFF les registres ax,bx,cx,dx .model small .stack .code call proc1 mov ah,4ch int 21h proc1 proc ; mise à FFFF de 4 registres ; paramètres d’entrée : aucun ; paramètres de sortie : aucun movax,0FFFFh movbx,0FFFFh movcx,0FFFFh movdx,0FFFFh ret proc1 endp end

  7. EXEMPLE 2 : calcul de la somme de 2 nombres passés comme paramètres en utilisant les registres AX et BX (passage par valeur). .model small .stack .data a dw 1234h b dw 5678h .code movax,@data movds,ax movax, a movbx, b call somme mov ah,4ch int 21h somme proc ; calcul de la somme de 2 nombres ; paramètres d’entrée : les opérandes en AX et BX ; paramètres de sortie : le résultat dans AX addax,bx ret somme endp end Les procédures (6/9)

  8. Les procédures (7/9) • EXEMPLE 3 : • Somme de 2 nombres passés comme paramètres en utilisant les registres SI, DI et BX (passage par adresse). .model small .stack .data a dw 1234h b dw 5678h resultdw ? .code movax,@data movds,ax movsi,offset a movdi,offset b movbx,offsetresult call somme mov ah,4ch int 21h somme proc ; calcul de la somme de 2 nombres ; paramètres d’entrée : adresse des opérandes en SI et DI ; paramètres de sortie : Résultat à l’adresse pointée par BX ; (c.à.d. dans result) movax,[si] addax,[di] mov [bx],ax ret somme endp end Remarque: :Etant donné que AX est utilisé dans la procédure, si la valeur de AX avait été importante pour la suite du programme, AX aurait été sauvé sur la pile avant le CALL (en utilisant PUSH AX)

  9. Les procédures (8/9) • EXEMPLE 4 : • calcul de la somme de 2 nombres (16 bits) passés comme paramètres en utilisant la pile. .model small .stack .data a dw 1234h b dw 5678h resultdw ? .code movax,@data movds,ax push result push b ; passage des push a ; paramètres call somme pop a pop b pop result mov ah,4ch int 21h somme proc ; calcul de la somme de 2 nombres ; paramètres d’entrée : les opérandes a et b dans la pile ; paramètres de sortie : le résultat dans la pile push bp ; sauve bp movbp,sp movax,[bp+4] addax, [bp+6] mov [bp+8],ax pop bp ; récupère bp ret somme endp end

  10. Après CALL Après PUSH A Après PUSH B Début .CODE Après PUSH RESULT SP : 0A RESULT RESULT RESULT RESULT SP : 08 B B B SP : 06 A A SP : 04 IP SP : 02 Après PUSH BP Après POP BP Après POP A Après RET RESULT RESULT RESULT RESULT B B B B SP : 06 A A A SP : 04 IP IP SP : 02 ... BP SP : 00 Les procédures (9/9) • EXEMPLE 4 (suite): Que se passe-t-il dans la pile ?

More Related