diff options
Diffstat (limited to 'contrib/llvm/lib/Target/Mips/Disassembler/MipsDisassembler.cpp')
| -rw-r--r-- | contrib/llvm/lib/Target/Mips/Disassembler/MipsDisassembler.cpp | 50 | 
1 files changed, 27 insertions, 23 deletions
| diff --git a/contrib/llvm/lib/Target/Mips/Disassembler/MipsDisassembler.cpp b/contrib/llvm/lib/Target/Mips/Disassembler/MipsDisassembler.cpp index 82dbcc5bcf7d..59e49d8ddc6c 100644 --- a/contrib/llvm/lib/Target/Mips/Disassembler/MipsDisassembler.cpp +++ b/contrib/llvm/lib/Target/Mips/Disassembler/MipsDisassembler.cpp @@ -12,18 +12,15 @@  //===----------------------------------------------------------------------===//  #include "Mips.h" -#include "MipsSubtarget.h"  #include "MipsRegisterInfo.h" -#include "llvm/MC/EDInstInfo.h" +#include "MipsSubtarget.h"  #include "llvm/MC/MCDisassembler.h"  #include "llvm/MC/MCFixedLenDisassembler.h" -#include "llvm/Support/MemoryObject.h" -#include "llvm/Support/TargetRegistry.h" -#include "llvm/MC/MCSubtargetInfo.h"  #include "llvm/MC/MCInst.h" +#include "llvm/MC/MCSubtargetInfo.h"  #include "llvm/Support/MathExtras.h" - -#include "MipsGenEDInfo.inc" +#include "llvm/Support/MemoryObject.h" +#include "llvm/Support/TargetRegistry.h"  using namespace llvm; @@ -42,9 +39,6 @@ public:    virtual ~MipsDisassemblerBase() {} -  /// getEDInfo - See MCDisassembler. -  const EDInstInfo *getEDInfo() const; -    const MCRegisterInfo *getRegInfo() const { return RegInfo; }  private: @@ -92,10 +86,6 @@ public:  } // end anonymous namespace -const EDInstInfo *MipsDisassemblerBase::getEDInfo() const { -  return instInfoMips; -} -  // Forward declare these because the autogenerated code will reference them.  // Definitions are further down.  static DecodeStatus DecodeCPU64RegsRegisterClass(MCInst &Inst, @@ -103,6 +93,11 @@ static DecodeStatus DecodeCPU64RegsRegisterClass(MCInst &Inst,                                                   uint64_t Address,                                                   const void *Decoder); +static DecodeStatus DecodeCPU16RegsRegisterClass(MCInst &Inst, +                                                 unsigned RegNo, +                                                 uint64_t Address, +                                                 const void *Decoder); +  static DecodeStatus DecodeCPURegsRegisterClass(MCInst &Inst,                                                 unsigned RegNo,                                                 uint64_t Address, @@ -143,10 +138,10 @@ static DecodeStatus DecodeHWRegs64RegisterClass(MCInst &Inst,                                                  uint64_t Address,                                                  const void *Decoder); -static DecodeStatus DecodeACRegsRegisterClass(MCInst &Inst, -                                              unsigned RegNo, -                                              uint64_t Address, -                                              const void *Decoder); +static DecodeStatus DecodeACRegsDSPRegisterClass(MCInst &Inst, +                                                 unsigned RegNo, +                                                 uint64_t Address, +                                                 const void *Decoder);  static DecodeStatus DecodeBranchTarget(MCInst &Inst,                                         unsigned Offset, @@ -332,6 +327,15 @@ static unsigned getReg(const void *D, unsigned RC, unsigned RegNo) {    return *(Dis->getRegInfo()->getRegClass(RC).begin() + RegNo);  } +static DecodeStatus DecodeCPU16RegsRegisterClass(MCInst &Inst, +                                                 unsigned RegNo, +                                                 uint64_t Address, +                                                 const void *Decoder) { + +  return MCDisassembler::Fail; + +} +  static DecodeStatus DecodeCPU64RegsRegisterClass(MCInst &Inst,                                                   unsigned RegNo,                                                   uint64_t Address, @@ -480,14 +484,14 @@ static DecodeStatus DecodeHWRegs64RegisterClass(MCInst &Inst,    return MCDisassembler::Success;  } -static DecodeStatus DecodeACRegsRegisterClass(MCInst &Inst, -                                              unsigned RegNo, -                                              uint64_t Address, -                                              const void *Decoder) { +static DecodeStatus DecodeACRegsDSPRegisterClass(MCInst &Inst, +                                                 unsigned RegNo, +                                                 uint64_t Address, +                                                 const void *Decoder) {    if (RegNo >= 4)      return MCDisassembler::Fail; -  unsigned Reg = getReg(Decoder, Mips::ACRegsRegClassID, RegNo); +  unsigned Reg = getReg(Decoder, Mips::ACRegsDSPRegClassID, RegNo);    Inst.addOperand(MCOperand::CreateReg(Reg));    return MCDisassembler::Success;  } | 
