12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758 |
- /* Macros to test for CPU features on ARM. Generic ARM version.
- Copyright (C) 2012-2025 Free Software Foundation, Inc.
- The GNU C Library is free software; you can redistribute it and/or
- modify it under the terms of the GNU Lesser General Public
- License as published by the Free Software Foundation; either
- version 2.1 of the License, or (at your option) any later version.
- The GNU C Library is distributed in the hope that it will be useful,
- but WITHOUT ANY WARRANTY; without even the implied warranty of
- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
- Lesser General Public License for more details.
- You should have received a copy of the GNU Lesser General Public
- License along with the GNU C Library. If not, see
- <https://www.gnu.org/licenses/>. */
- #ifndef _ARM_ARM_FEATURES_H
- #define _ARM_ARM_FEATURES_H 1
- /* An OS-specific arm-features.h file should define ARM_HAVE_VFP to
- an appropriate expression for testing at runtime whether the VFP
- hardware is present. We'll then redefine it to a constant if we
- know at compile time that we can assume VFP. */
- #ifndef __SOFTFP__
- /* The compiler is generating VFP instructions, so we're already
- assuming the hardware exists. */
- # undef ARM_HAVE_VFP
- # define ARM_HAVE_VFP 1
- #endif
- /* An OS-specific arm-features.h file may define ARM_ASSUME_NO_IWMMXT
- to indicate at compile time that iWMMXt hardware is never present
- at runtime (or that we never care about its state) and so need not
- be checked for. */
- /* A more-specific arm-features.h file may define ARM_ALWAYS_BX to indicate
- that instructions using pc as a destination register must never be used,
- so a "bx" (or "blx") instruction is always required. */
- /* The log2 of the minimum alignment required for an address that
- is the target of a computed branch (i.e. a "bx" instruction).
- A more-specific arm-features.h file may define this to set a more
- stringent requirement.
- Using this only makes sense for code in ARM mode (where instructions
- always have a fixed size of four bytes), or for Thumb-mode code that is
- specifically aligning all the related branch targets to match (since
- Thumb instructions might be either two or four bytes). */
- #ifndef ARM_BX_ALIGN_LOG2
- # define ARM_BX_ALIGN_LOG2 2
- #endif
- /* An OS-specific arm-features.h file may define ARM_NO_INDEX_REGISTER to
- indicate that the two-register addressing modes must never be used. */
- #endif /* arm-features.h */
|