diff options
Diffstat (limited to 'llvm/lib/Target')
| -rw-r--r-- | llvm/lib/Target/ARM/Disassembler/ARMDisassemblerCore.cpp | 60 | ||||
| -rw-r--r-- | llvm/lib/Target/ARM/Disassembler/ARMDisassemblerCore.h | 55 | ||||
| -rw-r--r-- | llvm/lib/Target/ARM/Makefile | 5 | 
3 files changed, 31 insertions, 89 deletions
| diff --git a/llvm/lib/Target/ARM/Disassembler/ARMDisassemblerCore.cpp b/llvm/lib/Target/ARM/Disassembler/ARMDisassemblerCore.cpp index eb67d754e26..db921ef0b62 100644 --- a/llvm/lib/Target/ARM/Disassembler/ARMDisassemblerCore.cpp +++ b/llvm/lib/Target/ARM/Disassembler/ARMDisassemblerCore.cpp @@ -8,8 +8,8 @@  //===----------------------------------------------------------------------===//  //  // This file is part of the ARM Disassembler. -// It contains code to represent the core concepts of Builder, Builder Factory, -// as well as the Algorithm to solve the problem of disassembling an ARM instr. +// It contains code to represent the core concepts of Builder and DisassembleFP +// to solve the problem of disassembling an ARM instr.  //  //===----------------------------------------------------------------------===// @@ -3127,40 +3127,12 @@ static const DisassembleFP FuncPtrs[] = {    NULL  }; -/// Algorithms - Algorithms stores a map from Format to ARMAlgorithm*. -static std::vector<ARMAlgorithm*> Algorithms; - -/// DoCleanup - Do cleanup of Algorithms upon exit. -void ARMAlgorithm::DoCleanup() { -  for (unsigned i = 0; i < array_lengthof(FuncPtrs); ++i) -    if (Algorithms[i]) -      delete Algorithms[i]; -} - -/// GetInstance - GetInstance returns an instance of ARMAlgorithm given the -/// encoding Format.  API clients should not free up the returned instance. -ARMAlgorithm *ARMAlgorithm::GetInstance(ARMFormat Format) { -  /// Init the first time. -  if (Algorithms.size() == 0) { -    Algorithms.resize(array_lengthof(FuncPtrs)); -    for (unsigned i = 0, num = array_lengthof(FuncPtrs); i < num; ++i) -      if (FuncPtrs[i]) -        Algorithms[i] = new ARMAlgorithm(FuncPtrs[i]); -      else -        Algorithms[i] = NULL; - -    // Register cleanup routine. -    atexit(DoCleanup); -  } -  return Algorithms[Format]; -} -  /// BuildIt - BuildIt performs the build step for this ARM Basic MC Builder.  /// The general idea is to set the Opcode for the MCInst, followed by adding  /// the appropriate MCOperands to the MCInst.  ARM Basic MC Builder delegates -/// to the Algo (ARM Disassemble Algorithm) object to perform Format-specific -/// disassembly, followed by TryPredicateAndSBitModifier() to do -/// PredicateOperand and OptionalDefOperand which follow the Dst/Src Operands. +/// to the Format-specific disassemble function for disassembly, followed by +/// TryPredicateAndSBitModifier() to do PredicateOperand and OptionalDefOperand +/// which follow the Dst/Src Operands.  bool ARMBasicMCBuilder::BuildIt(MCInst &MI, uint32_t insn) {    // Stage 1 sets the Opcode.    MI.setOpcode(Opcode); @@ -3168,9 +3140,12 @@ bool ARMBasicMCBuilder::BuildIt(MCInst &MI, uint32_t insn) {    if (NumOps == 0)      return true; -  // Stage 2 calls the ARM Disassembly Algorithm to build the operand list. +  // Stage 2 calls the format-specific disassemble function to build the operand +  // list. +  if (Disasm == NULL) +    return false;    unsigned NumOpsAdded = 0; -  bool OK = Algo.Solve(MI, Opcode, insn, NumOps, NumOpsAdded, this); +  bool OK = (*Disasm)(MI, Opcode, insn, NumOps, NumOpsAdded, this);    if (!OK) return false;    if (NumOpsAdded >= NumOps) @@ -3256,6 +3231,15 @@ bool ARMBasicMCBuilder::RunBuildAfterHook(bool Status, MCInst &MI,    return Status;  } +/// Opcode, Format, and NumOperands make up an ARM Basic MCBuilder. +ARMBasicMCBuilder::ARMBasicMCBuilder(unsigned opc, ARMFormat format, +                                     unsigned short num) +  : Opcode(opc), Format(format), NumOps(num), SP(0) { +  unsigned Idx = (unsigned)format; +  assert(Idx < (array_lengthof(FuncPtrs) - 1) && "Unknown format"); +  Disasm = FuncPtrs[Idx]; +} +  /// CreateMCBuilder - Return an ARMBasicMCBuilder that can build up the MC  /// infrastructure of an MCInst given the Opcode and Format of the instr.  /// Return NULL if it fails to create/return a proper builder.  API clients @@ -3263,10 +3247,6 @@ bool ARMBasicMCBuilder::RunBuildAfterHook(bool Status, MCInst &MI,  /// performed by the API clients to improve performance.  ARMBasicMCBuilder *llvm::CreateMCBuilder(unsigned Opcode, ARMFormat Format) { -  ARMAlgorithm *Algo = ARMAlgorithm::GetInstance(Format); -  if (!Algo) -    return NULL; -    return new ARMBasicMCBuilder(Opcode, Format, -                               ARMInsts[Opcode].getNumOperands(), *Algo); +                               ARMInsts[Opcode].getNumOperands());  } diff --git a/llvm/lib/Target/ARM/Disassembler/ARMDisassemblerCore.h b/llvm/lib/Target/ARM/Disassembler/ARMDisassemblerCore.h index 6d742512f83..30752303708 100644 --- a/llvm/lib/Target/ARM/Disassembler/ARMDisassemblerCore.h +++ b/llvm/lib/Target/ARM/Disassembler/ARMDisassemblerCore.h @@ -13,8 +13,8 @@  // specifies the encoding used by the instruction, as well as a helper function  // to convert the enums to printable char strings.  // -// It also contains code to represent the concepts of Builder, Builder Factory, -// as well as the Algorithm to solve the problem of disassembling an ARM instr. +// It also contains code to represent the concepts of Builder and DisassembleFP +// to solve the problem of disassembling an ARM instr.  //  //===----------------------------------------------------------------------===// @@ -171,60 +171,23 @@ typedef ARMBasicMCBuilder *BO;  typedef bool (*DisassembleFP)(MCInst &MI, unsigned Opcode, uint32_t insn,      unsigned short NumOps, unsigned &NumOpsAdded, BO Builder); -/// ARMAlgorithm - ARMAlgorithm implements the ARM/Thumb disassembly by solving -/// the problem of building the MCOperands of an MCInst.  Construction of -/// ARMAlgorithm requires passing in a function pointer with the DisassembleFP -/// data type. -class ARMAlgorithm { -public: -  /// GetInstance - GetInstance returns an instance of ARMAlgorithm given the -  /// encoding Format.  API clients should not free up the returned instance. -  static ARMAlgorithm *GetInstance(ARMFormat Format); - -  /// DoCleanup - DoCleanup is meant to be called upon exit as an exit handler. -  static void DoCleanup(); - -  /// Return true if this algorithm successfully disassembles the instruction. -  /// NumOpsAdded is updated to reflect the number of operands added by the -  /// algorithm.  NumOpsAdded may be less than NumOps, in which case, there are -  /// operands unaccounted for which need to be dealt with by the API client. -  bool Solve(MCInst &MI, unsigned Opcode, uint32_t insn, unsigned short NumOps, -      unsigned &NumOpsAdded, BO Builder) const { -    if (Disassemble == NULL) -      return false; - -    return (*Disassemble)(MI, Opcode, insn, NumOps, NumOpsAdded, Builder); -  } - -private: -  ARMAlgorithm(DisassembleFP fp) : Disassemble(fp) {} -  ARMAlgorithm(ARMAlgorithm &AA) : Disassemble(AA.Disassemble) {} - -  virtual ~ARMAlgorithm() {} - -  DisassembleFP Disassemble; -}; -  /// ARMBasicMCBuilder - ARMBasicMCBuilder represents an ARM MCInst builder that  /// knows how to build up the MCOperand list.  class ARMBasicMCBuilder {    unsigned Opcode;    ARMFormat Format;    unsigned short NumOps; -  const ARMAlgorithm &Algo; +  DisassembleFP Disasm;    Session *SP;  public:    ARMBasicMCBuilder(ARMBasicMCBuilder &B) -    : Opcode(B.Opcode), Format(B.Format), NumOps(B.NumOps), Algo(B.Algo), +    : Opcode(B.Opcode), Format(B.Format), NumOps(B.NumOps), Disasm(B.Disasm),        SP(B.SP)    {} -  /// Opcode, Format, NumOperands, and Algo make an ARM Basic MCBuilder. -  ARMBasicMCBuilder(unsigned opc, ARMFormat format, unsigned short num, -                    const ARMAlgorithm &algo) -    : Opcode(opc), Format(format), NumOps(num), Algo(algo), SP(0) -  {} +  /// Opcode, Format, and NumOperands make up an ARM Basic MCBuilder. +  ARMBasicMCBuilder(unsigned opc, ARMFormat format, unsigned short num);    virtual ~ARMBasicMCBuilder() {} @@ -256,9 +219,9 @@ public:    /// BuildIt - BuildIt performs the build step for this ARM Basic MC Builder.    /// The general idea is to set the Opcode for the MCInst, followed by adding    /// the appropriate MCOperands to the MCInst.  ARM Basic MC Builder delegates -  /// to the Algo (ARM Disassemble Algorithm) object to perform Format-specific -  /// disassembly, followed by class method TryPredicateAndSBitModifier() to do -  /// PredicateOperand and OptionalDefOperand which follow the Dst/Src Operands. +  /// to the Format-specific disassemble function for disassembly, followed by +  /// TryPredicateAndSBitModifier() for PredicateOperand and OptionalDefOperand +  /// which follow the Dst/Src Operands.    virtual bool BuildIt(MCInst &MI, uint32_t insn);    /// RunBuildAfterHook - RunBuildAfterHook performs operations deemed necessary diff --git a/llvm/lib/Target/ARM/Makefile b/llvm/lib/Target/ARM/Makefile index b7ed14abed7..a8dd38cb362 100644 --- a/llvm/lib/Target/ARM/Makefile +++ b/llvm/lib/Target/ARM/Makefile @@ -16,9 +16,8 @@ BUILT_SOURCES = ARMGenRegisterInfo.h.inc ARMGenRegisterNames.inc \                  ARMGenRegisterInfo.inc ARMGenInstrNames.inc \                  ARMGenInstrInfo.inc ARMGenAsmWriter.inc \                  ARMGenDAGISel.inc ARMGenSubtarget.inc \ -                ARMGenCodeEmitter.inc ARMGenCallingConv.inc \ -		ARMGenDecoderTables.inc +                ARMGenCodeEmitter.inc ARMGenCallingConv.inc -DIRS = AsmPrinter AsmParser Disassembler TargetInfo +DIRS = AsmPrinter AsmParser TargetInfo  include $(LEVEL)/Makefile.common | 

