ELF_CNTL(3ELF) ELF Library Functions ELF_CNTL(3ELF)
NAME
elf_cntl - control an elf file descriptor
SYNOPSIS
cc [
flag ... ]
file ...
-lelf [
library ... ]
#include <libelf.h>
int elf_cntl(
Elf *elf,
Elf_Cmd cmd);
DESCRIPTION
elf_cntl() instructs the library to modify its behavior with respect
to an
ELF descriptor,
elf. As
elf_begin(3ELF) describes, an
ELF descriptor can have multiple activations, and multiple
ELF descriptors may share a single file descriptor. Generally,
elf_cntl() commands apply to all activations of
elf. Moreover, if the
ELF descriptor is associated with an archive file, descriptors for
members within the archive will also be affected as described below.
Unless stated otherwise, operations on archive members do not affect
the descriptor for the containing archive.
The
cmd argument tells what actions to take and may have the
following values:
ELF_C_FDDONE This value tells the library not to use the file
descriptor associated with
elf. A program should use
this command when it has requested all the
information it cares to use and wishes to avoid the
overhead of reading the rest of the file. The memory
for all completed operations remains valid, but later
file operations, such as the initial
elf_getdata() for a section, will fail if the data are not in
memory already.
ELF_C_FDREAD This command is similar to
ELF_C_FDDONE, except it
forces the library to read the rest of the file. A
program should use this command when it must close
the file descriptor but has not yet read everything
it needs from the file. After
elf_cntl() completes
the
ELF_C_FDREAD command, future operations, such as
elf_getdata(), will use the memory version of the
file without needing to use the file descriptor.
If
elf_cntl() succeeds, it returns
0. Otherwise
elf was
NULL or an
error occurred, and the function returns
-1.
ATTRIBUTES
See
attributes(7) for descriptions of the following attributes:
+--------------------+-----------------+
| ATTRIBUTE TYPE | ATTRIBUTE VALUE |
+--------------------+-----------------+
|Interface Stability | Stable |
+--------------------+-----------------+
|MT-Level | MT-Safe |
+--------------------+-----------------+
SEE ALSO
elf(3ELF),
elf_begin(3ELF),
elf_getdata(3ELF),
elf_rawfile(3ELF),
libelf(3LIB),
attributes(7)NOTES
If the program wishes to use the ``raw'' operations (see
elf_rawdata(), which
elf_getdata(3ELF) describes, and
elf_rawfile(3ELF)) after disabling the file descriptor with
ELF_C_FDDONE or
ELF_C_FDREAD, it must execute the raw operations
explicitly beforehand. Otherwise, the raw file operations will fail.
Calling
elf_rawfile() makes the entire image available, thus
supporting subsequent
elf_rawdata() calls.
July 11, 2001 ELF_CNTL(3ELF)