Blame libelf/libelf.h

Packit Service 97d2fb
/* Interface for libelf.
Packit Service 97d2fb
   Copyright (C) 1998-2010, 2015 Red Hat, Inc.
Packit Service 97d2fb
   This file is part of elfutils.
Packit Service 97d2fb
Packit Service 97d2fb
   This file is free software; you can redistribute it and/or modify
Packit Service 97d2fb
   it under the terms of either
Packit Service 97d2fb
Packit Service 97d2fb
     * the GNU Lesser General Public License as published by the Free
Packit Service 97d2fb
       Software Foundation; either version 3 of the License, or (at
Packit Service 97d2fb
       your option) any later version
Packit Service 97d2fb
Packit Service 97d2fb
   or
Packit Service 97d2fb
Packit Service 97d2fb
     * the GNU General Public License as published by the Free
Packit Service 97d2fb
       Software Foundation; either version 2 of the License, or (at
Packit Service 97d2fb
       your option) any later version
Packit Service 97d2fb
Packit Service 97d2fb
   or both in parallel, as here.
Packit Service 97d2fb
Packit Service 97d2fb
   elfutils is distributed in the hope that it will be useful, but
Packit Service 97d2fb
   WITHOUT ANY WARRANTY; without even the implied warranty of
Packit Service 97d2fb
   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
Packit Service 97d2fb
   General Public License for more details.
Packit Service 97d2fb
Packit Service 97d2fb
   You should have received copies of the GNU General Public License and
Packit Service 97d2fb
   the GNU Lesser General Public License along with this program.  If
Packit Service 97d2fb
   not, see <http://www.gnu.org/licenses/>.  */
Packit Service 97d2fb
Packit Service 97d2fb
#ifndef _LIBELF_H
Packit Service 97d2fb
#define _LIBELF_H 1
Packit Service 97d2fb
Packit Service 97d2fb
#include <stdint.h>
Packit Service 97d2fb
#include <sys/types.h>
Packit Service 97d2fb
Packit Service 97d2fb
/* Get the ELF types.  */
Packit Service 97d2fb
#include <elf.h>
Packit Service 97d2fb
Packit Service 97d2fb
#ifndef SHF_COMPRESSED
Packit Service 97d2fb
 /* Older glibc elf.h might not yet define the ELF compression types.  */
Packit Service 97d2fb
 #define SHF_COMPRESSED      (1 << 11)  /* Section with compressed data. */
Packit Service 97d2fb
Packit Service 97d2fb
 /* Section compression header.  Used when SHF_COMPRESSED is set.  */
Packit Service 97d2fb
Packit Service 97d2fb
 typedef struct
Packit Service 97d2fb
 {
Packit Service 97d2fb
   Elf32_Word   ch_type;        /* Compression format.  */
Packit Service 97d2fb
   Elf32_Word   ch_size;        /* Uncompressed data size.  */
Packit Service 97d2fb
   Elf32_Word   ch_addralign;   /* Uncompressed data alignment.  */
Packit Service 97d2fb
 } Elf32_Chdr;
Packit Service 97d2fb
Packit Service 97d2fb
 typedef struct
Packit Service 97d2fb
 {
Packit Service 97d2fb
   Elf64_Word   ch_type;        /* Compression format.  */
Packit Service 97d2fb
   Elf64_Word   ch_reserved;
Packit Service 97d2fb
   Elf64_Xword  ch_size;        /* Uncompressed data size.  */
Packit Service 97d2fb
   Elf64_Xword  ch_addralign;   /* Uncompressed data alignment.  */
Packit Service 97d2fb
 } Elf64_Chdr;
Packit Service 97d2fb
Packit Service 97d2fb
 /* Legal values for ch_type (compression algorithm).  */
Packit Service 97d2fb
 #define ELFCOMPRESS_ZLIB       1          /* ZLIB/DEFLATE algorithm.  */
Packit Service 97d2fb
 #define ELFCOMPRESS_LOOS       0x60000000 /* Start of OS-specific.  */
Packit Service 97d2fb
 #define ELFCOMPRESS_HIOS       0x6fffffff /* End of OS-specific.  */
Packit Service 97d2fb
 #define ELFCOMPRESS_LOPROC     0x70000000 /* Start of processor-specific.  */
Packit Service 97d2fb
 #define ELFCOMPRESS_HIPROC     0x7fffffff /* End of processor-specific.  */
