diff options
author | Sean Callanan <scallanan@apple.com> | 2011-04-20 00:43:34 +0000 |
---|---|---|
committer | Sean Callanan <scallanan@apple.com> | 2011-04-20 00:43:34 +0000 |
commit | 863f84648f937683a88d09877c51d6257165bed6 (patch) | |
tree | d1128e16ad229cc24fdfb7d71cc653a03958427e /lib/MC/MCDisassembler/EDOperand.cpp | |
parent | 558692fd0a31d4d3ae4fd09a3a02f80da2e44e5c (diff) |
Made the MC disassembler check before accessing
MCInst operands for ARM. This allows it to be
more tolerant of malformed MCInsts or incorrect
instruction metadata.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@129840 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/MC/MCDisassembler/EDOperand.cpp')
-rw-r--r-- | lib/MC/MCDisassembler/EDOperand.cpp | 9 |
1 files changed, 9 insertions, 0 deletions
diff --git a/lib/MC/MCDisassembler/EDOperand.cpp b/lib/MC/MCDisassembler/EDOperand.cpp index 04b21cb359..492bb08f33 100644 --- a/lib/MC/MCDisassembler/EDOperand.cpp +++ b/lib/MC/MCDisassembler/EDOperand.cpp @@ -198,15 +198,24 @@ int EDOperand::evaluate(uint64_t &result, default: return -1; case kOperandTypeImmediate: + if (!Inst.Inst->getOperand(MCOpIndex).isImm()) + return -1; + result = Inst.Inst->getOperand(MCOpIndex).getImm(); return 0; case kOperandTypeRegister: { + if (!Inst.Inst->getOperand(MCOpIndex).isReg()) + return -1; + unsigned reg = Inst.Inst->getOperand(MCOpIndex).getReg(); return callback(&result, reg, arg); } case kOperandTypeARMBranchTarget: { + if (!Inst.Inst->getOperand(MCOpIndex).isImm()) + return -1; + int64_t displacement = Inst.Inst->getOperand(MCOpIndex).getImm(); uint64_t pcVal; |