X-Git-Url: https://git.gag.com/?a=blobdiff_plain;f=device%2Finclude%2Fstdarg.h;h=7f77256c337d08408ab33c795d204c13387760d5;hb=0694926e60ec83b31f87590e601f7e0d8f86c512;hp=4802a8fdd43c3efb292830e2d7672489a7696dfb;hpb=17ac14c727bd7466b5ac78709231fafbb7f18e59;p=fw%2Fsdcc diff --git a/device/include/stdarg.h b/device/include/stdarg.h index 4802a8fd..7f77256c 100644 --- a/device/include/stdarg.h +++ b/device/include/stdarg.h @@ -5,25 +5,29 @@ #ifndef __SDC51_STDARG_H #define __SDC51_STDARG_H 1 -#if defined(SDCC_STACK_TENBIT) +#if defined(__z80) || defined(__gbz80) || defined(__hc08) -#error Foo! +typedef unsigned char * va_list; +#define va_start(list, last) list = (unsigned char *)&last + sizeof(last) +#define va_arg(list, type) *((type *)((list += sizeof(type)) - sizeof(type))) -typedef unsigned char _xdata * va_list ; -#define va_arg(marker,type) *((type _xdata * )(marker -= sizeof(type))) -#define va_start(marker,first) { marker = (va_list) ((char _xdata * )&first) ; } +#elif defined(__ds390) || defined(__ds400) + +typedef unsigned char * va_list ; +#define va_arg(marker,type) *((type *)(marker -= sizeof(type))) +#define va_start(marker,first) { marker = &first; } #elif defined(SDCC_USE_XSTACK) -typedef unsigned char _pdata * va_list ; -#define va_arg(marker,type) *((type _data * )(marker -= sizeof(type))) -#define va_start(marker,first) { marker = (va_list) ((char _pdata * )&first) ; } +typedef unsigned char pdata * va_list ; +#define va_arg(marker,type) *((type data *)(marker -= sizeof(type))) +#define va_start(marker,first) { marker = (va_list)((char pdata *)&first); } #else -typedef unsigned char _data * va_list ; -#define va_arg(marker,type) *((type _data * )(marker -= sizeof(type))) -#define va_start(marker,first) { marker = (va_list) ((char _data * )&first) ; } +typedef unsigned char data * va_list ; +#define va_arg(marker,type) *((type data * )(marker -= sizeof(type))) +#define va_start(marker,first) { marker = (va_list) ((char data * )&first); } #endif