Example focused on GNU debuglink data.
In case GNU debuglink data is followed the true_pathbuf content will not match path. The path actually used is copied to true_path_out.
In the case of MacOS dSYM the true_path_out may not match path.
If debuglink data is missing from the Elf executable or shared-object (ie, it is a normal object!) or unusable by libdwarf or true_path_buffer len is zero or true_path_out_buffer is zero libdwarf accepts the path given as the object to report on, no debuglink or dSYM processing will be used.
- See also
- https://sourceware.org/gdb/onlinedocs/gdb/Separate-Debug-Files.html
An example calling dwarf_init_path_dl() and dwarf_finish()
- Parameters
-
path | Path to an object we wish to open. |
groupnumber | Desired groupnumber. Use DW_DW_GROUPNUMBER_ANY unless you have reason to do otherwise. |
error | A pointer we can use to record error details. |
- Returns
- Returns the applicable result. DW_DLV_OK etc.
*/
int exampleinit_dl(const char *path, unsigned groupnumber,
{
static char true_pathbuf[FILENAME_MAX];
static const char *glpath[3] = {
"/usr/local/debug",
"/usr/local/private/debug",
"/usr/local/libdwarf/debug"
};
unsigned tpathlen = FILENAME_MAX;
int res = 0;
unsigned char path_source = 0;
tpathlen,groupnumber,errhand,
errarg,&dbg,
(char **)glpath,
3,
&path_source,
error);
if (res == DW_DLV_ERROR) {
*error = 0;
return res;
}
if (res == DW_DLV_NO_ENTRY) {
return res;
}
printf("The file we actually opened is %s\n",
true_pathbuf);
return res;
}
struct Dwarf_Debug_s * Dwarf_Debug
Definition libdwarf.h:603
struct Dwarf_Error_s * Dwarf_Error
Definition libdwarf.h:597
void(* Dwarf_Handler)(Dwarf_Error dw_error, Dwarf_Ptr dw_errarg)
Definition libdwarf.h:718
void * Dwarf_Ptr
Definition libdwarf.h:208
void dwarf_dealloc_error(Dwarf_Debug dw_dbg, Dwarf_Error dw_error)
Free (dealloc) an Dwarf_Error something created.
int dwarf_init_path_dl(const char *dw_path, char *dw_true_path_out_buffer, unsigned int dw_true_path_bufferlen, unsigned int dw_groupnumber, Dwarf_Handler dw_errhand, Dwarf_Ptr dw_errarg, Dwarf_Debug *dw_dbg, char **dw_dl_path_array, unsigned int dw_dl_path_array_size, unsigned char *dw_dl_path_source, Dwarf_Error *dw_error)
Initialization following GNU debuglink section data.
int dwarf_finish(Dwarf_Debug dw_dbg)
Close the initialized dw_dbg and free all data libdwarf has for this dw_dbg.