memory.h 3.2 KB
Newer Older
S
superjomn 已提交
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15
// 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.

#pragma once
S
superjomn 已提交
16
#include "paddle/fluid/lite/core/target_wrapper.h"
S
superjomn 已提交
17 18 19 20

namespace paddle {
namespace lite {

S
update  
superjomn 已提交
21
static void* TargetMalloc(TargetType target, size_t size) {
S
superjomn 已提交
22
  void* data{nullptr};
23 24 25 26
  switch (target) {
    case TargetType::kHost:
    case TargetType::kX86:
      data = TargetWrapper<TARGET(kHost)>::Malloc(size);
S
superjomn 已提交
27
      break;
S
superjomn 已提交
28
#ifdef LITE_WITH_CUDA
29
    case TargetType::kCUDA:
S
superjomn 已提交
30 31
      data =
          TargetWrapper<TARGET(kCUDA), cudaStream_t, cudaEvent_t>::Malloc(size);
S
superjomn 已提交
32
      break;
S
superjomn 已提交
33
#endif  // LITE_WITH_CUDA
S
superjomn 已提交
34
    default:
35
      LOG(FATAL) << "Unknown supported target " << TargetToStr(target);
S
superjomn 已提交
36 37 38 39
  }
  return data;
}

S
update  
superjomn 已提交
40
static void TargetFree(TargetType target, void* data) {
S
superjomn 已提交
41 42 43 44 45 46 47 48 49 50 51 52
  switch (static_cast<int>(target)) {
    case static_cast<int>(TargetType::kX86):
      TargetWrapper<TARGET(kX86)>::Free(data);
      break;
    case static_cast<int>(TargetType::kCUDA):
      TargetWrapper<TARGET(kX86)>::Free(data);
      break;
    default:
      LOG(FATAL) << "Unknown type";
  }
}

S
Superjomn 已提交
53 54
static void TargetCopy(TargetType target, void* dst, const void* src,
                       size_t size) {
55 56 57
  switch (target) {
    case TargetType::kX86:
    case TargetType::kHost:
S
Superjomn 已提交
58 59 60 61
      TargetWrapper<TARGET(kHost)>::MemcpySync(dst, src, size,
                                               IoDirection::DtoD);
      break;

62
    case TargetType::kCUDA:
S
Superjomn 已提交
63 64 65
      TargetWrapper<TARGET(kCUDA)>::MemcpySync(dst, src, size,
                                               IoDirection::DtoD);
      break;
66 67
    default:
      LOG(FATAL) << "unsupported type";
S
Superjomn 已提交
68 69 70
  }
}

S
superjomn 已提交
71 72 73
// Memory buffer manager.
class Buffer {
 public:
S
update  
superjomn 已提交
74
  Buffer() = default;
S
superjomn 已提交
75 76 77
  Buffer(TargetType target, size_t size) : space_(size), target_(target) {}

  void* data() const { return data_; }
S
Superjomn 已提交
78 79
  TargetType target() const { return target_; }
  size_t space() const { return space_; }
S
superjomn 已提交
80 81 82 83

  void ResetLazy(TargetType target, size_t size) {
    if (target != target_ || space_ < size) {
      Free();
84 85 86
      data_ = TargetMalloc(target, size);
      target_ = target;
      space_ = size;
S
superjomn 已提交
87 88 89 90 91 92 93 94 95 96 97 98 99
    }
  }

  void ResizeLazy(size_t size) { ResetLazy(target_, size); }

  void Free() {
    if (space_ > 0) {
      TargetFree(target_, data_);
    }
    target_ = TargetType::kHost;
    space_ = 0;
  }

S
Superjomn 已提交
100 101 102 103
  void CopyDataFrom(const Buffer& other, size_t nbytes) {
    target_ = other.target_;
    ResizeLazy(nbytes);
    // TODO(Superjomn) support copy between different targets.
S
Superjomn 已提交
104
    TargetCopy(target_, data_, other.data_, nbytes);
S
Superjomn 已提交
105 106
  }

S
superjomn 已提交
107
 private:
S
Superjomn 已提交
108
  // memory it actually malloced.
S
superjomn 已提交
109 110 111 112 113 114 115
  size_t space_{0};
  void* data_{nullptr};
  TargetType target_{TargetType::kHost};
};

}  // namespace lite
}  // namespace paddle