From a05cacad5239ab3f35ffb58f443356b484e6cc1b Mon Sep 17 00:00:00 2001
From: jinlicong <493886250@qq.com>
Date: Tue, 21 May 2024 19:17:22 +0800
Subject: [PATCH] 继续完善远传
---
Function/WirelessRemoteComm/wireless_remote_comm.c | 61 +++++++++++++++++++++++++-----
1 files changed, 51 insertions(+), 10 deletions(-)
diff --git a/Function/WirelessRemoteComm/wireless_remote_comm.c b/Function/WirelessRemoteComm/wireless_remote_comm.c
index 82ac24b..8184e3d 100644
--- a/Function/WirelessRemoteComm/wireless_remote_comm.c
+++ b/Function/WirelessRemoteComm/wireless_remote_comm.c
@@ -2,6 +2,7 @@
#include "uart.h"
#include "gpio.h"
#include "system_mem_para.h"
+#include "wrc_sizhu_v4.h"
WRC_CTRL_PARA_T wrc_ctrl_para_g={.wrc_state=WRC_IDLE};
WRC_UART_PARA_T wrc_uart_para_g = {.recv_flag = RESET};
@@ -96,11 +97,12 @@
WRC_SEND_NORMAL(buffer,205);
}
-LINK_STATUS link_data_analysis(uint8_t *receive_buf)
+LINK_STATUS LinkDataAnalysis(uint8_t *receive_buf)
{
char *buf_p = NULL;
uint8_t check_sum = 0;
uint16_t count_i = 0;
+ LINK_STATUS return_flag = LINK_NONE;
for(count_i = 0;count_i< 100;count_i++){
if((receive_buf[count_i]==0x41)&&(receive_buf[count_i+1]==0x41))
@@ -117,16 +119,48 @@
if((*(buf_p + 89) == check_sum)&&(*(buf_p + 90) == 0x16)){
if(*(buf_p + 2) == 1){
+ return_flag = LINK_OK;
+ if((*(buf_p+3) != 1)&&(*(buf_p+3) <0x39)){
+ link_info_g.net_signal_intensity = *(buf_p+3);
+ }
+ else{
+ link_info_g.net_signal_intensity = 0;
+ }
+
+ arrayA_2_arrayB((uint8_t *)(buf_p+4), (uint8_t *)link_info_g.ICCID, 20, LITTLE_ENDIAN);
+ link_info_g.SIM_Type = *(buf_p + 24);
+ arrayA_2_arrayB((uint8_t *)(buf_p+27), (uint8_t *)link_info_g.IMEI, 15, LITTLE_ENDIAN);
+ arrayA_2_arrayB((uint8_t *)(buf_p+44), (uint8_t *)link_info_g.SNR, 2, LITTLE_ENDIAN);
+
+
}else{
-
+ return_flag = LINK_NONE;
}
-
-
}
-
}
+ return return_flag;
+}
+
+
+WRC_STATUS ProtocolDataAnalysis(uint8_t *receive_buf)
+{
+ char *buf_p = NULL;
+ char *buf_next_p = NULL;
+// uint16_t check_crc = 0;
+ uint16_t count_i = 0;
+
+ buf_p = strstr((char *)receive_buf , "+R");
+ if(buf_p != NULL){
+ buf_next_p = strstr(buf_p , ",");
+ if(buf_next_p != NULL){
+ return SizhuV4ProtocolDataAnalysis((uint8_t *)buf_next_p);
+
+ }
+ }
+
+ return WRC_WAIT_REC_DATA;
}
@@ -139,7 +173,8 @@
delay_us(10);
WRC_PWR_ON;
- //?��Ҫ��ͨѶ������ʼ�����Է�������
+ //?��Ҫ��ͨѶ������ʼ�����Է�������,Ҳ���Է��������ɹ�֮��
+ SizhuV4SendParaInit();
return WRC_SEND_DATA;
}
@@ -172,7 +207,7 @@
WRC_STATUS WrcWaitRecDataPro(void)
{
-
+ WRC_STATUS return_status;
//����buf����
WRC_RX_DMA_check(&wrc_uart_para_g);
@@ -180,14 +215,20 @@
if(wrc_uart_para_g.recv_flag == SET){
wrc_uart_para_g.recv_flag = RESET;
if(wrc_ctrl_para_g.link_status ==LINK_NONE){
-
+ wrc_ctrl_para_g.link_status = LinkDataAnalysis(wrc_uart_para_g.recv_buf);
+ if(wrc_ctrl_para_g.link_status ==LINK_OK){
+ memset(wrc_uart_para_g.recv_buf,0,sizeof(wrc_uart_para_g.recv_buf));
+ return WRC_SEND_DATA;
+ }
}else if(wrc_ctrl_para_g.link_status ==LINK_OK){
-
+ return_status = ProtocolDataAnalysis(wrc_uart_para_g.recv_buf);
+ memset(wrc_uart_para_g.recv_buf,0,sizeof(wrc_uart_para_g.recv_buf));
+ return return_status;
}
}
- return WRC_SEND_DATA;
+ //�жϳ�ʱ�˳�
return WRC_CLOSE_PWR;
}
--
Gitblit v1.9.3