Back to index

cell-binutils  2.17cvs20070401
Classes | Defines
arm.h File Reference
This graph shows which files directly or indirectly include this file:

Go to the source code of this file.

Classes

struct  arm_feature_set

Defines

#define ARM_EXT_V1   0x00000001 /* All processors (core set). */
#define ARM_EXT_V2   0x00000002 /* Multiply instructions. */
#define ARM_EXT_V2S   0x00000004 /* SWP instructions. */
#define ARM_EXT_V3   0x00000008 /* MSR MRS. */
#define ARM_EXT_V3M   0x00000010 /* Allow long multiplies. */
#define ARM_EXT_V4   0x00000020 /* Allow half word loads. */
#define ARM_EXT_V4T   0x00000040 /* Thumb. */
#define ARM_EXT_V5   0x00000080 /* Allow CLZ, etc. */
#define ARM_EXT_V5T   0x00000100 /* Improved interworking. */
#define ARM_EXT_V5ExP   0x00000200 /* DSP core set. */
#define ARM_EXT_V5E   0x00000400 /* DSP Double transfers. */
#define ARM_EXT_V5J   0x00000800 /* Jazelle extension. */
#define ARM_EXT_V6   0x00001000 /* ARM V6. */
#define ARM_EXT_V6K   0x00002000 /* ARM V6K. */
#define ARM_EXT_V6Z   0x00004000 /* ARM V6Z. */
#define ARM_EXT_V6T2   0x00008000 /* Thumb-2. */
#define ARM_EXT_DIV   0x00010000 /* Integer division. */
#define ARM_EXT_V5E_NOTM   0x00020000 /* Arm V5E but not Arm V7M. */
#define ARM_EXT_V6_NOTM   0x00040000 /* Arm V6 but not Arm V7M. */
#define ARM_EXT_V7   0x00080000 /* Arm V7. */
#define ARM_EXT_V7A   0x00100000 /* Arm V7A. */
#define ARM_EXT_V7R   0x00200000 /* Arm V7R. */
#define ARM_EXT_V7M   0x00400000 /* Arm V7M. */
#define ARM_CEXT_XSCALE   0x00000001 /* Allow MIA etc. */
#define ARM_CEXT_MAVERICK   0x00000002 /* Use Cirrus/DSP coprocessor. */
#define ARM_CEXT_IWMMXT   0x00000004 /* Intel Wireless MMX technology coprocessor. */
#define ARM_CEXT_IWMMXT2   0x00000008 /* Intel Wireless MMX technology coprocessor version 2. */
#define FPU_ENDIAN_PURE   0x80000000 /* Pure-endian doubles. */
#define FPU_ENDIAN_BIG   0 /* Double words-big-endian. */
#define FPU_FPA_EXT_V1   0x40000000 /* Base FPA instruction set. */
#define FPU_FPA_EXT_V2   0x20000000 /* LFM/SFM. */
#define FPU_MAVERICK   0x10000000 /* Cirrus Maverick. */
#define FPU_VFP_EXT_V1xD   0x08000000 /* Base VFP instruction set. */
#define FPU_VFP_EXT_V1   0x04000000 /* Double-precision insns. */
#define FPU_VFP_EXT_V2   0x02000000 /* ARM10E VFPr1. */
#define FPU_VFP_EXT_V3   0x01000000 /* VFPv3 insns. */
#define FPU_NEON_EXT_V1   0x00800000 /* Neon (SIMD) insns. */
#define ARM_AEXT_V1   ARM_EXT_V1
#define ARM_AEXT_V2   (ARM_AEXT_V1 | ARM_EXT_V2)
#define ARM_AEXT_V2S   (ARM_AEXT_V2 | ARM_EXT_V2S)
#define ARM_AEXT_V3   (ARM_AEXT_V2S | ARM_EXT_V3)
#define ARM_AEXT_V3M   (ARM_AEXT_V3 | ARM_EXT_V3M)
#define ARM_AEXT_V4xM   (ARM_AEXT_V3 | ARM_EXT_V4)
#define ARM_AEXT_V4   (ARM_AEXT_V3M | ARM_EXT_V4)
#define ARM_AEXT_V4TxM   (ARM_AEXT_V4xM | ARM_EXT_V4T)
#define ARM_AEXT_V4T   (ARM_AEXT_V4 | ARM_EXT_V4T)
#define ARM_AEXT_V5xM   (ARM_AEXT_V4xM | ARM_EXT_V5)
#define ARM_AEXT_V5   (ARM_AEXT_V4 | ARM_EXT_V5)
#define ARM_AEXT_V5TxM   (ARM_AEXT_V5xM | ARM_EXT_V4T | ARM_EXT_V5T)
#define ARM_AEXT_V5T   (ARM_AEXT_V5 | ARM_EXT_V4T | ARM_EXT_V5T)
#define ARM_AEXT_V5TExP   (ARM_AEXT_V5T | ARM_EXT_V5ExP)
#define ARM_AEXT_V5TE   (ARM_AEXT_V5TExP | ARM_EXT_V5E)
#define ARM_AEXT_V5TEJ   (ARM_AEXT_V5TE | ARM_EXT_V5J)
#define ARM_AEXT_V6   (ARM_AEXT_V5TEJ | ARM_EXT_V6)
#define ARM_AEXT_V6K   (ARM_AEXT_V6 | ARM_EXT_V6K)
#define ARM_AEXT_V6Z   (ARM_AEXT_V6 | ARM_EXT_V6Z)
#define ARM_AEXT_V6ZK   (ARM_AEXT_V6 | ARM_EXT_V6K | ARM_EXT_V6Z)
#define ARM_AEXT_V6T2   (ARM_AEXT_V6 | ARM_EXT_V6T2 | ARM_EXT_V6_NOTM)
#define ARM_AEXT_V6KT2   (ARM_AEXT_V6T2 | ARM_EXT_V6K)
#define ARM_AEXT_V6ZT2   (ARM_AEXT_V6T2 | ARM_EXT_V6Z)
#define ARM_AEXT_V6ZKT2   (ARM_AEXT_V6T2 | ARM_EXT_V6K | ARM_EXT_V6Z)
#define ARM_AEXT_V7_ARM   (ARM_AEXT_V6ZKT2 | ARM_EXT_V7)
#define ARM_AEXT_V7A   (ARM_AEXT_V7_ARM | ARM_EXT_V7A)
#define ARM_AEXT_V7R   (ARM_AEXT_V7_ARM | ARM_EXT_V7R | ARM_EXT_DIV)
#define ARM_AEXT_NOTM   (ARM_AEXT_V4 | ARM_EXT_V5ExP | ARM_EXT_V5J | ARM_EXT_V6_NOTM)
#define ARM_AEXT_V7M   ((ARM_AEXT_V7_ARM | ARM_EXT_V7M | ARM_EXT_DIV) & ~(ARM_AEXT_NOTM))
#define ARM_AEXT_V7   (ARM_AEXT_V7A & ARM_AEXT_V7R & ARM_AEXT_V7M)
#define ARM_ARCH_XSCALE   ARM_FEATURE (ARM_AEXT_V5TE, ARM_CEXT_XSCALE)
#define ARM_ARCH_IWMMXT   ARM_FEATURE (ARM_AEXT_V5TE, ARM_CEXT_XSCALE | ARM_CEXT_IWMMXT)
#define ARM_ARCH_IWMMXT2   ARM_FEATURE (ARM_AEXT_V5TE, ARM_CEXT_XSCALE | ARM_CEXT_IWMMXT | ARM_CEXT_IWMMXT2)
#define FPU_VFP_V1xD   (FPU_VFP_EXT_V1xD | FPU_ENDIAN_PURE)
#define FPU_VFP_V1   (FPU_VFP_V1xD | FPU_VFP_EXT_V1)
#define FPU_VFP_V2   (FPU_VFP_V1 | FPU_VFP_EXT_V2)
#define FPU_VFP_V3   (FPU_VFP_V2 | FPU_VFP_EXT_V3)
#define FPU_VFP_HARD
#define FPU_FPA   (FPU_FPA_EXT_V1 | FPU_FPA_EXT_V2)
#define FPU_ARCH_VFP   ARM_FEATURE (0, FPU_ENDIAN_PURE)
#define FPU_ARCH_FPE   ARM_FEATURE (0, FPU_FPA_EXT_V1)
#define FPU_ARCH_FPA   ARM_FEATURE (0, FPU_FPA)
#define FPU_ARCH_VFP_V1xD   ARM_FEATURE (0, FPU_VFP_V1xD)
#define FPU_ARCH_VFP_V1   ARM_FEATURE (0, FPU_VFP_V1)
#define FPU_ARCH_VFP_V2   ARM_FEATURE (0, FPU_VFP_V2)
#define FPU_ARCH_VFP_V3   ARM_FEATURE (0, FPU_VFP_V3)
#define FPU_ARCH_NEON_V1   ARM_FEATURE (0, FPU_NEON_EXT_V1)
#define FPU_ARCH_VFP_V3_PLUS_NEON_V1   ARM_FEATURE (0, FPU_VFP_V3 | FPU_NEON_EXT_V1)
#define FPU_ARCH_VFP_HARD   ARM_FEATURE (0, FPU_VFP_HARD)
#define FPU_ARCH_ENDIAN_PURE   ARM_FEATURE (0, FPU_ENDIAN_PURE)
#define FPU_ARCH_MAVERICK   ARM_FEATURE (0, FPU_MAVERICK)
#define ARM_ARCH_V1   ARM_FEATURE (ARM_AEXT_V1, 0)
#define ARM_ARCH_V2   ARM_FEATURE (ARM_AEXT_V2, 0)
#define ARM_ARCH_V2S   ARM_FEATURE (ARM_AEXT_V2S, 0)
#define ARM_ARCH_V3   ARM_FEATURE (ARM_AEXT_V3, 0)
#define ARM_ARCH_V3M   ARM_FEATURE (ARM_AEXT_V3M, 0)
#define ARM_ARCH_V4xM   ARM_FEATURE (ARM_AEXT_V4xM, 0)
#define ARM_ARCH_V4   ARM_FEATURE (ARM_AEXT_V4, 0)
#define ARM_ARCH_V4TxM   ARM_FEATURE (ARM_AEXT_V4TxM, 0)
#define ARM_ARCH_V4T   ARM_FEATURE (ARM_AEXT_V4T, 0)
#define ARM_ARCH_V5xM   ARM_FEATURE (ARM_AEXT_V5xM, 0)
#define ARM_ARCH_V5   ARM_FEATURE (ARM_AEXT_V5, 0)
#define ARM_ARCH_V5TxM   ARM_FEATURE (ARM_AEXT_V5TxM, 0)
#define ARM_ARCH_V5T   ARM_FEATURE (ARM_AEXT_V5T, 0)
#define ARM_ARCH_V5TExP   ARM_FEATURE (ARM_AEXT_V5TExP, 0)
#define ARM_ARCH_V5TE   ARM_FEATURE (ARM_AEXT_V5TE, 0)
#define ARM_ARCH_V5TEJ   ARM_FEATURE (ARM_AEXT_V5TEJ, 0)
#define ARM_ARCH_V6   ARM_FEATURE (ARM_AEXT_V6, 0)
#define ARM_ARCH_V6K   ARM_FEATURE (ARM_AEXT_V6K, 0)
#define ARM_ARCH_V6Z   ARM_FEATURE (ARM_AEXT_V6Z, 0)
#define ARM_ARCH_V6ZK   ARM_FEATURE (ARM_AEXT_V6ZK, 0)
#define ARM_ARCH_V6T2   ARM_FEATURE (ARM_AEXT_V6T2, 0)
#define ARM_ARCH_V6KT2   ARM_FEATURE (ARM_AEXT_V6KT2, 0)
#define ARM_ARCH_V6ZT2   ARM_FEATURE (ARM_AEXT_V6ZT2, 0)
#define ARM_ARCH_V6ZKT2   ARM_FEATURE (ARM_AEXT_V6ZKT2, 0)
#define ARM_ARCH_V7   ARM_FEATURE (ARM_AEXT_V7, 0)
#define ARM_ARCH_V7A   ARM_FEATURE (ARM_AEXT_V7A, 0)
#define ARM_ARCH_V7R   ARM_FEATURE (ARM_AEXT_V7R, 0)
#define ARM_ARCH_V7M   ARM_FEATURE (ARM_AEXT_V7M, 0)
#define ARM_ARCH_NONE   ARM_FEATURE (0, 0)
#define FPU_NONE   ARM_FEATURE (0, 0)
#define ARM_ANY   ARM_FEATURE (-1, 0) /* Any basic core. */
#define FPU_ANY_HARD   ARM_FEATURE (0, FPU_FPA | FPU_VFP_HARD | FPU_MAVERICK)
#define ARM_ARCH_THUMB2   ARM_FEATURE (ARM_EXT_V6T2 | ARM_EXT_V7 | ARM_EXT_V7A | ARM_EXT_V7R | ARM_EXT_V7M | ARM_EXT_DIV, 0)
#define ARM_CPU_HAS_FEATURE(CPU, FEAT)   (((CPU).core & (FEAT).core) != 0 || ((CPU).coproc & (FEAT).coproc) != 0)
#define ARM_MERGE_FEATURE_SETS(TARG, F1, F2)
#define ARM_CLEAR_FEATURE(TARG, F1, F2)
#define ARM_FEATURE(core, coproc)   {(core), (coproc)}

