/** * Copyright 2019-2020 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/build_task_utils.h" #include "runtime/rt.h" #include "graph/load/new_model_manager/model_utils.h" #include "graph/manager/graph_var_manager.h" #include "graph/utils/type_utils.h" #include "framework/common/debug/ge_log.h" #include "framework/common/types.h" namespace ge { namespace { const uint64_t kSessionId = UINT64_MAX; uint8_t *kVarBase = nullptr; const uint64_t kLogicVarBase = 0; const uint64_t kVarSize = 0; } // namespace std::vector> BuildTaskUtils::GetAddresses(const OpDescPtr &op_desc, const SingleOpModelParam ¶m) { std::vector> ret; RuntimeParam runtime_para; runtime_para.mem_size = param.memory_size; runtime_para.logic_mem_base = param.base_addr; runtime_para.mem_base = param.mem_base; runtime_para.weight_size = param.weight_size; runtime_para.logic_weight_base = param.weight_addr; runtime_para.weight_base = param.weight_base; runtime_para.var_size = kVarSize; runtime_para.logic_var_base = kLogicVarBase; runtime_para.var_base = kVarBase; runtime_para.session_id = kSessionId; ret.emplace_back(ModelUtils::GetInputDataAddrs(runtime_para, op_desc)); ret.emplace_back(ModelUtils::GetOutputDataAddrs(runtime_para, op_desc)); ret.emplace_back(ModelUtils::GetWorkspaceDataAddrs(runtime_para, op_desc)); return ret; } std::vector BuildTaskUtils::JoinAddresses(const std::vector> &addresses) { std::vector ret; for (auto &address : addresses) { ret.insert(ret.end(), address.begin(), address.end()); } return ret; } std::vector BuildTaskUtils::GetKernelArgs(const OpDescPtr &op_desc, const SingleOpModelParam ¶m) { auto addresses = GetAddresses(op_desc, param); return JoinAddresses(addresses); } std::string BuildTaskUtils::GetTaskInfo(const OpDescPtr &op_desc) { std::stringstream ss; if (op_desc != nullptr) { auto op_type = op_desc->GetType(); if (op_type == ge::NETOUTPUT || op_type == ge::DATA) { return ss.str(); } // Conv2D IN[DT_FLOAT16 NC1HWC0[256, 128, 7, 7, 16],DT_FLOAT16 FRACTAL_Z[128, 32, 16, 16]] // OUT[DT_FLOAT16 NC1HWC0[256, 32, 7, 7, 16]] ss << op_type << " IN["; for (uint32_t idx = 0; idx < op_desc->GetInputsSize(); idx++) { const GeTensorDescPtr &input = op_desc->MutableInputDesc(idx); ss << TypeUtils::DataTypeToSerialString(input->GetDataType()) << " "; ss << TypeUtils::FormatToSerialString(input->GetFormat()); ss << VectorToString(input->GetShape().GetDims()); if (idx < op_desc->GetInputsSize() - 1) { ss << ","; } } ss << "] OUT["; for (uint32_t idx = 0; idx < op_desc->GetOutputsSize(); idx++) { const GeTensorDescPtr &output = op_desc->MutableOutputDesc(idx); ss << TypeUtils::DataTypeToSerialString(output->GetDataType()) << " "; Format out_format = output->GetFormat(); const GeShape &out_shape = output->GetShape(); const auto &dims = out_shape.GetDims(); ss << TypeUtils::FormatToSerialString(out_format); ss << VectorToString(dims); if (idx < op_desc->GetOutputsSize() - 1) { ss << ","; } } ss << "]\n"; } return ss.str(); } } // namespace ge