diff options
author | Chris Lattner <sabre@nondot.org> | 2005-01-29 17:05:56 +0000 |
---|---|---|
committer | Chris Lattner <sabre@nondot.org> | 2005-01-29 17:05:56 +0000 |
commit | 8c2cb42f08fbb3872a7d0a31236a890c14c9b024 (patch) | |
tree | a351316f40ada292fb6c6f744bd373948184dd5a /lib/Support | |
parent | 52b8752780c9ebf8f13a069625785a046b726f17 (diff) |
After reading in a bc file, trim the resultant buffer down to what we
really need. This reduces 4M of memory consumption reading 176.gcc.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@19916 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Support')
-rw-r--r-- | lib/Support/Compressor.cpp | 14 |
1 files changed, 12 insertions, 2 deletions
diff --git a/lib/Support/Compressor.cpp b/lib/Support/Compressor.cpp index 43e85495a1..167b26b53f 100644 --- a/lib/Support/Compressor.cpp +++ b/lib/Support/Compressor.cpp @@ -119,7 +119,7 @@ namespace { struct BufferContext { char* buff; unsigned size; - BufferContext(unsigned compressedSize ) { + BufferContext(unsigned compressedSize) { // Null to indicate malloc of a new block buff = 0; @@ -128,12 +128,21 @@ struct BufferContext { // in the callback for an initial allocation of 4x compressedSize. This // calculation is based on the typical compression ratio of bzip2 on LLVM // bytecode files which typically ranges in the 50%-75% range. Since we - // tyipcally get at least 50%, doubling is insufficient. By using a 4x + // typically get at least 50%, doubling is insufficient. By using a 4x // multiplier on the first allocation, we minimize the impact of having to // copy the buffer on reallocation. size = compressedSize*2; } + /// trimTo - Reduce the size of the buffer down to the specified amount. This + /// is useful after have read in the bytecode file to discard extra unused + /// memory. + /// + void trimTo(size_t NewSize) { + buff = (char*)::realloc(buff, NewSize); + size = NewSize; + } + /// This function handles allocation of the buffer used for decompression of /// compressed bytecode files. It is called by Compressor::decompress which is /// called by BytecodeReader::ParseBytecode. @@ -333,6 +342,7 @@ uint64_t Compressor::compressToNewBuffer(const char* in, unsigned size, char*&out) { BufferContext bc(size); uint64_t result = compress(in,size,BufferContext::callback,(void*)&bc); + bc.trimTo(result); out = bc.buff; return result; } |