Accueil > > > RESTAURER UN FICHIER IMAGE SUR UNE DISQUETTE [TASM]
RESTAURER UN FICHIER IMAGE SUR UNE DISQUETTE [TASM]
Information sur la source
Description
Ben vous saviez comment créer floppy.img d'une disquette ben maintenant vous pouvez réécrire cette image sur la disquette sans aucun souci, avec en prime par rapport à l'autre programme, un affichage de l'avancement de l'écriture sur le disque. Rappel: à la moindre erreur le programme se stoppe et le format de disquette est toujours 3''1/2 et 1.44MO
Source
- ;CODE ASM x86 COMPILE SOUS TASM 5.0
-
- ;------------------------SEGMENT DE DONNEES-------------------------
- ;-------------------------------------------------------------------
- _data segment public
- Buffer DB 512 Dup(0) ;buffer correspondant à 1 secteur
- floppy db 'FLOPPY.IMG',0
- err1 db 'Erreur du lecteur de disquette',10,13,'$'
- err2 db 'Erreur fichier',10,13,'$'
- err3 db 'Le fichier n existe pas',10,13,'$'
- piste db 'Piste : $'
- secteur db 'Secteur : $'
- tete db 'Tete : $'
- espace db ' $'
- Handle dw ? ;pointeur sur fichier
- _data ends
- ;-------------------------------------------------------------------
-
-
- ;------------------------SEGMENT DE CODE----------------------------
- ;-------------------------------------------------------------------
- _code segment public
- assume cs:_code, ss:_stack
-
-
-
-
- erreur1:
- mov dx, Offset err1
- jmp erreur
- erreur2:
- mov dx, Offset err2
- jmp erreur
- erreur3:
- mov dx, Offset err3
- jmp erreur
- erreur:
- mov ah, 09h ;fonction d'affichage 09 (via le dos)
- int 21h ;interruption pour afficher err1 ou err2
- mov al, 01h ;on mets dans al le code d'erreur 1
- jmp fin
- fin:
- mov ah, 4Ch ;fonction 4Ch de sortie de programme avec code d'erreur
- int 21h ;interruption pour sortir
-
-
- start:
-
- ;synchronise le segment de donnée avec ds ainsi que es
- mov ax, _data
- mov ds, ax
- mov es, ax
-
- ;initialise le lecteur de disquette
- xor ah, ah ;mets la fonction 00h dans ah pour "initialiser un disque"
- xor dl, dl ;précise le numéro du disque à réinitialiser(00h pour le disquette A:)
- int 13h ;par l'int 13 (lecteur de disquette)
- jc erreur1 ;si CF=1 alors on affiche une erreur
-
- ;ouverture du fichier floppy.img
- mov ax, 3DA0h ;fonction 3Dh pour ouvrir un fichier et A0 mode accès bloque le fichier
- mov dx, Offset floppy ;@ du nom du fichier dans dx
- int 21h ;interruption dos
- jc erreur3 ;s'il le fichier n'existe pas alors on arrête
- mov [ds:Handle], ax ;mets dans la variable "Handle" le pointeur sur le fichier
-
- ;copie de la disquette (chaque boucle lit un secteur du fichier et l'écrit dans la disquette)
-
- ;initialisation des compteurs de la boucle (entre autres)
- mov al, 01h ;on lit un seul secteur à chaque fois
- xor dx, dx ;#lecteur disquette 0 + #face 0
- xor cx, cx ;#piste 0 + #secteur 0
- inc cl ;euh en fait #secteur 1 :-)
- mov bx, Offset Buffer;zone que l'on veut écrire
-
- ;debut de la copie
- jmp faire
-
- tantque:
- inc cl
- cmp cl,19 ;il y a 18 secteurs par piste
- jne faire
-
- mov cl, 1
- inc dh
- cmp dh, 2 ;il y a 2 faces par disques
- jne faire
-
- xor dh, dh
- inc ch
- cmp ch, 80 ;il y a 80 pistes par face
- je fintantque
-
- faire:
-
- ;lecture de 512 octets dans le fichier floppy.img
- push ax ;on sauvegarde quelques registres
- push bx
- push cx
- push dx
- mov ah, 3Fh ;fonction 40h pour lire dans un fichier
- mov bx, [ds:Handle] ;on précise dans bx le pointeur sur le fichier
- mov cx, 512 ;nombre d'octets à lire
- mov dx, Offset Buffer;@ du buffer où stoquer les 512 octets
- int 21h ;interruption dos pour lire
- jc erreur2 ;s'il s'est produit une erreur alors on arrête tout :)
- pop dx
- pop cx
- pop bx
- pop ax
-
-
- ;écriture du secteur de la disquette
- mov ah, 02h ;ATTENTION il faut mettre 02 avant CHAQUE écriture
- int 13h ;en effet si la lecture est un succès, ah vaut alors 00h
- jc erreur1
- ;/////////////////////////////////////////////AFFICHAGE FALCUTATIF/////////////////////////////
- ;affichage si le secteur est 1
- cmp cl, 1
- jne nepasafficher
- push ax bx cx dx
-
- mov ah, 0Eh
- mov al, 13
- int 10h
- mov ah, 09h
- mov dx, Offset piste
- int 21h
- mov al, ch
- call AFFICHER_AL_DEC
- mov dx, Offset espace
- int 21h
- mov dx, Offset secteur
- int 21h
- mov al, cl
- call AFFICHER_AL_DEC
- mov dx, Offset espace
- int 21h
- mov dx, Offset tete
- int 21h
- pop dx
- push dx
- mov al, dh
- call AFFICHER_AL_DEC
-
- pop dx cx bx ax
- nepasafficher:
- ;///////////////////////////////////////////////////////////////////////////////////////////
-
- jmp tantque
-
- fintantque:
-
- mov al, 00h
- jmp fin
-
-
- ;//////////////////////////////AFFICHER UN NOMBRE - FALCUTATIF/////////////////////////////////
- AFFICHER_AL_DEC: ;affiche une valeur comprise entre 0 et 255 contenue dans AL
- push cx bx ax
- mov bl, 64h ;100 en dec
- xor cl, cl
- boucle1:
- xor ah, ah
- div bl
- ;test pour ne pas afficher les zéros de devant
- or cl, al
- cmp cl, 0
- je nepasafficherzero1
- push ax
- add al, 30h ;48 en dec, cette addition permet d'obtenir un code ASCII
- mov ah, 0Eh
- int 10h
- pop ax
- nepasafficherzero1:
- cmp bx, 1
- je finboucle1
- push ax
- xor ah, ah
- mov al, bl
- mov bl, 0Ah ;pour diviser par 10 soit 0A
- div bl
- mov bl, al
- pop ax
- mov al, ah
- jmp boucle1
- finboucle1:
- cmp cl, 0
- jne fin1
- mov ax, 0E30h
- int 10h
- fin1:
- pop ax bx cx
- ret
- ;//////////////////////////////////////////////////////////////////////////////////////////
-
- _code ends
- ;--------------------------------------------------------------------
-
-
-
-
- ;------------------------SEGMENT DE LA PILE--------------------------
- ;--------------------------------------------------------------------
- _stack segment stack
- db 100h dup (?) ;déclare une pile de 256 octets
- _stack ends
- ;--------------------------------------------------------------------
-
-
-
-
- ;------------------------SAUT AU DEBUT DU PROGRAMME------------------
- end start
- ;--------------------------------------------------------------------
;CODE ASM x86 COMPILE SOUS TASM 5.0
;------------------------SEGMENT DE DONNEES-------------------------
;-------------------------------------------------------------------
_data segment public
Buffer DB 512 Dup(0) ;buffer correspondant à 1 secteur
floppy db 'FLOPPY.IMG',0
err1 db 'Erreur du lecteur de disquette',10,13,'$'
err2 db 'Erreur fichier',10,13,'$'
err3 db 'Le fichier n existe pas',10,13,'$'
piste db 'Piste : $'
secteur db 'Secteur : $'
tete db 'Tete : $'
espace db ' $'
Handle dw ? ;pointeur sur fichier
_data ends
;-------------------------------------------------------------------
;------------------------SEGMENT DE CODE----------------------------
;-------------------------------------------------------------------
_code segment public
assume cs:_code, ss:_stack
erreur1:
mov dx, Offset err1
jmp erreur
erreur2:
mov dx, Offset err2
jmp erreur
erreur3:
mov dx, Offset err3
jmp erreur
erreur:
mov ah, 09h ;fonction d'affichage 09 (via le dos)
int 21h ;interruption pour afficher err1 ou err2
mov al, 01h ;on mets dans al le code d'erreur 1
jmp fin
fin:
mov ah, 4Ch ;fonction 4Ch de sortie de programme avec code d'erreur
int 21h ;interruption pour sortir
start:
;synchronise le segment de donnée avec ds ainsi que es
mov ax, _data
mov ds, ax
mov es, ax
;initialise le lecteur de disquette
xor ah, ah ;mets la fonction 00h dans ah pour "initialiser un disque"
xor dl, dl ;précise le numéro du disque à réinitialiser(00h pour le disquette A:)
int 13h ;par l'int 13 (lecteur de disquette)
jc erreur1 ;si CF=1 alors on affiche une erreur
;ouverture du fichier floppy.img
mov ax, 3DA0h ;fonction 3Dh pour ouvrir un fichier et A0 mode accès bloque le fichier
mov dx, Offset floppy ;@ du nom du fichier dans dx
int 21h ;interruption dos
jc erreur3 ;s'il le fichier n'existe pas alors on arrête
mov [ds:Handle], ax ;mets dans la variable "Handle" le pointeur sur le fichier
;copie de la disquette (chaque boucle lit un secteur du fichier et l'écrit dans la disquette)
;initialisation des compteurs de la boucle (entre autres)
mov al, 01h ;on lit un seul secteur à chaque fois
xor dx, dx ;#lecteur disquette 0 + #face 0
xor cx, cx ;#piste 0 + #secteur 0
inc cl ;euh en fait #secteur 1 :-)
mov bx, Offset Buffer;zone que l'on veut écrire
;debut de la copie
jmp faire
tantque:
inc cl
cmp cl,19 ;il y a 18 secteurs par piste
jne faire
mov cl, 1
inc dh
cmp dh, 2 ;il y a 2 faces par disques
jne faire
xor dh, dh
inc ch
cmp ch, 80 ;il y a 80 pistes par face
je fintantque
faire:
;lecture de 512 octets dans le fichier floppy.img
push ax ;on sauvegarde quelques registres
push bx
push cx
push dx
mov ah, 3Fh ;fonction 40h pour lire dans un fichier
mov bx, [ds:Handle] ;on précise dans bx le pointeur sur le fichier
mov cx, 512 ;nombre d'octets à lire
mov dx, Offset Buffer;@ du buffer où stoquer les 512 octets
int 21h ;interruption dos pour lire
jc erreur2 ;s'il s'est produit une erreur alors on arrête tout :)
pop dx
pop cx
pop bx
pop ax
;écriture du secteur de la disquette
mov ah, 02h ;ATTENTION il faut mettre 02 avant CHAQUE écriture
int 13h ;en effet si la lecture est un succès, ah vaut alors 00h
jc erreur1
;/////////////////////////////////////////////AFFICHAGE FALCUTATIF/////////////////////////////
;affichage si le secteur est 1
cmp cl, 1
jne nepasafficher
push ax bx cx dx
mov ah, 0Eh
mov al, 13
int 10h
mov ah, 09h
mov dx, Offset piste
int 21h
mov al, ch
call AFFICHER_AL_DEC
mov dx, Offset espace
int 21h
mov dx, Offset secteur
int 21h
mov al, cl
call AFFICHER_AL_DEC
mov dx, Offset espace
int 21h
mov dx, Offset tete
int 21h
pop dx
push dx
mov al, dh
call AFFICHER_AL_DEC
pop dx cx bx ax
nepasafficher:
;///////////////////////////////////////////////////////////////////////////////////////////
jmp tantque
fintantque:
mov al, 00h
jmp fin
;//////////////////////////////AFFICHER UN NOMBRE - FALCUTATIF/////////////////////////////////
AFFICHER_AL_DEC: ;affiche une valeur comprise entre 0 et 255 contenue dans AL
push cx bx ax
mov bl, 64h ;100 en dec
xor cl, cl
boucle1:
xor ah, ah
div bl
;test pour ne pas afficher les zéros de devant
or cl, al
cmp cl, 0
je nepasafficherzero1
push ax
add al, 30h ;48 en dec, cette addition permet d'obtenir un code ASCII
mov ah, 0Eh
int 10h
pop ax
nepasafficherzero1:
cmp bx, 1
je finboucle1
push ax
xor ah, ah
mov al, bl
mov bl, 0Ah ;pour diviser par 10 soit 0A
div bl
mov bl, al
pop ax
mov al, ah
jmp boucle1
finboucle1:
cmp cl, 0
jne fin1
mov ax, 0E30h
int 10h
fin1:
pop ax bx cx
ret
;//////////////////////////////////////////////////////////////////////////////////////////
_code ends
;--------------------------------------------------------------------
;------------------------SEGMENT DE LA PILE--------------------------
;--------------------------------------------------------------------
_stack segment stack
db 100h dup (?) ;déclare une pile de 256 octets
_stack ends
;--------------------------------------------------------------------
;------------------------SAUT AU DEBUT DU PROGRAMME------------------
end start
;--------------------------------------------------------------------
Conclusion
bon ben voilà deux petits programmes assez complets permettant de créer une image puis de la réécrire, pratique pour archiver ses disques, de plus ce format .img est standard vous pouvez par exemple créer l'image d'une disquette bootable et la réutiliser avec un simulateur de pc comme Bochs.... Manque peut-être une petite amélioration sympa passer en paramètre de la ligne de commande le nom du fichier que l'on souhaiterait créer ou écrire car floppy.img c'est quelque peu contraignant...
Sources du même auteur
Sources de la même categorie
Commentaires et avis
|
Derniers Blogs
[MIX10] KEYNOTE DEUXIèME JOURNéE - INTERNET EXPLORER 9, HTML5, VISUAL STUDIO 2010, ODATA[MIX10] KEYNOTE DEUXIèME JOURNéE - INTERNET EXPLORER 9, HTML5, VISUAL STUDIO 2010, ODATA par cyril
Le deuxième keynote du mix fut très riche en contenu. Internet Explorer 9 Juste un après le lancement de Internet Explorer 8, Microsoft a dévoilé les nouveautés de Internet Explorer 9. Désormais, IE supportera HTML5, SVG et CSS3. L'élément ...
Cliquez pour lire la suite de l'article par cyril CERTIFICATIONS BETA .NET 4CERTIFICATIONS BETA .NET 4 par KooKiz
Les inscriptions pour les certifications beta .NET 4 ont commencé. L'inscription est offerte pour les examens suivants : - 71-511, TS: Windows Applications Development with Microsoft .NET Framework 4 - 71-515, TS: Web Applications Development with...
Cliquez pour lire la suite de l'article par KooKiz [MIX 2010] - MICROSOFT TRANSLATOR TECHNOLOGY PREVIEW V2[MIX 2010] - MICROSOFT TRANSLATOR TECHNOLOGY PREVIEW V2 par redo
J'imagine que la plupart d'entre vous connaissent bien et utilisent le service de traduction de Google, mais connaissez-vous celui de Microsoft . Microsoft Translator ? Effectivement, Microsoft nous annoncé le lancement version 2 de la Technologie Preview...
Cliquez pour lire la suite de l'article par redo LANCEMENT EN PREVIEW DE CYCLONE LORS DES TECHDAYS 2010!LANCEMENT EN PREVIEW DE CYCLONE LORS DES TECHDAYS 2010! par MPOWARE
Toutes les vidéos de ce lancement sont en ligne!
Partie I - Intro
http://www.youtube.com/watch?v=LkQzTQ8T6CA
Partie II - Démo 1
http://www.youtube.com/watch?v=drAhYQ7lqvo
Partie III - Démo 2
http://www.youtube.com/watch?v=c8KM_1Gqybc...
Cliquez pour lire la suite de l'article par MPOWARE
Forum
RE : ASSEMBLEURRE : ASSEMBLEUR par ghuysmans99
Cliquez pour lire la suite par ghuysmans99 RE : ASSEMBLEURRE : ASSEMBLEUR par ghuysmans99
Cliquez pour lire la suite par ghuysmans99 ASSEMBLEURASSEMBLEUR par solleil
Cliquez pour lire la suite par solleil
Logiciels
Academy System (10.9.4.0)ACADEMY SYSTEM (10.9.4.0)Logiciel de gestion des établissements.
- élèves/étudiants (inscription, dossier, absence...)
-... Cliquez pour télécharger Academy System Xilisoft Convertisseur Vidéo Ultimate (5.1.39.0305)XILISOFT CONVERTISSEUR VIDéO ULTIMATE (5.1.39.0305)Xilisoft Convertisseur Vidéo Ultimate est un outil puissant de conversion vidéo, facile à utilise... Cliquez pour télécharger Xilisoft Convertisseur Vidéo Ultimate Xilisoft DVD Ripper Ultimate (5.0.64.0304)XILISOFT DVD RIPPER ULTIMATE (5.0.64.0304)Xilisoft DVD Ripper Ultimate est un logiciel excellent pour copier et convertir DVD vers presque ... Cliquez pour télécharger Xilisoft DVD Ripper Ultimate Rigs of Rods (63.3)RIGS OF RODS (63.3)c'est un jeu de multi-simulation camions,autobus voitures, avions, bateaux, hélicoptère avec défo... Cliquez pour télécharger Rigs of Rods
|