dwarf_arrayorder
,
dwarf_bitoffset
,
dwarf_bitsize
, dwarf_bytesize
,
dwarf_highpc
, dwarf_highpc_b
,
dwarf_lowpc
, dwarf_srclang
—
retrieve the value of a DWARF attribute
DWARF Access Library (libdwarf, -ldwarf)
#include <libdwarf.h>
int
dwarf_arrayorder
(Dwarf_Die die,
Dwarf_Unsigned *ret_order, Dwarf_Error
*err);
int
dwarf_bitoffset
(Dwarf_Die die,
Dwarf_Unsigned *ret_size, Dwarf_Error
*err);
int
dwarf_bitsize
(Dwarf_Die die,
Dwarf_Unsigned *ret_size, Dwarf_Error
*err);
int
dwarf_bytesize
(Dwarf_Die die,
Dwarf_Unsigned *ret_size, Dwarf_Error
*err);
int
dwarf_highpc
(Dwarf_Die die,
Dwarf_Addr *ret_highpc, Dwarf_Error
*err);
int
dwarf_highpc_b
(Dwarf_Die die,
Dwarf_Addr *ret_highpc, Dwarf_Half
*ret_form, enum Dwarf_Form_Class *ret_class,
Dwarf_Error *err);
int
dwarf_lowpc
(Dwarf_Die die,
Dwarf_Addr *ret_lowpc, Dwarf_Error
*err);
int
dwarf_srclang
(Dwarf_Die die,
Dwarf_Unsigned *ret_lang, Dwarf_Error
*err);
These convenience functions are used to retrieve DWARF attribute values
associated with a Debugging Information Entry (DIE) descriptor denoted by
argument die. These functions store the value of the
requested attribute into the location pointed to by their second argument,
provided that the requested attribute exists in the debugging information
entry.
The list of functions and the DWARF attribute that they retrieve
are:
dwarf_arrayorder
()
- Retrieve the
DW_AT_ordering
attribute value.
dwarf_bitoffset
()
- Retrieve the
DW_AT_bit_offset
attribute
value.
dwarf_bitsize
()
- Retrieve the
DW_AT_bit_size
attribute value.
dwarf_bytesize
()
- Retrieve the
DW_AT_byte_size
attribute value.
dwarf_highpc
()
- Retrieve the
DW_AT_high_pc
attribute value.
dwarf_highpc_b
()
- Retrieve the
DW_AT_high_pc
attribute value.
dwarf_lowpc
()
- Retrieve the
DW_AT_low_pc
attribute value.
dwarf_srclang
()
- Retrieve the
DW_AT_language
attribute value.
Function dwarf_highpc_b
() is an enhanced
version of function dwarf_highpc
(). It sets the
location specified by argument ret_form to the form
code of the attribute DW_AT_high_pc
, and sets the
location specified by argument ret_class to the class
of that form. A value of NULL may be used for either of the arguments
ret_form or ret_class if the
caller is not interested in the respective value.
These functions return DW_DLV_OK
on success.
If the debugging information entry descriptor denoted by argument
die does not contain the requested attribute, these
functions return DW_DLV_NO_ENTRY
and set argument
err. For other errors, they return
DW_DLV_ERROR
and set argument
err.
These functions can fail with the following errors:
- [
DW_DLE_ARGUMENT
]
- Arguments die, ret_highpc,
ret_lowpc, ret_size,
ret_lang or ret_order were
NULL.
- [
DW_DLE_NO_ENTRY
]
- Argument die had no requested attribute.