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 :

Analyse d'un fichier .sys


Sujet :

x86 32-bits / 64-bits Assembleur

  1. #1
    Membre actif Avatar de Muesko
    Profil pro
    Collégien
    Inscrit en
    Mai 2006
    Messages
    249
    Détails du profil
    Informations personnelles :
    Âge : 32
    Localisation : France

    Informations professionnelles :
    Activité : Collégien

    Informations forums :
    Inscription : Mai 2006
    Messages : 249
    Points : 204
    Points
    204
    Par défaut Analyse d'un fichier .sys
    Bonjour,

    J'ai un fichier .sys, qui contient un bug, que je souhaite analyser et si possible corriger.

    -Avec quel logiciel je dois m'y prendre ?
    -Est-il possible de convertir un fichier désassemblé en fichier .c ou .cpp ? et si oui, avec quel programme.

    Merci.
    Bonjour,
    Si vous lisez ceci, c'est que vous êtes à la fin de mon message.

  2. #2
    Rédacteur
    Avatar de Neitsa
    Homme Profil pro
    Chercheur sécurité informatique
    Inscrit en
    Octobre 2003
    Messages
    1 041
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Chercheur sécurité informatique

    Informations forums :
    Inscription : Octobre 2003
    Messages : 1 041
    Points : 1 956
    Points
    1 956
    Par défaut
    Bonjour,

    Citation Envoyé par L'apprentis
    bonjour,
    j'ai un fichier .sys, qui contient un bug, que je shouaite analyser et si possible corrigé.
    -Avec quel logiciel je dois m'y prendre ?
    Un désassembleur suffira. Il existe une version gratuite d'IDA (the Interactive DisAssembler) qui peut analyser les fichier au format PE (Portable executable).
    La version gratuite est la v4.3.

    À condition que ce *.sys soit bien un fichier à la norme PE (driver Windows).

    -Est il possible de convertir un fichier désassembler en fichier .c ou .cpp ? et si oui avec quel programme.
    C'est une question qui revient souvent sur le forum assembleur. La réponse est non, ça n'est pas possible.

    Il y a eu beaucoup de thèses et de recherches sur la décompilation (transition d'un langage de bas niveau vers un langage de haut niveau) et aucune n'est jamais parvenue à un niveau de reconstruction qui soit juger utilisable ou acceptable.

    Ce type de décompilation est toujours dévolue à des opérateurs humains, que ce soit dans un but légal (étude et analyse de virus / malwares, rétro-ingénierie, interopérabilité) ou non (vol d'algorithme, piratage industriel, craking, etc.).

    Les outils sont une aide à la compréhension du code et du data flow par la personne chargée de la décompilation, mais à la fin c'est bien un humain qui sera chargé de faire le chemin mental nécessaire : il faut à la fois parfaitement connaître le langage source (assembleur) et cible (C / C++, etc).

    S'il y a une seule chose à retenir c'est celle-ci :

    La compilation en langage natif est une opération destructrice.

  3. #3
    Membre actif Avatar de Muesko
    Profil pro
    Collégien
    Inscrit en
    Mai 2006
    Messages
    249
    Détails du profil
    Informations personnelles :
    Âge : 32
    Localisation : France

    Informations professionnelles :
    Activité : Collégien

    Informations forums :
    Inscription : Mai 2006
    Messages : 249
    Points : 204
    Points
    204
    Par défaut
    Bon tout d'abbord merci pour ta réponse c'est très clair .

    -Est il possible de convertir un fichier désassembler en fichier .c ou .cpp ? et si oui avec quel programme.

    C'est une question qui revient souvent sur le forum assembleur. La réponse est non, ça n'est pas possible.
    Ha c'est vraiment dommage ca enfin bon c'est pas grave je vais essayer de me débrouiller avec de l'asm.

    Encore merci
    Bonjour,
    Si vous lisez ceci, c'est que vous êtes à la fin de mon message.

  4. #4
    Rédacteur

    Avatar de millie
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    7 015
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2006
    Messages : 7 015
    Points : 9 818
    Points
    9 818
    Par défaut
    -Est il possible de convertir un fichier désassembler en fichier .c ou .cpp ? et si oui avec quel programme.
    J'avais bossé sur un compilateur d'un langage du type C vers un langage 3 adresses.

    Un fichier du style :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    bool u;
    bool v;
    u = true;
    if(u) then
    {
     v = true;
    }
    else
    {
     while(u) do
     {
       u = false;
     };
    };
    (bon, le code est débile, mais c'est pas grave, il y a aussi des décompositions des expressions, mais j'en ai pas mis ici).

    Devenait ça :

    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
    v3 = true
    user1 = v3
    v4 = user1
    if !v4 goto 1
    v5 = true
    user2 = v5
    goto 2 
    label 1:
    label 3: 
    v6 = user1
    if !v6  goto 4
    v7 = false
    user1 = v7
    goto 3 
    label 4:
    label 2:
    Tu vois tout de suite qu'en général, les variables sont renommés (ce qui rend beaucoup plus difficile la comprehension du code quand les variables ont une sémantiques particulière). Ensuite, il est possible de transcrire mon programme 3 adresse en C, mais ça restera très incompréhensible par rapport à la version originale.

    Ici, il n'y a aucune optimisation, si le compilateur en ajoute, ça devient incroyablement plus difficile (il est impossible de détecter une fonction inliné une seule fois).
    Je ne répondrai à aucune question technique en privé

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

Discussions similaires

  1. [MASM] Compiler un fichier .sys ?
    Par - Robby - dans le forum x86 16-bits
    Réponses: 12
    Dernier message: 08/01/2008, 11h28
  2. analyse d'un fichier xml/dtd
    Par bo_goss dans le forum XML
    Réponses: 1
    Dernier message: 13/11/2007, 12h44
  3. [DOM XML] Erreur chez mon hébergeur sur l'analyse d'un fichier XML
    Par ipeteivince dans le forum Bibliothèques et frameworks
    Réponses: 3
    Dernier message: 26/07/2007, 10h33
  4. boucle analyser tous les fichiers d'un répertoire
    Par petitange_lili dans le forum Langage
    Réponses: 1
    Dernier message: 24/03/2007, 20h02
  5. Analyse complexe de fichier
    Par ecthelion dans le forum Langage
    Réponses: 5
    Dernier message: 17/03/2007, 11h10

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