aboutsummaryrefslogtreecommitdiff
path: root/gcc/ginclude
diff options
context:
space:
mode:
authorRichard Kenner <kenner@gcc.gnu.org>1996-12-12 08:29:02 -0500
committerRichard Kenner <kenner@gcc.gnu.org>1996-12-12 08:29:02 -0500
commit8cc0156dce140b6c729ad293273433cfa531950f (patch)
tree5a8f236fb7c56f12d2ed75fda7f7d43ce212c208 /gcc/ginclude
parent74ba6761da8bd5a95b8e01bde002656fa8e5b64c (diff)
downloadgcc-8cc0156dce140b6c729ad293273433cfa531950f.zip
gcc-8cc0156dce140b6c729ad293273433cfa531950f.tar.gz
gcc-8cc0156dce140b6c729ad293273433cfa531950f.tar.bz2
Add definitions for VMS; they differ from Unix.
From-SVN: r13295
Diffstat (limited to 'gcc/ginclude')
-rw-r--r--gcc/ginclude/va-alpha.h28
1 files changed, 28 insertions, 0 deletions
diff --git a/gcc/ginclude/va-alpha.h b/gcc/ginclude/va-alpha.h
index 33f6c2d..16f0acf 100644
--- a/gcc/ginclude/va-alpha.h
+++ b/gcc/ginclude/va-alpha.h
@@ -10,10 +10,19 @@
#ifndef __GNUC_VA_LIST
#define __GNUC_VA_LIST
+
+/* In VMS, __gnuc_va_list is simply char *; on OSF, it's a structure. */
+
+#ifdef VMS
+typedef char *__gnuc_va_list;
+#else
+
typedef struct {
char *__base; /* Pointer to first integer register. */
int __offset; /* Byte offset of args so far. */
} __gnuc_va_list;
+#endif
+
#endif /* not __GNUC_VA_LIST */
/* If this is for internal libc use, don't define anything but
@@ -29,7 +38,11 @@ typedef struct {
/* varargs support */
#define va_alist __builtin_va_alist
#define va_dcl int __builtin_va_alist;...
+#ifdef VMS
+#define va_start(pvar) ((pvar) = __builtin_saveregs ())
+#else
#define va_start(pvar) ((pvar) = * (__gnuc_va_list *) __builtin_saveregs ())
+#endif
#else /* STDARG.H */
@@ -37,9 +50,16 @@ typedef struct {
/* Call __builtin_next_arg even though we aren't using its value, so that
we can verify that firstarg is correct. */
+
+#ifdef VMS
+#define va_start(pvar, firstarg) \
+ (__builtin_next_arg (firstarg), \
+ (pvar) = __builtin_saveregs ())
+#else
#define va_start(pvar, firstarg) \
(__builtin_next_arg (firstarg), \
(pvar) = *(__gnuc_va_list *) __builtin_saveregs ())
+#endif
#endif /* _STDARG_H */
@@ -89,12 +109,20 @@ enum {
(((sizeof (__type) + __extension__ sizeof (long long) - 1) \
/ __extension__ sizeof (long long)) * __extension__ sizeof (long long))
+#ifdef VMS
+#define va_arg(__va, __type) \
+(*(((__va) += __va_tsize (__type)), \
+ (__type *)(void *)((__va) - __va_tsize (__type))))
+
+#else
+
#define va_arg(__va, __type) \
(*(((__va).__offset += __va_tsize (__type)), \
(__type *)(void *)((__va).__base + (__va).__offset \
- (((__builtin_classify_type (* (__type *) 0) \
== __real_type_class) && (__va).__offset <= (6 * 8)) \
? (6 * 8) + 8 : __va_tsize (__type)))))
+#endif
#endif /* defined (_STDARG_H) || defined (_VARARGS_H) */