summaryrefslogtreecommitdiff
path: root/src/arch/arm/instruction.c
diff options
context:
space:
mode:
Diffstat (limited to 'src/arch/arm/instruction.c')
-rw-r--r--src/arch/arm/instruction.c101
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
+}