summaryrefslogtreecommitdiffstats
path: root/sys/arch/sparc/include/stdarg.h
diff options
context:
space:
mode:
authorderaadt <deraadt@openbsd.org>1995-10-18 08:37:01 +0000
committerderaadt <deraadt@openbsd.org>1995-10-18 08:37:01 +0000
commitdf930be708d50e9715f173caa26ffe1b7599b157 (patch)
treeaa317e49e28cb999c9cf3db7f00c20903fe6010a /sys/arch/sparc/include/stdarg.h
downloadwireguard-openbsd-df930be708d50e9715f173caa26ffe1b7599b157.tar.xz
wireguard-openbsd-df930be708d50e9715f173caa26ffe1b7599b157.zip
initial import of NetBSD tree
Diffstat (limited to 'sys/arch/sparc/include/stdarg.h')
-rw-r--r--sys/arch/sparc/include/stdarg.h118
1 files changed, 118 insertions, 0 deletions
diff --git a/sys/arch/sparc/include/stdarg.h b/sys/arch/sparc/include/stdarg.h
new file mode 100644
index 00000000000..a1069e6a385
--- /dev/null
+++ b/sys/arch/sparc/include/stdarg.h
@@ -0,0 +1,118 @@
+/* $NetBSD: stdarg.h,v 1.6 1995/01/28 01:52:21 jtc Exp $ */
+
+/*
+ * Copyright (c) 1992, 1993
+ * The Regents of the University of California. All rights reserved.
+ *
+ * This software was developed by the Computer Systems Engineering group
+ * at Lawrence Berkeley Laboratory under DARPA contract BG 91-66 and
+ * contributed to Berkeley.
+ *
+ * All advertising materials mentioning features or use of this software
+ * must display the following acknowledgement:
+ * This product includes software developed by the University of
+ * California, Lawrence Berkeley Laboratory.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions
+ * are met:
+ * 1. Redistributions of source code must retain the above copyright
+ * notice, this list of conditions and the following disclaimer.
+ * 2. Redistributions in binary form must reproduce the above copyright
+ * notice, this list of conditions and the following disclaimer in the
+ * documentation and/or other materials provided with the distribution.
+ * 3. All advertising materials mentioning features or use of this software
+ * must display the following acknowledgement:
+ * This product includes software developed by the University of
+ * California, Berkeley and its contributors.
+ * 4. Neither the name of the University nor the names of its contributors
+ * may be used to endorse or promote products derived from this software
+ * without specific prior written permission.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
+ * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
+ * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
+ * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
+ * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
+ * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
+ * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
+ * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
+ * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
+ * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
+ * SUCH DAMAGE.
+ *
+ * from: @(#)stdarg.h 8.2 (Berkeley) 9/27/93
+ */
+
+/*
+ * SPARC stdarg.h
+ */
+
+#ifndef _SPARC_STDARG_H_
+#define _SPARC_STDARG_H_
+
+#include <machine/ansi.h>
+
+typedef _BSD_VA_LIST_ va_list;
+
+/*
+ * va_start sets ap to point to the first variable argument.
+ * The `last fixed argument' parameter l is ignored (and should
+ * never have been included in the ANSI standard!).
+ *
+ * va_end cleans up after va_start. There is nothing to do there.
+ */
+#ifdef __GCC_NEW_VARARGS__ /* gcc 2.4.5 */
+#define va_start(ap, l) ((ap) = (va_list)__builtin_saveregs())
+#else /* gcc 2.3.3 */
+#define va_start(ap, l) (__builtin_saveregs(), \
+ (ap) = (va_list)__builtin_next_arg())
+#endif
+#define va_end(ap) ((void) 0)
+
+#if __GNUC__ == 1
+#define __extension__ /* hack for bootstrapping via gcc 1.x */
+#endif
+
+/*
+ * va_arg picks up the next argument of type `ty'. Appending an
+ * asterisk to ty must produce a pointer to ty (i.e., ty may not be,
+ * e.g., `int (*)()'). In addition, ty must not be any type which
+ * undergoes promotion to some other type (e.g., char): it must
+ * be the promoted type instead.
+ *
+ * Gcc-2.x tries to use ldd/std for double and quad_t values, but Sun's
+ * brain-damaged calling convention does not quad-align these. Thus,
+ * for 8-byte arguments, we have to pick up the actual value four bytes
+ * at a time, and use type punning (i.e., a union) to produce the result.
+ * (We could also do this with a libc function, actually, by returning
+ * 8 byte integers in %o0+%o1 and the same 8 bytes as a double in %f0+%f1.)
+ *
+ * Note: we cannot use the union trick (which generates better code) for
+ * C++, since `ty' might be a type with a constructor (these may not appear
+ * in a union).
+ *
+ * The extraneous casts through `void *' avoid gcc alignment warnings.
+ */
+#ifdef __cplusplus
+#define __va_8byte(ap, ty) ({ \
+ int __va_i[2]; \
+ __va_i[0] = ((int *)(void *)(ap))[0]; \
+ __va_i[1] = ((int *)(void *)(ap))[1]; \
+ (ap) += 8; *(ty *)(void *)__va_i; })
+#else
+#define __va_8byte(ap, ty) ({ \
+ union { ty __d; int __i[2]; } __va_u; \
+ __va_u.__i[0] = ((int *)(void *)(ap))[0]; \
+ __va_u.__i[1] = ((int *)(void *)(ap))[1]; \
+ (ap) += 8; __va_u.__d; })
+#endif /* __cplusplus */
+
+#define va_arg(ap, ty) __extension__ ({ \
+ ty __va_temp; /* to check for invisible-ptr struct-valued args */ \
+ __builtin_classify_type(__va_temp) >= 12 ? \
+ ((ty **)(void *)((ap) += sizeof(ty *)))[-1][0] : \
+ sizeof(ty) == 8 ? __va_8byte(ap, ty) : \
+ ((ty *)(void *)(ap += sizeof(ty)))[-1]; })
+
+#endif /* !_SPARC_STDARG_H_ */