xref: /aosp_15_r20/bionic/libc/include/limits.h (revision 8d67ca893c1523eb926b9080dbe4e2ffd2a27ba1)
1*8d67ca89SAndroid Build Coastguard Worker /*
2*8d67ca89SAndroid Build Coastguard Worker  * Copyright (c) 1988 The Regents of the University of California.
3*8d67ca89SAndroid Build Coastguard Worker  * All rights reserved.
4*8d67ca89SAndroid Build Coastguard Worker  *
5*8d67ca89SAndroid Build Coastguard Worker  * Redistribution and use in source and binary forms, with or without
6*8d67ca89SAndroid Build Coastguard Worker  * modification, are permitted provided that the following conditions
7*8d67ca89SAndroid Build Coastguard Worker  * are met:
8*8d67ca89SAndroid Build Coastguard Worker  * 1. Redistributions of source code must retain the above copyright
9*8d67ca89SAndroid Build Coastguard Worker  *    notice, this list of conditions and the following disclaimer.
10*8d67ca89SAndroid Build Coastguard Worker  * 2. Redistributions in binary form must reproduce the above copyright
11*8d67ca89SAndroid Build Coastguard Worker  *    notice, this list of conditions and the following disclaimer in the
12*8d67ca89SAndroid Build Coastguard Worker  *    documentation and/or other materials provided with the distribution.
13*8d67ca89SAndroid Build Coastguard Worker  * 3. Neither the name of the University nor the names of its contributors
14*8d67ca89SAndroid Build Coastguard Worker  *    may be used to endorse or promote products derived from this software
15*8d67ca89SAndroid Build Coastguard Worker  *    without specific prior written permission.
16*8d67ca89SAndroid Build Coastguard Worker  *
17*8d67ca89SAndroid Build Coastguard Worker  * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
18*8d67ca89SAndroid Build Coastguard Worker  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
19*8d67ca89SAndroid Build Coastguard Worker  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
20*8d67ca89SAndroid Build Coastguard Worker  * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
21*8d67ca89SAndroid Build Coastguard Worker  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
22*8d67ca89SAndroid Build Coastguard Worker  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
23*8d67ca89SAndroid Build Coastguard Worker  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
24*8d67ca89SAndroid Build Coastguard Worker  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
25*8d67ca89SAndroid Build Coastguard Worker  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
26*8d67ca89SAndroid Build Coastguard Worker  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
27*8d67ca89SAndroid Build Coastguard Worker  * SUCH DAMAGE.
28*8d67ca89SAndroid Build Coastguard Worker  *
29*8d67ca89SAndroid Build Coastguard Worker  *	@(#)limits.h	5.9 (Berkeley) 4/3/91
30*8d67ca89SAndroid Build Coastguard Worker  */
31*8d67ca89SAndroid Build Coastguard Worker 
32*8d67ca89SAndroid Build Coastguard Worker #pragma once
33*8d67ca89SAndroid Build Coastguard Worker 
34*8d67ca89SAndroid Build Coastguard Worker /**
35*8d67ca89SAndroid Build Coastguard Worker  * @file limits.h
36*8d67ca89SAndroid Build Coastguard Worker  * @brief Constants relating to implementation limits.
37*8d67ca89SAndroid Build Coastguard Worker  *
38*8d67ca89SAndroid Build Coastguard Worker  * This file is included via `#include_next` from the clang header of the same
39*8d67ca89SAndroid Build Coastguard Worker  * name that provides all the limits that the compiler is responsible for,
40*8d67ca89SAndroid Build Coastguard Worker  * primarily those relating to integer types defined by the C standard.
41*8d67ca89SAndroid Build Coastguard Worker  * This file defines the additional limits defined by POSIX.
42*8d67ca89SAndroid Build Coastguard Worker  */
43*8d67ca89SAndroid Build Coastguard Worker 
44*8d67ca89SAndroid Build Coastguard Worker /*
45*8d67ca89SAndroid Build Coastguard Worker  * The Android build system has bionic _before_ the clang headers,
46*8d67ca89SAndroid Build Coastguard Worker  * so although the claim above that clang does an `#include_next`
47*8d67ca89SAndroid Build Coastguard Worker  * of this file is true for the NDK, it's not true for the OS,
48*8d67ca89SAndroid Build Coastguard Worker  * and we need to paper over that difference here until/unless
49*8d67ca89SAndroid Build Coastguard Worker  * the OS build changes.
50*8d67ca89SAndroid Build Coastguard Worker  */
51*8d67ca89SAndroid Build Coastguard Worker #if __has_include_next(<limits.h>)
52*8d67ca89SAndroid Build Coastguard Worker #include_next <limits.h>
53*8d67ca89SAndroid Build Coastguard Worker #endif
54*8d67ca89SAndroid Build Coastguard Worker 
55*8d67ca89SAndroid Build Coastguard Worker #include <sys/cdefs.h>
56*8d67ca89SAndroid Build Coastguard Worker 
57*8d67ca89SAndroid Build Coastguard Worker /* Historically bionic exposed the content of <float.h> from <limits.h> and <sys/limits.h> too. */
58*8d67ca89SAndroid Build Coastguard Worker #include <float.h>
59*8d67ca89SAndroid Build Coastguard Worker 
60*8d67ca89SAndroid Build Coastguard Worker /* Many of the POSIX limits come from the kernel. */
61*8d67ca89SAndroid Build Coastguard Worker #include <linux/limits.h>
62*8d67ca89SAndroid Build Coastguard Worker 
63*8d67ca89SAndroid Build Coastguard Worker /*
64*8d67ca89SAndroid Build Coastguard Worker  * bionic always exposed these alternative names,
65*8d67ca89SAndroid Build Coastguard Worker  * but clang's <limits.h> considers them GNU extensions,
66*8d67ca89SAndroid Build Coastguard Worker  * and may or may not have defined them.
67*8d67ca89SAndroid Build Coastguard Worker  */
68*8d67ca89SAndroid Build Coastguard Worker #ifndef LONG_LONG_MIN
69*8d67ca89SAndroid Build Coastguard Worker /** Non-portable synonym; use LLONG_MIN directly instead. */
70*8d67ca89SAndroid Build Coastguard Worker #define LONG_LONG_MIN LLONG_MIN
71*8d67ca89SAndroid Build Coastguard Worker #endif
72*8d67ca89SAndroid Build Coastguard Worker #ifndef LONG_LONG_MAX
73*8d67ca89SAndroid Build Coastguard Worker /** Non-portable synonym; use LLONG_MAX directly instead. */
74*8d67ca89SAndroid Build Coastguard Worker #define LONG_LONG_MAX LLONG_MAX
75*8d67ca89SAndroid Build Coastguard Worker #endif
76*8d67ca89SAndroid Build Coastguard Worker #ifndef ULONG_LONG_MAX
77*8d67ca89SAndroid Build Coastguard Worker /** Non-portable synonym; use ULLONG_MAX directly instead. */
78*8d67ca89SAndroid Build Coastguard Worker #define ULONG_LONG_MAX ULLONG_MAX
79*8d67ca89SAndroid Build Coastguard Worker #endif
80*8d67ca89SAndroid Build Coastguard Worker 
81*8d67ca89SAndroid Build Coastguard Worker /** Maximum number of positional arguments in a printf()/scanf() format string. */
82*8d67ca89SAndroid Build Coastguard Worker #define NL_ARGMAX 9
83*8d67ca89SAndroid Build Coastguard Worker /** Maximum number of bytes in a $LANG name. */
84*8d67ca89SAndroid Build Coastguard Worker #define NL_LANGMAX 14
85*8d67ca89SAndroid Build Coastguard Worker /** Irrelevant with Android's <nl_types.h>. */
86*8d67ca89SAndroid Build Coastguard Worker #define NL_MSGMAX 32767
87*8d67ca89SAndroid Build Coastguard Worker /** Obsolete; removed from POSIX. */
88*8d67ca89SAndroid Build Coastguard Worker #define NL_NMAX 1
89*8d67ca89SAndroid Build Coastguard Worker /** Irrelevant with Android's <nl_types.h>. */
90*8d67ca89SAndroid Build Coastguard Worker #define NL_SETMAX 255
91*8d67ca89SAndroid Build Coastguard Worker /** Irrelevant with Android's <nl_types.h>. */
92*8d67ca89SAndroid Build Coastguard Worker #define NL_TEXTMAX 255
93*8d67ca89SAndroid Build Coastguard Worker 
94*8d67ca89SAndroid Build Coastguard Worker /** Obsolete; removed from POSIX. */
95*8d67ca89SAndroid Build Coastguard Worker #define PASS_MAX 128
96*8d67ca89SAndroid Build Coastguard Worker /** Obsolete; removed from POSIX. */
97*8d67ca89SAndroid Build Coastguard Worker #define TMP_MAX 308915776
98*8d67ca89SAndroid Build Coastguard Worker 
99*8d67ca89SAndroid Build Coastguard Worker /** Number of bits in a `long` (POSIX). */
100*8d67ca89SAndroid Build Coastguard Worker #if __LP64__
101*8d67ca89SAndroid Build Coastguard Worker #define LONG_BIT 64
102*8d67ca89SAndroid Build Coastguard Worker #else
103*8d67ca89SAndroid Build Coastguard Worker #define LONG_BIT 32
104*8d67ca89SAndroid Build Coastguard Worker #endif
105*8d67ca89SAndroid Build Coastguard Worker /** Number of bits in a "word" of `int` (POSIX). */
106*8d67ca89SAndroid Build Coastguard Worker #define WORD_BIT 32
107*8d67ca89SAndroid Build Coastguard Worker 
108*8d67ca89SAndroid Build Coastguard Worker /** Maximum value of a uid_t. */
109*8d67ca89SAndroid Build Coastguard Worker #define UID_MAX UINT_MAX
110*8d67ca89SAndroid Build Coastguard Worker /** Maximum value of a gid_t. */
111*8d67ca89SAndroid Build Coastguard Worker #define GID_MAX UINT_MAX
112*8d67ca89SAndroid Build Coastguard Worker /** Maximum value of a size_t. */
113*8d67ca89SAndroid Build Coastguard Worker #define SIZE_T_MAX ULONG_MAX
114*8d67ca89SAndroid Build Coastguard Worker /** Maximum value of a ssize_t. */
115*8d67ca89SAndroid Build Coastguard Worker #define SSIZE_MAX LONG_MAX
116*8d67ca89SAndroid Build Coastguard Worker 
117*8d67ca89SAndroid Build Coastguard Worker /** Maximum number of bytes in a multibyte character. */
118*8d67ca89SAndroid Build Coastguard Worker #define MB_LEN_MAX 4
119*8d67ca89SAndroid Build Coastguard Worker 
120*8d67ca89SAndroid Build Coastguard Worker /** Default process priority. */
121*8d67ca89SAndroid Build Coastguard Worker #define NZERO 20
122*8d67ca89SAndroid Build Coastguard Worker 
123*8d67ca89SAndroid Build Coastguard Worker /** Maximum number of struct iovec that can be passed in a single readv()/writev(). */
124*8d67ca89SAndroid Build Coastguard Worker #define IOV_MAX 1024
125*8d67ca89SAndroid Build Coastguard Worker 
126*8d67ca89SAndroid Build Coastguard Worker /** Maximum value for a semaphore. */
127*8d67ca89SAndroid Build Coastguard Worker #define SEM_VALUE_MAX 0x3fffffff
128*8d67ca89SAndroid Build Coastguard Worker 
129*8d67ca89SAndroid Build Coastguard Worker /** Do not use: prefer getline() or asprintf() rather than hard-coding an arbitrary size. */
130*8d67ca89SAndroid Build Coastguard Worker #define LINE_MAX _POSIX2_LINE_MAX
131*8d67ca89SAndroid Build Coastguard Worker 
132*8d67ca89SAndroid Build Coastguard Worker /* POSIX says these belong in <unistd.h> but BSD has some in <limits.h>. */
133*8d67ca89SAndroid Build Coastguard Worker #include <bits/posix_limits.h>
134*8d67ca89SAndroid Build Coastguard Worker 
135*8d67ca89SAndroid Build Coastguard Worker /** Maximum length of a hostname returned by gethostname(). */
136*8d67ca89SAndroid Build Coastguard Worker #define HOST_NAME_MAX _POSIX_HOST_NAME_MAX
137*8d67ca89SAndroid Build Coastguard Worker 
138*8d67ca89SAndroid Build Coastguard Worker /** Maximum length of a login name. */
139*8d67ca89SAndroid Build Coastguard Worker #define LOGIN_NAME_MAX 256
140*8d67ca89SAndroid Build Coastguard Worker 
141*8d67ca89SAndroid Build Coastguard Worker /** Maximum length of terminal device name. */
142*8d67ca89SAndroid Build Coastguard Worker #define TTY_NAME_MAX 32
143*8d67ca89SAndroid Build Coastguard Worker 
144*8d67ca89SAndroid Build Coastguard Worker /** Maximum number of attempts to destroy thread-specific data when a thread exits. */
145*8d67ca89SAndroid Build Coastguard Worker #define PTHREAD_DESTRUCTOR_ITERATIONS _POSIX_THREAD_DESTRUCTOR_ITERATIONS
146*8d67ca89SAndroid Build Coastguard Worker 
147*8d67ca89SAndroid Build Coastguard Worker /**
148*8d67ca89SAndroid Build Coastguard Worker  * The number of calls to pthread_key_create() without intervening calls to
149*8d67ca89SAndroid Build Coastguard Worker  * pthread_key_delete() that are guaranteed to succeed. See pthread_key_create()
150*8d67ca89SAndroid Build Coastguard Worker  * for more details and ways to avoid hitting this limit.
151*8d67ca89SAndroid Build Coastguard Worker  */
152*8d67ca89SAndroid Build Coastguard Worker #define PTHREAD_KEYS_MAX 128
153*8d67ca89SAndroid Build Coastguard Worker 
154*8d67ca89SAndroid Build Coastguard Worker /** bionic has no fixed limit on the number of threads. */
155*8d67ca89SAndroid Build Coastguard Worker #undef PTHREAD_THREADS_MAX
156