| Server IP : www.new.bangkokfinder.com / Your IP : 172.68.164.61 Web Server : nginx/1.20.1 System : Linux new 4.15.0-159-generic #167-Ubuntu SMP Tue Sep 21 08:55:05 UTC 2021 x86_64 User : bangkokfinder ( 1000) PHP Version : 7.4.33 Disable Function : pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals,pcntl_unshare, MySQL : OFF | cURL : ON | WGET : ON | Perl : ON | Python : ON | Sudo : ON | Pkexec : ON Directory : /proc/thread-self/root/usr/src/libde265/libde265/ |
Upload File : |
/*
* H.265 video codec.
* Copyright (c) 2014 struktur AG, Dirk Farin <[email protected]>
*
* Authors: Dirk Farin <[email protected]>
*
* This file is part of libde265.
*
* libde265 is free software: you can redistribute it and/or modify
* it under the terms of the GNU Lesser General Public License as
* published by the Free Software Foundation, either version 3 of
* the License, or (at your option) any later version.
*
* libde265 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 Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public License
* along with libde265. If not, see <http://www.gnu.org/licenses/>.
*/
#include "libde265/alloc_pool.h"
#include "libde265/util.h"
#include <assert.h>
#include <stdio.h>
#define DEBUG_MEMORY 1
alloc_pool::alloc_pool(size_t objSize, int poolSize, bool grow)
: mObjSize(objSize),
mPoolSize(poolSize),
mGrow(grow)
{
m_freeList.reserve(poolSize);
m_memBlocks.reserve(8);
add_memory_block();
}
void alloc_pool::add_memory_block()
{
uint8_t* p = new uint8_t[mObjSize * mPoolSize];
m_memBlocks.push_back(p);
for (int i=0;i<mPoolSize;i++)
{
m_freeList.push_back(p + (mPoolSize-1-i) * mObjSize);
}
}
alloc_pool::~alloc_pool()
{
FOR_LOOP(uint8_t*, p, m_memBlocks) {
delete[] p;
}
}
void* alloc_pool::new_obj(const size_t size)
{
if (size != mObjSize) {
return ::operator new(size);
}
if (m_freeList.size()==0) {
if (mGrow) {
add_memory_block();
if (DEBUG_MEMORY) { fprintf(stderr,"additional block allocated in memory pool\n"); }
}
else {
return NULL;
}
}
assert(!m_freeList.empty());
void* p = m_freeList.back();
m_freeList.pop_back();
return p;
}
void alloc_pool::delete_obj(void* obj)
{
int memBlockSize = mObjSize * mPoolSize;
FOR_LOOP(uint8_t*, memBlk, m_memBlocks) {
if (memBlk <= obj && obj < memBlk + memBlockSize) {
m_freeList.push_back(obj);
return;
}
}
::operator delete(obj);
}