FreeBSD manual
download PDF document: gelf_update_ehdr.3.pdf
GELF_UPDATE_EHDR(3) FreeBSD Library Functions Manual GELF_UPDATE_EHDR(3)
NAME
gelf_update_ehdr, gelf_update_phdr, gelf_update_shdr - update underlying
ELF data structures
LIBRARY
ELF Access Library (libelf, -lelf)
SYNOPSIS
#include <gelf.h>
int
gelf_update_ehdr(Elf *elf, GElf_Ehdr *ehdr);
int
gelf_update_phdr(Elf *elf, int ndx, GElf_Phdr *phdr);
int
gelf_update_shdr(Elf_Scn *scn, GElf_Shdr *shdr);
DESCRIPTION
These functions are used to update ELF data structures on the underlying
ELF descriptor. Class-dependent data structures in the underlying ELF
descriptor are updated using the data in the class-independent GElf
descriptors and the underlying ELF data structures are marked "dirty".
The conversion process signals an error if the values being copied to the
target ELF data structure would exceed representation limits. GElf
descriptors are described in gelf(3).
Function gelf_update_ehdr() updates the ELF Executable Header with the
values in the class-independent executable header ehdr.
Function gelf_update_phdr() updates the ELF Program Header structure at
index ndx with the values in the class-independent program header phdr.
Function gelf_update_shdr() updates the ELF Section Header structure
associated with section descriptor scn with the values in argument shdr.
RETURN VALUES
These functions return a non-zero integer on success, or zero in case of
an error.
ERRORS
These functions may fail with the following errors:
[ELF_E_ARGUMENT] Arguments elf, ehdr, phdr, scn, or shdr were NULL.
[ELF_E_ARGUMENT] Argument elf was not a descriptor for an ELF object.
[ELF_E_ARGUMENT] Argument elf had an unsupported ELF class.
[ELF_E_ARGUMENT] Argument ndx exceeded the number of entries in the
program header table.
[ELF_E_ARGUMENT] Section descriptor scn was not associated with an ELF
descriptor.
[ELF_E_MODE] ELF descriptor elf was not opened for writing or
FreeBSD 14.2-RELEASE August 27, 2006 FreeBSD 14.2-RELEASE