* Copyright (c) 2025 Huawei Technologies Co., Ltd.
* This file is part of the MindStudio project.
*
* MindStudio is licensed under Mulan PSL v2.
* You can use this software according to the terms and conditions of the Mulan PSL v2.
* You may obtain a copy of Mulan PSL v2 at:
*
* http://license.coscl.org.cn/MulanPSL2
*
* THIS SOFTWARE IS PROVIDED ON AN "AS IS" BASIS, WITHOUT WARRANTIES OF ANY KIND,
* EITHER EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO NON-INFRINGEMENT,
* MERCHANTABILITY OR FIT FOR A PARTICULAR PURPOSE.
* See the Mulan PSL v2 for more details.
* -------------------------------------------------------------------------*/
#ifndef ANALYSIS_ASSOCIATION_CANN_TREE_BUILDER_H
#define ANALYSIS_ASSOCIATION_CANN_TREE_BUILDER_H
#include <memory>
#include <vector>
#include <map>
#include "analysis/csrc/domain/entities/tree/include/event.h"
#include "analysis/csrc/domain/entities/tree/include/event_queue.h"
#include "analysis/csrc/domain/entities/tree/include/tree.h"
#include "analysis/csrc/domain/services/parser/host/cann/cann_warehouse.h"
#include "analysis/csrc/infrastructure/utils/prof_common.h"
#include "analysis/csrc/infrastructure/utils/thread_pool.h"
namespace Analysis {
namespace Domain {
namespace Cann {
using EventQueue = Analysis::Domain::EventQueue;
using TreeNode = Analysis::Domain::TreeNode;
using Event = Analysis::Domain::Event;
using EventType = Analysis::Domain::EventType;
using EventInfo = Analysis::Domain::EventInfo;
using CANNWarehouse = Analysis::Domain::Host::Cann::CANNWarehouse;
using ThreadPool = Analysis::Utils::ThreadPool;
using EventQueuePair = std::pair<std::shared_ptr<EventQueue>, std::shared_ptr<EventQueue>>;
class TreeBuilder {
public:
TreeBuilder(std::shared_ptr<CANNWarehouse> &cannWarehouse, const uint32_t threadId)
: cannWarehouse_(cannWarehouse), threadId_(threadId)
{}
std::shared_ptr<TreeNode> Build();
void MultiThreadAddLevelEvents();
bool AddLevelEvents(std::shared_ptr<EventQueue> &events,
std::vector<std::shared_ptr<TreeNode>> &levelNodes,
EventType eventType) const;
bool AddTaskTrackEvents(std::shared_ptr<TreeNode> &treeNode,
std::shared_ptr<EventQueue> &events, uint16_t depth = 1);
std::shared_ptr<TreeNode> MakeDummyNode(const std::shared_ptr<Event>& event);
void LogTreeNode(std::shared_ptr<TreeNode> &treeNode);
private:
std::shared_ptr<TreeNode> BuildTree(std::shared_ptr<TreeNode>, int depth);
EventQueuePair GroupCtxIdEvents(std::shared_ptr<EventQueue> &ctxIdEvents);
void RecordTreeNode(const std::shared_ptr<TreeNode> &treeNode, const uint16_t &eventLevel);
std::shared_ptr<TreeNode> GenerateRoot();
static size_t GetEventOffset(size_t idx, std::shared_ptr<Event> &event,
std::vector<std::shared_ptr<TreeNode>> &levelNodes, EventType eventType);
private:
std::shared_ptr<EventQueue> kernelEvents_ = nullptr;
std::shared_ptr<CANNWarehouse> cannWarehouse_ = nullptr;
uint32_t threadId_ = 0;
std::vector<std::shared_ptr<TreeNode>> modelLevelNodes_;
std::vector<std::shared_ptr<TreeNode>> nodeLevelNodes_;
std::vector<std::shared_ptr<TreeNode>> hcclLevelNodes_;
std::vector<std::shared_ptr<TreeNode>> runtimeLevelNodes_;
};
}
}
}
#endif