/** * Copyright 2019 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 "kernel/hccl/hccl_kernel_metadata.h" #include #include "utils/utils.h" #include "kernel/hccl/hcom_util.h" #include "session/anf_runtime_algorithm.h" namespace mindspore { namespace kernel { void HcclMetadataInfo(const CNodePtr &kernel_node, std::vector> *kernel_info_list) { MS_EXCEPTION_IF_NULL(kernel_info_list); MS_EXCEPTION_IF_NULL(kernel_node); std::string op_name = AnfAlgo::GetCNodeName(kernel_node); if (op_name != kAllGather && op_name != kAllReduce && op_name != kBroadcast && op_name != kReduceScatter) { MS_LOG(DEBUG) << "Hccl does not have op [" << op_name << "]"; return; } std::vector data_type_list{kNumberTypeFloat32, kNumberTypeFloat16, kNumberTypeInt8, kNumberTypeInt32}; std::vector input_format, output_format; std::vector input_type, output_type; for (const auto &data_type : data_type_list) { for (const auto &format : k4DSupportFormat) { auto builder = std::make_shared(); input_format.clear(); input_format.push_back(format); input_type.clear(); input_type.push_back(data_type); output_format.clear(); output_format.push_back(format); output_type.clear(); output_type.push_back(data_type); builder->SetInputsFormat(input_format); builder->SetInputsDeviceType(input_type); builder->SetOutputsFormat(output_format); builder->SetOutputsDeviceType(output_type); builder->SetKernelType(HCCL_KERNEL); kernel_info_list->emplace_back(builder->Build()); } } } } // namespace kernel } // namespace mindspore