/** * Copyright 2013-2021 Software Radio Systems Limited * * This file is part of srsRAN. * * srsRAN is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero General Public License as * published by the Free Software Foundation, either version 3 of * the License, or (at your option) any later version. * * srsRAN 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 Affero General Public License for more details. * * A copy of the GNU Affero General Public License can be found in * the LICENSE file in the top-level directory of this distribution * and at http://www.gnu.org/licenses/. * */ #ifndef SRSRAN_POOL_INTERFACE_H #define SRSRAN_POOL_INTERFACE_H #include "srsran/adt/move_callback.h" namespace srsran { /// unique ptr with type-erased dtor, so that it can be used by any object or memory pool constexpr size_t unique_pool_deleter_small_buffer = sizeof(void*) * 2u; template using unique_pool_ptr = std::unique_ptr >; /// Common object pool interface template class obj_pool_itf { public: using object_type = T; obj_pool_itf() = default; // Object pool address should not change obj_pool_itf(const obj_pool_itf&) = delete; obj_pool_itf(obj_pool_itf&&) = delete; obj_pool_itf& operator=(const obj_pool_itf&) = delete; obj_pool_itf& operator=(obj_pool_itf&&) = delete; virtual ~obj_pool_itf() = default; virtual unique_pool_ptr make() = 0; }; /// Allocate object in memory pool template unique_pool_ptr make_pool_obj_with_heap_fallback(MemPool& mempool, Args&&... args) { void* block = mempool.allocate(sizeof(T), alignof(T)); if (block == nullptr) { return unique_pool_ptr(new T(std::forward(args)...), std::default_delete()); } new (block) T(std::forward(args)...); return unique_pool_ptr(block, [&mempool](T* ptr) { if (ptr != nullptr) { ptr->~T(); mempool.deallocate(ptr); } }); } } // namespace srsran #endif // SRSRAN_POOL_INTERFACE_H