From 980cd6a4ffe3e62ca4a78fd42e689f164542c524 Mon Sep 17 00:00:00 2001 From: Fancy code <258828110.@qq.com> Date: Thu, 9 May 2024 20:37:21 +0800 Subject: [PATCH] Add readme files. --- middleware/McuManager/README.md | 320 ++++++++++++++++++++++++++++++++ utils/McuProtocol/README.md | 151 +++++++++++++++ 2 files changed, 471 insertions(+) create mode 100644 middleware/McuManager/README.md create mode 100644 utils/McuProtocol/README.md diff --git a/middleware/McuManager/README.md b/middleware/McuManager/README.md new file mode 100644 index 0000000..2bc02a9 --- /dev/null +++ b/middleware/McuManager/README.md @@ -0,0 +1,320 @@ +# 1. 打猎相机外置MCU软件设计 + +  为满足打猎相机的低功耗需求,使用外置MCU的硬件设计框架,在非工作状态下保持外置MCU供电,CPU断电,满足低功耗的产品需求。 + +## 1.1. 基本概念 + +* **启动模式:决定CPU单次启动的任务内容;** + +  每次启动的时间都是有限的,由CPU完成单次启动完成任务后发送断电关机指令给MCU,MCU给CPU断开物理电源;启动模式可以由CPU主动询问,也可以由MCU主动发送。 + +| 启动模式 | 说明 | +| ---- | ---- | +| PIR启动 | PIR触发启动。 | +| TEST启动 | 三档拨键拨到“TEST”,常通电的工作模式。 | +| 连拍启动 | PIR触发场景下,用户可以设置连拍的张数和连拍的间隔,CPU通过协议告诉MCU在多少时间之后进行连拍启动。 | +| PIR延时启动 | 同PIR启动,只是PIR触发后,需要延时一段时间再给CPU上电。 | +| 定时启动 | 间隔固定时间启动一次,例如:60min/次 | +| 关机启动 | 某种场景下需要关机,给CPU上电一次,由CPU正式下发“关机”指令。 | +| 低电关机 | 电池低电需要关机,给CPU上电一次,由CPU正式下发“关机”指令。 | +| 异常启动 | CPU不正常时断电重启,例如:喂狗异常,心跳异常。 | + +* **工作状态:** + +| 工作状态 | 说明 | +| ---- | ---- | +| OFF状态 | 整机处于断电状态,包括外置MCU和主控。 | +| TEST状态 | 非正常工作状态,此时主控常通电,除非无操作时自动切换到ON状态。 | +| ON状态 | 设备正常工作状态,必须保证低功耗性能,PIR触发抓拍后必须快速关机(主控断电)。 | + +  工作模式对应板子上的三档拨键,有三个工作模式:关机/TEST/ON。 + +## 1.2. MCU基本功能 + +* 外围连接RTC,PIR传感器; +* 保存数据包括:CPU的启动模式,CPU定时启动时间,工作时间周期; +* 使用串口协议与CPU进行数据/功能协议交互; + +| 需要保存的数据 | 说明 | +| ---- | ---- | +| 启动模式 | ---- | +| 定时启动时间 | 例如:60min/次 | +| 工作时间 | 打猎机正常PIR触发的时间周期,例如:2:00 ~ 20:00 | +| PIR灵敏度 | PIR灵敏度设置 | + +**存疑:** + +硬件光敏接在主控上,先由主控内置MCU控制,正常启动后Linux是否可以复用此GPIO口。 + +## 1.3. 功能UML时序图 + +### 1.3.1. 整机物理上电启动 + +  整机物理上电时,根据实际情况刷新设备的工作状态。 + +```mermaid +sequenceDiagram +participant CPU +participant MCU +MCU ->> MCU:物理上电 +MCU ->> MCU:串口初始化 +opt 检测到TEST拨档挡位 + MCU ->> CPU:物理上电 + MCU ->> +CPU:发送启动模式:TEST启动 + CPU ->> CPU:TEST启动 + CPU -->> -MCU:回复OK + loop 无操作 + CPU ->> +MCU:发送关机指令 + MCU -->> -CPU:回复OK + MCU ->> CPU:物理断电 + end +end +opt 检测到ON拨档挡位 +note over MCU:正常工作模式,PIR触发后可给主控上电 +end +opt PIR触发中断 + MCU ->> CPU:物理上电 + MCU ->> +CPU:发送PIR触发启动 + CPU ->> CPU:PIR启动 + CPU -->> -MCU:回复OK + CPU ->> +MCU:发送关机指令 + MCU -->> -CPU:回复OK + MCU ->> CPU:物理断电 +end +MCU ->> MCU:休眠 +note over MCU:休眠后进入正常工作模式:当发生PIR触发时,
给CPU物理上电并发送PIR启动命令 +``` + +### 1.3.2. MCU休眠逻辑 + +  合理的休眠设计,最大降低产品功耗,延长单次换电的使用周期。 + +```mermaid +sequenceDiagram +participant CPU +participant MCU +loop 常通电待机 + opt CPU关机 + CPU ->> MCU:发送关机指令 + MCU ->> CPU:物理断电 + MCU ->> MCU:休眠 + end + opt PIR触发中断 + MCU ->> MCU:休眠唤醒 + MCU ->> CPU:物理上电 + MCU ->> +CPU:发送PIR触发启动 + CPU -->> -MCU:回复OK + end + opt TEST按键中断 + MCU ->> MCU:休眠唤醒 + MCU ->> CPU:物理上电 + MCU ->> +CPU:发送TEST启动 + CPU -->> -MCU:回复OK + end + opt 设置定时唤醒 + CPU ->> MCU:发送设置定时唤醒协议 + opt 定时唤醒中断 + MCU ->> MCU:休眠唤醒 + MCU ->> CPU:物理上电 + MCU ->> +CPU:发送定时唤醒启动 + CPU -->> -MCU:回复OK + end + end +end +``` + +### 1.3.3. 常通电待机 + +  描述上电后的各种场景。 + +#### 1.3.3.1. 定时唤醒刷新环境数据(**待定,忽略**) + +  MCU定时唤醒更新环境参数,保证工作触发时的环境参数正确性。 + +```mermaid +sequenceDiagram +participant CPU +participant MCU +loop 常通电待机 + loop 大循环定时中断(20min/次) + note over MCU:大循环定时中断负责定时触发小循环定时中断 + opt 定时唤醒中断 + loop 小循环采集数据(1s/次,共30次) + note over MCU:小循环定时器,短时间间隔唤醒,多次采集环境数据,
计算出合理稳定的环境参数并保存,在工作时可快速响应。 + MCU ->> MCU:采集环境数据 + note right of MCU:采集光敏数据 + opt 采集30次完成 + note over MCU:计算平均值作为单次采集的真实数据 + MCU ->> MCU:计算30次平均值 + opt 对比上次发生翻转 + MCU ->> MCU:保存最新数据(白天/黑夜) + MCU ->> +CPU:发送数据同步任务 + CPU -->> -MCU:回复OK + MCU ->> CPU:物理上电 + CPU ->> +MCU:读取白天黑夜数据 + MCU -->> -CPU:回复白天黑夜数据 + CPU ->> MCU:断电关机 + MCU ->> CPU:物理断电 + end + end + end + end + end +end +``` + +#### 1.3.3.2. 喂狗 + +  外置MCU充当硬件狗,在系统异常时断电重启系统。喂狗逻辑和启动模式无关。 + +```mermaid +sequenceDiagram +participant CPU +participant MCU +MCU ->> MCU:物理上电 +MCU ->> CPU:某种启动模式触发物理上电 +opt 主控开启喂狗 + CPU ->> +MCU:开启狗/设置喂狗周期 + MCU -->> -CPU:回复OK + loop 主控喂狗 + note over MCU:喂狗不需要回复 + CPU ->> MCU:喂狗 + end + loop MCU定时查狗 + alt 主控喂狗异常 + MCU ->> CPU:断电重启 + MCU ->> +CPU:发送启动模式:喂狗异常启动 + CPU ->> CPU:喂狗异常启动 + CPU -->> -MCU:回复OK + CPU ->> MCU:断电关机 + end + end +end +CPU ->> MCU:断电关机 +MCU ->> CPU:物理断电 +MCU ->> MCU:休眠 +note over MCU:休眠后进入正常工作模式:当发生PIR触发时,
给CPU物理上电并发送PIR启动命令 +``` + +#### 1.3.3.3. 心跳 + +  CPU单次上电时间都是有限的,在主控未主动开启喂狗时,30s主动查询一次心跳,未回复则断电重启。此设计保证程序异常时电量不会一直消耗完。 + +**注意:** 整机上电之后如果从来未开启过喂狗功能,此功能不生效。避免调试版本不停重启。 + +```mermaid +sequenceDiagram +participant CPU +participant MCU +MCU ->> MCU:物理上电 +MCU ->> CPU:某种启动模式触发物理上电 +opt 主控开启喂狗 + CPU ->> +MCU:开启狗/设置喂狗周期 + MCU -->> -CPU:回复OK + MCU ->> MCU:激活心跳功能 +end +CPU ->> MCU:断电关机 +MCU ->> CPU:物理断电 +MCU ->> MCU:休眠 +note over MCU:只要CPU某次启动开启喂狗功能,下次启动心跳功能就会生效。 + +MCU ->> CPU:某种启动模式触发物理上电 +opt 心跳功能已经激活 +note over MCU:心跳功能在主控未开启喂狗时(异常)发挥作用。 + opt 主控未开启喂狗 + loop 30s主动查询一次心跳 + MCU ->> +CPU:发送心跳包 + alt 心跳回复 + CPU -->> -MCU:回复OK + else 5s超时, 心跳未回复 + MCU ->> CPU:断电重启 + MCU ->> +CPU:发送启动模式:心跳异常启动 + CPU ->> CPU:心跳异常启动 + CPU -->> -MCU:回复OK + CPU ->> MCU:断电关机 + end + end + end +CPU ->> MCU:断电关机 +MCU ->> CPU:物理断电 +MCU ->> MCU:休眠 +end +``` + +#### 1.3.3.4. PIR触发任务 + +  PIR触发是相机的正常工作模式,相机会快速启动抓拍,并快速关机。 + +```mermaid +sequenceDiagram +participant CPU +participant MCU +loop 常通电待机 + opt PIR触发中断 + MCU ->> MCU:休眠唤醒 + MCU ->> CPU:物理上电 + MCU ->> +CPU:发送PIR触发启动模式 + CPU ->> CPU:PIR启动 + CPU -->> -MCU:回复OK + CPU ->> MCU:断电关机 + MCU ->> CPU:物理断电 + MCU ->> MCU:休眠 + end +end +``` + +#### 1.3.3.5. TEST拨键启动 + +  TEST模式,相机处于一个长通电状态,功耗较高,长时间无操作会进入正常工作状态。 + +**存疑:** 实际使用时,当有人把按键从ON拨到TEST时,大概率会先触发PIR启动,再触发TEST启动。 + +```mermaid +sequenceDiagram +participant CPU +participant MCU +MCU ->> MCU:常电待机 +opt 拨键从ON拨到TEST +note over MCU:TEST模式启动,只会发生在从ON切换到TEST的瞬间,
如果PIR触发时,已经处于TEST挡位,此时不影响PIR模式启动 + MCU ->> CPU:物理上电 + MCU ->> +CPU:发送启动模式:TEST启动 + CPU ->> CPU:TEST启动 + CPU -->> -MCU:回复OK + opt 拨键从TEST拨到ON + note over MCU:进入ON模式,设备处于正常工作状态 + CPU ->> MCU:发送断电关机 + MCU ->> CPU:物理断电 + end + opt CPU关机 + note over MCU:超时关机时,
此时拨键还是处于“TEST”挡位的 + CPU ->> MCU:发送断电关机 + MCU ->> CPU:物理断电 + end +end +MCU ->> MCU:休眠 +``` + +#### 1.3.3.6. 数据同步 + +  主控和外置MCU之间数据同步,包括主控发给外置MCU的,也包括外置MCU发给主控的。数据同步流程可以在任意的工作状态下进行。 + +```mermaid +sequenceDiagram +participant CPU +participant MCU +MCU ->> MCU:物理上电 +MCU ->> CPU:某种启动模式触发物理上电 +opt 数据同步 +note over MCU:此处根据协议只做一个数据示例,其它协议雷同。 + CPU ->> +MCU:设置灵敏度 + MCU -->> -CPU:回复OK +end +CPU ->> MCU:断电关机 +MCU ->> CPU:物理断电 +MCU ->> MCU:休眠 +note over MCU:休眠后进入正常工作模式:当发生PIR触发时,
给CPU物理上电并发送PIR启动命令 +``` + +## 1.4. MCU协议 + +  负责对MCU协议进行封包/解包,协议封包/解包功能独立封装成库,详见[协议文档](../../utils/McuProtocol/README.md)。 \ No newline at end of file diff --git a/utils/McuProtocol/README.md b/utils/McuProtocol/README.md new file mode 100644 index 0000000..097b21f --- /dev/null +++ b/utils/McuProtocol/README.md @@ -0,0 +1,151 @@ + +# 1. MCU协议模块 + +  负责对MCU协议进行封包/解包,负责协议的多态替换。协议数据统一使用网络字节序(大端字节序)。 + +## 1.1. 协议格式 + +| 协议头 | 流水号 | 命令字 | 长度 | 数据段 | 校验码 | +|----|----|----|----|----|----| +| 2字节
0xFAC1 | 4字节 | 2字节 | 2字节 | - | 2字节 | + +**流水号** + +  流水号用于强绑定问答型协议的发送数据和回复数据,回复者原数据回传即可。例如: + +``` +unsigned char ASK_IPC_MISSION[] = {0xFA, 0xC1, 0x00, 0x00, 0x00, 0x01, 0x81, 0x01, 0x00, 0x0C, 0x71, 0x88}; +unsigned char REPLY_IPC_MISSION[] = {0xFA, 0xC1, 0x00, 0x00, 0x00, 0x01, 0x01, 0x01, 0x00, 0x0D, 0x01, 0xAA, 0x89}; +``` + +  流水号管理发送方和接收方互相独立,各自往外发的协议中流水号存在重复的可能,接收方直接复制回传即可。 + +  流水号必须大于等于1,0用于代码初始化值,代码意义上表示无效的流水号。 + +**协议收发匹配逻辑** +  协议发送时,附带自管理的流水号,对端回复时,根据流水号绑定发送的协议,为了避免对端回复时,流水号错误导致的业务逻辑错乱,本端除了匹配流水号,还需要根据协议匹配回复的命令字,保证回复内容的有效匹配。如果流水号和命令字无法同时匹配,该回复的数据包被丢弃。 + +**校验码算法** + +  校验码算法使用ModBus CRC16方法计算。 + +**参考代码(查表法)** + +``` +/* Table of CRC values for high–order byte */ +unsigned char chCRCHi[] ={ + 0x00, 0xC1, 0x81, 0x40, 0x01, 0xC0, 0x80, 0x41, 0x01, 0xC0, + 0x80, 0x41, 0x00, 0xC1, 0x81, 0x40, 0x01, 0xC0, 0x80, 0x41, + 0x00, 0xC1, 0x81, 0x40, 0x00, 0xC1, 0x81, 0x40, 0x01, 0xC0, + 0x80, 0x41, 0x01, 0xC0, 0x80, 0x41, 0x00, 0xC1, 0x81, 0x40, + 0x00, 0xC1, 0x81, 0x40, 0x01, 0xC0, 0x80, 0x41, 0x00, 0xC1, + 0x81, 0x40, 0x01, 0xC0, 0x80, 0x41, 0x01, 0xC0, 0x80, 0x41, + 0x00, 0xC1, 0x81, 0x40, 0x01, 0xC0, 0x80, 0x41, 0x00, 0xC1, + 0x81, 0x40, 0x00, 0xC1, 0x81, 0x40, 0x01, 0xC0, 0x80, 0x41, + 0x00, 0xC1, 0x81, 0x40, 0x01, 0xC0, 0x80, 0x41, 0x01, 0xC0, + 0x80, 0x41, 0x00, 0xC1, 0x81, 0x40, 0x00, 0xC1, 0x81, 0x40, + 0x01, 0xC0, 0x80, 0x41, 0x01, 0xC0, 0x80, 0x41, 0x00, 0xC1, + 0x81, 0x40, 0x01, 0xC0, 0x80, 0x41, 0x00, 0xC1, 0x81, 0x40, + 0x00, 0xC1, 0x81, 0x40, 0x01, 0xC0, 0x80, 0x41, 0x01, 0xC0, + 0x80, 0x41, 0x00, 0xC1, 0x81, 0x40, 0x00, 0xC1, 0x81, 0x40, + 0x01, 0xC0, 0x80, 0x41, 0x00, 0xC1, 0x81, 0x40, 0x01, 0xC0, + 0x80, 0x41, 0x01, 0xC0, 0x80, 0x41, 0x00, 0xC1, 0x81, 0x40, + 0x00, 0xC1, 0x81, 0x40, 0x01, 0xC0, 0x80, 0x41, 0x01, 0xC0, + 0x80, 0x41, 0x00, 0xC1, 0x81, 0x40, 0x01, 0xC0, 0x80, 0x41, + 0x00, 0xC1, 0x81, 0x40, 0x00, 0xC1, 0x81, 0x40, 0x01, 0xC0, + 0x80, 0x41, 0x00, 0xC1, 0x81, 0x40, 0x01, 0xC0, 0x80, 0x41, + 0x01, 0xC0, 0x80, 0x41, 0x00, 0xC1, 0x81, 0x40, 0x01, 0xC0, + 0x80, 0x41, 0x00, 0xC1, 0x81, 0x40, 0x00, 0xC1, 0x81, 0x40, + 0x01, 0xC0, 0x80, 0x41, 0x01, 0xC0, 0x80, 0x41, 0x00, 0xC1, + 0x81, 0x40, 0x00, 0xC1, 0x81, 0x40, 0x01, 0xC0, 0x80, 0x41, + 0x00, 0xC1, 0x81, 0x40, 0x01, 0xC0, 0x80, 0x41, 0x01, 0xC0, + 0x80, 0x41, 0x00, 0xC1, 0x81, 0x40 +}; + +/* Table of CRC values for low–order byte */ +unsigned char chCRCLo[] ={ + 0x00, 0xC0, 0xC1, 0x01, 0xC3, 0x03, 0x02, 0xC2, 0xC6, 0x06, + 0x07, 0xC7, 0x05, 0xC5, 0xC4, 0x04, 0xCC, 0x0C, 0x0D, 0xCD, + 0x0F, 0xCF, 0xCE, 0x0E, 0x0A, 0xCA, 0xCB, 0x0B, 0xC9, 0x09, + 0x08, 0xC8, 0xD8, 0x18, 0x19, 0xD9, 0x1B, 0xDB, 0xDA, 0x1A, + 0x1E, 0xDE, 0xDF, 0x1F, 0xDD, 0x1D, 0x1C, 0xDC, 0x14, 0xD4, + 0xD5, 0x15, 0xD7, 0x17, 0x16, 0xD6, 0xD2, 0x12, 0x13, 0xD3, + 0x11, 0xD1, 0xD0, 0x10, 0xF0, 0x30, 0x31, 0xF1, 0x33, 0xF3, + 0xF2, 0x32, 0x36, 0xF6, 0xF7, 0x37, 0xF5, 0x35, 0x34, 0xF4, + 0x3C, 0xFC, 0xFD, 0x3D, 0xFF, 0x3F, 0x3E, 0xFE, 0xFA, 0x3A, + 0x3B, 0xFB, 0x39, 0xF9, 0xF8, 0x38, 0x28, 0xE8, 0xE9, 0x29, + 0xEB, 0x2B, 0x2A, 0xEA, 0xEE, 0x2E, 0x2F, 0xEF, 0x2D, 0xED, + 0xEC, 0x2C, 0xE4, 0x24, 0x25, 0xE5, 0x27, 0xE7, 0xE6, 0x26, + 0x22, 0xE2, 0xE3, 0x23, 0xE1, 0x21, 0x20, 0xE0, 0xA0, 0x60, + 0x61, 0xA1, 0x63, 0xA3, 0xA2, 0x62, 0x66, 0xA6, 0xA7, 0x67, + 0xA5, 0x65, 0x64, 0xA4, 0x6C, 0xAC, 0xAD, 0x6D, 0xAF, 0x6F, + 0x6E, 0xAE, 0xAA, 0x6A, 0x6B, 0xAB, 0x69, 0xA9, 0xA8, 0x68, + 0x78, 0xB8, 0xB9, 0x79, 0xBB, 0x7B, 0x7A, 0xBA, 0xBE, 0x7E, + 0x7F, 0xBF, 0x7D, 0xBD, 0xBC, 0x7C, 0xB4, 0x74, 0x75, 0xB5, + 0x77, 0xB7, 0xB6, 0x76, 0x72, 0xB2, 0xB3, 0x73, 0xB1, 0x71, + 0x70, 0xB0, 0x50, 0x90, 0x91, 0x51, 0x93, 0x53, 0x52, 0x92, + 0x96, 0x56, 0x57, 0x97, 0x55, 0x95, 0x94, 0x54, 0x9C, 0x5C, + 0x5D, 0x9D, 0x5F, 0x9F, 0x9E, 0x5E, 0x5A, 0x9A, 0x9B, 0x5B, + 0x99, 0x59, 0x58, 0x98, 0x88, 0x48, 0x49, 0x89, 0x4B, 0x8B, + 0x8A, 0x4A, 0x4E, 0x8E, 0x8F, 0x4F, 0x8D, 0x4D, 0x4C, 0x8C, + 0x44, 0x84, 0x85, 0x45, 0x87, 0x47, 0x46, 0x86, 0x82, 0x42, + 0x43, 0x83, 0x41, 0x81, 0x80, 0x40 +}; +/** + * @brief 计算校验和 + * + * @param pData 数据指针 + * @param length 数据长度 + * @return unsigned short + */ +unsigned short calculate_check_sum(const unsigned char* pData, unsigned short length) +{ + unsigned char CRCHi = 0xFF; + unsigned char CRCLo = 0xFF; + int uIndex; + while (length--) + { + uIndex = CRCHi ^ *pData++; + CRCHi = CRCLo ^ chCRCHi[uIndex]; + CRCLo = chCRCLo[uIndex]; + } + return (CRCHi << 8 | CRCLo); +} +``` + +## 1.2. 协议内容 + +**基本描述** +1. 大于等于0x8000的命令字由CPU发给MCU; +2. 小于0x8000的命令字由MCU发给CPU; +3. 大于0x0801而小于0xC101的命令由CPU主动发送给MCU,大于等于0xC101的命令由CPU回复发送给MCU; +4. 问答型协议只有按位最高位相反,其它位相等,例如:0x8101与0x0101是一问一答的协议; + +| 命令字 | CPU | MCU | 数据段 | 协议解析 | 备注 | +|----|----|----|----|----|----| +| 0x8101 | ask | - | - | 获取启动模式 | - | +| 0x0101 | - | reply | Data[0]:启动模式
0x01:PIR启动
0x02:TEST启动
0x03:连拍启动
0x04:PIR延时启动
0x05:定时(间隔一定时间)启动
0x06:关机
0x07:低电关机
0x08:异常启动 | 回复启动模式 | 异常启动数据:Data[1]
0x00:喂狗异常启动
0x01:心跳异常启动 | +| 0x8102 | ask | - | - | 断电关机 | - | +| 0x8103 | ask | - | - | 喂狗 | - | +| 0x8104 | ask | - | Data[0]:Hour
0-23
Data[1]:Min
0-59
Data[2]:Sec
0-59 | 开启狗/设置喂狗周期 | - | +| 0x0104 | - | reply | Data[0]:结果
0x01:成功
0x02:失败 | 开启狗/设置喂狗周期回复 | - | +| 0x8105 | ask | - | - | 关闭狗 | - | +| 0x0105 | - | reply | Data[0]:结果
0x01:成功
0x02:失败 | 关闭狗回复 | - | +| 0x8106 | ask | - | Data[0]:Hour
0-23
Data[1]:Min
0-59
Data[2]:Sec
0-59 | 设置间隔启动时间 | - | +| 0x0106 | - | reply | Data[0]:结果
0x01:成功
0x02:失败 | 设置间隔启动时间回复 | - | +| 0x8107 | ask | - | Data[0]:Year
Data[1]:Mon
1-12
Data[2]:Day
0-31
Data[3]:Hour
0-23
Data[4]:Min
0-59
Data[5]:Sec
0-59 | 设置日期和时间 | - | +| 0x0107 | - | reply | Data[0]:结果
0x01:成功
0x02:失败 | 设置日期和时间回复 | - | +| 0x8108 | ask | - | Data[0]:灵敏度
0-9 | 设置PIR灵敏度 | - | +| 0x0108 | - | reply | Data[0]:结果
0x01:成功
0x02:失败 | 设置PIR灵敏度回复 | - | +| 0x8109 | ask | - | Data[0]:Hour
0-23
Data[1]:Min
0-59
Data[2]:Sec
0-59 | 设置连拍间隔 | - | +| 0x0109 | - | reply | Data[0]:结果
0x01:成功
0x02:失败 | 设置连拍间隔回复 | - | +| 0x810A | ask | - | Data[0]:控制模式
0-关闭红外灯
1-开启红外灯 | 红外灯控制 | 取消 | +| 0x010A | - | reply | Data[0]:结果
0x01:成功
0x02:失败 | 红外灯控制回复 | 取消 | +| 0x810B | ask | - | - | 获取光敏值 | 取消 | +| 0x010B | - | reply | Data[0]:结果
0-100 | 获取光敏值回复 | 取消 | +| ====== | === | ====== | ============================ | ==================== | ======= | +| 0xC101 | reply | - | Data[0]:结果
0x01:成功
0x02:失败 | 发送启动模式回复 | - | +| 0x4101 | - | ask | Data[0]:启动模式
0x01:PIR启动
0x02:TEST启动
0x03:连拍启动
0x04:PIR延时启动
0x05:定时(间隔一定时间)启动
0x06:关机
0x07:低电关机
0x08:异常启动 | 发送启动模式 | 异常启动数据:Data[1]
0x00:喂狗异常启动
0x01:心跳异常启动 | +| 0xC102 | reply | - | - | 回复心跳包 | - | +| 0x4102 | - | ask | - | 发送心跳包 | - | +