summaryrefslogtreecommitdiff
path: root/gcc/ginclude
diff options
context:
space:
mode:
authorlaw <law@138bc75d-0d04-0410-961f-82ee72b054a4>1998-09-19 00:03:07 +0000
committerlaw <law@138bc75d-0d04-0410-961f-82ee72b054a4>1998-09-19 00:03:07 +0000
commit7e0259d368b37877fee955eadb239409124a2626 (patch)
treeb0ebf2a8a557674219c6a8fe1c16245efbd77ea3 /gcc/ginclude
parent9f32ccea62d245c8efe8825e95b7e0fa4a83bc38 (diff)
downloadgcc-7e0259d368b37877fee955eadb239409124a2626.tar.gz
* README.C4X: New file with information about the c4x ports.
* ginclude/va-c4x.h: New file for c4x varargs support. * config/c4x: New directory with c4x port files. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@22475 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'gcc/ginclude')
-rw-r--r--gcc/ginclude/va-c4x.h34
1 files changed, 34 insertions, 0 deletions
diff --git a/gcc/ginclude/va-c4x.h b/gcc/ginclude/va-c4x.h
new file mode 100644
index 00000000000..c73c6d592bd
--- /dev/null
+++ b/gcc/ginclude/va-c4x.h
@@ -0,0 +1,34 @@
+/* GNU C varargs support for the TMS320C[34]x */
+
+/* C[34]x arguments grow in weird ways (downwards) that the standard
+ varargs stuff can't handle. */
+
+#ifndef __GNUC_VA_LIST
+#define __GNUC_VA_LIST
+
+typedef void *__gnuc_va_list;
+
+#endif /* not __GNUC_VA_LIST */
+
+/* If this is for internal libc use, don't define anything but
+ __gnuc_va_list. */
+#if defined (_STDARG_H) || defined (_VARARGS_H)
+
+#ifdef _STDARG_H /* stdarg.h support */
+
+#define va_start(AP,LASTARG) AP=(__gnuc_va_list) __builtin_next_arg (LASTARG)
+
+#else /* varargs.h support */
+
+#define __va_ellipsis ...
+#define va_alist __builtin_va_alist
+#define va_dcl int __builtin_va_alist; __va_ellipsis
+#define va_start(AP) AP=(__gnuc_va_list) ((int *)&__builtin_va_alist + 1)
+
+#endif /* _STDARG_H */
+
+#define va_end(AP) ((void) 0)
+#define va_arg(AP,TYPE) (AP = (__gnuc_va_list) ((char *) (AP) - sizeof(TYPE)), \
+ *((TYPE *) ((char *) (AP))))
+
+#endif /* defined (_STDARG_H) || defined (_VARARGS_H) */