Path: blob/main/contrib/llvm-project/llvm/lib/Support/ARMBuildAttrs.cpp
35234 views
//===-- ARMBuildAttrs.cpp - ARM Build Attributes --------------------------===//1//2// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.3// See https://llvm.org/LICENSE.txt for license information.4// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception5//6//===----------------------------------------------------------------------===//78#include "llvm/Support/ARMBuildAttributes.h"9#include "llvm/ADT/Twine.h"10#include "llvm/Support/LEB128.h"11#include <iomanip>12#include <sstream>1314using namespace llvm;1516static const TagNameItem tagData[] = {17{ARMBuildAttrs::File, "Tag_File"},18{ARMBuildAttrs::Section, "Tag_Section"},19{ARMBuildAttrs::Symbol, "Tag_Symbol"},20{ARMBuildAttrs::CPU_raw_name, "Tag_CPU_raw_name"},21{ARMBuildAttrs::CPU_name, "Tag_CPU_name"},22{ARMBuildAttrs::CPU_arch, "Tag_CPU_arch"},23{ARMBuildAttrs::CPU_arch_profile, "Tag_CPU_arch_profile"},24{ARMBuildAttrs::ARM_ISA_use, "Tag_ARM_ISA_use"},25{ARMBuildAttrs::THUMB_ISA_use, "Tag_THUMB_ISA_use"},26{ARMBuildAttrs::FP_arch, "Tag_FP_arch"},27{ARMBuildAttrs::WMMX_arch, "Tag_WMMX_arch"},28{ARMBuildAttrs::Advanced_SIMD_arch, "Tag_Advanced_SIMD_arch"},29{ARMBuildAttrs::MVE_arch, "Tag_MVE_arch"},30{ARMBuildAttrs::PCS_config, "Tag_PCS_config"},31{ARMBuildAttrs::ABI_PCS_R9_use, "Tag_ABI_PCS_R9_use"},32{ARMBuildAttrs::ABI_PCS_RW_data, "Tag_ABI_PCS_RW_data"},33{ARMBuildAttrs::ABI_PCS_RO_data, "Tag_ABI_PCS_RO_data"},34{ARMBuildAttrs::ABI_PCS_GOT_use, "Tag_ABI_PCS_GOT_use"},35{ARMBuildAttrs::ABI_PCS_wchar_t, "Tag_ABI_PCS_wchar_t"},36{ARMBuildAttrs::ABI_FP_rounding, "Tag_ABI_FP_rounding"},37{ARMBuildAttrs::ABI_FP_denormal, "Tag_ABI_FP_denormal"},38{ARMBuildAttrs::ABI_FP_exceptions, "Tag_ABI_FP_exceptions"},39{ARMBuildAttrs::ABI_FP_user_exceptions, "Tag_ABI_FP_user_exceptions"},40{ARMBuildAttrs::ABI_FP_number_model, "Tag_ABI_FP_number_model"},41{ARMBuildAttrs::ABI_align_needed, "Tag_ABI_align_needed"},42{ARMBuildAttrs::ABI_align_preserved, "Tag_ABI_align_preserved"},43{ARMBuildAttrs::ABI_enum_size, "Tag_ABI_enum_size"},44{ARMBuildAttrs::ABI_HardFP_use, "Tag_ABI_HardFP_use"},45{ARMBuildAttrs::ABI_VFP_args, "Tag_ABI_VFP_args"},46{ARMBuildAttrs::ABI_WMMX_args, "Tag_ABI_WMMX_args"},47{ARMBuildAttrs::ABI_optimization_goals, "Tag_ABI_optimization_goals"},48{ARMBuildAttrs::ABI_FP_optimization_goals, "Tag_ABI_FP_optimization_goals"},49{ARMBuildAttrs::compatibility, "Tag_compatibility"},50{ARMBuildAttrs::CPU_unaligned_access, "Tag_CPU_unaligned_access"},51{ARMBuildAttrs::FP_HP_extension, "Tag_FP_HP_extension"},52{ARMBuildAttrs::ABI_FP_16bit_format, "Tag_ABI_FP_16bit_format"},53{ARMBuildAttrs::MPextension_use, "Tag_MPextension_use"},54{ARMBuildAttrs::DIV_use, "Tag_DIV_use"},55{ARMBuildAttrs::DSP_extension, "Tag_DSP_extension"},56{ARMBuildAttrs::PAC_extension, "Tag_PAC_extension"},57{ARMBuildAttrs::BTI_extension, "Tag_BTI_extension"},58{ARMBuildAttrs::BTI_use, "Tag_BTI_use"},59{ARMBuildAttrs::PACRET_use, "Tag_PACRET_use"},60{ARMBuildAttrs::nodefaults, "Tag_nodefaults"},61{ARMBuildAttrs::also_compatible_with, "Tag_also_compatible_with"},62{ARMBuildAttrs::T2EE_use, "Tag_T2EE_use"},63{ARMBuildAttrs::conformance, "Tag_conformance"},64{ARMBuildAttrs::Virtualization_use, "Tag_Virtualization_use"},6566// Legacy Names67{ARMBuildAttrs::FP_arch, "Tag_VFP_arch"},68{ARMBuildAttrs::FP_HP_extension, "Tag_VFP_HP_extension"},69{ARMBuildAttrs::ABI_align_needed, "Tag_ABI_align8_needed"},70{ARMBuildAttrs::ABI_align_preserved, "Tag_ABI_align8_preserved"},71};7273constexpr TagNameMap ARMAttributeTags{tagData};74const TagNameMap &llvm::ARMBuildAttrs::getARMAttributeTags() {75return ARMAttributeTags;76}777879