/* Chrysalide - Outil d'analyse de fichiers binaires * routine.h - prototypes pour la manipulation des prototypes de fonctions et de variables * * Copyright (C) 2009-2017 Cyrille Bagard * * This file is part of Chrysalide. * * Chrysalide is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 3 of the License, or * (at your option) any later version. * * Chrysalide is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with Foobar. If not, see . */ #ifndef _ANALYSIS_ROUTINE_H #define _ANALYSIS_ROUTINE_H #include #include #include #include "binary.h" #include "variable.h" #include "disass/block.h" #include "../arch/processor.h" //#include "../arch/instruction.h" typedef struct _GArchInstruction GArchInstruction; /* Type de routine traitée */ typedef enum _RoutineType { RTT_CLASSIC, /* Fonction ou méthode */ RTT_CONSTRUCTOR, /* Constructeur */ RTT_DESTRUCTOR /* Destructeur */ } RoutineType; #define G_TYPE_BIN_ROUTINE g_bin_routine_get_type() #define G_BIN_ROUTINE(obj) (G_TYPE_CHECK_INSTANCE_CAST((obj), g_bin_routine_get_type(), GBinRoutine)) #define G_IS_BIN_ROUTINE(obj) (G_TYPE_CHECK_INSTANCE_TYPE((obj), g_bin_routine_get_type())) #define G_BIN_ROUTINE_GET_IFACE(inst) (G_TYPE_INSTANCE_GET_INTERFACE((inst), g_bin_routine_get_type(), GBinRoutineIface)) /* Représentation générique de routine (instance) */ typedef struct _GBinRoutine GBinRoutine; /* Représentation générique de routine (classe) */ typedef struct _GBinRoutineClass GBinRoutineClass; /* Modalités de représentation en chaîne */ typedef enum _Routine2StringOptions { RSO_LONG_TYPE = (1 << 0), /* Type avec espace de noms */ RSO_NAMESPACE = (1 << 1) /* Affichage de l'appartenance */ } Routine2StringOptions; #define RSO_ALL (RSO_LONG_TYPE | RSO_NAMESPACE) /* Indique le type définit pour une représentation de routine. */ GType g_bin_routine_get_type(void); /* Crée une représentation de routine. */ GBinRoutine *g_binary_routine_new(void); /* Crée une représentation de routine construisant une instance. */ GBinRoutine *g_binary_routine_new_constructor(GDataType *); /* Etablit la comparaison ascendante entre deux routines. */ int g_binary_routine_compare(const GBinRoutine **, const GBinRoutine **); /* Etablit la comparaison descendante entre deux routines. */ int g_binary_routine_rcompare(const GBinRoutine **, const GBinRoutine **); /* Définit la couverture physique / en mémoire d'une routine. */ void g_binary_routine_set_range(GBinRoutine *, const mrange_t *); /* Fournit la couverture physique / en mémoire d'une routine. */ const mrange_t *g_binary_routine_get_range(const GBinRoutine *); /* Fournit la position physique / en mémoire d'une routine. */ //const vmpa2t *g_binary_routine_get_address(const GBinRoutine *); #define g_binary_routine_get_address(r) 0 /* Définit la taille du code d'une routine. */ void g_binary_routine_set_size(GBinRoutine *, off_t); /* Fournit la taille du code associé à une routine. */ //off_t g_binary_routine_get_size(const GBinRoutine *); #define g_binary_routine_get_size(r) 0 /* Définit le type d'une routine. */ void g_binary_routine_set_type(GBinRoutine *, RoutineType); /* Définit le groupe d'appartenance d'une routine donnée. */ void g_binary_routine_set_namespace(GBinRoutine *, GDataType *, const char *); /* Fournit le groupe d'appartenance d'une routine donnée. */ GDataType *g_binary_routine_get_namespace(const GBinRoutine *); /* Définit le nom humain d'une routine. */ void g_binary_routine_set_name(GBinRoutine *, char *); /* Désignation humainement lisible ou NULL si non définie. */ const char *g_binary_routine_get_name(const GBinRoutine *); /* Définit de façon indirecte le nom humain d'une routine. */ void g_binary_routine_set_name_from_type(GBinRoutine *, GDataType *); /* Fournit le type construisant le nom humain d'une routine. */ GDataType *g_binary_routine_get_type_from_name(const GBinRoutine *); /* Définit le type de retour d'une routine. */ void g_binary_routine_set_return_type(GBinRoutine *, GDataType *); /* Fournit le type de retour d'une routine. */ GDataType *g_binary_routine_get_return_type(const GBinRoutine *); /* Ajoute un argument à une routine. */ void g_binary_routine_add_arg(GBinRoutine *, GBinVariable *); /* Indique le nombre d'arguments associés à une routine. */ size_t g_binary_routine_get_args_count(const GBinRoutine *); /* Fournit un argument d'une routine. */ GBinVariable *g_binary_routine_get_arg(GBinRoutine *, size_t); /* Retire un argument d'une routine. */ void g_binary_routine_remove_arg(GBinRoutine *, size_t); /* Fournit le nom humain d'une routine. */ const char *g_binary_routine_get_declarator(GBinRoutine *, bool); /* S'assure qu'une variable est bien associée à une routine. */ void g_binary_routine_register_if_needed(GBinRoutine *, size_t, bool); /* Donne l'indice d'une variable dans la liste d'une routine. */ size_t g_binary_routine_get_var_index_from_offset(const GBinRoutine *, size_t, bool); /* Fournit les instructions natives correspondantes. */ GArchInstruction *g_binary_routine_get_instructions(const GBinRoutine *); /* Définit les instructions natives de la routine. */ void g_binary_routine_set_instructions(GBinRoutine *, GArchInstruction *); /* Fournit les blocs basiques de la routine. */ GBlockList *g_binary_routine_get_basic_blocks(const GBinRoutine *); /* Définit les blocs basiques de la routine. */ void g_binary_routine_set_basic_blocks(GBinRoutine *, GBlockList *); /* Fournit les instructions décompilées correspondantes. */ //GDecInstruction *g_binary_routine_get_decomp_instructions(const GBinRoutine *); /* Définit les instructions décompilées de la routine. */ //void g_binary_routine_set_decomp_instructions(GBinRoutine *, GDecInstruction *); /* Décrit le prototype de la routine sous forme de caractères. */ char *_g_binary_routine_to_string(const GBinRoutine *, Routine2StringOptions); #define g_binary_routine_to_string(r) _g_binary_routine_to_string((r), RSO_ALL) /* Procède à l'impression de la description d'une routine. */ //void g_binary_routine_output_info(const GBinRoutine *, GLangOutput *, GCodeBuffer *); /* Procède à l'impression de la décompilation d'une routine. */ //void g_binary_routine_print_code(const GBinRoutine *, GLangOutput *, GCodeBuffer *, bool); /* Construit un petit résumé concis de la routine. */ char *g_binary_routine_build_tooltip(const GBinRoutine *, const GLoadedBinary *); #endif /* _ANALYSIS_ROUTINE_H */