diff options
author | huderlem <huderlem@gmail.com> | 2020-02-15 09:06:38 -0600 |
---|---|---|
committer | GitHub <noreply@github.com> | 2020-02-15 09:06:38 -0600 |
commit | 74e171579e0bbefbd72b83f3764fe504464bbdbe (patch) | |
tree | 8db5aacbe963fef56eb2d9965fc87db1a6642387 /gcc_arm/ginclude/va-fr30.h | |
parent | 27176890c4a688ea7de44d3f55af32827016a9fd (diff) | |
parent | c6bcd24dfe44d58ed1b6bef6653270dbf6cd6bfa (diff) |
Merge pull request #30 from camthesaxman/arm_support
Build ARM compiler
Diffstat (limited to 'gcc_arm/ginclude/va-fr30.h')
-rwxr-xr-x | gcc_arm/ginclude/va-fr30.h | 49 |
1 files changed, 49 insertions, 0 deletions
diff --git a/gcc_arm/ginclude/va-fr30.h b/gcc_arm/ginclude/va-fr30.h new file mode 100755 index 0000000..17b8e37 --- /dev/null +++ b/gcc_arm/ginclude/va-fr30.h @@ -0,0 +1,49 @@ +/* Define __gnuc_va_list. */ + +#ifndef __GNUC_VA_LIST +#define __GNUC_VA_LIST +typedef void * __gnuc_va_list; +#endif /* not __GNUC_VA_LIST */ + +/* If this is for internal libc use, don't define anything but + __gnuc_va_list. */ +#if defined (_STDARG_H) || defined (_VARARGS_H) + +#ifdef _STDARG_H +#define va_start(AP, LASTARG) \ + (AP = ((__gnuc_va_list) __builtin_next_arg (LASTARG))) +#else +#define __va_ellipsis ... +#define va_alist __builtin_va_alist +#define va_dcl int __builtin_va_alist; __va_ellipsis +#define va_start(AP) AP = (char *) & __builtin_va_alist +#endif + +/* Now stuff common to both varargs & stdarg implementations. */ +#define __va_rounded_size(TYPE) \ + (((sizeof (TYPE) + sizeof (int) - 1) / sizeof (int)) * sizeof (int)) + +#undef va_end + +void va_end (__gnuc_va_list); + +#define va_end(AP) ((void)0) + +/* We need to be able to detect structures and handle them specially. */ +#define __va_aggregate_p(TYPE) (__builtin_classify_type(*(TYPE *)0) >= 12) + +#define va_arg(AP, TYPE) \ + (__va_aggregate_p (TYPE) ? \ + (AP = (__gnuc_va_list) ((char *) (AP) + __va_rounded_size (char *)), \ + ** ((TYPE **) (void *)((char *) (AP) - __va_rounded_size (char *)))) \ + : (sizeof (TYPE) % sizeof (int) == 0) ? \ + (AP = (__gnuc_va_list) ((char *) (AP) + __va_rounded_size (TYPE)), \ + * ((TYPE *) (void *) ((char *) (AP) - __va_rounded_size (TYPE)))) \ + : (sizeof (TYPE) < 4) ? \ + (AP = (__gnuc_va_list) ((char *) (AP) + __va_rounded_size (TYPE)), \ + * ((TYPE *) (void *) ((char *) (AP) - sizeof (TYPE)))) \ + : \ + (AP = (__gnuc_va_list) ((char *) (AP) + __va_rounded_size (char *)), \ + ** ((TYPE **) (void *)((char *) (AP) - __va_rounded_size (char *))))) + +#endif /* defined (_STDARG_H) || defined (_VARARGS_H) */ |