Provided by: manpages-posix-dev_2.16-1_all bug

NAME

       dlsym - obtain the address of a symbol from a dlopen object

SYNOPSIS

       #include <dlfcn.h>

       void *dlsym(void *restrict handle, const char *restrict name);

DESCRIPTION

       The  dlsym()  function  shall  obtain  the  address  of a symbol defined within an object made accessible
       through a dlopen() call. The handle argument is the value returned from a call to dlopen() (and which has
       not since been released via a call to dlclose()), and name is the symbol's name as a character string.

       The dlsym() function shall search for the named symbol in all objects loaded automatically as a result of
       loading the object referenced by handle (see dlopen() ). Load ordering is used in dlsym() operations upon
       the global symbol object. The symbol resolution algorithm used shall be dependency order as described  in
       dlopen() .

       The RTLD_DEFAULT and RTLD_NEXT flags are reserved for future use.

RETURN VALUE

       If  handle  does  not  refer to a valid object opened by dlopen(), or if the named symbol cannot be found
       within any of the objects associated with handle, dlsym() shall return  NULL.  More  detailed  diagnostic
       information shall be available through dlerror() .

ERRORS

       No errors are defined.

       The following sections are informative.

EXAMPLES

       The  following  example  shows  how  dlopen()  and  dlsym() can be used to access either function or data
       objects. For simplicity, error checking has been omitted.

              void    *handle;
              int     *iptr, (*fptr)(int);

              /* open the needed object */
              handle = dlopen("/usr/home/me/libfoo.so", RTLD_LOCAL | RTLD_LAZY);

              /* find the address of function and data objects */
              *(void **)(&fptr) = dlsym(handle, "my_function");
              iptr = (int *)dlsym(handle, "my_object");

              /* invoke function, passing value of integer as a parameter */
              (*fptr)(*iptr);

APPLICATION USAGE

       Special purpose values for handle are reserved for future use.  These values and their meanings are:

       RTLD_DEFAULT
              The symbol lookup happens in the normal global scope; that is, a search for a  symbol  using  this
              handle would find the same definition as a direct use of this symbol in the program code.

       RTLD_NEXT
              Specifies  the  next  object  after  this  one  that  defines name.  This one refers to the object
              containing the invocation of dlsym(). The next object is the one found upon the application  of  a
              load  order  symbol  resolution algorithm (see dlopen() ). The next object is either one of global
              scope (because it was introduced as part of the original process image or  because  it  was  added
              with  a  dlopen()  operation including the RTLD_GLOBAL flag), or is an object that was included in
              the same dlopen() operation that loaded this one.

       The RTLD_NEXT flag is useful to navigate an intentionally created hierarchy of  multiply-defined  symbols
       created  through  interposition. For example, if a program wished to create an implementation of malloc()
       that embedded some statistics gathering about memory allocations, such an implementation  could  use  the
       real  malloc()  definition  to perform the memory allocation-and itself only embed the necessary logic to
       implement the statistics gathering function.

RATIONALE

       The ISO C standard does not require that pointers to functions can be cast back and forth to pointers  to
       data.  Indeed,  the ISO C standard does not require that an object of type void * can hold a pointer to a
       function. Implementations supporting the XSI extension, however, do require that an object of type void *
       can hold a pointer to a function. The result of converting a pointer to a  function  into  a  pointer  to
       another  data  type  (except  void  *) is still undefined, however. Note that compilers conforming to the
       ISO C standard are required to generate a warning if a conversion from a void *  pointer  to  a  function
       pointer is attempted as in:

              fptr = (int (*)(int))dlsym(handle, "my_function");

       Due  to  the  problem  noted  here,  a  future  version  may either add a new function to return function
       pointers, or the current interface may be deprecated in favor of two new functions: one that returns data
       pointers and the other that returns function pointers.

FUTURE DIRECTIONS

       None.

SEE ALSO

       dlclose() , dlerror() , dlopen() , the Base Definitions volume of IEEE Std 1003.1-2001, <dlfcn.h>

COPYRIGHT

       Portions of this text are reprinted and reproduced in electronic form from IEEE Std 1003.1, 2003 Edition,
       Standard for Information Technology -- Portable Operating System Interface (POSIX), The Open  Group  Base
       Specifications Issue 6, Copyright (C) 2001-2003 by the Institute of Electrical and Electronics Engineers,
       Inc  and  The  Open Group. In the event of any discrepancy between this version and the original IEEE and
       The Open Group Standard, the original IEEE and The Open Group  Standard  is  the  referee  document.  The
       original Standard can be obtained online at http://www.opengroup.org/unix/online.html .

IEEE/The Open Group                                   2003                                              DLSYM(P)