diff options
author | Joerg Wunsch <joerg@FreeBSD.org> | 2005-03-02 21:33:29 +0000 |
---|---|---|
committer | Joerg Wunsch <joerg@FreeBSD.org> | 2005-03-02 21:33:29 +0000 |
commit | a5f50ef9e43b28e15a7e2a2aec73754456619f17 (patch) | |
tree | 69c98a86a28838e983d8eca9ba158f46450df8c1 /sys/sparc64/include/_types.h | |
parent | f685f62c9869f2c8181041ae3e3d87a09d2d3fbf (diff) | |
download | src-a5f50ef9e43b28e15a7e2a2aec73754456619f17.tar.gz src-a5f50ef9e43b28e15a7e2a2aec73754456619f17.zip |
netchild's mega-patch to isolate compiler dependencies into a central
place.
This moves the dependency on GCC's and other compiler's features into
the central sys/cdefs.h file, while the individual source files can
then refer to #ifdef __COMPILER_FEATURE_FOO where they by now used to
refer to #if __GNUC__ > 3.1415 && __BARC__ <= 42.
By now, GCC and ICC (the Intel compiler) have been actively tested on
IA32 platforms by netchild. Extension to other compilers is supposed
to be possible, of course.
Submitted by: netchild
Reviewed by: various developers on arch@, some time ago
Notes
Notes:
svn path=/head/; revision=143063
Diffstat (limited to 'sys/sparc64/include/_types.h')
-rw-r--r-- | sys/sparc64/include/_types.h | 11 |
1 files changed, 8 insertions, 3 deletions
diff --git a/sys/sparc64/include/_types.h b/sys/sparc64/include/_types.h index f014b54eb1f7..f810c159a6ef 100644 --- a/sys/sparc64/include/_types.h +++ b/sys/sparc64/include/_types.h @@ -35,6 +35,10 @@ #ifndef _MACHINE__TYPES_H_ #define _MACHINE__TYPES_H_ +#ifndef _SYS_CDEFS_H_ +#error this file needs sys/cdefs.h as a prerequisite +#endif + /* * Basic types upon which most other types are built. */ @@ -93,12 +97,13 @@ typedef __uint64_t __vm_size_t; /* * Unusual type definitions. */ -#if defined(__GNUC__) && (__GNUC__ == 2 && __GNUC_MINOR__ > 95 || __GNUC__ >= 3) +#ifdef __GNUCLIKE_BUILTIN_VARARGS typedef __builtin_va_list __va_list; /* internally known to gcc */ #else typedef char * __va_list; -#endif /* post GCC 2.95 */ -#if defined __GNUC__ && !defined(__GNUC_VA_LIST) && !defined(__NO_GNUC_VA_LIST) +#endif /* __GNUCLIKE_BUILTIN_VARARGS */ +#if defined(__GNUCLIKE_BUILTIN_VAALIST) && !defined(__GNUC_VA_LIST) \ + && !defined(__NO_GNUC_VA_LIST) #define __GNUC_VA_LIST typedef __va_list __gnuc_va_list; /* compatibility w/GNU headers*/ #endif |