commsfwutils/commsbufs/version1/mbufmgr/INC/MBufPoolChain.h
author Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
Thu, 17 Dec 2009 09:22:25 +0200
changeset 0 dfb7c4ff071f
permissions -rw-r--r--
Revision: 200951 Kit: 200951

/**
* Copyright (c) 2007-2009 Nokia Corporation and/or its subsidiary(-ies).
* All rights reserved.
* This component and the accompanying materials are made available
* under the terms of "Eclipse Public License v1.0"
* which accompanies this distribution, and is available
* at the URL "http://www.eclipse.org/legal/epl-v10.html".
*
* Initial Contributors:
* Nokia Corporation - initial contribution.
*
* Contributors:
*
* Description:
* RMBufPoolChain decleration
* 
*
*/



/**
 @file
 @internalTechnology
*/

#ifndef MBUF_POOL_CHAIN_H
#define MBUF_POOL_CHAIN_H

#include <e32def.h>     // for std types

// forward decleration(s) to avoid circular dependency by including this file
// - this is a symptom of multiple class declerations within the same header file
//   eg. es_mbman.h required for CMBufPool, but also contains CMBufManager which inturn requires RMBufPoolChain defined in this file!
class RMBufPoolChain;
#include <es_mbman.h>       // for CMBufPool


// this class is internal to MBM, but alas this can't be enforced by C++ (except by not exporting its header file)
class RMBufPoolChain
	{
	friend class CMBufPoolManager;	// to allow access to private members
   
	RMBufPoolChain(TInt aMBufSize, CMBufPoolManager& aMBufPoolManager); // to be used only in searching for existing poolchain
	RMBufPoolChain(TInt aMBufSize, TInt aInitialAllocation, TInt aMinGrowth, TInt aHighGrowthThresholdPercentage, CMBufPoolManager& aMBufPoolManager);

	void OpenL();
	void Close();
	
public:	
	
	TInt GrowthSize(TInt aSize);
	void ExtendFreeList(CMBufPool* aPool);  // assumed that the caller has already acquired the lock, refer comments within the definition
	
	TInt Alloc(RMBufQ& aList, TInt aSize, TBool aIsAllocPool);
	static TInt Compare(const TInt* aMBufSize, const RMBufPoolChain& aRHSPoolChain);
	static TInt Compare(const RMBufPoolChain& aLHSPoolChain, const RMBufPoolChain& aRHSPoolChain);
	CMBufPoolManager& MBufPoolManager();
	
private:

	RWorkerLock iLockFreeList;				// lock for free list
    TInt iLenFree;					// number of bytes free within the pool chain
    TInt iLenTotal;				// number of bytes allocated (free + used) within the pool chain
    RMBufQ iFreeMBufs;				// free list of mbufs ready to be consumed, use of plural naming implies the queue (hence the name isn't appended)
    TDblQue<CMBufPool> iPools;

   	const TInt iMBufSize;          // size (in bytes) of contained mbufs, also stored within mbuf but kept here for encapsulation & ease of reference
    const TInt iInitialAllocation; // initial allocation size in num of MBufs (not bytes)
    TInt iMinGrowth;  				// minimum (automatic) incremental allocation in num of MBufs (not bytes) - actual allocate may be larger (refer )
    TInt iGrowthThreshold; 		// if the num of free mbufs is <= this value, then a a new pool is automatically allocated

	TBool iSignalled;				// background growth in progress
	TInt iNumMBufsToAdd;			// background growth
	TBool iNoMoreSpace;				// last background growth failed
	TInt iLastGrowth;				// last attempted growth
	TInt iMaxGrowthAttempt;			// largest growth attempt

	TInt iDbgPoolLimit;				// limit size of pool chain
	
	CMBufPoolManager& iMBufPoolManager;
	};

#endif  // MBUF_POOL_CHAIN_H