forked from OSchip/llvm-project
Check for unallocated instruction encodings when disassembling Thumb Branch instructions (tBcc and t2Bcc).
rdar://problem/9280470 llvm-svn: 129471
This commit is contained in:
parent
5d3e822926
commit
b6a37bff21
|
@ -3625,11 +3625,17 @@ bool ARMBasicMCBuilder::TryPredicateAndSBitModifier(MCInst& MI, unsigned Opcode,
|
|||
// like ARM.
|
||||
//
|
||||
// A8.6.16 B
|
||||
if (Name == "t2Bcc")
|
||||
MI.addOperand(MCOperand::CreateImm(CondCode(slice(insn, 25, 22))));
|
||||
else if (Name == "tBcc")
|
||||
MI.addOperand(MCOperand::CreateImm(CondCode(slice(insn, 11, 8))));
|
||||
else
|
||||
// Check for undefined encodings.
|
||||
unsigned cond;
|
||||
if (Name == "t2Bcc") {
|
||||
if ((cond = slice(insn, 25, 22)) >= 14)
|
||||
return false;
|
||||
MI.addOperand(MCOperand::CreateImm(CondCode(cond)));
|
||||
} else if (Name == "tBcc") {
|
||||
if ((cond = slice(insn, 11, 8)) == 14)
|
||||
return false;
|
||||
MI.addOperand(MCOperand::CreateImm(CondCode(cond)));
|
||||
} else
|
||||
MI.addOperand(MCOperand::CreateImm(ARMCC::AL));
|
||||
} else {
|
||||
// ARM instructions get their condition field from Inst{31-28}.
|
||||
|
|
|
@ -0,0 +1,11 @@
|
|||
# RUN: llvm-mc --disassemble %s -triple=thumb-apple-darwin9 |& grep {invalid instruction encoding}
|
||||
|
||||
# Opcode=1894 Name=t2Bcc Format=ARM_FORMAT_THUMBFRM(25)
|
||||
# 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0
|
||||
# -------------------------------------------------------------------------------------------------
|
||||
# | 1: 1: 1: 1| 0: 1: 1: 1| 1: 0: 1: 0| 1: 1: 1: 1| 1: 0: 0: 0| 1: 0: 1: 1| 0: 1: 0: 0| 0: 1: 0: 0|
|
||||
# -------------------------------------------------------------------------------------------------
|
||||
#
|
||||
# A8.6.16 B
|
||||
# if cond<3:1> == '111' then SEE "Related Encodings"
|
||||
0xaf 0xf7 0x44 0x8b
|
|
@ -9,8 +9,8 @@
|
|||
# CHECK: b #30
|
||||
0x0f 0xe0
|
||||
|
||||
# CHECK: b.w #-16
|
||||
0xff 0xf7 0xf8 0xaf
|
||||
# CHECK: bgt.w #-16
|
||||
0x3f 0xf7 0xf8 0xaf
|
||||
|
||||
# CHECK: bfi r2, r10, #0, #1
|
||||
0x6a 0xf3 0x00 0x02
|
||||
|
|
Loading…
Reference in New Issue