DWARF の初心者として、このページ(コードはこちら) に示されているコードを試しましたが、起動すると次のようになります。
$> ./dwarf_get_func_addr tracedprog
DW_TAG_subprogram: 'do_stuff'
abort() in libdwarf. No error argument, no handler.
zsh: abort (core dumped) ./dwarf_get_func_addr tracedprog
デバッグ セッションの後、問題は 78 行目から発生しているように見えます。
else if (attrcode == DW_AT_high_pc)
dwarf_formaddr(attrs[i], &highpc, 0);
問題は、form
of attrs[i]
showsattrs[i]
がアドレスではないことです (1 ではなく 7 に設定されています)。それを使って探索tracedprog
するobjdump
と、関数が得られdo_stuff
ます:
<1><73>: Numéro d'abréviation: 4 (DW_TAG_subprogram)
<74> DW_AT_external : 1
<74> DW_AT_name : (chaîne indirecte, décalage: 0x55): do_stuff
<78> DW_AT_decl_file : 1
<79> DW_AT_decl_line : 4
<7a> DW_AT_prototyped : 1
<7a> DW_AT_low_pc : 0x400500
<82> DW_AT_high_pc : 0x3f
<8a> DW_AT_frame_base : 1 bloc d'octets: 9c (DW_OP_call_frame_cfa)
<8c> DW_AT_GNU_all_tail_call_sites: 1
<8c> DW_AT_sibling : <0xb9>
この出力では、DW_AT_high_pc
長さが 2 オクテットしかないため、私には正しくないようです。
参考までに、私は次のようにコンパイルtracedprog
しました。
$> gcc -g tracedprog2.c -o tracedprog
gcc
別のマシンでは問題がないため、編集は問題のようです。を使用してgcc 4.8.2
います。