From 8ad117ff197ba8fdd9e12fc01c830d7abdfd434d Mon Sep 17 00:00:00 2001 From: Michael Meissner Date: Thu, 12 Sep 1991 22:22:50 +0000 Subject: [PATCH] Initial revision From-SVN: r39 --- gcc/ginclude/va-mips.h | 42 ++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 42 insertions(+) create mode 100644 gcc/ginclude/va-mips.h diff --git a/gcc/ginclude/va-mips.h b/gcc/ginclude/va-mips.h new file mode 100644 index 0000000..24fa9ba --- /dev/null +++ b/gcc/ginclude/va-mips.h @@ -0,0 +1,42 @@ +/* ---------------------------------------- */ +/* VARARGS for MIPS/GNU CC */ +/* */ +/* */ +/* */ +/* */ +/* ---------------------------------------- */ + + +/* These macros implement traditional (non-ANSI) varargs + for GNU C. */ + +/* In GCC version 2, we want an ellipsis at the end of the declaration + of the argument list. GCC version 1 can't parse it. */ + +#if __GNUC__ > 1 +#define __va_ellipsis ... +#else +#define __va_ellipsis +#endif + +#define va_alist __builtin_va_alist +#define va_dcl int __builtin_va_alist; __va_ellipsis +#ifndef _VA_LIST_ +#define _VA_LIST_ +/* Make this a macro rather than a typedef, so we can undef any other defn. */ +#define va_list __va___list +typedef char * __va___list; +#endif + +#define va_start(AP) AP = (char *) &__builtin_va_alist +#define va_end(AP) + +#ifdef lint /* complains about constant in conditional context */ +#define va_arg(list, mode) ((mode *)(list += sizeof(mode)))[-1] + +#else /* !lint */ +#define va_arg(AP, mode) ((mode *)(AP = \ + (char *) (sizeof(mode) > 4 ? ((int)AP + 2*8 - 1) & -8 \ + : ((int)AP + 2*4 - 1) & -4)))[-1] +#endif /* lint */ + -- 2.7.4