Files
mars-flaim/flaim/src/fbuff.h
dsandersoremutah c55dab446f Renamed version4 to flaim and version5 to xflaim
git-svn-id: https://svn.code.sf.net/p/flaim/code/trunk@7 0109f412-320b-0410-ab79-c3e0c5ffbbe6
2006-01-27 21:06:39 +00:00

267 lines
5.0 KiB
C++

//-------------------------------------------------------------------------
// Desc: Buffer management for asynchronous I/O - class definition.
// Tabs: 3
//
// Copyright (c) 2001-2006 Novell, Inc. All Rights Reserved.
//
// This program is free software; you can redistribute it and/or
// modify it under the terms of version 2 of the GNU General Public
// License as published by the Free Software Foundation.
//
// This program is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU General Public License for more details.
//
// You should have received a copy of the GNU General Public License
// along with this program; if not, contact Novell, Inc.
//
// To contact Novell about this file by physical or electronic mail,
// you may find current contact information at www.novell.com
//
// $Id: fbuff.h 12329 2006-01-20 17:49:30 -0700 (Fri, 20 Jan 2006) ahodgkinson $
//-------------------------------------------------------------------------
#ifndef FBUFF_H
#define FBUFF_H
#include "fpackon.h"
// IMPORTANT NOTE: No other include files should follow this one except
// for fpackoff.h
class F_IOBuffer;
#define F_MAX_BUFFER_BLOCKS 16
typedef void (* WRITE_COMPLETION_CB)(
F_IOBuffer * pWriteBuffer);
class F_IOBufferMgr : public F_Base
{
public:
// Constructor
F_IOBufferMgr();
// Destructor
virtual ~F_IOBufferMgr();
RCODE waitForAllPendingIO( void);
FINLINE void setMaxBuffers(
FLMUINT uiMaxBuffers)
{
m_uiMaxBuffers = uiMaxBuffers;
}
FINLINE void setMaxBytes(
FLMUINT uiMaxBytes)
{
m_uiMaxBufferBytesToUse = uiMaxBytes;
}
FINLINE void enableKeepBuffer( void)
{
m_bKeepBuffers = TRUE;
}
RCODE getBuffer(
F_IOBuffer ** ppIOBuffer,
FLMUINT uiBufferSize,
FLMUINT uiBlockSize);
FINLINE FLMBOOL havePendingIO( void)
{
return( m_pFirstPending ? TRUE : FALSE);
}
FINLINE FLMBOOL haveUsed( void)
{
return( m_pFirstUsed ? TRUE : FALSE);
}
private:
F_IOBuffer * m_pFirstPending;
F_IOBuffer * m_pFirstAvail;
F_IOBuffer * m_pFirstUsed;
FLMUINT m_uiMaxBuffers;
FLMUINT m_uiMaxBufferBytesToUse;
FLMUINT m_uiBufferBytesInUse;
FLMUINT m_uiBuffersInUse;
RCODE m_completionRc;
FLMBOOL m_bKeepBuffers;
void linkToList(
F_IOBuffer ** ppListHead,
F_IOBuffer * pIOBuffer);
void unlinkFromList(
F_IOBuffer * pIOBuffer);
friend class F_IOBuffer;
};
class F_IOBuffer : public F_Base
{
public:
typedef enum
{
MGR_LIST_NONE,
MGR_LIST_AVAIL,
MGR_LIST_PENDING,
MGR_LIST_USED
} eBufferMgrList;
// Constructor
F_IOBuffer();
// Destructor
virtual ~F_IOBuffer();
RCODE setupBuffer(
FLMUINT uiBufferSize,
FLMUINT uiBlockSize);
FINLINE FLMUINT getBufferSize( void)
{
return( m_uiBufferSize);
}
FINLINE FLMUINT getBlockSize( void)
{
return( m_uiBlockSize);
}
void notifyComplete(
RCODE rc);
FINLINE void setCompletionCallback(
WRITE_COMPLETION_CB fnCompletion)
{
m_fnCompletion = fnCompletion;
}
FINLINE void startTimer(
DB_STATS * pDbStats )
{
if ((m_pDbStats = pDbStats) != NULL)
{
m_ui64ElapMilli = 0;
f_timeGetTimeStamp( &m_StartTime);
}
}
FINLINE void endTimer( void)
{
if (m_pDbStats)
{
flmAddElapTime( &m_StartTime, &m_ui64ElapMilli);
}
}
FINLINE FLMUINT64 getElapTime( void)
{
return( m_ui64ElapMilli);
}
FINLINE DB_STATS * getDbStats( void)
{
return( m_pDbStats);
}
FINLINE void setCompletionCallbackData(
FLMUINT uiBlockNumber,
void * pvData)
{
flmAssert( uiBlockNumber < F_MAX_BUFFER_BLOCKS);
m_UserData [uiBlockNumber] = pvData;
}
FINLINE void * getCompletionCallbackData(
FLMUINT uiBlockNumber)
{
flmAssert( uiBlockNumber < F_MAX_BUFFER_BLOCKS);
return( m_UserData [uiBlockNumber]);
}
FINLINE RCODE getCompletionCode( void)
{
return( m_completionRc);
}
FINLINE eBufferMgrList getList( void)
{
return( m_eList);
}
FINLINE FLMBYTE * getBuffer( void)
{
return( m_pucBuffer);
}
void makePending( void);
#ifdef FLM_WIN
FINLINE OVERLAPPED * getOverlapped( void)
{
return( &m_Overlapped);
}
FINLINE void setFileHandle(
HANDLE FileHandle)
{
m_FileHandle = FileHandle;
}
#endif
#ifdef FLM_NLM
void signalComplete(
RCODE rc);
#endif
private:
RCODE setupIOBuffer(
F_IOBufferMgr * pIOBufferMgr);
FLMBOOL isIOComplete( void);
RCODE waitToComplete( void);
F_IOBufferMgr * m_pIOBufferMgr;
F_IOBuffer * m_pNext;
F_IOBuffer * m_pPrev;
WRITE_COMPLETION_CB m_fnCompletion;
RCODE m_completionRc;
FLMBYTE * m_pucBuffer;
void * m_UserData[ F_MAX_BUFFER_BLOCKS];
FLMUINT m_uiBufferSize;
FLMUINT m_uiBlockSize;
eBufferMgrList m_eList;
FLMBOOL m_bDeleteOnNotify;
DB_STATS * m_pDbStats;
F_TMSTAMP m_StartTime;
FLMUINT64 m_ui64ElapMilli;
#ifdef FLM_WIN
HANDLE m_FileHandle;
OVERLAPPED m_Overlapped;
#endif
#ifdef FLM_NLM
F_SEM m_hSem;
#endif
friend class F_IOBufferMgr;
friend class F_Rfl;
};
#include "fpackoff.h"
#endif