2008-11-17 00:36:30 +08:00
|
|
|
/****************************************************************************
|
|
|
|
* include/stdlib.h
|
2007-02-18 07:21:28 +08:00
|
|
|
*
|
2015-08-14 22:35:01 +08:00
|
|
|
* Copyright (C) 2007-2015 Gregory Nutt. All rights reserved.
|
2012-02-01 07:39:12 +08:00
|
|
|
* Author: Gregory Nutt <gnutt@nuttx.org>
|
2007-02-18 07:21:28 +08:00
|
|
|
*
|
|
|
|
* Redistribution and use in source and binary forms, with or without
|
|
|
|
* modification, are permitted provided that the following conditions
|
|
|
|
* are met:
|
|
|
|
*
|
|
|
|
* 1. Redistributions of source code must retain the above copyright
|
|
|
|
* notice, this list of conditions and the following disclaimer.
|
|
|
|
* 2. Redistributions in binary form must reproduce the above copyright
|
|
|
|
* notice, this list of conditions and the following disclaimer in
|
|
|
|
* the documentation and/or other materials provided with the
|
|
|
|
* distribution.
|
2008-11-17 00:36:30 +08:00
|
|
|
* 3. Neither the name NuttX nor the names of its contributors may be
|
2007-02-18 07:21:28 +08:00
|
|
|
* used to endorse or promote products derived from this software
|
|
|
|
* without specific prior written permission.
|
|
|
|
*
|
|
|
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
|
|
|
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
|
|
|
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
|
|
|
|
* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
|
|
|
|
* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
|
|
|
|
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
|
|
|
|
* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
|
|
|
|
* OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
|
|
|
|
* AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
|
|
|
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
|
|
|
|
* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
|
|
|
* POSSIBILITY OF SUCH DAMAGE.
|
|
|
|
*
|
2008-11-17 00:36:30 +08:00
|
|
|
****************************************************************************/
|
2007-02-18 07:21:28 +08:00
|
|
|
|
2008-11-17 00:36:30 +08:00
|
|
|
#ifndef __INCLUDE_STDLIB_H
|
|
|
|
#define __INCLUDE_STDLIB_H
|
2007-02-18 07:21:28 +08:00
|
|
|
|
2008-11-17 00:36:30 +08:00
|
|
|
/****************************************************************************
|
2007-02-18 07:21:28 +08:00
|
|
|
* Included Files
|
2008-11-17 00:36:30 +08:00
|
|
|
****************************************************************************/
|
2007-02-18 07:21:28 +08:00
|
|
|
|
2007-07-01 01:05:44 +08:00
|
|
|
#include <nuttx/config.h>
|
2010-10-10 05:12:49 +08:00
|
|
|
#include <nuttx/compiler.h>
|
2007-02-18 07:21:28 +08:00
|
|
|
#include <sys/types.h>
|
2010-10-10 05:12:49 +08:00
|
|
|
#include <stdint.h>
|
2007-02-18 07:21:28 +08:00
|
|
|
|
2008-11-17 00:36:30 +08:00
|
|
|
/****************************************************************************
|
2014-09-29 00:15:33 +08:00
|
|
|
* Pre-processor Definitions
|
2008-11-17 00:36:30 +08:00
|
|
|
****************************************************************************/
|
2007-02-18 07:21:28 +08:00
|
|
|
|
2015-08-04 01:01:41 +08:00
|
|
|
/* The C standard specifies two constants, EXIT_SUCCESS and EXIT_FAILURE,
|
|
|
|
* that may be passed to exit() to indicate successful or unsuccessful
|
|
|
|
* termination, respectively.
|
2007-02-18 07:21:28 +08:00
|
|
|
*/
|
|
|
|
|
|
|
|
#define EXIT_SUCCESS 0
|
|
|
|
#define EXIT_FAILURE 1
|
|
|
|
|
2011-10-31 01:28:54 +08:00
|
|
|
/* The NULL pointer should be defined in this file but is currently defined
|
|
|
|
* in sys/types.h.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/* Maximum value returned by rand() */
|
|
|
|
|
2015-04-16 23:35:29 +08:00
|
|
|
#define RAND_MAX 32767
|
2011-10-31 01:28:54 +08:00
|
|
|
|
|
|
|
/* Integer expression whose value is the maximum number of bytes in a
|
2014-04-14 04:32:20 +08:00
|
|
|
* character specified by the current locale.
|
2011-10-31 01:28:54 +08:00
|
|
|
*/
|
|
|
|
|
|
|
|
#define MB_CUR_MAX 1
|
|
|
|
|
2015-08-04 01:01:41 +08:00
|
|
|
/* The environ variable, normally 'char **environ;' is not implemented as a
|
|
|
|
* function call. However, get_environ_ptr() can be used in its place.
|
2007-07-01 01:05:44 +08:00
|
|
|
*/
|
|
|
|
|
2015-05-24 07:08:35 +08:00
|
|
|
#ifndef CONFIG_DISABLE_ENVIRON
|
2007-07-01 01:05:44 +08:00
|
|
|
# define environ get_environ_ptr()
|
|
|
|
#endif
|
|
|
|
|
2008-11-17 00:36:30 +08:00
|
|
|
/****************************************************************************
|
2015-08-04 01:01:41 +08:00
|
|
|
* Public Type Definitions
|
2008-11-17 00:36:30 +08:00
|
|
|
****************************************************************************/
|
2007-02-18 07:21:28 +08:00
|
|
|
|
|
|
|
struct mallinfo
|
|
|
|
{
|
|
|
|
int arena; /* This is the total size of memory allocated
|
|
|
|
* for use by malloc in bytes. */
|
|
|
|
int ordblks; /* This is the number of free (not in use) chunks */
|
|
|
|
int mxordblk; /* Size of the largest free (not in use) chunk */
|
|
|
|
int uordblks; /* This is the total size of memory occupied by
|
|
|
|
* chunks handed out by malloc. */
|
|
|
|
int fordblks; /* This is the total size of memory occupied
|
|
|
|
* by free (not in use) chunks.*/
|
|
|
|
};
|
|
|
|
|
2015-08-14 22:35:01 +08:00
|
|
|
/* Structure type returned by the div() function. */
|
|
|
|
|
|
|
|
struct div_s
|
|
|
|
{
|
|
|
|
int quot; /* Quotient */
|
|
|
|
int rem; /* Remainder */
|
|
|
|
};
|
|
|
|
|
|
|
|
typedef struct div_s div_t;
|
|
|
|
|
2015-08-14 22:45:59 +08:00
|
|
|
/* Structure type returned by the ldiv() function. */
|
|
|
|
|
|
|
|
struct ldiv_s
|
|
|
|
{
|
|
|
|
long quot; /* Quotient */
|
|
|
|
long rem; /* Remainder */
|
|
|
|
};
|
|
|
|
|
|
|
|
typedef struct ldiv_s ldiv_t;
|
|
|
|
|
|
|
|
/* Structure type returned by the lldiv() function. */
|
|
|
|
|
|
|
|
struct lldiv_s
|
|
|
|
{
|
|
|
|
long quot; /* Quotient */
|
|
|
|
long rem; /* Remainder */
|
|
|
|
};
|
|
|
|
|
|
|
|
typedef struct lldiv_s lldiv_t;
|
|
|
|
|
2008-11-17 00:36:30 +08:00
|
|
|
/****************************************************************************
|
2015-08-04 01:01:41 +08:00
|
|
|
* Public Function Prototypes
|
2008-11-17 00:36:30 +08:00
|
|
|
****************************************************************************/
|
2007-02-18 07:21:28 +08:00
|
|
|
|
|
|
|
#undef EXTERN
|
|
|
|
#if defined(__cplusplus)
|
|
|
|
#define EXTERN extern "C"
|
2013-03-09 04:36:18 +08:00
|
|
|
extern "C"
|
|
|
|
{
|
2007-02-18 07:21:28 +08:00
|
|
|
#else
|
|
|
|
#define EXTERN extern
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/* Random number generation */
|
2007-02-28 05:17:21 +08:00
|
|
|
|
2013-03-09 04:36:18 +08:00
|
|
|
void srand(unsigned int seed);
|
|
|
|
int rand(void);
|
2007-02-18 07:21:28 +08:00
|
|
|
|
|
|
|
/* Environment variable support */
|
2007-02-28 05:17:21 +08:00
|
|
|
|
2015-05-24 07:08:35 +08:00
|
|
|
#ifndef CONFIG_DISABLE_ENVIRON
|
2013-03-09 04:36:18 +08:00
|
|
|
FAR char **get_environ_ptr( void );
|
|
|
|
FAR char *getenv(FAR const char *name);
|
|
|
|
int putenv(FAR const char *string);
|
|
|
|
int clearenv(void);
|
|
|
|
int setenv(const char *name, const char *value, int overwrite);
|
|
|
|
int unsetenv(const char *name);
|
2007-07-01 01:05:44 +08:00
|
|
|
#endif
|
2007-02-18 07:21:28 +08:00
|
|
|
|
|
|
|
/* Process exit functions */
|
2007-02-28 05:17:21 +08:00
|
|
|
|
2013-03-09 04:36:18 +08:00
|
|
|
void exit(int status) noreturn_function;
|
|
|
|
void abort(void) noreturn_function;
|
2012-02-01 07:39:12 +08:00
|
|
|
#ifdef CONFIG_SCHED_ATEXIT
|
2013-03-09 04:36:18 +08:00
|
|
|
int atexit(CODE void (*func)(void));
|
2012-02-01 07:39:12 +08:00
|
|
|
#endif
|
|
|
|
#ifdef CONFIG_SCHED_ONEXIT
|
2013-03-09 04:36:18 +08:00
|
|
|
int on_exit(CODE void (*func)(int, FAR void *), FAR void *arg);
|
2012-02-01 07:39:12 +08:00
|
|
|
#endif
|
2007-02-18 07:21:28 +08:00
|
|
|
|
2013-04-19 06:13:38 +08:00
|
|
|
/* _Exit() is a stdlib.h equivalent to the unistd.h _exit() function */
|
|
|
|
|
|
|
|
void _exit(int status); /* See unistd.h */
|
|
|
|
#define _Exit(s) _exit(s)
|
|
|
|
|
2007-02-18 07:21:28 +08:00
|
|
|
/* String to binary conversions */
|
2007-02-28 05:17:21 +08:00
|
|
|
|
2013-03-09 04:36:18 +08:00
|
|
|
long strtol(const char *, char **, int);
|
|
|
|
unsigned long strtoul(const char *, char **, int);
|
2009-06-14 23:36:18 +08:00
|
|
|
#ifdef CONFIG_HAVE_LONG_LONG
|
2013-03-09 04:36:18 +08:00
|
|
|
long long strtoll(const char *, char **, int);
|
|
|
|
unsigned long long strtoull(const char *, char **, int);
|
2009-06-14 23:36:18 +08:00
|
|
|
#endif
|
2013-03-09 04:36:18 +08:00
|
|
|
double_t strtod(const char *, char **);
|
2009-06-14 23:36:18 +08:00
|
|
|
|
2012-01-13 10:49:10 +08:00
|
|
|
#define atoi(nptr) strtol((nptr), NULL, 10)
|
|
|
|
#define atol(nptr) strtol((nptr), NULL, 10)
|
2009-06-14 23:36:18 +08:00
|
|
|
#ifdef CONFIG_HAVE_LONG_LONG
|
2012-01-13 10:49:10 +08:00
|
|
|
#define atoll(nptr) strtoll((nptr), NULL, 10)
|
2009-06-14 23:36:18 +08:00
|
|
|
#endif
|
2012-01-13 10:49:10 +08:00
|
|
|
#define atof(nptr) strtod((nptr), NULL)
|
2007-02-18 07:21:28 +08:00
|
|
|
|
2013-03-15 02:30:06 +08:00
|
|
|
/* Binary to string conversions */
|
|
|
|
|
|
|
|
char *itoa(int value, char *str, int base);
|
|
|
|
|
2007-02-18 07:21:28 +08:00
|
|
|
/* Memory Management */
|
2007-02-28 05:17:21 +08:00
|
|
|
|
2013-03-09 04:36:18 +08:00
|
|
|
FAR void *malloc(size_t);
|
|
|
|
void free(FAR void*);
|
|
|
|
FAR void *realloc(FAR void*, size_t);
|
|
|
|
FAR void *memalign(size_t, size_t);
|
|
|
|
FAR void *zalloc(size_t);
|
|
|
|
FAR void *calloc(size_t, size_t);
|
2007-02-28 05:17:21 +08:00
|
|
|
|
2015-08-14 22:35:01 +08:00
|
|
|
/* Arithmetic */
|
2010-10-10 04:46:14 +08:00
|
|
|
|
2013-03-09 04:36:18 +08:00
|
|
|
int abs(int j);
|
2015-08-15 02:04:57 +08:00
|
|
|
long int labs(long int j);
|
|
|
|
#ifdef CONFIG_HAVE_LONG_LONG
|
|
|
|
long long int llabs(long long int j);
|
|
|
|
#endif
|
|
|
|
|
2015-08-14 22:35:01 +08:00
|
|
|
#ifdef CONFIG_CAN_PASS_STRUCTS
|
|
|
|
div_t div(int numer, int denom);
|
2015-08-14 22:45:59 +08:00
|
|
|
ldiv_t ldiv(long numer, long denom);
|
|
|
|
#ifdef CONFIG_HAVE_LONG_LONG
|
|
|
|
lldiv_t lldiv(long long numer, long long denom);
|
|
|
|
#endif
|
2015-08-14 22:35:01 +08:00
|
|
|
#endif
|
|
|
|
|
|
|
|
/* Temporary files */
|
|
|
|
|
2014-11-06 21:00:23 +08:00
|
|
|
int mktemp(FAR char *path_template);
|
|
|
|
int mkstemp(FAR char *path_template);
|
2010-10-10 04:46:14 +08:00
|
|
|
|
2009-06-21 02:22:47 +08:00
|
|
|
/* Sorting */
|
|
|
|
|
2015-06-12 23:57:12 +08:00
|
|
|
void qsort(FAR void *base, size_t nmemb, size_t size,
|
|
|
|
int (*compar)(FAR const void *, FAR const void *));
|
2009-06-21 02:22:47 +08:00
|
|
|
|
2007-02-28 05:17:21 +08:00
|
|
|
#ifdef CONFIG_CAN_PASS_STRUCTS
|
2013-03-09 04:36:18 +08:00
|
|
|
struct mallinfo mallinfo(void);
|
2007-02-28 05:17:21 +08:00
|
|
|
#else
|
2013-03-09 04:36:18 +08:00
|
|
|
int mallinfo(struct mallinfo *info);
|
2007-02-28 05:17:21 +08:00
|
|
|
#endif
|
2007-02-18 07:21:28 +08:00
|
|
|
|
|
|
|
#undef EXTERN
|
|
|
|
#if defined(__cplusplus)
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2008-11-17 00:36:30 +08:00
|
|
|
#endif /* __INCLUDE_STDLIB_H */
|