X-Git-Url: https://pd.if.org/git/?p=pdclib;a=blobdiff_plain;f=platform%2Fexample%2Finternals%2F_PDCLIB_config.h;h=150161f18373a92e262765a1774bd8d68c1aa96e;hp=41fe02cb3f62711e2ee40b482ef3adc66f3137f7;hb=d02f38605b53cdff5460cc6b9e1b2a80c3a2ba4c;hpb=3f6094115e79a45413f08361b68b71eb08da306e diff --git a/platform/example/internals/_PDCLIB_config.h b/platform/example/internals/_PDCLIB_config.h index 41fe02c..150161f 100644 --- a/platform/example/internals/_PDCLIB_config.h +++ b/platform/example/internals/_PDCLIB_config.h @@ -28,6 +28,12 @@ /* specific platforms, e.g. by swapping int instead of char. */ #define _PDCLIB_memswp( i, j, size ) char tmp; do { tmp = *i; *i++ = *j; *j++ = tmp; } while ( --size ); +/* Define this to some compiler directive that can be written after the */ +/* parameter list of a function declaration to indicate the function does */ +/* never return. If your compiler does not support such a directive, define */ +/* to nothing. (This is to avoid warnings with the exit functions under GCC.) */ +#define _PDCLIB_NORETURN __attribute__(( noreturn )) + /* -------------------------------------------------------------------------- */ /* Integers */ /* -------------------------------------------------------------------------- */ @@ -201,15 +207,12 @@ typedef char * _PDCLIB_va_list; #define _PDCLIB_va_start( ap, parmN ) ( (ap) = (char *) &parmN + ( _PDCLIB_va_round(parmN) ), (void)0 ) /* -------------------------------------------------------------------------- */ -/* OS "glue" */ -/* This is where PDCLib interfaces with the operating system. The examples */ -/* below are POSIX calls; provide your OS' equivalents. */ +/* OS "glue", part 1 */ +/* These are values and data type definitions that you would have to adapt to */ +/* the capabilities and requirements of your OS. */ +/* The actual *functions* of the OS interface are declared in _PDCLIB_glue.h. */ /* -------------------------------------------------------------------------- */ -/* A system call that terminates the calling process */ -void _exit( int status ) __attribute__(( noreturn )); -#define _PDCLIB_Exit( x ) _exit( x ) - /* Memory management */ /* Set this to the page size of your OS. If your OS does not support paging, set @@ -223,9 +226,24 @@ void _exit( int status ) __attribute__(( noreturn )); */ #define _PDCLIB_MINALLOC 8 -/* Request another x pages (of size _PDCLIB_PAGESIZE) of memory from the kernel, - or release them back to the kernel if n is negative. - Return a (void *) pointing to the former end-of-heap if successful, NULL - otherwise. -*/ -void * _PDCLIB_allocpages( int n ); +/* I/O */ + +/* The unique file descriptor returned by _PDCLIB_open(). */ +typedef int _PDCLIB_fd_t; + +/* A type in which to store file offsets. See fgetpos() / fsetpos(). */ +typedef struct +{ + int position; + int parse_state; +} _PDCLIB_fpos_t; + +/* The mode flags used in calls to _PDCLIB_open(). */ +enum _PDCLIB_iomode_e +{ + _PDCLIB_io_read = 1, + _PDCLIB_io_write = 2, + _PDCLIB_io_append = 4, + _PDCLIB_io_create = 8, + _PDCLIB_io_truncate = 16, +};