From 2874cb8393678a041dc533fa54debd5e862d7616 Mon Sep 17 00:00:00 2001 From: Joel Brobecker Date: Wed, 8 May 2013 05:50:47 +0000 Subject: [doco] Document the XML format used for AIX shared lib support. gdb/doc/ChangeLog: * gdbint.texinfo (Native Debugging): Add "AIX Shared Library Support" subsection documenting the XML format used to transfer shared library info on AIX. --- gdb/doc/ChangeLog | 6 +++++ gdb/doc/gdbint.texinfo | 71 ++++++++++++++++++++++++++++++++++++++++++++++++++ 2 files changed, 77 insertions(+) (limited to 'gdb') diff --git a/gdb/doc/ChangeLog b/gdb/doc/ChangeLog index 4becbe9..80f08a5 100644 --- a/gdb/doc/ChangeLog +++ b/gdb/doc/ChangeLog @@ -1,5 +1,11 @@ 2013-05-08 Joel Brobecker + * gdbint.texinfo (Native Debugging): Add "AIX Shared Library + Support" subsection documenting the XML format used to transfer + shared library info on AIX. + +2013-05-08 Joel Brobecker + * gdb.texinfo (Debugging Output): Add documentation of "set debug aix-solib" and "show debug aix-solib" commands. diff --git a/gdb/doc/gdbint.texinfo b/gdb/doc/gdbint.texinfo index 9bdbe74..7f1f49f 100644 --- a/gdb/doc/gdbint.texinfo +++ b/gdb/doc/gdbint.texinfo @@ -5391,6 +5391,77 @@ the Unix @code{ptrace} call in a vanilla way. @section shared libraries +@subsection AIX Shared Library Support + +Shared library support on AIX is based on reading some data provided +by the loader. With a live process, this information is accessed +via a @code{ptrace} call (@code{PT_LDINFO}), while it is obtained +by reading the @samp{.ldinfo} section when debugging from a core file. +In both cases, the data has the same format, provided by the +@file{sys/ldr.h} system header file. + +Internally, the relevant portions of the loader information is +transformed into an XML representation, which lists all objects +currently mapped in memory. The associated DTD can be found in +@file{gdb/features/library-list-aix.dtd}. For each library element, +the following parameters are reported: + +@itemize @minus + +@item +@code{name}, the path name of an object. This is usually the name +of an archive, or the name of the main executable. + +@item +If the @code{name} parameter refers to an archive, @code{member} provides +the name of the object inside the archive on which the program depends. +Otherwise, this field should be omitted. + +@item +@code{text_addr}, the address where the @code{.text} section was mapped +in memory. + +@item +@code{text_size}, the size of the @code{.text} section. + +@item +@code{data_addr}, the address where the @code{.data} section was mapped +in memory. + +@item +@code{data_size}, the size of the @code{.data} section. + +@end itemize + +By convention, the library list always has at least one element, and +the first entry always refers to the main executable. + +Below is an example of such XML representation for a small program: + +@smallexample + + + + + + +@end smallexample + +In that example, the list shows that the main executable is named +@file{simple}, and its text section was loaded at 0x10000000. +This program depends on member @file{shr.o} from the @file{/lib/libc.a} +archive, whose text and data sections were loaded at (resp.) +0xd0100700 and 0xf0633e50. + @section Native Conditionals @cindex native conditionals -- cgit v1.1