diff options
| author | 1995-10-18 08:37:01 +0000 | |
|---|---|---|
| committer | 1995-10-18 08:37:01 +0000 | |
| commit | df930be708d50e9715f173caa26ffe1b7599b157 (patch) | |
| tree | aa317e49e28cb999c9cf3db7f00c20903fe6010a /sys/arch/sparc/include/stdarg.h | |
| download | wireguard-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.h | 118 |
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_ */ |
