Fix last change.
[linux-flexiantxendom0-3.2.10.git] / arch / ppc64 / kdb / ansidecl.h
1 /* ANSI and traditional C compatability macros
2    Copyright 1991, 1992, 1996, 1999 Free Software Foundation, Inc.
3    This file is part of the GNU C Library.
4
5 This program is free software; you can redistribute it and/or modify
6 it under the terms of the GNU General Public License as published by
7 the Free Software Foundation; either version 2 of the License, or
8 (at your option) any later version.
9
10 This program is distributed in the hope that it will be useful,
11 but WITHOUT ANY WARRANTY; without even the implied warranty of
12 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
13 GNU General Public License for more details.
14
15 You should have received a copy of the GNU General Public License
16 along with this program; if not, write to the Free Software
17 Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.  */
18
19 /* ANSI and traditional C compatibility macros
20
21    ANSI C is assumed if __STDC__ is #defined.
22
23    Macro        ANSI C definition       Traditional C definition
24    -----        ---- - ----------       ----------- - ----------
25    PTR          `void *'                `char *'
26    LONG_DOUBLE  `long double'           `double'
27    VOLATILE     `volatile'              `'
28    SIGNED       `signed'                `'
29    PTRCONST     `void *const'           `char *'
30    ANSI_PROTOTYPES  1                   not defined
31
32    CONST is also defined, but is obsolete.  Just use const.
33
34    obsolete --     DEFUN (name, arglist, args)
35
36         Defines function NAME.
37
38         ARGLIST lists the arguments, separated by commas and enclosed in
39         parentheses.  ARGLIST becomes the argument list in traditional C.
40
41         ARGS list the arguments with their types.  It becomes a prototype in
42         ANSI C, and the type declarations in traditional C.  Arguments should
43         be separated with `AND'.  For functions with a variable number of
44         arguments, the last thing listed should be `DOTS'.
45
46    obsolete --     DEFUN_VOID (name)
47
48         Defines a function NAME, which takes no arguments.
49
50    obsolete --     EXFUN (name, (prototype))    -- obsolete.
51
52         Replaced by PARAMS.  Do not use; will disappear someday soon.
53         Was used in external function declarations.
54         In ANSI C it is `NAME PROTOTYPE' (so PROTOTYPE should be enclosed in
55         parentheses).  In traditional C it is `NAME()'.
56         For a function that takes no arguments, PROTOTYPE should be `(void)'.
57
58    obsolete --     PROTO (type, name, (prototype)    -- obsolete.
59
60         This one has also been replaced by PARAMS.  Do not use.
61
62    PARAMS ((args))
63
64         We could use the EXFUN macro to handle prototype declarations, but
65         the name is misleading and the result is ugly.  So we just define a
66         simple macro to handle the parameter lists, as in:
67
68               static int foo PARAMS ((int, char));
69
70         This produces:  `static int foo();' or `static int foo (int, char);'
71
72         EXFUN would have done it like this:
73
74               static int EXFUN (foo, (int, char));
75
76         but the function is not external...and it's hard to visually parse
77         the function name out of the mess.   EXFUN should be considered
78         obsolete; new code should be written to use PARAMS.
79
80    DOTS is also obsolete.
81
82    Examples:
83
84         extern int printf PARAMS ((const char *format, ...));
85 */
86
87 #ifndef _ANSIDECL_H
88
89 #define _ANSIDECL_H     1
90
91
92 /* Every source file includes this file,
93    so they will all get the switch for lint.  */
94 /* LINTLIBRARY */
95
96
97 #if defined (__STDC__) || defined (_AIX) || (defined (__mips) && defined (_SYSTYPE_SVR4)) || defined(_WIN32)
98 /* All known AIX compilers implement these things (but don't always
99    define __STDC__).  The RISC/OS MIPS compiler defines these things
100    in SVR4 mode, but does not define __STDC__.  */
101
102 #define PTR             void *
103 #define PTRCONST        void *CONST
104 #define LONG_DOUBLE     long double
105
106 #ifndef IN_GCC
107 #define AND             ,
108 #define NOARGS          void
109 #define VOLATILE        volatile
110 #define SIGNED          signed
111 #endif /* ! IN_GCC */
112
113 #ifndef PARAMS
114 #define PARAMS(paramlist)               paramlist
115 #endif
116 #define ANSI_PROTOTYPES                 1
117
118 #define VPARAMS(ARGS)                   ARGS
119 #define VA_START(va_list,var)           va_start(va_list,var)
120
121 /* These are obsolete.  Do not use.  */
122 #ifndef IN_GCC
123 #define CONST                           const
124 #define DOTS                            , ...
125 #define PROTO(type, name, arglist)      type name arglist
126 #define EXFUN(name, proto)              name proto
127 #define DEFUN(name, arglist, args)      name(args)
128 #define DEFUN_VOID(name)                name(void)
129 #endif /* ! IN_GCC */
130
131 #else   /* Not ANSI C.  */
132
133 #define PTR             char *
134 #define PTRCONST        PTR
135 #define LONG_DOUBLE     double
136
137 #ifndef IN_GCC
138 #define AND             ;
139 #define NOARGS
140 #define VOLATILE
141 #define SIGNED
142 #endif /* !IN_GCC */
143
144 #ifndef const /* some systems define it in header files for non-ansi mode */
145 #define const
146 #endif
147
148 #define PARAMS(paramlist)               ()
149
150 #define VPARAMS(ARGS)                   (va_alist) va_dcl
151 #define VA_START(va_list,var)           va_start(va_list)
152
153 /* These are obsolete.  Do not use.  */
154 #ifndef IN_GCC
155 #define CONST
156 #define DOTS
157 #define PROTO(type, name, arglist)      type name ()
158 #define EXFUN(name, proto)              name()
159 #define DEFUN(name, arglist, args)      name arglist args;
160 #define DEFUN_VOID(name)                name()
161 #endif /* ! IN_GCC */
162
163 #endif  /* ANSI C.  */
164
165 /* Define macros for some gcc attributes.  This permits us to use the
166    macros freely, and know that they will come into play for the
167    version of gcc in which they are supported.  */
168
169 #if __GNUC__ < 2 || (__GNUC__ == 2 && __GNUC_MINOR__ < 7)
170 # define __attribute__(x)
171 #endif
172
173 #ifndef ATTRIBUTE_UNUSED_LABEL
174 # if __GNUC__ < 2 || (__GNUC__ == 2 && __GNUC_MINOR__ < 93)
175 #  define ATTRIBUTE_UNUSED_LABEL
176 # else
177 #  define ATTRIBUTE_UNUSED_LABEL ATTRIBUTE_UNUSED
178 # endif /* GNUC < 2.93 */
179 #endif /* ATTRIBUTE_UNUSED_LABEL */
180
181 #ifndef ATTRIBUTE_UNUSED
182 #define ATTRIBUTE_UNUSED __attribute__ ((__unused__))
183 #endif /* ATTRIBUTE_UNUSED */
184
185 #ifndef ATTRIBUTE_NORETURN
186 #define ATTRIBUTE_NORETURN __attribute__ ((__noreturn__))
187 #endif /* ATTRIBUTE_NORETURN */
188
189 #ifndef ATTRIBUTE_PRINTF
190 #define ATTRIBUTE_PRINTF(m, n) __attribute__ ((format (__printf__, m, n)))
191 #define ATTRIBUTE_PRINTF_1 ATTRIBUTE_PRINTF(1, 2)
192 #define ATTRIBUTE_PRINTF_2 ATTRIBUTE_PRINTF(2, 3)
193 #define ATTRIBUTE_PRINTF_3 ATTRIBUTE_PRINTF(3, 4)
194 #define ATTRIBUTE_PRINTF_4 ATTRIBUTE_PRINTF(4, 5)
195 #define ATTRIBUTE_PRINTF_5 ATTRIBUTE_PRINTF(5, 6)
196 #endif /* ATTRIBUTE_PRINTF */
197
198 #endif  /* ansidecl.h   */