Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/netbsd-1-5]: src/sys/arch/sparc64/include Approved by thorpej:
details: https://anonhg.NetBSD.org/src/rev/561af827d764
branches: netbsd-1-5
changeset: 488751:561af827d764
user: mycroft <mycroft%NetBSD.org@localhost>
date: Wed Jul 26 23:29:42 2000 +0000
description:
Approved by thorpej:
Fix multiple problems with floating point and structure handling.
syssrc/sys/arch/sparc64/include/stdarg.h 1.10 -> 1.11
diffstat:
sys/arch/sparc64/include/stdarg.h | 24 ++++++++++++------------
1 files changed, 12 insertions(+), 12 deletions(-)
diffs (46 lines):
diff -r 5bfa3a0c0806 -r 561af827d764 sys/arch/sparc64/include/stdarg.h
--- a/sys/arch/sparc64/include/stdarg.h Wed Jul 26 23:28:09 2000 +0000
+++ b/sys/arch/sparc64/include/stdarg.h Wed Jul 26 23:29:42 2000 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: stdarg.h,v 1.9.4.1 2000/07/18 16:23:24 mrg Exp $ */
+/* $NetBSD: stdarg.h,v 1.9.4.2 2000/07/26 23:29:42 mycroft Exp $ */
/*
* Copyright (c) 1992, 1993
@@ -74,25 +74,25 @@
/*
* For sparcv9 code.
*/
-#define __va_arg(ap, type) \
- (*(type *)(void *)((ap) += 8, (ap) - (sizeof (type))))
-
-/* Like __va_arg(), except when the type must be 16-byte aligned. */
+#define __va_arg8(ap, type) \
+ (*(type *)(void *)((ap) += 8, (ap) - 8))
#define __va_arg16(ap, type) \
- (*(type *)((__alignof__(type) == 16 ? \
- (ap) = (va_list)(((unsigned long)(ap) + 31) & -16) :\
- ((ap) += 16)), (ap) - (sizeof (type))))
+ (*(type *)(void *)((ap) = (va_list)(((unsigned long)(ap) + 31) & -16),\
+ (ap) - 16))
+#define __va_int(ap, type) \
+ (*(type *)(void *)((ap) += 8, (ap) - sizeof(type)))
#define __REAL_TYPE_CLASS 8
#define __RECORD_TYPE_CLASS 12
#define va_arg(ap, type) \
(__builtin_classify_type(*(type *)0) == __REAL_TYPE_CLASS ? \
- __va_arg16(ap, type) : \
+ (__alignof__(type) == 16 ? __va_arg16(ap, type) : \
+ __va_arg8(ap, type)) : \
(__builtin_classify_type(*(type *)0) < __RECORD_TYPE_CLASS ? \
- __va_arg(ap, type) : \
- (sizeof(type) <= 8 ? __va_arg(ap, type) : \
+ __va_int(ap, type) : \
+ (sizeof(type) <= 8 ? __va_arg8(ap, type) : \
(sizeof(type) <= 16 ? __va_arg16(ap, type) : \
- *__va_arg(ap, type *)))))
+ *__va_arg8(ap, type *)))))
#else
/*
* For sparcv8 code.
Home |
Main Index |
Thread Index |
Old Index