From 16ccf41b599457daa3e870be7875d23cda6183f2 Mon Sep 17 00:00:00 2001 From: WXK <287788329@qq.com> Date: 星期三, 02 四月 2025 15:14:35 +0800 Subject: [PATCH] 1.7 改变gps上传解析逻辑,按键跟关机改为中断触发 --- keil/include/src/TCPClient.c | 123 ++++++++++++++++++++++++++-------------- 1 files changed, 80 insertions(+), 43 deletions(-) diff --git a/keil/include/src/TCPClient.c b/keil/include/src/TCPClient.c index 62222cc..e0c1dd6 100644 --- a/keil/include/src/TCPClient.c +++ b/keil/include/src/TCPClient.c @@ -23,6 +23,9 @@ #include "PCA9555.h" #include "WS2812.h" #include "PCA9555.h" +#include "mk_flash.h" +#include <serial_at_cmd_app.h> +#include "DBG.h" /******************************************************************************* * Macro * *******************************************************************************/ @@ -46,7 +49,7 @@ static HIDO_UINT32 l_u32HeartBeatTick = 0; static HIDO_UINT8 l_au8CmdBuff[1024]; -static uint8_t TCPfail_flag = 0,flag_first_TCPconnect=1; +uint8_t TCPfail_flag = 0,flag_first_TCPconnect=0; static uint32_t TCPfailetimer; uint16_t ip0,ip1,ip2,ip3,port; @@ -55,7 +58,7 @@ *******************************************************************************/ static HIDO_INT32 TCPClient_Heartbeat(HIDO_VOID); void TCPHeartBeatUpload(void); -void UDPClient_UploadGPS(void); +void UDPClient_UploadGPS(HIDO_CHAR *_pcGGA); void TCPReceiveMessageReply(void); /******************************************************************************* * Local Function * @@ -155,11 +158,29 @@ /* 设备ID检查 */ if(HIDO_UtilHexStrToInt(apcSplitStr[1]) == g_com_map[DEV_ID]) { - ota_flag=1; +// ota_flag=1; // LOG_INFO(TRACE_MODULE_APP,"OTA文件地址名称:%s.\r\n",(char *)&apcSplitStr[2]); // uart_send(UART_ID1, (char *)&apcSplitStr[2],strlen(apcSplitStr[3]), NULL); - memcpy(testdata,(HIDO_UINT8*)apcSplitStr[2],strlen(apcSplitStr[2]) + 1); - OTA_Start((HIDO_UINT8*)apcSplitStr[2]); +// memcpy(testdata,(HIDO_UINT8*)apcSplitStr[2],strlen(apcSplitStr[2]) + 1); +// OTA_Start((HIDO_UINT8*)apcSplitStr[2]); + +// g_com_map[OTA_FLAG]=1; +// g_com_map[OTA_URL_CHANGDU]=strlen(apcSplitStr[2]) + 1; +// memcpy(g_com_map+OTA_URL_INDEX,(HIDO_UINT8*)apcSplitStr[2],strlen(apcSplitStr[2]) + 1); +// save_com_map_to_flash(); +// delay_us(100000); + uint16_t tmp = 0xCCCC; + __disable_irq(); + result=flash_open(FLASH_ID0,NULL); + if(!result) + { + flash_erase(FLASH_ID0, APP_CONFIG_IAPFLAG_SECTOR_ADDR, FLASH_SECTOR_SIZE);//擦除APPFLAG + flash_write_nbytes(FLASH_ID0, APP_CONFIG_IAPFLAG_MAP, (uint8_t*)&tmp, sizeof(tmp)); + flash_erase(FLASH_ID0, APP_CONFIG_IAP_PARAM_MAP, FLASH_SECTOR_SIZE);//擦除APPFLAG + flash_write_nbytes(FLASH_ID0, APP_CONFIG_IAP_PARAM_MAP, (HIDO_UINT8*)apcSplitStr[2], strlen(apcSplitStr[2]) + 1); + } + __enable_irq(); + NVIC_SystemReset(); //软复位回到bootloader } } /* $getlog,id,url */ @@ -203,7 +224,7 @@ PCA9555_Set_One_Value_Output(TTS_ENABLE,1); //打开TTS电源 delay_ms(800); //再短一点,会丢失语音的第一个字,不是不读,而是就像没有下发第一个字 - TTS_Play((HIDO_UINT8 *)apcSplitStr[3], strlen(apcSplitStr[3])); //服务器语音播报 +// TTS_Play((HIDO_UINT8 *)apcSplitStr[3], strlen(apcSplitStr[3])); //服务器语音播报 u32Len = HIDO_UtilSnprintf((HIDO_CHAR *)l_au8CmdBuff, sizeof(l_au8CmdBuff), "$Receivevoice,%X\r\n", @@ -373,26 +394,34 @@ uint16_t g_spsum,g_snum,ave_sp; extern uint8_t GPS_ParseGGA_data[256]; extern uint8_t GPS_ParseGGA_changdu; -void UDPClient_UploadGPS(void) +uint8_t uwbsendnum,gpssendnum; +void UDPClient_UploadGPS(HIDO_CHAR *_pcGGA) { - HIDO_CHAR acHeart[200]; - HIDO_UINT32 u32HeartLen; - ave_sp = g_spsum/g_snum; - g_spsum = 0; - g_snum = 0; -// if(alarm_type==1) -// { -// u32HeartLen = snprintf(acHeart, sizeof(acHeart), "$message,alarm,%04x,%d,%04x,%d,%02u%%,%d,%d,%lf,%lf,%s,%d,%d,0\r\n", \ -// g_com_map[DEV_ID],GetUWBBindState(),g_com_map[BIND_DEV_ID],alarm_type,bat_percent,g_com_map[ALARM_DISTANCE1],g_com_map[ALARM_DISTANCE2],jd,wd,applyid,result,distance); -// } else { -// u32HeartLen = snprintf(acHeart, sizeof(acHeart), "$message,heart,%04x,%d,%04x,%d,%02u%%,%d,%d,%lf,%lf,%s,%d,%d,0\r\n", \ -// g_com_map[DEV_ID],GetUWBBindState(),g_com_map[BIND_DEV_ID],alarm_type,bat_percent,g_com_map[ALARM_DISTANCE1],g_com_map[ALARM_DISTANCE2],jd,wd,applyid,result,distance); -// } - -// u32HeartLen = snprintf(acHeart, sizeof(acHeart), "%s,%04x,%02u%%,%d,%d\r\n", -// GPS_ParseGGA_data,g_com_map[DEV_ID],bat_percent,userkey_state,gps_timeout_flag); -// userkey_state = 0; - Socket_Send(l_i32TCPClientID, (HIDO_UINT8 *)GPS_ParseGGA_data, GPS_ParseGGA_changdu); + if(TCP_CLIENT_STATE_CONNECTED == l_eTCPClientState) + { + + HIDO_UINT32 u32Len = HIDO_UtilSnprintf((HIDO_CHAR *)l_au8CmdBuff, sizeof(l_au8CmdBuff), "%s,%X,%02x,%x,%d,%d,%d%\r\n", + _pcGGA, g_com_map[DEV_ID], bat_percent,ave_sp,0,0,0); + + +// if((l_u32UploadBuffLen + u32Len) < sizeof(l_acUploadBuff)) +// { +// memcpy(l_acUploadBuff + l_u32UploadBuffLen, l_au8CmdBuff, u32Len); +// l_u32UploadBuffLen += u32Len; +// } + //memcpy(l_acUploadBuff + l_u32UploadBuffLen, l_au8CmdBuff, u32Len); + //l_u32UploadBuffLen += u32Len; + // if((l_u32UploadBuffLen + u32Len )> sizeof(l_acUploadBuff)) +// if((HIDO_TimerGetTick() - l_u32UdpsendTick) >= 200) + { +// l_u32UdpsendTick = HIDO_TimerGetTick(); + Socket_Send(l_i32TCPClientID, (HIDO_UINT8 *)l_au8CmdBuff, u32Len); + gpssendnum++; +// l_u32UploadBuffLen = 0; + } + + + } } char senddata[2048]; void HexToAsciiSendUDP(uint8_t* data,uint8_t len) @@ -422,6 +451,7 @@ // { // l_u32UdpsendTick = HIDO_TimerGetTick(); Socket_Send(l_i32TCPClientID, (HIDO_UINT8 *)l_acUploadBuff, l_u32UploadBuffLen); + uwbsendnum++; l_u32UploadBuffLen = 0; // } @@ -430,22 +460,29 @@ } void TCPHeartBeatUpload(void) { - HIDO_CHAR acHeart[200]; - HIDO_UINT32 u32HeartLen; - ave_sp = g_spsum/g_snum; - g_spsum = 0; - g_snum = 0; -// if(alarm_type==1) -// { -// u32HeartLen = snprintf(acHeart, sizeof(acHeart), "$message,alarm,%04x,%d,%04x,%d,%02u%%,%d,%d,%lf,%lf,%s,%d,%d,0\r\n", \ -// g_com_map[DEV_ID],GetUWBBindState(),g_com_map[BIND_DEV_ID],alarm_type,bat_percent,g_com_map[ALARM_DISTANCE1],g_com_map[ALARM_DISTANCE2],jd,wd,applyid,result,distance); -// } else { -// u32HeartLen = snprintf(acHeart, sizeof(acHeart), "$message,heart,%04x,%d,%04x,%d,%02u%%,%d,%d,%lf,%lf,%s,%d,%d,0\r\n", \ -// g_com_map[DEV_ID],GetUWBBindState(),g_com_map[BIND_DEV_ID],alarm_type,bat_percent,g_com_map[ALARM_DISTANCE1],g_com_map[ALARM_DISTANCE2],jd,wd,applyid,result,distance); -// } - u32HeartLen = HIDO_UtilSnprintf((HIDO_CHAR *)acHeart, sizeof(acHeart), "$XTB,%X,%02u%%,%d.%d,%s", - g_com_map[DEV_ID], bat_percent, g_com_map[VERSION]>>8,g_com_map[VERSION]&0xff, Module_GetCCID()); - Socket_Send(l_i32TCPClientID, (HIDO_UINT8 *)acHeart, u32HeartLen); + HIDO_UINT32 u32Len = 0; + if(TCP_CLIENT_STATE_CONNECTED == l_eTCPClientState) + { + if(g_com_map[RTCMMODE_INDEX] == RTCMMODE_TCP) + { u32Len = HIDO_UtilSnprintf((HIDO_CHAR *)l_au8CmdBuff, sizeof(l_au8CmdBuff), "$XTB,%X,%02u%%,%d.%d,%s,%d,3:%d.%d.%d.%d:%d.,1", + g_com_map[DEV_ID], bat_percent, g_com_map[VERSION]>>8,g_com_map[VERSION]&0xff, Module_GetCCID(),\ + userkey_state,g_com_map[TCP_IP_0],g_com_map[TCP_IP_1],g_com_map[TCP_IP_2],g_com_map[TCP_IP_3],g_com_map[TCP_PORT]); + } else if(g_com_map[RTCMMODE_INDEX] == RTCMMODE_NTRIP) + { + u32Len = HIDO_UtilSnprintf((HIDO_CHAR *)l_au8CmdBuff, sizeof(l_au8CmdBuff), "$XTB,%X,%02u%%,%d.%d,%s,%d,2%s %s,1", + g_com_map[DEV_ID], bat_percent, g_com_map[VERSION]>>8,g_com_map[VERSION]&0xff, \ + Module_GetCCID(),userkey_state,(char *)&g_com_map[NTRIP_HOST_INDEX],(char *)&g_com_map[NTRIP_USERNANME_INDEX]); + } else if(g_com_map[RTCMMODE_INDEX] == RTCMMODE_NONE) + { + u32Len = HIDO_UtilSnprintf((HIDO_CHAR *)l_au8CmdBuff, sizeof(l_au8CmdBuff), "$XTB,%X,%02u%%,%d.%d,%s,%d,1.,1", + g_com_map[DEV_ID], bat_percent, g_com_map[VERSION]>>8,g_com_map[VERSION]&0xff, Module_GetCCID(),\ + userkey_state,g_com_map[TCP_IP_0],g_com_map[TCP_IP_1],g_com_map[TCP_IP_2],g_com_map[TCP_IP_3],g_com_map[TCP_PORT]); + } + Socket_Send(l_i32TCPClientID, (HIDO_UINT8 *)l_au8CmdBuff, u32Len); + } +// u32HeartLen = HIDO_UtilSnprintf((HIDO_CHAR *)acHeart, sizeof(acHeart), "$XTB,%X,%02u%%,%d.%d,%s", +// g_com_map[DEV_ID], bat_percent, g_com_map[VERSION]>>8,g_com_map[VERSION]&0xff, Module_GetCCID()); +// Socket_Send(l_i32TCPClientID, (HIDO_UINT8 *)acHeart, u32HeartLen); } @@ -592,9 +629,9 @@ void AIR780E_Reset(void) { PCA9555_Set_One_Value_Output(AIR780E_ENBALE,0);//关闭4G - delay_ms(1500); + delay_ms(100); PCA9555_Set_One_Value_Output(AIR780E_ENBALE,1);//打开4G - delay_ms(3000); +// delay_ms(3000); // Uart_ReConfigBaudRate(UART_ID_4G,9600); // uart_send(UART_ID0, str,19, NULL); // Uart_ReConfigBaudRate(UART_ID_4G,115200); -- Gitblit v1.9.3