Class Documentation

struct arm_feature_set

Definition at line 176 of file arm.h.

Class Members
unsigned long coproc
unsigned long core

Define Documentation

Definition at line 97 of file arm.h.

#define ARM_AEXT_V1   ARM_EXT_V1

Definition at line 70 of file arm.h.

Definition at line 71 of file arm.h.

Definition at line 72 of file arm.h.

Definition at line 73 of file arm.h.

Definition at line 74 of file arm.h.

Definition at line 76 of file arm.h.

Definition at line 78 of file arm.h.

Definition at line 77 of file arm.h.

Definition at line 75 of file arm.h.

Definition at line 80 of file arm.h.

Definition at line 82 of file arm.h.

Definition at line 84 of file arm.h.

Definition at line 85 of file arm.h.

Definition at line 83 of file arm.h.

Definition at line 81 of file arm.h.

Definition at line 79 of file arm.h.

Definition at line 86 of file arm.h.

Definition at line 87 of file arm.h.

Definition at line 91 of file arm.h.

Definition at line 90 of file arm.h.

Definition at line 88 of file arm.h.

Definition at line 89 of file arm.h.

Definition at line 93 of file arm.h.

Definition at line 92 of file arm.h.

Definition at line 101 of file arm.h.

Definition at line 94 of file arm.h.

