diff options
Diffstat (limited to 'llvm/lib/Target/RISCV/Disassembler/RISCVDisassembler.cpp')
| -rw-r--r-- | llvm/lib/Target/RISCV/Disassembler/RISCVDisassembler.cpp | 118 | 
1 files changed, 78 insertions, 40 deletions
| diff --git a/llvm/lib/Target/RISCV/Disassembler/RISCVDisassembler.cpp b/llvm/lib/Target/RISCV/Disassembler/RISCVDisassembler.cpp index ff96b2b254ca..1c732a15de2f 100644 --- a/llvm/lib/Target/RISCV/Disassembler/RISCVDisassembler.cpp +++ b/llvm/lib/Target/RISCV/Disassembler/RISCVDisassembler.cpp @@ -14,8 +14,8 @@  #include "MCTargetDesc/RISCVMCTargetDesc.h"  #include "TargetInfo/RISCVTargetInfo.h"  #include "llvm/MC/MCContext.h" +#include "llvm/MC/MCDecoderOps.h"  #include "llvm/MC/MCDisassembler/MCDisassembler.h" -#include "llvm/MC/MCFixedLenDisassembler.h"  #include "llvm/MC/MCInst.h"  #include "llvm/MC/MCInstrInfo.h"  #include "llvm/MC/MCRegisterInfo.h" @@ -60,11 +60,9 @@ extern "C" LLVM_EXTERNAL_VISIBILITY void LLVMInitializeRISCVDisassembler() {  static DecodeStatus DecodeGPRRegisterClass(MCInst &Inst, uint64_t RegNo,                                             uint64_t Address, -                                           const void *Decoder) { +                                           const MCDisassembler *Decoder) {    const FeatureBitset &FeatureBits = -      static_cast<const MCDisassembler *>(Decoder) -          ->getSubtargetInfo() -          .getFeatureBits(); +      Decoder->getSubtargetInfo().getFeatureBits();    bool IsRV32E = FeatureBits[RISCV::FeatureRV32E];    if (RegNo >= 32 || (IsRV32E && RegNo >= 16)) @@ -77,7 +75,7 @@ static DecodeStatus DecodeGPRRegisterClass(MCInst &Inst, uint64_t RegNo,  static DecodeStatus DecodeFPR16RegisterClass(MCInst &Inst, uint64_t RegNo,                                               uint64_t Address, -                                             const void *Decoder) { +                                             const MCDisassembler *Decoder) {    if (RegNo >= 32)      return MCDisassembler::Fail; @@ -88,7 +86,7 @@ static DecodeStatus DecodeFPR16RegisterClass(MCInst &Inst, uint64_t RegNo,  static DecodeStatus DecodeFPR32RegisterClass(MCInst &Inst, uint64_t RegNo,                                               uint64_t Address, -                                             const void *Decoder) { +                                             const MCDisassembler *Decoder) {    if (RegNo >= 32)      return MCDisassembler::Fail; @@ -99,7 +97,7 @@ static DecodeStatus DecodeFPR32RegisterClass(MCInst &Inst, uint64_t RegNo,  static DecodeStatus DecodeFPR32CRegisterClass(MCInst &Inst, uint64_t RegNo,                                                uint64_t Address, -                                              const void *Decoder) { +                                              const MCDisassembler *Decoder) {    if (RegNo >= 8) {      return MCDisassembler::Fail;    } @@ -110,7 +108,7 @@ static DecodeStatus DecodeFPR32CRegisterClass(MCInst &Inst, uint64_t RegNo,  static DecodeStatus DecodeFPR64RegisterClass(MCInst &Inst, uint64_t RegNo,                                               uint64_t Address, -                                             const void *Decoder) { +                                             const MCDisassembler *Decoder) {    if (RegNo >= 32)      return MCDisassembler::Fail; @@ -121,7 +119,7 @@ static DecodeStatus DecodeFPR64RegisterClass(MCInst &Inst, uint64_t RegNo,  static DecodeStatus DecodeFPR64CRegisterClass(MCInst &Inst, uint64_t RegNo,                                                uint64_t Address, -                                              const void *Decoder) { +                                              const MCDisassembler *Decoder) {    if (RegNo >= 8) {      return MCDisassembler::Fail;    } @@ -132,7 +130,7 @@ static DecodeStatus DecodeFPR64CRegisterClass(MCInst &Inst, uint64_t RegNo,  static DecodeStatus DecodeGPRNoX0RegisterClass(MCInst &Inst, uint64_t RegNo,                                                 uint64_t Address, -                                               const void *Decoder) { +                                               const MCDisassembler *Decoder) {    if (RegNo == 0) {      return MCDisassembler::Fail;    } @@ -140,9 +138,9 @@ static DecodeStatus DecodeGPRNoX0RegisterClass(MCInst &Inst, uint64_t RegNo,    return DecodeGPRRegisterClass(Inst, RegNo, Address, Decoder);  } -static DecodeStatus DecodeGPRNoX0X2RegisterClass(MCInst &Inst, uint64_t RegNo, -                                                 uint64_t Address, -                                                 const void *Decoder) { +static DecodeStatus +DecodeGPRNoX0X2RegisterClass(MCInst &Inst, uint64_t RegNo, uint64_t Address, +                             const MCDisassembler *Decoder) {    if (RegNo == 2) {      return MCDisassembler::Fail;    } @@ -152,7 +150,7 @@ static DecodeStatus DecodeGPRNoX0X2RegisterClass(MCInst &Inst, uint64_t RegNo,  static DecodeStatus DecodeGPRCRegisterClass(MCInst &Inst, uint64_t RegNo,                                              uint64_t Address, -                                            const void *Decoder) { +                                            const MCDisassembler *Decoder) {    if (RegNo >= 8)      return MCDisassembler::Fail; @@ -161,9 +159,20 @@ static DecodeStatus DecodeGPRCRegisterClass(MCInst &Inst, uint64_t RegNo,    return MCDisassembler::Success;  } +static DecodeStatus DecodeGPRPF64RegisterClass(MCInst &Inst, uint64_t RegNo, +                                               uint64_t Address, +                                               const MCDisassembler *Decoder) { +  if (RegNo >= 32 || RegNo & 1) +    return MCDisassembler::Fail; + +  MCRegister Reg = RISCV::X0 + RegNo; +  Inst.addOperand(MCOperand::createReg(Reg)); +  return MCDisassembler::Success; +} +  static DecodeStatus DecodeVRRegisterClass(MCInst &Inst, uint64_t RegNo,                                            uint64_t Address, -                                          const void *Decoder) { +                                          const MCDisassembler *Decoder) {    if (RegNo >= 32)      return MCDisassembler::Fail; @@ -174,7 +183,7 @@ static DecodeStatus DecodeVRRegisterClass(MCInst &Inst, uint64_t RegNo,  static DecodeStatus DecodeVRM2RegisterClass(MCInst &Inst, uint64_t RegNo,                                              uint64_t Address, -                                            const void *Decoder) { +                                            const MCDisassembler *Decoder) {    if (RegNo >= 32)      return MCDisassembler::Fail; @@ -194,7 +203,7 @@ static DecodeStatus DecodeVRM2RegisterClass(MCInst &Inst, uint64_t RegNo,  static DecodeStatus DecodeVRM4RegisterClass(MCInst &Inst, uint64_t RegNo,                                              uint64_t Address, -                                            const void *Decoder) { +                                            const MCDisassembler *Decoder) {    if (RegNo >= 32)      return MCDisassembler::Fail; @@ -214,7 +223,7 @@ static DecodeStatus DecodeVRM4RegisterClass(MCInst &Inst, uint64_t RegNo,  static DecodeStatus DecodeVRM8RegisterClass(MCInst &Inst, uint64_t RegNo,                                              uint64_t Address, -                                            const void *Decoder) { +                                            const MCDisassembler *Decoder) {    if (RegNo >= 32)      return MCDisassembler::Fail; @@ -233,7 +242,8 @@ static DecodeStatus DecodeVRM8RegisterClass(MCInst &Inst, uint64_t RegNo,  }  static DecodeStatus decodeVMaskReg(MCInst &Inst, uint64_t RegNo, -                                   uint64_t Address, const void *Decoder) { +                                   uint64_t Address, +                                   const MCDisassembler *Decoder) {    MCRegister Reg = RISCV::NoRegister;    switch (RegNo) {    default: @@ -250,7 +260,8 @@ static DecodeStatus decodeVMaskReg(MCInst &Inst, uint64_t RegNo,  // Add implied SP operand for instructions *SP compressed instructions. The SP  // operand isn't explicitly encoded in the instruction. -static void addImplySP(MCInst &Inst, int64_t Address, const void *Decoder) { +static void addImplySP(MCInst &Inst, int64_t Address, +                       const MCDisassembler *Decoder) {    if (Inst.getOpcode() == RISCV::C_LWSP || Inst.getOpcode() == RISCV::C_SWSP ||        Inst.getOpcode() == RISCV::C_LDSP || Inst.getOpcode() == RISCV::C_SDSP ||        Inst.getOpcode() == RISCV::C_FLWSP || @@ -268,7 +279,8 @@ static void addImplySP(MCInst &Inst, int64_t Address, const void *Decoder) {  template <unsigned N>  static DecodeStatus decodeUImmOperand(MCInst &Inst, uint64_t Imm, -                                      int64_t Address, const void *Decoder) { +                                      int64_t Address, +                                      const MCDisassembler *Decoder) {    assert(isUInt<N>(Imm) && "Invalid immediate");    addImplySP(Inst, Address, Decoder);    Inst.addOperand(MCOperand::createImm(Imm)); @@ -278,7 +290,7 @@ static DecodeStatus decodeUImmOperand(MCInst &Inst, uint64_t Imm,  template <unsigned N>  static DecodeStatus decodeUImmNonZeroOperand(MCInst &Inst, uint64_t Imm,                                               int64_t Address, -                                             const void *Decoder) { +                                             const MCDisassembler *Decoder) {    if (Imm == 0)      return MCDisassembler::Fail;    return decodeUImmOperand<N>(Inst, Imm, Address, Decoder); @@ -286,7 +298,8 @@ static DecodeStatus decodeUImmNonZeroOperand(MCInst &Inst, uint64_t Imm,  template <unsigned N>  static DecodeStatus decodeSImmOperand(MCInst &Inst, uint64_t Imm, -                                      int64_t Address, const void *Decoder) { +                                      int64_t Address, +                                      const MCDisassembler *Decoder) {    assert(isUInt<N>(Imm) && "Invalid immediate");    addImplySP(Inst, Address, Decoder);    // Sign-extend the number in the bottom N bits of Imm @@ -297,7 +310,7 @@ static DecodeStatus decodeSImmOperand(MCInst &Inst, uint64_t Imm,  template <unsigned N>  static DecodeStatus decodeSImmNonZeroOperand(MCInst &Inst, uint64_t Imm,                                               int64_t Address, -                                             const void *Decoder) { +                                             const MCDisassembler *Decoder) {    if (Imm == 0)      return MCDisassembler::Fail;    return decodeSImmOperand<N>(Inst, Imm, Address, Decoder); @@ -306,7 +319,7 @@ static DecodeStatus decodeSImmNonZeroOperand(MCInst &Inst, uint64_t Imm,  template <unsigned N>  static DecodeStatus decodeSImmOperandAndLsl1(MCInst &Inst, uint64_t Imm,                                               int64_t Address, -                                             const void *Decoder) { +                                             const MCDisassembler *Decoder) {    assert(isUInt<N>(Imm) && "Invalid immediate");    // Sign-extend the number in the bottom N bits of Imm after accounting for    // the fact that the N bit immediate is stored in N-1 bits (the LSB is @@ -317,7 +330,7 @@ static DecodeStatus decodeSImmOperandAndLsl1(MCInst &Inst, uint64_t Imm,  static DecodeStatus decodeCLUIImmOperand(MCInst &Inst, uint64_t Imm,                                           int64_t Address, -                                         const void *Decoder) { +                                         const MCDisassembler *Decoder) {    assert(isUInt<6>(Imm) && "Invalid immediate");    if (Imm > 31) {      Imm = (SignExtend64<6>(Imm) & 0xfffff); @@ -326,9 +339,8 @@ static DecodeStatus decodeCLUIImmOperand(MCInst &Inst, uint64_t Imm,    return MCDisassembler::Success;  } -static DecodeStatus decodeFRMArg(MCInst &Inst, uint64_t Imm, -                                 int64_t Address, -                                 const void *Decoder) { +static DecodeStatus decodeFRMArg(MCInst &Inst, uint64_t Imm, int64_t Address, +                                 const MCDisassembler *Decoder) {    assert(isUInt<3>(Imm) && "Invalid immediate");    if (!llvm::RISCVFPRndMode::isValidRoundingMode(Imm))      return MCDisassembler::Fail; @@ -338,26 +350,30 @@ static DecodeStatus decodeFRMArg(MCInst &Inst, uint64_t Imm,  }  static DecodeStatus decodeRVCInstrSImm(MCInst &Inst, unsigned Insn, -                                       uint64_t Address, const void *Decoder); +                                       uint64_t Address, +                                       const MCDisassembler *Decoder);  static DecodeStatus decodeRVCInstrRdSImm(MCInst &Inst, unsigned Insn, -                                         uint64_t Address, const void *Decoder); +                                         uint64_t Address, +                                         const MCDisassembler *Decoder);  static DecodeStatus decodeRVCInstrRdRs1UImm(MCInst &Inst, unsigned Insn,                                              uint64_t Address, -                                            const void *Decoder); +                                            const MCDisassembler *Decoder);  static DecodeStatus decodeRVCInstrRdRs2(MCInst &Inst, unsigned Insn, -                                        uint64_t Address, const void *Decoder); +                                        uint64_t Address, +                                        const MCDisassembler *Decoder);  static DecodeStatus decodeRVCInstrRdRs1Rs2(MCInst &Inst, unsigned Insn,                                             uint64_t Address, -                                           const void *Decoder); +                                           const MCDisassembler *Decoder);  #include "RISCVGenDisassemblerTables.inc"  static DecodeStatus decodeRVCInstrSImm(MCInst &Inst, unsigned Insn, -                                       uint64_t Address, const void *Decoder) { +                                       uint64_t Address, +                                       const MCDisassembler *Decoder) {    uint64_t SImm6 =        fieldFromInstruction(Insn, 12, 1) << 5 | fieldFromInstruction(Insn, 2, 5);    DecodeStatus Result = decodeSImmOperand<6>(Inst, SImm6, Address, Decoder); @@ -368,7 +384,7 @@ static DecodeStatus decodeRVCInstrSImm(MCInst &Inst, unsigned Insn,  static DecodeStatus decodeRVCInstrRdSImm(MCInst &Inst, unsigned Insn,                                           uint64_t Address, -                                         const void *Decoder) { +                                         const MCDisassembler *Decoder) {    DecodeGPRRegisterClass(Inst, 0, Address, Decoder);    uint64_t SImm6 =        fieldFromInstruction(Insn, 12, 1) << 5 | fieldFromInstruction(Insn, 2, 5); @@ -380,7 +396,7 @@ static DecodeStatus decodeRVCInstrRdSImm(MCInst &Inst, unsigned Insn,  static DecodeStatus decodeRVCInstrRdRs1UImm(MCInst &Inst, unsigned Insn,                                              uint64_t Address, -                                            const void *Decoder) { +                                            const MCDisassembler *Decoder) {    DecodeGPRRegisterClass(Inst, 0, Address, Decoder);    Inst.addOperand(Inst.getOperand(0));    uint64_t UImm6 = @@ -392,7 +408,8 @@ static DecodeStatus decodeRVCInstrRdRs1UImm(MCInst &Inst, unsigned Insn,  }  static DecodeStatus decodeRVCInstrRdRs2(MCInst &Inst, unsigned Insn, -                                        uint64_t Address, const void *Decoder) { +                                        uint64_t Address, +                                        const MCDisassembler *Decoder) {    unsigned Rd = fieldFromInstruction(Insn, 7, 5);    unsigned Rs2 = fieldFromInstruction(Insn, 2, 5);    DecodeGPRRegisterClass(Inst, Rd, Address, Decoder); @@ -402,7 +419,7 @@ static DecodeStatus decodeRVCInstrRdRs2(MCInst &Inst, unsigned Insn,  static DecodeStatus decodeRVCInstrRdRs1Rs2(MCInst &Inst, unsigned Insn,                                             uint64_t Address, -                                           const void *Decoder) { +                                           const MCDisassembler *Decoder) {    unsigned Rd = fieldFromInstruction(Insn, 7, 5);    unsigned Rs2 = fieldFromInstruction(Insn, 2, 5);    DecodeGPRRegisterClass(Inst, Rd, Address, Decoder); @@ -427,6 +444,27 @@ DecodeStatus RISCVDisassembler::getInstruction(MCInst &MI, uint64_t &Size,        return MCDisassembler::Fail;      }      Insn = support::endian::read32le(Bytes.data()); +    if (STI.getFeatureBits()[RISCV::FeatureStdExtZdinx] && +        !STI.getFeatureBits()[RISCV::Feature64Bit]) { +      LLVM_DEBUG(dbgs() << "Trying RV32Zdinx table (Double in Integer and" +                           "rv32)\n"); +      Result = decodeInstruction(DecoderTableRV32Zdinx32, MI, Insn, Address, +                                 this, STI); +      if (Result != MCDisassembler::Fail) { +        Size = 4; +        return Result; +      } +    } + +    if (STI.getFeatureBits()[RISCV::FeatureStdExtZfinx]) { +      LLVM_DEBUG(dbgs() << "Trying RVZfinx table (Float in Integer):\n"); +      Result = decodeInstruction(DecoderTableRVZfinx32, MI, Insn, Address, this, +                                 STI); +      if (Result != MCDisassembler::Fail) { +        Size = 4; +        return Result; +      } +    }      LLVM_DEBUG(dbgs() << "Trying RISCV32 table :\n");      Result = decodeInstruction(DecoderTable32, MI, Insn, Address, this, STI);      Size = 4; | 
