|
|
1.1 root 1: /* Note: We must use the name __builtin_savregs. GCC attaches special
2: significance to that name. In particular, regardless of where in a
3: function __builtin_saveregs is called, GCC moves the call up to the
4: very start of the function. */
5:
6:
7: /* Define __gnuc_va_list. */
8:
9: #ifndef __GNUC_VA_LIST
10: #define __GNUC_VA_LIST
11:
12: typedef union {
13: float __freg[8];
14: double __dreg[4];
15: } __f_regs;
16:
17: typedef struct {
18: #if defined (__SVR4__) || defined (__svr4__) || defined (__alliant__) || defined (__PARAGON__)
19: __f_regs __float_regs; long __ireg[12];
20: #else /* pre-SVR4 */
21: long __ireg[12]; __f_regs __float_regs;
22: #endif
23: } __va_saved_regs;
24:
25: typedef struct {
26: #if defined(__SVR4__) || defined(__svr4__) || defined(__alliant__) || defined (__PARAGON__)
27: unsigned __ireg_used; /* How many int regs consumed 'til now? */
28: unsigned __freg_used; /* How many flt regs consumed 'til now? */
29: long *__reg_base; /* Address of where we stored the regs. */
30: long * __mem_ptr; /* Address of memory overflow args area. */
31: #else /* pre-SVR4 */
32: long *__reg_base; /* Address of where we stored the regs. */
33: long * __mem_ptr; /* Address of memory overflow args area. */
34: unsigned __ireg_used; /* How many int regs consumed 'til now? */
35: unsigned __freg_used; /* How many flt regs consumed 'til now? */
36: #endif
37: } __gnuc_va_list;
38: #endif /* not __GNUC_VA_LIST */
39:
40: /* If this is for internal libc use, don't define anything but
41: __gnuc_va_list. */
42: #if defined (_STDARG_H) || defined (_VARARGS_H)
43:
44: #if !defined(_STDARG_H)
45:
46: /* varargs support */
47: #define va_alist __builtin_va_alist
48: #if defined (__PARAGON__)
49: #define va_dcl int va_alist;
50: #else /* __PARAGON__ */
51: #define va_dcl
52: #endif /* __PARAGON__ */
53: #define va_start(pvar) ((pvar) = * (__gnuc_va_list *) __builtin_saveregs ())
54:
55: #else /* STDARG.H */
56:
57: /* ANSI alternative. */
58: /* Note that CUMULATIVE_ARGS elements are measured in bytes on the i860,
59: so we divide by 4 to get # of registers. */
60: #define va_start(pvar, firstarg) \
61: ((pvar) = *(__gnuc_va_list *) __builtin_saveregs (), \
62: (pvar).__ireg_used = __builtin_args_info (0) / 4, \
63: (pvar).__freg_used = __builtin_args_info (1) / 4, \
64: (pvar).__mem_ptr = __builtin_next_arg ())
65:
66: #endif /* _STDARG_H */
67:
68: /* Values returned by __builtin_classify_type. */
69:
70: #ifndef va_end
71: enum {
72: __no_type_class = -1,
73: __void_type_class,
74: __integer_type_class,
75: __char_type_class,
76: __enumeral_type_class,
77: __boolean_type_class,
78: __pointer_type_class,
79: __reference_type_class,
80: __offset_type_class,
81: __real_type_class,
82: __complex_type_class,
83: __function_type_class,
84: __method_type_class,
85: __record_type_class,
86: __union_type_class,
87: __array_type_class,
88: __string_type_class,
89: __set_type_class,
90: __file_type_class,
91: __lang_type_class
92: };
93:
94: void va_end (__gnuc_va_list); /* Defined in libgcc.a */
95: #endif
96: #define va_end(__va)
97:
98: #define __NUM_PARM_FREGS 8
99: #define __NUM_PARM_IREGS 12
100:
101: #define __savereg(__va) ((__va_saved_regs *) ((__va).__reg_base))
102:
103: /* This macro works both for SVR4 and pre-SVR4 environments. */
104:
105: /* Note that parameters are always aligned at least to a word boundary
106: (when passed) regardless of what GCC's __alignof__ operator says. */
107:
108: /* Make allowances here for adding 128-bit (long double) floats someday. */
109:
110: #if 0 /* What was this for? */
111: #ifndef __GNU_VA_LIST
112: #define __ireg_used ireg_used
113: #define __freg_used freg_used
114: #define __mem_ptr mem_ptr
115: #define __reg_base reg_base
116: #endif
117: #endif /* 0 */
118:
119: /* Avoid errors if compiling GCC v2 with GCC v1. */
120: #if __GNUC__ == 1
121: #define __extension__
122: #endif
123:
124: #define va_arg(__va, __type) \
125: __extension__ \
126: (* (__type *) \
127: ({ \
128: register void *__rv; /* result value */ \
129: register unsigned __align; \
130: switch (__builtin_classify_type (* (__type *) 0)) \
131: { \
132: case __real_type_class: \
133: switch (sizeof (__type)) \
134: { \
135: case sizeof (float): \
136: case sizeof (double): \
137: if ((__va).__freg_used < __NUM_PARM_FREGS - 1) \
138: { \
139: if (((__va).__freg_used & 1) != 0) \
140: (__va).__freg_used++; /* skip odd */ \
141: __rv = &__savereg((__va))->__float_regs.__freg[(__va).__freg_used];\
142: (__va).__freg_used += 2; \
143: } \
144: else \
145: { \
146: if ((((unsigned) (__va).__mem_ptr) & (sizeof(double)-1)) != 0) \
147: (__va).__mem_ptr++; /* skip odd */ \
148: __rv = (__va).__mem_ptr; \
149: (__va).__mem_ptr += 2; \
150: } \
151: if (sizeof (__type) == sizeof (float)) \
152: { \
153: *((float *) __rv) = *((double *) __rv); \
154: *(((long *) __rv) + 1) = 0xfff00001; \
155: } \
156: break; \
157: default: \
158: abort (); \
159: } \
160: break; \
161: case __void_type_class: \
162: case __integer_type_class: \
163: case __char_type_class: \
164: case __enumeral_type_class: \
165: case __boolean_type_class: \
166: case __pointer_type_class: \
167: case __reference_type_class: \
168: case __offset_type_class: \
169: if (sizeof (__type) <= 4) \
170: { \
171: __rv = ((__va).__ireg_used < __NUM_PARM_IREGS \
172: ? (&__savereg((__va))->__ireg[(__va).__ireg_used++]) \
173: : (__va).__mem_ptr++); \
174: break; \
175: } \
176: else if ((__va).__ireg_used + sizeof (__type) / 4 <= __NUM_PARM_IREGS) \
177: { \
178: __rv = &__savereg((__va))->__ireg[(__va).__ireg_used]; \
179: (__va).__ireg_used += sizeof (__type) / 4; \
180: break; \
181: } \
182: /* Fall through to fetch from memory. */ \
183: case __record_type_class: \
184: case __union_type_class: \
185: __align = (__alignof__ (__type) < sizeof (long) \
186: ? sizeof (long) \
187: : __alignof__ (__type)); \
188: (__va).__mem_ptr \
189: = (long *) \
190: ((((unsigned) (__va).__mem_ptr) + (__align-1)) & ~(__align-1)); \
191: __rv = (__va).__mem_ptr; \
192: (__va).__mem_ptr \
193: += ((sizeof (__type) + sizeof (long) - 1) / sizeof (long)); \
194: break; \
195: case __complex_type_class: \
196: case __function_type_class: \
197: case __method_type_class: \
198: case __array_type_class: \
199: case __string_type_class: \
200: case __set_type_class: \
201: case __file_type_class: \
202: case __lang_type_class: \
203: case __no_type_class: \
204: default: \
205: abort (); \
206: } \
207: __rv; \
208: }))
209:
210: #endif /* defined (_STDARG_H) || defined (_VARARGS_H) */
211:
This archive runs on limited infrastructure. Preserving old code on modern bandwidth. Automated agents are requested to crawl responsibly.