diff options
author | Chris Lattner <sabre@nondot.org> | 2003-10-09 20:45:42 +0000 |
---|---|---|
committer | Chris Lattner <sabre@nondot.org> | 2003-10-09 20:45:42 +0000 |
commit | 819ce2dca1b9e7e02093331c67cd90ba00f0bea8 (patch) | |
tree | dd3647306231fdcba6554fffbb95dee0bb38d72d /llvm/lib | |
parent | c6ba9de7b7c1cdb12a79edd72f24337848bfeee3 (diff) | |
download | bcm5719-llvm-819ce2dca1b9e7e02093331c67cd90ba00f0bea8.tar.gz bcm5719-llvm-819ce2dca1b9e7e02093331c67cd90ba00f0bea8.zip |
Pass a vector around to reduce dynamic allocation
Throw the RawInst class in an anon namespace
llvm-svn: 8990
Diffstat (limited to 'llvm/lib')
-rw-r--r-- | llvm/lib/Bytecode/Reader/InstructionReader.cpp | 24 | ||||
-rw-r--r-- | llvm/lib/Bytecode/Reader/Reader.cpp | 3 | ||||
-rw-r--r-- | llvm/lib/Bytecode/Reader/ReaderInternals.h | 3 |
3 files changed, 17 insertions, 13 deletions
diff --git a/llvm/lib/Bytecode/Reader/InstructionReader.cpp b/llvm/lib/Bytecode/Reader/InstructionReader.cpp index b085581c60e..1b2ada0d493 100644 --- a/llvm/lib/Bytecode/Reader/InstructionReader.cpp +++ b/llvm/lib/Bytecode/Reader/InstructionReader.cpp @@ -14,15 +14,16 @@ #include "llvm/iPHINode.h" #include "llvm/iOther.h" -struct RawInst { // The raw fields out of the bytecode stream... - unsigned NumOperands; - unsigned Opcode; - unsigned Type; - - RawInst(const unsigned char *&Buf, const unsigned char *EndBuf, - std::vector<unsigned> &Args); - -}; +namespace { + struct RawInst { // The raw fields out of the bytecode stream... + unsigned NumOperands; + unsigned Opcode; + unsigned Type; + + RawInst(const unsigned char *&Buf, const unsigned char *EndBuf, + std::vector<unsigned> &Args); + }; +} @@ -102,8 +103,9 @@ RawInst::RawInst(const unsigned char *&Buf, const unsigned char *EndBuf, Instruction *BytecodeParser::ParseInstruction(const unsigned char *&Buf, - const unsigned char *EndBuf) { - std::vector<unsigned> Args; + const unsigned char *EndBuf, + std::vector<unsigned> &Args) { + Args.clear(); RawInst RI(Buf, EndBuf, Args); const Type *InstTy = getType(RI.Type); diff --git a/llvm/lib/Bytecode/Reader/Reader.cpp b/llvm/lib/Bytecode/Reader/Reader.cpp index bf2b0118a35..ac380372372 100644 --- a/llvm/lib/Bytecode/Reader/Reader.cpp +++ b/llvm/lib/Bytecode/Reader/Reader.cpp @@ -200,7 +200,8 @@ BasicBlock *BytecodeParser::ParseBasicBlock(const unsigned char *&Buf, BB = ParsedBasicBlocks[BlockNo]; while (Buf < EndBuf) { - Instruction *Inst = ParseInstruction(Buf, EndBuf); + std::vector<unsigned> Args; + Instruction *Inst = ParseInstruction(Buf, EndBuf, Args); insertValue(Inst, Values); BB->getInstList().push_back(Inst); BCR_TRACE(4, Inst); diff --git a/llvm/lib/Bytecode/Reader/ReaderInternals.h b/llvm/lib/Bytecode/Reader/ReaderInternals.h index 1fefe23fafb..2d75a321313 100644 --- a/llvm/lib/Bytecode/Reader/ReaderInternals.h +++ b/llvm/lib/Bytecode/Reader/ReaderInternals.h @@ -149,7 +149,8 @@ private: unsigned BlockNo); Instruction *ParseInstruction(const unsigned char *&Buf, - const unsigned char *End); + const unsigned char *End, + std::vector<unsigned> &Args); void ParseConstantPool(const unsigned char *&Buf, const unsigned char *EndBuf, ValueTable &Tab, TypeValuesListTy &TypeTab); |