Packit Service 97d2fb
#endif
Packit Service 97d2fb
Packit Service 97d2fb
#if __GNUC__ > 3 || (__GNUC__ == 3 && __GNUC_MINOR__ >= 3)
Packit Service 97d2fb
# define __nonnull_attribute__(...) __attribute__ ((__nonnull__ (__VA_ARGS__)))
Packit Service 97d2fb
# define __deprecated_attribute__ __attribute__ ((__deprecated__))
Packit Service 97d2fb
# define __pure_attribute__ __attribute__ ((__pure__))
Packit Service 97d2fb
# define __const_attribute__ __attribute__ ((__const__))
Packit Service 97d2fb
#else
Packit Service 97d2fb
# define __nonnull_attribute__(...)
Packit Service 97d2fb
# define __deprecated_attribute__
Packit Service 97d2fb
# define __pure_attribute__
Packit Service 97d2fb
# define __const_attribute__
Packit Service 97d2fb
#endif
Packit Service 97d2fb
Packit Service 97d2fb
#if __GNUC__ < 4
Packit Service 97d2fb
#define __noreturn_attribute__
Packit Service 97d2fb
#else
Packit Service 97d2fb
#define __noreturn_attribute__ __attribute__ ((noreturn))
Packit Service 97d2fb
#endif
Packit Service 97d2fb
Packit Service 97d2fb
#ifdef __GNUC_STDC_INLINE__
Packit Service 97d2fb
# define __libdw_extern_inline extern __inline __attribute__ ((__gnu_inline__))
Packit Service 97d2fb
#else
Packit Service 97d2fb
# define __libdw_extern_inline extern __inline
Packit Service 97d2fb
#endif
Packit Service 97d2fb
Packit Service 97d2fb
/* Known translation types.  */
Packit Service 97d2fb
typedef enum
Packit Service 97d2fb
{
Packit Service 97d2fb
  ELF_T_BYTE,                   /* unsigned char */
Packit Service 97d2fb
  ELF_T_ADDR,                   /* Elf32_Addr, Elf64_Addr, ... */
Packit Service 97d2fb
  ELF_T_DYN,                    /* Dynamic section record.  */
Packit Service 97d2fb
  ELF_T_EHDR,                   /* ELF header.  */
Packit Service 97d2fb
  ELF_T_HALF,                   /* Elf32_Half, Elf64_Half, ... */
Packit Service 97d2fb
  ELF_T_OFF,                    /* Elf32_Off, Elf64_Off, ... */
Packit Service 97d2fb
  ELF_T_PHDR,                   /* Program header.  */
Packit Service 97d2fb
  ELF_T_RELA,                   /* Relocation entry with addend.  */
Packit Service 97d2fb
  ELF_T_REL,                    /* Relocation entry.  */
Packit Service 97d2fb
  ELF_T_SHDR,                   /* Section header.  */
Packit Service 97d2fb
  ELF_T_SWORD,                  /* Elf32_Sword, Elf64_Sword, ... */
Packit Service 97d2fb
  ELF_T_SYM,                    /* Symbol record.  */
Packit Service 97d2fb
  ELF_T_WORD,                   /* Elf32_Word, Elf64_Word, ... */
Packit Service 97d2fb
  ELF_T_XWORD,                  /* Elf32_Xword, Elf64_Xword, ... */
Packit Service 97d2fb
  ELF_T_SXWORD,                 /* Elf32_Sxword, Elf64_Sxword, ... */
Packit Service 97d2fb
  ELF_T_VDEF,                   /* Elf32_Verdef, Elf64_Verdef, ... */
Packit Service 97d2fb
  ELF_T_VDAUX,                  /* Elf32_Verdaux, Elf64_Verdaux, ... */
Packit Service 97d2fb
  ELF_T_VNEED,                  /* Elf32_Verneed, Elf64_Verneed, ... */
Packit Service 97d2fb
  ELF_T_VNAUX,                  /* Elf32_Vernaux, Elf64_Vernaux, ... */
Packit Service 97d2fb
  ELF_T_NHDR,                   /* Elf32_Nhdr, Elf64_Nhdr, ... */
Packit Service 97d2fb
  ELF_T_SYMINFO,		/* Elf32_Syminfo, Elf64_Syminfo, ... */
Packit Service 97d2fb
  ELF_T_MOVE,			/* Elf32_Move, Elf64_Move, ... */
Packit Service 97d2fb
  ELF_T_LIB,			/* Elf32_Lib, Elf64_Lib, ... */
Packit Service 97d2fb
  ELF_T_GNUHASH,		/* GNU-style hash section.  */
Packit Service 97d2fb
  ELF_T_AUXV,			/* Elf32_auxv_t, Elf64_auxv_t, ... */
Packit Service 97d2fb
  ELF_T_CHDR,			/* Compressed, Elf32_Chdr, Elf64_Chdr, ... */
Packit Service 97d2fb
  ELF_T_NHDR8,			/* Special GNU Properties note.  Same as Nhdr,
Packit Service 97d2fb
				   except padding.  */
Packit Service 97d2fb
  /* Keep this the last entry.  */
Packit Service 97d2fb
  ELF_T_NUM
Packit Service 97d2fb
} Elf_Type;
Packit Service 97d2fb
Packit Service 97d2fb
/* Descriptor for data to be converted to or from memory format.  */
Packit Service 97d2fb
typedef struct
Packit Service 97d2fb
{
Packit Service 97d2fb
  void *d_buf;			/* Pointer to the actual data.  */
Packit Service 97d2fb
  Elf_Type d_type;		/* Type of this piece of data.  */
Packit Service 97d2fb
  unsigned int d_version;	/* ELF version.  */
Packit Service 97d2fb
  size_t d_size;		/* Size in bytes.  */
Packit Service 97d2fb
  int64_t d_off;		/* Offset into section.  */
Packit Service 97d2fb
  size_t d_align;		/* Alignment in section.  */
Packit Service 97d2fb
} Elf_Data;
Packit Service 97d2fb
Packit Service 97d2fb
Packit Service 97d2fb
/* Commands for `...'.  */
Packit Service 97d2fb
typedef enum
Packit Service 97d2fb
{
Packit Service 97d2fb
  ELF_C_NULL,			/* Nothing, terminate, or compute only.  */
Packit Service 97d2fb
  ELF_C_READ,			/* Read .. */
Packit Service 97d2fb
  ELF_C_RDWR,			/* Read and write .. */
Packit Service 97d2fb
  ELF_C_WRITE,			/* Write .. */
Packit Service 97d2fb
  ELF_C_CLR,			/* Clear flag.  */
Packit Service 97d2fb
  ELF_C_SET,			/* Set flag.  */
Packit Service 97d2fb
  ELF_C_FDDONE,			/* Signal that file descriptor will not be
Packit Service 97d2fb
				   used anymore.  */
Packit Service 97d2fb
  ELF_C_FDREAD,			/* Read rest of data so that file descriptor
Packit Service 97d2fb
				   is not used anymore.  */
Packit Service 97d2fb
  /* The following are extensions.  */
Packit Service 97d2fb
  ELF_C_READ_MMAP,		/* Read, but mmap the file if possible.  */
Packit Service 97d2fb
  ELF_C_RDWR_MMAP,		/* Read and write, with mmap.  */
Packit Service 97d2fb
  ELF_C_WRITE_MMAP,		/* Write, with mmap.  */
Packit Service 97d2fb
  ELF_C_READ_MMAP_PRIVATE,	/* Read, but memory is writable, results are
Packit Service 97d2fb
				   not written to the file.  */
Packit Service 97d2fb
  ELF_C_EMPTY,			/* Copy basic file data but not the content. */
Packit Service 97d2fb
  /* Keep this the last entry.  */
Packit Service 97d2fb
  ELF_C_NUM
Packit Service 97d2fb
} Elf_Cmd;
Packit Service 97d2fb
Packit Service 97d2fb
Packit Service 97d2fb
/* Flags for the ELF structures.  */
Packit Service 97d2fb
enum
Packit Service 97d2fb
{
Packit Service 97d2fb
  ELF_F_DIRTY = 0x1,
Packit Service 97d2fb
#define ELF_F_DIRTY		ELF_F_DIRTY
Packit Service 97d2fb
  ELF_F_LAYOUT = 0x4,
Packit Service 97d2fb
#define ELF_F_LAYOUT		ELF_F_LAYOUT
Packit Service 97d2fb
  ELF_F_PERMISSIVE = 0x8
Packit Service 97d2fb
#define ELF_F_PERMISSIVE	ELF_F_PERMISSIVE
Packit Service 97d2fb
};
Packit Service 97d2fb
Packit Service 97d2fb
/* Flags for elf_compress[_gnu].  */
Packit Service 97d2fb
enum
Packit Service 97d2fb
{
Packit Service 97d2fb
  ELF_CHF_FORCE = 0x1
Packit Service 97d2fb
#define ELF_CHF_FORCE ELF_CHF_FORCE
Packit Service 97d2fb
};
Packit Service 97d2fb
Packit Service 97d2fb
/* Identification values for recognized object files.  */
Packit Service 97d2fb
typedef enum
Packit Service 97d2fb
{
Packit Service 97d2fb
  ELF_K_NONE,			/* Unknown.  */
Packit Service 97d2fb
  ELF_K_AR,			/* Archive.  */
Packit Service 97d2fb
  ELF_K_COFF,			/* Stupid old COFF.  */
Packit Service 97d2fb
  ELF_K_ELF,			/* ELF file.  */
Packit Service 97d2fb
  /* Keep this the last entry.  */
Packit Service 97d2fb
  ELF_K_NUM
Packit Service 97d2fb
} Elf_Kind;
Packit Service 97d2fb
Packit Service 97d2fb
Packit Service 97d2fb
/* Archive member header.  */
Packit Service 97d2fb
typedef struct
Packit Service 97d2fb
{
Packit Service 97d2fb
  char *ar_name;		/* Name of archive member.  */
Packit Service 97d2fb
  time_t ar_date;		/* File date.  */
Packit Service 97d2fb
  uid_t ar_uid;			/* User ID.  */
Packit Service 97d2fb
  gid_t ar_gid;			/* Group ID.  */
Packit Service 97d2fb
  mode_t ar_mode;		/* File mode.  */
Packit Service 97d2fb
  int64_t ar_size;		/* File size.  */
Packit Service 97d2fb
  char *ar_rawname;		/* Original name of archive member.  */
Packit Service 97d2fb
} Elf_Arhdr;
Packit Service 97d2fb
Packit Service 97d2fb
Packit Service 97d2fb
/* Archive symbol table entry.  */
Packit Service 97d2fb
typedef struct
Packit Service 97d2fb
{
Packit Service 97d2fb
  char *as_name;		/* Symbol name.  */
Packit Service 97d2fb
  size_t as_off;		/* Offset for this file in the archive.  */
Packit Service 97d2fb
  unsigned long int as_hash;	/* Hash value of the name.  */
Packit Service 97d2fb
} Elf_Arsym;
Packit Service 97d2fb
Packit Service 97d2fb
Packit Service 97d2fb
/* Descriptor for the ELF file.  */
Packit Service 97d2fb
typedef struct Elf Elf;
Packit Service 97d2fb
Packit Service 97d2fb
/* Descriptor for ELF file section.  */
Packit Service 97d2fb
typedef struct Elf_Scn Elf_Scn;
Packit Service 97d2fb
Packit Service 97d2fb
Packit Service 97d2fb
#ifdef __cplusplus
Packit Service 97d2fb
extern "C" {
Packit Service 97d2fb
#endif
Packit Service 97d2fb
Packit Service 97d2fb
/* Return descriptor for ELF file to work according to CMD.  */
Packit Service 97d2fb
extern Elf *elf_begin (int __fildes, Elf_Cmd __cmd, Elf *__ref);
Packit Service 97d2fb
Packit Service 97d2fb
/* Create a clone of an existing ELF descriptor.  */
Packit Service 97d2fb
  extern Elf *elf_clone (Elf *__elf, Elf_Cmd __cmd);
Packit Service 97d2fb
Packit Service 97d2fb
/* Create descriptor for memory region.  */
Packit Service 97d2fb
extern Elf *elf_memory (char *__image, size_t __size);
Packit Service 97d2fb
Packit Service 97d2fb
/* Advance archive descriptor to next element.  */
Packit Service 97d2fb
extern Elf_Cmd elf_next (Elf *__elf);
Packit Service 97d2fb
Packit Service 97d2fb
/* Free resources allocated for ELF.  */
Packit Service 97d2fb
extern int elf_end (Elf *__elf);
Packit Service 97d2fb
Packit Service 97d2fb
/* Update ELF descriptor and write file to disk.  */
Packit Service 97d2fb
extern int64_t elf_update (Elf *__elf, Elf_Cmd __cmd);
Packit Service 97d2fb
Packit Service 97d2fb
/* Determine what kind of file is associated with ELF.  */
Packit Service 97d2fb
extern Elf_Kind elf_kind (Elf *__elf) __pure_attribute__;
Packit Service 97d2fb
Packit Service 97d2fb
/* Get the base offset for an object file.  */
Packit Service 97d2fb
extern int64_t elf_getbase (Elf *__elf);
Packit Service 97d2fb
Packit Service 97d2fb
Packit Service 97d2fb
/* Retrieve file identification data.  */
Packit Service 97d2fb
extern char *elf_getident (Elf *__elf, size_t *__nbytes);
Packit Service 97d2fb
Packit Service 97d2fb
/* Retrieve class-dependent object file header.  */
Packit Service 97d2fb
extern Elf32_Ehdr *elf32_getehdr (Elf *__elf);
Packit Service 97d2fb
/* Similar but this time the binary calls is ELFCLASS64.  */
Packit Service 97d2fb
extern Elf64_Ehdr *elf64_getehdr (Elf *__elf);
Packit Service 97d2fb
Packit Service 97d2fb
/* Create ELF header if none exists.  */
Packit Service 97d2fb
extern Elf32_Ehdr *elf32_newehdr (Elf *__elf);
Packit Service 97d2fb
/* Similar but this time the binary calls is ELFCLASS64.  */
Packit Service 97d2fb
extern Elf64_Ehdr *elf64_newehdr (Elf *__elf);
Packit Service 97d2fb
Packit Service 97d2fb
/* Get the number of program headers in the ELF file.  If the file uses
Packit Service 97d2fb
   more headers than can be represented in the e_phnum field of the ELF
Packit Service 97d2fb
   header the information from the sh_info field in the zeroth section
Packit Service 97d2fb
   header is used.  */
Packit Service 97d2fb
extern int elf_getphdrnum (Elf *__elf, size_t *__dst);
Packit Service 97d2fb
Packit Service 97d2fb
/* Retrieve class-dependent program header table.  */
Packit Service 97d2fb
extern Elf32_Phdr *elf32_getphdr (Elf *__elf);
Packit Service 97d2fb
/* Similar but this time the binary calls is ELFCLASS64.  */
Packit Service 97d2fb
extern Elf64_Phdr *elf64_getphdr (Elf *__elf);
Packit Service 97d2fb
Packit Service 97d2fb
/* Create ELF program header.  */
Packit Service 97d2fb
extern Elf32_Phdr *elf32_newphdr (Elf *__elf, size_t __cnt);
Packit Service 97d2fb
/* Similar but this time the binary calls is ELFCLASS64.  */
Packit Service 97d2fb
extern Elf64_Phdr *elf64_newphdr (Elf *__elf, size_t __cnt);
Packit Service 97d2fb
Packit Service 97d2fb
Packit Service 97d2fb
/* Get section at INDEX.  */
Packit Service 97d2fb
extern Elf_Scn *elf_getscn (Elf *__elf, size_t __index);
Packit Service 97d2fb
Packit Service 97d2fb
/* Get section at OFFSET.  */
Packit Service 97d2fb
extern Elf_Scn *elf32_offscn (Elf *__elf, Elf32_Off __offset);
Packit Service 97d2fb
/* Similar bug this time the binary calls is ELFCLASS64.  */
Packit Service 97d2fb
extern Elf_Scn *elf64_offscn (Elf *__elf, Elf64_Off __offset);
Packit Service 97d2fb
Packit Service 97d2fb
/* Get index of section.  */
Packit Service 97d2fb
extern size_t elf_ndxscn (Elf_Scn *__scn);
Packit Service 97d2fb
Packit Service 97d2fb
/* Get section with next section index.  */
Packit Service 97d2fb
extern Elf_Scn *elf_nextscn (Elf *__elf, Elf_Scn *__scn);
Packit Service 97d2fb
Packit Service 97d2fb
/* Create a new section and append it at the end of the table.  */
Packit Service 97d2fb
extern Elf_Scn *elf_newscn (Elf *__elf);
Packit Service 97d2fb
Packit Service 97d2fb
/* Get the section index of the extended section index table for the
Packit Service 97d2fb
   given symbol table.  */
Packit Service 97d2fb
extern int elf_scnshndx (Elf_Scn *__scn);
Packit Service 97d2fb
Packit Service 97d2fb
/* Get the number of sections in the ELF file.  If the file uses more
Packit Service 97d2fb
   sections than can be represented in the e_shnum field of the ELF
Packit Service 97d2fb
   header the information from the sh_size field in the zeroth section
Packit Service 97d2fb
   header is used.  */
Packit Service 97d2fb
extern int elf_getshdrnum (Elf *__elf, size_t *__dst);
Packit Service 97d2fb
/* Sun messed up the implementation of 'elf_getshnum' in their implementation.
Packit Service 97d2fb
   It was agreed to make the same functionality available under a different
Packit Service 97d2fb
   name and obsolete the old name.  */
Packit Service 97d2fb
extern int elf_getshnum (Elf *__elf, size_t *__dst)
Packit Service 97d2fb
     __deprecated_attribute__;
Packit Service 97d2fb
Packit Service 97d2fb
Packit Service 97d2fb
/* Get the section index of the section header string table in the ELF
Packit Service 97d2fb
   file.  If the index cannot be represented in the e_shstrndx field of
Packit Service 97d2fb
   the ELF header the information from the sh_link field in the zeroth
Packit Service 97d2fb
   section header is used.  */
Packit Service 97d2fb
extern int elf_getshdrstrndx (Elf *__elf, size_t *__dst);
Packit Service 97d2fb
/* Sun messed up the implementation of 'elf_getshstrndx' in their
Packit Service 97d2fb
   implementation.  It was agreed to make the same functionality available
Packit Service 97d2fb
   under a different name and obsolete the old name.  */
Packit Service 97d2fb
extern int elf_getshstrndx (Elf *__elf, size_t *__dst)
Packit Service 97d2fb
     __deprecated_attribute__;
Packit Service 97d2fb
Packit Service 97d2fb
Packit Service 97d2fb
/* Retrieve section header of ELFCLASS32 binary.  */
Packit Service 97d2fb
extern Elf32_Shdr *elf32_getshdr (Elf_Scn *__scn);
Packit Service 97d2fb
/* Similar for ELFCLASS64.  */
Packit Service 97d2fb
extern Elf64_Shdr *elf64_getshdr (Elf_Scn *__scn);
Packit Service 97d2fb
Packit Service 97d2fb
/* Returns compression header for a section if section data is
Packit Service 97d2fb
   compressed.  Returns NULL and sets elf_errno if the section isn't
Packit Service 97d2fb
   compressed or an error occurred.  */
Packit Service 97d2fb
extern Elf32_Chdr *elf32_getchdr (Elf_Scn *__scn);
Packit Service 97d2fb
extern Elf64_Chdr *elf64_getchdr (Elf_Scn *__scn);
Packit Service 97d2fb
Packit Service 97d2fb
/* Compress or decompress the data of a section and adjust the section
Packit Service 97d2fb
   header.
Packit Service 97d2fb
Packit Service 97d2fb
   elf_compress works by setting or clearing the SHF_COMPRESS flag
Packit Service 97d2fb
   from the section Shdr and will encode or decode a Elf32_Chdr or
Packit Service 97d2fb
   Elf64_Chdr at the start of the section data.  elf_compress_gnu will
Packit Service 97d2fb
   encode or decode any section, but is traditionally only used for
Packit Service 97d2fb
   sections that have a name starting with ".debug" when
Packit Service 97d2fb
   uncompressed or ".zdebug" when compressed and stores just the
Packit Service 97d2fb
   uncompressed size.  The GNU compression method is deprecated and
Packit Service 97d2fb
   should only be used for legacy support.
Packit Service 97d2fb
Packit Service 97d2fb
   elf_compress takes a compression type that should be either zero to
Packit Service 97d2fb
   decompress or an ELFCOMPRESS algorithm to use for compression.
Packit Service 97d2fb
   Currently only ELFCOMPRESS_ZLIB is supported.  elf_compress_gnu
Packit Service 97d2fb
   will compress in the traditional GNU compression format when
Packit Service 97d2fb
   compress is one and decompress the section data when compress is
Packit Service 97d2fb
   zero.
Packit Service 97d2fb
Packit Service 97d2fb
   The FLAGS argument can be zero or ELF_CHF_FORCE.  If FLAGS contains
Packit Service 97d2fb
   ELF_CHF_FORCE then it will always compress the section, even if
Packit Service 97d2fb
   that would not reduce the size of the data section (including the
Packit Service 97d2fb
   header).  Otherwise elf_compress and elf_compress_gnu will compress
Packit Service 97d2fb
   the section only if the total data size is reduced.
Packit Service 97d2fb
Packit Service 97d2fb
   On successful compression or decompression the function returns
Packit Service 97d2fb
   one.  If (not forced) compression is requested and the data section
Packit Service 97d2fb
   would not actually reduce in size, the section is not actually
Packit Service 97d2fb
   compressed and zero is returned.  Otherwise -1 is returned and
Packit Service 97d2fb
   elf_errno is set.
Packit Service 97d2fb
Packit Service 97d2fb
   It is an error to request compression for a section that already
Packit Service 97d2fb
   has SHF_COMPRESSED set, or (for elf_compress) to request
Packit Service 97d2fb
   decompression for an section that doesn't have SHF_COMPRESSED set.
Packit Service 97d2fb
   If a section has SHF_COMPRESSED set then calling elf_compress_gnu
Packit Service 97d2fb
   will result in an error.  The section has to be decompressed first
Packit Service 97d2fb
   using elf_compress.  Calling elf_compress on a section compressed
Packit Service 97d2fb
   with elf_compress_gnu is fine, but probably useless.
Packit Service 97d2fb
Packit Service 97d2fb
   It is always an error to call these functions on SHT_NOBITS
Packit Service 97d2fb
   sections or if the section has the SHF_ALLOC flag set.
Packit Service 97d2fb
   elf_compress_gnu will not check whether the section name starts
Packit Service 97d2fb
   with ".debug" or .zdebug".  It is the responsibilty of the caller
Packit Service 97d2fb
   to make sure the deprecated GNU compression method is only called
Packit Service 97d2fb
   on correctly named sections (and to change the name of the section
Packit Service 97d2fb
   when using elf_compress_gnu).
Packit Service 97d2fb
Packit Service 97d2fb
   All previous returned Shdrs and Elf_Data buffers are invalidated by
Packit Service 97d2fb
   this call and should no longer be accessed.
Packit Service 97d2fb
Packit Service 97d2fb
   Note that although this changes the header and data returned it
Packit Service 97d2fb
   doesn't mark the section as dirty.  To keep the changes when
Packit Service 97d2fb
   calling elf_update the section has to be flagged ELF_F_DIRTY.  */
Packit Service 97d2fb
extern int elf_compress (Elf_Scn *scn, int type, unsigned int flags);
Packit Service 97d2fb
extern int elf_compress_gnu (Elf_Scn *scn, int compress, unsigned int flags);
Packit Service 97d2fb
Packit Service 97d2fb
/* Set or clear flags for ELF file.  */
Packit Service 97d2fb
extern unsigned int elf_flagelf (Elf *__elf, Elf_Cmd __cmd,
Packit Service 97d2fb
				 unsigned int __flags);
Packit Service 97d2fb
/* Similarly for the ELF header.  */
Packit Service 97d2fb
extern unsigned int elf_flagehdr (Elf *__elf, Elf_Cmd __cmd,
Packit Service 97d2fb
				  unsigned int __flags);
Packit Service 97d2fb
/* Similarly for the ELF program header.  */
Packit Service 97d2fb
extern unsigned int elf_flagphdr (Elf *__elf, Elf_Cmd __cmd,
Packit Service 97d2fb
				  unsigned int __flags);
Packit Service 97d2fb
/* Similarly for the given ELF section.  */
Packit Service 97d2fb
extern unsigned int elf_flagscn (Elf_Scn *__scn, Elf_Cmd __cmd,
Packit Service 97d2fb
				 unsigned int __flags);
Packit Service 97d2fb
/* Similarly for the given ELF data.  */
Packit Service 97d2fb
extern unsigned int elf_flagdata (Elf_Data *__data, Elf_Cmd __cmd,
Packit Service 97d2fb
				  unsigned int __flags);
Packit Service 97d2fb
/* Similarly for the given ELF section header.  */
Packit Service 97d2fb
extern unsigned int elf_flagshdr (Elf_Scn *__scn, Elf_Cmd __cmd,
Packit Service 97d2fb
				  unsigned int __flags);
Packit Service 97d2fb
Packit Service 97d2fb
Packit Service 97d2fb
/* Get data from section while translating from file representation to
Packit Service 97d2fb
   memory representation.  The Elf_Data d_type is set based on the
Packit Service 97d2fb
   section type if known.  Otherwise d_type is set to ELF_T_BYTE.  If
Packit Service 97d2fb
   the section contains compressed data then d_type is always set to
Packit Service 97d2fb
   ELF_T_CHDR.  */
Packit Service 97d2fb
extern Elf_Data *elf_getdata (Elf_Scn *__scn, Elf_Data *__data);
Packit Service 97d2fb
Packit Service 97d2fb
/* Get uninterpreted section content.  */
Packit Service 97d2fb
extern Elf_Data *elf_rawdata (Elf_Scn *__scn, Elf_Data *__data);
Packit Service 97d2fb
Packit Service 97d2fb
/* Create new data descriptor for section SCN.  */
Packit Service 97d2fb
extern Elf_Data *elf_newdata (Elf_Scn *__scn);
Packit Service 97d2fb
Packit Service 97d2fb
/* Get data translated from a chunk of the file contents as section data
Packit Service 97d2fb
   would be for TYPE.  The resulting Elf_Data pointer is valid until
Packit Service 97d2fb
   elf_end (ELF) is called.  */
Packit Service 97d2fb
extern Elf_Data *elf_getdata_rawchunk (Elf *__elf,
Packit Service 97d2fb
				       int64_t __offset, size_t __size,
Packit Service 97d2fb
				       Elf_Type __type);
Packit Service 97d2fb
Packit Service 97d2fb
Packit Service 97d2fb
/* Return pointer to string at OFFSET in section INDEX.  */
Packit Service 97d2fb
extern char *elf_strptr (Elf *__elf, size_t __index, size_t __offset);
Packit Service 97d2fb
Packit Service 97d2fb
Packit Service 97d2fb
/* Return header of archive.  */
Packit Service 97d2fb
extern Elf_Arhdr *elf_getarhdr (Elf *__elf);
Packit Service 97d2fb
Packit Service 97d2fb
/* Return offset in archive for current file ELF.  */
Packit Service 97d2fb
extern int64_t elf_getaroff (Elf *__elf);
Packit Service 97d2fb
Packit Service 97d2fb
/* Select archive element at OFFSET.  */
Packit Service 97d2fb
extern size_t elf_rand (Elf *__elf, size_t __offset);
Packit Service 97d2fb
Packit Service 97d2fb
/* Get symbol table of archive.  */
Packit Service 97d2fb
extern Elf_Arsym *elf_getarsym (Elf *__elf, size_t *__narsyms);
Packit Service 97d2fb
Packit Service 97d2fb
Packit Service 97d2fb
/* Control ELF descriptor.  */
Packit Service 97d2fb
extern int elf_cntl (Elf *__elf, Elf_Cmd __cmd);
Packit Service 97d2fb
Packit Service 97d2fb
/* Retrieve uninterpreted file contents.  */
Packit Service 97d2fb
extern char *elf_rawfile (Elf *__elf, size_t *__nbytes);
Packit Service 97d2fb
Packit Service 97d2fb
Packit Service 97d2fb
/* Return size of array of COUNT elements of the type denoted by TYPE
Packit Service 97d2fb
   in the external representation.  The binary class is taken from ELF.
Packit Service 97d2fb
   The result is based on version VERSION of the ELF standard.  */
Packit Service 97d2fb
extern size_t elf32_fsize (Elf_Type __type, size_t __count,
Packit Service 97d2fb
			   unsigned int __version)
Packit Service 97d2fb
       __const_attribute__;
Packit Service 97d2fb
/* Similar but this time the binary calls is ELFCLASS64.  */
Packit Service 97d2fb
extern size_t elf64_fsize (Elf_Type __type, size_t __count,
Packit Service 97d2fb
			   unsigned int __version)
Packit Service 97d2fb
       __const_attribute__;
Packit Service 97d2fb
Packit Service 97d2fb
Packit Service 97d2fb
/* Convert data structure from the representation in the file represented
Packit Service 97d2fb
   by ELF to their memory representation.  */
Packit Service 97d2fb
extern Elf_Data *elf32_xlatetom (Elf_Data *__dest, const Elf_Data *__src,
Packit Service 97d2fb
				 unsigned int __encode);
Packit Service 97d2fb
/* Same for 64 bit class.  */
Packit Service 97d2fb
extern Elf_Data *elf64_xlatetom (Elf_Data *__dest, const Elf_Data *__src,
Packit Service 97d2fb
				 unsigned int __encode);
Packit Service 97d2fb
Packit Service 97d2fb
/* Convert data structure from to the representation in memory
Packit Service 97d2fb
   represented by ELF file representation.  */
Packit Service 97d2fb
extern Elf_Data *elf32_xlatetof (Elf_Data *__dest, const Elf_Data *__src,
Packit Service 97d2fb
				 unsigned int __encode);
Packit Service 97d2fb
/* Same for 64 bit class.  */
Packit Service 97d2fb
extern Elf_Data *elf64_xlatetof (Elf_Data *__dest, const Elf_Data *__src,
Packit Service 97d2fb
				 unsigned int __encode);
Packit Service 97d2fb
Packit Service 97d2fb
Packit Service 97d2fb
/* Return error code of last failing function call.  This value is kept
Packit Service 97d2fb
   separately for each thread.  */
Packit Service 97d2fb
extern int elf_errno (void);
Packit Service 97d2fb
Packit Service 97d2fb
/* Return error string for ERROR.  If ERROR is zero, return error string
Packit Service 97d2fb
   for most recent error or NULL is none occurred.  If ERROR is -1 the
Packit Service 97d2fb
   behaviour is similar to the last case except that not NULL but a legal
Packit Service 97d2fb
   string is returned.  */
Packit Service 97d2fb
extern const char *elf_errmsg (int __error);
Packit Service 97d2fb
Packit Service 97d2fb
Packit Service 97d2fb
/* Coordinate ELF library and application versions.  */
Packit Service 97d2fb
extern unsigned int elf_version (unsigned int __version);
Packit Service 97d2fb
Packit Service 97d2fb
/* Set fill bytes used to fill holes in data structures.  */
Packit Service 97d2fb
extern void elf_fill (int __fill);
Packit Service 97d2fb
Packit Service 97d2fb
/* Compute hash value.  */
Packit Service 97d2fb
extern unsigned long int elf_hash (const char *__string)
Packit Service 97d2fb
       __pure_attribute__;
Packit Service 97d2fb
Packit Service 97d2fb
/* Compute hash value using the GNU-specific hash function.  */
Packit Service 97d2fb
extern unsigned long int elf_gnu_hash (const char *__string)
Packit Service 97d2fb
       __pure_attribute__;
Packit Service 97d2fb
Packit Service 97d2fb
Packit Service 97d2fb
/* Compute simple checksum from permanent parts of the ELF file.  */
Packit Service 97d2fb
extern long int elf32_checksum (Elf *__elf);
Packit Service 97d2fb
/* Similar but this time the binary calls is ELFCLASS64.  */
Packit Service 97d2fb
extern long int elf64_checksum (Elf *__elf);
Packit Service 97d2fb
Packit Service 97d2fb
#ifdef __cplusplus
Packit Service 97d2fb
}
Packit Service 97d2fb
#endif
Packit Service 97d2fb
Packit Service 97d2fb
#endif  /* libelf.h */