/** * 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. */ #ifndef GE_GE_RUNTIME_TASK_HCCL_TASK_H_ #define GE_GE_RUNTIME_TASK_HCCL_TASK_H_ #include #include #include #include #include #include "ge_runtime/task/task.h" namespace ge { namespace model_runner { class HcclTask : public TaskRepeater { public: HcclTask(const ModelContext &model_context, const std::shared_ptr &task_info); ~HcclTask() override; bool Distribute() override; private: class StreamGuard; bool SetSecondaryStream(); bool CreateStream(int64_t stream_num, int64_t master_stream_id); bool CreateStream(rtModel_t model, rtStream_t *stream) const; void SaveHcclSecondaryStream(int64_t master_stream_id, const std::shared_ptr &stream); std::shared_ptr task_info_; void *stream_; void *workspace_mem_; rtModel_t rt_model_handle_; int32_t priority_; std::vector> secondary_stream_list_; // map>> static std::map>>> model_stream_mapping_; static std::mutex model_stream_mapping_mutex_; }; class HcclTask::StreamGuard { public: StreamGuard(rtModel_t model, rtStream_t stream) : model_(model), stream_(stream) {} ~StreamGuard(); rtStream_t GetStream() const { return stream_; } private: rtModel_t model_; rtStream_t stream_; }; } // namespace model_runner } // namespace ge #endif // GE_GE_RUNTIME_TASK_HCCL_TASK_H_