1.\" 2.\" Copyright (c) 2003 Alexey Zelkin <phantom@FreeBSD.org> 3.\" All rights reserved. 4.\" 5.\" Redistribution and use in source and binary forms, with or without 6.\" modification, are permitted provided that the following conditions 7.\" are met: 8.\" 1. Redistributions of source code must retain the above copyright 9.\" notice, this list of conditions and the following disclaimer. 10.\" 2. Redistributions in binary form must reproduce the above copyright 11.\" notice, this list of conditions and the following disclaimer in the 12.\" documentation and/or other materials provided with the distribution. 13.\" 14.\" THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND 15.\" ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 16.\" IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 17.\" ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE 18.\" FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 19.\" DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 20.\" OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 21.\" HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 22.\" LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 23.\" OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 24.\" SUCH DAMAGE. 25.\" 26.\" $FreeBSD$ 27.\" 28.Dd February 14, 2003 29.Os 30.Dt DLINFO 3 31.Sh NAME 32.Nm dlinfo 33.Nd information about dynamically loaded object 34.Sh LIBRARY 35.Lb libc 36.Sh SYNOPSIS 37.In link.h 38.In dlfcn.h 39.Ft int 40.Fn dlinfo "void * restrict handle" "int request" "void * restrict p" 41.Sh DESCRIPTION 42The 43.Fn dlinfo 44function provides information about dynamically loaded object. 45The action taken by 46.Fn dlinfo 47and exact meaning and type of 48.Fa p 49argument depend on value of the 50.Fa request 51argument provided by caller. 52.Pp 53The 54.Fa handle 55argument is either the value returned from the 56.Xr dlopen 3 57function call or special handle 58.Dv RTLD_SELF . 59If 60.Fa handle 61is the value returned from 62.Xr dlopen 3 , 63the information returned by the 64.Fn dlinfo 65function pertains to the specified object. 66If handle is the special handle 67.Dv RTLD_SELF , 68the information returned pertains to the caller itself. 69.Pp 70Possible values for the 71.Fa request 72argument are: 73.Bl -tag -width indent 74.It Dv RTLD_DI_LINKMAP 75Retrieve the 76.Vt Link_map 77.Pq Vt "struct link_map" 78structure pointer for the specified 79.Fa handle . 80On successful return, the 81.Fa p 82argument is filled with the pointer to the 83.Vt Link_map 84structure 85.Pq Fa "Link_map **p" 86describing a shared object specified by the 87.Fa handle 88argument. 89The 90.Vt Link_map 91structures are maintained as a doubly linked list by 92.Xr ld.so 1 , 93in the same order as 94.Xr dlopen 3 95and 96.Xr dlclose 3 97are called. 98See 99.Sx EXAMPLES , 100example 1. 101.Pp 102The 103.Vt Link_map 104structure is defined in 105.In link.h 106and has the following members: 107.Bd -literal -offset indent 108caddr_t l_addr; /* Base Address of library */ 109const char *l_name; /* Absolute Path to Library */ 110const void *l_ld; /* Pointer to .dynamic in memory */ 111struct link_map *l_next, /* linked list of mapped libs */ 112 *l_prev; 113.Ed 114.Bl -tag -width ".Va l_addr" 115.It Va l_addr 116The base address of the object loaded into memory. 117.It Va l_name 118The full name of the loaded shared object. 119.It Va l_ld 120The address of the dynamic linking information segment 121.Pq Dv PT_DYNAMIC 122loaded into memory. 123.It Va l_next 124The next 125.Vt Link_map 126structure on the link-map list. 127.It Va l_prev 128The previous 129.Vt Link_map 130structure on the link-map list. 131.El 132.It Dv RTLD_DI_SERINFO 133Retrieve the library search paths associated with the given 134.Fa handle 135argument. 136The 137.Fa p 138argument should point to 139.Vt Dl_serinfo 140structure buffer 141.Pq Fa "Dl_serinfo *p" . 142The 143.Vt Dl_serinfo 144structure must be initialized first with the 145.Dv RTLD_DI_SERINFOSIZE 146request. 147.Pp 148The returned 149.Vt Dl_serinfo 150structure contains 151.Va dls_cnt 152.Vt Dl_serpath 153entries. 154Each entry's 155.Va dlp_name 156field points to the search path. 157The corresponding 158.Va dlp_info 159field contains one of more flags indicating the origin of the path (see the 160.Dv LA_SER_* 161flags defined in the 162.In link.h 163header file). 164See 165.Sx EXAMPLES , 166example 2, for a usage example. 167.It Dv RTLD_DI_SERINFOSIZE 168Initialize a 169.Vt Dl_serinfo 170structure for use in a 171.Dv RTLD_DI_SERINFO 172request. 173Both the 174.Va dls_cnt 175and 176.Va dls_size 177fields are returned to indicate the number of search paths applicable 178to the handle, and the total size of a 179.Vt Dl_serinfo 180buffer required to hold 181.Va dls_cnt 182.Vt Dl_serpath 183entries and the associated search path strings. 184See 185.Sx EXAMPLES , 186example 2, for a usage example. 187.It Va RTLD_DI_ORIGIN 188Retrieve the origin of the dynamic object associated with the handle. 189On successful return, 190.Fa p 191argument is filled with the 192.Vt char 193pointer 194.Pq Fa "char *p" . 195.El 196.Sh EXAMPLES 197Example 1: Using 198.Fn dlinfo 199to retrieve 200.Vt Link_map 201structure. 202.Pp 203The following example shows how dynamic library can detect the list 204of shared libraries loaded after caller's one. 205For simplicity, error checking has been omitted. 206.Bd -literal -offset indent 207Link_map *map; 208 209dlinfo(RTLD_SELF, RTLD_DI_LINKMAP, &map); 210 211while (map != NULL) { 212 printf("%p: %s\\n", map->l_addr, map->l_name); 213 map = map->l_next; 214} 215.Ed 216.Pp 217Example 2: Using 218.Fn dlinfo 219to retrieve the library search paths. 220.Pp 221The following example shows how a dynamic object can inspect the library 222search paths that would be used to locate a simple filename with 223.Xr dlopen 3 . 224For simplicity, error checking has been omitted. 225.Bd -literal -offset indent 226Dl_serinfo _info, *info = &_info; 227Dl_serpath *path; 228unsigned int cnt; 229 230/* determine search path count and required buffer size */ 231dlinfo(RTLD_SELF, RTLD_DI_SERINFOSIZE, (void *)info); 232 233/* allocate new buffer and initialize */ 234info = malloc(_info.dls_size); 235info->dls_size = _info.dls_size; 236info->dls_cnt = _info.dls_cnt; 237 238/* obtain sarch path information */ 239dlinfo(RTLD_SELF, RTLD_DI_SERINFO, (void *)info); 240 241path = &info->dls_serpath[0]; 242 243for (cnt = 1; cnt <= info->dls_cnt; cnt++, path++) { 244 (void) printf("%2d: %s\\n", cnt, path->dls_name); 245} 246.Ed 247.Sh RETURN VALUES 248The 249.Fn dlinfo 250function returns 0 on success, or \-1 if an error occurred. 251Whenever an error has been detected, a message detailing it can 252be retrieved via a call to 253.Xr dlerror 3 . 254.Sh SEE ALSO 255.Xr rtld 1 , 256.Xr dladdr 3 , 257.Xr dlopen 3 , 258.Xr dlsym 3 259.Sh HISTORY 260The 261.Fn dlinfo 262function first appeared in the Solaris operating system. 263In 264.Fx , 265it first appeared in 266.Fx 4.8 . 267.Sh AUTHORS 268.An -nosplit 269The 270.Fx 271implementation of the 272.Fn dlinfo 273function was originally written by 274.An Alexey Zelkin 275.Aq phantom@FreeBSD.org 276and later extended and improved by 277.An Alexander Kabaev 278.Aq kan@FreeBSD.org . 279.Pp 280The manual page for this function was written by 281.An Alexey Zelkin 282.Aq phantom@FreeBSD.org . 283