| //===- ARMAttributeParser.h - ARM Attribute Information Printer -*- C++ -*-===// |
| // |
| // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. |
| // See https://llvm.org/LICENSE.txt for license information. |
| // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception |
| // |
| //===----------------------------------------------------------------------===// |
| |
| #ifndef LLVM_SUPPORT_ARMATTRIBUTEPARSER_H |
| #define LLVM_SUPPORT_ARMATTRIBUTEPARSER_H |
| |
| #include "ARMBuildAttributes.h" |
| #include "ELFAttributeParser.h" |
| #include "ScopedPrinter.h" |
| #include "llvm/ADT/ArrayRef.h" |
| #include "llvm/Support/DataExtractor.h" |
| #include "llvm/Support/Endian.h" |
| #include "llvm/Support/Error.h" |
| |
| namespace llvm { |
| class StringRef; |
| |
| class ARMAttributeParser : public ELFAttributeParser { |
| struct DisplayHandler { |
| ARMBuildAttrs::AttrType attribute; |
| Error (ARMAttributeParser::*routine)(ARMBuildAttrs::AttrType); |
| }; |
| static const DisplayHandler displayRoutines[]; |
| |
| Error handler(uint64_t tag, bool &handled) override; |
| |
| Error stringAttribute(ARMBuildAttrs::AttrType tag); |
| |
| Error CPU_arch(ARMBuildAttrs::AttrType tag); |
| Error CPU_arch_profile(ARMBuildAttrs::AttrType tag); |
| Error ARM_ISA_use(ARMBuildAttrs::AttrType tag); |
| Error THUMB_ISA_use(ARMBuildAttrs::AttrType tag); |
| Error FP_arch(ARMBuildAttrs::AttrType tag); |
| Error WMMX_arch(ARMBuildAttrs::AttrType tag); |
| Error Advanced_SIMD_arch(ARMBuildAttrs::AttrType tag); |
| Error MVE_arch(ARMBuildAttrs::AttrType tag); |
| Error PCS_config(ARMBuildAttrs::AttrType tag); |
| Error ABI_PCS_R9_use(ARMBuildAttrs::AttrType tag); |
| Error ABI_PCS_RW_data(ARMBuildAttrs::AttrType tag); |
| Error ABI_PCS_RO_data(ARMBuildAttrs::AttrType tag); |
| Error ABI_PCS_GOT_use(ARMBuildAttrs::AttrType tag); |
| Error ABI_PCS_wchar_t(ARMBuildAttrs::AttrType tag); |
| Error ABI_FP_rounding(ARMBuildAttrs::AttrType tag); |
| Error ABI_FP_denormal(ARMBuildAttrs::AttrType tag); |
| Error ABI_FP_exceptions(ARMBuildAttrs::AttrType tag); |
| Error ABI_FP_user_exceptions(ARMBuildAttrs::AttrType tag); |
| Error ABI_FP_number_model(ARMBuildAttrs::AttrType tag); |
| Error ABI_align_needed(ARMBuildAttrs::AttrType tag); |
| Error ABI_align_preserved(ARMBuildAttrs::AttrType tag); |
| Error ABI_enum_size(ARMBuildAttrs::AttrType tag); |
| Error ABI_HardFP_use(ARMBuildAttrs::AttrType tag); |
| Error ABI_VFP_args(ARMBuildAttrs::AttrType tag); |
| Error ABI_WMMX_args(ARMBuildAttrs::AttrType tag); |
| Error ABI_optimization_goals(ARMBuildAttrs::AttrType tag); |
| Error ABI_FP_optimization_goals(ARMBuildAttrs::AttrType tag); |
| Error compatibility(ARMBuildAttrs::AttrType tag); |
| Error CPU_unaligned_access(ARMBuildAttrs::AttrType tag); |
| Error FP_HP_extension(ARMBuildAttrs::AttrType tag); |
| Error ABI_FP_16bit_format(ARMBuildAttrs::AttrType tag); |
| Error MPextension_use(ARMBuildAttrs::AttrType tag); |
| Error DIV_use(ARMBuildAttrs::AttrType tag); |
| Error DSP_extension(ARMBuildAttrs::AttrType tag); |
| Error T2EE_use(ARMBuildAttrs::AttrType tag); |
| Error Virtualization_use(ARMBuildAttrs::AttrType tag); |
| Error nodefaults(ARMBuildAttrs::AttrType tag); |
| |
| public: |
| ARMAttributeParser(ScopedPrinter *sw) |
| : ELFAttributeParser(sw, ARMBuildAttrs::ARMAttributeTags, "aeabi") {} |
| ARMAttributeParser() |
| : ELFAttributeParser(ARMBuildAttrs::ARMAttributeTags, "aeabi") {} |
| }; |
| } |
| |
| #endif |