Details | Last modification | View Log | RSS feed
| Rev | Author | Line No. | Line |
|---|---|---|---|
| 14 | pmbaty | 1 | //===-- llvm/MC/MCInstrInfo.h - Target Instruction Info ---------*- C++ -*-===// |
| 2 | // |
||
| 3 | // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. |
||
| 4 | // See https://llvm.org/LICENSE.txt for license information. |
||
| 5 | // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception |
||
| 6 | // |
||
| 7 | //===----------------------------------------------------------------------===// |
||
| 8 | // |
||
| 9 | // This file describes the target machine instruction set. |
||
| 10 | // |
||
| 11 | //===----------------------------------------------------------------------===// |
||
| 12 | |||
| 13 | #ifndef LLVM_MC_MCINSTRINFO_H |
||
| 14 | #define LLVM_MC_MCINSTRINFO_H |
||
| 15 | |||
| 16 | #include "llvm/ADT/StringRef.h" |
||
| 17 | #include "llvm/MC/MCInstrDesc.h" |
||
| 18 | #include <cassert> |
||
| 19 | |||
| 20 | namespace llvm { |
||
| 21 | |||
| 22 | class MCSubtargetInfo; |
||
| 23 | |||
| 24 | //--------------------------------------------------------------------------- |
||
| 25 | /// Interface to description of machine instruction set. |
||
| 26 | class MCInstrInfo { |
||
| 27 | public: |
||
| 28 | using ComplexDeprecationPredicate = bool (*)(MCInst &, |
||
| 29 | const MCSubtargetInfo &, |
||
| 30 | std::string &); |
||
| 31 | |||
| 32 | private: |
||
| 33 | const MCInstrDesc *LastDesc; // Raw array to allow static init'n |
||
| 34 | const unsigned *InstrNameIndices; // Array for name indices in InstrNameData |
||
| 35 | const char *InstrNameData; // Instruction name string pool |
||
| 36 | // Subtarget feature that an instruction is deprecated on, if any |
||
| 37 | // -1 implies this is not deprecated by any single feature. It may still be |
||
| 38 | // deprecated due to a "complex" reason, below. |
||
| 39 | const uint8_t *DeprecatedFeatures; |
||
| 40 | // A complex method to determine if a certain instruction is deprecated or |
||
| 41 | // not, and return the reason for deprecation. |
||
| 42 | const ComplexDeprecationPredicate *ComplexDeprecationInfos; |
||
| 43 | unsigned NumOpcodes; // Number of entries in the desc array |
||
| 44 | |||
| 45 | public: |
||
| 46 | /// Initialize MCInstrInfo, called by TableGen auto-generated routines. |
||
| 47 | /// *DO NOT USE*. |
||
| 48 | void InitMCInstrInfo(const MCInstrDesc *D, const unsigned *NI, const char *ND, |
||
| 49 | const uint8_t *DF, |
||
| 50 | const ComplexDeprecationPredicate *CDI, unsigned NO) { |
||
| 51 | LastDesc = D + NO - 1; |
||
| 52 | InstrNameIndices = NI; |
||
| 53 | InstrNameData = ND; |
||
| 54 | DeprecatedFeatures = DF; |
||
| 55 | ComplexDeprecationInfos = CDI; |
||
| 56 | NumOpcodes = NO; |
||
| 57 | } |
||
| 58 | |||
| 59 | unsigned getNumOpcodes() const { return NumOpcodes; } |
||
| 60 | |||
| 61 | /// Return the machine instruction descriptor that corresponds to the |
||
| 62 | /// specified instruction opcode. |
||
| 63 | const MCInstrDesc &get(unsigned Opcode) const { |
||
| 64 | assert(Opcode < NumOpcodes && "Invalid opcode!"); |
||
| 65 | // The table is indexed backwards from the last entry. |
||
| 66 | return *(LastDesc - Opcode); |
||
| 67 | } |
||
| 68 | |||
| 69 | /// Returns the name for the instructions with the given opcode. |
||
| 70 | StringRef getName(unsigned Opcode) const { |
||
| 71 | assert(Opcode < NumOpcodes && "Invalid opcode!"); |
||
| 72 | return StringRef(&InstrNameData[InstrNameIndices[Opcode]]); |
||
| 73 | } |
||
| 74 | |||
| 75 | /// Returns true if a certain instruction is deprecated and if so |
||
| 76 | /// returns the reason in \p Info. |
||
| 77 | bool getDeprecatedInfo(MCInst &MI, const MCSubtargetInfo &STI, |
||
| 78 | std::string &Info) const; |
||
| 79 | }; |
||
| 80 | |||
| 81 | } // End llvm namespace |
||
| 82 | |||
| 83 | #endif |