From 63bf8ea65ca11349d5fae93580f91a87d3633dba Mon Sep 17 00:00:00 2001 From: WXK <287788329@qq.com> Date: 星期五, 14 三月 2025 18:45:47 +0800 Subject: [PATCH] 工卡改为通道9,加入ntrip跟tcp。ntrip不能用 shell不能用 --- keil/include/src/TCPClient.c | 105 +++++++++++++++++++++++++++++++++++++++++----------- 1 files changed, 83 insertions(+), 22 deletions(-) diff --git a/keil/include/src/TCPClient.c b/keil/include/src/TCPClient.c index e5a2d3c..879d542 100644 --- a/keil/include/src/TCPClient.c +++ b/keil/include/src/TCPClient.c @@ -21,6 +21,7 @@ #include "mk_trace.h" #include "dw_app_anchor.h" #include "PCA9555.h" +#include "WS2812.h" /******************************************************************************* * Macro * *******************************************************************************/ @@ -39,19 +40,19 @@ * Local Variable * *******************************************************************************/ HIDO_INT32 l_i32TCPClientID = 0; -extern uint8_t gps_power_state; +uint8_t gps_power_state; static E_TCPClientState l_eTCPClientState = TCP_CLIENT_STATE_IDLE; static HIDO_UINT32 l_u32HeartBeatTick = 0; static HIDO_UINT8 l_au8CmdBuff[1024]; -uint8_t TCPfail_flag = 0,flag_first_TCPconnect=1; -uint32_t TCPfailetimer; +static uint8_t TCPfail_flag = 0,flag_first_TCPconnect=1; +static uint32_t TCPfailetimer; uint16_t ip0,ip1,ip2,ip3,port; /******************************************************************************* * Local Function Declaration * *******************************************************************************/ -HIDO_INT32 TCPClient_Heartbeat(HIDO_VOID); +static HIDO_INT32 TCPClient_Heartbeat(HIDO_VOID); void TCPHeartBeatUpload(void); void UDPClient_UploadGPS(void); void TCPReceiveMessageReply(void); @@ -268,8 +269,12 @@ uint8_t alarm_type; extern double jd,wd; extern int32_t distance; -extern uint8_t GPS_GGAmessage[150],userkey_state,gps_timeout_flag; -extern uint16_t g_spsum,g_snum,ave_sp; +extern uint8_t userkey_state; +uint8_t gps_timeout_flag; +extern uint8_t GPS_GGAmessage[150]; +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) { HIDO_CHAR acHeart[200]; @@ -286,12 +291,45 @@ // 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_GGAmessage,g_com_map[DEV_ID],bat_percent,userkey_state,gps_timeout_flag); - userkey_state = 0; - Socket_Send(l_i32TCPClientID, (HIDO_UINT8 *)acHeart, u32HeartLen); +// 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); } +char senddata[2048]; +void HexToAsciiSendUDP(uint8_t* data,uint8_t len) +{ + static HIDO_CHAR l_acUploadBuff[2048]; + static HIDO_UINT32 l_u32UploadBuffLen = 0; + static HIDO_UINT32 l_u32UdpsendTick = 0; + uint8_t i,temp; + + for(i=0;i<len;i++) + { + temp = *data++; + sprintf(&senddata[2*i],"%x",temp>>4); + sprintf(&senddata[2*i+1],"%x",temp&0xf); + } + senddata[2*len] = 0x0d; + senddata[2*len+1] = 0x0a; +// if(DBG_GetMode() == DBG_MODE_CFG) +// Uart_Send(0, (HIDO_UINT8 *) senddata, 2*len+2); +// UDPClient_Uploadhex(senddata,2*len+2); + if(TCP_CLIENT_STATE_CONNECTED == l_eTCPClientState) + { + memcpy(l_acUploadBuff + l_u32UploadBuffLen, senddata, 2*len+2); + l_u32UploadBuffLen += 2*len+2; + // if((l_u32UploadBuffLen + u32Len )> sizeof(l_acUploadBuff)) +// if((HIDO_TimerGetTick() - l_u32UdpsendTick) >= 200) +// { +// l_u32UdpsendTick = HIDO_TimerGetTick(); + Socket_Send(l_i32TCPClientID, (HIDO_UINT8 *)l_acUploadBuff, l_u32UploadBuffLen); + l_u32UploadBuffLen = 0; +// } + + } +} void TCPHeartBeatUpload(void) { HIDO_CHAR acHeart[200]; @@ -307,9 +345,11 @@ // 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%%\r\n", \ - GPS_GGAmessage,g_com_map[DEV_ID],bat_percent); + 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); + + } void TCPReceiveMessageReply(void) { @@ -324,7 +364,7 @@ if(alarm_type == 2) alarm_type = 0; } - +extern uint32_t uwbled,rtkled,led4g,powerled; HIDO_INT32 TCPClient_Poll(void) { if (Internet_IsIPReady() == HIDO_TRUE) @@ -332,14 +372,15 @@ HIDO_UINT32 u32CurTick = HIDO_TimerGetTick(); if (TCP_CLIENT_STATE_IDLE == l_eTCPClientState) { + led4g=RED; if (!TCPfail_flag) { l_eTCPClientState = TCP_CLIENT_STATE_CONNECTING; - HIDO_UtilSnprintf((HIDO_CHAR *) l_au8CmdBuff, sizeof(l_au8CmdBuff), "%u.%u.%u.%u", ip0,ip1, ip2, ip3); + HIDO_UtilSnprintf((HIDO_CHAR *) l_au8CmdBuff, sizeof(l_au8CmdBuff), "%u.%u.%u.%u", g_com_map[IP_0], g_com_map[IP_1], g_com_map[IP_2], g_com_map[IP_3]); - Socket_Connect(l_i32TCPClientID, (HIDO_CHAR *) l_au8CmdBuff, port); + Socket_Connect(l_i32TCPClientID, (HIDO_CHAR *) l_au8CmdBuff, g_com_map[PORT]); // HIDO_UtilSnprintf((HIDO_CHAR *) l_au8CmdBuff, sizeof(l_au8CmdBuff), "123.57.87.125"); // Socket_Connect(l_i32TCPClientID, (HIDO_CHAR *) l_au8CmdBuff, 8888); @@ -359,10 +400,7 @@ } else if (TCP_CLIENT_STATE_CONNECTED == l_eTCPClientState) { - - - - + led4g=GREEN; if ((u32CurTick - l_u32HeartBeatTick) >= HIDO_TIMER_TICK_S(60)||flag_first_TCPconnect) //if ((u32CurTick - l_u32HeartBeatTick) >= HIDO_TIMER_TICK_S(g_com_map[SEND_4G_SECOND])||flag_first_TCPconnect) { @@ -379,6 +417,7 @@ } else { + led4g=RED; l_eTCPClientState = TCP_CLIENT_STATE_IDLE; } @@ -400,7 +439,29 @@ return HIDO_OK; } +HIDO_INT32 TCPClient_Uploadhex(uint8_t *_pcGGA,uint16_t u32Len) +{ + static HIDO_CHAR l_acUploadBuff[1024]; + static HIDO_UINT32 l_u32UploadBuffLen = 0; + static HIDO_UINT32 l_u32UdpsendTick = 0; + + if(TCP_CLIENT_STATE_CONNECTED == l_eTCPClientState) + { + memcpy(l_acUploadBuff + l_u32UploadBuffLen, _pcGGA, 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_acUploadBuff, l_u32UploadBuffLen); + l_u32UploadBuffLen = 0; + } + + } + + return HIDO_OK; +} HIDO_BOOL TCPClient_IsSendOver(HIDO_VOID) { return Socket_IsSendQueueEmpty(l_i32TCPClientID); @@ -429,16 +490,16 @@ return HIDO_OK; } -char str[17]= {"AT+IPR=9600;&W\r\n"}; +char str[19]= {"AT+IPR=115200;&W\r\n"}; void AIR780E_Reset(void) { PCA9555_Set_One_Value_Output(AIR780E_ENBALE,0);//关闭4G delay_ms(1500); PCA9555_Set_One_Value_Output(AIR780E_ENBALE,1);//打开4G delay_ms(3000); -// Uart_ReConfigBaudRate(UART_ID_4G,115200); -// uart_send(UART_ID0, str,17, NULL); // Uart_ReConfigBaudRate(UART_ID_4G,9600); +// uart_send(UART_ID0, str,19, NULL); +// Uart_ReConfigBaudRate(UART_ID_4G,115200); } uint8_t IfTCPConnected(void) -- Gitblit v1.9.3