Definition at line 95 of file arm.h.

Definition at line 99 of file arm.h.

Definition at line 96 of file arm.h.

#define ARM_ANY   ARM_FEATURE (-1, 0) /* Any basic core. */

Definition at line 169 of file arm.h.

Definition at line 105 of file arm.h.

Definition at line 107 of file arm.h.

#define ARM_ARCH_NONE   ARM_FEATURE (0, 0)

Definition at line 167 of file arm.h.

Definition at line 171 of file arm.h.

#define ARM_ARCH_V1   ARM_FEATURE (ARM_AEXT_V1, 0)

Definition at line 137 of file arm.h.

#define ARM_ARCH_V2   ARM_FEATURE (ARM_AEXT_V2, 0)

Definition at line 138 of file arm.h.

Definition at line 139 of file arm.h.

#define ARM_ARCH_V3   ARM_FEATURE (ARM_AEXT_V3, 0)

Definition at line 140 of file arm.h.

Definition at line 141 of file arm.h.

#define ARM_ARCH_V4   ARM_FEATURE (ARM_AEXT_V4, 0)

Definition at line 143 of file arm.h.

Definition at line 145 of file arm.h.

Definition at line 144 of file arm.h.

Definition at line 142 of file arm.h.

#define ARM_ARCH_V5   ARM_FEATURE (ARM_AEXT_V5, 0)

