From dcbd0e93b5cc05ea9f1e1152c7951a37e12d177f Mon Sep 17 00:00:00 2001 From: chen <15335560115@163.com> Date: 星期二, 03 六月 2025 15:23:36 +0800 Subject: [PATCH] V1.13版本修改接收时间和帧间隔和延迟接收时间参数,适配铁鞋稳定一对多测距版本 --- keil/include/drivers/serial_at_cmd_app.c | 89 ++++++++++++++------------------------------ 1 files changed, 29 insertions(+), 60 deletions(-) diff --git a/keil/include/drivers/serial_at_cmd_app.c b/keil/include/drivers/serial_at_cmd_app.c index 763b933..46b369f 100644 --- a/keil/include/drivers/serial_at_cmd_app.c +++ b/keil/include/drivers/serial_at_cmd_app.c @@ -19,17 +19,8 @@ #define Lora_TXD_bff_MAX 220 //发送缓存区大小 >4+8+4*基站数量+2=14+4*基站数量 uint8_t mUsartReceivePack[100] = {0}; -uint8_t mUsart2ReceivePack[150] = {0}; -double jd,wd; -int analysis_num,pos_state; -uint8_t state5V_prase_flag,gps_prase_flag=1; -extern void IO_LED_control_change(uint8_t data); -extern void IO_control_init(void); -extern void blink_led(uint8_t*state); -extern void updata_led_power_state(void); -extern uint8_t gps_success_state; -extern uint8_t gps_success_state,gps_enable_flag,gps_need_data_flag,gps_timeout_flag; -extern int gps_wait_count; +uint8_t mUsart2ReceivePack[100] = {0}; + typedef enum { BLE_RECV_STATE_IDLE = 0, @@ -37,12 +28,6 @@ BLE_RECV_STATE_RSSI, //BLE_RECV_STATE_LF, } E_BLERecvState; -static char gps_header[20]; -typedef struct -{ - char m_pData[100]; - uint32_t m_u32Len; -}GGA_DataStruct; typedef struct { E_BLERecvState m_eState; @@ -79,7 +64,27 @@ sum = ~sum; return sum; } - +void SendComMap0(uint8_t data_length, uint8_t index)//表示成功读取的回应包 + { + static uint8_t send_frame[EUART_RX_BUF_SIZE]; + uint16_t checksum = 0; + send_frame[0] = 0x55; + send_frame[1] = 0xAA; + send_frame[2] = 0x03; + send_frame[3] = data_length+5; + send_frame[4] = CMD_REPLY; + send_frame[5] = index; + send_frame[6] = data_length; + memcpy(&send_frame[7], &g_com_map[index], data_length); + for(int i = 0; i<(data_length+5); i++) + { + checksum += send_frame[2+i]; + } + checksum = Checksum_u16(&send_frame[2],5+data_length); + memcpy(&send_frame[7+data_length],&checksum,2); + + uart_send(UART_ID0, send_frame,data_length+9, NULL); +} void SendComMap(uint8_t data_length, uint8_t index)//表示成功读取的回应包 { static uint8_t send_frame[EUART_RX_BUF_SIZE]; @@ -135,9 +140,9 @@ } } +extern uint8_t enable_sleep_count,sleep_flag; void UsartParseDataHandler(uint8_t data) { - if(state5V_prase_flag){//升级程序 static UsartRecvPackState usart_receive_state = UsartReceiveWaitHead0; uint16_t checksum = 0; static uint8_t pack_datalen = 0,pack_length = 0,pack_index = 0,pack_msgtype = 0,pack_cmd = CMD_READ; @@ -162,7 +167,9 @@ { case CMD_WRITE: //从mUsartReceivePack中读取pack_length长度的字节,放到全局变量中,赋值保存的参数并且存入flash + enable_sleep_count=0; memcpy((uint8_t*)&g_com_map + pack_index, mUsartReceivePack, pack_datalen); + if(mUsartReceivePack[0]==1) UpdateProcess(pack_index); //返回一个error状态 @@ -172,9 +179,10 @@ NVIC_SystemReset(); break; case CMD_READ: + enable_sleep_count=0; //read包中data字节,即mUsartReceivePack[0]表示数据长度; //从g_com_data结构体中的第index位置读取长度为mUsartReceivePack[0]的字节,发送出来 - SendComMap(pack_datalen,pack_index>>1); + SendComMap0(pack_datalen,pack_index>>1); break; default: break; @@ -218,46 +226,7 @@ pack_index = 0; pack_length = 0; } -}else if(gps_prase_flag){ -//GPS解析数据 -// static ST_BLERecv BLE_recvive; - GGA_DataStruct jdrecv,wdrecv,Posstate; - static uint8_t index = 0; - //接收数据开始分析 - mUsart2ReceivePack[index] = data; //char数组传进来参数data - mUsart2ReceivePack_before = mUsart2ReceivePack_now; - mUsart2ReceivePack_now=data; - index++; - if( mUsart2ReceivePack_before == 0x0D && mUsart2ReceivePack_now==0x0A )//接收数据到“0x0D 0x0A”结束 - { - //解析该条GPS报文 - analysis_num=sscanf((char*)mUsart2ReceivePack,"$%[^,],%*[^,],%[^,],%*[^,],%[^,],%*[^,],%[^,],%*[^,],%*[^,],%*[^,],%*[^,],%*[^,],%*[^,],%*[^,],%*s",gps_header,wdrecv.m_pData,jdrecv.m_pData,Posstate.m_pData); - if(!memcmp(gps_header,"GNGGA",5)){ - wd=strtod(wdrecv.m_pData,NULL); - jd=strtod(jdrecv.m_pData,NULL); - pos_state=atoi(Posstate.m_pData); - }else{ - wd=0; - jd=0; - } - blink_led(&gps_success_state); - if(pos_state!=0){ - //4g.jd=jd; - //4g.wd=wd; - gps_timeout_flag=1;//不超时接收状态 - gps_need_data_flag=0;//接收数据完成 - gps_wait_count=0;//清0接收状态 -// gps_enable_flag=0;//收到有效数据关闭GPS - } - //memset(mUsart2ReceivePack,0,sizeof(mUsart2ReceivePack)); - memset(wdrecv.m_pData,0,sizeof(wdrecv.m_pData)); - memset(jdrecv.m_pData,0,sizeof(jdrecv.m_pData)); - memset(Posstate.m_pData,0,sizeof(Posstate.m_pData)); - index=0; - mUsart2ReceivePack_before=0; - mUsart2ReceivePack_now=0; - } - } + } void Usart2ParseDataHandler(uint8_t data)//UART蓝牙数据分析处理 -- Gitblit v1.9.3