sentry_gimbal_hzz/modules/daemon/daemon.h

78 lines
2.2 KiB
C
Raw Normal View History

2022-12-08 17:36:12 +08:00
#ifndef MONITOR_H
#define MONITOR_H
2022-12-12 22:29:51 +08:00
#include "stdint.h"
2023-06-23 17:05:55 +08:00
#include "string.h"
2022-12-08 17:36:12 +08:00
#define DAEMON_MX_CNT 64
/* 模块离线处理函数指针 */
typedef void (*offline_callback)(void *);
2023-06-23 17:05:55 +08:00
typedef enum
{
ALARM_OFF = 0,
ALARM_ON = 1,
}alarm_state_e;
typedef enum
{
ALARM_LEVEL_LOW = 0,
ALARM_LEVEL_BELOW_MEDIUM = 1,
ALARM_LEVEL_MEDIUM = 2,
ALARM_LEVEL_ABOVE_MEDIUM = 3,
ALARM_LEVEL_HIGH = 4,
ALARM_OFFLINE = 5,
}alarm_level_e;
2022-12-08 17:36:12 +08:00
/* daemon结构体定义 */
typedef struct daemon_ins
{
uint16_t reload_count; // 重载值
2022-12-08 17:36:12 +08:00
offline_callback callback; // 异常处理函数,当模块发生异常时会被调用
2023-06-23 17:05:55 +08:00
alarm_state_e alarm_state; // 蜂鸣器状态
alarm_level_e alarm_level; //警报级别
uint16_t temp_count; // 当前值,减为零说明模块离线或异常
void *owner_id; // daemon实例的地址,初始化的时候填入
2022-12-08 17:36:12 +08:00
} DaemonInstance;
/* daemon初始化配置 */
typedef struct
{
2023-01-01 17:32:22 +08:00
uint16_t reload_count; // 实际上这是app唯一需要设置的值?
offline_callback callback; // 异常处理函数,当模块发生异常时会被调用
2023-06-23 17:05:55 +08:00
alarm_state_e alarm_state; // 蜂鸣器状态
alarm_level_e alarm_level; //警报级别
2023-01-01 17:32:22 +08:00
void *owner_id; // id取拥有daemon的实例的地址,如DJIMotorInstance*,cast成void*类型
2022-12-08 17:36:12 +08:00
} Daemon_Init_Config_s;
/**
* @brief daemon实例
*
2022-12-08 17:36:12 +08:00
* @param config
* @return DaemonInstance*
*/
DaemonInstance *DaemonRegister(Daemon_Init_Config_s *config);
/**
* @brief ,temp_count,"喂狗"
*
2022-12-08 17:36:12 +08:00
* @param instance daemon实例指针
*/
void DaemonReload(DaemonInstance *instance);
/**
* @brief 线
*
2022-12-08 17:36:12 +08:00
* @param instance daemon实例指针
* @return uint8_t 线,1;. 线.
*/
uint8_t DaemonIsOnline(DaemonInstance *instance);
/**
* @brief rtos中,daemon实例的temp_count按频率进行递减操作.
* temp_count的值为reload_count.
*
2022-12-08 17:36:12 +08:00
*/
void DaemonTask();
#endif // !MONITOR_H