target_wrapper.cc 2.0 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21
// 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.

#include "lite/backends/xpu/target_wrapper.h"

namespace paddle {
namespace lite {

void* TargetWrapperXPU::Malloc(size_t size) {
  void* ptr{nullptr};
22
  XPU_CALL(xpu_malloc(&ptr, size));
23 24 25
  return ptr;
}

26
void TargetWrapperXPU::Free(void* ptr) { XPU_CALL(xpu_free(ptr)); }
27 28 29 30 31 32 33

void TargetWrapperXPU::MemcpySync(void* dst,
                                  const void* src,
                                  size_t size,
                                  IoDirection dir) {
  switch (dir) {
    case IoDirection::HtoD:
34
      XPU_CALL(xpu_memcpy(dst, src, size, XPU_HOST_TO_DEVICE));
35 36
      break;
    case IoDirection::DtoH:
37
      XPU_CALL(xpu_memcpy(dst, src, size, XPU_DEVICE_TO_HOST));
38 39 40 41 42 43
      break;
    default:
      LOG(FATAL) << "Unsupported IoDirection " << static_cast<int>(dir);
  }
}

44 45 46 47 48 49 50 51
XPUScratchPadGuard TargetWrapperXPU::MallocScratchPad(size_t size,
                                                      bool use_l3) {
  void* ptr{nullptr};
  if (use_l3) {
    ptr = xdnn::alloc_workspace(GetRawContext(), size);
  } else {
    ptr = TargetWrapperXPU::Malloc(size);
  }
52
  CHECK(ptr != nullptr) << "size = " << size << ", use_l3 = " << use_l3;
53 54 55 56 57 58 59
  return XPUScratchPadGuard(new XPUScratchPad(ptr, use_l3));
}

std::string TargetWrapperXPU::multi_encoder_precision;  // NOLINT
int TargetWrapperXPU::workspace_l3_size_per_thread{0};
thread_local xdnn::Context* TargetWrapperXPU::tls_raw_ctx_{nullptr};

60 61
}  // namespace lite
}  // namespace paddle