Home | History | Annotate | Line # | Download | only in include
cdefs.h revision 1.17
      1  1.17     skrll /*	$NetBSD: cdefs.h,v 1.17 2020/10/11 16:22:02 skrll Exp $	*/
      2   1.1     bjh21 
      3   1.8      matt #ifndef	_ARM_CDEFS_H_
      4   1.8      matt #define	_ARM_CDEFS_H_
      5   1.1     bjh21 
      6  1.15  christos #ifndef __lint__
      7  1.12      matt #if (__GNUC__ == 4 && __GNUC_MINOR__ < 1) || __GNUC__ < 4
      8  1.11      matt #error GCC 4.1 or compatible required.
      9  1.11      matt #endif
     10  1.15  christos #endif
     11  1.11      matt 
     12  1.17     skrll 
     13  1.17     skrll #if defined (__ARM_ARCH_8A__) || defined (__ARM_ARCH_8A)
     14  1.17     skrll 	/* __ARM_ARCH_8A__ is a typo */
     15  1.17     skrll #define _ARM_ARCH_8
     16  1.10      matt #endif
     17  1.10      matt 
     18  1.10      matt #if defined (_ARM_ARCH_8) || defined (__ARM_ARCH_7__) || \
     19  1.10      matt     defined (__ARM_ARCH_7A__) || defined (__ARM_ARCH_7R__) || \
     20  1.10      matt     defined (__ARM_ARCH_7M__) || defined (__ARM_ARCH_7EM__)
     21  1.10      matt 	/* 7R, 7M, 7EM are for non MMU arms */
     22   1.5      matt #define _ARM_ARCH_7
     23   1.5      matt #endif
     24   1.5      matt 
     25   1.8      matt #if defined (_ARM_ARCH_7) || defined (__ARM_ARCH_6T2__)
     26   1.8      matt #define _ARM_ARCH_T2		/* Thumb2 */
     27   1.8      matt #endif
     28   1.8      matt 
     29   1.8      matt #if defined (_ARM_ARCH_T2) || defined (__ARM_ARCH_6__) || \
     30  1.16     joerg     defined (__ARM_ARCH_6J__) || \
     31  1.16     joerg     defined (__ARM_ARCH_6K__) || defined (__ARM_ARCH_6KZ__) || \
     32   1.5      matt     defined (__ARM_ARCH_6Z__) || defined (__ARM_ARCH_6ZK__) || \
     33   1.8      matt     defined (__ARM_ARCH_6ZM__)
     34   1.2      matt #define _ARM_ARCH_6
     35   1.2      matt #endif
     36   1.2      matt 
     37   1.9      matt #if defined (_ARM_ARCH_6) || defined (__ARM_ARCH_5T__) || \
     38   1.9      matt     defined (__ARM_ARCH_5TE__) || defined (__ARM_ARCH_5TEJ__)
     39   1.9      matt #define _ARM_ARCH_5T
     40   1.9      matt #endif
     41   1.9      matt 
     42   1.9      matt #if defined (_ARM_ARCH_6) || defined (_ARM_ARCH_5T) || defined (__ARM_ARCH_5__)
     43   1.2      matt #define _ARM_ARCH_5
     44   1.2      matt #endif
     45   1.2      matt 
     46   1.2      matt #if defined (_ARM_ARCH_5) || defined (__ARM_ARCH_4T__)
     47   1.2      matt #define _ARM_ARCH_4T
     48   1.2      matt #endif
     49   1.1     bjh21 
     50   1.8      matt #if defined (_ARM_ARCH_T2) || \
     51   1.8      matt     (!defined (__thumb__) && \
     52   1.8      matt      (defined (_ARM_ARCH_6) || defined (__ARM_ARCH_5TE__) || \
     53   1.8      matt       defined (__ARM_ARCH_5TEJ__)))
     54   1.7      matt #define	_ARM_ARCH_DWORD_OK
     55   1.7      matt #endif
     56   1.7      matt 
     57  1.14      matt #if defined(__ARM_PCS_AAPCS64)
     58  1.14      matt #define __ALIGNBYTES		(sizeof(__int128_t) - 1)
     59  1.14      matt #elif defined(__ARM_EABI__)
     60  1.14      matt #define __ALIGNBYTES		(sizeof(long long) - 1)
     61   1.6      matt #else
     62   1.4     joerg #define __ALIGNBYTES		(sizeof(int) - 1)
     63   1.6      matt #endif
     64   1.4     joerg 
     65   1.8      matt #endif /* !_ARM_CDEFS_H_ */
     66