1 /* Interfaces for libdwfl.
2    Copyright (C) 2005-2010, 2013 Red Hat, Inc.
3    This file is part of elfutils.
4 
5    This file is free software; you can redistribute it and/or modify
6    it under the terms of either
7 
8      * the GNU Lesser General Public License as published by the Free
9        Software Foundation; either version 3 of the License, or (at
10        your option) any later version
11 
12    or
13 
14      * the GNU General Public License as published by the Free
15        Software Foundation; either version 2 of the License, or (at
16        your option) any later version
17 
18    or both in parallel, as here.
19 
20    elfutils is distributed in the hope that it will be useful, but
21    WITHOUT ANY WARRANTY; without even the implied warranty of
22    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
23    General Public License for more details.
24 
25    You should have received copies of the GNU General Public License and
26    the GNU Lesser General Public License along with this program.  If
27    not, see <http://www.gnu.org/licenses/>.  */
28 
29 #ifndef _LIBDWFL_H
30 #define _LIBDWFL_H	1
31 
32 #include "libdw.h"
33 #include <stdio.h>
34 
35 /* Handle for a session using the library.  */
36 typedef struct Dwfl Dwfl;
37 
38 /* Handle for a module.  */
39 typedef struct Dwfl_Module Dwfl_Module;
40 
41 /* Handle describing a line record.  */
42 typedef struct Dwfl_Line Dwfl_Line;
43 
44 /* This holds information common for all the frames of one backtrace for
45    a partical thread/task/TID.  Several threads belong to one Dwfl.  */
46 typedef struct Dwfl_Thread Dwfl_Thread;
47 
48 /* This holds everything we know about the state of the frame at a particular
49    PC location described by an FDE belonging to Dwfl_Thread.  */
50 typedef struct Dwfl_Frame Dwfl_Frame;
51 
52 /* Callbacks.  */
53 typedef struct
54 {
55   int (*find_elf) (Dwfl_Module *mod, void **userdata,
56 		   const char *modname, Dwarf_Addr base,
57 		   char **file_name, Elf **elfp);
58 
59   int (*find_debuginfo) (Dwfl_Module *mod, void **userdata,
60 			 const char *modname, Dwarf_Addr base,
61 			 const char *file_name,
62 			 const char *debuglink_file, GElf_Word debuglink_crc,
63 			 char **debuginfo_file_name);
64 
65   /* Fill *ADDR with the loaded address of the section called SECNAME in
66      the given module.  Use (Dwarf_Addr) -1 if this section is omitted from
67      accessible memory.  This is called exactly once for each SHF_ALLOC
68      section that relocations affecting DWARF data refer to, so it can
69      easily be used to collect state about the sections referenced.  */
70   int (*section_address) (Dwfl_Module *mod, void **userdata,
71 			  const char *modname, Dwarf_Addr base,
72 			  const char *secname,
73 			  GElf_Word shndx, const GElf_Shdr *shdr,
74 			  Dwarf_Addr *addr);
75 
76   char **debuginfo_path;	/* See dwfl_standard_find_debuginfo.  */
77 } Dwfl_Callbacks;
78 
79 
80 #ifdef __cplusplus
81 extern "C" {
82 #endif
83 
84 /* Start a new session with the library.  */
85 extern Dwfl *dwfl_begin (const Dwfl_Callbacks *callbacks)
86   __nonnull_attribute__ (1);
87 
88 
89 /* End a session.  */
90 extern void dwfl_end (Dwfl *);
91 
92 /* Return implementation's version string suitable for printing.  */
93 extern const char *dwfl_version (Dwfl *);
94 
95 /* Return error code of last failing function call.  This value is kept
96    separately for each thread.  */
97 extern int dwfl_errno (void);
98 
99 /* Return error string for ERROR.  If ERROR is zero, return error string
100    for most recent error or NULL if none occurred.  If ERROR is -1 the
101    behaviour is similar to the last case except that not NULL but a legal
102    string is returned.  */
103 extern const char *dwfl_errmsg (int err);
104 
105 
106 /* Start reporting the current set of segments and modules to the library.
107    All existing segments are wiped.  Existing modules are marked to be
108    deleted, and will not be found via dwfl_addrmodule et al if they are not
109    re-reported before dwfl_report_end is called.  */
110 extern void dwfl_report_begin (Dwfl *dwfl);
111 
112 /* Report that segment NDX begins at PHDR->p_vaddr + BIAS.
113    If NDX is < 0, the value succeeding the last call's NDX
114    is used instead (zero on the first call).
115 
116    If nonzero, the smallest PHDR->p_align value seen sets the
117    effective page size for the address space DWFL describes.
118    This is the granularity at which reported module boundary
119    addresses will be considered to fall in or out of a segment.
120 
121    Returns -1 for errors, or NDX (or its assigned replacement) on success.
122 
123    When NDX is the value succeeding the last call's NDX (or is implicitly
124    so as above), IDENT is nonnull and matches the value in the last call,
125    and the PHDR and BIAS values reflect a segment that would be contiguous,
126    in both memory and file, with the last segment reported, then this
127    segment may be coalesced internally with preceding segments.  When given
128    an address inside this segment, dwfl_addrsegment may return the NDX of a
129    preceding contiguous segment.  To prevent coalesced segments, always
130    pass a null pointer for IDENT.
131 
132    The values passed are not stored (except to track coalescence).
133    The only information that can be extracted from DWFL later is the
134    mapping of an address to a segment index that starts at or below
135    it.  Reporting segments at all is optional.  Its only benefit to
136    the caller is to offer this quick lookup via dwfl_addrsegment,
137    or use other segment-based calls.  */
138 extern int dwfl_report_segment (Dwfl *dwfl, int ndx,
139 				const GElf_Phdr *phdr, GElf_Addr bias,
140 				const void *ident);
141 
142 /* Report that a module called NAME spans addresses [START, END).
143    Returns the module handle, either existing or newly allocated,
144    or returns a null pointer for an allocation error.  */
145 extern Dwfl_Module *dwfl_report_module (Dwfl *dwfl, const char *name,
146 					Dwarf_Addr start, Dwarf_Addr end);
147 
148 /* Report a module to address BASE with start and end addresses computed
149    from the ELF program headers in the given file - see the table below.
150    FD may be -1 to open FILE_NAME.  On success, FD is consumed by the
151    library, and the `find_elf' callback will not be used for this module.
152 	    ADD_P_VADDR  BASE
153    ET_EXEC  ignored      ignored
154    ET_DYN   false        absolute address where to place the file
155 	    true         start address relative to ELF's phdr p_vaddr
156    ET_REL   ignored      absolute address where to place the file
157    ET_CORE  ignored      ignored
158    ET_DYN ELF phdr p_vaddr address can be non-zero if the shared library
159    has been prelinked by tool prelink(8).  */
160 extern Dwfl_Module *dwfl_report_elf (Dwfl *dwfl, const char *name,
161 				     const char *file_name, int fd,
162 				     GElf_Addr base, bool add_p_vaddr);
163 
164 /* Similar, but report the module for offline use.  All ET_EXEC files
165    being reported must be reported before any relocatable objects.
166    If this is used, dwfl_report_module and dwfl_report_elf may not be
167    used in the same reporting session.  */
168 extern Dwfl_Module *dwfl_report_offline (Dwfl *dwfl, const char *name,
169 					 const char *file_name, int fd);
170 
171 
172 /* Finish reporting the current set of modules to the library.
173    If REMOVED is not null, it's called for each module that
174    existed before but was not included in the current report.
175    Returns a nonzero return value from the callback.
176    The callback may call dwfl_report_module; doing so with the
177    details of the module being removed prevents its removal.
178    DWFL cannot be used until this function has returned zero.  */
179 extern int dwfl_report_end (Dwfl *dwfl,
180 			    int (*removed) (Dwfl_Module *, void *,
181 					    const char *, Dwarf_Addr,
182 					    void *arg),
183 			    void *arg);
184 
185 /* Start reporting additional modules to the library.  No calls but
186    dwfl_report_* can be made on DWFL until dwfl_report_end is called.
187    This is like dwfl_report_begin, but all the old modules are kept on.
188    More dwfl_report_* calls can follow to add more modules.
189    When dwfl_report_end is called, no old modules will be removed.  */
190 extern void dwfl_report_begin_add (Dwfl *dwfl);
191 
192 
193 /* Return the name of the module, and for each non-null argument store
194    interesting details: *USERDATA is a location for storing your own
195    pointer, **USERDATA is initially null; *START and *END give the address
196    range covered by the module; *DWBIAS is the address bias for debugging
197    information, and *SYMBIAS for symbol table entries (either is -1 if not
198    yet accessed); *MAINFILE is the name of the ELF file, and *DEBUGFILE the
199    name of the debuginfo file (might be equal to *MAINFILE; either is null
200    if not yet accessed).  */
201 extern const char *dwfl_module_info (Dwfl_Module *mod, void ***userdata,
202 				     Dwarf_Addr *start, Dwarf_Addr *end,
203 				     Dwarf_Addr *dwbias, Dwarf_Addr *symbias,
204 				     const char **mainfile,
205 				     const char **debugfile);
206 
207 /* Iterate through the modules, starting the walk with OFFSET == 0.
208    Calls *CALLBACK for each module as long as it returns DWARF_CB_OK.
209    When *CALLBACK returns another value, the walk stops and the
210    return value can be passed as OFFSET to resume it.  Returns 0 when
211    there are no more modules, or -1 for errors.  */
212 extern ptrdiff_t dwfl_getmodules (Dwfl *dwfl,
213 				  int (*callback) (Dwfl_Module *, void **,
214 						   const char *, Dwarf_Addr,
215 						   void *arg),
216 				  void *arg,
217 				  ptrdiff_t offset);
218 
219 /* Find the module containing the given address.  */
220 extern Dwfl_Module *dwfl_addrmodule (Dwfl *dwfl, Dwarf_Addr address);
221 
222 /* Find the segment, if any, and module, if any, containing ADDRESS.
223    Returns a segment index returned by dwfl_report_segment, or -1
224    if no segment matches the address.  Regardless of the return value,
225    *MOD is always set to the module containing ADDRESS, or to null.  */
226 extern int dwfl_addrsegment (Dwfl *dwfl, Dwarf_Addr address, Dwfl_Module **mod);
227 
228 
229 
230 /* Report the known build ID bits associated with a module.
231    If VADDR is nonzero, it gives the absolute address where those
232    bits are found within the module.  This can be called at any
233    time, but is usually used immediately after dwfl_report_module.
234    Once the module's main ELF file is opened, the ID note found
235    there takes precedence and cannot be changed.  */
236 extern int dwfl_module_report_build_id (Dwfl_Module *mod,
237 					const unsigned char *bits, size_t len,
238 					GElf_Addr vaddr)
239   __nonnull_attribute__ (2);
240 
241 /* Extract the build ID bits associated with a module.
242    Returns -1 for errors, 0 if no ID is known, or the number of ID bytes.
243    When an ID is found, *BITS points to it; *VADDR is the absolute address
244    at which the ID bits are found within the module, or 0 if unknown.
245 
246    This returns 0 when the module's main ELF file has not yet been loaded
247    and its build ID bits were not reported.  To ensure the ID is always
248    returned when determinable, call dwfl_module_getelf first.  */
249 extern int dwfl_module_build_id (Dwfl_Module *mod,
250 				 const unsigned char **bits, GElf_Addr *vaddr)
251   __nonnull_attribute__ (2, 3);
252 
253 
254 /*** Standard callbacks ***/
255 
256 /* These standard find_elf and find_debuginfo callbacks are
257    controlled by a string specifying directories to look in.
258    If `debuginfo_path' is set in the Dwfl_Callbacks structure
259    and the char * it points to is not null, that supplies the
260    string.  Otherwise a default path is used.
261 
262    If the first character of the string is + or - that enables or
263    disables CRC32 checksum validation when it's necessary.  The
264    remainder of the string is composed of elements separated by
265    colons.  Each element can start with + or - to override the
266    global checksum behavior.  This flag is never relevant when
267    working with build IDs, but it's always parsed in the path
268    string.  The remainder of the element indicates a directory.
269 
270    Searches by build ID consult only the elements naming absolute
271    directory paths.  They look under those directories for a link
272    named ".build-id/xx/yy" or ".build-id/xx/yy.debug", where "xxyy"
273    is the lower-case hexadecimal representation of the ID bytes.
274 
275    In searches for debuginfo by name, if the remainder of the
276    element is empty, the directory containing the main file is
277    tried; if it's an absolute path name, the absolute directory path
278    (and any subdirectory of that path) containing the main file is
279    taken as a subdirectory of this path; a relative path name is taken
280    as a subdirectory of the directory containing the main file.
281    Hence for /usr/bin/ls, the default string ":.debug:/usr/lib/debug"
282    says to look in /usr/bin, then /usr/bin/.debug, then the path subdirs
283    under /usr/lib/debug, in the order /usr/lib/debug/usr/bin, then
284    /usr/lib/debug/bin, and finally /usr/lib/debug, for the file name in
285    the .gnu_debuglink section (or "ls.debug" if none was found).  */
286 
287 /* Standard find_elf callback function working solely on build ID.
288    This can be tried first by any find_elf callback, to use the
289    bits passed to dwfl_module_report_build_id, if any.  */
290 extern int dwfl_build_id_find_elf (Dwfl_Module *, void **,
291 				   const char *, Dwarf_Addr,
292 				   char **, Elf **);
293 
294 /* Standard find_debuginfo callback function working solely on build ID.
295    This can be tried first by any find_debuginfo callback,
296    to use the build ID bits from the main file when present.  */
297 extern int dwfl_build_id_find_debuginfo (Dwfl_Module *, void **,
298 					 const char *, Dwarf_Addr,
299 					 const char *, const char *,
300 					 GElf_Word, char **);
301 
302 /* Standard find_debuginfo callback function.
303    If a build ID is available, this tries first to use that.
304    If there is no build ID or no valid debuginfo found by ID,
305    it searches the debuginfo path by name, as described above.
306    Any file found in the path is validated by build ID if possible,
307    or else by CRC32 checksum if enabled, and skipped if it does not match.  */
308 extern int dwfl_standard_find_debuginfo (Dwfl_Module *, void **,
309 					 const char *, Dwarf_Addr,
310 					 const char *, const char *,
311 					 GElf_Word, char **);
312 
313 
314 /* This callback must be used when using dwfl_offline_* to report modules,
315    if ET_REL is to be supported.  */
316 extern int dwfl_offline_section_address (Dwfl_Module *, void **,
317 					 const char *, Dwarf_Addr,
318 					 const char *, GElf_Word,
319 					 const GElf_Shdr *,
320 					 Dwarf_Addr *addr);
321 
322 
323 /* Callbacks for working with kernel modules in the running Linux kernel.  */
324 extern int dwfl_linux_kernel_find_elf (Dwfl_Module *, void **,
325 				       const char *, Dwarf_Addr,
326 				       char **, Elf **);
327 extern int dwfl_linux_kernel_module_section_address (Dwfl_Module *, void **,
328 						     const char *, Dwarf_Addr,
329 						     const char *, GElf_Word,
330 						     const GElf_Shdr *,
331 						     Dwarf_Addr *addr);
332 
333 /* Call dwfl_report_elf for the running Linux kernel.
334    Returns zero on success, -1 if dwfl_report_module failed,
335    or an errno code if opening the kernel binary failed.  */
336 extern int dwfl_linux_kernel_report_kernel (Dwfl *dwfl);
337 
338 /* Call dwfl_report_module for each kernel module in the running Linux kernel.
339    Returns zero on success, -1 if dwfl_report_module failed,
340    or an errno code if reading the list of modules failed.  */
341 extern int dwfl_linux_kernel_report_modules (Dwfl *dwfl);
342 
343 /* Report a kernel and its modules found on disk, for offline use.
344    If RELEASE starts with '/', it names a directory to look in;
345    if not, it names a directory to find under /lib/modules/;
346    if null, /lib/modules/`uname -r` is used.
347    Returns zero on success, -1 if dwfl_report_module failed,
348    or an errno code if finding the files on disk failed.
349 
350    If PREDICATE is not null, it is called with each module to be reported;
351    its arguments are the module name, and the ELF file name or null if unknown,
352    and its return value should be zero to skip the module, one to report it,
353    or -1 to cause the call to fail and return errno.  */
354 extern int dwfl_linux_kernel_report_offline (Dwfl *dwfl, const char *release,
355 					     int (*predicate) (const char *,
356 							       const char *));
357 
358 /* Examine an ET_CORE file and report modules based on its contents.
359    This can follow a dwfl_report_offline call to bootstrap the
360    DT_DEBUG method of following the dynamic linker link_map chain, in
361    case the core file does not contain enough of the executable's text
362    segment to locate its PT_DYNAMIC in the dump.  In such case you need to
363    supply non-NULL EXECUTABLE, otherwise dynamic libraries will not be loaded
364    into the DWFL map.  This might call dwfl_report_elf on file names found in
365    the dump if reading some link_map files is the only way to ascertain those
366    modules' addresses.  Returns the number of modules reported, or -1 for
367    errors.  */
368 extern int dwfl_core_file_report (Dwfl *dwfl, Elf *elf, const char *executable);
369 
370 /* Call dwfl_report_module for each file mapped into the address space of PID.
371    Returns zero on success, -1 if dwfl_report_module failed,
372    or an errno code if opening the proc files failed.  */
373 extern int dwfl_linux_proc_report (Dwfl *dwfl, pid_t pid);
374 
375 /* Similar, but reads an input stream in the format of Linux /proc/PID/maps
376    files giving module layout, not the file for a live process.  */
377 extern int dwfl_linux_proc_maps_report (Dwfl *dwfl, FILE *);
378 
379 /* Trivial find_elf callback for use with dwfl_linux_proc_report.
380    This uses the module name as a file name directly and tries to open it
381    if it begin with a slash, or handles the magic string "[vdso]".  */
382 extern int dwfl_linux_proc_find_elf (Dwfl_Module *mod, void **userdata,
383 				     const char *module_name, Dwarf_Addr base,
384 				     char **file_name, Elf **);
385 
386 /* Standard argument parsing for using a standard callback set.  */
387 struct argp;
388 extern const struct argp *dwfl_standard_argp (void) __const_attribute__;
389 
390 
391 /*** Relocation of addresses from Dwfl ***/
392 
393 /* Return the number of relocatable bases associated with the module,
394    which is zero for ET_EXEC and one for ET_DYN.  Returns -1 for errors.  */
395 extern int dwfl_module_relocations (Dwfl_Module *mod);
396 
397 /* Return the relocation base index associated with the *ADDRESS location,
398    and adjust *ADDRESS to be an offset relative to that base.
399    Returns -1 for errors.  */
400 extern int dwfl_module_relocate_address (Dwfl_Module *mod,
401 					 Dwarf_Addr *address);
402 
403 /* Return the ELF section name for the given relocation base index;
404    if SHNDXP is not null, set *SHNDXP to the ELF section index.
405    For ET_DYN, returns "" and sets *SHNDXP to SHN_ABS; the relocation
406    base is the runtime start address reported for the module.
407    Returns null for errors.  */
408 extern const char *dwfl_module_relocation_info (Dwfl_Module *mod,
409 						unsigned int idx,
410 						GElf_Word *shndxp);
411 
412 /* Validate that ADDRESS and ADDRESS+OFFSET lie in a known module
413    and both within the same contiguous region for relocation purposes.
414    Returns zero for success and -1 for errors.  */
415 extern int dwfl_validate_address (Dwfl *dwfl,
416 				  Dwarf_Addr address, Dwarf_Sword offset);
417 
418 
419 /*** ELF access functions ***/
420 
421 /* Fetch the module main ELF file (where the allocated sections
422    are found) for use with libelf.  If successful, fills in *BIAS
423    with the difference between addresses within the loaded module
424    and those in symbol tables or Dwarf information referring to it.  */
425 extern Elf *dwfl_module_getelf (Dwfl_Module *, GElf_Addr *bias)
426   __nonnull_attribute__ (2);
427 
428 /* Return the number of symbols in the module's symbol table,
429    or -1 for errors.  */
430 extern int dwfl_module_getsymtab (Dwfl_Module *mod);
431 
432 /* Return the index of the first global symbol in the module's symbol
433    table, or -1 for errors.  In each symbol table, all symbols with
434    STB_LOCAL binding precede the weak and global symbols.  This
435    function returns the symbol table index one greater than the last
436    local symbol.  */
437 extern int dwfl_module_getsymtab_first_global (Dwfl_Module *mod);
438 
439 /* Fetch one entry from the module's symbol table.  On errors, returns
440    NULL.  If successful, fills in *SYM and returns the string for st_name.
441    This works like gelf_getsym except that st_value is always adjusted to
442    an absolute value based on the module's location, when the symbol is in
443    an SHF_ALLOC section.  If SHNDXP is non-null, it's set with the section
444    index (whether from st_shndx or extended index table); in case of a
445    symbol in a non-allocated section, *SHNDXP is instead set to -1.
446    Note that since symbols can come from either the main, debug or auxiliary
447    ELF symbol file (either dynsym or symtab) the section index can only
448    be reliably used to compare against special section constants like
449    SHN_UNDEF or SHN_ABS.  It is recommended to use dwfl_module_getsym_info
450    which doesn't have these deficiencies.  */
451 extern const char *dwfl_module_getsym (Dwfl_Module *mod, int ndx,
452 				       GElf_Sym *sym, GElf_Word *shndxp)
453   __nonnull_attribute__ (3);
454 
455 /* Fetch one entry from the module's symbol table and the associated
456    address value.  On errors, returns NULL.  If successful, fills in
457    *SYM, *ADDR and returns the string for st_name.  This works like
458    gelf_getsym.  *ADDR is set to the st_value adjusted to an absolute
459    value based on the module's location, when the symbol is in an
460    SHF_ALLOC section.  For non-ET_REL files, if the arch uses function
461    descriptors, and the st_value points to one, *ADDR will be resolved
462    to the actual function entry address.  The SYM->ST_VALUE itself
463    isn't adjusted in any way.  Fills in ELFP, if not NULL, with the
464    ELF file the symbol originally came from.  Note that symbols can
465    come from either the main, debug or auxiliary ELF symbol file
466    (either dynsym or symtab).  If SHNDXP is non-null, it's set with
467    the section index (whether from st_shndx or extended index table);
468    in case of a symbol in a non-allocated section, *SHNDXP is instead
469    set to -1.  Fills in BIAS, if not NULL, with the difference between
470    addresses within the loaded module and those in symbol table of the
471    ELF file.  Note that the address associated with the symbol might
472    be in a different section than the returned symbol.  The section in
473    the main elf file in which returned ADDR falls can be found with
474    dwfl_module_address_section.  */
475 extern const char *dwfl_module_getsym_info (Dwfl_Module *mod, int ndx,
476 					    GElf_Sym *sym, GElf_Addr *addr,
477 					    GElf_Word *shndxp,
478 					    Elf **elfp, Dwarf_Addr *bias)
479   __nonnull_attribute__ (3, 4);
480 
481 /* Find the symbol that ADDRESS lies inside, and return its name.  */
482 extern const char *dwfl_module_addrname (Dwfl_Module *mod, GElf_Addr address);
483 
484 /* Find the symbol associated with ADDRESS.  Return its name or NULL
485    when nothing was found.  If the architecture uses function
486    descriptors, and symbol st_value points to one, ADDRESS wil be
487    matched against either the adjusted st_value or the associated
488    function entry value as described in dwfl_module_getsym_info.  If
489    OFFSET is not NULL it will be filled in with the difference from
490    the start of the symbol (or function entry).  If SYM is not NULL it
491    is filled in with the symbol associated with the matched ADDRESS.
492    The SYM->ST_VALUE itself isn't adjusted in any way.  Fills in ELFP,
493    if not NULL, with the ELF file the symbol originally came from.
494    Note that symbols can come from either the main, debug or auxiliary
495    ELF symbol file (either dynsym or symtab).  If SHNDXP is non-null,
496    it's set with the section index (whether from st_shndx or extended
497    index table).  Fills in BIAS, if not NULL, with the difference
498    between addresses within the loaded module and those in symbol
499    table of the ELF file.  Note that the address matched against the
500    symbol might be in a different section than the returned symbol.
501    The section in the main elf file in ADDRESS falls can be found with
502    dwfl_module_address_section.  */
503 extern const char *dwfl_module_addrinfo (Dwfl_Module *mod, GElf_Addr address,
504 					 GElf_Off *offset, GElf_Sym *sym,
505 					 GElf_Word *shndxp, Elf **elfp,
506 					 Dwarf_Addr *bias)
507   __nonnull_attribute__ (3);
508 
509 /* Find the symbol that ADDRESS lies inside, and return detailed
510    information as for dwfl_module_getsym (above).  Note that like
511    dwfl_module_getsym this function also adjusts SYM->ST_VALUE to an
512    absolute value based on the module's location.  ADDRESS is only
513    matched against this adjusted SYM->ST_VALUE.  This means that
514    depending on architecture this might only match symbols that
515    represent function descriptor addresses (and not function entry
516    addresses).  For these reasons it is recommended to use
517    dwfl_module_addrinfo instead.  */
518 extern const char *dwfl_module_addrsym (Dwfl_Module *mod, GElf_Addr address,
519 					GElf_Sym *sym, GElf_Word *shndxp)
520   __nonnull_attribute__ (3);
521 
522 /* Find the ELF section that *ADDRESS lies inside and return it.
523    On success, adjusts *ADDRESS to be relative to the section,
524    and sets *BIAS to the difference between addresses used in
525    the returned section's headers and run-time addresses.  */
526 extern Elf_Scn *dwfl_module_address_section (Dwfl_Module *mod,
527 					     Dwarf_Addr *address,
528 					     Dwarf_Addr *bias)
529   __nonnull_attribute__ (2, 3);
530 
531 
532 /*** Dwarf access functions ***/
533 
534 /* Fetch the module's debug information for use with libdw.
535    If successful, fills in *BIAS with the difference between
536    addresses within the loaded module and those  to use with libdw.  */
537 extern Dwarf *dwfl_module_getdwarf (Dwfl_Module *, Dwarf_Addr *bias)
538      __nonnull_attribute__ (2);
539 
540 /* Get the libdw handle for each module.  */
541 extern ptrdiff_t dwfl_getdwarf (Dwfl *,
542 				int (*callback) (Dwfl_Module *, void **,
543 						 const char *, Dwarf_Addr,
544 						 Dwarf *, Dwarf_Addr, void *),
545 				void *arg, ptrdiff_t offset);
546 
547 /* Look up the module containing ADDR and return its debugging information,
548    loading it if necessary.  */
549 extern Dwarf *dwfl_addrdwarf (Dwfl *dwfl, Dwarf_Addr addr, Dwarf_Addr *bias)
550      __nonnull_attribute__ (3);
551 
552 
553 /* Find the CU containing ADDR and return its DIE.  */
554 extern Dwarf_Die *dwfl_addrdie (Dwfl *dwfl, Dwarf_Addr addr, Dwarf_Addr *bias)
555      __nonnull_attribute__ (3);
556 extern Dwarf_Die *dwfl_module_addrdie (Dwfl_Module *mod,
557 				       Dwarf_Addr addr, Dwarf_Addr *bias)
558      __nonnull_attribute__ (3);
559 
560 /* Iterate through the CUs, start with null for LASTCU.  */
561 extern Dwarf_Die *dwfl_nextcu (Dwfl *dwfl, Dwarf_Die *lastcu, Dwarf_Addr *bias)
562      __nonnull_attribute__ (3);
563 extern Dwarf_Die *dwfl_module_nextcu (Dwfl_Module *mod,
564 				      Dwarf_Die *lastcu, Dwarf_Addr *bias)
565      __nonnull_attribute__ (3);
566 
567 /* Return the module containing the CU DIE.  */
568 extern Dwfl_Module *dwfl_cumodule (Dwarf_Die *cudie);
569 
570 
571 /* Cache the source line information fo the CU and return the
572    number of Dwfl_Line entries it has.  */
573 extern int dwfl_getsrclines (Dwarf_Die *cudie, size_t *nlines);
574 
575 /* Access one line number entry within the CU.  */
576 extern Dwfl_Line *dwfl_onesrcline (Dwarf_Die *cudie, size_t idx);
577 
578 /* Get source for address.  */
579 extern Dwfl_Line *dwfl_module_getsrc (Dwfl_Module *mod, Dwarf_Addr addr);
580 extern Dwfl_Line *dwfl_getsrc (Dwfl *dwfl, Dwarf_Addr addr);
581 
582 /* Get address for source.  */
583 extern int dwfl_module_getsrc_file (Dwfl_Module *mod,
584 				    const char *fname, int lineno, int column,
585 				    Dwfl_Line ***srcsp, size_t *nsrcs);
586 
587 /* Return the module containing this line record.  */
588 extern Dwfl_Module *dwfl_linemodule (Dwfl_Line *line);
589 
590 /* Return the CU containing this line record.  */
591 extern Dwarf_Die *dwfl_linecu (Dwfl_Line *line);
592 
593 /* Return the source file name and fill in other information.
594    Arguments may be null for unneeded fields.  */
595 extern const char *dwfl_lineinfo (Dwfl_Line *line, Dwarf_Addr *addr,
596 				  int *linep, int *colp,
597 				  Dwarf_Word *mtime, Dwarf_Word *length);
598 
599   /* Return the equivalent Dwarf_Line and the bias to apply to its address.  */
600 extern Dwarf_Line *dwfl_dwarf_line (Dwfl_Line *line, Dwarf_Addr *bias);
601 
602 /* Return the compilation directory (AT_comp_dir) from this line's CU.  */
603 extern const char *dwfl_line_comp_dir (Dwfl_Line *line);
604 
605 
606 /*** Machine backend access functions ***/
607 
608 /* Return location expression to find return value given a
609    DW_TAG_subprogram, DW_TAG_subroutine_type, or similar DIE describing
610    function itself (whose DW_AT_type attribute describes its return type).
611    The given DIE must come from the given module.  Returns -1 for errors.
612    Returns zero if the function has no return value (e.g. "void" in C).
613    Otherwise, *LOCOPS gets a location expression to find the return value,
614    and returns the number of operations in the expression.  The pointer is
615    permanently allocated at least as long as the module is live.  */
616 extern int dwfl_module_return_value_location (Dwfl_Module *mod,
617 					      Dwarf_Die *functypedie,
618 					      const Dwarf_Op **locops);
619 
620 /* Enumerate the DWARF register numbers and their names.
621    For each register, CALLBACK gets its DWARF number, a string describing
622    the register set (such as "integer" or "FPU"), a prefix used in
623    assembler syntax (such as "%" or "$", may be ""), and the name for the
624    register (contains identifier characters only, possibly all digits).
625    The REGNAME string is valid only during the callback. */
626 extern int dwfl_module_register_names (Dwfl_Module *mod,
627 				       int (*callback) (void *arg,
628 							int regno,
629 							const char *setname,
630 							const char *prefix,
631 							const char *regname,
632 							int bits, int type),
633 				       void *arg);
634 
635 
636 /* Find the CFI for this module.  Returns NULL if there is no CFI.
637    On success, fills in *BIAS with the difference between addresses
638    within the loaded module and those in the CFI referring to it.
639    The pointer returned can be used until the module is cleaned up.
640    Calling these more than once returns the same pointers.
641 
642    dwfl_module_dwarf_cfi gets the '.debug_frame' information found with the
643    rest of the DWARF information.  dwfl_module_eh_cfi gets the '.eh_frame'
644    information found linked into the text.  A module might have either or
645    both.  */
646 extern Dwarf_CFI *dwfl_module_dwarf_cfi (Dwfl_Module *mod, Dwarf_Addr *bias);
647 extern Dwarf_CFI *dwfl_module_eh_cfi (Dwfl_Module *mod, Dwarf_Addr *bias);
648 
649 
650 typedef struct
651 {
652   /* Called to iterate through threads.  Returns next TID (thread ID) on
653      success, a negative number on failure and zero if there are no more
654      threads.  dwfl_errno () should be set if negative number has been
655      returned.  *THREAD_ARGP is NULL on first call, and may be optionally
656      set by the implementation. The value set by the implementation will
657      be passed in on the next call to NEXT_THREAD.  THREAD_ARGP is never
658      NULL.  *THREAD_ARGP will be passed to set_initial_registers or
659      thread_detach callbacks together with Dwfl_Thread *thread.  This
660      method must not be NULL.  */
661   pid_t (*next_thread) (Dwfl *dwfl, void *dwfl_arg, void **thread_argp)
662     __nonnull_attribute__ (1);
663 
664   /* Called to get a specific thread.  Returns true if there is a
665      thread with the given thread id number, returns false if no such
666      thread exists and will set dwfl_errno in that case.  THREAD_ARGP
667      is never NULL.  *THREAD_ARGP will be passed to
668      set_initial_registers or thread_detach callbacks together with
669      Dwfl_Thread *thread.  This method may be NULL and will then be
670      emulated using the next_thread callback. */
671   bool (*get_thread) (Dwfl *dwfl, pid_t tid, void *dwfl_arg,
672 		      void **thread_argp)
673     __nonnull_attribute__ (1);
674 
675   /* Called during unwinding to access memory (stack) state.  Returns true for
676      successfully read *RESULT or false and sets dwfl_errno () on failure.
677      This method may be NULL - in such case dwfl_thread_getframes will return
678      only the initial frame.  */
679   bool (*memory_read) (Dwfl *dwfl, Dwarf_Addr addr, Dwarf_Word *result,
680                        void *dwfl_arg)
681     __nonnull_attribute__ (1, 3);
682 
683   /* Called on initial unwind to get the initial register state of the first
684      frame.  Should call dwfl_thread_state_registers, possibly multiple times
685      for different ranges and possibly also dwfl_thread_state_register_pc, to
686      fill in initial (DWARF) register values.  After this call, till at least
687      thread_detach is called, the thread is assumed to be frozen, so that it is
688      safe to unwind.  Returns true on success or false and sets dwfl_errno ()
689      on failure.  In the case of a failure thread_detach will not be called.
690      This method must not be NULL.  */
691   bool (*set_initial_registers) (Dwfl_Thread *thread, void *thread_arg)
692     __nonnull_attribute__ (1);
693 
694   /* Called by dwfl_end.  All thread_detach method calls have been already
695      done.  This method may be NULL.  */
696   void (*detach) (Dwfl *dwfl, void *dwfl_arg)
697     __nonnull_attribute__ (1);
698 
699   /* Called when unwinding is done.  No callback will be called after
700      this method has been called.  Iff set_initial_registers was called for
701      a TID and it returned success thread_detach will be called before the
702      detach method above.  This method may be NULL.  */
703   void (*thread_detach) (Dwfl_Thread *thread, void *thread_arg)
704     __nonnull_attribute__ (1);
705 } Dwfl_Thread_Callbacks;
706 
707 /* PID is the process id associated with the DWFL state.  Architecture of DWFL
708    modules is specified by ELF, ELF must remain valid during DWFL lifetime.
709    Use NULL ELF to detect architecture from DWFL, the function will then detect
710    it from arbitrary Dwfl_Module of DWFL.  DWFL_ARG is the callback backend
711    state.  DWFL_ARG will be provided to the callbacks.  *THREAD_CALLBACKS
712    function pointers must remain valid during lifetime of DWFL.  Function
713    returns true on success, false otherwise.  */
714 bool dwfl_attach_state (Dwfl *dwfl, Elf *elf, pid_t pid,
715                         const Dwfl_Thread_Callbacks *thread_callbacks,
716 			void *dwfl_arg)
717   __nonnull_attribute__ (1, 4);
718 
719 /* Calls dwfl_attach_state with Dwfl_Thread_Callbacks setup for extracting
720    thread state from the ELF core file.  Returns the pid number extracted
721    from the core file, or -1 for errors.  */
722 extern int dwfl_core_file_attach (Dwfl *dwfl, Elf *elf);
723 
724 /* Calls dwfl_attach_state with Dwfl_Thread_Callbacks setup for extracting
725    thread state from the proc file system.  Uses ptrace to attach and stop
726    the thread under inspection and detaches when thread_detach is called
727    and unwinding for the thread is done, unless ASSUME_PTRACE_STOPPED is
728    true.  If ASSUME_PTRACE_STOPPED is true the caller should make sure that
729    the thread is ptrace attached and stopped before unwinding by calling
730    either dwfl_thread_getframes or dwfl_getthread_frames.  Returns zero on
731    success, -1 if dwfl_attach_state failed, or an errno code if opening the
732    proc files failed.  */
733 extern int dwfl_linux_proc_attach (Dwfl *dwfl, pid_t pid,
734 				   bool assume_ptrace_stopped);
735 
736 /* Return PID for the process associated with DWFL.  Function returns -1 if
737    dwfl_attach_state was not called for DWFL.  */
738 pid_t dwfl_pid (Dwfl *dwfl)
739   __nonnull_attribute__ (1);
740 
741 /* Return DWFL from which THREAD was created using dwfl_getthreads.  */
742 Dwfl *dwfl_thread_dwfl (Dwfl_Thread *thread)
743   __nonnull_attribute__ (1);
744 
745 /* Return positive TID (thread ID) for THREAD.  This function never fails.  */
746 pid_t dwfl_thread_tid (Dwfl_Thread *thread)
747   __nonnull_attribute__ (1);
748 
749 /* Return thread for frame STATE.  This function never fails.  */
750 Dwfl_Thread *dwfl_frame_thread (Dwfl_Frame *state)
751   __nonnull_attribute__ (1);
752 
753 /* Called by Dwfl_Thread_Callbacks.set_initial_registers implementation.
754    For every known continuous block of registers <FIRSTREG..FIRSTREG+NREGS)
755    (inclusive..exclusive) set their content to REGS (array of NREGS items).
756    Function returns false if any of the registers has invalid number.  */
757 bool dwfl_thread_state_registers (Dwfl_Thread *thread, int firstreg,
758                                   unsigned nregs, const Dwarf_Word *regs)
759   __nonnull_attribute__ (1, 4);
760 
761 /* Called by Dwfl_Thread_Callbacks.set_initial_registers implementation.
762    If PC is not contained among DWARF registers passed by
763    dwfl_thread_state_registers on the target architecture pass the PC value
764    here.  */
765 void dwfl_thread_state_register_pc (Dwfl_Thread *thread, Dwarf_Word pc)
766   __nonnull_attribute__ (1);
767 
768 /* Iterate through the threads for a process.  Returns zero if all threads have
769    been processed by the callback, returns -1 on error, or the value of the
770    callback when not DWARF_CB_OK.  -1 returned on error will set dwfl_errno ().
771    Keeps calling the callback with the next thread while the callback returns
772    DWARF_CB_OK, till there are no more threads.  */
773 int dwfl_getthreads (Dwfl *dwfl,
774 		     int (*callback) (Dwfl_Thread *thread, void *arg),
775 		     void *arg)
776   __nonnull_attribute__ (1, 2);
777 
778 /* Iterate through the frames for a thread.  Returns zero if all frames
779    have been processed by the callback, returns -1 on error, or the value of
780    the callback when not DWARF_CB_OK.  -1 returned on error will
781    set dwfl_errno ().  Some systems return error instead of zero on end of the
782    backtrace, for cross-platform compatibility callers should consider error as
783    a zero.  Keeps calling the callback with the next frame while the callback
784    returns DWARF_CB_OK, till there are no more frames.  On start will call the
785    set_initial_registers callback and on return will call the detach_thread
786    callback of the Dwfl_Thread.  */
787 int dwfl_thread_getframes (Dwfl_Thread *thread,
788 			   int (*callback) (Dwfl_Frame *state, void *arg),
789 			   void *arg)
790   __nonnull_attribute__ (1, 2);
791 
792 /* Like dwfl_thread_getframes, but specifying the thread by its unique
793    identifier number.  Returns zero if all frames have been processed
794    by the callback, returns -1 on error (and when no thread with
795    the given thread id number exists), or the value of the callback
796    when not DWARF_CB_OK.  -1 returned on error will set dwfl_errno ().  */
797 int dwfl_getthread_frames (Dwfl *dwfl, pid_t tid,
798 			   int (*callback) (Dwfl_Frame *thread, void *arg),
799 			   void *arg)
800   __nonnull_attribute__ (1, 3);
801 
802 /* Return *PC (program counter) for thread-specific frame STATE.
803    Set *ISACTIVATION according to DWARF frame "activation" definition.
804    Typically you need to substract 1 from *PC if *ACTIVATION is false to safely
805    find function of the caller.  ACTIVATION may be NULL.  PC must not be NULL.
806    Function returns false if it failed to find *PC.  */
807 bool dwfl_frame_pc (Dwfl_Frame *state, Dwarf_Addr *pc, bool *isactivation)
808   __nonnull_attribute__ (1, 2);
809 
810 #ifdef __cplusplus
811 }
812 #endif
813 
814 #endif	/* libdwfl.h */
815