/** * Copyright 2021 Huawei Technologies Co., Ltd * * 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 "single_op/task/rts_kernel_task_builder.h" #include "build_task_utils.h" namespace ge { namespace { const size_t kNumAddresses = 2; } // namespace Status RtsKernelTaskBuilder::BuildMemcpyAsyncTask(const OpDescPtr &op_desc, const domi::MemcpyAsyncDef &kernel_def, const SingleOpModelParam ¶m, std::unique_ptr &task) { task.reset(new(std::nothrow)MemcpyAsyncTask()); GE_CHECK_NOTNULL(task); task->SetOpDesc(op_desc); task->dst_max_ = kernel_def.dst_max(); task->count_ = kernel_def.count(); task->kind_ = static_cast(kernel_def.kind()); auto addresses = BuildTaskUtils::JoinAddresses(BuildTaskUtils::GetAddresses(op_desc, param, false)); if (addresses.size() != kNumAddresses) { GELOGE(INTERNAL_ERROR, "[Build][MemcpyAsyncTask] Invalid address count: %zu", addresses.size()); return INTERNAL_ERROR; } task->addresses_[0] = reinterpret_cast(addresses[0]); task->addresses_[1] = reinterpret_cast(addresses[1]); return SUCCESS; } } // namespace ge