* Copyright (c) 2025 Huawei Technologies Co., Ltd.
* This program is free software, you can redistribute it and/or modify it under the terms and conditions of
* CANN Open Software License Agreement Version 2.0 (the "License").
* Please refer to the License for details. You may not use this file except in compliance with the License.
* 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 FITNESS FOR A PARTICULAR PURPOSE.
* See LICENSE in the root of the software repository for the full text of the License.
*/
#ifndef MSPROF_ENGINE_PROF_ENGINE_H
#define MSPROF_ENGINE_PROF_ENGINE_H
#define MSVP_PROF_API __attribute__((visibility("default")))
#include <map>
#include <string>
#include "prof_reporter.h"
* @file prof_engine.h
* @defgroup ModuleJobConfig the ModuleJobConfig group
* This is the ModuleJobConfig group
*/
namespace Msprof {
namespace Engine {
* @ingroup ModuleJobConfig
* @brief struct ModuleJobConfig
* record config info
*/
struct ModuleJobConfig {
std::map<std::string, std::string> switches;
};
* @defgroup PluginIntf the pluginInf group
* This is the pluginInf group
*/
* @ingroup PluginIntf
* @brief class PluginIntf
*/
class MSVP_PROF_API PluginIntf {
public:
virtual ~PluginIntf() {}
public:
* @ingroup PluginIntf
* @name : Init
* @brief : API of user plugin, libmsporf call this API to send a Reporter to user plugin
* @par description :
* API of user plugin, libmsporf call this API to send a Reporter to user plugin.
* @param reporter [IN] const Reporter* the Reporter from libmsprof
* @retval PROFILING_SUCCESS 0 (success)
* @retval PROFILING_FAILED -1 (failed)
*
* @par depend:
* @li libmsprof
* @li prof_engine.h
* @since c60
* @see UnInit
*/
virtual int32_t Init(const Reporter *reporter) = 0;
* @ingroup PluginIntf
* @name : OnNewConfig
* @brief : API of user plugin, libmsprof call this API to send config info to user plugin \n
If the user plugin needn't config, no need to redefine this function
* @param config [IN] const ModuleJobConfig * the config from libmsprof
* @retval PROFILING_SUCCESS 0 (success)
* @retval PROFILING_FAILED -1 (failed)
*
* @par depend:
* @li libmsprof
* @li prof_engine.h
* @since c60
* @see Init | UnInit
*/
virtual int32_t OnNewConfig(const ModuleJobConfig *config) = 0;
* @ingroup PluginIntf
* @name : UnInit
* @brief : API of user plugin, libmsprof call this API to notify plugin stop to send data
* @retval PROFILING_SUCCESS 0 (success)
* @retval PROFILING_FAILED -1 (failed)
*
* @par depend:
* @li libmsprof
* @li prof_engine.h
* @since c60
* @see Init
*/
virtual int32_t UnInit() = 0;
};
* @defgroup EngineIntf the EngineIntf group
* This is the EngineIntf group
*/
* @ingroup EngineIntf
* @brief class EngineIntf
*/
class MSVP_PROF_API EngineIntf {
public:
virtual ~EngineIntf() {}
public:
* @ingroup EngineIntf
* @name : CreatePlugin
* @brief : API of user engine, libmsporf call this API to get a plugin
* @retval PluginIntf * The pointer of the new plugin
*
* @par depend:
* @li libmsprof
* @li prof_engine.h
* @since c60
* @see ReleasePlugin
*/
virtual PluginIntf *CreatePlugin() = 0;
* @ingroup EngineIntf
* @name : ReleasePlugin
* @brief : API of user engine, libmsprof call this API to release a plugin
* @param plugin [IN] PluginIntf * the plugin to release
* @retval PROFILING_SUCCESS 0 (success)
* @retval PROFILING_FAILED -1 (failed)
*
* @par depend:
* @li libmsprof
* @li prof_engine.h
* @since c60
* @see CreatePlugin
*/
virtual int32_t ReleasePlugin(PluginIntf *plugin) = 0;
};
* @defgroup EngineMgr the EngineMgr group
* This is the EngineMgr group
*/
* @ingroup EngineMgr
* @name : Init
* @brief : API of libmsprof, init an engine with a name
* @param module [IN] const std::string the name of plugin
* @param module [IN] const EngineIntf* the plugin
* @retval PROFILING_SUCCESS 0 (success)
* @retval PROFILING_FAILED -1 (failed)
*
* @par depend:
* @li libmsprof
* @li prof_engine.h
* @since c60
* @see UnInit
*/
MSVP_PROF_API int32_t Init(const std::string &module, const EngineIntf *engine);
* @ingroup EngineMgr
* @name : Init
* @brief : API of libmsprof, uninit an engine with a name
* @param module [IN] const std::string the name of plugin
* @retval PROFILING_SUCCESS 0 (success)
* @retval PROFILING_FAILED -1 (failed)
*
* @par depend:
* @li libmsprof
* @li prof_engine.h
* @since c60
* @see Init
*/
MSVP_PROF_API int32_t UnInit(const std::string &module);
}
}
#endif