2000-07-22 19:03:03 +00:00
|
|
|
|
/*****************************************************************************/
|
|
|
|
|
/* */
|
|
|
|
|
/* stdlib.h */
|
|
|
|
|
/* */
|
|
|
|
|
/* General utilities */
|
|
|
|
|
/* */
|
|
|
|
|
/* */
|
|
|
|
|
/* */
|
2005-01-05 21:07:23 +00:00
|
|
|
|
/* (C) 1998-2005 Ullrich von Bassewitz */
|
2003-08-16 08:23:01 +00:00
|
|
|
|
/* R<>merstrasse 52 */
|
|
|
|
|
/* D-70794 Filderstadt */
|
|
|
|
|
/* EMail: uz@cc65.org */
|
2000-07-22 19:03:03 +00:00
|
|
|
|
/* */
|
|
|
|
|
/* */
|
|
|
|
|
/* This software is provided 'as-is', without any expressed or implied */
|
|
|
|
|
/* warranty. In no event will the authors be held liable for any damages */
|
|
|
|
|
/* arising from the use of this software. */
|
|
|
|
|
/* */
|
|
|
|
|
/* Permission is granted to anyone to use this software for any purpose, */
|
|
|
|
|
/* including commercial applications, and to alter it and redistribute it */
|
|
|
|
|
/* freely, subject to the following restrictions: */
|
|
|
|
|
/* */
|
|
|
|
|
/* 1. The origin of this software must not be misrepresented; you must not */
|
|
|
|
|
/* claim that you wrote the original software. If you use this software */
|
|
|
|
|
/* in a product, an acknowledgment in the product documentation would be */
|
|
|
|
|
/* appreciated but is not required. */
|
|
|
|
|
/* 2. Altered source versions must be plainly marked as such, and must not */
|
|
|
|
|
/* be misrepresented as being the original software. */
|
|
|
|
|
/* 3. This notice may not be removed or altered from any source */
|
|
|
|
|
/* distribution. */
|
|
|
|
|
/* */
|
|
|
|
|
/*****************************************************************************/
|
2000-05-28 13:40:48 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
#ifndef _STDLIB_H
|
|
|
|
|
#define _STDLIB_H
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2003-08-16 08:23:01 +00:00
|
|
|
|
/* size_t is needed */
|
|
|
|
|
#ifndef _HAVE_size_t
|
|
|
|
|
typedef unsigned size_t;
|
|
|
|
|
#define _HAVE_size_t
|
|
|
|
|
#endif
|
2000-05-28 13:40:48 +00:00
|
|
|
|
|
|
|
|
|
/* Standard exit codes */
|
|
|
|
|
#define EXIT_SUCCESS 0
|
|
|
|
|
#define EXIT_FAILURE 1
|
|
|
|
|
|
2002-10-25 20:46:57 +00:00
|
|
|
|
/* Return type of the div function */
|
|
|
|
|
typedef struct {
|
|
|
|
|
int rem;
|
|
|
|
|
int quot;
|
|
|
|
|
} div_t;
|
2000-05-28 13:40:48 +00:00
|
|
|
|
|
|
|
|
|
/* Memory management */
|
2000-07-21 16:57:58 +00:00
|
|
|
|
void* __fastcall__ malloc (size_t size);
|
2001-11-15 21:53:31 +00:00
|
|
|
|
void* __fastcall__ calloc (size_t count, size_t size);
|
2002-11-05 20:23:06 +00:00
|
|
|
|
void* __fastcall__ realloc (void* block, size_t size);
|
2000-07-16 22:10:47 +00:00
|
|
|
|
void __fastcall__ free (void* block);
|
2003-02-01 12:22:09 +00:00
|
|
|
|
|
|
|
|
|
/* Non standard memory management functions */
|
|
|
|
|
|
2005-01-05 21:28:54 +00:00
|
|
|
|
void* __fastcall__ _aligned_malloc (size_t size, size_t alignment);
|
2005-01-05 21:07:23 +00:00
|
|
|
|
/* Allocate a block of memory with the given size, which is aligned to a
|
|
|
|
|
* memory address that is a multiple of alignment. alignment MUST NOT be
|
|
|
|
|
* zero and MUST be a power of two, otherwise a call to this function will
|
|
|
|
|
* cause undefined behaviour. The function returns NULL if not enough memory
|
|
|
|
|
* is available to satisfy the request. To free the allocated block, use the
|
|
|
|
|
* free() function.
|
|
|
|
|
*/
|
|
|
|
|
|
2003-02-01 12:22:09 +00:00
|
|
|
|
void __fastcall__ _heapadd (void* mem, size_t size);
|
|
|
|
|
/* Add a block to the heap */
|
|
|
|
|
|
2004-07-17 12:05:36 +00:00
|
|
|
|
size_t __fastcall__ _heapblocksize (const void* block);
|
|
|
|
|
/* Return the size of an allocated block */
|
|
|
|
|
|
2003-02-01 12:22:09 +00:00
|
|
|
|
size_t __fastcall__ _heapmemavail (void);
|
|
|
|
|
/* Return the total free heap space */
|
|
|
|
|
|
|
|
|
|
size_t __fastcall__ _heapmaxavail (void);
|
|
|
|
|
/* Return the size of the largest free block on the heap */
|
2000-05-28 13:40:48 +00:00
|
|
|
|
|
2004-07-17 12:05:36 +00:00
|
|
|
|
|
2000-05-28 13:40:48 +00:00
|
|
|
|
/* Random numbers */
|
2002-11-05 20:23:06 +00:00
|
|
|
|
#define RAND_MAX 0x7FFF
|
2000-05-28 13:40:48 +00:00
|
|
|
|
int rand (void);
|
|
|
|
|
void __fastcall__ srand (unsigned seed);
|
2002-11-05 20:23:06 +00:00
|
|
|
|
void _randomize (void); /* Non-standard */
|
2000-05-28 13:40:48 +00:00
|
|
|
|
|
|
|
|
|
/* Other standard stuff */
|
|
|
|
|
void abort (void);
|
|
|
|
|
int __fastcall__ abs (int val);
|
|
|
|
|
long __fastcall__ labs (long val);
|
2002-03-06 06:58:24 +00:00
|
|
|
|
int __fastcall__ atoi (const char* s);
|
|
|
|
|
long __fastcall__ atol (const char* s);
|
2000-05-28 13:40:48 +00:00
|
|
|
|
int __fastcall__ atexit (void (*exitfunc) (void));
|
2003-10-29 21:51:59 +00:00
|
|
|
|
void* __fastcall__ bsearch (const void* key, const void* base, size_t n,
|
|
|
|
|
size_t size, int (*cmp) (const void*, const void*));
|
2002-10-25 20:46:57 +00:00
|
|
|
|
div_t __fastcall__ div (int numer, int denom);
|
2003-02-01 10:20:35 +00:00
|
|
|
|
void __fastcall__ exit (int ret);
|
2000-05-28 13:40:48 +00:00
|
|
|
|
char* __fastcall__ getenv (const char* name);
|
2003-10-29 21:59:19 +00:00
|
|
|
|
void __fastcall__ qsort (void* base, size_t count, size_t size,
|
|
|
|
|
int (*compare) (const void*, const void*));
|
2003-05-27 18:24:16 +00:00
|
|
|
|
int system (const char* s);
|
2000-05-28 13:40:48 +00:00
|
|
|
|
|
|
|
|
|
/* Non-ANSI functions */
|
|
|
|
|
void __fastcall__ _swap (void* p, void* q, size_t size);
|
2004-06-21 22:22:11 +00:00
|
|
|
|
#if __CC65_STD__ == __CC65_STD_CC65__
|
2000-05-28 13:40:48 +00:00
|
|
|
|
char* __fastcall__ itoa (int val, char* buf, int radix);
|
|
|
|
|
char* __fastcall__ utoa (unsigned val, char* buf, int radix);
|
|
|
|
|
char* __fastcall__ ltoa (long val, char* buf, int radix);
|
|
|
|
|
char* __fastcall__ ultoa (unsigned long val, char* buf, int radix);
|
2005-04-21 21:27:17 +00:00
|
|
|
|
int __fastcall__ putenv (char* s);
|
2000-05-28 13:40:48 +00:00
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/* End of stdlib.h */
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|