1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 | //=- WebAssemblySubtarget.h - Define Subtarget for the WebAssembly -*- 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 // //===----------------------------------------------------------------------===// /// /// \file /// This file declares the WebAssembly-specific subclass of /// TargetSubtarget. /// //===----------------------------------------------------------------------===// #ifndef LLVM_LIB_TARGET_WEBASSEMBLY_WEBASSEMBLYSUBTARGET_H #define LLVM_LIB_TARGET_WEBASSEMBLY_WEBASSEMBLYSUBTARGET_H #include "WebAssemblyFrameLowering.h" #include "WebAssemblyISelLowering.h" #include "WebAssemblyInstrInfo.h" #include "WebAssemblySelectionDAGInfo.h" #include "llvm/CodeGen/TargetSubtargetInfo.h" #include <string> #define GET_SUBTARGETINFO_ENUM #define GET_SUBTARGETINFO_HEADER #include "WebAssemblyGenSubtargetInfo.inc" namespace llvm { // Defined in WebAssemblyGenSubtargetInfo.inc. extern const SubtargetFeatureKV WebAssemblyFeatureKV[WebAssembly::NumSubtargetFeatures]; class WebAssemblySubtarget final : public WebAssemblyGenSubtargetInfo { enum SIMDEnum { NoSIMD, SIMD128, UnimplementedSIMD128, } SIMDLevel = NoSIMD; bool HasAtomics = false; bool HasNontrappingFPToInt = false; bool HasSignExt = false; bool HasExceptionHandling = false; bool HasBulkMemory = false; bool HasMultivalue = false; bool HasMutableGlobals = false; bool HasTailCall = false; bool HasReferenceTypes = false; /// What processor and OS we're targeting. Triple TargetTriple; WebAssemblyFrameLowering FrameLowering; WebAssemblyInstrInfo InstrInfo; WebAssemblySelectionDAGInfo TSInfo; WebAssemblyTargetLowering TLInfo; WebAssemblySubtarget &initializeSubtargetDependencies(StringRef CPU, StringRef FS); public: /// This constructor initializes the data members to match that /// of the specified triple. WebAssemblySubtarget(const Triple &TT, const std::string &CPU, const std::string &FS, const TargetMachine &TM); const WebAssemblySelectionDAGInfo *getSelectionDAGInfo() const override { return &TSInfo; } const WebAssemblyFrameLowering *getFrameLowering() const override { return &FrameLowering; } const WebAssemblyTargetLowering *getTargetLowering() const override { return &TLInfo; } const WebAssemblyInstrInfo *getInstrInfo() const override { return &InstrInfo; } const WebAssemblyRegisterInfo *getRegisterInfo() const override { return &getInstrInfo()->getRegisterInfo(); } const Triple &getTargetTriple() const { return TargetTriple; } bool enableAtomicExpand() const override; bool enableIndirectBrExpand() const override { return true; } bool enableMachineScheduler() const override; bool useAA() const override; // Predicates used by WebAssemblyInstrInfo.td. bool hasAddr64() const { return TargetTriple.isArch64Bit(); } bool hasSIMD128() const { return SIMDLevel >= SIMD128; } bool hasUnimplementedSIMD128() const { return SIMDLevel >= UnimplementedSIMD128; } bool hasAtomics() const { return HasAtomics; } bool hasNontrappingFPToInt() const { return HasNontrappingFPToInt; } bool hasSignExt() const { return HasSignExt; } bool hasExceptionHandling() const { return HasExceptionHandling; } bool hasBulkMemory() const { return HasBulkMemory; } bool hasMultivalue() const { return HasMultivalue; } bool hasMutableGlobals() const { return HasMutableGlobals; } bool hasTailCall() const { return HasTailCall; } bool hasReferenceTypes() const { return HasReferenceTypes; } /// Parses features string setting specified subtarget options. Definition of /// function is auto generated by tblgen. void ParseSubtargetFeatures(StringRef CPU, StringRef FS); }; } // end namespace llvm #endif |