stdlib.h revision 1.130 1 1.130 riastrad /* $NetBSD: stdlib.h,v 1.130 2025/03/02 16:35:40 riastradh Exp $ */
2 1.20 cgd
3 1.1 cgd /*-
4 1.30 perry * Copyright (c) 1990, 1993
5 1.30 perry * The Regents of the University of California. All rights reserved.
6 1.1 cgd *
7 1.1 cgd * Redistribution and use in source and binary forms, with or without
8 1.1 cgd * modification, are permitted provided that the following conditions
9 1.1 cgd * are met:
10 1.1 cgd * 1. Redistributions of source code must retain the above copyright
11 1.1 cgd * notice, this list of conditions and the following disclaimer.
12 1.1 cgd * 2. Redistributions in binary form must reproduce the above copyright
13 1.1 cgd * notice, this list of conditions and the following disclaimer in the
14 1.1 cgd * documentation and/or other materials provided with the distribution.
15 1.64 agc * 3. Neither the name of the University nor the names of its contributors
16 1.1 cgd * may be used to endorse or promote products derived from this software
17 1.1 cgd * without specific prior written permission.
18 1.1 cgd *
19 1.1 cgd * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
20 1.1 cgd * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
21 1.1 cgd * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
22 1.1 cgd * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
23 1.1 cgd * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
24 1.1 cgd * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
25 1.1 cgd * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
26 1.1 cgd * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
27 1.1 cgd * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
28 1.1 cgd * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
29 1.1 cgd * SUCH DAMAGE.
30 1.1 cgd *
31 1.30 perry * @(#)stdlib.h 8.5 (Berkeley) 5/19/95
32 1.1 cgd */
33 1.1 cgd
34 1.1 cgd #ifndef _STDLIB_H_
35 1.1 cgd #define _STDLIB_H_
36 1.6 jtc
37 1.37 mycroft #include <sys/cdefs.h>
38 1.32 kleink #include <sys/featuretest.h>
39 1.32 kleink
40 1.62 bjh21 #if defined(_NETBSD_SOURCE)
41 1.32 kleink #include <sys/types.h> /* for quad_t, etc. */
42 1.23 jtc #endif
43 1.23 jtc
44 1.30 perry #include <machine/ansi.h>
45 1.30 perry
46 1.16 cgd #ifdef _BSD_SIZE_T_
47 1.16 cgd typedef _BSD_SIZE_T_ size_t;
48 1.16 cgd #undef _BSD_SIZE_T_
49 1.6 jtc #endif
50 1.1 cgd
51 1.90 christos #if defined(_BSD_WCHAR_T_) && !defined(__cplusplus)
52 1.16 cgd typedef _BSD_WCHAR_T_ wchar_t;
53 1.16 cgd #undef _BSD_WCHAR_T_
54 1.1 cgd #endif
55 1.1 cgd
56 1.1 cgd typedef struct {
57 1.1 cgd int quot; /* quotient */
58 1.1 cgd int rem; /* remainder */
59 1.1 cgd } div_t;
60 1.23 jtc
61 1.1 cgd typedef struct {
62 1.1 cgd long quot; /* quotient */
63 1.1 cgd long rem; /* remainder */
64 1.1 cgd } ldiv_t;
65 1.10 jtc
66 1.126 riastrad #if defined(_ISOC99_SOURCE) || (__STDC_VERSION__ - 0) >= 199901L || \
67 1.126 riastrad defined(_NETBSD_SOURCE) || (__cplusplus - 0) >= 201103L
68 1.45 kleink typedef struct {
69 1.45 kleink /* LONGLONG */
70 1.45 kleink long long int quot; /* quotient */
71 1.45 kleink /* LONGLONG */
72 1.45 kleink long long int rem; /* remainder */
73 1.45 kleink } lldiv_t;
74 1.45 kleink #endif
75 1.45 kleink
76 1.62 bjh21 #if defined(_NETBSD_SOURCE)
77 1.23 jtc typedef struct {
78 1.23 jtc quad_t quot; /* quotient */
79 1.23 jtc quad_t rem; /* remainder */
80 1.23 jtc } qdiv_t;
81 1.23 jtc #endif
82 1.23 jtc
83 1.23 jtc
84 1.44 kleink #include <sys/null.h>
85 1.1 cgd
86 1.1 cgd #define EXIT_FAILURE 1
87 1.1 cgd #define EXIT_SUCCESS 0
88 1.1 cgd
89 1.1 cgd #define RAND_MAX 0x7fffffff
90 1.1 cgd
91 1.47 kleink extern size_t __mb_cur_max;
92 1.30 perry #define MB_CUR_MAX __mb_cur_max
93 1.1 cgd
94 1.1 cgd __BEGIN_DECLS
95 1.80 perry __dead void _Exit(int);
96 1.80 perry __dead void abort(void);
97 1.121 maya __constfunc int abs(int);
98 1.69 perry int atexit(void (*)(void));
99 1.69 perry double atof(const char *);
100 1.69 perry int atoi(const char *);
101 1.69 perry long atol(const char *);
102 1.51 christos #ifndef __BSEARCH_DECLARED
103 1.51 christos #define __BSEARCH_DECLARED
104 1.51 christos /* also in search.h */
105 1.69 perry void *bsearch(const void *, const void *, size_t, size_t,
106 1.69 perry int (*)(const void *, const void *));
107 1.51 christos #endif /* __BSEARCH_DECLARED */
108 1.69 perry void *calloc(size_t, size_t);
109 1.69 perry div_t div(int, int);
110 1.80 perry __dead void exit(int);
111 1.69 perry void free(void *);
112 1.69 perry __aconst char *getenv(const char *);
113 1.121 maya __constfunc long
114 1.69 perry labs(long);
115 1.69 perry ldiv_t ldiv(long, long);
116 1.69 perry void *malloc(size_t);
117 1.69 perry void qsort(void *, size_t, size_t, int (*)(const void *, const void *));
118 1.69 perry int rand(void);
119 1.69 perry void *realloc(void *, size_t);
120 1.69 perry void srand(unsigned);
121 1.69 perry double strtod(const char * __restrict, char ** __restrict);
122 1.69 perry long strtol(const char * __restrict, char ** __restrict, int);
123 1.1 cgd unsigned long
124 1.69 perry strtoul(const char * __restrict, char ** __restrict, int);
125 1.111 christos #ifdef _OPENBSD_SOURCE
126 1.112 christos long long strtonum(const char *, long long, long long, const char **);
127 1.111 christos #endif
128 1.69 perry int system(const char *);
129 1.1 cgd
130 1.30 perry /* These are currently just stubs. */
131 1.69 perry int mblen(const char *, size_t);
132 1.69 perry size_t mbstowcs(wchar_t * __restrict, const char * __restrict, size_t);
133 1.69 perry int wctomb(char *, wchar_t);
134 1.69 perry int mbtowc(wchar_t * __restrict, const char * __restrict, size_t);
135 1.69 perry size_t wcstombs(char * __restrict, const wchar_t * __restrict, size_t);
136 1.5 brezak
137 1.62 bjh21 #if defined(_POSIX_C_SOURCE) || defined(_XOPEN_SOURCE) || \
138 1.62 bjh21 defined(_NETBSD_SOURCE)
139 1.32 kleink
140 1.32 kleink
141 1.33 kleink /*
142 1.33 kleink * IEEE Std 1003.1c-95, also adopted by X/Open CAE Spec Issue 5 Version 2
143 1.33 kleink */
144 1.62 bjh21 #if (_POSIX_C_SOURCE - 0) >= 199506L || (_XOPEN_SOURCE - 0) >= 500 || \
145 1.62 bjh21 defined(_REENTRANT) || defined(_NETBSD_SOURCE)
146 1.69 perry int rand_r(unsigned int *);
147 1.33 kleink #endif
148 1.32 kleink
149 1.32 kleink
150 1.33 kleink /*
151 1.33 kleink * X/Open Portability Guide >= Issue 4
152 1.33 kleink */
153 1.83 drochner #if defined(_XOPEN_SOURCE) || defined(_NETBSD_SOURCE)
154 1.69 perry double drand48(void);
155 1.69 perry double erand48(unsigned short[3]);
156 1.69 perry long jrand48(unsigned short[3]);
157 1.69 perry void lcong48(unsigned short[7]);
158 1.69 perry long lrand48(void);
159 1.69 perry long mrand48(void);
160 1.69 perry long nrand48(unsigned short[3]);
161 1.32 kleink unsigned short *
162 1.69 perry seed48(unsigned short[3]);
163 1.69 perry void srand48(long);
164 1.32 kleink
165 1.98 christos #ifndef __LIBC12_SOURCE__
166 1.98 christos int putenv(char *) __RENAME(__putenv50);
167 1.98 christos #endif
168 1.33 kleink #endif
169 1.33 kleink
170 1.33 kleink
171 1.33 kleink /*
172 1.33 kleink * X/Open Portability Guide >= Issue 4 Version 2
173 1.33 kleink */
174 1.62 bjh21 #if (defined(_XOPEN_SOURCE) && defined(_XOPEN_SOURCE_EXTENDED)) || \
175 1.62 bjh21 (_XOPEN_SOURCE - 0) >= 500 || defined(_NETBSD_SOURCE)
176 1.69 perry long a64l(const char *);
177 1.69 perry char *l64a(long);
178 1.33 kleink
179 1.69 perry long random(void);
180 1.69 perry char *setstate(char *);
181 1.108 christos #ifndef __LIBC12_SOURCE__
182 1.109 christos char *initstate(unsigned int, char *, size_t) __RENAME(__initstate60);
183 1.109 christos void srandom(unsigned int) __RENAME(__srandom60);
184 1.108 christos #endif
185 1.82 christos #ifdef _NETBSD_SOURCE
186 1.84 yamt #define RANDOM_MAX 0x7fffffff /* (((long)1 << 31) - 1) */
187 1.110 christos int mkostemps(char *, int, int);
188 1.82 christos #endif
189 1.33 kleink
190 1.70 christos char *mktemp(char *)
191 1.70 christos #ifdef __MKTEMP_OK__
192 1.70 christos __RENAME(_mktemp)
193 1.36 mycroft #endif
194 1.70 christos ;
195 1.33 kleink
196 1.69 perry int setkey(const char *);
197 1.33 kleink
198 1.100 christos char *realpath(const char * __restrict, char * __restrict);
199 1.33 kleink
200 1.69 perry int ttyslot(void);
201 1.33 kleink
202 1.69 perry void *valloc(size_t); /* obsoleted by malloc() */
203 1.67 christos
204 1.69 perry int grantpt(int);
205 1.69 perry int unlockpt(int);
206 1.69 perry char *ptsname(int);
207 1.33 kleink #endif
208 1.33 kleink
209 1.45 kleink /*
210 1.45 kleink * ISO C99
211 1.45 kleink */
212 1.62 bjh21 #if defined(_ISOC99_SOURCE) || (__STDC_VERSION__ - 0) >= 199901L || \
213 1.105 joerg defined(_NETBSD_SOURCE) || (__cplusplus - 0) >= 201103L
214 1.105 joerg
215 1.45 kleink /* LONGLONG */
216 1.69 perry long long int atoll(const char *);
217 1.45 kleink /* LONGLONG */
218 1.69 perry long long int llabs(long long int);
219 1.45 kleink /* LONGLONG */
220 1.69 perry lldiv_t lldiv(long long int, long long int);
221 1.45 kleink /* LONGLONG */
222 1.69 perry long long int strtoll(const char * __restrict, char ** __restrict, int);
223 1.45 kleink /* LONGLONG */
224 1.54 kleink unsigned long long int
225 1.69 perry strtoull(const char * __restrict, char ** __restrict, int);
226 1.76 kleink float strtof(const char * __restrict, char ** __restrict);
227 1.76 kleink long double strtold(const char * __restrict, char ** __restrict);
228 1.45 kleink #endif
229 1.33 kleink
230 1.106 christos #if defined(_ISOC11_SOURCE) || (__STDC_VERSION__ - 0) >= 201101L || \
231 1.106 christos defined(_NETBSD_SOURCE) || (__cplusplus - 0) >= 201103L
232 1.116 nros void *aligned_alloc(size_t, size_t);
233 1.106 christos int at_quick_exit(void (*)(void));
234 1.106 christos __dead void quick_exit(int);
235 1.106 christos #endif
236 1.106 christos
237 1.33 kleink /*
238 1.61 kleink * The Open Group Base Specifications, Issue 6; IEEE Std 1003.1-2001 (POSIX)
239 1.59 kleink */
240 1.62 bjh21 #if (_POSIX_C_SOURCE - 0) >= 200112L || (_XOPEN_SOURCE - 0) >= 600 || \
241 1.62 bjh21 defined(_NETBSD_SOURCE)
242 1.69 perry int setenv(const char *, const char *, int);
243 1.71 christos #ifndef __LIBC12_SOURCE__
244 1.69 perry int unsetenv(const char *) __RENAME(__unsetenv13);
245 1.59 kleink #endif
246 1.67 christos
247 1.69 perry int posix_openpt(int);
248 1.78 ad int posix_memalign(void **, size_t, size_t);
249 1.59 kleink #endif
250 1.59 kleink
251 1.59 kleink /*
252 1.123 christos * The Open Group Base Specifications, Issue 7; IEEE Std 1003.1-2008 (POSIX)
253 1.123 christos * or
254 1.123 christos * X/Open Portability Guide >= Issue 4 Version 2
255 1.123 christos */
256 1.123 christos #if (_POSIX_C_SOURCE - 0) >= 200809L || \
257 1.123 christos (defined(_XOPEN_SOURCE) && defined(_XOPEN_SOURCE_EXTENDED)) || \
258 1.123 christos (_XOPEN_SOURCE - 0) >= 500 || defined(_NETBSD_SOURCE)
259 1.123 christos char *mkdtemp(char *);
260 1.123 christos int mkstemp(char *);
261 1.123 christos
262 1.123 christos int getsubopt(char **, char * const *, char **);
263 1.123 christos #endif
264 1.123 christos
265 1.123 christos /*
266 1.33 kleink * Implementation-defined extensions
267 1.33 kleink */
268 1.62 bjh21 #if defined(_NETBSD_SOURCE)
269 1.124 nia #if defined(__PCC__) && !defined(__GNUC__)
270 1.85 gmcgarry #define alloca(size) __builtin_alloca(size)
271 1.82 christos #else
272 1.82 christos void *alloca(size_t);
273 1.82 christos #endif /* __GNUC__ */
274 1.11 cgd
275 1.75 perry uint32_t arc4random(void);
276 1.69 perry void arc4random_stir(void);
277 1.95 christos void arc4random_buf(void *, size_t);
278 1.95 christos uint32_t arc4random_uniform(uint32_t);
279 1.122 joerg void arc4random_addrandom(unsigned char *, int);
280 1.69 perry char *getbsize(int *, long *);
281 1.69 perry char *cgetcap(char *, const char *, int);
282 1.69 perry int cgetclose(void);
283 1.69 perry int cgetent(char **, const char * const *, const char *);
284 1.69 perry int cgetfirst(char **, const char * const *);
285 1.69 perry int cgetmatch(const char *, const char *);
286 1.69 perry int cgetnext(char **, const char * const *);
287 1.69 perry int cgetnum(char *, const char *, long *);
288 1.69 perry int cgetset(const char *);
289 1.69 perry int cgetstr(char *, const char *, char **);
290 1.69 perry int cgetustr(char *, const char *, char **);
291 1.81 christos void csetexpandtc(int);
292 1.69 perry
293 1.69 perry int daemon(int, int);
294 1.99 joerg int devname_r(dev_t, mode_t, char *, size_t);
295 1.86 christos #ifndef __LIBC12_SOURCE__
296 1.86 christos __aconst char *devname(dev_t, mode_t) __RENAME(__devname50);
297 1.86 christos #endif
298 1.79 christos
299 1.79 christos #define HN_DECIMAL 0x01
300 1.79 christos #define HN_NOSPACE 0x02
301 1.79 christos #define HN_B 0x04
302 1.79 christos #define HN_DIVISOR_1000 0x08
303 1.79 christos
304 1.79 christos #define HN_GETSCALE 0x10
305 1.79 christos #define HN_AUTOSCALE 0x20
306 1.79 christos
307 1.79 christos int humanize_number(char *, size_t, int64_t, const char *, int, int);
308 1.79 christos int dehumanize_number(const char *, int64_t *);
309 1.117 christos ssize_t hmac(const char *, const void *, size_t, const void *, size_t, void *,
310 1.117 christos size_t);
311 1.79 christos
312 1.88 drochner devmajor_t getdevmajor(const char *, mode_t);
313 1.69 perry int getloadavg(double [], int);
314 1.69 perry
315 1.73 kleink int getenv_r(const char *, char *, size_t);
316 1.73 kleink
317 1.69 perry void cfree(void *);
318 1.69 perry
319 1.69 perry int heapsort(void *, size_t, size_t, int (*)(const void *, const void *));
320 1.130 riastrad int heapsort_r(void *, size_t, size_t,
321 1.130 riastrad int (*)(const void *, const void *, void *), void *);
322 1.69 perry int mergesort(void *, size_t, size_t,
323 1.69 perry int (*)(const void *, const void *));
324 1.130 riastrad int mergesort_r(void *, size_t, size_t,
325 1.130 riastrad int (*)(const void *, const void *, void *), void *);
326 1.107 christos int ptsname_r(int, char *, size_t);
327 1.69 perry int radixsort(const unsigned char **, int, const unsigned char *,
328 1.69 perry unsigned);
329 1.69 perry int sradixsort(const unsigned char **, int, const unsigned char *,
330 1.69 perry unsigned);
331 1.7 jtc
332 1.89 joerg void mi_vector_hash(const void * __restrict, size_t, uint32_t,
333 1.89 joerg uint32_t[3]);
334 1.89 joerg
335 1.69 perry void setproctitle(const char *, ...)
336 1.91 joerg __printflike(1, 2);
337 1.94 jruoho const char *getprogname(void) __constfunc;
338 1.69 perry void setprogname(const char *);
339 1.19 jtc
340 1.69 perry quad_t qabs(quad_t);
341 1.69 perry quad_t strtoq(const char * __restrict, char ** __restrict, int);
342 1.69 perry u_quad_t strtouq(const char * __restrict, char ** __restrict, int);
343 1.57 lukem
344 1.57 lukem /* LONGLONG */
345 1.57 lukem long long strsuftoll(const char *, const char *, long long, long long);
346 1.57 lukem /* LONGLONG */
347 1.57 lukem long long strsuftollx(const char *, const char *, long long, long long,
348 1.57 lukem char *, size_t);
349 1.42 kleink
350 1.69 perry int l64a_r(long, char *, int);
351 1.53 cgd
352 1.69 perry size_t shquote(const char *, char *, size_t);
353 1.69 perry size_t shquotev(int, char * const *, char *, size_t);
354 1.114 joerg
355 1.114 joerg int reallocarr(void *, size_t, size_t);
356 1.62 bjh21 #endif /* _NETBSD_SOURCE */
357 1.62 bjh21 #endif /* _POSIX_C_SOURCE || _XOPEN_SOURCE || _NETBSD_SOURCE */
358 1.55 kleink
359 1.62 bjh21 #if defined(_NETBSD_SOURCE)
360 1.69 perry qdiv_t qdiv(quad_t, quad_t);
361 1.55 kleink #endif
362 1.101 joerg
363 1.101 joerg #if (_POSIX_C_SOURCE - 0) >= 200809L || defined(_NETBSD_SOURCE)
364 1.101 joerg # ifndef __LOCALE_T_DECLARED
365 1.101 joerg typedef struct _locale *locale_t;
366 1.101 joerg # define __LOCALE_T_DECLARED
367 1.101 joerg # endif
368 1.102 joerg double strtod_l(const char * __restrict, char ** __restrict, locale_t);
369 1.102 joerg float strtof_l(const char * __restrict, char ** __restrict, locale_t);
370 1.102 joerg long double strtold_l(const char * __restrict, char ** __restrict,
371 1.102 joerg locale_t);
372 1.101 joerg long strtol_l(const char * __restrict, char ** __restrict, int, locale_t);
373 1.101 joerg unsigned long
374 1.101 joerg strtoul_l(const char * __restrict, char ** __restrict, int, locale_t);
375 1.101 joerg /* LONGLONG */
376 1.101 joerg long long int
377 1.101 joerg strtoll_l(const char * __restrict, char ** __restrict, int, locale_t);
378 1.101 joerg /* LONGLONG */
379 1.101 joerg unsigned long long int
380 1.101 joerg strtoull_l(const char * __restrict, char ** __restrict, int, locale_t);
381 1.101 joerg
382 1.101 joerg # if defined(_NETBSD_SOURCE)
383 1.101 joerg quad_t strtoq_l(const char * __restrict, char ** __restrict, int, locale_t);
384 1.101 joerg u_quad_t strtouq_l(const char * __restrict, char ** __restrict, int, locale_t);
385 1.103 joerg
386 1.104 joerg size_t _mb_cur_max_l(locale_t);
387 1.104 joerg #define MB_CUR_MAX_L(loc) _mb_cur_max_l(loc)
388 1.103 joerg int mblen_l(const char *, size_t, locale_t);
389 1.103 joerg size_t mbstowcs_l(wchar_t * __restrict, const char * __restrict, size_t,
390 1.103 joerg locale_t);
391 1.103 joerg int wctomb_l(char *, wchar_t, locale_t);
392 1.103 joerg int mbtowc_l(wchar_t * __restrict, const char * __restrict, size_t,
393 1.103 joerg locale_t);
394 1.103 joerg size_t wcstombs_l(char * __restrict, const wchar_t * __restrict, size_t,
395 1.103 joerg locale_t);
396 1.103 joerg
397 1.103 joerg # endif /* _NETBSD_SOURCE */
398 1.101 joerg #endif /* _POSIX_C_SOURCE >= 200809 || _NETBSD_SOURCE */
399 1.101 joerg
400 1.127 riastrad #if (_POSIX_C_SOURCE - 0) >= 202405L || \
401 1.127 riastrad defined(_NETBSD_SOURCE) || defined(_OPENBSD_SOURCE)
402 1.127 riastrad void *reallocarray(void *, size_t, size_t);
403 1.129 nia #endif /* _POSIX_C_SOURCE >= 202405L || _NETBSD_SOURCE || _OPENBSD_SOURCE */
404 1.129 nia
405 1.129 nia #if (_POSIX_C_SOURCE - 0) >= 202405L || defined(_NETBSD_SOURCE)
406 1.128 nia int mkostemp(char *, int);
407 1.130 riastrad void qsort_r(void *, size_t, size_t,
408 1.130 riastrad int (*)(const void *, const void *, void *), void *);
409 1.129 nia #endif /* _POSIX_C_SOURCE >= 202405L || _NETBSD_SOURCE */
410 1.127 riastrad
411 1.1 cgd __END_DECLS
412 1.1 cgd
413 1.27 mikel #endif /* !_STDLIB_H_ */
414