2016-04-14 08:54:32 +01:00
|
|
|
#ifndef BLOCK_CACHE_MEM_POOL_H
|
|
|
|
#define BLOCK_CACHE_MEM_POOL_H
|
|
|
|
|
|
|
|
#include <boost/intrusive/list.hpp>
|
|
|
|
#include <boost/optional.hpp>
|
|
|
|
#include <list>
|
|
|
|
|
|
|
|
namespace bi = boost::intrusive;
|
|
|
|
|
|
|
|
//----------------------------------------------------------------
|
|
|
|
|
|
|
|
namespace bcache {
|
|
|
|
// FIXME: move to base?
|
|
|
|
|
|
|
|
namespace mempool_detail {
|
2016-05-07 11:47:40 +01:00
|
|
|
struct alloc_block : public bi::list_base_hook<bi::link_mode<bi::normal_link>> {
|
2016-04-14 08:54:32 +01:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
class mempool {
|
|
|
|
public:
|
2016-05-07 11:47:40 +01:00
|
|
|
// alignment must be a power of 2
|
|
|
|
mempool(size_t block_size, size_t total_mem, size_t alignment = 8);
|
2016-04-14 08:54:32 +01:00
|
|
|
~mempool();
|
|
|
|
|
2016-06-01 14:46:27 +01:00
|
|
|
void *alloc();
|
2016-04-14 08:54:32 +01:00
|
|
|
void free(void *data);
|
|
|
|
|
|
|
|
private:
|
|
|
|
static void *alloc_aligned(size_t len, size_t alignment);
|
|
|
|
|
|
|
|
using block_list = bi::list<mempool_detail::alloc_block>;
|
|
|
|
|
|
|
|
void *mem_;
|
|
|
|
block_list free_;
|
|
|
|
|
|
|
|
//----------------
|
|
|
|
|
|
|
|
mempool(mempool const &) = delete;
|
|
|
|
mempool &operator =(mempool const &) = delete;
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
//----------------------------------------------------------------
|
|
|
|
|
|
|
|
#endif
|