blob: e52d556ce83fb611cf850772111b14a8c6f63f5c [file] [log] [blame]
/* ------------------------------------------------------------------
* Copyright (C) 2008 PacketVideo
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either
* express or implied.
* See the License for the specific language governing permissions
* and limitations under the License.
* -------------------------------------------------------------------
*/
/*********************************************************************************/
/* ------------------------------------------------------------------- */
/* MPEG-4 Util: MediaBufferManager Class */
/* ------------------------------------------------------------------- */
/*********************************************************************************/
/*
This MediaBufferManager Class is responsible for maintaining list of used
and free MediaBuffers. This is promarily used by the Mpeg4File class when
it is retrieving media data from disk. It needs buffers to store data and
to pass to the consumers of the media data - namesly PVServer and PVPlayer.
*/
#define IMPLEMENT_MediaBufferManager
#include "mediabuffermanager.h"
typedef Oscl_Vector<MediaBuffer*, OsclMemAllocator> mediaBufferVecType;
// Constructor
MediaBufferManager::MediaBufferManager(int32 bufSize, uint32 numBufs)
{
_bufferSize = bufSize;
// Create 'numBufs' initial buffers each of size 'bufSize'
PV_MP4_FF_NEW(fp->auditCB, mediaBufferVecType, (), _pfreeBufVec);
PV_MP4_FF_NEW(fp->auditCB, mediaBufferVecType, (), _pusedBufVec);
// Allocate free buffers
for (uint32 i = 0; i < numBufs; i++)
{
MediaBuffer *mb = NULL;
PV_MP4_FF_NEW(fp->auditCB, MediaBuffer, (bufSize), mb);
mb->setOwner(this);
(*_pfreeBufVec).push_back(mb);
}
}
MediaBufferManager::~MediaBufferManager()
{
uint32 i;
// Clean up the vectors of buffers
for (i = 0; i < _pfreeBufVec->size(); i++)
{
PV_MP4_FF_DELETE(NULL, MediaBuffer, (*_pfreeBufVec)[i]);
}
PV_MP4_FF_TEMPLATED_DELETE(NULL, mediaBufferVecType, Oscl_Vector, _pfreeBufVec);
for (i = 0; i < _pusedBufVec->size(); i++)
{
PV_MP4_FF_DELETE(NULL, MediaBuffer, (*_pusedBufVec)[i]);
}
PV_MP4_FF_TEMPLATED_DELETE(NULL, mediaBufferVecType, Oscl_Vector, _pusedBufVec);
}
// Called by buffer when it is freed
void
MediaBufferManager::freeBuf(MediaBuffer *buf)
{
// Need to find buffer in _pusedBufVec
int32 i = 0;
MediaBuffer **x;
for (x = _pusedBufVec->begin();x < _pusedBufVec->end(); x++)
{
MediaBuffer *used = (MediaBuffer*)(*_pusedBufVec)[i];
if (used == buf)
{
break; // Found buffer in used vec
}
i++;
}
(*_pfreeBufVec).push_back(buf); // buffer to free vec
_pusedBufVec->erase(x); // Delete buffer from used vec
}
MediaBuffer*
MediaBufferManager::getBuf()
{
if (_pfreeBufVec->size() != 0)
{
MediaBuffer *mb = (MediaBuffer *)(*_pfreeBufVec)[_pfreeBufVec->size()-1]; // get last buf
_pfreeBufVec->pop_back();
(*_pusedBufVec).push_back(mb);
return mb;
}
else // No free buffers - need to create one
{
MediaBuffer *mb = newBuf();
(*_pusedBufVec).push_back(mb);
return mb;
}
}
// By default create a 32KB buffer - if want another size buffer, need to set
// the bufSize member for this class
MediaBuffer*
MediaBufferManager::newBuf()
{
MediaBuffer *mb = NULL;
PV_MP4_FF_NEW(fp->auditCB, MediaBuffer, (_bufferSize), mb);
return mb;
}