diff options
-rw-r--r-- | lib/libc/gen/nlist.c | 44 |
1 files changed, 23 insertions, 21 deletions
diff --git a/lib/libc/gen/nlist.c b/lib/libc/gen/nlist.c index 90bd795ff34..a67901ddb04 100644 --- a/lib/libc/gen/nlist.c +++ b/lib/libc/gen/nlist.c @@ -32,7 +32,7 @@ */ #if defined(LIBC_SCCS) && !defined(lint) -static char rcsid[] = "$OpenBSD: nlist.c,v 1.21 1997/07/23 21:04:06 kstailey Exp $"; +static char rcsid[] = "$OpenBSD: nlist.c,v 1.22 1997/12/15 10:19:17 deraadt Exp $"; #endif /* LIBC_SCCS and not lint */ #include <sys/types.h> @@ -95,7 +95,8 @@ __aout_fdnlist(fd, list) * (i.e., munmap will return it to the system). */ strsize = st.st_size - stroff; - strtab = mmap(NULL, (size_t)strsize, PROT_READ, 0, fd, stroff); + strtab = mmap(NULL, (size_t)strsize, PROT_READ, MAP_COPY|MAP_FILE, + fd, stroff); if (strtab == (char *)-1) return (-1); /* @@ -176,7 +177,8 @@ __ecoff_fdnlist(fd, list) BAD; } mappedsize = st.st_size; - mappedfile = mmap(NULL, mappedsize, PROT_READ, 0, fd, 0); + mappedfile = mmap(NULL, mappedsize, PROT_READ, MAP_COPY|MAP_FILE, + fd, 0); if (mappedfile == (char *)-1) BAD; @@ -314,8 +316,8 @@ __elf_fdnlist(fd, list) } /* mmap section header table */ - shdr = (Elf32_Shdr *)mmap(NULL, (size_t)shdr_size, - PROT_READ, 0, fd, (off_t) ehdr.e_shoff); + shdr = (Elf32_Shdr *)mmap(NULL, (size_t)shdr_size, PROT_READ, + MAP_COPY|MAP_FILE, fd, (off_t) ehdr.e_shoff); if (shdr == (Elf32_Shdr *)-1) return (-1); @@ -350,7 +352,8 @@ __elf_fdnlist(fd, list) * making the memory allocation permanent as with malloc/free * (i.e., munmap will return it to the system). */ - strtab = mmap(NULL, (size_t)symstrsize, PROT_READ, 0, fd, (off_t) symstroff); + strtab = mmap(NULL, (size_t)symstrsize, PROT_READ, MAP_COPY|MAP_FILE, + fd, (off_t) symstroff); if (strtab == (char *)-1) return (-1); /* @@ -376,7 +379,7 @@ __elf_fdnlist(fd, list) /* ELFism - dunno if stripped by looking at header */ if (symoff == 0) goto done; - + if (lseek(fd, (off_t) symoff, SEEK_SET) == -1) { nent = -1; goto done; @@ -408,18 +411,18 @@ __elf_fdnlist(fd, list) /* XXX - type conversion */ /* is pretty rude. */ switch(ELF32_ST_TYPE(s->st_info)) { - case STT_NOTYPE: - p->n_type = N_UNDF; - break; - case STT_OBJECT: - p->n_type = N_DATA; - break; - case STT_FUNC: - p->n_type = N_TEXT; - break; - case STT_FILE: - p->n_type = N_FN; - break; + case STT_NOTYPE: + p->n_type = N_UNDF; + break; + case STT_OBJECT: + p->n_type = N_DATA; + break; + case STT_FUNC: + p->n_type = N_TEXT; + break; + case STT_FILE: + p->n_type = N_FN; + break; } if (ELF32_ST_BIND(s->st_info) == STB_LOCAL) @@ -432,9 +435,8 @@ __elf_fdnlist(fd, list) } } } - done: +done: munmap(strtab, symstrsize); - return (nent); } #endif /* _NLIST_DO_ELF */ |