mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-07 11:33:44 +00:00
Move the ARM so_imm encoding into a custom operand encoder and remove the
explicit handling of the instructions referencing it from the MC code emitter. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@116367 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
c14b80f6d3
commit
2a6a93d542
@ -166,6 +166,8 @@ namespace {
|
||||
// far along that this one can be eliminated entirely.
|
||||
unsigned getCCOutOpValue(const MachineInstr &MI, unsigned Op)
|
||||
const { return 0; }
|
||||
unsigned getSOImmOpValue(const MachineInstr &MI, unsigned Op)
|
||||
const { return 0; }
|
||||
|
||||
/// getMovi32Value - Return binary encoding of operand for movw/movt. If the
|
||||
/// machine operand requires relocation, record the relocation and return
|
||||
|
@ -323,6 +323,7 @@ def so_reg : Operand<i32>, // reg reg imm
|
||||
// into so_imm instructions: the 8-bit immediate is the least significant bits
|
||||
// [bits 0-7], the 4-bit shift amount is the next 4 bits [bits 8-11].
|
||||
def so_imm : Operand<i32>, PatLeaf<(imm), [{ return Pred_so_imm(N); }]> {
|
||||
string EncoderMethod = "getSOImmOpValue";
|
||||
let PrintMethod = "printSOImmOperand";
|
||||
}
|
||||
|
||||
@ -477,9 +478,11 @@ multiclass AsI1_bin_irs<bits<4> opcod, string opc,
|
||||
[(set GPR:$Rd, (opnode GPR:$Rn, so_imm:$imm))]> {
|
||||
bits<4> Rd;
|
||||
bits<4> Rn;
|
||||
bits<12> imm;
|
||||
let Inst{25} = 1;
|
||||
let Inst{15-12} = Rd;
|
||||
let Inst{19-16} = Rn;
|
||||
let Inst{11-0} = imm;
|
||||
}
|
||||
}
|
||||
def rr : AsI1<opcod, (outs GPR:$Rd), (ins GPR:$Rn, GPR:$Rm), DPFrm,
|
||||
@ -1544,12 +1547,14 @@ def MOVs : AsI1<0b1101, (outs GPR:$Rd), (ins so_reg:$src),
|
||||
}
|
||||
|
||||
let isReMaterializable = 1, isAsCheapAsAMove = 1 in
|
||||
def MOVi : AsI1<0b1101, (outs GPR:$dst), (ins so_imm:$src), DPFrm, IIC_iMOVi,
|
||||
"mov", "\t$dst, $src", [(set GPR:$dst, so_imm:$src)]>, UnaryDP {
|
||||
def MOVi : AsI1<0b1101, (outs GPR:$Rd), (ins so_imm:$imm), DPFrm, IIC_iMOVi,
|
||||
"mov", "\t$Rd, $imm", [(set GPR:$Rd, so_imm:$imm)]>, UnaryDP {
|
||||
bits<4> Rd;
|
||||
bits<12> imm;
|
||||
let Inst{25} = 1;
|
||||
let Inst{15-12} = Rd;
|
||||
let Inst{19-16} = 0b0000;
|
||||
let Inst{11-0} = imm;
|
||||
}
|
||||
|
||||
let isReMaterializable = 1, isAsCheapAsAMove = 1 in
|
||||
|
@ -55,6 +55,20 @@ public:
|
||||
// '1' respectively.
|
||||
return MI.getOperand(Op).getReg() == ARM::CPSR;
|
||||
}
|
||||
/// getSOImmOpValue - Return an encoded 12-bit shifted-immediate value.
|
||||
unsigned getSOImmOpValue(const MCInst &MI, unsigned Op) const {
|
||||
unsigned SoImm = MI.getOperand(Op).getImm();
|
||||
int SoImmVal = ARM_AM::getSOImmVal(SoImm);
|
||||
assert(SoImmVal != -1 && "Not a valid so_imm value!");
|
||||
|
||||
// Encode rotate_imm.
|
||||
unsigned Binary = (ARM_AM::getSOImmValRot((unsigned)SoImmVal) >> 1)
|
||||
<< ARMII::SoRotImmShift;
|
||||
|
||||
// Encode immed_8.
|
||||
Binary |= ARM_AM::getSOImmValImm((unsigned)SoImmVal);
|
||||
return Binary;
|
||||
}
|
||||
|
||||
unsigned getNumFixupKinds() const {
|
||||
assert(0 && "ARMMCCodeEmitter::getNumFixupKinds() not yet implemented.");
|
||||
@ -93,19 +107,6 @@ public:
|
||||
|
||||
} // end anonymous namespace
|
||||
|
||||
unsigned ARMMCCodeEmitter::getMachineSoImmOpValue(unsigned SoImm) const {
|
||||
int SoImmVal = ARM_AM::getSOImmVal(SoImm);
|
||||
assert(SoImmVal != -1 && "Not a valid so_imm value!");
|
||||
|
||||
// Encode rotate_imm.
|
||||
unsigned Binary = (ARM_AM::getSOImmValRot((unsigned)SoImmVal) >> 1)
|
||||
<< ARMII::SoRotImmShift;
|
||||
|
||||
// Encode immed_8.
|
||||
Binary |= ARM_AM::getSOImmValImm((unsigned)SoImmVal);
|
||||
return Binary;
|
||||
}
|
||||
|
||||
MCCodeEmitter *llvm::createARMMCCodeEmitter(const Target &,
|
||||
TargetMachine &TM,
|
||||
MCContext &Ctx) {
|
||||
@ -157,19 +158,6 @@ EncodeInstruction(const MCInst &MI, raw_ostream &OS,
|
||||
unsigned Value = getBinaryCodeForInstr(MI);
|
||||
switch (Opcode) {
|
||||
default: break;
|
||||
case ARM::MOVi:
|
||||
// The shifted immediate value.
|
||||
Value |= getMachineSoImmOpValue((unsigned)MI.getOperand(1).getImm());
|
||||
break;
|
||||
case ARM::ADDri:
|
||||
case ARM::ANDri:
|
||||
case ARM::BICri:
|
||||
case ARM::EORri:
|
||||
case ARM::ORRri:
|
||||
case ARM::SUBri:
|
||||
// The shifted immediate value.
|
||||
Value |= getMachineSoImmOpValue((unsigned)MI.getOperand(2).getImm());
|
||||
break;
|
||||
case ARM::ADDrs:
|
||||
case ARM::ANDrs:
|
||||
case ARM::BICrs:
|
||||
|
Loading…
Reference in New Issue
Block a user