/** * 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 INC_FRAMEWORK_GE_RUNTIME_DAVINCI_MODEL_H_ #define INC_FRAMEWORK_GE_RUNTIME_DAVINCI_MODEL_H_ #include #include #include "ge_runtime/op_info.h" #include "ge_runtime/task_info.h" namespace ge { namespace model_runner { class DavinciModel { public: DavinciModel(const std::vector> &task_info_list, const std::vector> &data_info_list, const std::vector> &output_info_list, const std::vector> &constant_info_list, const std::vector &variable_info_list, const std::vector &wait_active_stream_list, const std::vector &force_copy_stream_list, uint64_t mem_size = 0, uint64_t weight_size = 0, uint64_t var_size = 0, uintptr_t logic_mem_base = 0, uintptr_t logic_weight_base = 0, uintptr_t logic_var_base = 0, uint32_t stream_num = 0, uint32_t batch_num = 0, uint32_t event_num = 0, int32_t priority = 0) : task_info_list_(task_info_list), data_info_list_(data_info_list), output_info_list_(output_info_list), constant_info_list_(constant_info_list), variable_info_list_(variable_info_list), wait_active_stream_list_(wait_active_stream_list), force_copy_stream_list_(force_copy_stream_list), mem_size_(mem_size), weight_size_(weight_size), var_size_(var_size), logic_mem_base_(logic_mem_base), logic_weight_base_(logic_weight_base), logic_var_base_(logic_var_base), stream_num_(stream_num), batch_num_(batch_num), event_num_(event_num), priority_(priority) {} ~DavinciModel() {} uint64_t GetMemSize() const { return mem_size_; } uint64_t GetWeightSize() const { return weight_size_; } uint64_t GetVarSize() const { return var_size_; } uintptr_t GetLogicMemBase() const { return logic_mem_base_; } uintptr_t GetLogicWeightBase() const { return logic_weight_base_; } uintptr_t GetLogicVarBase() const { return logic_var_base_; } uint32_t GetStreamNum() const { return stream_num_; } uint32_t GetBatchNum() const { return batch_num_; } uint32_t GetEventNum() const { return event_num_; } const std::vector &GetWaitActiveStreams() const { return wait_active_stream_list_; } const std::vector &GetForceCopyStreams() const { return force_copy_stream_list_; } int32_t GetPriority() const { return priority_; } const std::vector> &GetTaskInfoList() const { return task_info_list_; } const std::vector> &GetDataInfoList() const { return data_info_list_; } const std::vector> &GetOutputInfoList() const { return output_info_list_; } const std::vector> &GetConstantInfoList() const { return output_info_list_; } const std::vector &GetVariableInfoList() const { return variable_info_list_; } private: std::vector> task_info_list_; std::vector> data_info_list_; std::vector> output_info_list_; std::vector> constant_info_list_; std::vector variable_info_list_; std::vector wait_active_stream_list_; std::vector force_copy_stream_list_; uint64_t mem_size_; uint64_t weight_size_; uint64_t var_size_; uintptr_t logic_mem_base_; uintptr_t logic_weight_base_; uintptr_t logic_var_base_; uint32_t stream_num_; uint32_t batch_num_; uint32_t event_num_; int32_t priority_; // Disable to copy constructor and assignment operator DavinciModel &operator=(const DavinciModel &) = delete; DavinciModel(const DavinciModel &) = delete; }; } // namespace model_runner } // namespace ge #endif // INC_FRAMEWORK_GE_RUNTIME_DAVINCI_MODEL_H_