Revert "Tidy up and document <limits.h>."
This reverts commit 47eb52732097ff9d4311f923ba48f4eabffe04b7.
Reason for revert: breaks ndk build because the OS build and the NDK build [which is just clang's built-in default] have clang's built-in include/ directory and ours in the opposite order; we'll have to fix the OS build include order before we can come back and do this properly.
Change-Id: Ide5e05dec2f28d36e731bd896b00f7fd8469a6d0
diff --git a/libc/include/limits.h b/libc/include/limits.h
index 132f1ed..e1f566c 100644
--- a/libc/include/limits.h
+++ b/libc/include/limits.h
@@ -1,3 +1,6 @@
+/* $OpenBSD: limits.h,v 1.13 2005/12/31 19:29:38 millert Exp $ */
+/* $NetBSD: limits.h,v 1.7 1994/10/26 00:56:00 cgd Exp $ */
+
/*
* Copyright (c) 1988 The Regents of the University of California.
* All rights reserved.
@@ -29,83 +32,108 @@
* @(#)limits.h 5.9 (Berkeley) 4/3/91
*/
-#pragma once
+#ifndef _LIMITS_H_
+#define _LIMITS_H_
#include <sys/cdefs.h>
-/* Defer to the compiler for the built-in C types. */
-#include_next <limits.h>
-
/* Historically bionic exposed the content of <float.h> from <limits.h> and <sys/limits.h> too. */
#include <float.h>
-/* Many of the POSIX limits come from the kernel. */
#include <linux/limits.h>
-/*
- * bionic always exposed these alternative names,
- * but clang's <limits.h> considers them GNU extensions,
- * and may or may not have defined them.
- */
-#ifndef LONG_LONG_MIN
-/** Non-portable synonym; use LLONG_MIN directly instead. */
-#define LONG_LONG_MIN LLONG_MIN
-#endif
-#ifndef LONG_LONG_MAX
-/** Non-portable synonym; use LLONG_MAX directly instead. */
-#define LONG_LONG_MAX LLONG_MAX
-#endif
-#ifndef ULONG_LONG_MAX
-/** Non-portable synonym; use ULLONG_MAX directly instead. */
-#define ULONG_LONG_MAX ULLONG_MAX
-#endif
+#define PASS_MAX 128 /* _PASSWORD_LEN from <pwd.h> */
-/** Maximum number of positional arguments in a printf()/scanf() format string. */
-#define NL_ARGMAX 9
-/** Maximum number of bytes in a $LANG name. */
-#define NL_LANGMAX 14
-/** Irrelevant with Android's <nl_types.h>. */
-#define NL_MSGMAX 32767
-/** Obsolete; removed from POSIX. */
-#define NL_NMAX 1
-/** Irrelevant with Android's <nl_types.h>. */
-#define NL_SETMAX 255
-/** Irrelevant with Android's <nl_types.h>. */
-#define NL_TEXTMAX 255
+#define NL_ARGMAX 9
+#define NL_LANGMAX 14
+#define NL_MSGMAX 32767
+#define NL_NMAX 1
+#define NL_SETMAX 255
+#define NL_TEXTMAX 255
-/** Obsolete; removed from POSIX. */
-#define PASS_MAX 128
-/** Obsolete; removed from POSIX. */
-#define TMP_MAX 308915776
+#define TMP_MAX 308915776
-/** Number of bits in a `long` (POSIX). */
-#if __LP64__
-#define LONG_BIT 64
+/* TODO: get all these from the compiler's <limits.h>? */
+
+#define CHAR_BIT 8
+#ifdef __LP64__
+# define LONG_BIT 64
#else
-#define LONG_BIT 32
+# define LONG_BIT 32
#endif
-/** Number of bits in a "word" of `int` (POSIX). */
#define WORD_BIT 32
-/** Maximum value of a uid_t. */
-#define UID_MAX UINT_MAX
-/** Maximum value of a gid_t. */
-#define GID_MAX UINT_MAX
-/** Maximum value of a size_t. */
-#define SIZE_T_MAX ULONG_MAX
-/** Maximum value of a ssize_t. */
-#define SSIZE_MAX LONG_MAX
+#define SCHAR_MAX 0x7f /* max value for a signed char */
+#define SCHAR_MIN (-0x7f-1) /* min value for a signed char */
-/** Maximum number of bytes in a multibyte character. */
+#define UCHAR_MAX 0xffU /* max value for an unsigned char */
+#ifdef __CHAR_UNSIGNED__
+# define CHAR_MIN 0 /* min value for a char */
+# define CHAR_MAX 0xff /* max value for a char */
+#else
+# define CHAR_MAX 0x7f
+# define CHAR_MIN (-0x7f-1)
+#endif
+
+#define USHRT_MAX 0xffffU /* max value for an unsigned short */
+#define SHRT_MAX 0x7fff /* max value for a short */
+#define SHRT_MIN (-0x7fff-1) /* min value for a short */
+
+#define UINT_MAX 0xffffffffU /* max value for an unsigned int */
+#define INT_MAX 0x7fffffff /* max value for an int */
+#define INT_MIN (-0x7fffffff-1) /* min value for an int */
+
+#ifdef __LP64__
+# define ULONG_MAX 0xffffffffffffffffUL /* max value for unsigned long */
+# define LONG_MAX 0x7fffffffffffffffL /* max value for a signed long */
+# define LONG_MIN (-0x7fffffffffffffffL-1) /* min value for a signed long */
+#else
+# define ULONG_MAX 0xffffffffUL /* max value for an unsigned long */
+# define LONG_MAX 0x7fffffffL /* max value for a long */
+# define LONG_MIN (-0x7fffffffL-1)/* min value for a long */
+#endif
+
+# define ULLONG_MAX 0xffffffffffffffffULL /* max value for unsigned long long */
+# define LLONG_MAX 0x7fffffffffffffffLL /* max value for a signed long long */
+# define LLONG_MIN (-0x7fffffffffffffffLL-1) /* min value for a signed long long */
+
+/* GLibc compatibility definitions.
+ Note that these are defined by GCC's <limits.h>
+ only when __GNU_LIBRARY__ is defined, i.e. when
+ targetting GLibc. */
+#ifndef LONG_LONG_MIN
+#define LONG_LONG_MIN LLONG_MIN
+#endif
+
+#ifndef LONG_LONG_MAX
+#define LONG_LONG_MAX LLONG_MAX
+#endif
+
+#ifndef ULONG_LONG_MAX
+#define ULONG_LONG_MAX ULLONG_MAX
+#endif
+
+#if defined(__USE_BSD) || defined(__BIONIC__) /* Historically bionic exposed these. */
+# define UID_MAX UINT_MAX /* max value for a uid_t */
+# define GID_MAX UINT_MAX /* max value for a gid_t */
+#if defined(__LP64__)
+#define SIZE_T_MAX ULONG_MAX
+#else
+#define SIZE_T_MAX UINT_MAX
+#endif
+#endif
+
+#if defined(__LP64__)
+#define SSIZE_MAX LONG_MAX
+#else
+#define SSIZE_MAX INT_MAX
+#endif
+
#define MB_LEN_MAX 4
-/** Default process priority. */
#define NZERO 20
-/** Maximum number of struct iovec that can be passed in a single readv()/writev(). */
#define IOV_MAX 1024
-
-/** Maximum value for a semaphore. */
#define SEM_VALUE_MAX 0x3fffffff
/** Do not use: prefer getline() or asprintf() rather than hard-coding an arbitrary size. */
@@ -114,17 +142,12 @@
/* POSIX says these belong in <unistd.h> but BSD has some in <limits.h>. */
#include <bits/posix_limits.h>
-/** Maximum length of a hostname returned by gethostname(). */
#define HOST_NAME_MAX _POSIX_HOST_NAME_MAX
-
-/** Maximum length of a login name. */
#define LOGIN_NAME_MAX 256
-
-/** Maximum length of terminal device name. */
#define TTY_NAME_MAX 32
-/** Maximum number of attempts to destroy thread-specific data when a thread exits. */
-#define PTHREAD_DESTRUCTOR_ITERATIONS _POSIX_THREAD_DESTRUCTOR_ITERATIONS
+/* >= _POSIX_THREAD_DESTRUCTOR_ITERATIONS */
+#define PTHREAD_DESTRUCTOR_ITERATIONS 4
/**
* The number of calls to pthread_key_create() without intervening calls to
@@ -133,5 +156,7 @@
*/
#define PTHREAD_KEYS_MAX 128
-/** bionic has no fixed limit on the number of threads. */
+/** bionic has no specific limit on the number of threads. */
#undef PTHREAD_THREADS_MAX
+
+#endif /* !_LIMITS_H_ */