diff options
author | Cyrille Bagard <nocbos@gmail.com> | 2015-03-08 19:30:52 (GMT) |
---|---|---|
committer | Cyrille Bagard <nocbos@gmail.com> | 2015-03-08 19:30:52 (GMT) |
commit | 68bb7efaf61e4f5ca2f2cffce84995ffd667c4cc (patch) | |
tree | 9b6a6f63ee20b08d8c2ac35849ee051d61787447 /src/arch/target.c | |
parent | dc9e68505c4cc7ad208e63dbc7d0e0e8f582d0d9 (diff) |
Handle cross references as well as entry points.
git-svn-id: svn://svn.gna.org/svn/chrysalide/trunk@482 abbe820e-26c8-41b2-8c08-b7b2b41f8b0a
Diffstat (limited to 'src/arch/target.c')
-rw-r--r-- | src/arch/target.c | 13 |
1 files changed, 9 insertions, 4 deletions
diff --git a/src/arch/target.c b/src/arch/target.c index 40e9598..7509711 100644 --- a/src/arch/target.c +++ b/src/arch/target.c @@ -212,6 +212,7 @@ GArchOperand *g_target_operand_new(MemoryDataSize size, virt_t addr) static void g_target_operand_print(const GTargetOperand *operand, GBufferLine *line, AsmSyntax syntax) { const char *label; /* Etiquette liée à un symbole */ + GBufferSegment *segment; /* Nouveau segment mis en place*/ vmpa2t tmp; /* Coquille vide pour argument */ VMPA_BUFFER(value); /* Adresse brute à imprimer */ size_t len; /* Taille de l'élément inséré */ @@ -222,16 +223,19 @@ static void g_target_operand_print(const GTargetOperand *operand, GBufferLine *l g_buffer_line_insert_text(line, BLC_MAIN, "<", 1, RTT_LTGT); label = g_binary_symbol_get_label(operand->symbol); - g_buffer_line_insert_text(line, BLC_MAIN, label, strlen(label), RTT_LABEL); + segment = g_buffer_line_insert_text(line, BLC_MAIN, label, strlen(label), RTT_LABEL); + g_buffer_segment_set_creator(segment, G_OBJECT(operand)); if (operand->diff > 0) { - g_buffer_line_insert_text(line, BLC_MAIN, "+", 1, RTT_SIGNS); + segment = g_buffer_line_insert_text(line, BLC_MAIN, "+", 1, RTT_SIGNS); + g_buffer_segment_set_creator(segment, G_OBJECT(operand)); init_vmpa(&tmp, operand->diff, VMPA_NO_VIRTUAL); vmpa2_phys_to_string(&tmp, MDS_4_BITS, value, &len); - g_buffer_line_insert_text(line, BLC_MAIN, value, len, RTT_LABEL); + segment = g_buffer_line_insert_text(line, BLC_MAIN, value, len, RTT_LABEL); + g_buffer_segment_set_creator(segment, G_OBJECT(operand)); g_buffer_line_insert_text(line, BLC_MAIN, ">", 1, RTT_LTGT); @@ -243,7 +247,8 @@ static void g_target_operand_print(const GTargetOperand *operand, GBufferLine *l init_vmpa(&tmp, VMPA_NO_PHYSICAL, operand->addr); vmpa2_virt_to_string(&tmp, operand->size, value, &len); - g_buffer_line_insert_text(line, BLC_MAIN, value, len, RTT_LABEL); + segment = g_buffer_line_insert_text(line, BLC_MAIN, value, len, RTT_LABEL); + g_buffer_segment_set_creator(segment, G_OBJECT(operand)); } |