[llvm-commits] [llvm] r119747 - /llvm/trunk/lib/Target/ARM/AsmParser/ARMAsmParser.cpp
Bill Wendling
isanbard at gmail.com
Thu Nov 18 13:50:54 PST 2010
Author: void
Date: Thu Nov 18 15:50:54 2010
New Revision: 119747
URL: http://llvm.org/viewvc/llvm-project?rev=119747&view=rev
Log:
Don't allocate the SmallVector of Registers. It gets messy figuring out who
should delete what when the object gets copied around. It's also making valgrind
upset.
Modified:
llvm/trunk/lib/Target/ARM/AsmParser/ARMAsmParser.cpp
Modified: llvm/trunk/lib/Target/ARM/AsmParser/ARMAsmParser.cpp
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/Target/ARM/AsmParser/ARMAsmParser.cpp?rev=119747&r1=119746&r2=119747&view=diff
==============================================================================
--- llvm/trunk/lib/Target/ARM/AsmParser/ARMAsmParser.cpp (original)
+++ llvm/trunk/lib/Target/ARM/AsmParser/ARMAsmParser.cpp Thu Nov 18 15:50:54 2010
@@ -113,6 +113,7 @@
} Kind;
SMLoc StartLoc, EndLoc;
+ SmallVector<unsigned, 8> Registers;
union {
struct {
@@ -130,10 +131,6 @@
} Reg;
struct {
- SmallVector<unsigned, 32> *Registers;
- } RegList;
-
- struct {
const MCExpr *Val;
} Imm;
@@ -172,7 +169,7 @@
case RegisterList:
case DPRRegisterList:
case SPRRegisterList:
- RegList = o.RegList;
+ Registers = o.Registers;
break;
case Immediate:
Imm = o.Imm;
@@ -182,10 +179,6 @@
break;
}
}
- ~ARMOperand() {
- if (isRegList())
- delete RegList.Registers;
- }
/// getStartLoc - Get the location of the first token of this operand.
SMLoc getStartLoc() const { return StartLoc; }
@@ -210,7 +203,7 @@
const SmallVectorImpl<unsigned> &getRegList() const {
assert((Kind == RegisterList || Kind == DPRRegisterList ||
Kind == SPRRegisterList) && "Invalid access!");
- return *RegList.Registers;
+ return Registers;
}
const MCExpr *getImm() const {
@@ -350,11 +343,10 @@
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;
More information about the llvm-commits
mailing list