78 lines
2.2 KiB
C
78 lines
2.2 KiB
C
#ifndef MONITOR_H
|
|
#define MONITOR_H
|
|
|
|
#include "stdint.h"
|
|
#include "string.h"
|
|
|
|
#define DAEMON_MX_CNT 64
|
|
|
|
/* 模块离线处理函数指针 */
|
|
typedef void (*offline_callback)(void *);
|
|
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;
|
|
/* daemon结构体定义 */
|
|
typedef struct daemon_ins
|
|
{
|
|
uint16_t reload_count; // 重载值
|
|
offline_callback callback; // 异常处理函数,当模块发生异常时会被调用
|
|
alarm_state_e alarm_state; // 蜂鸣器状态
|
|
alarm_level_e alarm_level; //警报级别
|
|
|
|
uint16_t temp_count; // 当前值,减为零说明模块离线或异常
|
|
void *owner_id; // daemon实例的地址,初始化的时候填入
|
|
} DaemonInstance;
|
|
|
|
/* daemon初始化配置 */
|
|
typedef struct
|
|
{
|
|
uint16_t reload_count; // 实际上这是app唯一需要设置的值?
|
|
offline_callback callback; // 异常处理函数,当模块发生异常时会被调用
|
|
alarm_state_e alarm_state; // 蜂鸣器状态
|
|
alarm_level_e alarm_level; //警报级别
|
|
|
|
void *owner_id; // id取拥有daemon的实例的地址,如DJIMotorInstance*,cast成void*类型
|
|
} Daemon_Init_Config_s;
|
|
|
|
/**
|
|
* @brief 注册一个daemon实例
|
|
*
|
|
* @param config 初始化配置
|
|
* @return DaemonInstance* 返回实例指针
|
|
*/
|
|
DaemonInstance *DaemonRegister(Daemon_Init_Config_s *config);
|
|
|
|
/**
|
|
* @brief 当模块收到新的数据或进行其他动作时,调用该函数重载temp_count,相当于"喂狗"
|
|
*
|
|
* @param instance daemon实例指针
|
|
*/
|
|
void DaemonReload(DaemonInstance *instance);
|
|
|
|
/**
|
|
* @brief 确认模块是否离线
|
|
*
|
|
* @param instance daemon实例指针
|
|
* @return uint8_t 若在线且工作正常,返回1;否则返回零. 后续根据异常类型和离线状态等进行优化.
|
|
*/
|
|
uint8_t DaemonIsOnline(DaemonInstance *instance);
|
|
|
|
/**
|
|
* @brief 放入rtos中,会给每个daemon实例的temp_count按频率进行递减操作.
|
|
* 模块成功接受数据或成功操作则会重载temp_count的值为reload_count.
|
|
*
|
|
*/
|
|
void DaemonTask();
|
|
|
|
#endif // !MONITOR_H
|