mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2025-01-03 09:28:58 +00:00
Encode the register list operands for ARM mode LDM/STM instructions.
llvm-svn: 117753
This commit is contained in:
parent
b68e0d0ee3
commit
996d1280bd
@ -197,6 +197,9 @@ namespace {
|
||||
unsigned getNEONVcvtImm32OpValue(const MachineInstr &MI, unsigned Op)
|
||||
const { return 0; }
|
||||
|
||||
unsigned getRegisterListOpValue(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
|
||||
/// zero.
|
||||
|
@ -937,17 +937,21 @@ class AXI4ld<dag oops, dag iops, IndexMode im, Format f, InstrItinClass itin,
|
||||
string asm, string cstr, list<dag> pattern>
|
||||
: XI<oops, iops, AddrMode4, Size4Bytes, im, f, itin,
|
||||
asm, cstr, pattern> {
|
||||
bits<16> dsts;
|
||||
let Inst{20} = 1; // L bit
|
||||
let Inst{22} = 0; // S bit
|
||||
let Inst{27-25} = 0b100;
|
||||
let Inst{15-0} = dsts;
|
||||
}
|
||||
class AXI4st<dag oops, dag iops, IndexMode im, Format f, InstrItinClass itin,
|
||||
string asm, string cstr, list<dag> pattern>
|
||||
: XI<oops, iops, AddrMode4, Size4Bytes, im, f, itin,
|
||||
asm, cstr, pattern> {
|
||||
bits<16> srcs;
|
||||
let Inst{20} = 0; // L bit
|
||||
let Inst{22} = 0; // S bit
|
||||
let Inst{27-25} = 0b100;
|
||||
let Inst{15-0} = srcs;
|
||||
}
|
||||
|
||||
// Unsigned multiply, multiply-accumulate instructions.
|
||||
|
@ -279,6 +279,7 @@ def brtarget : Operand<OtherVT>;
|
||||
|
||||
// A list of registers separated by comma. Used by load/store multiple.
|
||||
def reglist : Operand<i32> {
|
||||
string EncoderMethod = "getRegisterListOpValue";
|
||||
let PrintMethod = "printRegisterList";
|
||||
}
|
||||
|
||||
|
@ -98,6 +98,9 @@ public:
|
||||
|
||||
unsigned getBitfieldInvertedMaskOpValue(const MCInst &MI, unsigned Op) const;
|
||||
|
||||
unsigned getRegisterListOpValue(const MCInst &MI, unsigned Op) const;
|
||||
|
||||
|
||||
unsigned getNumFixupKinds() const {
|
||||
assert(0 && "ARMMCCodeEmitter::getNumFixupKinds() not yet implemented.");
|
||||
return 0;
|
||||
@ -285,6 +288,18 @@ unsigned ARMMCCodeEmitter::getBitfieldInvertedMaskOpValue(const MCInst &MI,
|
||||
return lsb | (msb << 5);
|
||||
}
|
||||
|
||||
unsigned ARMMCCodeEmitter::getRegisterListOpValue(const MCInst &MI,
|
||||
unsigned Op) const {
|
||||
// Convert a list of GPRs into a bitfield (R0 -> bit 0). For each
|
||||
// register in the list, set the corresponding bit.
|
||||
unsigned Binary = 0;
|
||||
for (unsigned i = Op; i < MI.getNumOperands(); ++i) {
|
||||
unsigned regno = getARMRegisterNumbering(MI.getOperand(i).getReg());
|
||||
Binary |= 1 << regno;
|
||||
}
|
||||
return Binary;
|
||||
}
|
||||
|
||||
void ARMMCCodeEmitter::
|
||||
EncodeInstruction(const MCInst &MI, raw_ostream &OS,
|
||||
SmallVectorImpl<MCFixup> &Fixups) const {
|
||||
|
Loading…
Reference in New Issue
Block a user