mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-28 06:32:09 +00:00
Addrmode 1 S bit can be dynamically set. Look for CPSR def.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@56172 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
5f1db7bf31
commit
49a9f2958d
@ -56,24 +56,27 @@ namespace {
|
|||||||
|
|
||||||
private:
|
private:
|
||||||
unsigned getAddrModeNoneInstrBinary(const MachineInstr &MI,
|
unsigned getAddrModeNoneInstrBinary(const MachineInstr &MI,
|
||||||
const TargetInstrDesc &Desc,
|
const TargetInstrDesc &TID,
|
||||||
unsigned Binary);
|
unsigned Binary);
|
||||||
|
|
||||||
unsigned getMachineSoRegOpValue(const MachineInstr &MI,
|
unsigned getMachineSoRegOpValue(const MachineInstr &MI,
|
||||||
const TargetInstrDesc &Desc,
|
const TargetInstrDesc &TID,
|
||||||
unsigned OpIdx);
|
unsigned OpIdx);
|
||||||
|
|
||||||
|
unsigned getAddrMode1SBit(const MachineInstr &MI,
|
||||||
|
const TargetInstrDesc &TID) const;
|
||||||
|
|
||||||
unsigned getAddrMode1InstrBinary(const MachineInstr &MI,
|
unsigned getAddrMode1InstrBinary(const MachineInstr &MI,
|
||||||
const TargetInstrDesc &Desc,
|
const TargetInstrDesc &TID,
|
||||||
unsigned Binary);
|
unsigned Binary);
|
||||||
unsigned getAddrMode2InstrBinary(const MachineInstr &MI,
|
unsigned getAddrMode2InstrBinary(const MachineInstr &MI,
|
||||||
const TargetInstrDesc &Desc,
|
const TargetInstrDesc &TID,
|
||||||
unsigned Binary);
|
unsigned Binary);
|
||||||
unsigned getAddrMode3InstrBinary(const MachineInstr &MI,
|
unsigned getAddrMode3InstrBinary(const MachineInstr &MI,
|
||||||
const TargetInstrDesc &Desc,
|
const TargetInstrDesc &TID,
|
||||||
unsigned Binary);
|
unsigned Binary);
|
||||||
unsigned getAddrMode4InstrBinary(const MachineInstr &MI,
|
unsigned getAddrMode4InstrBinary(const MachineInstr &MI,
|
||||||
const TargetInstrDesc &Desc,
|
const TargetInstrDesc &TID,
|
||||||
unsigned Binary);
|
unsigned Binary);
|
||||||
|
|
||||||
/// getInstrBinary - Return binary encoding for the specified
|
/// getInstrBinary - Return binary encoding for the specified
|
||||||
@ -232,9 +235,9 @@ void ARMCodeEmitter::emitInstruction(const MachineInstr &MI) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
unsigned ARMCodeEmitter::getAddrModeNoneInstrBinary(const MachineInstr &MI,
|
unsigned ARMCodeEmitter::getAddrModeNoneInstrBinary(const MachineInstr &MI,
|
||||||
const TargetInstrDesc &Desc,
|
const TargetInstrDesc &TID,
|
||||||
unsigned Binary) {
|
unsigned Binary) {
|
||||||
switch (Desc.TSFlags & ARMII::FormMask) {
|
switch (TID.TSFlags & ARMII::FormMask) {
|
||||||
default:
|
default:
|
||||||
assert(0 && "Unknown instruction subtype!");
|
assert(0 && "Unknown instruction subtype!");
|
||||||
break;
|
break;
|
||||||
@ -243,7 +246,7 @@ unsigned ARMCodeEmitter::getAddrModeNoneInstrBinary(const MachineInstr &MI,
|
|||||||
Binary |= getMachineOpValue(MI, 0);
|
Binary |= getMachineOpValue(MI, 0);
|
||||||
|
|
||||||
// if it is a conditional branch, set cond field
|
// if it is a conditional branch, set cond field
|
||||||
if (Desc.Opcode == ARM::Bcc) {
|
if (TID.Opcode == ARM::Bcc) {
|
||||||
Binary &= 0x0FFFFFFF; // clear conditional field
|
Binary &= 0x0FFFFFFF; // clear conditional field
|
||||||
Binary |= getMachineOpValue(MI, 1) << 28; // set conditional field
|
Binary |= getMachineOpValue(MI, 1) << 28; // set conditional field
|
||||||
}
|
}
|
||||||
@ -252,7 +255,7 @@ unsigned ARMCodeEmitter::getAddrModeNoneInstrBinary(const MachineInstr &MI,
|
|||||||
case ARMII::BranchMisc: {
|
case ARMII::BranchMisc: {
|
||||||
// Set bit[19:8] to 0xFFF
|
// Set bit[19:8] to 0xFFF
|
||||||
Binary |= 0xfff << 8;
|
Binary |= 0xfff << 8;
|
||||||
if (Desc.Opcode == ARM::BX_RET)
|
if (TID.Opcode == ARM::BX_RET)
|
||||||
Binary |= 0xe; // the return register is LR
|
Binary |= 0xe; // the return register is LR
|
||||||
else
|
else
|
||||||
// otherwise, set the return register
|
// otherwise, set the return register
|
||||||
@ -265,7 +268,7 @@ unsigned ARMCodeEmitter::getAddrModeNoneInstrBinary(const MachineInstr &MI,
|
|||||||
}
|
}
|
||||||
|
|
||||||
unsigned ARMCodeEmitter::getMachineSoRegOpValue(const MachineInstr &MI,
|
unsigned ARMCodeEmitter::getMachineSoRegOpValue(const MachineInstr &MI,
|
||||||
const TargetInstrDesc &Desc,
|
const TargetInstrDesc &TID,
|
||||||
unsigned OpIdx) {
|
unsigned OpIdx) {
|
||||||
// Set last operand (register Rm)
|
// Set last operand (register Rm)
|
||||||
unsigned Binary = getMachineOpValue(MI, OpIdx);
|
unsigned Binary = getMachineOpValue(MI, OpIdx);
|
||||||
@ -322,14 +325,27 @@ unsigned ARMCodeEmitter::getMachineSoRegOpValue(const MachineInstr &MI,
|
|||||||
return Binary | ARM_AM::getSORegOffset(MO2.getImm()) << 7;
|
return Binary | ARM_AM::getSORegOffset(MO2.getImm()) << 7;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
unsigned ARMCodeEmitter::getAddrMode1SBit(const MachineInstr &MI,
|
||||||
|
const TargetInstrDesc &TID) const {
|
||||||
|
for (unsigned i = MI.getNumOperands(), e = TID.getNumOperands(); i != e; --i){
|
||||||
|
const MachineOperand &MO = MI.getOperand(i-1);
|
||||||
|
if (MO.isRegister() && MO.isDef() && MO.getReg() == ARM::CPSR)
|
||||||
|
return 1 << ARMII::S_BitShift;
|
||||||
|
}
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
unsigned ARMCodeEmitter::getAddrMode1InstrBinary(const MachineInstr &MI,
|
unsigned ARMCodeEmitter::getAddrMode1InstrBinary(const MachineInstr &MI,
|
||||||
const TargetInstrDesc &Desc,
|
const TargetInstrDesc &TID,
|
||||||
unsigned Binary) {
|
unsigned Binary) {
|
||||||
if (MI.getOpcode() == ARM::MOVi2pieces)
|
if (MI.getOpcode() == ARM::MOVi2pieces)
|
||||||
// FIXME.
|
// FIXME.
|
||||||
abort();
|
abort();
|
||||||
|
|
||||||
unsigned Format = Desc.TSFlags & ARMII::FormMask;
|
// Encode S bit if MI modifies CPSR.
|
||||||
|
Binary |= getAddrMode1SBit(MI, TID);
|
||||||
|
|
||||||
|
unsigned Format = TID.TSFlags & ARMII::FormMask;
|
||||||
// FIXME: Consolidate into a single bit.
|
// FIXME: Consolidate into a single bit.
|
||||||
bool isUnary = (Format == ARMII::DPRdMisc ||
|
bool isUnary = (Format == ARMII::DPRdMisc ||
|
||||||
Format == ARMII::DPRdIm ||
|
Format == ARMII::DPRdIm ||
|
||||||
@ -342,7 +358,7 @@ unsigned ARMCodeEmitter::getAddrMode1InstrBinary(const MachineInstr &MI,
|
|||||||
unsigned OpIdx = 0;
|
unsigned OpIdx = 0;
|
||||||
|
|
||||||
// Encode register def if there is one.
|
// Encode register def if there is one.
|
||||||
unsigned NumDefs = Desc.getNumDefs();
|
unsigned NumDefs = TID.getNumDefs();
|
||||||
if (NumDefs) {
|
if (NumDefs) {
|
||||||
Binary |= getMachineOpValue(MI, OpIdx) << ARMII::RegRdShift;
|
Binary |= getMachineOpValue(MI, OpIdx) << ARMII::RegRdShift;
|
||||||
++OpIdx;
|
++OpIdx;
|
||||||
@ -355,9 +371,9 @@ unsigned ARMCodeEmitter::getAddrMode1InstrBinary(const MachineInstr &MI,
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Encode shifter operand.
|
// Encode shifter operand.
|
||||||
if (Desc.getNumOperands() - OpIdx > 1)
|
if (TID.getNumOperands() - OpIdx > 1)
|
||||||
// Encode SoReg.
|
// Encode SoReg.
|
||||||
return Binary | getMachineSoRegOpValue(MI, Desc, OpIdx);
|
return Binary | getMachineSoRegOpValue(MI, TID, OpIdx);
|
||||||
|
|
||||||
const MachineOperand &MO = MI.getOperand(OpIdx);
|
const MachineOperand &MO = MI.getOperand(OpIdx);
|
||||||
if (MO.isRegister())
|
if (MO.isRegister())
|
||||||
@ -376,7 +392,7 @@ unsigned ARMCodeEmitter::getAddrMode1InstrBinary(const MachineInstr &MI,
|
|||||||
}
|
}
|
||||||
|
|
||||||
unsigned ARMCodeEmitter::getAddrMode2InstrBinary(const MachineInstr &MI,
|
unsigned ARMCodeEmitter::getAddrMode2InstrBinary(const MachineInstr &MI,
|
||||||
const TargetInstrDesc &Desc,
|
const TargetInstrDesc &TID,
|
||||||
unsigned Binary) {
|
unsigned Binary) {
|
||||||
// Set first operand
|
// Set first operand
|
||||||
Binary |= getMachineOpValue(MI, 0) << ARMII::RegRdShift;
|
Binary |= getMachineOpValue(MI, 0) << ARMII::RegRdShift;
|
||||||
@ -414,7 +430,7 @@ unsigned ARMCodeEmitter::getAddrMode2InstrBinary(const MachineInstr &MI,
|
|||||||
}
|
}
|
||||||
|
|
||||||
unsigned ARMCodeEmitter::getAddrMode3InstrBinary(const MachineInstr &MI,
|
unsigned ARMCodeEmitter::getAddrMode3InstrBinary(const MachineInstr &MI,
|
||||||
const TargetInstrDesc &Desc,
|
const TargetInstrDesc &TID,
|
||||||
unsigned Binary) {
|
unsigned Binary) {
|
||||||
// Set first operand
|
// Set first operand
|
||||||
Binary |= getMachineOpValue(MI, 0) << ARMII::RegRdShift;
|
Binary |= getMachineOpValue(MI, 0) << ARMII::RegRdShift;
|
||||||
@ -448,7 +464,7 @@ unsigned ARMCodeEmitter::getAddrMode3InstrBinary(const MachineInstr &MI,
|
|||||||
}
|
}
|
||||||
|
|
||||||
unsigned ARMCodeEmitter::getAddrMode4InstrBinary(const MachineInstr &MI,
|
unsigned ARMCodeEmitter::getAddrMode4InstrBinary(const MachineInstr &MI,
|
||||||
const TargetInstrDesc &Desc,
|
const TargetInstrDesc &TID,
|
||||||
unsigned Binary) {
|
unsigned Binary) {
|
||||||
// Set first operand
|
// Set first operand
|
||||||
Binary |= getMachineOpValue(MI, 0) << ARMII::RegRnShift;
|
Binary |= getMachineOpValue(MI, 0) << ARMII::RegRnShift;
|
||||||
@ -492,18 +508,18 @@ unsigned ARMCodeEmitter::getInstrBinary(const MachineInstr &MI) {
|
|||||||
// Part of binary is determined by TableGn.
|
// Part of binary is determined by TableGn.
|
||||||
unsigned Binary = getBinaryCodeForInstr(MI);
|
unsigned Binary = getBinaryCodeForInstr(MI);
|
||||||
|
|
||||||
const TargetInstrDesc &Desc = MI.getDesc();
|
const TargetInstrDesc &TID = MI.getDesc();
|
||||||
switch (Desc.TSFlags & ARMII::AddrModeMask) {
|
switch (TID.TSFlags & ARMII::AddrModeMask) {
|
||||||
case ARMII::AddrModeNone:
|
case ARMII::AddrModeNone:
|
||||||
return getAddrModeNoneInstrBinary(MI, Desc, Binary);
|
return getAddrModeNoneInstrBinary(MI, TID, Binary);
|
||||||
case ARMII::AddrMode1:
|
case ARMII::AddrMode1:
|
||||||
return getAddrMode1InstrBinary(MI, Desc, Binary);
|
return getAddrMode1InstrBinary(MI, TID, Binary);
|
||||||
case ARMII::AddrMode2:
|
case ARMII::AddrMode2:
|
||||||
return getAddrMode2InstrBinary(MI, Desc, Binary);
|
return getAddrMode2InstrBinary(MI, TID, Binary);
|
||||||
case ARMII::AddrMode3:
|
case ARMII::AddrMode3:
|
||||||
return getAddrMode3InstrBinary(MI, Desc, Binary);
|
return getAddrMode3InstrBinary(MI, TID, Binary);
|
||||||
case ARMII::AddrMode4:
|
case ARMII::AddrMode4:
|
||||||
return getAddrMode4InstrBinary(MI, Desc, Binary);
|
return getAddrMode4InstrBinary(MI, TID, Binary);
|
||||||
}
|
}
|
||||||
|
|
||||||
abort();
|
abort();
|
||||||
|
@ -218,7 +218,6 @@ class AsI1<bits<4> opcod, dag oops, dag iops, Format f, string opc,
|
|||||||
string asm, list<dag> pattern>
|
string asm, list<dag> pattern>
|
||||||
: sI<opcod, oops, iops, AddrMode1, Size4Bytes, IndexModeNone, f, opc,
|
: sI<opcod, oops, iops, AddrMode1, Size4Bytes, IndexModeNone, f, opc,
|
||||||
asm, "", pattern> {
|
asm, "", pattern> {
|
||||||
let Inst{20} = 1;
|
|
||||||
let Inst{21-24} = opcod;
|
let Inst{21-24} = opcod;
|
||||||
let Inst{26-27} = 0;
|
let Inst{26-27} = 0;
|
||||||
}
|
}
|
||||||
@ -226,7 +225,6 @@ class AXI1<bits<4> opcod, dag oops, dag iops, Format f, string asm,
|
|||||||
list<dag> pattern>
|
list<dag> pattern>
|
||||||
: XI<opcod, oops, iops, AddrMode1, Size4Bytes, IndexModeNone, f, asm,
|
: XI<opcod, oops, iops, AddrMode1, Size4Bytes, IndexModeNone, f, asm,
|
||||||
"", pattern> {
|
"", pattern> {
|
||||||
let Inst{20} = 1;
|
|
||||||
let Inst{21-24} = opcod;
|
let Inst{21-24} = opcod;
|
||||||
let Inst{26-27} = 0;
|
let Inst{26-27} = 0;
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user