/*
* Copyright (c) 2002-2005 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: Declaration of DIscBufferQueue class
*
*/
#ifndef ISCBUFFERQUEUE_H
#define ISCBUFFERQUEUE_H
// INCLUDES
#include <kernel.h>
// CONSTANTS
// MACROS
// DATA TYPES
// FUNCTION PROTOTYPES
// FORWARD DECLARATIONS
class DIscQueue;
// CLASS DECLARATION
/**
* Queue class for buffer allocation and management
*
* @lib IscDataTransmissionBase.LIB
* @since 2.8
*/
class DIscBufferQueue
{
public: // Constructors and destructor
/**
* C++ default constructor.
*/
DIscBufferQueue();
/**
* Construct a new queue
* @since 2.8
* @param TUint16 aSize size of element in queue
* @param TUint16 aCount amount of elements in queue
* @param TUint8* &aCurrentAddress start address of queue
* @return DIscBufferQueue* pointer to queue
*/
static DIscBufferQueue* New( TUint16 aSize, TUint16 aCount, TUint8* &aCurrentAddress );
/**
* Destructor.
*/
~DIscBufferQueue();
public: // New functions
/**
* Checks if queue is empty
* @since 2.8
* @return TBool ETrue if empty, otherwise EFalse
*/
inline TBool Empty(){return iCount ? EFalse : ETrue;};
/**
* Reserves first element from the queue
* @since 2.8
* @return TDes8* pointer to element if succesful, otherwise NULL
*/
TDes8* Reserve();
/**
* Releases element from the queue
* @since 2.8
* @param TDes8* aPtr pointer to element
* @return void
*/
void Release( TDes8* aPtr );
protected: // New functions
/**
* Function to disable interrupts
* @since 2.8
* @return TInt KErrNone if succesful
*/
TInt DisableIrqs();
/**
* Function to restore interrupts
* @since 2.8
* @param TInt aLevel level where interrupts should be restored
* @return void
*/
void RestoreIrqs( TInt aLevel );
protected: // Functions from base classes
private:
/**
* 2nd phase constructor
* @since 2.8
* @param TUint16 aSize size of element in queue
* @param TUint16 aCount amount of elements in queue
* @param TUint8* &aCurrentAddress start address of queue
* @return TInt
*/
TInt Construct( TUint16 aSize, TUint16 aCount, TUint8* &aCurrentAddress );
public: // Data
protected: // Data
private: // Data
volatile TUint32 iCount;
TUint32** iBuffers;
DIscQueue* iBuffersQueue;
};
#endif // ISCBUFFERQUEUE_H
// End of File