[PDF] [PDF] Travaux dirigés : programmation en mini-assembleur

L'objectif de ce TD est de vous familiariser avec le cycle d'exécution d'un processeur et avec la notion de flux d'instructions Pour cela, il vous est demandé d' 



Previous PDF Next PDF





[PDF] Assembleur - Ecole Mohammadia dingénieurs

Assembleur : Exercices avec Solutions EMI Page 3/34 Introduction à la programmation en assembleur (TASM) Le langage assembleur est classé dans la 



[PDF] EXERCICE A : Programmation en assembleur (5 points) Corrigé - SoC

assembleur ? Soit le programme C suivant : int fonca(int a) { int la1,la2; la1= 



[PDF] TD 4 : Programmation en assembleur 8086 - jouili

Exercice 1 : Ecrire un programme, en langage assembleur 8086, qui permet de compter les nombres nuls dans un tableau d'octets mémoire de longueur 100h 



[PDF] Premier examen – Corrigé

c 4004 d 80186 e 8080 f 8086 g 8088 h Pentium 4 i Pentium j Pentium II k Pour chacune des lignes de la routine assembleur, identifiez les modes d' adressage utilisés : Numéro Le prototype suivant a été défini dans un programme C



[PDF] Initiation à lassembleur - Zenk - Security

Corrigé des exercices externe qui est de 16 bits dans le 8086 et de 8 bits dans le 8088 Exercices 1 Écrire un programme assembleur qui affiche le message “Bonjour le monde



[PDF] Travaux pratique en programmation assembleur - ResearchGate

d'un processeur 8086 Avec rappels de cours, corrigés et programmes types embarqué à base d'un CPU Intel 8086, Micro Assembleur MASM comme assembleur et débugger Titres du Travail Pratique, Exercice N°-- ; Matière systemes 



[PDF] Travaux dirigés : programmation en mini-assembleur

L'objectif de ce TD est de vous familiariser avec le cycle d'exécution d'un processeur et avec la notion de flux d'instructions Pour cela, il vous est demandé d' 



[PDF] ´Eléments darchitecture des ordinateurs : travaux pratiques d

1979 le 8088 est la version 8 bits du 8086 il a les mêmes caractéristiques, mais un Le fichier source d'un programme assembleur est divisé en — au moins — deux Recommencez l'exercice précédent avec les dispositions suivantes :



[PDF] EXAMEN FINAL

Dans cet exercice, on s'intéresse à un microprocesseur qui a les mêmes rotation à droite ; écrire une portion de programme assembleur 8086 qui réalise cela



[PDF] Assembleur i8086 - Academie pro

ANATOMIE D'UN PROGRAMME EN ASSEMBLEUR 2 1 Exemple ; Forme générale d'un fichier source en assembleur 8086 ; Nom du fichier : modele asm



pdf 4 Initiation à l'assembleur - Université Laval

Vers 1980 le 8086 et le 8088 font leur apparition ce dernier avec le premier PC d’IBM Ce sont des processeurs de 16 bits avec un bus d ’adresses de 20 bits qui avaient une capacité d ’adressage de 1 Mo Le 8088 diffère du 8086 par la largeur du bus de données externe qui est de 16 bits dans le 8086 et de 8 bits dans le 8088



Exercices corrig es sur l’assembleur - Université TÉLUQ

Exercice 1 2 Ecrivez un code assembleur qui permet de calculer le carr e d’un nombre Solution 1 2 Le code assembleur pour calculer le carr e d’un nombre est comme suit: MOV AX#nombre MUL AX Exercice 1 3 Ecrivez un code assembleur qui permet de calculer la somme des nombres binaires suivants: 1010 et 1001 Solution 1 3



4 Initiation à l'assembleur - Université Laval

EXERCICE A : Programmation en assembleur (5 points) Corrigé A2) A partir du code C précédent remplir le tableau suivant A1) Quelles sont les 3 grandes parties qui composent une fonction F écrite en assembleur ? Soit le programme C suivant : int fonca(int a) { int la1la2; la1=a+1; la2=a+2; return (la1+la2)/2;



Searches related to exercices corrigés programmation assembleur 8086

Pour le 8086 et donc pour nous programmeurs du 8086 un octet est d´esign´e par un couple ( num´ero de segment d´eplacement dans le segment ) qui constituent une adresse segment´ee (AS) Un segment est un ensemble de 64 Koctets cons´ecutifs Le d´eplacement (ou o?set) sp´eci?e un octet particulier dans un segment (cf ?g 1 2)

[PDF] exercices corrigés programmation en c pdf

[PDF] exercices corrigés reaction chimique pdf

[PDF] exercices corrigés recherche opérationnelle

[PDF] exercices corrigés relation binaire pdf

[PDF] exercices corrigés relation fondamentale de la dynamique

[PDF] exercices corrigés repère dans le plan 3ème pdf

[PDF] exercices corrigés rmn terminale s

[PDF] exercices corrigés second degré 1ère s

[PDF] exercices corrigés second principe thermodynamique

[PDF] exercices corrigés seconde fonctions

[PDF] exercices corrigés spectroscopie moléculaire

[PDF] exercices corrigés sur amplificateur opérationnel pdf

[PDF] exercices corrigés sur architecture des ordinateurs pdf

[PDF] exercices corrigés sur champ electrostatique pdf

[PDF] exercices corrigés sur l'auto induction pdf

Université Paris-NordL1

Institut GaliléeAnnée 2009-2010

Licence 1 - 1er semestre

Travaux dirigés : programmation en mini-assembleur. L"objectif de ce TD est de vous familiariser avec le cycle d"exécution d"un processeur et avec la notion de flux d"instructions. Pour cela, il vous est demandé d"écrire de petits programmes

dans le langage assembleur présenté en cours et de simuler leur exécution par le processeur.

Correction.

Note aux chargés de TD.

- Dans le texte des corrections se trouvent également quelques explications de correction. Bien entendu, vous n"avez pas à en parler aux étudiants (boucle for,gcc -S, etc.). - Amil est très rudimentaire dans ses possibilités d"écriredes commentaires. Dans cette feuille, il y a des commentaires ligne à ligne, mais aussi unetentative d"indiquer où sont les différents blocs de code dans un style balise xml/html : une ligne avec en commentaire signale la première ligne du blocbloc1, une ligne avec en commentaire signale la dernière ligne du bloc, et une ligne avec en commentairesignale l"unique ligne du blocbloc1. - les traces contiennent une colonneinstructions: cette colonne n"a pas lieu d"être dans les corrections (elle aide juste à relire la trace, qui est générée automatiquement). 1

CyclesCPinstructionr01011

INIT1?5?

12lecture 10 r05

23ecriture r0 115

34stop

Figure1 - Simulation de la copie de valeur

Jeu d"instructions (simplifié)

stopArrête l"exécution du programme. noopN"effectue aucune opération. saut iMet le compteur ordinal à la valeuri. sautpos ri jSi la valeur contenue dans le registreiest positive ou nulle, met le comp- teur de programme à la valeurj. valeur x riInitialise le registreiavec la valeurx. lecture i rjCharge, dans le registrej, le contenu de la mémoire d"adressei. ecriture ri jÉcrit le contenu du registreidans la mémoire d"adressej. inverse riInverse le signe du contenu du registrei. add ri rjAjoute la valeur du registreià celle du registrej(la somme obtenue est placé dans le registrej). soustr ri rjSoustrait la valeur du registreià celle du registrej(la différence obtenue est placé dans le registrej). mult ri rjMultiplie par la valeur du registreicelle du registrej(le produit obtenue est placé dans le registrej). div ri rjDivise par la valeur du registreicelle du registrej(le quotient obtenue, arrondi à la valeur entière inférieure, est placé dans le registrej).

Instructions plus avancées

et ri rjEffectue le et bit à bit de la valeur du registreiet de celle du registrej.

Le résultat est placé dans le registrej.

lecture *ri rjCharge, dans le registrej, le contenu de la mémoire dont l"adresse est la valeur du registrei ecriture ri *rjÉcrit le contenu du registreidans la mémoire dont l"adresse est la valeur du registrej.

1 Initialisation de la mémoire

Écrire les programmes répondant aux problèmes suivants :

1. Soit la valeur 8 contenue dans la case mémoire d"adresse 10. Recopier cette valeur à

l"adresse 11.

Correction.

1lecture 10 r0

2ecriture r0 11

3stop 4 2

2. Sans connaître la valeur contenue à l"adresse 10, écrire 7à l"adresse 10.

Correction.

1valeur 7 r0

2ecriture r0 10

3stop 4

3. Sans connaître la valeur contenue à l"adresse 10, incrémenter cette valeur de 1.

Correction.

1lecture 10 r0

2valeur 1 r1

3add r1 r0

4ecriture r0 10

5stop 6

4. Soit une valeur quelconque,a, contenue à l"adresse 10. Initialiser la case d"adresse 11 à

a×2 + 1.

Correction.

1lecture 10 r0

2valeur 2 r1

3mult r1 r0

4valeur 1 r1

5add r1 r0

6ecriture r0 11

7stop 8

5. Soit une valeur quelconque,a, contenue à l"adresse 10. Initialiser la case d"adresse 11 à

a×(2 + 1).

Correction.

1lecture 10 r0

2valeur 2 r1

3valeur 1 r2

4add r1 r2

5mult r2 r0

6ecriture r0 11

7stop 8 3

2 Trace de programme assembleur

Nous allons désormais produire une représentation de l"exécution pas à pas de nos pro- grammes. Unetraced"un programme assembleur sera un tableau dont chaque lignecorrespond

à l"exécution d"une instruction par le processeur. Une colonne contiendra le cycle d"horloge du

processeur et une autre colonne le compteur de programme. Ily aura également une colonne

par registre utilisé dans le programme et par case mémoire oùdes données sont lues ou écrites

par les instructions du programme. Une première ligne, d"initialisation, montrera l"état de ces

registres et cases mémoires avant le début du programme. Ensuite, chaque exécution d"instruc-

tion sera représentée par une nouvelle ligne du tableau, jusqu"à exécution de l"instructionstop.

Dans cette ligne nous représenterons le cycle d"horloge du processeur (en commençant à 0 pour

la ligne d"initialisation), la valeur du compteur de programme après exécution de l"instruction,

et, s"il y a lieu, la valeur du registre ou de la case mémoire modifiée par le programme.

2.1 Exemple de trace

Soit le programme ci-dessous :

1lecture 10 r0

2valeur 5 r2

3soustr r2 r0

4sautpos r0 8

5valeur 0 r0

6ecriture r0 11

7saut 9

quotesdbs_dbs2.pdfusesText_3