Definition at line 147 of file arm.h.

Definition at line 149 of file arm.h.

Definition at line 151 of file arm.h.

Definition at line 152 of file arm.h.

Definition at line 150 of file arm.h.

Definition at line 148 of file arm.h.

Definition at line 146 of file arm.h.

#define ARM_ARCH_V6   ARM_FEATURE (ARM_AEXT_V6, 0)

Definition at line 153 of file arm.h.

Definition at line 154 of file arm.h.

Definition at line 158 of file arm.h.

Definition at line 157 of file arm.h.

Definition at line 155 of file arm.h.

Definition at line 156 of file arm.h.

Definition at line 160 of file arm.h.

Definition at line 159 of file arm.h.

#define ARM_ARCH_V7   ARM_FEATURE (ARM_AEXT_V7, 0)

Definition at line 161 of file arm.h.

Definition at line 162 of file arm.h.

Definition at line 164 of file arm.h.

Definition at line 163 of file arm.h.

Definition at line 104 of file arm.h.

#define ARM_CEXT_IWMMXT   0x00000004 /* Intel Wireless MMX technology coprocessor. */

Definition at line 51 of file arm.h.

#define ARM_CEXT_IWMMXT2   0x00000008 /* Intel Wireless MMX technology coprocessor version 2. */

