003 File Manager
Current Path:
/usr/src/contrib/elftoolchain/libelf
usr
/
src
/
contrib
/
elftoolchain
/
libelf
/
📁
..
📄
Makefile
(3.83 KB)
📄
Version.map
(1.49 KB)
📄
_libelf.h
(8.22 KB)
📄
_libelf_ar.h
(2.25 KB)
📄
_libelf_config.h
(5.2 KB)
📄
elf.3
(17.82 KB)
📄
elf.c
(1.64 KB)
📄
elf_begin.3
(7.24 KB)
📄
elf_begin.c
(2.55 KB)
📄
elf_cntl.3
(3.11 KB)
📄
elf_cntl.c
(1.81 KB)
📄
elf_data.c
(7.25 KB)
📄
elf_end.3
(2.38 KB)
📄
elf_end.c
(2.61 KB)
📄
elf_errmsg.3
(3.5 KB)
📄
elf_errmsg.c
(2.99 KB)
📄
elf_errno.c
(1.57 KB)
📄
elf_fill.3
(1.94 KB)
📄
elf_fill.c
(1.5 KB)
📄
elf_flag.c
(4.46 KB)
📄
elf_flagdata.3
(5.98 KB)
📄
elf_getarhdr.3
(3 KB)
📄
elf_getarhdr.c
(1.65 KB)
📄
elf_getarsym.3
(3.64 KB)
📄
elf_getarsym.c
(1.96 KB)
📄
elf_getbase.3
(2.29 KB)
📄
elf_getbase.c
(1.68 KB)
📄
elf_getdata.3
(6.26 KB)
📄
elf_getident.3
(2.58 KB)
📄
elf_getident.c
(1.98 KB)
📄
elf_getphdrnum.3
(2.68 KB)
📄
elf_getphnum.3
(2.78 KB)
📄
elf_getscn.3
(4.22 KB)
📄
elf_getshdrnum.3
(2.5 KB)
📄
elf_getshdrstrndx.3
(2.62 KB)
📄
elf_getshnum.3
(2.57 KB)
📄
elf_getshstrndx.3
(2.89 KB)
📄
elf_hash.3
(2.13 KB)
📄
elf_hash.c
(1.76 KB)
📄
elf_kind.3
(2.19 KB)
📄
elf_kind.c
(1.6 KB)
📄
elf_memory.3
(3.47 KB)
📄
elf_memory.c
(1.72 KB)
📄
elf_next.3
(2.81 KB)
📄
elf_next.c
(2.55 KB)
📄
elf_open.3
(3.41 KB)
📄
elf_open.c
(2.01 KB)
📄
elf_phnum.c
(1.98 KB)
📄
elf_rand.3
(3.1 KB)
📄
elf_rand.c
(2.14 KB)
📄
elf_rawfile.3
(2.38 KB)
📄
elf_rawfile.c
(1.73 KB)
📄
elf_scn.c
(6.17 KB)
📄
elf_shnum.c
(1.98 KB)
📄
elf_shstrndx.c
(2.32 KB)
📄
elf_strptr.3
(3.3 KB)
📄
elf_strptr.c
(3.58 KB)
📄
elf_types.m4
(6.35 KB)
📄
elf_update.3
(10.84 KB)
📄
elf_update.c
(29.37 KB)
📄
elf_version.3
(2.91 KB)
📄
elf_version.c
(1.72 KB)
📄
gelf.3
(6.43 KB)
📄
gelf.h
(5 KB)
📄
gelf_cap.c
(3.64 KB)
📄
gelf_chdr.c
(2.31 KB)
📄
gelf_checksum.3
(3.28 KB)
📄
gelf_checksum.c
(1.81 KB)
📄
gelf_dyn.c
(3.68 KB)
📄
gelf_ehdr.c
(4.1 KB)
📄
gelf_fsize.3
(2.83 KB)
📄
gelf_fsize.c
(1.95 KB)
📄
gelf_getcap.3
(3.55 KB)
📄
gelf_getchdr.3
(3.24 KB)
📄
gelf_getclass.3
(2 KB)
📄
gelf_getclass.c
(1.52 KB)
📄
gelf_getdyn.3
(3.59 KB)
📄
gelf_getehdr.3
(3.47 KB)
📄
gelf_getmove.3
(3.61 KB)
📄
gelf_getphdr.3
(3.91 KB)
📄
gelf_getrel.3
(3.55 KB)
📄
gelf_getrela.3
(3.59 KB)
📄
gelf_getshdr.3
(3.18 KB)
📄
gelf_getsym.3
(3.68 KB)
📄
gelf_getsyminfo.3
(3.47 KB)
📄
gelf_getsymshndx.3
(4.27 KB)
📄
gelf_mips64el.c
(2.65 KB)
📄
gelf_move.c
(3.93 KB)
📄
gelf_newehdr.3
(5.06 KB)
📄
gelf_newphdr.3
(3.78 KB)
📄
gelf_phdr.c
(4.19 KB)
📄
gelf_rel.c
(4.16 KB)
📄
gelf_rela.c
(4.29 KB)
📄
gelf_shdr.c
(3.43 KB)
📄
gelf_sym.c
(3.95 KB)
📄
gelf_syminfo.c
(3.75 KB)
📄
gelf_symshndx.c
(3.55 KB)
📄
gelf_update_ehdr.3
(3.63 KB)
📄
gelf_xlate.c
(2.67 KB)
📄
gelf_xlatetof.3
(7.41 KB)
📄
libelf.h
(7.72 KB)
📄
libelf_align.c
(3.86 KB)
📄
libelf_allocate.c
(4 KB)
📄
libelf_ar.c
(13.03 KB)
📄
libelf_ar_util.c
(8.33 KB)
📄
libelf_chdr.c
(2.86 KB)
📄
libelf_checksum.c
(2.81 KB)
📄
libelf_convert.m4
(28.16 KB)
📄
libelf_data.c
(3.18 KB)
📄
libelf_ehdr.c
(5.99 KB)
📄
libelf_elfmachine.c
(1.94 KB)
📄
libelf_extended.c
(3.38 KB)
📄
libelf_fsize.m4
(4.35 KB)
📄
libelf_memory.c
(2.89 KB)
📄
libelf_msize.m4
(3.2 KB)
📄
libelf_open.c
(5.49 KB)
📄
libelf_phdr.c
(4.04 KB)
📄
libelf_shdr.c
(1.79 KB)
📄
libelf_xlate.c
(4.25 KB)
📄
os.FreeBSD.mk
(182 B)
📄
os.Linux.mk
(761 B)
📄
os.NetBSD.mk
(128 B)
Editing: libelf_open.c
/*- * Copyright (c) 2006,2008-2011 Joseph Koshy * All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * 1. Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * 2. Redistributions in binary form must reproduce the above copyright * notice, this list of conditions and the following disclaimer in the * documentation and/or other materials provided with the distribution. * * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF * SUCH DAMAGE. */ #include <sys/types.h> #include <sys/stat.h> #include <assert.h> #include <errno.h> #include <libelf.h> #include <stdlib.h> #include <unistd.h> #include "_libelf.h" #if ELFTC_HAVE_MMAP #include <sys/mman.h> #endif ELFTC_VCSID("$Id: libelf_open.c 3007 2014-03-22 08:10:14Z jkoshy $"); #define _LIBELF_INITSIZE (64*1024) /* * Read from a device file, pipe or socket. */ static void * _libelf_read_special_file(int fd, size_t *fsz) { ssize_t readsz; size_t bufsz, datasz; unsigned char *buf, *t; datasz = 0; readsz = 0; bufsz = _LIBELF_INITSIZE; if ((buf = malloc(bufsz)) == NULL) goto resourceerror; /* * Read data from the file descriptor till we reach EOF, or * till an error is encountered. */ do { /* Check if we need to expand the data buffer. */ if (datasz == bufsz) { bufsz *= 2; if ((t = realloc(buf, bufsz)) == NULL) goto resourceerror; buf = t; } do { assert(bufsz - datasz > 0); t = buf + datasz; if ((readsz = read(fd, t, bufsz - datasz)) <= 0) break; datasz += (size_t) readsz; } while (datasz < bufsz); } while (readsz > 0); if (readsz < 0) { LIBELF_SET_ERROR(IO, errno); goto error; } assert(readsz == 0); /* * Free up extra buffer space. */ if (bufsz > datasz) { if (datasz > 0) { if ((t = realloc(buf, datasz)) == NULL) goto resourceerror; buf = t; } else { /* Zero bytes read. */ LIBELF_SET_ERROR(ARGUMENT, 0); free(buf); buf = NULL; } } *fsz = datasz; return (buf); resourceerror: LIBELF_SET_ERROR(RESOURCE, 0); error: if (buf != NULL) free(buf); return (NULL); } /* * Read the contents of the file referenced by the file descriptor * 'fd'. */ Elf * _libelf_open_object(int fd, Elf_Cmd c, int reporterror) { Elf *e; void *m; mode_t mode; size_t fsize; struct stat sb; unsigned int flags; assert(c == ELF_C_READ || c == ELF_C_RDWR || c == ELF_C_WRITE); if (fstat(fd, &sb) < 0) { LIBELF_SET_ERROR(IO, errno); return (NULL); } mode = sb.st_mode; fsize = (size_t) sb.st_size; /* * Reject unsupported file types. */ if (!S_ISREG(mode) && !S_ISCHR(mode) && !S_ISFIFO(mode) && !S_ISSOCK(mode)) { LIBELF_SET_ERROR(ARGUMENT, 0); return (NULL); } /* * For ELF_C_WRITE mode, allocate and return a descriptor. */ if (c == ELF_C_WRITE) { if ((e = _libelf_allocate_elf()) != NULL) { _libelf_init_elf(e, ELF_K_ELF); e->e_byteorder = LIBELF_PRIVATE(byteorder); e->e_fd = fd; e->e_cmd = c; if (!S_ISREG(mode)) e->e_flags |= LIBELF_F_SPECIAL_FILE; } return (e); } /* * ELF_C_READ and ELF_C_RDWR mode. */ m = NULL; flags = 0; if (S_ISREG(mode)) { /* * Reject zero length files. */ if (fsize == 0) { LIBELF_SET_ERROR(ARGUMENT, 0); return (NULL); } #if ELFTC_HAVE_MMAP /* * Always map regular files in with 'PROT_READ' * permissions. * * For objects opened in ELF_C_RDWR mode, when * elf_update(3) is called, we remove this mapping, * write file data out using write(2), and map the new * contents back. */ m = mmap(NULL, fsize, PROT_READ, MAP_PRIVATE, fd, (off_t) 0); if (m == MAP_FAILED) m = NULL; else flags = LIBELF_F_RAWFILE_MMAP; #endif /* * Fallback to a read() if the call to mmap() failed, * or if mmap() is not available. */ if (m == NULL) { if ((m = malloc(fsize)) == NULL) { LIBELF_SET_ERROR(RESOURCE, 0); return (NULL); } if (read(fd, m, fsize) != (ssize_t) fsize) { LIBELF_SET_ERROR(IO, errno); free(m); return (NULL); } flags = LIBELF_F_RAWFILE_MALLOC; } } else if ((m = _libelf_read_special_file(fd, &fsize)) != NULL) flags = LIBELF_F_RAWFILE_MALLOC | LIBELF_F_SPECIAL_FILE; else return (NULL); if ((e = _libelf_memory(m, fsize, reporterror)) == NULL) { assert((flags & LIBELF_F_RAWFILE_MALLOC) || (flags & LIBELF_F_RAWFILE_MMAP)); if (flags & LIBELF_F_RAWFILE_MALLOC) free(m); #if ELFTC_HAVE_MMAP else (void) munmap(m, fsize); #endif return (NULL); } /* ar(1) archives aren't supported in RDWR mode. */ if (c == ELF_C_RDWR && e->e_kind == ELF_K_AR) { (void) elf_end(e); LIBELF_SET_ERROR(ARGUMENT, 0); return (NULL); } e->e_flags |= flags; e->e_fd = fd; e->e_cmd = c; return (e); }
Upload File
Create Folder