uselib(2)


NAME

   uselib - load shared library

SYNOPSIS

   #include <unistd.h>

   int uselib(const char *library);

   Note:  No declaration of this system call is provided in glibc headers;
   see NOTES.

DESCRIPTION

   The system call uselib() serves to load a shared library to be used  by
   the  calling  process.   It  is given a pathname.  The address where to
   load is found  in  the  library  itself.   The  library  can  have  any
   recognized binary format.

RETURN VALUE

   On  success,  zero is returned.  On error, -1 is returned, and errno is
   set appropriately.

ERRORS

   In addition to all of the error codes returned by open(2) and  mmap(2),
   the following may also be returned:

   EACCES The  library  specified by library does not have read or execute
          permission, or the caller does not have  search  permission  for
          one   of   the  directories  in  the  path  prefix.   (See  also
          path_resolution(7).)

   ENFILE The system-wide limit on the total number of open files has been
          reached.

   ENOEXEC
          The  file  specified  by library is not an executable of a known
          type; for example, it does not have the correct magic numbers.

CONFORMING TO

   uselib() is Linux-specific, and should not be used in programs intended
   to be portable.

NOTES

   This obsolete system call is not supported by glibc.  No declaration is
   provided in glibc headers, but,  through  a  quirk  of  history,  glibc
   versions   before  2.23  did  export  an  ABI  for  this  system  call.
   Therefore, in order to employ this system call, it  was  sufficient  to
   manually  declare  the interface in your code; alternatively, you could
   invoke the system call using syscall(2).

   In ancient  libc  versions,  uselib()  was  used  to  load  the  shared
   libraries with names found in an array of names in the binary.

   Since  libc  4.3.2,  startup  code  tries  to  prefix  these names with
   "/usr/lib", "/lib" and "" before giving up.  In libc  4.3.4  and  later
   these names are looked for in the directories found in LD_LIBRARY_PATH,
   and if not found there, prefixes "/usr/lib", "/lib" and "/" are tried.

   From libc 4.4.4 on only the library "/lib/ld.so"  is  loaded,  so  that
   this  dynamic  library  can  load the remaining libraries needed (again
   using this call).  This is also the state of affairs in libc5.

   glibc2 does not use this call.

   Since Linux 3.15, this system call is available only when the kernel is
   configured with the CONFIG_USELIB option.

SEE ALSO

   ar(1),    gcc(1),   ld(1),   ldd(1),   mmap(2),   open(2),   dlopen(3),
   capabilities(7), ld.so(8)

COLOPHON

   This page is part of release 4.09 of the Linux  man-pages  project.   A
   description  of  the project, information about reporting bugs, and the
   latest    version    of    this    page,    can     be     found     at
   https://www.kernel.org/doc/man-pages/.


More Linux Commands

manpages/SDL_VideoDriverName.3.html
SDL_VideoDriverName(3) - Obtain the name of the video driver
The buffer pointed to by namebuf is filled up to a maximum of maxlen characters (include the NULL terminator) with the name of the initialised video driver. The

manpages/find_key_by_type_and_name.3.html
find_key_by_type_and_name(3) Find a key by type and name....
find_key_by_type_and_name() searches for a key with the given type and exact description, firstly in the thread, process and session keyrings to which a process

manpages/IsCursorKey.3.html
IsCursorKey(3) - keysym classification macros (Man Page)....
The IsCursorKey macro returns True if the specified KeySym is a cursor key. The IsFunctionKey macro returns True if the KeySym is a function key. The IsKeypadKe

manpages/pfbtops.1.html
pfbtops(1) - translate a PostScript font in .pfb format to A
pfbtops translates a PostScript font in .pfb format to ASCII, splitting overlong lines in text packets into smaller chunks. If pfb_file is omitted the pfb file

manpages/bootchart.conf.5.html
bootchart.conf(5) Boot performance analysis graphing tool co
When starting, systemd-bootchart will read the configuration file bootchart.conf. This configuration file determines logging parameters and graph output. OPTION

manpages/ldap_dn2dcedn.3.html
ldap_dn2dcedn(3) - LDAP DN handling routines (Man Page).....
These routines allow LDAP entry names (Distinguished Names, or DNs) to be obtained, parsed, converted to a user-friendly form, and tested. A DN has the form des

manpages/XkbKeySymsPtr.3.html
XkbKeySymsPtr(3) - Returns the pointer to the two-dimensiona
XkbKeySymsPtr.3 - The key width and number of groups associated with a key are used to form a small two-dimensional array of KeySyms for a key. This array may b

manpages/Encode::Alias.3pm.html
Encode::Alias(3pm) - alias definitions to encodings.........
Allows newName to be used as an alias for ENCODING . ENCODING may be either the name of an encoding or an encoding object (as described in Encode). Currently th

manpages/XSetClipRectangles.3.html
XSetClipRectangles(3) - GC convenience routines (Man Page)
The XSetClipOrigin function sets the clip origin in the specified GC. The clip-mask origin is interpreted relative to the origin of whatever destination drawabl

manpages/Tcl_ExprObj.3.html
Tcl_ExprObj(3) - evaluate an expression - Linux manual page
These four procedures all evaluate an expression, returning the result in one of four different forms. The expression is given by the objPtr argument, and it ca

manpages/splashy-theme.xml.5.html
splashy-theme.xml(5) - a user-mode, POSIX and LSB compliant,
/etc/splashy/themes/*/theme.xml describes the themes behaviour The theme on which the file will have effect is the one which is contained in the same directory

manpages/mbrlen.3.html
mbrlen(3) - determine number of bytes in next multibyte char
The mbrlen() function inspects at most n bytes of the multibyte string starting at s and extracts the next complete multibyte character. It updates the shift st





We can't live, work or learn in freedom unless the software we use is free.