diff options
author | Cyrille Bagard <nocbos@gmail.com> | 2014-10-01 20:44:39 (GMT) |
---|---|---|
committer | Cyrille Bagard <nocbos@gmail.com> | 2014-10-01 20:44:39 (GMT) |
commit | ada6b756efd6ca109f6c46aa4d3eb11c17ad6b84 (patch) | |
tree | ef182c00ffb3881f6537e96dfa07acb875ac0846 /src/arch/arm/instruction.c | |
parent | 15c0cc127f0f4551c88de6c0d46b7d38f4b3ed4b (diff) |
Prepared the ground for the ARMv7 architecture.
git-svn-id: svn://svn.gna.org/svn/chrysalide/trunk@408 abbe820e-26c8-41b2-8c08-b7b2b41f8b0a
Diffstat (limited to 'src/arch/arm/instruction.c')
-rw-r--r-- | src/arch/arm/instruction.c | 101 |
1 files changed, 69 insertions, 32 deletions
diff --git a/src/arch/arm/instruction.c b/src/arch/arm/instruction.c index 77dd621..5ea3926 100644 --- a/src/arch/arm/instruction.c +++ b/src/arch/arm/instruction.c @@ -28,29 +28,29 @@ - - -/* Initialise la classe des instructions pour Arm. */ +/* Initialise la classe des instructions ARM. */ static void g_arm_instruction_class_init(GArmInstructionClass *); -/* Initialise une instance d'opérande d'architecture Arm. */ +/* Initialise une instance de instruction ARM. */ static void g_arm_instruction_init(GArmInstruction *); +/* Supprime toutes les références externes. */ +static void g_arm_instruction_dispose(GArmInstruction *); +/* Procède à la libération totale de la mémoire. */ +static void g_arm_instruction_finalize(GArmInstruction *); - -/* Indique le type défini pour une instruction d'architecture Arm. */ -G_DEFINE_TYPE(GArmInstruction, g_arm_instruction, G_TYPE_ARCH_INSTRUCTION); - +/* Indique le type défini pour une représentation d'une instruction ARM. */ +G_DEFINE_TYPE(GArmInstruction, g_arm_instruction, G_TYPE_ARM_INSTRUCTION); /****************************************************************************** * * * Paramètres : klass = classe à initialiser. * * * -* Description : Initialise la classe des instructions pour ARM. * +* Description : Initialise la classe des instructions ARM. * * * * Retour : - * * * @@ -60,6 +60,12 @@ G_DEFINE_TYPE(GArmInstruction, g_arm_instruction, G_TYPE_ARCH_INSTRUCTION); static void g_arm_instruction_class_init(GArmInstructionClass *klass) { + GObjectClass *object_class; /* Autre version de la classe */ + + object_class = G_OBJECT_CLASS(klass); + + object_class->dispose = (GObjectFinalizeFunc/* ! */)g_arm_instruction_dispose; + object_class->finalize = (GObjectFinalizeFunc)g_arm_instruction_finalize; } @@ -68,7 +74,7 @@ static void g_arm_instruction_class_init(GArmInstructionClass *klass) * * * Paramètres : instr = instance à initialiser. * * * -* Description : Initialise une instance d'instruction d'architecture ARM. * +* Description : Initialise une instance d'instruction ARM. * * * * Retour : - * * * @@ -78,51 +84,82 @@ static void g_arm_instruction_class_init(GArmInstructionClass *klass) static void g_arm_instruction_init(GArmInstruction *instr) { - GArchInstruction *parent; /* Instance parente */ - parent = G_ARCH_INSTRUCTION(instr); +} - /* ... TODO ! */ -} +/****************************************************************************** +* * +* Paramètres : instr = instance d'objet GLib à traiter. * +* * +* Description : Supprime toutes les références externes. * +* * +* Retour : - * +* * +* Remarques : - * +* * +******************************************************************************/ +static void g_arm_instruction_dispose(GArmInstruction *instr) +{ + G_OBJECT_CLASS(g_arm_instruction_parent_class)->dispose(G_OBJECT(instr)); +} -/* ---------------------------------------------------------------------------------- */ -/* AIDE A LA MISE EN PLACE D'INSTRUCTIONS */ -/* ---------------------------------------------------------------------------------- */ +/****************************************************************************** +* * +* Paramètres : instr = instance d'objet GLib à traiter. * +* * +* Description : Procède à la libération totale de la mémoire. * +* * +* Retour : - * +* * +* Remarques : - * +* * +******************************************************************************/ +static void g_arm_instruction_finalize(GArmInstruction *instr) +{ + G_OBJECT_CLASS(g_arm_instruction_parent_class)->finalize(G_OBJECT(instr)); +} -#if 0 /****************************************************************************** * * -* Paramètres : data = flux de données à analyser. * -* pos = position courante dans ce flux. * -* end = limite des données à analyser. * +* Paramètres : instr = instruction ARM à mettre à jour. * +* cond = condition d'exécution de l'instruction. * * * -* Description : Recherche l'identifiant de la prochaine instruction. * +* Description : Définit les conditions d'exécution d'une instruction ARM. * * * -* Retour : Identifiant de la prochaine instruction à tenter de charger. * +* Retour : - * * * * Remarques : - * * * ******************************************************************************/ -ArmOpcodes arm_guess_next_instruction(const bin_t *data, off_t pos, off_t end) +void g_armv7_instruction_set_cond(GArmInstruction *instr, ArmCondCode cond) { - ArmOpcodes result; /* Identifiant à retourner */ + instr->cond = cond; - result = (ArmOpcodes)data[pos]; +} - /* Si l'instruction est marquée comme non utilisée... */ - if (_instructions[result].keyword == NULL) - result = DOP_COUNT; - return result; +/****************************************************************************** +* * +* Paramètres : instr = instruction ARM à consulter. * +* * +* Description : Indique les conditions d'exécution d'une instruction ARM. * +* * +* Retour : Condition d'exécution de l'instruction. * +* * +* Remarques : - * +* * +******************************************************************************/ -} +ArmCondCode g_armv7_instruction_get_cond(const GArmInstruction *instr) +{ + return instr->cond; -#endif +} |