xref: /openbsd-src/gnu/gcc/libmudflap/mf-hooks2.c (revision 404b540a9034ac75a6199ad1a32d1bbc7a0d4210)
1*404b540aSrobert /* Mudflap: narrow-pointer bounds-checking by tree rewriting.
2*404b540aSrobert    Copyright (C) 2002, 2003, 2004 Free Software Foundation, Inc.
3*404b540aSrobert    Contributed by Frank Ch. Eigler <fche@redhat.com>
4*404b540aSrobert    and Graydon Hoare <graydon@redhat.com>
5*404b540aSrobert 
6*404b540aSrobert This file is part of GCC.
7*404b540aSrobert 
8*404b540aSrobert GCC is free software; you can redistribute it and/or modify it under
9*404b540aSrobert the terms of the GNU General Public License as published by the Free
10*404b540aSrobert Software Foundation; either version 2, or (at your option) any later
11*404b540aSrobert version.
12*404b540aSrobert 
13*404b540aSrobert In addition to the permissions in the GNU General Public License, the
14*404b540aSrobert Free Software Foundation gives you unlimited permission to link the
15*404b540aSrobert compiled version of this file into combinations with other programs,
16*404b540aSrobert and to distribute those combinations without any restriction coming
17*404b540aSrobert from the use of this file.  (The General Public License restrictions
18*404b540aSrobert do apply in other respects; for example, they cover modification of
19*404b540aSrobert the file, and distribution when not linked into a combine
20*404b540aSrobert executable.)
21*404b540aSrobert 
22*404b540aSrobert GCC is distributed in the hope that it will be useful, but WITHOUT ANY
23*404b540aSrobert WARRANTY; without even the implied warranty of MERCHANTABILITY or
24*404b540aSrobert FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
25*404b540aSrobert for more details.
26*404b540aSrobert 
27*404b540aSrobert You should have received a copy of the GNU General Public License
28*404b540aSrobert along with GCC; see the file COPYING.  If not, write to the Free
29*404b540aSrobert Software Foundation, 51 Franklin Street, Fifth Floor, Boston, MA
30*404b540aSrobert 02110-1301, USA.  */
31*404b540aSrobert 
32*404b540aSrobert 
33*404b540aSrobert #include "config.h"
34*404b540aSrobert 
35*404b540aSrobert #ifndef HAVE_SOCKLEN_T
36*404b540aSrobert #define socklen_t int
37*404b540aSrobert #endif
38*404b540aSrobert 
39*404b540aSrobert /* These attempt to coax various unix flavours to declare all our
40*404b540aSrobert    needed tidbits in the system headers.  */
41*404b540aSrobert #if !defined(__FreeBSD__) && !defined(__APPLE__)
42*404b540aSrobert #define _POSIX_SOURCE
43*404b540aSrobert #endif /* Some BSDs break <sys/socket.h> if this is defined. */
44*404b540aSrobert #define _GNU_SOURCE
45*404b540aSrobert #define _XOPEN_SOURCE
46*404b540aSrobert #define _BSD_TYPES
47*404b540aSrobert #define __EXTENSIONS__
48*404b540aSrobert #define _ALL_SOURCE
49*404b540aSrobert #define _LARGE_FILE_API
50*404b540aSrobert #define _LARGEFILE64_SOURCE
51*404b540aSrobert #define _XOPEN_SOURCE_EXTENDED 1
52*404b540aSrobert 
53*404b540aSrobert #include <string.h>
54*404b540aSrobert #include <stdarg.h>
55*404b540aSrobert #include <stdio.h>
56*404b540aSrobert #include <stdlib.h>
57*404b540aSrobert #include <sys/stat.h>
58*404b540aSrobert #include <sys/time.h>
59*404b540aSrobert #include <sys/types.h>
60*404b540aSrobert #include <unistd.h>
61*404b540aSrobert #include <assert.h>
62*404b540aSrobert #include <errno.h>
63*404b540aSrobert #include <limits.h>
64*404b540aSrobert #include <time.h>
65*404b540aSrobert #include <ctype.h>
66*404b540aSrobert #ifdef HAVE_DLFCN_H
67*404b540aSrobert #include <dlfcn.h>
68*404b540aSrobert #endif
69*404b540aSrobert #ifdef HAVE_DIRENT_H
70*404b540aSrobert #include <dirent.h>
71*404b540aSrobert #endif
72*404b540aSrobert #ifdef HAVE_SYS_SOCKET_H
73*404b540aSrobert #include <sys/socket.h>
74*404b540aSrobert #endif
75*404b540aSrobert #ifdef HAVE_NETDB_H
76*404b540aSrobert #include <netdb.h>
77*404b540aSrobert #endif
78*404b540aSrobert #ifdef HAVE_SYS_WAIT_H
79*404b540aSrobert #include <sys/wait.h>
80*404b540aSrobert #endif
81*404b540aSrobert #ifdef HAVE_SYS_IPC_H
82*404b540aSrobert #include <sys/ipc.h>
83*404b540aSrobert #endif
84*404b540aSrobert #ifdef HAVE_SYS_SEM_H
85*404b540aSrobert #include <sys/sem.h>
86*404b540aSrobert #endif
87*404b540aSrobert #ifdef HAVE_SYS_SHM_H
88*404b540aSrobert #include <sys/shm.h>
89*404b540aSrobert #endif
90*404b540aSrobert #ifdef HAVE_PWD_H
91*404b540aSrobert #include <pwd.h>
92*404b540aSrobert #endif
93*404b540aSrobert #ifdef HAVE_GRP_H
94*404b540aSrobert #include <grp.h>
95*404b540aSrobert #endif
96*404b540aSrobert #ifdef HAVE_MNTENT_H
97*404b540aSrobert #include <mntent.h>
98*404b540aSrobert #endif
99*404b540aSrobert #ifdef HAVE_SYS_SOCKET_H
100*404b540aSrobert #include <sys/socket.h>
101*404b540aSrobert #endif
102*404b540aSrobert #ifdef HAVE_NETINET_IN_H
103*404b540aSrobert #include <netinet/in.h>
104*404b540aSrobert #endif
105*404b540aSrobert #ifdef HAVE_ARPA_INET_H
106*404b540aSrobert #include <arpa/inet.h>
107*404b540aSrobert #endif
108*404b540aSrobert 
109*404b540aSrobert #include "mf-runtime.h"
110*404b540aSrobert #include "mf-impl.h"
111*404b540aSrobert 
112*404b540aSrobert #ifdef _MUDFLAP
113*404b540aSrobert #error "Do not compile this file with -fmudflap!"
114*404b540aSrobert #endif
115*404b540aSrobert 
116*404b540aSrobert 
117*404b540aSrobert /* A bunch of independent stdlib/unistd hook functions, all
118*404b540aSrobert    intercepted by mf-runtime.h macros.  */
119*404b540aSrobert 
120*404b540aSrobert #ifndef HAVE_STRNLEN
size_t(strnlen)121*404b540aSrobert static inline size_t (strnlen) (const char* str, size_t n)
122*404b540aSrobert {
123*404b540aSrobert   const char *s;
124*404b540aSrobert 
125*404b540aSrobert   for (s = str; n && *s; ++s, --n)
126*404b540aSrobert     ;
127*404b540aSrobert   return (s - str);
128*404b540aSrobert }
129*404b540aSrobert #endif
130*404b540aSrobert 
131*404b540aSrobert 
132*404b540aSrobert /* str*,mem*,b* */
133*404b540aSrobert 
WRAPPER2(void *,memcpy,void * dest,const void * src,size_t n)134*404b540aSrobert WRAPPER2(void *, memcpy, void *dest, const void *src, size_t n)
135*404b540aSrobert {
136*404b540aSrobert   TRACE ("%s\n", __PRETTY_FUNCTION__);
137*404b540aSrobert   MF_VALIDATE_EXTENT(src, n, __MF_CHECK_READ, "memcpy source");
138*404b540aSrobert   MF_VALIDATE_EXTENT(dest, n, __MF_CHECK_WRITE, "memcpy dest");
139*404b540aSrobert   return memcpy (dest, src, n);
140*404b540aSrobert }
141*404b540aSrobert 
142*404b540aSrobert 
WRAPPER2(void *,memmove,void * dest,const void * src,size_t n)143*404b540aSrobert WRAPPER2(void *, memmove, void *dest, const void *src, size_t n)
144*404b540aSrobert {
145*404b540aSrobert   TRACE ("%s\n", __PRETTY_FUNCTION__);
146*404b540aSrobert   MF_VALIDATE_EXTENT(src, n, __MF_CHECK_READ, "memmove src");
147*404b540aSrobert   MF_VALIDATE_EXTENT(dest, n, __MF_CHECK_WRITE, "memmove dest");
148*404b540aSrobert   return memmove (dest, src, n);
149*404b540aSrobert }
150*404b540aSrobert 
151*404b540aSrobert 
WRAPPER2(void *,memset,void * s,int c,size_t n)152*404b540aSrobert WRAPPER2(void *, memset, void *s, int c, size_t n)
153*404b540aSrobert {
154*404b540aSrobert   TRACE ("%s\n", __PRETTY_FUNCTION__);
155*404b540aSrobert   MF_VALIDATE_EXTENT(s, n, __MF_CHECK_WRITE, "memset dest");
156*404b540aSrobert   return memset (s, c, n);
157*404b540aSrobert }
158*404b540aSrobert 
159*404b540aSrobert 
WRAPPER2(int,memcmp,const void * s1,const void * s2,size_t n)160*404b540aSrobert WRAPPER2(int, memcmp, const void *s1, const void *s2, size_t n)
161*404b540aSrobert {
162*404b540aSrobert   TRACE ("%s\n", __PRETTY_FUNCTION__);
163*404b540aSrobert   MF_VALIDATE_EXTENT(s1, n, __MF_CHECK_READ, "memcmp 1st arg");
164*404b540aSrobert   MF_VALIDATE_EXTENT(s2, n, __MF_CHECK_READ, "memcmp 2nd arg");
165*404b540aSrobert   return memcmp (s1, s2, n);
166*404b540aSrobert }
167*404b540aSrobert 
168*404b540aSrobert 
WRAPPER2(void *,memchr,const void * s,int c,size_t n)169*404b540aSrobert WRAPPER2(void *, memchr, const void *s, int c, size_t n)
170*404b540aSrobert {
171*404b540aSrobert   TRACE ("%s\n", __PRETTY_FUNCTION__);
172*404b540aSrobert   MF_VALIDATE_EXTENT(s, n, __MF_CHECK_READ, "memchr region");
173*404b540aSrobert   return memchr (s, c, n);
174*404b540aSrobert }
175*404b540aSrobert 
176*404b540aSrobert 
177*404b540aSrobert #ifdef HAVE_MEMRCHR
WRAPPER2(void *,memrchr,const void * s,int c,size_t n)178*404b540aSrobert WRAPPER2(void *, memrchr, const void *s, int c, size_t n)
179*404b540aSrobert {
180*404b540aSrobert   TRACE ("%s\n", __PRETTY_FUNCTION__);
181*404b540aSrobert   MF_VALIDATE_EXTENT(s, n, __MF_CHECK_READ, "memrchr region");
182*404b540aSrobert   return memrchr (s, c, n);
183*404b540aSrobert }
184*404b540aSrobert #endif
185*404b540aSrobert 
186*404b540aSrobert 
WRAPPER2(char *,strcpy,char * dest,const char * src)187*404b540aSrobert WRAPPER2(char *, strcpy, char *dest, const char *src)
188*404b540aSrobert {
189*404b540aSrobert   /* nb: just because strlen(src) == n doesn't mean (src + n) or (src + n +
190*404b540aSrobert      1) are valid pointers. the allocated object might have size < n.
191*404b540aSrobert      check anyways. */
192*404b540aSrobert 
193*404b540aSrobert   size_t n = strlen (src);
194*404b540aSrobert   TRACE ("%s\n", __PRETTY_FUNCTION__);
195*404b540aSrobert   MF_VALIDATE_EXTENT(src, CLAMPADD(n, 1), __MF_CHECK_READ, "strcpy src");
196*404b540aSrobert   MF_VALIDATE_EXTENT(dest, CLAMPADD(n, 1), __MF_CHECK_WRITE, "strcpy dest");
197*404b540aSrobert   return strcpy (dest, src);
198*404b540aSrobert }
199*404b540aSrobert 
200*404b540aSrobert 
201*404b540aSrobert #ifdef HAVE_STRNCPY
WRAPPER2(char *,strncpy,char * dest,const char * src,size_t n)202*404b540aSrobert WRAPPER2(char *, strncpy, char *dest, const char *src, size_t n)
203*404b540aSrobert {
204*404b540aSrobert   size_t len = strnlen (src, n);
205*404b540aSrobert   TRACE ("%s\n", __PRETTY_FUNCTION__);
206*404b540aSrobert   MF_VALIDATE_EXTENT(src, len, __MF_CHECK_READ, "strncpy src");
207*404b540aSrobert   MF_VALIDATE_EXTENT(dest, len, __MF_CHECK_WRITE, "strncpy dest"); /* nb: strNcpy */
208*404b540aSrobert   return strncpy (dest, src, n);
209*404b540aSrobert }
210*404b540aSrobert #endif
211*404b540aSrobert 
212*404b540aSrobert 
WRAPPER2(char *,strcat,char * dest,const char * src)213*404b540aSrobert WRAPPER2(char *, strcat, char *dest, const char *src)
214*404b540aSrobert {
215*404b540aSrobert   size_t dest_sz;
216*404b540aSrobert   size_t src_sz;
217*404b540aSrobert   TRACE ("%s\n", __PRETTY_FUNCTION__);
218*404b540aSrobert   dest_sz = strlen (dest);
219*404b540aSrobert   src_sz = strlen (src);
220*404b540aSrobert   MF_VALIDATE_EXTENT(src, CLAMPADD(src_sz, 1), __MF_CHECK_READ, "strcat src");
221*404b540aSrobert   MF_VALIDATE_EXTENT(dest, CLAMPADD(dest_sz, CLAMPADD(src_sz, 1)),
222*404b540aSrobert 		     __MF_CHECK_WRITE, "strcat dest");
223*404b540aSrobert   return strcat (dest, src);
224*404b540aSrobert }
225*404b540aSrobert 
226*404b540aSrobert 
WRAPPER2(char *,strncat,char * dest,const char * src,size_t n)227*404b540aSrobert WRAPPER2(char *, strncat, char *dest, const char *src, size_t n)
228*404b540aSrobert {
229*404b540aSrobert 
230*404b540aSrobert   /* nb: validating the extents (s,n) might be a mistake for two reasons.
231*404b540aSrobert 
232*404b540aSrobert   (1) the string s might be shorter than n chars, and n is just a
233*404b540aSrobert   poor choice by the programmer. this is not a "true" error in the
234*404b540aSrobert   sense that the call to strncat would still be ok.
235*404b540aSrobert 
236*404b540aSrobert   (2) we could try to compensate for case (1) by calling strlen(s) and
237*404b540aSrobert   using that as a bound for the extent to verify, but strlen might fall off
238*404b540aSrobert   the end of a non-terminated string, leading to a false positive.
239*404b540aSrobert 
240*404b540aSrobert   so we will call strnlen(s,n) and use that as a bound.
241*404b540aSrobert 
242*404b540aSrobert   if strnlen returns a length beyond the end of the registered extent
243*404b540aSrobert   associated with s, there is an error: the programmer's estimate for n is
244*404b540aSrobert   too large _AND_ the string s is unterminated, in which case they'd be
245*404b540aSrobert   about to touch memory they don't own while calling strncat.
246*404b540aSrobert 
247*404b540aSrobert   this same logic applies to further uses of strnlen later down in this
248*404b540aSrobert   file. */
249*404b540aSrobert 
250*404b540aSrobert   size_t src_sz;
251*404b540aSrobert   size_t dest_sz;
252*404b540aSrobert   TRACE ("%s\n", __PRETTY_FUNCTION__);
253*404b540aSrobert   src_sz = strnlen (src, n);
254*404b540aSrobert   dest_sz = strnlen (dest, n);
255*404b540aSrobert   MF_VALIDATE_EXTENT(src, src_sz, __MF_CHECK_READ, "strncat src");
256*404b540aSrobert   MF_VALIDATE_EXTENT(dest, (CLAMPADD(dest_sz, CLAMPADD(src_sz, 1))),
257*404b540aSrobert 		     __MF_CHECK_WRITE, "strncat dest");
258*404b540aSrobert   return strncat (dest, src, n);
259*404b540aSrobert }
260*404b540aSrobert 
261*404b540aSrobert 
WRAPPER2(int,strcmp,const char * s1,const char * s2)262*404b540aSrobert WRAPPER2(int, strcmp, const char *s1, const char *s2)
263*404b540aSrobert {
264*404b540aSrobert   size_t s1_sz;
265*404b540aSrobert   size_t s2_sz;
266*404b540aSrobert   TRACE ("%s\n", __PRETTY_FUNCTION__);
267*404b540aSrobert   s1_sz = strlen (s1);
268*404b540aSrobert   s2_sz = strlen (s2);
269*404b540aSrobert   MF_VALIDATE_EXTENT(s1, CLAMPADD(s1_sz, 1), __MF_CHECK_READ, "strcmp 1st arg");
270*404b540aSrobert   MF_VALIDATE_EXTENT(s2, CLAMPADD(s2_sz, 1), __MF_CHECK_WRITE, "strcmp 2nd arg");
271*404b540aSrobert   return strcmp (s1, s2);
272*404b540aSrobert }
273*404b540aSrobert 
274*404b540aSrobert 
WRAPPER2(int,strcasecmp,const char * s1,const char * s2)275*404b540aSrobert WRAPPER2(int, strcasecmp, const char *s1, const char *s2)
276*404b540aSrobert {
277*404b540aSrobert   size_t s1_sz;
278*404b540aSrobert   size_t s2_sz;
279*404b540aSrobert   TRACE ("%s\n", __PRETTY_FUNCTION__);
280*404b540aSrobert   s1_sz = strlen (s1);
281*404b540aSrobert   s2_sz = strlen (s2);
282*404b540aSrobert   MF_VALIDATE_EXTENT(s1, CLAMPADD(s1_sz, 1), __MF_CHECK_READ, "strcasecmp 1st arg");
283*404b540aSrobert   MF_VALIDATE_EXTENT(s2, CLAMPADD(s2_sz, 1), __MF_CHECK_READ, "strcasecmp 2nd arg");
284*404b540aSrobert   return strcasecmp (s1, s2);
285*404b540aSrobert }
286*404b540aSrobert 
287*404b540aSrobert 
WRAPPER2(int,strncmp,const char * s1,const char * s2,size_t n)288*404b540aSrobert WRAPPER2(int, strncmp, const char *s1, const char *s2, size_t n)
289*404b540aSrobert {
290*404b540aSrobert   size_t s1_sz;
291*404b540aSrobert   size_t s2_sz;
292*404b540aSrobert   TRACE ("%s\n", __PRETTY_FUNCTION__);
293*404b540aSrobert   s1_sz = strnlen (s1, n);
294*404b540aSrobert   s2_sz = strnlen (s2, n);
295*404b540aSrobert   MF_VALIDATE_EXTENT(s1, s1_sz, __MF_CHECK_READ, "strncmp 1st arg");
296*404b540aSrobert   MF_VALIDATE_EXTENT(s2, s2_sz, __MF_CHECK_READ, "strncmp 2nd arg");
297*404b540aSrobert   return strncmp (s1, s2, n);
298*404b540aSrobert }
299*404b540aSrobert 
300*404b540aSrobert 
WRAPPER2(int,strncasecmp,const char * s1,const char * s2,size_t n)301*404b540aSrobert WRAPPER2(int, strncasecmp, const char *s1, const char *s2, size_t n)
302*404b540aSrobert {
303*404b540aSrobert   size_t s1_sz;
304*404b540aSrobert   size_t s2_sz;
305*404b540aSrobert   TRACE ("%s\n", __PRETTY_FUNCTION__);
306*404b540aSrobert   s1_sz = strnlen (s1, n);
307*404b540aSrobert   s2_sz = strnlen (s2, n);
308*404b540aSrobert   MF_VALIDATE_EXTENT(s1, s1_sz, __MF_CHECK_READ, "strncasecmp 1st arg");
309*404b540aSrobert   MF_VALIDATE_EXTENT(s2, s2_sz, __MF_CHECK_READ, "strncasecmp 2nd arg");
310*404b540aSrobert   return strncasecmp (s1, s2, n);
311*404b540aSrobert }
312*404b540aSrobert 
313*404b540aSrobert 
WRAPPER2(char *,strdup,const char * s)314*404b540aSrobert WRAPPER2(char *, strdup, const char *s)
315*404b540aSrobert {
316*404b540aSrobert   DECLARE(void *, malloc, size_t sz);
317*404b540aSrobert   char *result;
318*404b540aSrobert   size_t n = strlen (s);
319*404b540aSrobert   TRACE ("%s\n", __PRETTY_FUNCTION__);
320*404b540aSrobert   MF_VALIDATE_EXTENT(s, CLAMPADD(n,1), __MF_CHECK_READ, "strdup region");
321*404b540aSrobert   result = (char *)CALL_REAL(malloc,
322*404b540aSrobert 			     CLAMPADD(CLAMPADD(n,1),
323*404b540aSrobert 				      CLAMPADD(__mf_opts.crumple_zone,
324*404b540aSrobert 					       __mf_opts.crumple_zone)));
325*404b540aSrobert 
326*404b540aSrobert   if (UNLIKELY(! result)) return result;
327*404b540aSrobert 
328*404b540aSrobert   result += __mf_opts.crumple_zone;
329*404b540aSrobert   memcpy (result, s, n);
330*404b540aSrobert   result[n] = '\0';
331*404b540aSrobert 
332*404b540aSrobert   __mf_register (result, CLAMPADD(n,1), __MF_TYPE_HEAP_I, "strdup region");
333*404b540aSrobert   return result;
334*404b540aSrobert }
335*404b540aSrobert 
336*404b540aSrobert 
WRAPPER2(char *,strndup,const char * s,size_t n)337*404b540aSrobert WRAPPER2(char *, strndup, const char *s, size_t n)
338*404b540aSrobert {
339*404b540aSrobert   DECLARE(void *, malloc, size_t sz);
340*404b540aSrobert   char *result;
341*404b540aSrobert   size_t sz = strnlen (s, n);
342*404b540aSrobert   TRACE ("%s\n", __PRETTY_FUNCTION__);
343*404b540aSrobert   MF_VALIDATE_EXTENT(s, sz, __MF_CHECK_READ, "strndup region"); /* nb: strNdup */
344*404b540aSrobert 
345*404b540aSrobert   /* note: strndup still adds a \0, even with the N limit! */
346*404b540aSrobert   result = (char *)CALL_REAL(malloc,
347*404b540aSrobert 			     CLAMPADD(CLAMPADD(n,1),
348*404b540aSrobert 				      CLAMPADD(__mf_opts.crumple_zone,
349*404b540aSrobert 					       __mf_opts.crumple_zone)));
350*404b540aSrobert 
351*404b540aSrobert   if (UNLIKELY(! result)) return result;
352*404b540aSrobert 
353*404b540aSrobert   result += __mf_opts.crumple_zone;
354*404b540aSrobert   memcpy (result, s, n);
355*404b540aSrobert   result[n] = '\0';
356*404b540aSrobert 
357*404b540aSrobert   __mf_register (result, CLAMPADD(n,1), __MF_TYPE_HEAP_I, "strndup region");
358*404b540aSrobert   return result;
359*404b540aSrobert }
360*404b540aSrobert 
361*404b540aSrobert 
WRAPPER2(char *,strchr,const char * s,int c)362*404b540aSrobert WRAPPER2(char *, strchr, const char *s, int c)
363*404b540aSrobert {
364*404b540aSrobert   size_t n;
365*404b540aSrobert   TRACE ("%s\n", __PRETTY_FUNCTION__);
366*404b540aSrobert   n = strlen (s);
367*404b540aSrobert   MF_VALIDATE_EXTENT(s, CLAMPADD(n,1), __MF_CHECK_READ, "strchr region");
368*404b540aSrobert   return strchr (s, c);
369*404b540aSrobert }
370*404b540aSrobert 
371*404b540aSrobert 
WRAPPER2(char *,strrchr,const char * s,int c)372*404b540aSrobert WRAPPER2(char *, strrchr, const char *s, int c)
373*404b540aSrobert {
374*404b540aSrobert   size_t n;
375*404b540aSrobert   TRACE ("%s\n", __PRETTY_FUNCTION__);
376*404b540aSrobert   n = strlen (s);
377*404b540aSrobert   MF_VALIDATE_EXTENT(s, CLAMPADD(n,1), __MF_CHECK_READ, "strrchr region");
378*404b540aSrobert   return strrchr (s, c);
379*404b540aSrobert }
380*404b540aSrobert 
381*404b540aSrobert 
WRAPPER2(char *,strstr,const char * haystack,const char * needle)382*404b540aSrobert WRAPPER2(char *, strstr, const char *haystack, const char *needle)
383*404b540aSrobert {
384*404b540aSrobert   size_t haystack_sz;
385*404b540aSrobert   size_t needle_sz;
386*404b540aSrobert   TRACE ("%s\n", __PRETTY_FUNCTION__);
387*404b540aSrobert   haystack_sz = strlen (haystack);
388*404b540aSrobert   needle_sz = strlen (needle);
389*404b540aSrobert   MF_VALIDATE_EXTENT(haystack, CLAMPADD(haystack_sz, 1), __MF_CHECK_READ, "strstr haystack");
390*404b540aSrobert   MF_VALIDATE_EXTENT(needle, CLAMPADD(needle_sz, 1), __MF_CHECK_READ, "strstr needle");
391*404b540aSrobert   return strstr (haystack, needle);
392*404b540aSrobert }
393*404b540aSrobert 
394*404b540aSrobert 
395*404b540aSrobert #ifdef HAVE_MEMMEM
WRAPPER2(void *,memmem,const void * haystack,size_t haystacklen,const void * needle,size_t needlelen)396*404b540aSrobert WRAPPER2(void *, memmem,
397*404b540aSrobert 	const void *haystack, size_t haystacklen,
398*404b540aSrobert 	const void *needle, size_t needlelen)
399*404b540aSrobert {
400*404b540aSrobert   TRACE ("%s\n", __PRETTY_FUNCTION__);
401*404b540aSrobert   MF_VALIDATE_EXTENT(haystack, haystacklen, __MF_CHECK_READ, "memmem haystack");
402*404b540aSrobert   MF_VALIDATE_EXTENT(needle, needlelen, __MF_CHECK_READ, "memmem needle");
403*404b540aSrobert   return memmem (haystack, haystacklen, needle, needlelen);
404*404b540aSrobert }
405*404b540aSrobert #endif
406*404b540aSrobert 
407*404b540aSrobert 
WRAPPER2(size_t,strlen,const char * s)408*404b540aSrobert WRAPPER2(size_t, strlen, const char *s)
409*404b540aSrobert {
410*404b540aSrobert   size_t result = strlen (s);
411*404b540aSrobert   TRACE ("%s\n", __PRETTY_FUNCTION__);
412*404b540aSrobert   MF_VALIDATE_EXTENT(s, CLAMPADD(result, 1), __MF_CHECK_READ, "strlen region");
413*404b540aSrobert   return result;
414*404b540aSrobert }
415*404b540aSrobert 
416*404b540aSrobert 
WRAPPER2(size_t,strnlen,const char * s,size_t n)417*404b540aSrobert WRAPPER2(size_t, strnlen, const char *s, size_t n)
418*404b540aSrobert {
419*404b540aSrobert   size_t result = strnlen (s, n);
420*404b540aSrobert   TRACE ("%s\n", __PRETTY_FUNCTION__);
421*404b540aSrobert   MF_VALIDATE_EXTENT(s, result, __MF_CHECK_READ, "strnlen region");
422*404b540aSrobert   return result;
423*404b540aSrobert }
424*404b540aSrobert 
425*404b540aSrobert 
WRAPPER2(void,bzero,void * s,size_t n)426*404b540aSrobert WRAPPER2(void, bzero, void *s, size_t n)
427*404b540aSrobert {
428*404b540aSrobert   TRACE ("%s\n", __PRETTY_FUNCTION__);
429*404b540aSrobert   MF_VALIDATE_EXTENT(s, n, __MF_CHECK_WRITE, "bzero region");
430*404b540aSrobert   bzero (s, n);
431*404b540aSrobert }
432*404b540aSrobert 
433*404b540aSrobert 
434*404b540aSrobert #undef bcopy
WRAPPER2(void,bcopy,const void * src,void * dest,size_t n)435*404b540aSrobert WRAPPER2(void, bcopy, const void *src, void *dest, size_t n)
436*404b540aSrobert {
437*404b540aSrobert   TRACE ("%s\n", __PRETTY_FUNCTION__);
438*404b540aSrobert   MF_VALIDATE_EXTENT(src, n, __MF_CHECK_READ, "bcopy src");
439*404b540aSrobert   MF_VALIDATE_EXTENT(dest, n, __MF_CHECK_WRITE, "bcopy dest");
440*404b540aSrobert   bcopy (src, dest, n);
441*404b540aSrobert }
442*404b540aSrobert 
443*404b540aSrobert 
444*404b540aSrobert #undef bcmp
WRAPPER2(int,bcmp,const void * s1,const void * s2,size_t n)445*404b540aSrobert WRAPPER2(int, bcmp, const void *s1, const void *s2, size_t n)
446*404b540aSrobert {
447*404b540aSrobert   TRACE ("%s\n", __PRETTY_FUNCTION__);
448*404b540aSrobert   MF_VALIDATE_EXTENT(s1, n, __MF_CHECK_READ, "bcmp 1st arg");
449*404b540aSrobert   MF_VALIDATE_EXTENT(s2, n, __MF_CHECK_READ, "bcmp 2nd arg");
450*404b540aSrobert   return bcmp (s1, s2, n);
451*404b540aSrobert }
452*404b540aSrobert 
453*404b540aSrobert 
WRAPPER2(char *,index,const char * s,int c)454*404b540aSrobert WRAPPER2(char *, index, const char *s, int c)
455*404b540aSrobert {
456*404b540aSrobert   size_t n = strlen (s);
457*404b540aSrobert   TRACE ("%s\n", __PRETTY_FUNCTION__);
458*404b540aSrobert   MF_VALIDATE_EXTENT(s, CLAMPADD(n, 1), __MF_CHECK_READ, "index region");
459*404b540aSrobert   return index (s, c);
460*404b540aSrobert }
461*404b540aSrobert 
462*404b540aSrobert 
WRAPPER2(char *,rindex,const char * s,int c)463*404b540aSrobert WRAPPER2(char *, rindex, const char *s, int c)
464*404b540aSrobert {
465*404b540aSrobert   size_t n = strlen (s);
466*404b540aSrobert   TRACE ("%s\n", __PRETTY_FUNCTION__);
467*404b540aSrobert   MF_VALIDATE_EXTENT(s, CLAMPADD(n, 1), __MF_CHECK_READ, "rindex region");
468*404b540aSrobert   return rindex (s, c);
469*404b540aSrobert }
470*404b540aSrobert 
471*404b540aSrobert /* XXX:  stpcpy, memccpy */
472*404b540aSrobert 
473*404b540aSrobert /* XXX: *printf,*scanf */
474*404b540aSrobert 
475*404b540aSrobert /* XXX: setjmp, longjmp */
476*404b540aSrobert 
WRAPPER2(char *,asctime,struct tm * tm)477*404b540aSrobert WRAPPER2(char *, asctime, struct tm *tm)
478*404b540aSrobert {
479*404b540aSrobert   static char *reg_result = NULL;
480*404b540aSrobert   char *result;
481*404b540aSrobert   TRACE ("%s\n", __PRETTY_FUNCTION__);
482*404b540aSrobert   MF_VALIDATE_EXTENT(tm, sizeof (struct tm), __MF_CHECK_READ, "asctime tm");
483*404b540aSrobert   result = asctime (tm);
484*404b540aSrobert   if (reg_result == NULL)
485*404b540aSrobert     {
486*404b540aSrobert       __mf_register (result, strlen (result)+1, __MF_TYPE_STATIC, "asctime string");
487*404b540aSrobert       reg_result = result;
488*404b540aSrobert     }
489*404b540aSrobert   return result;
490*404b540aSrobert }
491*404b540aSrobert 
492*404b540aSrobert 
WRAPPER2(char *,ctime,const time_t * timep)493*404b540aSrobert WRAPPER2(char *, ctime, const time_t *timep)
494*404b540aSrobert {
495*404b540aSrobert   static char *reg_result = NULL;
496*404b540aSrobert   char *result;
497*404b540aSrobert   TRACE ("%s\n", __PRETTY_FUNCTION__);
498*404b540aSrobert   MF_VALIDATE_EXTENT(timep, sizeof (time_t), __MF_CHECK_READ, "ctime time");
499*404b540aSrobert   result = ctime (timep);
500*404b540aSrobert   if (reg_result == NULL)
501*404b540aSrobert     {
502*404b540aSrobert       /* XXX: what if asctime and ctime return the same static ptr? */
503*404b540aSrobert       __mf_register (result, strlen (result)+1, __MF_TYPE_STATIC, "ctime string");
504*404b540aSrobert       reg_result = result;
505*404b540aSrobert     }
506*404b540aSrobert   return result;
507*404b540aSrobert }
508*404b540aSrobert 
509*404b540aSrobert 
WRAPPER2(struct tm *,localtime,const time_t * timep)510*404b540aSrobert WRAPPER2(struct tm*, localtime, const time_t *timep)
511*404b540aSrobert {
512*404b540aSrobert   static struct tm *reg_result = NULL;
513*404b540aSrobert   struct tm *result;
514*404b540aSrobert   TRACE ("%s\n", __PRETTY_FUNCTION__);
515*404b540aSrobert   MF_VALIDATE_EXTENT(timep, sizeof (time_t), __MF_CHECK_READ, "localtime time");
516*404b540aSrobert   result = localtime (timep);
517*404b540aSrobert   if (reg_result == NULL)
518*404b540aSrobert     {
519*404b540aSrobert       __mf_register (result, sizeof (struct tm), __MF_TYPE_STATIC, "localtime tm");
520*404b540aSrobert       reg_result = result;
521*404b540aSrobert     }
522*404b540aSrobert   return result;
523*404b540aSrobert }
524*404b540aSrobert 
525*404b540aSrobert 
WRAPPER2(struct tm *,gmtime,const time_t * timep)526*404b540aSrobert WRAPPER2(struct tm*, gmtime, const time_t *timep)
527*404b540aSrobert {
528*404b540aSrobert   static struct tm *reg_result = NULL;
529*404b540aSrobert   struct tm *result;
530*404b540aSrobert   TRACE ("%s\n", __PRETTY_FUNCTION__);
531*404b540aSrobert   MF_VALIDATE_EXTENT(timep, sizeof (time_t), __MF_CHECK_READ, "gmtime time");
532*404b540aSrobert   result = gmtime (timep);
533*404b540aSrobert   if (reg_result == NULL)
534*404b540aSrobert     {
535*404b540aSrobert       __mf_register (result, sizeof (struct tm), __MF_TYPE_STATIC, "gmtime tm");
536*404b540aSrobert       reg_result = result;
537*404b540aSrobert     }
538*404b540aSrobert   return result;
539*404b540aSrobert }
540*404b540aSrobert 
541*404b540aSrobert 
542*404b540aSrobert /* EL start */
543*404b540aSrobert 
544*404b540aSrobert /* The following indicate if the result of the corresponding function
545*404b540aSrobert  * should be explicitly un/registered by the wrapper
546*404b540aSrobert */
547*404b540aSrobert 
548*404b540aSrobert #ifdef __FreeBSD__
549*404b540aSrobert #define MF_REGISTER_fopen		__MF_TYPE_STATIC
550*404b540aSrobert #else
551*404b540aSrobert #undef  MF_REGISTER_fopen
552*404b540aSrobert #endif
553*404b540aSrobert #define MF_RESULT_SIZE_fopen		(sizeof (FILE))
554*404b540aSrobert 
555*404b540aSrobert #undef  MF_REGISTER_opendir
556*404b540aSrobert #define MF_RESULT_SIZE_opendir		0	/* (sizeof (DIR)) */
557*404b540aSrobert #undef  MF_REGISTER_readdir
558*404b540aSrobert #define MF_REGISTER_gethostbyname	__MF_TYPE_STATIC
559*404b540aSrobert #undef  MF_REGISTER_gethostbyname_items
560*404b540aSrobert #undef  MF_REGISTER_dlopen
561*404b540aSrobert #undef  MF_REGISTER_dlerror
562*404b540aSrobert #undef  MF_REGISTER_dlsym
563*404b540aSrobert #define MF_REGISTER_shmat		__MF_TYPE_GUESS
564*404b540aSrobert 
565*404b540aSrobert 
566*404b540aSrobert #include <time.h>
WRAPPER2(time_t,time,time_t * timep)567*404b540aSrobert WRAPPER2(time_t, time, time_t *timep)
568*404b540aSrobert {
569*404b540aSrobert   TRACE ("%s\n", __PRETTY_FUNCTION__);
570*404b540aSrobert   if (NULL != timep)
571*404b540aSrobert     MF_VALIDATE_EXTENT (timep, sizeof (*timep), __MF_CHECK_WRITE,
572*404b540aSrobert       "time timep");
573*404b540aSrobert   return time (timep);
574*404b540aSrobert }
575*404b540aSrobert 
576*404b540aSrobert 
WRAPPER2(char *,strerror,int errnum)577*404b540aSrobert WRAPPER2(char *, strerror, int errnum)
578*404b540aSrobert {
579*404b540aSrobert   char *p;
580*404b540aSrobert   static char * last_strerror = NULL;
581*404b540aSrobert 
582*404b540aSrobert   TRACE ("%s\n", __PRETTY_FUNCTION__);
583*404b540aSrobert   p = strerror (errnum);
584*404b540aSrobert   if (last_strerror != NULL)
585*404b540aSrobert     __mf_unregister (last_strerror, 0, __MF_TYPE_STATIC);
586*404b540aSrobert   if (NULL != p)
587*404b540aSrobert     __mf_register (p, strlen (p) + 1, __MF_TYPE_STATIC, "strerror result");
588*404b540aSrobert   last_strerror = p;
589*404b540aSrobert   return p;
590*404b540aSrobert }
591*404b540aSrobert 
592*404b540aSrobert 
593*404b540aSrobert 
594*404b540aSrobert /* An auxiliary data structure for tracking the hand-made stdio
595*404b540aSrobert    buffers we generate during the fopen/fopen64 hooks.  In a civilized
596*404b540aSrobert    language, this would be a simple dynamically sized FILE*->char*
597*404b540aSrobert    lookup table, but this is C and we get to do it by hand.  */
598*404b540aSrobert struct mf_filebuffer
599*404b540aSrobert {
600*404b540aSrobert   FILE *file;
601*404b540aSrobert   char *buffer;
602*404b540aSrobert   struct mf_filebuffer *next;
603*404b540aSrobert };
604*404b540aSrobert static struct mf_filebuffer *mf_filebuffers = NULL;
605*404b540aSrobert 
606*404b540aSrobert static void
mkbuffer(FILE * f)607*404b540aSrobert mkbuffer (FILE *f)
608*404b540aSrobert {
609*404b540aSrobert   /* Reset any buffer automatically provided by libc, since this may
610*404b540aSrobert      have been done via mechanisms that libmudflap couldn't
611*404b540aSrobert      intercept.  */
612*404b540aSrobert   int rc;
613*404b540aSrobert   size_t bufsize = BUFSIZ;
614*404b540aSrobert   int bufmode;
615*404b540aSrobert   char *buffer = malloc (bufsize);
616*404b540aSrobert   struct mf_filebuffer *b = malloc (sizeof (struct mf_filebuffer));
617*404b540aSrobert   assert ((buffer != NULL) && (b != NULL));
618*404b540aSrobert 
619*404b540aSrobert   /* Link it into list.  */
620*404b540aSrobert   b->file = f;
621*404b540aSrobert   b->buffer = buffer;
622*404b540aSrobert   b->next = mf_filebuffers;
623*404b540aSrobert   mf_filebuffers = b;
624*404b540aSrobert 
625*404b540aSrobert   /* Determine how the file is supposed to be buffered at the moment.  */
626*404b540aSrobert   bufmode = fileno (f) == 2 ? _IONBF : (isatty (fileno (f)) ? _IOLBF : _IOFBF);
627*404b540aSrobert 
628*404b540aSrobert   rc = setvbuf (f, buffer, bufmode, bufsize);
629*404b540aSrobert   assert (rc == 0);
630*404b540aSrobert }
631*404b540aSrobert 
632*404b540aSrobert static void
unmkbuffer(FILE * f)633*404b540aSrobert unmkbuffer (FILE *f)
634*404b540aSrobert {
635*404b540aSrobert   struct mf_filebuffer *b = mf_filebuffers;
636*404b540aSrobert   struct mf_filebuffer **pb = & mf_filebuffers;
637*404b540aSrobert   while (b != NULL)
638*404b540aSrobert     {
639*404b540aSrobert       if (b->file == f)
640*404b540aSrobert         {
641*404b540aSrobert           *pb = b->next;
642*404b540aSrobert           free (b->buffer);
643*404b540aSrobert           free (b);
644*404b540aSrobert           return;
645*404b540aSrobert         }
646*404b540aSrobert       pb = & b->next;
647*404b540aSrobert       b = b->next;
648*404b540aSrobert     }
649*404b540aSrobert }
650*404b540aSrobert 
651*404b540aSrobert 
652*404b540aSrobert 
WRAPPER2(FILE *,fopen,const char * path,const char * mode)653*404b540aSrobert WRAPPER2(FILE *, fopen, const char *path, const char *mode)
654*404b540aSrobert {
655*404b540aSrobert   size_t n;
656*404b540aSrobert   FILE *p;
657*404b540aSrobert   TRACE ("%s\n", __PRETTY_FUNCTION__);
658*404b540aSrobert 
659*404b540aSrobert   n = strlen (path);
660*404b540aSrobert   MF_VALIDATE_EXTENT (path, CLAMPADD(n, 1), __MF_CHECK_READ, "fopen path");
661*404b540aSrobert 
662*404b540aSrobert   n = strlen (mode);
663*404b540aSrobert   MF_VALIDATE_EXTENT (mode, CLAMPADD(n, 1), __MF_CHECK_READ, "fopen mode");
664*404b540aSrobert 
665*404b540aSrobert   p = fopen (path, mode);
666*404b540aSrobert   if (NULL != p) {
667*404b540aSrobert #ifdef MF_REGISTER_fopen
668*404b540aSrobert     __mf_register (p, sizeof (*p), MF_REGISTER_fopen, "fopen result");
669*404b540aSrobert #endif
670*404b540aSrobert     MF_VALIDATE_EXTENT (p, sizeof (*p), __MF_CHECK_WRITE, "fopen result");
671*404b540aSrobert 
672*404b540aSrobert     mkbuffer (p);
673*404b540aSrobert   }
674*404b540aSrobert 
675*404b540aSrobert   return p;
676*404b540aSrobert }
677*404b540aSrobert 
678*404b540aSrobert 
WRAPPER2(int,setvbuf,FILE * stream,char * buf,int mode,size_t size)679*404b540aSrobert WRAPPER2(int, setvbuf, FILE *stream, char *buf, int mode, size_t size)
680*404b540aSrobert {
681*404b540aSrobert   int rc = 0;
682*404b540aSrobert   TRACE ("%s\n", __PRETTY_FUNCTION__);
683*404b540aSrobert 
684*404b540aSrobert   MF_VALIDATE_EXTENT (stream, sizeof (*stream), __MF_CHECK_WRITE, "setvbuf stream");
685*404b540aSrobert 
686*404b540aSrobert   unmkbuffer (stream);
687*404b540aSrobert 
688*404b540aSrobert   if (buf != NULL)
689*404b540aSrobert     MF_VALIDATE_EXTENT (buf, size, __MF_CHECK_WRITE, "setvbuf buffer");
690*404b540aSrobert 
691*404b540aSrobert   /* Override the user only if it's an auto-allocated buffer request.  Otherwise
692*404b540aSrobert      assume that the supplied buffer is already known to libmudflap.  */
693*404b540aSrobert   if ((buf == NULL) && ((mode == _IOFBF) || (mode == _IOLBF)))
694*404b540aSrobert     mkbuffer (stream);
695*404b540aSrobert   else
696*404b540aSrobert     rc = setvbuf (stream, buf, mode, size);
697*404b540aSrobert 
698*404b540aSrobert   return rc;
699*404b540aSrobert }
700*404b540aSrobert 
701*404b540aSrobert 
702*404b540aSrobert #ifdef HAVE_SETBUF
WRAPPER2(int,setbuf,FILE * stream,char * buf)703*404b540aSrobert WRAPPER2(int, setbuf, FILE* stream, char *buf)
704*404b540aSrobert {
705*404b540aSrobert   return __mfwrap_setvbuf (stream, buf, buf ? _IOFBF : _IONBF, BUFSIZ);
706*404b540aSrobert }
707*404b540aSrobert #endif
708*404b540aSrobert 
709*404b540aSrobert #ifdef HAVE_SETBUFFER
WRAPPER2(int,setbuffer,FILE * stream,char * buf,size_t sz)710*404b540aSrobert WRAPPER2(int, setbuffer, FILE* stream, char *buf, size_t sz)
711*404b540aSrobert {
712*404b540aSrobert   return __mfwrap_setvbuf (stream, buf, buf ? _IOFBF : _IONBF, sz);
713*404b540aSrobert }
714*404b540aSrobert #endif
715*404b540aSrobert 
716*404b540aSrobert #ifdef HAVE_SETLINEBUF
WRAPPER2(int,setlinebuf,FILE * stream)717*404b540aSrobert WRAPPER2(int, setlinebuf, FILE* stream)
718*404b540aSrobert {
719*404b540aSrobert   return __mfwrap_setvbuf(stream, NULL, _IOLBF, 0);
720*404b540aSrobert }
721*404b540aSrobert #endif
722*404b540aSrobert 
723*404b540aSrobert 
724*404b540aSrobert 
WRAPPER2(FILE *,fdopen,int fd,const char * mode)725*404b540aSrobert WRAPPER2(FILE *, fdopen, int fd, const char *mode)
726*404b540aSrobert {
727*404b540aSrobert   size_t n;
728*404b540aSrobert   FILE *p;
729*404b540aSrobert   TRACE ("%s\n", __PRETTY_FUNCTION__);
730*404b540aSrobert 
731*404b540aSrobert   n = strlen (mode);
732*404b540aSrobert   MF_VALIDATE_EXTENT (mode, CLAMPADD(n, 1), __MF_CHECK_READ, "fdopen mode");
733*404b540aSrobert 
734*404b540aSrobert   p = fdopen (fd, mode);
735*404b540aSrobert   if (NULL != p) {
736*404b540aSrobert #ifdef MF_REGISTER_fopen
737*404b540aSrobert     __mf_register (p, sizeof (*p), MF_REGISTER_fopen, "fdopen result");
738*404b540aSrobert #endif
739*404b540aSrobert     MF_VALIDATE_EXTENT (p, sizeof (*p), __MF_CHECK_WRITE, "fdopen result");
740*404b540aSrobert 
741*404b540aSrobert     mkbuffer (p);
742*404b540aSrobert   }
743*404b540aSrobert 
744*404b540aSrobert   return p;
745*404b540aSrobert }
746*404b540aSrobert 
747*404b540aSrobert 
WRAPPER2(FILE *,freopen,const char * path,const char * mode,FILE * s)748*404b540aSrobert WRAPPER2(FILE *, freopen, const char *path, const char *mode, FILE *s)
749*404b540aSrobert {
750*404b540aSrobert   size_t n;
751*404b540aSrobert   FILE *p;
752*404b540aSrobert   TRACE ("%s\n", __PRETTY_FUNCTION__);
753*404b540aSrobert 
754*404b540aSrobert   n = strlen (path);
755*404b540aSrobert   MF_VALIDATE_EXTENT (path, CLAMPADD(n, 1), __MF_CHECK_READ, "freopen path");
756*404b540aSrobert 
757*404b540aSrobert   MF_VALIDATE_EXTENT (s, (sizeof (*s)), __MF_CHECK_WRITE, "freopen stream");
758*404b540aSrobert   unmkbuffer (s);
759*404b540aSrobert 
760*404b540aSrobert   n = strlen (mode);
761*404b540aSrobert   MF_VALIDATE_EXTENT (mode, CLAMPADD(n, 1), __MF_CHECK_READ, "freopen mode");
762*404b540aSrobert 
763*404b540aSrobert   p = freopen (path, mode, s);
764*404b540aSrobert   if (NULL != p) {
765*404b540aSrobert #ifdef MF_REGISTER_fopen
766*404b540aSrobert     __mf_register (p, sizeof (*p), MF_REGISTER_fopen, "freopen result");
767*404b540aSrobert #endif
768*404b540aSrobert     MF_VALIDATE_EXTENT (p, sizeof (*p), __MF_CHECK_WRITE, "freopen result");
769*404b540aSrobert 
770*404b540aSrobert     mkbuffer (p);
771*404b540aSrobert   }
772*404b540aSrobert 
773*404b540aSrobert   return p;
774*404b540aSrobert }
775*404b540aSrobert 
776*404b540aSrobert 
777*404b540aSrobert #ifdef HAVE_FOPEN64
WRAPPER2(FILE *,fopen64,const char * path,const char * mode)778*404b540aSrobert WRAPPER2(FILE *, fopen64, const char *path, const char *mode)
779*404b540aSrobert {
780*404b540aSrobert   size_t n;
781*404b540aSrobert   FILE *p;
782*404b540aSrobert   TRACE ("%s\n", __PRETTY_FUNCTION__);
783*404b540aSrobert 
784*404b540aSrobert   n = strlen (path);
785*404b540aSrobert   MF_VALIDATE_EXTENT (path, CLAMPADD(n, 1), __MF_CHECK_READ, "fopen64 path");
786*404b540aSrobert 
787*404b540aSrobert   n = strlen (mode);
788*404b540aSrobert   MF_VALIDATE_EXTENT (mode, CLAMPADD(n, 1), __MF_CHECK_READ, "fopen64 mode");
789*404b540aSrobert 
790*404b540aSrobert   p = fopen64 (path, mode);
791*404b540aSrobert   if (NULL != p) {
792*404b540aSrobert #ifdef MF_REGISTER_fopen
793*404b540aSrobert     __mf_register (p, sizeof (*p), MF_REGISTER_fopen, "fopen64 result");
794*404b540aSrobert #endif
795*404b540aSrobert     MF_VALIDATE_EXTENT (p, sizeof (*p), __MF_CHECK_WRITE, "fopen64 result");
796*404b540aSrobert 
797*404b540aSrobert     mkbuffer (p);
798*404b540aSrobert   }
799*404b540aSrobert 
800*404b540aSrobert   return p;
801*404b540aSrobert }
802*404b540aSrobert #endif
803*404b540aSrobert 
804*404b540aSrobert 
805*404b540aSrobert #ifdef HAVE_FREOPEN64
WRAPPER2(FILE *,freopen64,const char * path,const char * mode,FILE * s)806*404b540aSrobert WRAPPER2(FILE *, freopen64, const char *path, const char *mode, FILE *s)
807*404b540aSrobert {
808*404b540aSrobert   size_t n;
809*404b540aSrobert   FILE *p;
810*404b540aSrobert   TRACE ("%s\n", __PRETTY_FUNCTION__);
811*404b540aSrobert 
812*404b540aSrobert   n = strlen (path);
813*404b540aSrobert   MF_VALIDATE_EXTENT (path, CLAMPADD(n, 1), __MF_CHECK_READ, "freopen64 path");
814*404b540aSrobert 
815*404b540aSrobert   MF_VALIDATE_EXTENT (s, (sizeof (*s)), __MF_CHECK_WRITE, "freopen64 stream");
816*404b540aSrobert   unmkbuffer (s);
817*404b540aSrobert 
818*404b540aSrobert   n = strlen (mode);
819*404b540aSrobert   MF_VALIDATE_EXTENT (mode, CLAMPADD(n, 1), __MF_CHECK_READ, "freopen64 mode");
820*404b540aSrobert 
821*404b540aSrobert   p = freopen (path, mode, s);
822*404b540aSrobert   if (NULL != p) {
823*404b540aSrobert #ifdef MF_REGISTER_fopen
824*404b540aSrobert     __mf_register (p, sizeof (*p), MF_REGISTER_fopen, "freopen64 result");
825*404b540aSrobert #endif
826*404b540aSrobert     MF_VALIDATE_EXTENT (p, sizeof (*p), __MF_CHECK_WRITE, "freopen64 result");
827*404b540aSrobert 
828*404b540aSrobert     mkbuffer (p);
829*404b540aSrobert   }
830*404b540aSrobert 
831*404b540aSrobert   return p;
832*404b540aSrobert }
833*404b540aSrobert #endif
834*404b540aSrobert 
835*404b540aSrobert 
WRAPPER2(int,fclose,FILE * stream)836*404b540aSrobert WRAPPER2(int, fclose, FILE *stream)
837*404b540aSrobert {
838*404b540aSrobert   int resp;
839*404b540aSrobert   TRACE ("%s\n", __PRETTY_FUNCTION__);
840*404b540aSrobert   MF_VALIDATE_EXTENT (stream, sizeof (*stream), __MF_CHECK_WRITE,
841*404b540aSrobert     "fclose stream");
842*404b540aSrobert   resp = fclose (stream);
843*404b540aSrobert #ifdef MF_REGISTER_fopen
844*404b540aSrobert   __mf_unregister (stream, sizeof (*stream), MF_REGISTER_fopen);
845*404b540aSrobert #endif
846*404b540aSrobert   unmkbuffer (stream);
847*404b540aSrobert 
848*404b540aSrobert   return resp;
849*404b540aSrobert }
850*404b540aSrobert 
851*404b540aSrobert 
WRAPPER2(size_t,fread,void * ptr,size_t size,size_t nmemb,FILE * stream)852*404b540aSrobert WRAPPER2(size_t, fread, void *ptr, size_t size, size_t nmemb, FILE *stream)
853*404b540aSrobert {
854*404b540aSrobert   TRACE ("%s\n", __PRETTY_FUNCTION__);
855*404b540aSrobert   MF_VALIDATE_EXTENT (stream, sizeof (*stream), __MF_CHECK_WRITE,
856*404b540aSrobert     "fread stream");
857*404b540aSrobert   MF_VALIDATE_EXTENT (ptr, size * nmemb, __MF_CHECK_WRITE, "fread buffer");
858*404b540aSrobert   return fread (ptr, size, nmemb, stream);
859*404b540aSrobert }
860*404b540aSrobert 
861*404b540aSrobert 
WRAPPER2(size_t,fwrite,const void * ptr,size_t size,size_t nmemb,FILE * stream)862*404b540aSrobert WRAPPER2(size_t, fwrite, const void *ptr, size_t size, size_t nmemb,
863*404b540aSrobert 	FILE *stream)
864*404b540aSrobert {
865*404b540aSrobert   TRACE ("%s\n", __PRETTY_FUNCTION__);
866*404b540aSrobert   MF_VALIDATE_EXTENT (stream, sizeof (*stream), __MF_CHECK_WRITE,
867*404b540aSrobert     "fwrite stream");
868*404b540aSrobert   MF_VALIDATE_EXTENT (ptr, size * nmemb, __MF_CHECK_READ, "fwrite buffer");
869*404b540aSrobert   return fwrite (ptr, size, nmemb, stream);
870*404b540aSrobert }
871*404b540aSrobert 
872*404b540aSrobert 
WRAPPER2(int,fgetc,FILE * stream)873*404b540aSrobert WRAPPER2(int, fgetc, FILE *stream)
874*404b540aSrobert {
875*404b540aSrobert   TRACE ("%s\n", __PRETTY_FUNCTION__);
876*404b540aSrobert   MF_VALIDATE_EXTENT (stream, sizeof (*stream), __MF_CHECK_WRITE,
877*404b540aSrobert     "fgetc stream");
878*404b540aSrobert   return fgetc (stream);
879*404b540aSrobert }
880*404b540aSrobert 
881*404b540aSrobert 
WRAPPER2(char *,fgets,char * s,int size,FILE * stream)882*404b540aSrobert WRAPPER2(char *, fgets, char *s, int size, FILE *stream)
883*404b540aSrobert {
884*404b540aSrobert   TRACE ("%s\n", __PRETTY_FUNCTION__);
885*404b540aSrobert   MF_VALIDATE_EXTENT (stream, sizeof (*stream), __MF_CHECK_WRITE,
886*404b540aSrobert     "fgets stream");
887*404b540aSrobert   MF_VALIDATE_EXTENT (s, size, __MF_CHECK_WRITE, "fgets buffer");
888*404b540aSrobert   return fgets (s, size, stream);
889*404b540aSrobert }
890*404b540aSrobert 
891*404b540aSrobert 
WRAPPER2(int,getc,FILE * stream)892*404b540aSrobert WRAPPER2(int, getc, FILE *stream)
893*404b540aSrobert {
894*404b540aSrobert   TRACE ("%s\n", __PRETTY_FUNCTION__);
895*404b540aSrobert   MF_VALIDATE_EXTENT (stream, sizeof (*stream), __MF_CHECK_WRITE,
896*404b540aSrobert     "getc stream");
897*404b540aSrobert   return getc (stream);
898*404b540aSrobert }
899*404b540aSrobert 
900*404b540aSrobert 
WRAPPER2(char *,gets,char * s)901*404b540aSrobert WRAPPER2(char *, gets, char *s)
902*404b540aSrobert {
903*404b540aSrobert   TRACE ("%s\n", __PRETTY_FUNCTION__);
904*404b540aSrobert   MF_VALIDATE_EXTENT (s, 1, __MF_CHECK_WRITE, "gets buffer");
905*404b540aSrobert   /* Avoid link-time warning... */
906*404b540aSrobert   s = fgets (s, INT_MAX, stdin);
907*404b540aSrobert   if (NULL != s) {	/* better late than never */
908*404b540aSrobert     size_t n = strlen (s);
909*404b540aSrobert     MF_VALIDATE_EXTENT (s, CLAMPADD(n, 1), __MF_CHECK_WRITE, "gets buffer");
910*404b540aSrobert   }
911*404b540aSrobert   return s;
912*404b540aSrobert }
913*404b540aSrobert 
914*404b540aSrobert 
WRAPPER2(int,ungetc,int c,FILE * stream)915*404b540aSrobert WRAPPER2(int, ungetc, int c, FILE *stream)
916*404b540aSrobert {
917*404b540aSrobert   TRACE ("%s\n", __PRETTY_FUNCTION__);
918*404b540aSrobert   MF_VALIDATE_EXTENT (stream, sizeof (*stream), __MF_CHECK_WRITE,
919*404b540aSrobert      "ungetc stream");
920*404b540aSrobert   return ungetc (c, stream);
921*404b540aSrobert }
922*404b540aSrobert 
923*404b540aSrobert 
WRAPPER2(int,fputc,int c,FILE * stream)924*404b540aSrobert WRAPPER2(int, fputc, int c, FILE *stream)
925*404b540aSrobert {
926*404b540aSrobert   TRACE ("%s\n", __PRETTY_FUNCTION__);
927*404b540aSrobert   MF_VALIDATE_EXTENT (stream, sizeof (*stream), __MF_CHECK_WRITE,
928*404b540aSrobert     "fputc stream");
929*404b540aSrobert   return fputc (c, stream);
930*404b540aSrobert }
931*404b540aSrobert 
932*404b540aSrobert 
WRAPPER2(int,fputs,const char * s,FILE * stream)933*404b540aSrobert WRAPPER2(int, fputs, const char *s, FILE *stream)
934*404b540aSrobert {
935*404b540aSrobert   size_t n;
936*404b540aSrobert   TRACE ("%s\n", __PRETTY_FUNCTION__);
937*404b540aSrobert   n = strlen (s);
938*404b540aSrobert   MF_VALIDATE_EXTENT (s, CLAMPADD(n, 1), __MF_CHECK_READ, "fputs buffer");
939*404b540aSrobert   MF_VALIDATE_EXTENT (stream, sizeof (*stream), __MF_CHECK_WRITE,
940*404b540aSrobert     "fputs stream");
941*404b540aSrobert   return fputs (s, stream);
942*404b540aSrobert }
943*404b540aSrobert 
944*404b540aSrobert 
WRAPPER2(int,putc,int c,FILE * stream)945*404b540aSrobert WRAPPER2(int, putc, int c, FILE *stream)
946*404b540aSrobert {
947*404b540aSrobert   TRACE ("%s\n", __PRETTY_FUNCTION__);
948*404b540aSrobert   MF_VALIDATE_EXTENT (stream, sizeof (*stream), __MF_CHECK_WRITE,
949*404b540aSrobert     "putc stream");
950*404b540aSrobert   return putc (c, stream);
951*404b540aSrobert }
952*404b540aSrobert 
953*404b540aSrobert 
WRAPPER2(int,puts,const char * s)954*404b540aSrobert WRAPPER2(int, puts, const char *s)
955*404b540aSrobert {
956*404b540aSrobert   size_t n;
957*404b540aSrobert   TRACE ("%s\n", __PRETTY_FUNCTION__);
958*404b540aSrobert   n = strlen (s);
959*404b540aSrobert   MF_VALIDATE_EXTENT (s, CLAMPADD(n, 1), __MF_CHECK_READ, "puts buffer");
960*404b540aSrobert   return puts (s);
961*404b540aSrobert }
962*404b540aSrobert 
963*404b540aSrobert 
WRAPPER2(void,clearerr,FILE * stream)964*404b540aSrobert WRAPPER2(void, clearerr, FILE *stream)
965*404b540aSrobert {
966*404b540aSrobert   TRACE ("%s\n", __PRETTY_FUNCTION__);
967*404b540aSrobert   MF_VALIDATE_EXTENT (stream, sizeof (*stream), __MF_CHECK_WRITE,
968*404b540aSrobert     "clearerr stream");
969*404b540aSrobert   clearerr (stream);
970*404b540aSrobert }
971*404b540aSrobert 
972*404b540aSrobert 
WRAPPER2(int,feof,FILE * stream)973*404b540aSrobert WRAPPER2(int, feof, FILE *stream)
974*404b540aSrobert {
975*404b540aSrobert   TRACE ("%s\n", __PRETTY_FUNCTION__);
976*404b540aSrobert   MF_VALIDATE_EXTENT (stream, sizeof (*stream), __MF_CHECK_WRITE,
977*404b540aSrobert     "feof stream");
978*404b540aSrobert   return feof (stream);
979*404b540aSrobert }
980*404b540aSrobert 
981*404b540aSrobert 
WRAPPER2(int,ferror,FILE * stream)982*404b540aSrobert WRAPPER2(int, ferror, FILE *stream)
983*404b540aSrobert {
984*404b540aSrobert   TRACE ("%s\n", __PRETTY_FUNCTION__);
985*404b540aSrobert   MF_VALIDATE_EXTENT (stream, sizeof (*stream), __MF_CHECK_WRITE,
986*404b540aSrobert     "ferror stream");
987*404b540aSrobert   return ferror (stream);
988*404b540aSrobert }
989*404b540aSrobert 
990*404b540aSrobert 
WRAPPER2(int,fileno,FILE * stream)991*404b540aSrobert WRAPPER2(int, fileno, FILE *stream)
992*404b540aSrobert {
993*404b540aSrobert   TRACE ("%s\n", __PRETTY_FUNCTION__);
994*404b540aSrobert   MF_VALIDATE_EXTENT (stream, sizeof (*stream), __MF_CHECK_WRITE,
995*404b540aSrobert     "fileno stream");
996*404b540aSrobert   return fileno (stream);
997*404b540aSrobert }
998*404b540aSrobert 
999*404b540aSrobert 
WRAPPER2(int,printf,const char * format,...)1000*404b540aSrobert WRAPPER2(int, printf, const char *format, ...)
1001*404b540aSrobert {
1002*404b540aSrobert   size_t n;
1003*404b540aSrobert   va_list ap;
1004*404b540aSrobert   int result;
1005*404b540aSrobert   TRACE ("%s\n", __PRETTY_FUNCTION__);
1006*404b540aSrobert   n = strlen (format);
1007*404b540aSrobert   MF_VALIDATE_EXTENT (format, CLAMPADD(n, 1), __MF_CHECK_READ,
1008*404b540aSrobert     "printf format");
1009*404b540aSrobert   va_start (ap, format);
1010*404b540aSrobert   result = vprintf (format, ap);
1011*404b540aSrobert   va_end (ap);
1012*404b540aSrobert   return result;
1013*404b540aSrobert }
1014*404b540aSrobert 
1015*404b540aSrobert 
WRAPPER2(int,fprintf,FILE * stream,const char * format,...)1016*404b540aSrobert WRAPPER2(int, fprintf, FILE *stream, const char *format, ...)
1017*404b540aSrobert {
1018*404b540aSrobert   size_t n;
1019*404b540aSrobert   va_list ap;
1020*404b540aSrobert   int result;
1021*404b540aSrobert   TRACE ("%s\n", __PRETTY_FUNCTION__);
1022*404b540aSrobert   MF_VALIDATE_EXTENT (stream, sizeof (*stream), __MF_CHECK_WRITE,
1023*404b540aSrobert     "fprintf stream");
1024*404b540aSrobert   n = strlen (format);
1025*404b540aSrobert   MF_VALIDATE_EXTENT (format, CLAMPADD(n, 1), __MF_CHECK_READ,
1026*404b540aSrobert     "fprintf format");
1027*404b540aSrobert   va_start (ap, format);
1028*404b540aSrobert   result = vfprintf (stream, format, ap);
1029*404b540aSrobert   va_end (ap);
1030*404b540aSrobert   return result;
1031*404b540aSrobert }
1032*404b540aSrobert 
1033*404b540aSrobert 
WRAPPER2(int,sprintf,char * str,const char * format,...)1034*404b540aSrobert WRAPPER2(int, sprintf, char *str, const char *format, ...)
1035*404b540aSrobert {
1036*404b540aSrobert   size_t n;
1037*404b540aSrobert   va_list ap;
1038*404b540aSrobert   int result;
1039*404b540aSrobert   TRACE ("%s\n", __PRETTY_FUNCTION__);
1040*404b540aSrobert   MF_VALIDATE_EXTENT (str, 1, __MF_CHECK_WRITE, "sprintf str");
1041*404b540aSrobert   n = strlen (format);
1042*404b540aSrobert   MF_VALIDATE_EXTENT (format, CLAMPADD(n, 1), __MF_CHECK_READ,
1043*404b540aSrobert     "sprintf format");
1044*404b540aSrobert   va_start (ap, format);
1045*404b540aSrobert   result = vsprintf (str, format, ap);
1046*404b540aSrobert   va_end (ap);
1047*404b540aSrobert   n = strlen (str);
1048*404b540aSrobert   MF_VALIDATE_EXTENT (str, CLAMPADD(n, 1), __MF_CHECK_WRITE, "sprintf str");
1049*404b540aSrobert   return result;
1050*404b540aSrobert }
1051*404b540aSrobert 
1052*404b540aSrobert 
WRAPPER2(int,snprintf,char * str,size_t size,const char * format,...)1053*404b540aSrobert WRAPPER2(int, snprintf, char *str, size_t size, const char *format, ...)
1054*404b540aSrobert {
1055*404b540aSrobert   size_t n;
1056*404b540aSrobert   va_list ap;
1057*404b540aSrobert   int result;
1058*404b540aSrobert   TRACE ("%s\n", __PRETTY_FUNCTION__);
1059*404b540aSrobert   MF_VALIDATE_EXTENT (str, size, __MF_CHECK_WRITE, "snprintf str");
1060*404b540aSrobert   n = strlen (format);
1061*404b540aSrobert   MF_VALIDATE_EXTENT (format, CLAMPADD(n, 1), __MF_CHECK_READ,
1062*404b540aSrobert     "snprintf format");
1063*404b540aSrobert   va_start (ap, format);
1064*404b540aSrobert   result = vsnprintf (str, size, format, ap);
1065*404b540aSrobert   va_end (ap);
1066*404b540aSrobert   return result;
1067*404b540aSrobert }
1068*404b540aSrobert 
1069*404b540aSrobert 
WRAPPER2(int,vprintf,const char * format,va_list ap)1070*404b540aSrobert WRAPPER2(int, vprintf,  const char *format, va_list ap)
1071*404b540aSrobert {
1072*404b540aSrobert   size_t n;
1073*404b540aSrobert   TRACE ("%s\n", __PRETTY_FUNCTION__);
1074*404b540aSrobert   n = strlen (format);
1075*404b540aSrobert   MF_VALIDATE_EXTENT (format, CLAMPADD(n, 1), __MF_CHECK_READ,
1076*404b540aSrobert     "vprintf format");
1077*404b540aSrobert   return vprintf (format, ap);
1078*404b540aSrobert }
1079*404b540aSrobert 
1080*404b540aSrobert 
WRAPPER2(int,vfprintf,FILE * stream,const char * format,va_list ap)1081*404b540aSrobert WRAPPER2(int, vfprintf, FILE *stream, const char *format, va_list ap)
1082*404b540aSrobert {
1083*404b540aSrobert   size_t n;
1084*404b540aSrobert   TRACE ("%s\n", __PRETTY_FUNCTION__);
1085*404b540aSrobert   MF_VALIDATE_EXTENT (stream, sizeof (*stream), __MF_CHECK_WRITE,
1086*404b540aSrobert     "vfprintf stream");
1087*404b540aSrobert   n = strlen (format);
1088*404b540aSrobert   MF_VALIDATE_EXTENT (format, CLAMPADD(n, 1), __MF_CHECK_READ,
1089*404b540aSrobert     "vfprintf format");
1090*404b540aSrobert   return vfprintf (stream, format, ap);
1091*404b540aSrobert }
1092*404b540aSrobert 
1093*404b540aSrobert 
WRAPPER2(int,vsprintf,char * str,const char * format,va_list ap)1094*404b540aSrobert WRAPPER2(int, vsprintf, char *str, const char *format, va_list ap)
1095*404b540aSrobert {
1096*404b540aSrobert   size_t n;
1097*404b540aSrobert   int result;
1098*404b540aSrobert   TRACE ("%s\n", __PRETTY_FUNCTION__);
1099*404b540aSrobert   MF_VALIDATE_EXTENT (str, 1, __MF_CHECK_WRITE, "vsprintf str");
1100*404b540aSrobert   n = strlen (format);
1101*404b540aSrobert   MF_VALIDATE_EXTENT (format, CLAMPADD(n, 1), __MF_CHECK_READ,
1102*404b540aSrobert     "vsprintf format");
1103*404b540aSrobert   result = vsprintf (str, format, ap);
1104*404b540aSrobert   n = strlen (str);
1105*404b540aSrobert   MF_VALIDATE_EXTENT (str, CLAMPADD(n, 1), __MF_CHECK_WRITE, "vsprintf str");
1106*404b540aSrobert   return result;
1107*404b540aSrobert }
1108*404b540aSrobert 
1109*404b540aSrobert 
WRAPPER2(int,vsnprintf,char * str,size_t size,const char * format,va_list ap)1110*404b540aSrobert WRAPPER2(int, vsnprintf, char *str, size_t size, const char *format,
1111*404b540aSrobert 	va_list ap)
1112*404b540aSrobert {
1113*404b540aSrobert   size_t n;
1114*404b540aSrobert   TRACE ("%s\n", __PRETTY_FUNCTION__);
1115*404b540aSrobert   MF_VALIDATE_EXTENT (str, size, __MF_CHECK_WRITE, "vsnprintf str");
1116*404b540aSrobert   n = strlen (format);
1117*404b540aSrobert   MF_VALIDATE_EXTENT (format, CLAMPADD(n, 1), __MF_CHECK_READ,
1118*404b540aSrobert     "vsnprintf format");
1119*404b540aSrobert   return vsnprintf (str, size, format, ap);
1120*404b540aSrobert }
1121*404b540aSrobert 
1122*404b540aSrobert 
WRAPPER2(int,access,const char * path,int mode)1123*404b540aSrobert WRAPPER2(int , access, const char *path, int mode)
1124*404b540aSrobert {
1125*404b540aSrobert   size_t n;
1126*404b540aSrobert   TRACE ("%s\n", __PRETTY_FUNCTION__);
1127*404b540aSrobert   n = strlen (path);
1128*404b540aSrobert   MF_VALIDATE_EXTENT (path, CLAMPADD(n, 1), __MF_CHECK_READ, "access path");
1129*404b540aSrobert   return access (path, mode);
1130*404b540aSrobert }
1131*404b540aSrobert 
1132*404b540aSrobert 
WRAPPER2(int,remove,const char * path)1133*404b540aSrobert WRAPPER2(int , remove, const char *path)
1134*404b540aSrobert {
1135*404b540aSrobert   size_t n;
1136*404b540aSrobert   TRACE ("%s\n", __PRETTY_FUNCTION__);
1137*404b540aSrobert   n = strlen (path);
1138*404b540aSrobert   MF_VALIDATE_EXTENT (path, CLAMPADD(n, 1), __MF_CHECK_READ, "remove path");
1139*404b540aSrobert   return remove (path);
1140*404b540aSrobert }
1141*404b540aSrobert 
1142*404b540aSrobert 
WRAPPER2(int,fflush,FILE * stream)1143*404b540aSrobert WRAPPER2(int, fflush, FILE *stream)
1144*404b540aSrobert {
1145*404b540aSrobert   TRACE ("%s\n", __PRETTY_FUNCTION__);
1146*404b540aSrobert   if (stream != NULL)
1147*404b540aSrobert     MF_VALIDATE_EXTENT (stream, sizeof (*stream), __MF_CHECK_WRITE,
1148*404b540aSrobert                         "fflush stream");
1149*404b540aSrobert   return fflush (stream);
1150*404b540aSrobert }
1151*404b540aSrobert 
1152*404b540aSrobert 
WRAPPER2(int,fseek,FILE * stream,long offset,int whence)1153*404b540aSrobert WRAPPER2(int, fseek, FILE *stream, long offset, int whence)
1154*404b540aSrobert {
1155*404b540aSrobert   TRACE ("%s\n", __PRETTY_FUNCTION__);
1156*404b540aSrobert   MF_VALIDATE_EXTENT (stream, sizeof (*stream), __MF_CHECK_WRITE,
1157*404b540aSrobert     "fseek stream");
1158*404b540aSrobert   return fseek (stream, offset, whence);
1159*404b540aSrobert }
1160*404b540aSrobert 
1161*404b540aSrobert 
1162*404b540aSrobert #ifdef HAVE_FSEEKO64
WRAPPER2(int,fseeko64,FILE * stream,off64_t offset,int whence)1163*404b540aSrobert WRAPPER2(int, fseeko64, FILE *stream, off64_t offset, int whence)
1164*404b540aSrobert {
1165*404b540aSrobert   TRACE ("%s\n", __PRETTY_FUNCTION__);
1166*404b540aSrobert   MF_VALIDATE_EXTENT (stream, sizeof (*stream), __MF_CHECK_WRITE,
1167*404b540aSrobert     "fseeko64 stream");
1168*404b540aSrobert   return fseeko64 (stream, offset, whence);
1169*404b540aSrobert }
1170*404b540aSrobert #endif
1171*404b540aSrobert 
1172*404b540aSrobert 
WRAPPER2(long,ftell,FILE * stream)1173*404b540aSrobert WRAPPER2(long, ftell, FILE *stream)
1174*404b540aSrobert {
1175*404b540aSrobert   TRACE ("%s\n", __PRETTY_FUNCTION__);
1176*404b540aSrobert   MF_VALIDATE_EXTENT (stream, sizeof (*stream), __MF_CHECK_WRITE,
1177*404b540aSrobert     "ftell stream");
1178*404b540aSrobert   return ftell (stream);
1179*404b540aSrobert }
1180*404b540aSrobert 
1181*404b540aSrobert 
1182*404b540aSrobert #ifdef HAVE_FTELLO64
WRAPPER2(off64_t,ftello64,FILE * stream)1183*404b540aSrobert WRAPPER2(off64_t, ftello64, FILE *stream)
1184*404b540aSrobert {
1185*404b540aSrobert   TRACE ("%s\n", __PRETTY_FUNCTION__);
1186*404b540aSrobert   MF_VALIDATE_EXTENT (stream, sizeof (*stream), __MF_CHECK_WRITE,
1187*404b540aSrobert     "ftello64 stream");
1188*404b540aSrobert   return ftello64 (stream);
1189*404b540aSrobert }
1190*404b540aSrobert #endif
1191*404b540aSrobert 
1192*404b540aSrobert 
WRAPPER2(void,rewind,FILE * stream)1193*404b540aSrobert WRAPPER2(void, rewind, FILE *stream)
1194*404b540aSrobert {
1195*404b540aSrobert   TRACE ("%s\n", __PRETTY_FUNCTION__);
1196*404b540aSrobert   MF_VALIDATE_EXTENT (stream, sizeof (*stream), __MF_CHECK_WRITE,
1197*404b540aSrobert     "rewind stream");
1198*404b540aSrobert   rewind (stream);
1199*404b540aSrobert }
1200*404b540aSrobert 
1201*404b540aSrobert 
WRAPPER2(int,fgetpos,FILE * stream,fpos_t * pos)1202*404b540aSrobert WRAPPER2(int, fgetpos, FILE *stream, fpos_t *pos)
1203*404b540aSrobert {
1204*404b540aSrobert   TRACE ("%s\n", __PRETTY_FUNCTION__);
1205*404b540aSrobert   MF_VALIDATE_EXTENT (stream, sizeof (*stream), __MF_CHECK_WRITE,
1206*404b540aSrobert     "fgetpos stream");
1207*404b540aSrobert   MF_VALIDATE_EXTENT (pos, sizeof (*pos), __MF_CHECK_WRITE, "fgetpos pos");
1208*404b540aSrobert   return fgetpos (stream, pos);
1209*404b540aSrobert }
1210*404b540aSrobert 
1211*404b540aSrobert 
WRAPPER2(int,fsetpos,FILE * stream,fpos_t * pos)1212*404b540aSrobert WRAPPER2(int, fsetpos, FILE *stream, fpos_t *pos)
1213*404b540aSrobert {
1214*404b540aSrobert   TRACE ("%s\n", __PRETTY_FUNCTION__);
1215*404b540aSrobert   MF_VALIDATE_EXTENT (stream, sizeof (*stream), __MF_CHECK_WRITE,
1216*404b540aSrobert     "fsetpos stream");
1217*404b540aSrobert   MF_VALIDATE_EXTENT (pos, sizeof (*pos), __MF_CHECK_READ, "fsetpos pos");
1218*404b540aSrobert   return fsetpos (stream, pos);
1219*404b540aSrobert }
1220*404b540aSrobert 
1221*404b540aSrobert 
WRAPPER2(int,stat,const char * path,struct stat * buf)1222*404b540aSrobert WRAPPER2(int , stat, const char *path, struct stat *buf)
1223*404b540aSrobert {
1224*404b540aSrobert   size_t n;
1225*404b540aSrobert   TRACE ("%s\n", __PRETTY_FUNCTION__);
1226*404b540aSrobert   n = strlen (path);
1227*404b540aSrobert   MF_VALIDATE_EXTENT (path, CLAMPADD(n, 1), __MF_CHECK_READ, "stat path");
1228*404b540aSrobert   MF_VALIDATE_EXTENT (buf, sizeof (*buf), __MF_CHECK_READ, "stat buf");
1229*404b540aSrobert   return stat (path, buf);
1230*404b540aSrobert }
1231*404b540aSrobert 
1232*404b540aSrobert 
1233*404b540aSrobert #ifdef HAVE_STAT64
WRAPPER2(int,stat64,const char * path,struct stat64 * buf)1234*404b540aSrobert WRAPPER2(int , stat64, const char *path, struct stat64 *buf)
1235*404b540aSrobert {
1236*404b540aSrobert   size_t n;
1237*404b540aSrobert   TRACE ("%s\n", __PRETTY_FUNCTION__);
1238*404b540aSrobert   n = strlen (path);
1239*404b540aSrobert   MF_VALIDATE_EXTENT (path, CLAMPADD(n, 1), __MF_CHECK_READ, "stat64 path");
1240*404b540aSrobert   MF_VALIDATE_EXTENT (buf, sizeof (*buf), __MF_CHECK_READ, "stat64 buf");
1241*404b540aSrobert   return stat64 (path, buf);
1242*404b540aSrobert }
1243*404b540aSrobert #endif
1244*404b540aSrobert 
1245*404b540aSrobert 
WRAPPER2(int,fstat,int filedes,struct stat * buf)1246*404b540aSrobert WRAPPER2(int , fstat, int filedes, struct stat *buf)
1247*404b540aSrobert {
1248*404b540aSrobert   TRACE ("%s\n", __PRETTY_FUNCTION__);
1249*404b540aSrobert   MF_VALIDATE_EXTENT (buf, sizeof (*buf), __MF_CHECK_READ, "fstat buf");
1250*404b540aSrobert   return fstat (filedes, buf);
1251*404b540aSrobert }
1252*404b540aSrobert 
1253*404b540aSrobert 
WRAPPER2(int,lstat,const char * path,struct stat * buf)1254*404b540aSrobert WRAPPER2(int , lstat, const char *path, struct stat *buf)
1255*404b540aSrobert {
1256*404b540aSrobert   size_t n;
1257*404b540aSrobert   TRACE ("%s\n", __PRETTY_FUNCTION__);
1258*404b540aSrobert   n = strlen (path);
1259*404b540aSrobert   MF_VALIDATE_EXTENT (path, CLAMPADD(n, 1), __MF_CHECK_READ, "lstat path");
1260*404b540aSrobert   MF_VALIDATE_EXTENT (buf, sizeof (*buf), __MF_CHECK_READ, "lstat buf");
1261*404b540aSrobert   return lstat (path, buf);
1262*404b540aSrobert }
1263*404b540aSrobert 
1264*404b540aSrobert 
WRAPPER2(int,mkfifo,const char * path,mode_t mode)1265*404b540aSrobert WRAPPER2(int , mkfifo, const char *path, mode_t mode)
1266*404b540aSrobert {
1267*404b540aSrobert   size_t n;
1268*404b540aSrobert   TRACE ("%s\n", __PRETTY_FUNCTION__);
1269*404b540aSrobert   n = strlen (path);
1270*404b540aSrobert   MF_VALIDATE_EXTENT (path, CLAMPADD(n, 1), __MF_CHECK_READ, "mkfifo path");
1271*404b540aSrobert   return mkfifo (path, mode);
1272*404b540aSrobert }
1273*404b540aSrobert 
1274*404b540aSrobert 
1275*404b540aSrobert #ifdef HAVE_DIRENT_H
WRAPPER2(DIR *,opendir,const char * path)1276*404b540aSrobert WRAPPER2(DIR *, opendir, const char *path)
1277*404b540aSrobert {
1278*404b540aSrobert   DIR *p;
1279*404b540aSrobert   size_t n;
1280*404b540aSrobert   TRACE ("%s\n", __PRETTY_FUNCTION__);
1281*404b540aSrobert   n = strlen (path);
1282*404b540aSrobert   MF_VALIDATE_EXTENT (path, CLAMPADD(n, 1), __MF_CHECK_READ, "opendir path");
1283*404b540aSrobert 
1284*404b540aSrobert   p = opendir (path);
1285*404b540aSrobert   if (NULL != p) {
1286*404b540aSrobert #ifdef MF_REGISTER_opendir
1287*404b540aSrobert     __mf_register (p, MF_RESULT_SIZE_opendir, MF_REGISTER_opendir,
1288*404b540aSrobert       "opendir result");
1289*404b540aSrobert #endif
1290*404b540aSrobert     MF_VALIDATE_EXTENT (p, MF_RESULT_SIZE_opendir, __MF_CHECK_WRITE,
1291*404b540aSrobert       "opendir result");
1292*404b540aSrobert   }
1293*404b540aSrobert   return p;
1294*404b540aSrobert }
1295*404b540aSrobert 
1296*404b540aSrobert 
WRAPPER2(int,closedir,DIR * dir)1297*404b540aSrobert WRAPPER2(int, closedir, DIR *dir)
1298*404b540aSrobert {
1299*404b540aSrobert   TRACE ("%s\n", __PRETTY_FUNCTION__);
1300*404b540aSrobert   MF_VALIDATE_EXTENT (dir, 0, __MF_CHECK_WRITE, "closedir dir");
1301*404b540aSrobert #ifdef MF_REGISTER_opendir
1302*404b540aSrobert   __mf_unregister (dir, MF_RESULT_SIZE_opendir, MF_REGISTER_opendir);
1303*404b540aSrobert #endif
1304*404b540aSrobert   return closedir (dir);
1305*404b540aSrobert }
1306*404b540aSrobert 
1307*404b540aSrobert 
WRAPPER2(struct dirent *,readdir,DIR * dir)1308*404b540aSrobert WRAPPER2(struct dirent *, readdir, DIR *dir)
1309*404b540aSrobert {
1310*404b540aSrobert   struct dirent *p;
1311*404b540aSrobert   TRACE ("%s\n", __PRETTY_FUNCTION__);
1312*404b540aSrobert   MF_VALIDATE_EXTENT (dir, 0, __MF_CHECK_READ, "readdir dir");
1313*404b540aSrobert   p = readdir (dir);
1314*404b540aSrobert   if (NULL != p) {
1315*404b540aSrobert #ifdef MF_REGISTER_readdir
1316*404b540aSrobert     __mf_register (p, sizeof (*p), MF_REGISTER_readdir, "readdir result");
1317*404b540aSrobert #endif
1318*404b540aSrobert     MF_VALIDATE_EXTENT (p, sizeof (*p), __MF_CHECK_WRITE, "readdir result");
1319*404b540aSrobert   }
1320*404b540aSrobert   return p;
1321*404b540aSrobert }
1322*404b540aSrobert #endif
1323*404b540aSrobert 
1324*404b540aSrobert 
1325*404b540aSrobert #ifdef HAVE_SYS_SOCKET_H
1326*404b540aSrobert 
WRAPPER2(int,recv,int s,void * buf,size_t len,int flags)1327*404b540aSrobert WRAPPER2(int, recv, int s, void *buf, size_t len, int flags)
1328*404b540aSrobert {
1329*404b540aSrobert   TRACE ("%s\n", __PRETTY_FUNCTION__);
1330*404b540aSrobert   MF_VALIDATE_EXTENT (buf, len, __MF_CHECK_WRITE, "recv buf");
1331*404b540aSrobert   return recv (s, buf, len, flags);
1332*404b540aSrobert }
1333*404b540aSrobert 
1334*404b540aSrobert 
WRAPPER2(int,recvfrom,int s,void * buf,size_t len,int flags,struct sockaddr * from,socklen_t * fromlen)1335*404b540aSrobert WRAPPER2(int, recvfrom, int s, void *buf, size_t len, int flags,
1336*404b540aSrobert 		struct sockaddr *from, socklen_t *fromlen)
1337*404b540aSrobert {
1338*404b540aSrobert   TRACE ("%s\n", __PRETTY_FUNCTION__);
1339*404b540aSrobert   MF_VALIDATE_EXTENT (buf, len, __MF_CHECK_WRITE, "recvfrom buf");
1340*404b540aSrobert   MF_VALIDATE_EXTENT (from, (size_t)*fromlen, __MF_CHECK_WRITE,
1341*404b540aSrobert     "recvfrom from");
1342*404b540aSrobert   return recvfrom (s, buf, len, flags, from, fromlen);
1343*404b540aSrobert }
1344*404b540aSrobert 
1345*404b540aSrobert 
WRAPPER2(int,recvmsg,int s,struct msghdr * msg,int flags)1346*404b540aSrobert WRAPPER2(int, recvmsg, int s, struct msghdr *msg, int flags)
1347*404b540aSrobert {
1348*404b540aSrobert   TRACE ("%s\n", __PRETTY_FUNCTION__);
1349*404b540aSrobert   MF_VALIDATE_EXTENT (msg, sizeof (*msg), __MF_CHECK_WRITE, "recvmsg msg");
1350*404b540aSrobert   return recvmsg (s, msg, flags);
1351*404b540aSrobert }
1352*404b540aSrobert 
1353*404b540aSrobert 
WRAPPER2(int,send,int s,const void * msg,size_t len,int flags)1354*404b540aSrobert WRAPPER2(int, send, int s, const void *msg, size_t len, int flags)
1355*404b540aSrobert {
1356*404b540aSrobert   TRACE ("%s\n", __PRETTY_FUNCTION__);
1357*404b540aSrobert   MF_VALIDATE_EXTENT (msg, len, __MF_CHECK_READ, "send msg");
1358*404b540aSrobert   return send (s, msg, len, flags);
1359*404b540aSrobert }
1360*404b540aSrobert 
1361*404b540aSrobert 
WRAPPER2(int,sendto,int s,const void * msg,size_t len,int flags,const struct sockaddr * to,socklen_t tolen)1362*404b540aSrobert WRAPPER2(int, sendto, int s, const void *msg, size_t len, int flags,
1363*404b540aSrobert 		const struct sockaddr *to, socklen_t tolen)
1364*404b540aSrobert {
1365*404b540aSrobert   TRACE ("%s\n", __PRETTY_FUNCTION__);
1366*404b540aSrobert   MF_VALIDATE_EXTENT (msg, len, __MF_CHECK_READ, "sendto msg");
1367*404b540aSrobert   MF_VALIDATE_EXTENT (to, (size_t)tolen, __MF_CHECK_WRITE, "sendto to");
1368*404b540aSrobert   return sendto (s, msg, len, flags, to, tolen);
1369*404b540aSrobert }
1370*404b540aSrobert 
1371*404b540aSrobert 
WRAPPER2(int,sendmsg,int s,const void * msg,int flags)1372*404b540aSrobert WRAPPER2(int, sendmsg, int s, const void *msg, int flags)
1373*404b540aSrobert {
1374*404b540aSrobert   TRACE ("%s\n", __PRETTY_FUNCTION__);
1375*404b540aSrobert   MF_VALIDATE_EXTENT (msg, sizeof (*msg), __MF_CHECK_READ, "sendmsg msg");
1376*404b540aSrobert   return sendmsg (s, msg, flags);
1377*404b540aSrobert }
1378*404b540aSrobert 
1379*404b540aSrobert 
WRAPPER2(int,setsockopt,int s,int level,int optname,const void * optval,socklen_t optlen)1380*404b540aSrobert WRAPPER2(int, setsockopt, int s, int level, int optname, const void *optval,
1381*404b540aSrobert 	socklen_t optlen)
1382*404b540aSrobert {
1383*404b540aSrobert   TRACE ("%s\n", __PRETTY_FUNCTION__);
1384*404b540aSrobert   MF_VALIDATE_EXTENT (optval, (size_t)optlen, __MF_CHECK_READ,
1385*404b540aSrobert     "setsockopt optval");
1386*404b540aSrobert   return setsockopt (s, level, optname, optval, optlen);
1387*404b540aSrobert }
1388*404b540aSrobert 
1389*404b540aSrobert 
WRAPPER2(int,getsockopt,int s,int level,int optname,void * optval,socklen_t * optlen)1390*404b540aSrobert WRAPPER2(int, getsockopt, int s, int level, int optname, void *optval,
1391*404b540aSrobert 		socklen_t *optlen)
1392*404b540aSrobert {
1393*404b540aSrobert   TRACE ("%s\n", __PRETTY_FUNCTION__);
1394*404b540aSrobert   MF_VALIDATE_EXTENT (optval, (size_t)*optlen, __MF_CHECK_WRITE,
1395*404b540aSrobert     "getsockopt optval");
1396*404b540aSrobert   return getsockopt (s, level, optname, optval, optlen);
1397*404b540aSrobert }
1398*404b540aSrobert 
1399*404b540aSrobert 
WRAPPER2(int,accept,int s,struct sockaddr * addr,socklen_t * addrlen)1400*404b540aSrobert WRAPPER2(int, accept, int s, struct  sockaddr *addr, socklen_t *addrlen)
1401*404b540aSrobert {
1402*404b540aSrobert   TRACE ("%s\n", __PRETTY_FUNCTION__);
1403*404b540aSrobert   if (addr != NULL)
1404*404b540aSrobert     MF_VALIDATE_EXTENT (addr, (size_t)*addrlen, __MF_CHECK_WRITE, "accept addr");
1405*404b540aSrobert   return accept (s, addr, addrlen);
1406*404b540aSrobert }
1407*404b540aSrobert 
1408*404b540aSrobert 
WRAPPER2(int,bind,int sockfd,struct sockaddr * addr,socklen_t addrlen)1409*404b540aSrobert WRAPPER2(int, bind, int sockfd, struct  sockaddr *addr, socklen_t addrlen)
1410*404b540aSrobert {
1411*404b540aSrobert   TRACE ("%s\n", __PRETTY_FUNCTION__);
1412*404b540aSrobert   MF_VALIDATE_EXTENT (addr, (size_t)addrlen, __MF_CHECK_WRITE, "bind addr");
1413*404b540aSrobert   return bind (sockfd, addr, addrlen);
1414*404b540aSrobert }
1415*404b540aSrobert 
1416*404b540aSrobert 
WRAPPER2(int,connect,int sockfd,const struct sockaddr * addr,socklen_t addrlen)1417*404b540aSrobert WRAPPER2(int, connect, int sockfd, const struct sockaddr  *addr,
1418*404b540aSrobert 	socklen_t addrlen)
1419*404b540aSrobert {
1420*404b540aSrobert   TRACE ("%s\n", __PRETTY_FUNCTION__);
1421*404b540aSrobert   MF_VALIDATE_EXTENT (addr, (size_t)addrlen, __MF_CHECK_READ,
1422*404b540aSrobert     "connect addr");
1423*404b540aSrobert   return connect (sockfd, addr, addrlen);
1424*404b540aSrobert }
1425*404b540aSrobert 
1426*404b540aSrobert #endif /* HAVE_SYS_SOCKET_H */
1427*404b540aSrobert 
1428*404b540aSrobert 
WRAPPER2(int,gethostname,char * name,size_t len)1429*404b540aSrobert WRAPPER2(int, gethostname, char *name, size_t len)
1430*404b540aSrobert {
1431*404b540aSrobert   TRACE ("%s\n", __PRETTY_FUNCTION__);
1432*404b540aSrobert   MF_VALIDATE_EXTENT (name, len, __MF_CHECK_WRITE, "gethostname name");
1433*404b540aSrobert   return gethostname (name, len);
1434*404b540aSrobert }
1435*404b540aSrobert 
1436*404b540aSrobert 
1437*404b540aSrobert #ifdef HAVE_SETHOSTNAME
WRAPPER2(int,sethostname,const char * name,size_t len)1438*404b540aSrobert WRAPPER2(int, sethostname, const char *name, size_t len)
1439*404b540aSrobert {
1440*404b540aSrobert   TRACE ("%s\n", __PRETTY_FUNCTION__);
1441*404b540aSrobert   MF_VALIDATE_EXTENT (name, len, __MF_CHECK_READ, "sethostname name");
1442*404b540aSrobert   return sethostname (name, len);
1443*404b540aSrobert }
1444*404b540aSrobert #endif
1445*404b540aSrobert 
1446*404b540aSrobert 
1447*404b540aSrobert #ifdef HAVE_NETDB_H
1448*404b540aSrobert 
WRAPPER2(struct hostent *,gethostbyname,const char * name)1449*404b540aSrobert WRAPPER2(struct hostent *, gethostbyname, const char *name)
1450*404b540aSrobert {
1451*404b540aSrobert   struct hostent *p;
1452*404b540aSrobert   char **ss;
1453*404b540aSrobert   char *s;
1454*404b540aSrobert   size_t n;
1455*404b540aSrobert   int nreg;
1456*404b540aSrobert   TRACE ("%s\n", __PRETTY_FUNCTION__);
1457*404b540aSrobert   n = strlen (name);
1458*404b540aSrobert   MF_VALIDATE_EXTENT (name, CLAMPADD(n, 1), __MF_CHECK_READ,
1459*404b540aSrobert     "gethostbyname name");
1460*404b540aSrobert   p = gethostbyname (name);
1461*404b540aSrobert   if (NULL != p) {
1462*404b540aSrobert #ifdef MF_REGISTER_gethostbyname
1463*404b540aSrobert     __mf_register (p, sizeof (*p), MF_REGISTER_gethostbyname,
1464*404b540aSrobert       "gethostbyname result");
1465*404b540aSrobert #endif
1466*404b540aSrobert     MF_VALIDATE_EXTENT (p, sizeof (*p), __MF_CHECK_WRITE,
1467*404b540aSrobert       "gethostbyname result");
1468*404b540aSrobert     if (NULL != (s = p->h_name)) {
1469*404b540aSrobert       n = strlen (s);
1470*404b540aSrobert       n = CLAMPADD(n, 1);
1471*404b540aSrobert #ifdef MF_REGISTER_gethostbyname_items
1472*404b540aSrobert       __mf_register (s, n, MF_REGISTER_gethostbyname_items,
1473*404b540aSrobert         "gethostbyname result->h_name");
1474*404b540aSrobert #endif
1475*404b540aSrobert       MF_VALIDATE_EXTENT (s, n, __MF_CHECK_WRITE,
1476*404b540aSrobert         "gethostbyname result->h_name");
1477*404b540aSrobert     }
1478*404b540aSrobert 
1479*404b540aSrobert     if (NULL != (ss = p->h_aliases)) {
1480*404b540aSrobert       for (nreg = 1;; ++nreg) {
1481*404b540aSrobert         s = *ss++;
1482*404b540aSrobert         if (NULL == s)
1483*404b540aSrobert           break;
1484*404b540aSrobert         n = strlen (s);
1485*404b540aSrobert         n = CLAMPADD(n, 1);
1486*404b540aSrobert #ifdef MF_REGISTER_gethostbyname_items
1487*404b540aSrobert         __mf_register (s, n, MF_REGISTER_gethostbyname_items,
1488*404b540aSrobert           "gethostbyname result->h_aliases[]");
1489*404b540aSrobert #endif
1490*404b540aSrobert         MF_VALIDATE_EXTENT (s, n, __MF_CHECK_WRITE,
1491*404b540aSrobert           "gethostbyname result->h_aliases[]");
1492*404b540aSrobert       }
1493*404b540aSrobert       nreg *= sizeof (*p->h_aliases);
1494*404b540aSrobert #ifdef MF_REGISTER_gethostbyname_items
1495*404b540aSrobert       __mf_register (p->h_aliases, nreg, MF_REGISTER_gethostbyname_items,
1496*404b540aSrobert         "gethostbyname result->h_aliases");
1497*404b540aSrobert #endif
1498*404b540aSrobert       MF_VALIDATE_EXTENT (p->h_aliases, nreg, __MF_CHECK_WRITE,
1499*404b540aSrobert         "gethostbyname result->h_aliases");
1500*404b540aSrobert     }
1501*404b540aSrobert 
1502*404b540aSrobert     if (NULL != (ss = p->h_addr_list)) {
1503*404b540aSrobert       for (nreg = 1;; ++nreg) {
1504*404b540aSrobert         s = *ss++;
1505*404b540aSrobert         if (NULL == s)
1506*404b540aSrobert           break;
1507*404b540aSrobert #ifdef MF_REGISTER_gethostbyname_items
1508*404b540aSrobert         __mf_register (s, p->h_length, MF_REGISTER_gethostbyname_items,
1509*404b540aSrobert           "gethostbyname result->h_addr_list[]");
1510*404b540aSrobert #endif
1511*404b540aSrobert         MF_VALIDATE_EXTENT (s, p->h_length, __MF_CHECK_WRITE,
1512*404b540aSrobert           "gethostbyname result->h_addr_list[]");
1513*404b540aSrobert       }
1514*404b540aSrobert       nreg *= sizeof (*p->h_addr_list);
1515*404b540aSrobert #ifdef MF_REGISTER_gethostbyname_items
1516*404b540aSrobert       __mf_register (p->h_addr_list, nreg, MF_REGISTER_gethostbyname_items,
1517*404b540aSrobert         "gethostbyname result->h_addr_list");
1518*404b540aSrobert #endif
1519*404b540aSrobert       MF_VALIDATE_EXTENT (p->h_addr_list, nreg, __MF_CHECK_WRITE,
1520*404b540aSrobert         "gethostbyname result->h_addr_list");
1521*404b540aSrobert     }
1522*404b540aSrobert   }
1523*404b540aSrobert   return p;
1524*404b540aSrobert }
1525*404b540aSrobert 
1526*404b540aSrobert #endif /* HAVE_NETDB_H */
1527*404b540aSrobert 
1528*404b540aSrobert 
1529*404b540aSrobert #ifdef HAVE_SYS_WAIT_H
1530*404b540aSrobert 
WRAPPER2(pid_t,wait,int * status)1531*404b540aSrobert WRAPPER2(pid_t, wait, int *status)
1532*404b540aSrobert {
1533*404b540aSrobert   TRACE ("%s\n", __PRETTY_FUNCTION__);
1534*404b540aSrobert   if (NULL != status)
1535*404b540aSrobert     MF_VALIDATE_EXTENT (status, sizeof (*status), __MF_CHECK_WRITE,
1536*404b540aSrobert       "wait status");
1537*404b540aSrobert   return wait (status);
1538*404b540aSrobert }
1539*404b540aSrobert 
1540*404b540aSrobert 
WRAPPER2(pid_t,waitpid,pid_t pid,int * status,int options)1541*404b540aSrobert WRAPPER2(pid_t, waitpid, pid_t pid, int *status, int options)
1542*404b540aSrobert {
1543*404b540aSrobert   TRACE ("%s\n", __PRETTY_FUNCTION__);
1544*404b540aSrobert   if (NULL != status)
1545*404b540aSrobert     MF_VALIDATE_EXTENT (status, sizeof (*status), __MF_CHECK_WRITE,
1546*404b540aSrobert       "waitpid status");
1547*404b540aSrobert   return waitpid (pid, status, options);
1548*404b540aSrobert }
1549*404b540aSrobert 
1550*404b540aSrobert #endif /* HAVE_SYS_WAIT_H */
1551*404b540aSrobert 
1552*404b540aSrobert 
WRAPPER2(FILE *,popen,const char * command,const char * mode)1553*404b540aSrobert WRAPPER2(FILE *, popen, const char *command, const char *mode)
1554*404b540aSrobert {
1555*404b540aSrobert   size_t n;
1556*404b540aSrobert   FILE *p;
1557*404b540aSrobert   TRACE ("%s\n", __PRETTY_FUNCTION__);
1558*404b540aSrobert 
1559*404b540aSrobert   n = strlen (command);
1560*404b540aSrobert   MF_VALIDATE_EXTENT (command, CLAMPADD(n, 1), __MF_CHECK_READ, "popen path");
1561*404b540aSrobert 
1562*404b540aSrobert   n = strlen (mode);
1563*404b540aSrobert   MF_VALIDATE_EXTENT (mode, CLAMPADD(n, 1), __MF_CHECK_READ, "popen mode");
1564*404b540aSrobert 
1565*404b540aSrobert   p = popen (command, mode);
1566*404b540aSrobert   if (NULL != p) {
1567*404b540aSrobert #ifdef MF_REGISTER_fopen
1568*404b540aSrobert     __mf_register (p, sizeof (*p), MF_REGISTER_fopen, "popen result");
1569*404b540aSrobert #endif
1570*404b540aSrobert     MF_VALIDATE_EXTENT (p, sizeof (*p), __MF_CHECK_WRITE, "popen result");
1571*404b540aSrobert   }
1572*404b540aSrobert   return p;
1573*404b540aSrobert }
1574*404b540aSrobert 
1575*404b540aSrobert 
WRAPPER2(int,pclose,FILE * stream)1576*404b540aSrobert WRAPPER2(int, pclose, FILE *stream)
1577*404b540aSrobert {
1578*404b540aSrobert   int resp;
1579*404b540aSrobert   TRACE ("%s\n", __PRETTY_FUNCTION__);
1580*404b540aSrobert   MF_VALIDATE_EXTENT (stream, sizeof (*stream), __MF_CHECK_WRITE,
1581*404b540aSrobert     "pclose stream");
1582*404b540aSrobert   resp = pclose (stream);
1583*404b540aSrobert #ifdef MF_REGISTER_fopen
1584*404b540aSrobert   __mf_unregister (stream, sizeof (*stream), MF_REGISTER_fopen);
1585*404b540aSrobert #endif
1586*404b540aSrobert   return resp;
1587*404b540aSrobert }
1588*404b540aSrobert 
1589*404b540aSrobert 
WRAPPER2(int,execve,const char * path,char * const argv[],char * const envp[])1590*404b540aSrobert WRAPPER2(int, execve, const char *path, char *const argv [],
1591*404b540aSrobert 	char *const envp[])
1592*404b540aSrobert {
1593*404b540aSrobert   size_t n;
1594*404b540aSrobert   char *const *p;
1595*404b540aSrobert   const char *s;
1596*404b540aSrobert   TRACE ("%s\n", __PRETTY_FUNCTION__);
1597*404b540aSrobert 
1598*404b540aSrobert   n = strlen (path);
1599*404b540aSrobert   MF_VALIDATE_EXTENT (path, CLAMPADD(n, 1), __MF_CHECK_READ, "execve path");
1600*404b540aSrobert 
1601*404b540aSrobert   for (p = argv;;) {
1602*404b540aSrobert     MF_VALIDATE_EXTENT (p, sizeof (*p), __MF_CHECK_READ, "execve *argv");
1603*404b540aSrobert     s = *p++;
1604*404b540aSrobert     if (NULL == s)
1605*404b540aSrobert       break;
1606*404b540aSrobert     n = strlen (s);
1607*404b540aSrobert     MF_VALIDATE_EXTENT (s, CLAMPADD(n, 1), __MF_CHECK_READ, "execve **argv");
1608*404b540aSrobert   }
1609*404b540aSrobert 
1610*404b540aSrobert   for (p = envp;;) {
1611*404b540aSrobert     MF_VALIDATE_EXTENT (p, sizeof (*p), __MF_CHECK_READ, "execve *envp");
1612*404b540aSrobert     s = *p++;
1613*404b540aSrobert     if (NULL == s)
1614*404b540aSrobert       break;
1615*404b540aSrobert     n = strlen (s);
1616*404b540aSrobert     MF_VALIDATE_EXTENT (s, CLAMPADD(n, 1), __MF_CHECK_READ, "execve **envp");
1617*404b540aSrobert   }
1618*404b540aSrobert   return execve (path, argv, envp);
1619*404b540aSrobert }
1620*404b540aSrobert 
1621*404b540aSrobert 
WRAPPER2(int,execv,const char * path,char * const argv[])1622*404b540aSrobert WRAPPER2(int, execv, const char *path, char *const argv [])
1623*404b540aSrobert {
1624*404b540aSrobert   size_t n;
1625*404b540aSrobert   char *const *p;
1626*404b540aSrobert   const char *s;
1627*404b540aSrobert   TRACE ("%s\n", __PRETTY_FUNCTION__);
1628*404b540aSrobert 
1629*404b540aSrobert   n = strlen (path);
1630*404b540aSrobert   MF_VALIDATE_EXTENT (path, CLAMPADD(n, 1), __MF_CHECK_READ, "execv path");
1631*404b540aSrobert 
1632*404b540aSrobert   for (p = argv;;) {
1633*404b540aSrobert     MF_VALIDATE_EXTENT (p, sizeof (*p), __MF_CHECK_READ, "execv *argv");
1634*404b540aSrobert     s = *p++;
1635*404b540aSrobert     if (NULL == s)
1636*404b540aSrobert       break;
1637*404b540aSrobert     n = strlen (s);
1638*404b540aSrobert     MF_VALIDATE_EXTENT (s, CLAMPADD(n, 1), __MF_CHECK_READ, "execv **argv");
1639*404b540aSrobert   }
1640*404b540aSrobert   return execv (path, argv);
1641*404b540aSrobert }
1642*404b540aSrobert 
1643*404b540aSrobert 
WRAPPER2(int,execvp,const char * path,char * const argv[])1644*404b540aSrobert WRAPPER2(int, execvp, const char *path, char *const argv [])
1645*404b540aSrobert {
1646*404b540aSrobert   size_t n;
1647*404b540aSrobert   char *const *p;
1648*404b540aSrobert   const char *s;
1649*404b540aSrobert   TRACE ("%s\n", __PRETTY_FUNCTION__);
1650*404b540aSrobert 
1651*404b540aSrobert   n = strlen (path);
1652*404b540aSrobert   MF_VALIDATE_EXTENT (path, CLAMPADD(n, 1), __MF_CHECK_READ, "execvp path");
1653*404b540aSrobert 
1654*404b540aSrobert   for (p = argv;;) {
1655*404b540aSrobert     MF_VALIDATE_EXTENT (p, sizeof (*p), __MF_CHECK_READ, "execvp *argv");
1656*404b540aSrobert     s = *p++;
1657*404b540aSrobert     if (NULL == s)
1658*404b540aSrobert       break;
1659*404b540aSrobert     n = strlen (s);
1660*404b540aSrobert     MF_VALIDATE_EXTENT (s, CLAMPADD(n, 1), __MF_CHECK_READ, "execvp **argv");
1661*404b540aSrobert   }
1662*404b540aSrobert   return execvp (path, argv);
1663*404b540aSrobert }
1664*404b540aSrobert 
1665*404b540aSrobert 
WRAPPER2(int,system,const char * string)1666*404b540aSrobert WRAPPER2(int, system, const char *string)
1667*404b540aSrobert {
1668*404b540aSrobert   size_t n;
1669*404b540aSrobert   TRACE ("%s\n", __PRETTY_FUNCTION__);
1670*404b540aSrobert   n = strlen (string);
1671*404b540aSrobert   MF_VALIDATE_EXTENT (string, CLAMPADD(n, 1), __MF_CHECK_READ,
1672*404b540aSrobert     "system string");
1673*404b540aSrobert   return system (string);
1674*404b540aSrobert }
1675*404b540aSrobert 
1676*404b540aSrobert 
WRAPPER2(void *,dlopen,const char * path,int flags)1677*404b540aSrobert WRAPPER2(void *, dlopen, const char *path, int flags)
1678*404b540aSrobert {
1679*404b540aSrobert   void *p;
1680*404b540aSrobert   size_t n;
1681*404b540aSrobert   TRACE ("%s\n", __PRETTY_FUNCTION__);
1682*404b540aSrobert   n = strlen (path);
1683*404b540aSrobert   MF_VALIDATE_EXTENT (path, CLAMPADD(n, 1), __MF_CHECK_READ, "dlopen path");
1684*404b540aSrobert   p = dlopen (path, flags);
1685*404b540aSrobert   if (NULL != p) {
1686*404b540aSrobert #ifdef MF_REGISTER_dlopen
1687*404b540aSrobert     __mf_register (p, 0, MF_REGISTER_dlopen, "dlopen result");
1688*404b540aSrobert #endif
1689*404b540aSrobert     MF_VALIDATE_EXTENT (p, 0, __MF_CHECK_WRITE, "dlopen result");
1690*404b540aSrobert   }
1691*404b540aSrobert   return p;
1692*404b540aSrobert }
1693*404b540aSrobert 
1694*404b540aSrobert 
WRAPPER2(int,dlclose,void * handle)1695*404b540aSrobert WRAPPER2(int, dlclose, void *handle)
1696*404b540aSrobert {
1697*404b540aSrobert   int resp;
1698*404b540aSrobert   TRACE ("%s\n", __PRETTY_FUNCTION__);
1699*404b540aSrobert   MF_VALIDATE_EXTENT (handle, 0, __MF_CHECK_READ, "dlclose handle");
1700*404b540aSrobert   resp = dlclose (handle);
1701*404b540aSrobert #ifdef MF_REGISTER_dlopen
1702*404b540aSrobert   __mf_unregister (handle, 0, MF_REGISTER_dlopen);
1703*404b540aSrobert #endif
1704*404b540aSrobert   return resp;
1705*404b540aSrobert }
1706*404b540aSrobert 
1707*404b540aSrobert 
WRAPPER2(char *,dlerror)1708*404b540aSrobert WRAPPER2(char *, dlerror)
1709*404b540aSrobert {
1710*404b540aSrobert   char *p;
1711*404b540aSrobert   TRACE ("%s\n", __PRETTY_FUNCTION__);
1712*404b540aSrobert   p = dlerror ();
1713*404b540aSrobert   if (NULL != p) {
1714*404b540aSrobert     size_t n;
1715*404b540aSrobert     n = strlen (p);
1716*404b540aSrobert     n = CLAMPADD(n, 1);
1717*404b540aSrobert #ifdef MF_REGISTER_dlerror
1718*404b540aSrobert     __mf_register (p, n, MF_REGISTER_dlerror, "dlerror result");
1719*404b540aSrobert #endif
1720*404b540aSrobert     MF_VALIDATE_EXTENT (p, n, __MF_CHECK_WRITE, "dlerror result");
1721*404b540aSrobert   }
1722*404b540aSrobert   return p;
1723*404b540aSrobert }
1724*404b540aSrobert 
1725*404b540aSrobert 
WRAPPER2(void *,dlsym,void * handle,char * symbol)1726*404b540aSrobert WRAPPER2(void *, dlsym, void *handle, char *symbol)
1727*404b540aSrobert {
1728*404b540aSrobert   size_t n;
1729*404b540aSrobert   void *p;
1730*404b540aSrobert   TRACE ("%s\n", __PRETTY_FUNCTION__);
1731*404b540aSrobert   MF_VALIDATE_EXTENT (handle, 0, __MF_CHECK_READ, "dlsym handle");
1732*404b540aSrobert   n = strlen (symbol);
1733*404b540aSrobert   MF_VALIDATE_EXTENT (symbol, CLAMPADD(n, 1), __MF_CHECK_READ, "dlsym symbol");
1734*404b540aSrobert   p = dlsym (handle, symbol);
1735*404b540aSrobert   if (NULL != p) {
1736*404b540aSrobert #ifdef MF_REGISTER_dlsym
1737*404b540aSrobert     __mf_register (p, 0, MF_REGISTER_dlsym, "dlsym result");
1738*404b540aSrobert #endif
1739*404b540aSrobert     MF_VALIDATE_EXTENT (p, 0, __MF_CHECK_WRITE, "dlsym result");
1740*404b540aSrobert   }
1741*404b540aSrobert   return p;
1742*404b540aSrobert }
1743*404b540aSrobert 
1744*404b540aSrobert 
1745*404b540aSrobert #if defined (HAVE_SYS_IPC_H) && defined (HAVE_SYS_SEM_H) && defined (HAVE_SYS_SHM_H)
1746*404b540aSrobert 
WRAPPER2(int,semop,int semid,struct sembuf * sops,unsigned nsops)1747*404b540aSrobert WRAPPER2(int, semop, int semid, struct sembuf *sops, unsigned nsops)
1748*404b540aSrobert {
1749*404b540aSrobert   TRACE ("%s\n", __PRETTY_FUNCTION__);
1750*404b540aSrobert   MF_VALIDATE_EXTENT (sops, sizeof (*sops) * nsops, __MF_CHECK_READ,
1751*404b540aSrobert     "semop sops");
1752*404b540aSrobert   return semop (semid, sops, nsops);
1753*404b540aSrobert }
1754*404b540aSrobert 
1755*404b540aSrobert 
1756*404b540aSrobert #ifndef HAVE_UNION_SEMUN
1757*404b540aSrobert union semun {
1758*404b540aSrobert 	int val;			/* value for SETVAL */
1759*404b540aSrobert 	struct semid_ds *buf;		/* buffer for IPC_STAT, IPC_SET */
1760*404b540aSrobert 	unsigned short int *array;	/* array for GETALL, SETALL */
1761*404b540aSrobert 	struct seminfo *__buf;		/* buffer for IPC_INFO */
1762*404b540aSrobert };
1763*404b540aSrobert #endif
WRAPPER2(int,semctl,int semid,int semnum,int cmd,union semun arg)1764*404b540aSrobert WRAPPER2(int, semctl, int semid, int semnum, int cmd, union semun arg)
1765*404b540aSrobert {
1766*404b540aSrobert   TRACE ("%s\n", __PRETTY_FUNCTION__);
1767*404b540aSrobert   switch (cmd) {
1768*404b540aSrobert   case IPC_STAT:
1769*404b540aSrobert     MF_VALIDATE_EXTENT (arg.buf, sizeof (*arg.buf), __MF_CHECK_WRITE,
1770*404b540aSrobert       "semctl buf");
1771*404b540aSrobert     break;
1772*404b540aSrobert   case IPC_SET:
1773*404b540aSrobert     MF_VALIDATE_EXTENT (arg.buf, sizeof (*arg.buf), __MF_CHECK_READ,
1774*404b540aSrobert       "semctl buf");
1775*404b540aSrobert     break;
1776*404b540aSrobert   case GETALL:
1777*404b540aSrobert     MF_VALIDATE_EXTENT (arg.array, sizeof (*arg.array), __MF_CHECK_WRITE,
1778*404b540aSrobert       "semctl array");
1779*404b540aSrobert   case SETALL:
1780*404b540aSrobert     MF_VALIDATE_EXTENT (arg.array, sizeof (*arg.array), __MF_CHECK_READ,
1781*404b540aSrobert       "semctl array");
1782*404b540aSrobert     break;
1783*404b540aSrobert #ifdef IPC_INFO
1784*404b540aSrobert   /* FreeBSD 5.1 And Cygwin headers include IPC_INFO but not the __buf field.  */
1785*404b540aSrobert #if !defined(__FreeBSD__) && !defined(__CYGWIN__)
1786*404b540aSrobert   case IPC_INFO:
1787*404b540aSrobert     MF_VALIDATE_EXTENT (arg.__buf, sizeof (*arg.__buf), __MF_CHECK_WRITE,
1788*404b540aSrobert       "semctl __buf");
1789*404b540aSrobert     break;
1790*404b540aSrobert #endif
1791*404b540aSrobert #endif
1792*404b540aSrobert   default:
1793*404b540aSrobert     break;
1794*404b540aSrobert   }
1795*404b540aSrobert   return semctl (semid, semnum, cmd, arg);
1796*404b540aSrobert }
1797*404b540aSrobert 
1798*404b540aSrobert 
WRAPPER2(int,shmctl,int shmid,int cmd,struct shmid_ds * buf)1799*404b540aSrobert WRAPPER2(int, shmctl, int shmid, int cmd, struct shmid_ds *buf)
1800*404b540aSrobert {
1801*404b540aSrobert   TRACE ("%s\n", __PRETTY_FUNCTION__);
1802*404b540aSrobert   switch (cmd) {
1803*404b540aSrobert   case IPC_STAT:
1804*404b540aSrobert     MF_VALIDATE_EXTENT (buf, sizeof (*buf), __MF_CHECK_WRITE,
1805*404b540aSrobert       "shmctl buf");
1806*404b540aSrobert     break;
1807*404b540aSrobert   case IPC_SET:
1808*404b540aSrobert     MF_VALIDATE_EXTENT (buf, sizeof (*buf), __MF_CHECK_READ,
1809*404b540aSrobert       "shmctl buf");
1810*404b540aSrobert     break;
1811*404b540aSrobert   default:
1812*404b540aSrobert     break;
1813*404b540aSrobert   }
1814*404b540aSrobert   return shmctl (shmid, cmd, buf);
1815*404b540aSrobert }
1816*404b540aSrobert 
1817*404b540aSrobert 
WRAPPER2(void *,shmat,int shmid,const void * shmaddr,int shmflg)1818*404b540aSrobert WRAPPER2(void *, shmat, int shmid, const void *shmaddr, int shmflg)
1819*404b540aSrobert {
1820*404b540aSrobert   void *p;
1821*404b540aSrobert   TRACE ("%s\n", __PRETTY_FUNCTION__);
1822*404b540aSrobert   p = shmat (shmid, shmaddr, shmflg);
1823*404b540aSrobert #ifdef MF_REGISTER_shmat
1824*404b540aSrobert   if (NULL != p) {
1825*404b540aSrobert     struct shmid_ds buf;
1826*404b540aSrobert     __mf_register (p, shmctl (shmid, IPC_STAT, &buf) ? 0 : buf.shm_segsz,
1827*404b540aSrobert       MF_REGISTER_shmat, "shmat result");
1828*404b540aSrobert   }
1829*404b540aSrobert #endif
1830*404b540aSrobert   return p;
1831*404b540aSrobert }
1832*404b540aSrobert 
1833*404b540aSrobert 
WRAPPER2(int,shmdt,const void * shmaddr)1834*404b540aSrobert WRAPPER2(int, shmdt, const void *shmaddr)
1835*404b540aSrobert {
1836*404b540aSrobert   int resp;
1837*404b540aSrobert   TRACE ("%s\n", __PRETTY_FUNCTION__);
1838*404b540aSrobert   resp = shmdt (shmaddr);
1839*404b540aSrobert #ifdef MF_REGISTER_shmat
1840*404b540aSrobert   __mf_unregister ((void *)shmaddr, 0, MF_REGISTER_shmat);
1841*404b540aSrobert #endif
1842*404b540aSrobert   return resp;
1843*404b540aSrobert }
1844*404b540aSrobert 
1845*404b540aSrobert 
1846*404b540aSrobert #endif /* HAVE_SYS_IPC/SEM/SHM_H */
1847*404b540aSrobert 
1848*404b540aSrobert 
1849*404b540aSrobert 
1850*404b540aSrobert /* ctype stuff.  This is host-specific by necessity, as the arrays
1851*404b540aSrobert    that is used by most is*()/to*() macros are implementation-defined.  */
1852*404b540aSrobert 
1853*404b540aSrobert /* GLIBC 2.3 */
1854*404b540aSrobert #ifdef HAVE___CTYPE_B_LOC
WRAPPER2(unsigned short **,__ctype_b_loc,void)1855*404b540aSrobert WRAPPER2(unsigned short **, __ctype_b_loc, void)
1856*404b540aSrobert {
1857*404b540aSrobert   static unsigned short * last_buf = (void *) 0;
1858*404b540aSrobert   static unsigned short ** last_ptr = (void *) 0;
1859*404b540aSrobert   unsigned short ** ptr = (unsigned short **) __ctype_b_loc ();
1860*404b540aSrobert   unsigned short * buf = * ptr;
1861*404b540aSrobert   if (ptr != last_ptr)
1862*404b540aSrobert     {
1863*404b540aSrobert       /* XXX: unregister last_ptr? */
1864*404b540aSrobert       last_ptr = ptr;
1865*404b540aSrobert       __mf_register (last_ptr, sizeof(last_ptr), __MF_TYPE_STATIC, "ctype_b_loc **");
1866*404b540aSrobert     }
1867*404b540aSrobert   if (buf != last_buf)
1868*404b540aSrobert     {
1869*404b540aSrobert       last_buf = buf;
1870*404b540aSrobert       __mf_register ((void *) (last_buf - 128), 384 * sizeof(unsigned short), __MF_TYPE_STATIC,
1871*404b540aSrobert                      "ctype_b_loc []");
1872*404b540aSrobert     }
1873*404b540aSrobert   return ptr;
1874*404b540aSrobert }
1875*404b540aSrobert #endif
1876*404b540aSrobert 
1877*404b540aSrobert #ifdef HAVE___CTYPE_TOUPPER_LOC
WRAPPER2(int **,__ctype_toupper_loc,void)1878*404b540aSrobert WRAPPER2(int **, __ctype_toupper_loc, void)
1879*404b540aSrobert {
1880*404b540aSrobert   static int * last_buf = (void *) 0;
1881*404b540aSrobert   static int ** last_ptr = (void *) 0;
1882*404b540aSrobert   int ** ptr = (int **) __ctype_toupper_loc ();
1883*404b540aSrobert   int * buf = * ptr;
1884*404b540aSrobert   if (ptr != last_ptr)
1885*404b540aSrobert     {
1886*404b540aSrobert       /* XXX: unregister last_ptr? */
1887*404b540aSrobert       last_ptr = ptr;
1888*404b540aSrobert       __mf_register (last_ptr, sizeof(last_ptr), __MF_TYPE_STATIC, "ctype_toupper_loc **");
1889*404b540aSrobert     }
1890*404b540aSrobert   if (buf != last_buf)
1891*404b540aSrobert     {
1892*404b540aSrobert       last_buf = buf;
1893*404b540aSrobert       __mf_register ((void *) (last_buf - 128), 384 * sizeof(int), __MF_TYPE_STATIC,
1894*404b540aSrobert                      "ctype_toupper_loc []");
1895*404b540aSrobert     }
1896*404b540aSrobert   return ptr;
1897*404b540aSrobert }
1898*404b540aSrobert #endif
1899*404b540aSrobert 
1900*404b540aSrobert #ifdef HAVE___CTYPE_TOLOWER_LOC
WRAPPER2(int **,__ctype_tolower_loc,void)1901*404b540aSrobert WRAPPER2(int **, __ctype_tolower_loc, void)
1902*404b540aSrobert {
1903*404b540aSrobert   static int * last_buf = (void *) 0;
1904*404b540aSrobert   static int ** last_ptr = (void *) 0;
1905*404b540aSrobert   int ** ptr = (int **) __ctype_tolower_loc ();
1906*404b540aSrobert   int * buf = * ptr;
1907*404b540aSrobert   if (ptr != last_ptr)
1908*404b540aSrobert     {
1909*404b540aSrobert       /* XXX: unregister last_ptr? */
1910*404b540aSrobert       last_ptr = ptr;
1911*404b540aSrobert       __mf_register (last_ptr, sizeof(last_ptr), __MF_TYPE_STATIC, "ctype_tolower_loc **");
1912*404b540aSrobert     }
1913*404b540aSrobert   if (buf != last_buf)
1914*404b540aSrobert     {
1915*404b540aSrobert       last_buf = buf;
1916*404b540aSrobert       __mf_register ((void *) (last_buf - 128), 384 * sizeof(int), __MF_TYPE_STATIC,
1917*404b540aSrobert                      "ctype_tolower_loc []");
1918*404b540aSrobert     }
1919*404b540aSrobert   return ptr;
1920*404b540aSrobert }
1921*404b540aSrobert #endif
1922*404b540aSrobert 
1923*404b540aSrobert 
1924*404b540aSrobert /* passwd/group related functions.  These register every (static) pointer value returned,
1925*404b540aSrobert    and rely on libmudflap's quiet toleration of duplicate static registrations.  */
1926*404b540aSrobert 
1927*404b540aSrobert #ifdef HAVE_GETLOGIN
WRAPPER2(char *,getlogin,void)1928*404b540aSrobert WRAPPER2(char *, getlogin, void)
1929*404b540aSrobert {
1930*404b540aSrobert   char *buf = getlogin ();
1931*404b540aSrobert   if (buf != NULL)
1932*404b540aSrobert     __mf_register (buf, sizeof(*buf), __MF_TYPE_STATIC,
1933*404b540aSrobert                    "getlogin() return");
1934*404b540aSrobert   return buf;
1935*404b540aSrobert }
1936*404b540aSrobert #endif
1937*404b540aSrobert 
1938*404b540aSrobert 
1939*404b540aSrobert #ifdef HAVE_CUSERID
WRAPPER2(char *,cuserid,char * buf)1940*404b540aSrobert WRAPPER2(char *, cuserid, char * buf)
1941*404b540aSrobert {
1942*404b540aSrobert   if (buf != NULL)
1943*404b540aSrobert     {
1944*404b540aSrobert       MF_VALIDATE_EXTENT(buf, L_cuserid, __MF_CHECK_WRITE,
1945*404b540aSrobert                          "cuserid destination");
1946*404b540aSrobert       return cuserid (buf);
1947*404b540aSrobert     }
1948*404b540aSrobert   buf = cuserid (NULL);
1949*404b540aSrobert   if (buf != NULL)
1950*404b540aSrobert     __mf_register (buf, sizeof(*buf), __MF_TYPE_STATIC,
1951*404b540aSrobert                    "getcuserid() return");
1952*404b540aSrobert   return buf;
1953*404b540aSrobert }
1954*404b540aSrobert #endif
1955*404b540aSrobert 
1956*404b540aSrobert 
1957*404b540aSrobert #ifdef HAVE_GETPWNAM
WRAPPER2(struct passwd *,getpwnam,const char * name)1958*404b540aSrobert WRAPPER2(struct passwd *, getpwnam, const char *name)
1959*404b540aSrobert {
1960*404b540aSrobert   struct passwd *buf;
1961*404b540aSrobert   MF_VALIDATE_EXTENT(name, strlen(name)+1, __MF_CHECK_READ,
1962*404b540aSrobert                      "getpwnam name");
1963*404b540aSrobert   buf = getpwnam (name);
1964*404b540aSrobert   if (buf != NULL)
1965*404b540aSrobert     __mf_register (buf, sizeof(*buf), __MF_TYPE_STATIC,
1966*404b540aSrobert                    "getpw*() return");
1967*404b540aSrobert   return buf;
1968*404b540aSrobert }
1969*404b540aSrobert #endif
1970*404b540aSrobert 
1971*404b540aSrobert 
1972*404b540aSrobert #ifdef HAVE_GETPWUID
WRAPPER2(struct passwd *,getpwuid,uid_t uid)1973*404b540aSrobert WRAPPER2(struct passwd *, getpwuid, uid_t uid)
1974*404b540aSrobert {
1975*404b540aSrobert   struct passwd *buf;
1976*404b540aSrobert   buf = getpwuid (uid);
1977*404b540aSrobert   if (buf != NULL)
1978*404b540aSrobert     __mf_register (buf, sizeof(*buf), __MF_TYPE_STATIC,
1979*404b540aSrobert                    "getpw*() return");
1980*404b540aSrobert   return buf;
1981*404b540aSrobert }
1982*404b540aSrobert #endif
1983*404b540aSrobert 
1984*404b540aSrobert 
1985*404b540aSrobert #ifdef HAVE_GETGRNAM
WRAPPER2(struct group *,getgrnam,const char * name)1986*404b540aSrobert WRAPPER2(struct group *, getgrnam, const char *name)
1987*404b540aSrobert {
1988*404b540aSrobert   struct group *buf;
1989*404b540aSrobert   MF_VALIDATE_EXTENT(name, strlen(name)+1, __MF_CHECK_READ,
1990*404b540aSrobert                      "getgrnam name");
1991*404b540aSrobert   buf = getgrnam (name);
1992*404b540aSrobert   if (buf != NULL)
1993*404b540aSrobert     __mf_register (buf, sizeof(*buf), __MF_TYPE_STATIC,
1994*404b540aSrobert                    "getgr*() return");
1995*404b540aSrobert   return buf;
1996*404b540aSrobert }
1997*404b540aSrobert #endif
1998*404b540aSrobert 
1999*404b540aSrobert 
2000*404b540aSrobert #ifdef HAVE_GETGRGID
WRAPPER2(struct group *,getgrgid,uid_t uid)2001*404b540aSrobert WRAPPER2(struct group *, getgrgid, uid_t uid)
2002*404b540aSrobert {
2003*404b540aSrobert   struct group *buf;
2004*404b540aSrobert   buf = getgrgid (uid);
2005*404b540aSrobert   if (buf != NULL)
2006*404b540aSrobert     __mf_register (buf, sizeof(*buf), __MF_TYPE_STATIC,
2007*404b540aSrobert                    "getgr*() return");
2008*404b540aSrobert   return buf;
2009*404b540aSrobert }
2010*404b540aSrobert #endif
2011*404b540aSrobert 
2012*404b540aSrobert 
2013*404b540aSrobert #ifdef HAVE_GETSERVENT
WRAPPER2(struct servent *,getservent,void)2014*404b540aSrobert WRAPPER2(struct servent *, getservent, void)
2015*404b540aSrobert {
2016*404b540aSrobert   struct servent *buf;
2017*404b540aSrobert   buf = getservent ();
2018*404b540aSrobert   if (buf != NULL)
2019*404b540aSrobert     __mf_register (buf, sizeof(*buf), __MF_TYPE_STATIC,
2020*404b540aSrobert                    "getserv*() return");
2021*404b540aSrobert   return buf;
2022*404b540aSrobert }
2023*404b540aSrobert #endif
2024*404b540aSrobert 
2025*404b540aSrobert 
2026*404b540aSrobert #ifdef HAVE_GETSERVBYNAME
WRAPPER2(struct servent *,getservbyname,const char * name,const char * proto)2027*404b540aSrobert WRAPPER2(struct servent *, getservbyname, const char *name, const char *proto)
2028*404b540aSrobert {
2029*404b540aSrobert   struct servent *buf;
2030*404b540aSrobert   MF_VALIDATE_EXTENT(name, strlen(name)+1, __MF_CHECK_READ,
2031*404b540aSrobert                      "getservbyname name");
2032*404b540aSrobert   MF_VALIDATE_EXTENT(proto, strlen(proto)+1, __MF_CHECK_READ,
2033*404b540aSrobert                      "getservbyname proto");
2034*404b540aSrobert   buf = getservbyname (name, proto);
2035*404b540aSrobert   if (buf != NULL)
2036*404b540aSrobert     __mf_register (buf, sizeof(*buf), __MF_TYPE_STATIC,
2037*404b540aSrobert                    "getserv*() return");
2038*404b540aSrobert   return buf;
2039*404b540aSrobert }
2040*404b540aSrobert #endif
2041*404b540aSrobert 
2042*404b540aSrobert 
2043*404b540aSrobert #ifdef HAVE_GETSERVBYPORT
WRAPPER2(struct servent *,getservbyport,int port,const char * proto)2044*404b540aSrobert WRAPPER2(struct servent *, getservbyport, int port, const char *proto)
2045*404b540aSrobert {
2046*404b540aSrobert   struct servent *buf;
2047*404b540aSrobert   MF_VALIDATE_EXTENT(proto, strlen(proto)+1, __MF_CHECK_READ,
2048*404b540aSrobert                      "getservbyport proto");
2049*404b540aSrobert   buf = getservbyport (port, proto);
2050*404b540aSrobert   if (buf != NULL)
2051*404b540aSrobert     __mf_register (buf, sizeof(*buf), __MF_TYPE_STATIC,
2052*404b540aSrobert                    "getserv*() return");
2053*404b540aSrobert   return buf;
2054*404b540aSrobert }
2055*404b540aSrobert #endif
2056*404b540aSrobert 
2057*404b540aSrobert 
2058*404b540aSrobert #ifdef HAVE_GAI_STRERROR
WRAPPER2(const char *,gai_strerror,int errcode)2059*404b540aSrobert WRAPPER2(const char *, gai_strerror, int errcode)
2060*404b540aSrobert {
2061*404b540aSrobert   const char *buf;
2062*404b540aSrobert   buf = gai_strerror (errcode);
2063*404b540aSrobert   if (buf != NULL)
2064*404b540aSrobert     __mf_register ((void *) buf, strlen(buf)+1, __MF_TYPE_STATIC,
2065*404b540aSrobert                    "gai_strerror() return");
2066*404b540aSrobert   return buf;
2067*404b540aSrobert }
2068*404b540aSrobert #endif
2069*404b540aSrobert 
2070*404b540aSrobert 
2071*404b540aSrobert #ifdef HAVE_GETMNTENT
WRAPPER2(struct mntent *,getmntent,FILE * filep)2072*404b540aSrobert WRAPPER2(struct mntent *, getmntent, FILE *filep)
2073*404b540aSrobert {
2074*404b540aSrobert   struct mntent *m;
2075*404b540aSrobert   static struct mntent *last = NULL;
2076*404b540aSrobert 
2077*404b540aSrobert   MF_VALIDATE_EXTENT (filep, sizeof (*filep), __MF_CHECK_WRITE,
2078*404b540aSrobert     "getmntent stream");
2079*404b540aSrobert #define UR(field) __mf_unregister(last->field, strlen (last->field)+1, __MF_TYPE_STATIC)
2080*404b540aSrobert   if (last)
2081*404b540aSrobert     {
2082*404b540aSrobert       UR (mnt_fsname);
2083*404b540aSrobert       UR (mnt_dir);
2084*404b540aSrobert       UR (mnt_type);
2085*404b540aSrobert       UR (mnt_opts);
2086*404b540aSrobert       __mf_unregister (last, sizeof (*last), __MF_TYPE_STATIC);
2087*404b540aSrobert     }
2088*404b540aSrobert #undef UR
2089*404b540aSrobert 
2090*404b540aSrobert   m = getmntent (filep);
2091*404b540aSrobert   last = m;
2092*404b540aSrobert 
2093*404b540aSrobert #define R(field) __mf_register(last->field, strlen (last->field)+1, __MF_TYPE_STATIC, "mntent " #field)
2094*404b540aSrobert   if (m)
2095*404b540aSrobert     {
2096*404b540aSrobert       R (mnt_fsname);
2097*404b540aSrobert       R (mnt_dir);
2098*404b540aSrobert       R (mnt_type);
2099*404b540aSrobert       R (mnt_opts);
2100*404b540aSrobert       __mf_register (last, sizeof (*last), __MF_TYPE_STATIC, "getmntent result");
2101*404b540aSrobert     }
2102*404b540aSrobert #undef R
2103*404b540aSrobert 
2104*404b540aSrobert   return m;
2105*404b540aSrobert }
2106*404b540aSrobert #endif
2107*404b540aSrobert 
2108*404b540aSrobert 
2109*404b540aSrobert #ifdef HAVE_INET_NTOA
WRAPPER2(char *,inet_ntoa,struct in_addr in)2110*404b540aSrobert WRAPPER2(char *, inet_ntoa, struct in_addr in)
2111*404b540aSrobert {
2112*404b540aSrobert   static char *last_buf = NULL;
2113*404b540aSrobert   char *buf;
2114*404b540aSrobert   if (last_buf)
2115*404b540aSrobert     __mf_unregister (last_buf, strlen (last_buf)+1, __MF_TYPE_STATIC);
2116*404b540aSrobert   buf = inet_ntoa (in);
2117*404b540aSrobert   last_buf = buf;
2118*404b540aSrobert   if (buf)
2119*404b540aSrobert     __mf_register (last_buf, strlen (last_buf)+1, __MF_TYPE_STATIC, "inet_ntoa result");
2120*404b540aSrobert   return buf;
2121*404b540aSrobert }
2122*404b540aSrobert #endif
2123*404b540aSrobert 
2124*404b540aSrobert 
2125*404b540aSrobert #ifdef HAVE_GETPROTOENT
WRAPPER2(struct protoent *,getprotoent,void)2126*404b540aSrobert WRAPPER2(struct protoent *, getprotoent, void)
2127*404b540aSrobert {
2128*404b540aSrobert   struct protoent *buf;
2129*404b540aSrobert   buf = getprotoent ();
2130*404b540aSrobert   if (buf != NULL)
2131*404b540aSrobert     __mf_register (buf, sizeof(*buf), __MF_TYPE_STATIC, "getproto*() return");
2132*404b540aSrobert   return buf;
2133*404b540aSrobert }
2134*404b540aSrobert #endif
2135*404b540aSrobert 
2136*404b540aSrobert 
2137*404b540aSrobert #ifdef HAVE_GETPROTOBYNAME
WRAPPER2(struct protoent *,getprotobyname,const char * name)2138*404b540aSrobert WRAPPER2(struct protoent *, getprotobyname, const char *name)
2139*404b540aSrobert {
2140*404b540aSrobert   struct protoent *buf;
2141*404b540aSrobert   MF_VALIDATE_EXTENT(name, strlen(name)+1, __MF_CHECK_READ,
2142*404b540aSrobert                      "getprotobyname name");
2143*404b540aSrobert   buf = getprotobyname (name);
2144*404b540aSrobert   if (buf != NULL)
2145*404b540aSrobert     __mf_register (buf, sizeof(*buf), __MF_TYPE_STATIC,
2146*404b540aSrobert                    "getproto*() return");
2147*404b540aSrobert   return buf;
2148*404b540aSrobert }
2149*404b540aSrobert #endif
2150*404b540aSrobert 
2151*404b540aSrobert 
2152*404b540aSrobert #ifdef HAVE_GETPROTOBYNUMBER
WRAPPER2(struct protoent *,getprotobynumber,int port)2153*404b540aSrobert WRAPPER2(struct protoent *, getprotobynumber, int port)
2154*404b540aSrobert {
2155*404b540aSrobert   struct protoent *buf;
2156*404b540aSrobert   buf = getprotobynumber (port);
2157*404b540aSrobert   if (buf != NULL)
2158*404b540aSrobert     __mf_register (buf, sizeof(*buf), __MF_TYPE_STATIC,
2159*404b540aSrobert                    "getproto*() return");
2160*404b540aSrobert   return buf;
2161*404b540aSrobert }
2162*404b540aSrobert #endif
2163