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

Autres architectures Assembleur Discussion :

[ARM 64] Modification d'un code


Sujet :

Autres architectures Assembleur

  1. #1
    Nouveau Candidat au Club
    Homme Profil pro
    Psychologue sportif
    Inscrit en
    Avril 2022
    Messages
    2
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 32
    Localisation : France, Seine Saint Denis (Île de France)

    Informations professionnelles :
    Activité : Psychologue sportif

    Informations forums :
    Inscription : Avril 2022
    Messages : 2
    Points : 1
    Points
    1
    Par défaut [ARM 64] Modification d'un code
    Bonjour tout le monde,

    Permettez-moi de vous présenter ma requête :

    J'ai désassemblé (via IDA pro) le fichier binaire d'un jeu, j'ai fais cela dans le but de pouvoir modifier le nombre de "relife" auquel j'ai le droit dans le jeu.
    Il me semble avoir identifié la bonne fonction, c'est à dire celle qui me permettrait d'augmenter mon nombre de "relife". Seulement voilà, je n'y connais rien en programmation et ici il s'agit (si je ne me trompe pas) d'un code en ARM64.

    Ma requête est donc la suivante : je vous met le code de la fonction identifiée et si quelqu'un a des conseils, peu m'orienter ou même me dire exactement quoi faire je suis preneur et l'en remercie d'avance.

    Merci beaucoup de prendre du temps pour ma requête ou même de la lire

    PS : Le code est en pièce jointe
    Fichiers attachés Fichiers attachés

  2. #2
    Expert éminent sénior
    Avatar de Kannagi
    Homme Profil pro
    cyber-paléontologue
    Inscrit en
    Mai 2010
    Messages
    3 214
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 35
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : cyber-paléontologue

    Informations forums :
    Inscription : Mai 2010
    Messages : 3 214
    Points : 10 140
    Points
    10 140
    Par défaut
    Tu ne trouveras personne qui va te dire quoi modifier exactement.
    Parce qu'il faut connaître l'ARM64, qui n'est pas ultra courant , les conventions d'appel, et avoir une idée un peu plus précise de ce que ça fait ; sans tester, c'est loin d'etre évident de trouver le pourquoi du comment !
    Surtout que le code généré par le compilo est "imbuvable" pour un humain.

    Je prends un exemple :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
     
    loc_10199816C                           ; CODE XREF: GameManager$$Relife+114↑j
    .il2cpp:000000010199816C                                         ; GameManager$$Relife+11C↑j
    .il2cpp:000000010199816C                 MOV             X0, #0
    .il2cpp:0000000101998170                 MOV             X1, X20
    .il2cpp:0000000101998174                 MOV             X2, #0
    .il2cpp:0000000101998178                 MOV             X3, #0
    .il2cpp:000000010199817C                 BL              UnityEngine.Object$$op_Inequality
    .il2cpp:0000000101998180                 CBZ             W0, loc_1019981A4
    .il2cpp:0000000101998184                 LDR             X20, [X19,#0xB8]
    .il2cpp:0000000101998188                 LDR             W21, [X19,#0xC8]
    .il2cpp:000000010199818C                 CBNZ            X20, loc_101998194
    .il2cpp:0000000101998190                 BL              sub_10181BE9C
    Ça initialise x0 à x4, mais ce n'est pas utilisé ensuite, donc je suppose que c'est appelé ensuite sur "UnityEngine.Object$$op_Inequality", donc il faut regarder ce que ça fait.
    Ensuite tu as CBZ qui lit W0, pourquoi ?
    Aucune idée, peut-être que c'est une convention d'appel, faut se renseigner, et que W0 soit le return.
    Donc ce que ça fait si W0 = 0, il va jump à l'adresse loc_1019981A4 sinon il va continuer, etc. etc.

    Par contre il y a plein d'appels de fonction de "sub_10181BE9C" mais aucune idée de ce que ça fait, ce qui n'aide pas à la compréhension.

    Et c'est tout le souci de lire du code asm désassemblé, il n'y a pas de nom de variable, donc les noms de fonctions, ou le nom des variables disparaissent, ce qui rend la lecture de code plus compliqué.
    Même si on connaît parfaitement l'asm.
    En clair, c'est comme si tu lisais du C avec que des var_1 , var_2 ,var_3 et des func_1, func_2, etc. etc., ça serait bien pénible à lire.

  3. #3
    Nouveau Candidat au Club
    Homme Profil pro
    Psychologue sportif
    Inscrit en
    Avril 2022
    Messages
    2
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 32
    Localisation : France, Seine Saint Denis (Île de France)

    Informations professionnelles :
    Activité : Psychologue sportif

    Informations forums :
    Inscription : Avril 2022
    Messages : 2
    Points : 1
    Points
    1
    Par défaut
    Merci Kannagi pour ta réponse,

    Du coup je comprend mieux pourquoi je n’ai pas eu de réponse et la difficulté à appréhender ce code...

    Bon bah je vais essayer de me débrouiller tout seul et voir comment je pourrais avoir de plus ample informations sur l’utilité des variables...

Discussions similaires

  1. modification dynamique du code
    Par amine198927 dans le forum C++Builder
    Réponses: 6
    Dernier message: 16/04/2008, 22h53
  2. Une aide sur la modification d'un code HTML/CSS d'un blog
    Par nanas dans le forum Balisage (X)HTML et validation W3C
    Réponses: 3
    Dernier message: 02/08/2007, 14h04
  3. Réponses: 5
    Dernier message: 15/06/2007, 19h26
  4. Réponses: 2
    Dernier message: 08/11/2006, 20h57
  5. Modification dynamique de code html
    Par xtendance dans le forum Général JavaScript
    Réponses: 3
    Dernier message: 10/10/2006, 11h55

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