BLE_TYQ_BJQ_CH584M/bsp/src/bsp_valve.c

316 lines
9.4 KiB
C
Raw Normal View History

2024-12-11 20:03:50 +08:00
/*
* @Author: mbw
* @Date: 2024-12-09 11:40:10
* @LastEditors: mbw && 1600520629@qq.com
* @LastEditTime: 2024-12-17 14:43:12
2024-12-11 20:03:50 +08:00
* @FilePath: \ble_-tyq_-bjq_-ch584-m\bsp\src\bsp_valve.c
* @Description:
*
* Copyright (c) 2024 by ${git_name_email}, All Rights Reserved.
*/
#include "bsp_valve.h"
#include "bsp_flash.h"
#include "CH58xBLE_LIB.h"
#include "bsp_uart.h"
#include "multiCentral.h"
2024-12-16 15:34:47 +08:00
2024-12-11 20:03:50 +08:00
/*
info
+ + + + +
+ + + + +
2024-12-11 20:03:50 +08:00
*/
#undef LOG_ENABLE
#define LOG_ENABLE 1
#include "log.h"
valve_data_list_t valve_list = {0};
BTFrameData valve_frame_data = {0};
2024-12-11 20:03:50 +08:00
2024-12-16 15:34:47 +08:00
uint8_t Valve_GenerateRawFrame(BTFrameData *pRawData, const uint8_t cmd, const uint8_t *p_src, uint8_t src_len)
2024-12-11 20:03:50 +08:00
{
pRawData->len = src_len + 5;
tmos_memset(pRawData->buf, 0, sizeof(pRawData->buf));
2024-12-11 20:03:50 +08:00
pRawData->buf[0] = 0XAA;
pRawData->buf[1] = cmd;
pRawData->buf[2] = src_len;
if (src_len > 0)
{
tmos_memcpy(&pRawData->buf[3], p_src, src_len);
}
pRawData->buf[pRawData->len - 2] = _CheckSum(&pRawData->buf[0], pRawData->len - 2);
pRawData->buf[pRawData->len - 1] = 0X55;
2024-12-16 15:34:47 +08:00
logInfo("向从机发送的数据:");
logHexDumpAll(pRawData->buf, pRawData->len);
2024-12-16 15:34:47 +08:00
return 0;
}
int BSP_Valve_Close(uint8_t valve_id)
{
uint8_t num = Flash_Get_Valve_Num();
uint8_t valve_ctr_valve = WirelessValveClose;
2024-12-11 20:03:50 +08:00
if ((valve_id > 8) && (num == 0))
{
logError("BSP_Valve_Close: valve id error");
2024-12-11 20:03:50 +08:00
return -1;
}
logDebug("BSP_Valve_Close: valve id: %d", valve_id);
// TODO:检查是否连接, 如果连接,则发送数据,将关闭阀门指令发送过去,然后等待数据接收响应如果接收到响应是关闭状态0x01则返回成功否则失败
2024-12-12 19:38:49 +08:00
Valve_GenerateRawFrame(&valve_frame_data, kCmdCloseVavle, &valve_ctr_valve, 1);
return BSP_Master_Send(centralConnList, CONNECT0_ITEM, &valve_frame_data.buf[0], valve_frame_data.len);
2024-12-11 20:03:50 +08:00
}
SHELL_EXPORT_CMD(SHELL_CMD_PERMISSION(0) | SHELL_CMD_TYPE(SHELL_TYPE_CMD_FUNC),
BSP_Valve_Close, BSP_Valve_Close, "valve_id:CONNECT0_ITEM = 0");
2024-12-11 20:03:50 +08:00
/*用于控制阀门的状态
* id: 1-8
* mac_addr: 6
* status: 0- 1-
*/
int BSP_Bt_Valve_Ctr(uint8_t *data, uint8_t len)
{
uint8_t mac_addr[FLASH_MAC_INFO_LEN] = {0};
if ((data[0] >= 1) && (data[0] <= 8))
{
Flash_Get_Mac_Addr(mac_addr, data[0] - 1);
}
else
{
logError("BSP_Bt_Valve_Ctr: id error");
return -1;
}
if (tmos_memcmp(&data[1], mac_addr, FLASH_MAC_INFO_LEN) != TRUE)
{
logError("mac addr error read mac addr : %02X %02X %02X %02X %02X %02X != bt_rx mac addr: %02X %02X %02X %02X %02X %02X",
mac_addr[0], mac_addr[1], mac_addr[2], mac_addr[3], mac_addr[4], mac_addr[5], data[1], data[2], data[3], data[4], data[5], data[6]);
return -2;
}
/*如果到这里了说明ID和MAC地址对应没问题则关闭对应阀门*/
return BSP_Valve_Close(data[0]);
}
/*注册阀门信息*/
int BSP_Bt_Register_Valve(uint8_t *data, uint8_t len)
{
uint8_t mac_addr[FLASH_MAC_INFO_LEN] = {0};
2024-12-16 15:34:47 +08:00
2024-12-11 20:03:50 +08:00
if ((data[0] >= 1) && (data[0] <= 8))
{
Flash_Get_Mac_Addr(mac_addr, data[0] - 1);
}
else
{
logError("valve id error");
2024-12-11 20:03:50 +08:00
return 1;
}
2024-12-16 20:47:16 +08:00
if (tmos_isbufset(&data[1], 0, FLASH_MAC_INFO_LEN) == TRUE)
{
logError("阀门写值错误为0");
return 1;
}
2024-12-16 15:34:47 +08:00
logDebug("注册阀门信息:");
if (tmos_memcmp(&data[1], mac_addr, FLASH_MAC_INFO_LEN) == TRUE)
2024-12-11 20:03:50 +08:00
{
2024-12-16 15:34:47 +08:00
logError("已经注册过了");
return 0; // 说明已经注册过了
2024-12-11 20:03:50 +08:00
}
2024-12-16 15:34:47 +08:00
else
2024-12-11 20:03:50 +08:00
{
2024-12-16 15:34:47 +08:00
if (tmos_isbufset(&mac_addr[0], 0xFF, 6) == TRUE) // 说明没有数据,那就全部写入
2024-12-11 20:03:50 +08:00
{
2024-12-16 15:34:47 +08:00
logDebug("没有数据,全部写入:");
logDebug("写入MAC 地址: %02X %02X %02X %02X %02X %02X", data[1], data[2], data[3], data[4], data[5], data[6]);
if (Flash_Set_Mac_Addr(&data[1], data[0] - 1) != 0)
{
logError("阀门注册写入flash 错误");
return 3;
}
else
2024-12-16 19:22:58 +08:00
{
uint8_t num = Flash_Get_Valve_Num();
2024-12-17 10:54:01 +08:00
logDebug("num : %02X ", num);
Flash_Set_Valve_Num(1);
logDebug("写入成功,当前阀门数量为: %d", num);
2024-12-16 15:34:47 +08:00
BSP_Bt_Valve_Updata(); // 更新阀门信息
2024-12-16 20:47:16 +08:00
2024-12-16 15:34:47 +08:00
}
}
else
{
logDebug("有数据 请检查");
2024-12-11 20:03:50 +08:00
}
}
return 0;
}
/*移除阀门信息*/
int BSP_Bt_Remove_Valve(uint8_t *data, uint8_t len)
{
2024-12-16 15:34:47 +08:00
size_t i = 0;
uint8_t mac_addr[FLASH_MAC_INFO_LEN + 2] = {0};
if ((data[0] >= 1) && (data[0] <= 8))// 判断是否是正确的ID
2024-12-11 20:03:50 +08:00
{
Flash_Get_Mac_Addr(mac_addr, data[0] - 1);
}
else
{
2024-12-16 19:22:58 +08:00
logError("valve id error:");
logHexDumpAll(data, len);
2024-12-11 20:03:50 +08:00
return -1;
}
2024-12-16 15:34:47 +08:00
if (tmos_memcmp(&data[1], mac_addr, FLASH_MAC_INFO_LEN) != TRUE)// 判断是否是相同的MAC地址
2024-12-11 20:03:50 +08:00
{
2024-12-16 15:34:47 +08:00
logError("mac addr error");
2024-12-16 19:22:58 +08:00
logHexDumpAll(data, len);
2024-12-16 15:34:47 +08:00
return -2;
2024-12-11 20:03:50 +08:00
}
2024-12-16 15:34:47 +08:00
else
2024-12-11 20:03:50 +08:00
{
tmos_memset(mac_addr, 0xFF, FLASH_MAC_INFO_LEN);
2024-12-16 15:34:47 +08:00
if (Flash_Set_Mac_Addr(mac_addr, data[0] - 1) != 0) // 清空掉对应位置MAC数据
2024-12-11 20:03:50 +08:00
{
logError("移除阀门信息失败");
2024-12-16 19:22:58 +08:00
logHexDumpAll(data, len);
2024-12-11 20:03:50 +08:00
return -2;
}
2024-12-16 15:34:47 +08:00
BSP_Bt_Valve_Updata();
Master_DisConnect();
2024-12-11 20:03:50 +08:00
}
2024-12-16 15:34:47 +08:00
2024-12-11 20:03:50 +08:00
return 0;
}
/*更换阀门信息*/
int BSP_Bt_Replace_Valve(uint8_t *data, uint8_t len)
{
size_t i = 0;
uint8_t mac_addr[FLASH_MAC_INFO_LEN] = {0};
logDebug("更换阀门信息:");
logHexDumpAll(data, len);
2024-12-16 15:34:47 +08:00
if ((len == 0) || (len < 13))//新旧MAC地址长度加id 6 + 6 + 1 = 13至少要大于12
2024-12-11 20:03:50 +08:00
{
2024-12-16 15:34:47 +08:00
logError("data len error");
2024-12-11 20:03:50 +08:00
return -1;
}
if ((data[0] >= 1) && (data[0] <= 8))
{
Flash_Get_Mac_Addr(mac_addr, data[0] - 1);
}
else
{
logError("valve id error");
return -2;
}
if (tmos_memcmp(&data[7], mac_addr, FLASH_MAC_INFO_LEN) == TRUE)
2024-12-11 20:03:50 +08:00
{
2024-12-16 15:34:47 +08:00
logError("已经注册过了"); // 不需要重复写入
return 0; // 说明已经注册过了
2024-12-11 20:03:50 +08:00
}
2024-12-16 15:34:47 +08:00
else
2024-12-11 20:03:50 +08:00
{
if (Flash_Set_Mac_Addr(&data[7], data[0] - 1) != 0)
2024-12-11 20:03:50 +08:00
{
2024-12-16 15:34:47 +08:00
logError("阀门注册写入flash 错误");
return 3;
2024-12-11 20:03:50 +08:00
}
2024-12-16 15:34:47 +08:00
BSP_Bt_Valve_Updata(); // 更新阀门信息
2024-12-17 15:55:21 +08:00
Master_DisConnect();//更新后先断联接
2024-12-11 20:03:50 +08:00
}
return 0;
}
/*更新阀门信息*/
void BSP_Bt_Valve_Updata(void)
{
uint8_t cnt = 0;
2024-12-11 20:03:50 +08:00
uint8_t mac[6] = {0};
2024-12-16 15:34:47 +08:00
uint8_t num = Flash_Get_Valve_Num();
2024-12-13 19:07:00 +08:00
logInfo("BSP_Bt_Valve_Updata num: %d ", num);
2024-12-16 20:47:16 +08:00
if (num == 0)
{
return;
}
2024-12-11 20:03:50 +08:00
tmos_memset(&valve_list, 0, sizeof(valve_data_list_t));
2024-12-16 15:34:47 +08:00
for (int i = 0; i < MAX_VALVE_NUM; i++) // 这个循环是为了将数据拷贝到valve_list中 并且保证id号和flash对应起来
2024-12-11 20:03:50 +08:00
{
2024-12-16 15:34:47 +08:00
if (Flash_Get_Mac_Addr(mac, i) == 0) // 说明有MAC数据
2024-12-11 20:03:50 +08:00
{
2024-12-16 15:34:47 +08:00
tmos_memcpy(valve_list.valve_data[cnt].valve_mac, mac, 6); // 这样做的目的就是读取方便只需要根据flash中读取到的数量进行读取前N个值
valve_list.valve_data[cnt].valve_id = i + 1;
logDebug("updata valve_id: %d, valve_mac: %02X %02X %02X %02X %02X %02X",
valve_list.valve_data[cnt].valve_id,
valve_list.valve_data[cnt].valve_mac[0],
valve_list.valve_data[cnt].valve_mac[1],
valve_list.valve_data[cnt].valve_mac[2],
valve_list.valve_data[cnt].valve_mac[3],
valve_list.valve_data[cnt].valve_mac[4],
valve_list.valve_data[cnt].valve_mac[5]);
cnt++;
valve_list.valve_num = cnt;
break;
2024-12-11 20:03:50 +08:00
}
else
{
logError("BSP_Bt_Valve_Updata: flash read error");
2024-12-16 15:34:47 +08:00
break;
2024-12-11 20:03:50 +08:00
}
}
2024-12-13 19:07:00 +08:00
Flash_Set_Valve_Num(valve_list.valve_num);
2024-12-16 15:34:47 +08:00
2024-12-11 20:03:50 +08:00
}
2024-12-13 19:07:00 +08:00
int BSP_Bt_Valve_Resp(uint8_t cmd, uint8_t id, uint8_t *mac_addr, uint8_t state)
2024-12-11 20:03:50 +08:00
{
2024-12-16 15:34:47 +08:00
uint8_t ret = 0;
BtData_t *ptr = (BtData_t *)tmos_msg_allocate(sizeof(struct valve_data));
ptr->cmd = cmd;
switch (cmd)
{
case kValveCmdCtr:
case kValveCmdReg:
case kValveCmdRem:
case kValveCmdRep:
ptr->buf[0] = id;
tmos_memcpy(&ptr->buf[1], mac_addr, 6);
ptr->buf[7] = state;
BT_GenerateRawFrame(&valve_frame_data, (uint8_t *)ptr, 9);
break;
case kValveEventStatus:
tmos_memcpy(&ptr->buf[0], &valve_list.valve_data[id - 1], sizeof(struct valve_data));
BT_GenerateRawFrame(&valve_frame_data, (uint8_t *)ptr, sizeof(struct valve_data));
break;
default:
break;
}
2024-12-13 19:07:00 +08:00
tmos_msg_deallocate((uint8_t *)ptr);
ret = BSP_Uart1_Send_Data((uint8_t *)&valve_frame_data.buf[0], valve_frame_data.len);
tmos_start_task(BtRxTaskId, BT_SEND_EVT, 50);
if (ret == valve_frame_data.len)
{
return 0;
}
return -1;
2024-12-11 20:03:50 +08:00
}
2024-12-16 15:34:47 +08:00
2024-12-11 20:03:50 +08:00
void BSP_Valve_Init(void)
{
2024-12-16 15:34:47 +08:00
logDebug("BSP_Valve_Init");
BSP_Bt_Valve_Updata();
2024-12-11 20:03:50 +08:00
}