mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-09-27 00:21:03 +00:00
Add Thumb2 alias for "mov Rd, #imm" to "mvn Rd, #~imm".
When '~imm' is encodable as a t2_so_imm but plain 'imm' is not. For example, mov r2, #-3 becomes mvn r2, #2 rdar://10349224 git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@143235 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
@@ -76,10 +76,16 @@ def t2_so_imm : Operand<i32>, ImmLeaf<i32, [{
|
|||||||
|
|
||||||
// t2_so_imm_not - Match an immediate that is a complement
|
// t2_so_imm_not - Match an immediate that is a complement
|
||||||
// of a t2_so_imm.
|
// of a t2_so_imm.
|
||||||
|
// Note: this pattern doesn't require an encoder method and such, as it's
|
||||||
|
// only used on aliases (Pat<> and InstAlias<>). The actual encoding
|
||||||
|
// is handled by the destination instructions, which use t2_so_imm.
|
||||||
|
def t2_so_imm_not_asmoperand : AsmOperandClass { let Name = "T2SOImmNot"; }
|
||||||
def t2_so_imm_not : Operand<i32>,
|
def t2_so_imm_not : Operand<i32>,
|
||||||
PatLeaf<(imm), [{
|
PatLeaf<(imm), [{
|
||||||
return ARM_AM::getT2SOImmVal(~((uint32_t)N->getZExtValue())) != -1;
|
return ARM_AM::getT2SOImmVal(~((uint32_t)N->getZExtValue())) != -1;
|
||||||
}], t2_so_imm_not_XFORM>;
|
}], t2_so_imm_not_XFORM> {
|
||||||
|
let ParserMatchClass = t2_so_imm_not_asmoperand;
|
||||||
|
}
|
||||||
|
|
||||||
// t2_so_imm_neg - Match an immediate that is a negation of a t2_so_imm.
|
// t2_so_imm_neg - Match an immediate that is a negation of a t2_so_imm.
|
||||||
def t2_so_imm_neg : Operand<i32>,
|
def t2_so_imm_neg : Operand<i32>,
|
||||||
@@ -4066,3 +4072,9 @@ def : t2InstAlias<"sxtb16${p} $Rd, $Rm$rot",
|
|||||||
(t2SXTB16 rGPR:$Rd, rGPR:$Rm, rot_imm:$rot, pred:$p)>;
|
(t2SXTB16 rGPR:$Rd, rGPR:$Rm, rot_imm:$rot, pred:$p)>;
|
||||||
def : t2InstAlias<"sxth${p} $Rd, $Rm$rot",
|
def : t2InstAlias<"sxth${p} $Rd, $Rm$rot",
|
||||||
(t2SXTH rGPR:$Rd, rGPR:$Rm, rot_imm:$rot, pred:$p)>;
|
(t2SXTH rGPR:$Rd, rGPR:$Rm, rot_imm:$rot, pred:$p)>;
|
||||||
|
|
||||||
|
|
||||||
|
// "mov Rd, t2_so_imm_not" can be handled via "mvn" in assembly, just like
|
||||||
|
// for isel.
|
||||||
|
def : t2InstAlias<"mov${p} $Rd, $imm",
|
||||||
|
(t2MVNi rGPR:$Rd, t2_so_imm_not:$imm, pred:$p, zero_reg)>;
|
||||||
|
@@ -665,6 +665,14 @@ public:
|
|||||||
int64_t Value = CE->getValue();
|
int64_t Value = CE->getValue();
|
||||||
return ARM_AM::getT2SOImmVal(Value) != -1;
|
return ARM_AM::getT2SOImmVal(Value) != -1;
|
||||||
}
|
}
|
||||||
|
bool isT2SOImmNot() const {
|
||||||
|
if (Kind != k_Immediate)
|
||||||
|
return false;
|
||||||
|
const MCConstantExpr *CE = dyn_cast<MCConstantExpr>(getImm());
|
||||||
|
if (!CE) return false;
|
||||||
|
int64_t Value = CE->getValue();
|
||||||
|
return ARM_AM::getT2SOImmVal(~Value) != -1;
|
||||||
|
}
|
||||||
bool isSetEndImm() const {
|
bool isSetEndImm() const {
|
||||||
if (Kind != k_Immediate)
|
if (Kind != k_Immediate)
|
||||||
return false;
|
return false;
|
||||||
@@ -1241,6 +1249,14 @@ public:
|
|||||||
addExpr(Inst, getImm());
|
addExpr(Inst, getImm());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void addT2SOImmNotOperands(MCInst &Inst, unsigned N) const {
|
||||||
|
assert(N == 1 && "Invalid number of operands!");
|
||||||
|
// The operand is actually a t2_so_imm, but we have its bitwise
|
||||||
|
// negation in the assembly source, so twiddle it here.
|
||||||
|
const MCConstantExpr *CE = dyn_cast<MCConstantExpr>(getImm());
|
||||||
|
Inst.addOperand(MCOperand::CreateImm(~CE->getValue()));
|
||||||
|
}
|
||||||
|
|
||||||
void addSetEndImmOperands(MCInst &Inst, unsigned N) const {
|
void addSetEndImmOperands(MCInst &Inst, unsigned N) const {
|
||||||
assert(N == 1 && "Invalid number of operands!");
|
assert(N == 1 && "Invalid number of operands!");
|
||||||
addExpr(Inst, getImm());
|
addExpr(Inst, getImm());
|
||||||
|
@@ -1118,6 +1118,10 @@ _func:
|
|||||||
movne.w r1, #12
|
movne.w r1, #12
|
||||||
mov.w r6, #450
|
mov.w r6, #450
|
||||||
|
|
||||||
|
@ alias for mvn
|
||||||
|
mov r3, #-3
|
||||||
|
|
||||||
|
|
||||||
@ CHECK: movs r1, #21 @ encoding: [0x15,0x21]
|
@ CHECK: movs r1, #21 @ encoding: [0x15,0x21]
|
||||||
@ CHECK: movs.w r1, #21 @ encoding: [0x5f,0xf0,0x15,0x01]
|
@ CHECK: movs.w r1, #21 @ encoding: [0x5f,0xf0,0x15,0x01]
|
||||||
@ CHECK: movs.w r8, #21 @ encoding: [0x5f,0xf0,0x15,0x08]
|
@ CHECK: movs.w r8, #21 @ encoding: [0x5f,0xf0,0x15,0x08]
|
||||||
@@ -1133,6 +1137,9 @@ _func:
|
|||||||
@ CHECK: movne.w r1, #12 @ encoding: [0x4f,0xf0,0x0c,0x01]
|
@ CHECK: movne.w r1, #12 @ encoding: [0x4f,0xf0,0x0c,0x01]
|
||||||
@ CHECK: mov.w r6, #450 @ encoding: [0x4f,0xf4,0xe1,0x76]
|
@ CHECK: mov.w r6, #450 @ encoding: [0x4f,0xf4,0xe1,0x76]
|
||||||
|
|
||||||
|
@ CHECK: mvn r3, #2 @ encoding: [0x6f,0xf0,0x02,0x03]
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
@------------------------------------------------------------------------------
|
@------------------------------------------------------------------------------
|
||||||
@ MOVT
|
@ MOVT
|
||||||
|
Reference in New Issue
Block a user