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