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