} Kind;
SMLoc StartLoc, EndLoc;
+ SmallVector<unsigned, 8> Registers;
union {
struct {
bool Writeback;
} Reg;
- struct {
- SmallVector<unsigned, 32> *Registers;
- } RegList;
-
struct {
const MCExpr *Val;
} Imm;
case RegisterList:
case DPRRegisterList:
case SPRRegisterList:
- RegList = o.RegList;
+ Registers = o.Registers;
break;
case Immediate:
Imm = o.Imm;
break;
}
}
- ~ARMOperand() {
- if (isRegList())
- delete RegList.Registers;
- }
/// getStartLoc - Get the location of the first token of this operand.
SMLoc getStartLoc() const { return StartLoc; }
const SmallVectorImpl<unsigned> &getRegList() const {
assert((Kind == RegisterList || Kind == DPRRegisterList ||
Kind == SPRRegisterList) && "Invalid access!");
- return *RegList.Registers;
+ return Registers;
}
const MCExpr *getImm() const {
Kind = SPRRegisterList;
ARMOperand *Op = new ARMOperand(Kind);
- Op->RegList.Registers = new SmallVector<unsigned, 32>();
for (SmallVectorImpl<std::pair<unsigned, SMLoc> >::const_iterator
I = Regs.begin(), E = Regs.end(); I != E; ++I)
- Op->RegList.Registers->push_back(I->first);
- std::sort(Op->RegList.Registers->begin(), Op->RegList.Registers->end());
+ Op->Registers.push_back(I->first);
+ std::sort(Op->Registers.begin(), Op->Registers.end());
Op->StartLoc = StartLoc;
Op->EndLoc = EndLoc;
return Op;