memory.cpp 2.9 KB
Newer Older
W
wangguibao 已提交
1 2 3 4 5 6 7 8 9 10 11 12 13 14
// Copyright (c) 2019 PaddlePaddle Authors. All Rights Reserved.
//
// 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.

W
wangguibao 已提交
15 16
#include "predictor/framework/memory.h"
#include "predictor/common/inner_common.h"
W
wangguibao 已提交
17 18 19 20 21

namespace baidu {
namespace paddle_serving {
namespace predictor {

X
xulongteng 已提交
22 23 24 25 26 27 28 29 30 31 32
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;
};

W
wangguibao 已提交
33
int MempoolWrapper::initialize() {
W
wangguibao 已提交
34 35 36 37 38 39 40 41 42 43
  if (THREAD_KEY_CREATE(&_bspec_key, NULL) != 0) {
    LOG(ERROR) << "unable to create thread_key of thrd_data";
    return -1;
  }
  if (THREAD_SETSPECIFIC(_bspec_key, NULL) != 0) {
    LOG(ERROR) << "failed initialize bsepecific key to null";
    return -1;
  }

  return 0;
W
wangguibao 已提交
44 45 46
}

int MempoolWrapper::thread_initialize() {
X
xulongteng 已提交
47 48 49 50 51
  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) {
W
wangguibao 已提交
52 53 54 55
    LOG(ERROR) << "Failed create thread mempool";
    return -1;
  }

X
xulongteng 已提交
56
  if (THREAD_SETSPECIFIC(_bspec_key, mempool_region) != 0) {
W
wangguibao 已提交
57
    LOG(ERROR) << "unable to set the thrd_data";
X
xulongteng 已提交
58 59
    delete region;
    delete mempool;
W
wangguibao 已提交
60 61 62 63 64
    return -1;
  }

  LOG(WARNING) << "Succ thread initialize mempool wrapper";
  return 0;
W
wangguibao 已提交
65 66 67
}

int MempoolWrapper::thread_clear() {
X
xulongteng 已提交
68 69 70 71 72 73 74 75 76 77
  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();
W
wangguibao 已提交
78 79
  }
  return 0;
W
wangguibao 已提交
80 81 82
}

void* MempoolWrapper::malloc(size_t size) {
X
xulongteng 已提交
83 84 85 86 87 88 89 90
  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) {
W
wangguibao 已提交
91 92 93 94
    LOG(WARNING) << "Cannot malloc memory:" << size
                 << ", since mempool is not thread initialized";
    return NULL;
  }
X
xulongteng 已提交
95
  return mempool->malloc(size);
W
wangguibao 已提交
96 97
}

W
wangguibao 已提交
98 99 100
}  // namespace predictor
}  // namespace paddle_serving
}  // namespace baidu