diff --git a/predictor/framework/memory.cpp b/predictor/framework/memory.cpp index 32f2547817983d8c6d280269b6003de117247c6c..78a4643468eeca9f1da925a67f1e1330b89927a3 100644 --- a/predictor/framework/memory.cpp +++ b/predictor/framework/memory.cpp @@ -19,6 +19,27 @@ namespace baidu { namespace paddle_serving { namespace predictor { +struct MempoolRegion { + MempoolRegion(im::fugue::memory::Region *region, + im::Mempool *mempool) : + _region(region), _mempool(mempool){} + im::fugue::memory::Region *region() {return _region;} + im::Mempool *mempool() {return _mempool;} + + im::fugue::memory::Region* _region; + im::Mempool* _mempool; + ~MempoolRegion() { + if (_region) { + delete _region; + _region = NULL; + } + if (_mempool) { + delete _mempool; + _mempool = NULL; + } + } +}; + int MempoolWrapper::initialize() { if (THREAD_KEY_CREATE(&_bspec_key, NULL) != 0) { LOG(ERROR) << "unable to create thread_key of thrd_data"; @@ -33,16 +54,20 @@ int MempoolWrapper::initialize() { } int MempoolWrapper::thread_initialize() { - _region.init(); - im::Mempool* p_mempool = new (std::nothrow) im::Mempool(&_region); - if (p_mempool == NULL) { + im::fugue::memory::Region *region = new im::fugue::memory::Region(); + region->init(); + im::Mempool* mempool = new (std::nothrow) im::Mempool(region); + MempoolRegion *mempool_region = new MempoolRegion(region, mempool); + if (mempool == NULL) { LOG(ERROR) << "Failed create thread mempool"; return -1; } - if (THREAD_SETSPECIFIC(_bspec_key, p_mempool) != 0) { + if (THREAD_SETSPECIFIC(_bspec_key, mempool_region) != 0) { LOG(ERROR) << "unable to set the thrd_data"; - delete p_mempool; + delete region; + delete mempool; + delete mempool_region; return -1; } @@ -51,23 +76,34 @@ int MempoolWrapper::thread_initialize() { } int MempoolWrapper::thread_clear() { - im::Mempool* p_mempool = (im::Mempool*)THREAD_GETSPECIFIC(_bspec_key); - if (p_mempool) { - p_mempool->release_block(); - _region.reset(); + MempoolRegion* mempool_region = (MempoolRegion*)THREAD_GETSPECIFIC(_bspec_key); + if (mempool_region == NULL) { + LOG(WARNING) << "THREAD_GETSPECIFIC() returned NULL"; + return -1; + } + im::Mempool* mempool = mempool_region->mempool(); + im::fugue::memory::Region* region = mempool_region->region(); + if (mempool) { + mempool->release_block(); + region->reset(); } - return 0; } void* MempoolWrapper::malloc(size_t size) { - im::Mempool* p_mempool = (im::Mempool*)THREAD_GETSPECIFIC(_bspec_key); - if (!p_mempool) { + MempoolRegion* mempool_region = (MempoolRegion*)THREAD_GETSPECIFIC(_bspec_key); + if (mempool_region == NULL) { + LOG(WARNING) << "THREAD_GETSPECIFIC() returned NULL"; + return NULL; + } + + im::Mempool* mempool = mempool_region->mempool(); + if (!mempool) { LOG(WARNING) << "Cannot malloc memory:" << size << ", since mempool is not thread initialized"; return NULL; } - return p_mempool->malloc(size); + return mempool->malloc(size); } } // namespace predictor diff --git a/predictor/framework/memory.h b/predictor/framework/memory.h index 9cc12e8f5c3b89c07578cb7807b03b4df26d75c5..c096bc2c6b2d96ff2bd93daa804bac007cef6295 100644 --- a/predictor/framework/memory.h +++ b/predictor/framework/memory.h @@ -39,7 +39,7 @@ class MempoolWrapper { void* malloc(size_t size); private: - im::fugue::memory::Region _region; + //im::fugue::memory::Region _region; THREAD_KEY_T _bspec_key; }; diff --git a/predictor/src/pdserving.cpp b/predictor/src/pdserving.cpp index be7f988744b6ef0530c8b725cb3d6275725831ec..3fc1eed7b632b68be1c5c9f39db63f260319d48c 100644 --- a/predictor/src/pdserving.cpp +++ b/predictor/src/pdserving.cpp @@ -143,7 +143,7 @@ int main(int argc, char** argv) { std::string filename(argv[0]); filename = filename.substr(filename.find_last_of('/') + 1); - settings.log_file = (std::string("./log/") + filename + ".log").c_str(); + settings.log_file = strdup((std::string("./log/") + filename + ".log").c_str()); settings.delete_old = logging::DELETE_OLD_LOG_FILE; logging::InitLogging(settings);