Added tests for corrupt Chunk. Added cout statements for debugging - and

these are inside a #ifdef block.


git-svn-id: svn://svn.code.sf.net/p/loki-lib/code/trunk@303 7ec92016-0320-0410-acc4-a06ded1c099a
This commit is contained in:
rich_sposato 2005-10-15 00:41:36 +00:00
parent c23e9f1e23
commit b53657017a

View file

@ -23,6 +23,13 @@
#include <algorithm> #include <algorithm>
#include <functional> #include <functional>
#define DO_EXTRA_LOKI_TESTS
#ifdef DO_EXTRA_LOKI_TESTS
#include <iostream>
#include <bitset>
#endif
using namespace Loki; using namespace Loki;
@ -99,6 +106,8 @@ namespace Loki
/// Releases the allocated block of memory. /// Releases the allocated block of memory.
void Release(); void Release();
bool IsCorrupt( unsigned char numBlocks, std::size_t blockSize ) const;
/// Returns true if block at address P is inside this Chunk. /// Returns true if block at address P is inside this Chunk.
inline bool HasBlock( unsigned char * p, std::size_t chunkLength ) const inline bool HasBlock( unsigned char * p, std::size_t chunkLength ) const
{ return ( pData_ <= p ) && ( p < pData_ + chunkLength ); } { return ( pData_ <= p ) && ( p < pData_ + chunkLength ); }
@ -320,24 +329,63 @@ void Chunk::Deallocate(void* p, std::size_t blockSize)
unsigned char* toRelease = static_cast<unsigned char*>(p); unsigned char* toRelease = static_cast<unsigned char*>(p);
// Alignment check // Alignment check
assert((toRelease - pData_) % blockSize == 0); assert((toRelease - pData_) % blockSize == 0);
unsigned char index = static_cast< unsigned char >(
( toRelease - pData_ ) / blockSize);
#if defined(DEBUG) || defined(_DEBUG) #if defined(DEBUG) || defined(_DEBUG)
// Check if block was already deleted. Attempting to delete the same // Check if block was already deleted. Attempting to delete the same
// block more than once causes Chunk's linked-list of stealth indexes to // block more than once causes Chunk's linked-list of stealth indexes to
// become corrupt. And causes count of blocksAvailable_ ) to be wrong. // become corrupt. And causes count of blocksAvailable_ ) to be wrong.
if ( 0 < blocksAvailable_ ) if ( 0 < blocksAvailable_ )
assert( firstAvailableBlock_ != *toRelease ); assert( firstAvailableBlock_ != index );
#endif #endif
*toRelease = firstAvailableBlock_; *toRelease = firstAvailableBlock_;
firstAvailableBlock_ = static_cast<unsigned char>( firstAvailableBlock_ = index;
(toRelease - pData_) / blockSize);
// Truncation check // Truncation check
assert(firstAvailableBlock_ == (toRelease - pData_) / blockSize); assert(firstAvailableBlock_ == (toRelease - pData_) / blockSize);
++blocksAvailable_; ++blocksAvailable_;
} }
// Chunk::IsCorrupt -----------------------------------------------------------
bool Chunk::IsCorrupt( unsigned char numBlocks, std::size_t blockSize ) const
{
if ( numBlocks < blocksAvailable_ ) return true;
unsigned char index = firstAvailableBlock_;
if ( numBlocks <= index ) return true;
if ( 0 == blocksAvailable_ ) return false;
#ifdef DO_EXTRA_LOKI_TESTS
std::bitset< 256 > foundBlocks;
unsigned char * nextBlock = NULL;
unsigned char cc = 0;
for ( ;; )
{
nextBlock = pData_ + ( index * blockSize );
foundBlocks.set( index, true );
++cc;
if ( cc >= blocksAvailable_ )
break;
index = *nextBlock;
if ( numBlocks <= index )
return true;
if ( foundBlocks.test( index ) )
return true;
}
if ( foundBlocks.count() != blocksAvailable_ )
return false;
#else
(void)blockSize; // cast as void to make warning go away.
#endif
return false;
}
// FixedAllocator::FixedAllocator --------------------------------------------- // FixedAllocator::FixedAllocator ---------------------------------------------
FixedAllocator::FixedAllocator() FixedAllocator::FixedAllocator()
@ -552,6 +600,7 @@ bool FixedAllocator::Deallocate( void * p, Chunk * hint )
assert( foundChunk->HasBlock( static_cast< unsigned char * >( p ), assert( foundChunk->HasBlock( static_cast< unsigned char * >( p ),
numBlocks_ * blockSize_ ) ); numBlocks_ * blockSize_ ) );
assert( !foundChunk->IsCorrupt( numBlocks_, blockSize_ ) );
deallocChunk_ = foundChunk; deallocChunk_ = foundChunk;
DoDeallocate(p); DoDeallocate(p);
assert( CountEmptyChunks() < 2 ); assert( CountEmptyChunks() < 2 );
@ -699,6 +748,7 @@ SmallObjAllocator::SmallObjAllocator( std::size_t pageSize,
maxSmallObjectSize_( maxObjectSize ), maxSmallObjectSize_( maxObjectSize ),
objectAlignSize_( objectAlignSize ) objectAlignSize_( objectAlignSize )
{ {
std::cout << "SmallObjAllocator " << this << std::endl;
assert( 0 != objectAlignSize ); assert( 0 != objectAlignSize );
const std::size_t allocCount = GetOffset( maxObjectSize, objectAlignSize ); const std::size_t allocCount = GetOffset( maxObjectSize, objectAlignSize );
pool_ = new FixedAllocator[ allocCount ]; pool_ = new FixedAllocator[ allocCount ];
@ -710,6 +760,7 @@ SmallObjAllocator::SmallObjAllocator( std::size_t pageSize,
SmallObjAllocator::~SmallObjAllocator( void ) SmallObjAllocator::~SmallObjAllocator( void )
{ {
std::cout << "~SmallObjAllocator " << this << std::endl;
delete [] pool_; delete [] pool_;
} }
@ -826,6 +877,10 @@ void SmallObjAllocator::Deallocate( void * p )
//////////////////////////////////////////////////////////////////////////////// ////////////////////////////////////////////////////////////////////////////////
// $Log$ // $Log$
// Revision 1.11 2005/10/15 00:41:36 rich_sposato
// Added tests for corrupt Chunk. Added cout statements for debugging - and
// these are inside a #ifdef block.
//
// Revision 1.10 2005/10/14 23:16:23 rich_sposato // Revision 1.10 2005/10/14 23:16:23 rich_sposato
// Added check for already deleted block. Made Chunk members private. // Added check for already deleted block. Made Chunk members private.
// //