Definition at line 52 of file arm.h.

#define ARM_CEXT_MAVERICK   0x00000002 /* Use Cirrus/DSP coprocessor. */

Definition at line 50 of file arm.h.

#define ARM_CEXT_XSCALE   0x00000001 /* Allow MIA etc. */

Definition at line 49 of file arm.h.

#define ARM_CLEAR_FEATURE (   TARG,
  F1,
  F2 
)
Value:
do {                                      \
    (TARG).core = (F1).core &~ (F2).core; \
    (TARG).coproc = (F1).coproc &~ (F2).coproc;  \
  } while (0)

Definition at line 191 of file arm.h.

#define ARM_CPU_HAS_FEATURE (   CPU,
  FEAT 
)    (((CPU).core & (FEAT).core) != 0 || ((CPU).coproc & (FEAT).coproc) != 0)

Definition at line 182 of file arm.h.

#define ARM_EXT_DIV   0x00010000 /* Integer division. */

Definition at line 38 of file arm.h.

#define ARM_EXT_V1   0x00000001 /* All processors (core set). */

Definition at line 22 of file arm.h.

#define ARM_EXT_V2   0x00000002 /* Multiply instructions. */

Definition at line 23 of file arm.h.

#define ARM_EXT_V2S   0x00000004 /* SWP instructions. */

Definition at line 24 of file arm.h.

#define ARM_EXT_V3   0x00000008 /* MSR MRS. */

Definition at line 25 of file arm.h.

#define ARM_EXT_V3M   0x00000010 /* Allow long multiplies. */

Definition at line 26 of file arm.h.

#define ARM_EXT_V4   0x00000020 /* Allow half word loads. */

Definition at line 27 of file arm.h.

#define ARM_EXT_V4T   0x00000040 /* Thumb. */

Definition at line 28 of file arm.h.

#define ARM_EXT_V5   0x00000080 /* Allow CLZ, etc. */

Definition at line 29 of file arm.h.

#define ARM_EXT_V5E   0x00000400 /* DSP Double transfers. */

Definition at line 32 of file arm.h.

#define ARM_EXT_V5E_NOTM   0x00020000 /* Arm V5E but not Arm V7M. */

Definition at line 41 of file arm.h.

#define ARM_EXT_V5ExP   0x00000200 /* DSP core set. */

Definition at line 31 of file arm.h.

#define ARM_EXT_V5J   0x00000800 /* Jazelle extension. */

