git-svn-id: https://svn.code.sf.net/p/flaim/code/trunk@7 0109f412-320b-0410-ab79-c3e0c5ffbbe6
267 lines
5.0 KiB
C++
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
|