Home | History | Annotate | Line # | Download | only in include
cdefs.h revision 1.16
      1  1.16     joerg /*	$NetBSD: cdefs.h,v 1.16 2019/08/02 12:07:25 joerg 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.10      matt #if defined (__ARM_ARCH_8A__)
     13  1.10      matt #define _ARM_ARCH_8		/* ARMv8 64-bit in AARCH32 */
     14  1.10      matt #endif
     15  1.10      matt 
     16  1.10      matt #if defined (_ARM_ARCH_8) || defined (__ARM_ARCH_7__) || \
     17  1.10      matt     defined (__ARM_ARCH_7A__) || defined (__ARM_ARCH_7R__) || \
     18  1.10      matt     defined (__ARM_ARCH_7M__) || defined (__ARM_ARCH_7EM__)
     19  1.10      matt 	/* 7R, 7M, 7EM are for non MMU arms */
     20   1.5      matt #define _ARM_ARCH_7
     21   1.5      matt #endif
     22   1.5      matt 
     23   1.8      matt #if defined (_ARM_ARCH_7) || defined (__ARM_ARCH_6T2__)
     24   1.8      matt #define _ARM_ARCH_T2		/* Thumb2 */
     25   1.8      matt #endif
     26   1.8      matt 
     27   1.8      matt #if defined (_ARM_ARCH_T2) || defined (__ARM_ARCH_6__) || \
     28  1.16     joerg     defined (__ARM_ARCH_6J__) || \
     29  1.16     joerg     defined (__ARM_ARCH_6K__) || defined (__ARM_ARCH_6KZ__) || \
     30   1.5      matt     defined (__ARM_ARCH_6Z__) || defined (__ARM_ARCH_6ZK__) || \
     31   1.8      matt     defined (__ARM_ARCH_6ZM__)
     32   1.2      matt #define _ARM_ARCH_6
     33   1.2      matt #endif
     34   1.2      matt 
     35   1.9      matt #if defined (_ARM_ARCH_6) || defined (__ARM_ARCH_5T__) || \
     36   1.9      matt     defined (__ARM_ARCH_5TE__) || defined (__ARM_ARCH_5TEJ__)
     37   1.9      matt #define _ARM_ARCH_5T
     38   1.9      matt #endif
     39   1.9      matt 
     40   1.9      matt #if defined (_ARM_ARCH_6) || defined (_ARM_ARCH_5T) || defined (__ARM_ARCH_5__)
     41   1.2      matt #define _ARM_ARCH_5
     42   1.2      matt #endif
     43   1.2      matt 
     44   1.2      matt #if defined (_ARM_ARCH_5) || defined (__ARM_ARCH_4T__)
     45   1.2      matt #define _ARM_ARCH_4T
     46   1.2      matt #endif
     47   1.1     bjh21 
     48   1.8      matt #if defined (_ARM_ARCH_T2) || \
     49   1.8      matt     (!defined (__thumb__) && \
     50   1.8      matt      (defined (_ARM_ARCH_6) || defined (__ARM_ARCH_5TE__) || \
     51   1.8      matt       defined (__ARM_ARCH_5TEJ__)))
     52   1.7      matt #define	_ARM_ARCH_DWORD_OK
     53   1.7      matt #endif
     54   1.7      matt 
     55  1.14      matt #if defined(__ARM_PCS_AAPCS64)
     56  1.14      matt #define __ALIGNBYTES		(sizeof(__int128_t) - 1)
     57  1.14      matt #elif defined(__ARM_EABI__)
     58  1.14      matt #define __ALIGNBYTES		(sizeof(long long) - 1)
     59   1.6      matt #else
     60   1.4     joerg #define __ALIGNBYTES		(sizeof(int) - 1)
     61   1.6      matt #endif
     62   1.4     joerg 
     63   1.8      matt #endif /* !_ARM_CDEFS_H_ */
     64