Definition at line 33 of file arm.h.

#define ARM_EXT_V5T   0x00000100 /* Improved interworking. */

Definition at line 30 of file arm.h.

#define ARM_EXT_V6   0x00001000 /* ARM V6. */

Definition at line 34 of file arm.h.

#define ARM_EXT_V6_NOTM   0x00040000 /* Arm V6 but not Arm V7M. */

Definition at line 42 of file arm.h.

#define ARM_EXT_V6K   0x00002000 /* ARM V6K. */

Definition at line 35 of file arm.h.

#define ARM_EXT_V6T2   0x00008000 /* Thumb-2. */

Definition at line 37 of file arm.h.

#define ARM_EXT_V6Z   0x00004000 /* ARM V6Z. */

Definition at line 36 of file arm.h.

#define ARM_EXT_V7   0x00080000 /* Arm V7. */

Definition at line 43 of file arm.h.

#define ARM_EXT_V7A   0x00100000 /* Arm V7A. */

Definition at line 44 of file arm.h.

#define ARM_EXT_V7M   0x00400000 /* Arm V7M. */

Definition at line 46 of file arm.h.

#define ARM_EXT_V7R   0x00200000 /* Arm V7R. */

Definition at line 45 of file arm.h.

#define ARM_FEATURE (   core,
  coproc 
)    {(core), (coproc)}

Definition at line 197 of file arm.h.

#define ARM_MERGE_FEATURE_SETS (   TARG,
  F1,
  F2 
)
Value:
do {                                      \
    (TARG).core = (F1).core | (F2).core;  \
    (TARG).coproc = (F1).coproc | (F2).coproc;   \
  } while (0)

Definition at line 185 of file arm.h.

Definition at line 170 of file arm.h.

Definition at line 133 of file arm.h.

#define FPU_ARCH_FPA   ARM_FEATURE (0, FPU_FPA)

Definition at line 122 of file arm.h.

Definition at line 121 of file arm.h.

Definition at line 135 of file arm.h.

Definition at line 128 of file arm.h.

Definition at line 119 of file arm.h.

Definition at line 131 of file arm.h.

Definition at line 125 of file arm.h.

Definition at line 124 of file arm.h.

Definition at line 126 of file arm.h.

Definition at line 127 of file arm.h.

Definition at line 129 of file arm.h.

#define FPU_ENDIAN_BIG   0 /* Double words-big-endian. */

Definition at line 55 of file arm.h.

#define FPU_ENDIAN_PURE   0x80000000 /* Pure-endian doubles. */

Definition at line 54 of file arm.h.

Definition at line 116 of file arm.h.

#define FPU_FPA_EXT_V1   0x40000000 /* Base FPA instruction set. */

Definition at line 56 of file arm.h.

#define FPU_FPA_EXT_V2   0x20000000 /* LFM/SFM. */

Definition at line 57 of file arm.h.

#define FPU_MAVERICK   0x10000000 /* Cirrus Maverick. */

Definition at line 58 of file arm.h.

#define FPU_NEON_EXT_V1   0x00800000 /* Neon (SIMD) insns. */

Definition at line 63 of file arm.h.

#define FPU_NONE   ARM_FEATURE (0, 0)

Definition at line 168 of file arm.h.

#define FPU_VFP_EXT_V1   0x04000000 /* Double-precision insns. */

Definition at line 60 of file arm.h.

#define FPU_VFP_EXT_V1xD   0x08000000 /* Base VFP instruction set. */

Definition at line 59 of file arm.h.

#define FPU_VFP_EXT_V2   0x02000000 /* ARM10E VFPr1. */

Definition at line 61 of file arm.h.

#define FPU_VFP_EXT_V3   0x01000000 /* VFPv3 insns. */

Definition at line 62 of file arm.h.

#define FPU_VFP_HARD
Value:

Definition at line 114 of file arm.h.

Definition at line 111 of file arm.h.

Definition at line 110 of file arm.h.

Definition at line 112 of file arm.h.

Definition at line 113 of file arm.h.