ARM assemly parsing and validation of IT instruction.

"Although a Thumb2 instruction, the IT mnemonic shall be permitted in
ARM mode, and the condition verified to match the condition code(s)
on the following instruction(s)."

PR11853

llvm-svn: 148969
This commit is contained in:
Jim Grosbach 2012-01-25 19:52:01 +00:00
parent 113cf60e0b
commit 82f76d1275
3 changed files with 25 additions and 3 deletions

View File

@ -5179,3 +5179,7 @@ def : ARMInstAlias<"mul${s}${p} $Rn, $Rm",
// "neg" is and alias for "rsb rd, rn, #0" // "neg" is and alias for "rsb rd, rn, #0"
def : ARMInstAlias<"neg${s}${p} $Rd, $Rm", def : ARMInstAlias<"neg${s}${p} $Rd, $Rm",
(RSBri GPR:$Rd, GPR:$Rm, 0, pred:$p, cc_out:$s)>; (RSBri GPR:$Rd, GPR:$Rm, 0, pred:$p, cc_out:$s)>;
// 'it' blocks in ARM mode just validate the predicates. The IT itself
// is discarded.
def ITasm : ARMAsmPseudo<"it$mask $cc", (ins it_pred:$cc, it_mask:$mask)>;

View File

@ -5080,10 +5080,11 @@ validateInstruction(MCInst &Inst,
const MCInstrDesc &MCID = getInstDesc(Inst.getOpcode()); const MCInstrDesc &MCID = getInstDesc(Inst.getOpcode());
SMLoc Loc = Operands[0]->getStartLoc(); SMLoc Loc = Operands[0]->getStartLoc();
// Check the IT block state first. // Check the IT block state first.
// NOTE: In Thumb mode, the BKPT instruction has the interesting property of // NOTE: BKPT instruction has the interesting property of being
// being allowed in IT blocks, but not being predicable. It just always // allowed in IT blocks, but not being predicable. It just always
// executes. // executes.
if (inITBlock() && Inst.getOpcode() != ARM::tBKPT) { if (inITBlock() && Inst.getOpcode() != ARM::tBKPT &&
Inst.getOpcode() != ARM::BKPT) {
unsigned bit = 1; unsigned bit = 1;
if (ITState.FirstCond) if (ITState.FirstCond)
ITState.FirstCond = false; ITState.FirstCond = false;
@ -7048,6 +7049,7 @@ processInstruction(MCInst &Inst,
} }
return false; return false;
} }
case ARM::ITasm:
case ARM::t2IT: { case ARM::t2IT: {
// The mask bits for all but the first condition are represented as // The mask bits for all but the first condition are represented as
// the low bit of the condition code value implies 't'. We currently // the low bit of the condition code value implies 't'. We currently
@ -7154,6 +7156,11 @@ MatchAndEmitInstruction(SMLoc IDLoc,
// block. // block.
forwardITPosition(); forwardITPosition();
// ITasm is an ARM mode pseudo-instruction that just sets the ITblock and
// doesn't actually encode.
if (Inst.getOpcode() == ARM::ITasm)
return false;
Out.EmitInstruction(Inst); Out.EmitInstruction(Inst);
return false; return false;
case Match_MissingFeature: case Match_MissingFeature:

View File

@ -0,0 +1,11 @@
@ RUN: llvm-mc -triple=armv7-apple-darwin -show-encoding < %s | FileCheck %s
.syntax unified
.globl _func
_func:
@ CHECK: _func:
it eq
moveq r2, r3
@ 'it' is parsed but not encoded.
@ CHECK-NOT: it
@ CHECK: moveq r2, r3 @ encoding: [0x03,0x20,0xa0,0x01]