mirror of
https://github.com/RPCSX/llvm.git
synced 2025-01-26 14:25:18 +00:00
Fix the arm's disassembler for blx that was building an MCInst without the
needed two predicate operands before the imm operand. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@126662 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
c24ab5c654
commit
d436d5b1c9
@ -1719,6 +1719,17 @@ static bool DisassembleThumb2BrMiscCtrl(MCInst &MI, unsigned Opcode,
|
||||
return true;
|
||||
}
|
||||
|
||||
// Some instructions have predicate operands first before the immediate.
|
||||
if(Opcode == ARM::tBLXi_r9 || Opcode == ARM::tBLr9) {
|
||||
// Handling the two predicate operands before the imm operand.
|
||||
if (B->DoPredicateOperands(MI, Opcode, insn, NumOps))
|
||||
NumOpsAdded += 2;
|
||||
else {
|
||||
DEBUG(errs() << "Expected predicate operands not found.\n");
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
||||
// Add the imm operand.
|
||||
int Offset = 0;
|
||||
|
||||
@ -1745,7 +1756,8 @@ static bool DisassembleThumb2BrMiscCtrl(MCInst &MI, unsigned Opcode,
|
||||
// to compensate.
|
||||
MI.addOperand(MCOperand::CreateImm(Offset + 4));
|
||||
|
||||
NumOpsAdded = 1;
|
||||
// This is an increment as some predicate operands may have been added first.
|
||||
NumOpsAdded += 1;
|
||||
|
||||
return true;
|
||||
}
|
||||
|
@ -118,3 +118,6 @@
|
||||
|
||||
# CHECK: msr cpsr_fc, r0
|
||||
0x80 0xf3 0x00 0x89
|
||||
|
||||
# CHECK: blx #0
|
||||
0xff 0xf7 0xfe 0xef
|
||||
|
Loading…
x
Reference in New Issue
Block a user