1 /* $NetBSD: nlist_aout.c,v 1.23 2012/03/21 15:32:26 christos Exp $ */
4 * Copyright (c) 1989, 1993
5 * The Regents of the University of California. All rights reserved.
7 * Redistribution and use in source and binary forms, with or without
8 * modification, are permitted provided that the following conditions
10 * 1. Redistributions of source code must retain the above copyright
11 * notice, this list of conditions and the following disclaimer.
12 * 2. Redistributions in binary form must reproduce the above copyright
13 * notice, this list of conditions and the following disclaimer in the
14 * documentation and/or other materials provided with the distribution.
15 * 3. Neither the name of the University nor the names of its contributors
16 * may be used to endorse or promote products derived from this software
17 * without specific prior written permission.
19 * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
20 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
21 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
22 * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
23 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
24 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
25 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
26 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
27 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
28 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
33 * Copyright (c) 1996 Christopher G. Demetriou. All rights reserved.
35 * Redistribution and use in source and binary forms, with or without
36 * modification, are permitted provided that the following conditions
38 * 1. Redistributions of source code must retain the above copyright
39 * notice, this list of conditions and the following disclaimer.
40 * 2. Redistributions in binary form must reproduce the above copyright
41 * notice, this list of conditions and the following disclaimer in the
42 * documentation and/or other materials provided with the distribution.
43 * 3. All advertising materials mentioning features or use of this software
44 * must display the following acknowledgement:
45 * This product includes software developed by the University of
46 * California, Berkeley and its contributors.
47 * 4. Neither the name of the University nor the names of its contributors
48 * may be used to endorse or promote products derived from this software
49 * without specific prior written permission.
51 * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
52 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
53 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
54 * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
55 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
56 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
57 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
58 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
59 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
60 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
64 #include <sys/cdefs.h>
65 #if defined(LIBC_SCCS) && !defined(lint)
67 static char sccsid
[] = "@(#)nlist.c 8.1 (Berkeley) 6/4/93";
69 __RCSID("$NetBSD: nlist_aout.c,v 1.23 2012/03/21 15:32:26 christos Exp $");
71 #endif /* LIBC_SCCS and not lint */
73 #include "namespace.h"
74 #include <sys/param.h>
87 #include "nlist_private.h"
91 #include <sys/exec_aout.h>
94 __fdnlist_aout(int fd
, struct nlist
*list
)
100 size_t strsize
, symsize
, cc
;
101 struct nlist nbuf
[1024];
104 char *scoreboard
, *scored
;
106 _DIAGASSERT(fd
!= -1);
107 _DIAGASSERT(list
!= NULL
);
109 if (pread(fd
, &exec
, sizeof(exec
), (off_t
)0) != sizeof(exec
) ||
110 N_BADMAG(exec
) || fstat(fd
, &st
) < 0)
113 symoff
= N_SYMOFF(exec
);
114 symsize
= (size_t)exec
.a_syms
;
115 stroff
= symoff
+ symsize
;
117 /* Check for files too large to mmap. */
118 if ((uintmax_t)(st
.st_size
- stroff
) > (uintmax_t)SIZE_T_MAX
) {
123 * Map string table into our address space. This gives us
124 * an easy way to randomly access all the strings, without
125 * making the memory allocation permanent as with malloc/free
126 * (i.e., munmap will return it to the system).
128 strsize
= (size_t)(st
.st_size
- stroff
);
129 strtab
= mmap(NULL
, strsize
, PROT_READ
, MAP_PRIVATE
|MAP_FILE
,
131 if (strtab
== (char *)-1)
134 * clean out any left-over information for all valid entries.
135 * Type and value defined to be 0 if not found; historical
136 * versions cleared other and desc as well. Also figure out
137 * the largest string length so don't read any more of the
138 * string table than we have to.
140 * XXX clearing anything other than n_type and n_value violates
141 * the semantics given in the man page.
144 for (p
= list
; !ISLAST(p
); ++p
) {
151 if (lseek(fd
, symoff
, SEEK_SET
) == -1)
153 #if defined(__SSP__) || defined(__SSP_ALL__)
154 scoreboard
= malloc((size_t)nent
);
156 scoreboard
= alloca((size_t)nent
);
158 if (scoreboard
== NULL
)
160 (void)memset(scoreboard
, 0, (size_t)nent
);
162 while (symsize
> 0) {
163 cc
= MIN(symsize
, sizeof(nbuf
));
164 if (read(fd
, nbuf
, cc
) != (ssize_t
) cc
)
167 for (s
= nbuf
; cc
> 0; ++s
, cc
-= sizeof(*s
)) {
168 long soff
= s
->n_un
.n_strx
;
170 if (soff
== 0 || (s
->n_type
& N_STAB
) != 0)
172 for (p
= list
, scored
= scoreboard
; !ISLAST(p
);
175 !strcmp(&strtab
[(size_t)soff
],
177 p
->n_value
= s
->n_value
;
178 p
->n_type
= s
->n_type
;
179 p
->n_desc
= s
->n_desc
;
180 p
->n_other
= s
->n_other
;
187 munmap(strtab
, strsize
);
188 #if defined(__SSP__) || defined(__SSP_ALL__)
193 #endif /* NLIST_AOUT */