/* Chrysalide - Outil d'analyse de fichiers binaires * post.c - traitements complémentaires à la phase de désassemblage * * Copyright (C) 2014 Cyrille Bagard * * This file is part of Chrysalide. * * OpenIDA 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. * * OpenIDA 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 . */ #include "link.h" #include #include "context.h" /****************************************************************************** * * * Paramètres : instr = instruction ARMv7 à traiter. * * context = contexte associé à la phase de désassemblage. * * format = acès aux données du binaire d'origine. * * * * Description : Complète un désassemblage accompli pour une instruction. * * * * Retour : - * * * * Remarques : - * * * ******************************************************************************/ void handle_links_with_thumb_instruction_bl(GArchInstruction *instr, GArmV7Context *context, GBinFormat *format) { const mrange_t *range; /* Emplacementt d'instruction */ virt_t pc; /* Position dans l'exécution */ GArchOperand *op; /* Opérande numérique en place */ int32_t offset; /* Décallage encodé en dur */ virt_t target; /* Adresse virtuelle visée */ ArmV7InstrSet iset; /* Type de jeu courant */ range = g_arch_instruction_get_range(instr); pc = get_virt_addr(get_mrange_addr(range)); /** * Qu'on se trouve en mode Thumb ou ARM, l'instruction * ne peut qu'être encodée sur 4 octets. */ assert(get_mrange_length(range) == 4); pc += 4; op = g_arch_instruction_get_operand(instr, 0); if (g_imm_operand_get_value(G_IMM_OPERAND(op), MDS_32_BITS_SIGNED, &offset)) g_imm_operand_set_value(G_IMM_OPERAND(op), MDS_32_BITS_UNSIGNED, pc + offset); //printf("[@ 0x%08x] Add 0x%08x to %p\n", (uint32_t)get_virt_addr(get_mrange_addr(range)), (uint32_t)(pc + offset), context); target = pc + offset; iset = g_armv7_context_find_encoding(context, get_virt_addr(get_mrange_addr(range))); g_armv7_context_define_encoding(context, target, iset); } /****************************************************************************** * * * Paramètres : instr = instruction ARMv7 à traiter. * * context = contexte associé à la phase de désassemblage. * * format = acès aux données du binaire d'origine. * * * * Description : Complète un désassemblage accompli pour une instruction. * * * * Retour : - * * * * Remarques : - * * * ******************************************************************************/ void handle_links_with_thumb_instruction_blx(GArchInstruction *instr, GArmV7Context *context, GBinFormat *format) { const mrange_t *range; /* Emplacementt d'instruction */ virt_t pc; /* Position dans l'exécution */ GArchOperand *op; /* Opérande numérique en place */ int32_t offset; /* Décallage encodé en dur */ virt_t target; /* Adresse virtuelle visée */ ArmV7InstrSet iset; /* Type de jeu courant */ range = g_arch_instruction_get_range(instr); pc = get_virt_addr(get_mrange_addr(range)); /** * Qu'on se trouve en mode Thumb ou ARM, l'instruction * ne peut qu'être encodée sur 4 octets. */ assert(get_mrange_length(range) == 4); pc += 4; pc -= pc % 4; op = g_arch_instruction_get_operand(instr, 0); if (g_imm_operand_get_value(G_IMM_OPERAND(op), MDS_32_BITS_SIGNED, &offset)) g_imm_operand_set_value(G_IMM_OPERAND(op), MDS_32_BITS_UNSIGNED, pc + offset); //printf("[@ 0x%08x] Add 0x%08x to %p\n", (uint32_t)get_virt_addr(get_mrange_addr(range)), (uint32_t)(pc + offset), context); target = pc + offset; iset = g_armv7_context_find_encoding(context, get_virt_addr(get_mrange_addr(range))); printf(" --link-- @ 0x%08x iset = %u\n", (unsigned int)target, (unsigned int)iset); if (iset == AV7IS_ARM) g_armv7_context_define_encoding(context, target, AV7IS_THUMB); else g_armv7_context_define_encoding(context, target, AV7IS_ARM); }