From f7107e325fbd42ed9875b7b28c340e1cda8627cc Mon Sep 17 00:00:00 2001
From: yincheng.zhong <634916154@qq.com>
Date: 星期日, 24 三月 2024 18:29:51 +0800
Subject: [PATCH] 1.12 修复大于25个的添加标签的bug

---
 Src/radio/Lora.c |  126 ++++++++++++++++++++++-------------------
 1 files changed, 68 insertions(+), 58 deletions(-)

diff --git a/Src/radio/Lora.c b/Src/radio/Lora.c
index bd078b6..c2be252 100644
--- a/Src/radio/Lora.c
+++ b/Src/radio/Lora.c
@@ -10,6 +10,8 @@
 #include "stdio.h"
 #include "delay.h"
 #include "dw_mbx_anc.h"
+#include "Flash.h"
+#include "dw_mbx_anc.h"
 #define USE_MODEM_LORA
 //#define USE_MODEM_FSK
 #define REGION_CN779
@@ -193,16 +195,20 @@
 {
 //	HAL_GPIO_TogglePin(GPIOB, LED1_Pin);
 }
-uint8_t tttt;
 
 uint8_t huifushengjibao_flag;
 uint8_t LoraUp_flag;
+extern uint8_t flag_writepara_needreset;
 void OnTxDone( void )
 {   
 //	T_R_Init(0);	
-//    Radio.Standby();
+    Radio.Standby();
 //    Radio.Rx( RX_TIMEOUT_VALUE ); //进入接收
-  tttt++;
+    if(flag_writepara_needreset) //配置写入完成设备需要重启
+    {
+        printf("网关下发配置写入完成,重启");
+        SCB->AIRCR = 0X05FA0000|(unsigned int)0x04; //软复位回到bootloader   
+    }
     if(LoraUp_flag)
     {
     huifushengjibao_flag=1;
@@ -230,6 +236,7 @@
 {
     rec_lp_count = HAL_LPTIM_ReadCounter(&hlptim1);
     rxbuff_len = size;
+
     memcpy( rxbuffer, payload, size );
     RssiValue = rssi;
     SnrValue = snr;
@@ -274,6 +281,7 @@
     Radio.Init( &RadioEvents );
     Radio.Standby();
     Radio.Sleep();
+    
 //	    Radio.SetChannel( UWB_CHANNEL_FRQ );														 
 //		Radio.SetTxConfig( MODEM_LORA, 22, 0, LORA_BANDWIDTH,
 //                                   LORA_SPREADING_FACTOR, LORA_CODINGRATE,
@@ -327,7 +335,7 @@
 //    Radio.Init( &RadioEvents );
     Radio.Standby();
   //  HAL_GPIO_WritePin(GPIOB, GPIO_PIN_12, GPIO_PIN_RESET);
-    Radio.SetChannel( freq );	
+    Radio.SetChannel( freq*1000000 );	
  
     Radio.SetTxConfig( MODEM_LORA, power, 0, 2,
     sf, LORA_CODINGRATE,LORA_PREAMBLE_LENGTH_T, LORA_FIX_LENGTH_PAYLOAD_ON,
@@ -349,26 +357,44 @@
 static uint16_t current_count1,target_count1,end_count1,start_count1;
 uint8_t huifushengjibaoerror_num;
 uint8_t final_bag_num;
+uint16_t testflag;
+uint32_t Zhongjian_data[60];
+uint16_t app1_or_app2;
+extern IWDG_HandleTypeDef hiwdg;
 void LoraUp_Poll()
 {    uint16_t  result ;
     uint16_t crc16;
-    memcpy(&rec_wenjian_daxiao,&rxbuffer[WRITEPATE_VALUE_IDX],2);//网关ID 占用2个字节
+    memcpy(&rec_wenjian_daxiao,&rxbuffer[WRITEPARA_VALUE_IDX],2);//文件大小
 //    rec_wenjian_daxiao=rxbuffer[WRITEPATE_VALUE_IDX];
     if(rec_wenjian_daxiao>0XAC00)
     {}//文件过大,超出范围
     else
-    {
-    final_bag_num=(rec_wenjian_daxiao/220)+1;//计算一共要请求多少包    
-    wangguan_up_id=rxbuffer[WG_ID_IDX];
+    { 
+    memcpy(&wangguan_up_id,&rxbuffer[SOURCE_ID_IDX],2);//网关ID 占用2个字节
     send_lora_data[MSG_TYPE_IDX]=LORA_MSGTYPE_UPDATE_CONFIRM;
-    memcpy(&send_lora_data[WANGGUAN_ID],&wangguan_up_id,2);//网关ID 占用2个字节
-    memcpy(&send_lora_data[JIZHAN_ID],&dev_id,2);//标签或者基站的设备ID 2个字节
-    send_lora_data[MUQIAN_BAG]=0xFF;
-    crc16=Cal_CRC16(send_lora_data,6);
+    memcpy(&send_lora_data[SOURCE_ID_IDX],&dev_id,2);//网关ID 占用2个字节
+    memcpy(&send_lora_data[DEST_ID_IDX],&wangguan_up_id,2);//标签或者基站的设备ID 2个字节
+//    send_lora_data[MUQIAN_BAG]=0xFF;
+    crc16=Checksum_u16(send_lora_data,6);
     memcpy(&send_lora_data[6],&crc16,2);
     huifushengjibao_flag=0;
     LoraUp_flag=1;
     Radio.Send(send_lora_data,8);//基站发送升级确认回复
+    Delay_Ms(1000);    
+    SwitchLoraSettings(LORA_UPCHANNEL_FRQ,LORA_UPCHANNEL_SF,22); //切换lora升级频点  
+    delay_ms(200);   
+    __disable_irq();
+//    FLASH_Read(APP_1OR2_ADRESS,(uint8_t*)&app1_or_app2,2);        
+    final_bag_num=(rec_wenjian_daxiao/220)+1;//计算一共要请求多少包   
+        while(1)
+        {
+            FLASH_Prepare(APP2_ADRESS, APP_SIZE);            
+            delay_ms(500);
+            if(testflag==0)
+            {break;}
+        }
+//    FLASH_Write(APP2_ADRESS, (const uint8_t*)&tmp111, 2);    
+    __enable_irq();             
     while(1)
     {
         if(huifushengjibao_flag==1)
@@ -376,13 +402,13 @@
             while(1)
             {
                 send_lora_data[MSG_TYPE_IDX]=LORA_MSGTYPE_UPDATEFILE_REQUEST;
-                memcpy(&send_lora_data[WANGGUAN_ID],&wangguan_up_id,2);//网关ID 占用2个字节
-                memcpy(&send_lora_data[JIZHAN_ID],&dev_id,2);//标签或者基站的设备ID 2个字节
+                memcpy(&send_lora_data[SOURCE_ID_IDX],&dev_id,2);//网关ID 占用2个字节
+                memcpy(&send_lora_data[DEST_ID_IDX],&wangguan_up_id,2);//标签或者基站的设备ID 2个字节
                 send_lora_data[MUQIAN_BAG]=muqiandeshengjibao;
-                crc16=Cal_CRC16(send_lora_data,6);
-                memcpy(&send_lora_data[6],&crc16,2);
+                crc16=Checksum_u16(send_lora_data,7);
+                memcpy(&send_lora_data[7],&crc16,2);
                 lora_up_rec_flag=0;    
-                Radio.Send(send_lora_data,8);//基站发送升级确认回复
+                Radio.Send(send_lora_data,9);//基站发送请求第x包
                 
                 start_count1=HAL_LPTIM_ReadCounter(&hlptim1);     //等待接收完成直到超时
                 end_count1=start_count1+32768/2;//500ms等待
@@ -396,30 +422,48 @@
                     {
                     break;
                     }
+                    delay_ms(100);
+                    if(lora_up_rec_flag)
+                    {break;}
+                    Radio.Send(send_lora_data,9);
                 }
+//                while(1);
                 if(lora_up_rec_flag)
                 {
-                     crc16=Cal_CRC16(rxbuffer,6+ONE_BAG_DAXIAO);
-                     if(!memcmp(&crc16,&rxbuffer[6+ONE_BAG_DAXIAO],2)&&!memcmp(&dev_id,&RX_Buffer[JIZHAN_ID],2)&& !memcmp(&wangguan_up_id,&RX_Buffer[WANGGUAN_ID],2))
+                    HAL_IWDG_Refresh(&hiwdg);
+                     crc16=Cal_CRC16(rxbuffer,DATA_IDX+ONE_BAG_DAXIAO);
+                     if(muqiandeshengjibao==rxbuffer[MUQIAN_BAG]&&!memcmp(&crc16,&rxbuffer[DATA_IDX+ONE_BAG_DAXIAO],2)&&!memcmp(&dev_id,&rxbuffer[DEST_ID_IDX],2)&& !memcmp(&wangguan_up_id,&rxbuffer[SOURCE_ID_IDX],2))
                      {
-                    result = FLASH_Prepare(APP2_ADRESS+ONE_BAG_DAXIAO*rxbuffer[MUQIAN_BAG], ONE_BAG_DAXIAO);
-                    if(result)
-                    result = FLASH_Write(APP2_ADRESS+ONE_BAG_DAXIAO*rxbuffer[MUQIAN_BAG],rxbuffer[DATA_IDX],ONE_BAG_DAXIAO);     
+                     memcpy(Zhongjian_data,&rxbuffer[DATA_IDX],ONE_BAG_DAXIAO);
+//                     if(app1_or_app2==1)
+//                     FLASH_Write(APP1_ADRESS+ONE_BAG_DAXIAO*rxbuffer[MUQIAN_BAG],(uint8_t*)Zhongjian_data,ONE_BAG_DAXIAO);                        
+//                     else
+                     FLASH_Write(APP2_ADRESS+ONE_BAG_DAXIAO*rxbuffer[MUQIAN_BAG],(uint8_t*)Zhongjian_data,ONE_BAG_DAXIAO);
+                     
                      muqiandeshengjibao++;   
                      }
                 }
                 else
                 {
+                    HAL_IWDG_Refresh(&hiwdg);
                     huifushengjibaoerror_num++;
                     if(huifushengjibaoerror_num>=20)
                     {
                     huifushengjibaoerror_num=0;    
+                    muqiandeshengjibao=0;
+                    Delay_Ms(500);
+                    HAL_NVIC_SystemReset();    
                     break;
                     }   
                 }
                 if(muqiandeshengjibao==final_bag_num)
                 {
-                Delay_Ms(500);
+                uint16_t tmp11 ,result11;
+                    tmp11=0XBB;
+                result11 = FLASH_Prepare(APP_1OR2_ADRESS, PAGE_SIZE);
+                if(result11)
+                result11 = FLASH_Write(APP_1OR2_ADRESS, (const uint8_t*)&tmp11, 2); 
+                Delay_Ms(1500);
                 HAL_NVIC_SystemReset();
                 }
             }
@@ -427,7 +471,7 @@
         else
         {
         Delay_Ms(500);
-        huifushengjibao_flag=0;
+//        huifushengjibao_flag=0;
         Radio.Send(send_lora_data,8);//基站发送升级确认回复
         huifushengjibaoerror_num++;
             if(huifushengjibaoerror_num>=5)
@@ -437,40 +481,6 @@
             }                
         }
     }
-//    LoraUp_flag=1;
-//    SetFlagLoraWaitSync(1);
-//   while(1)
-//   {
-//        start_count1=HAL_LPTIM_ReadCounter(&hlptim1);     //等待接收完成直到超时
-////        poll_timeout=500*10; //单位0.1ms
-//        end_count1=start_count1+(5000<<2);
-//        if(end_count1>=32768)
-//        {end_count1-=32768;}
-//        current_count1=HAL_LPTIM_ReadCounter(&hlptim1);
-//       while(GetFlagLoraWaitSync())
-//       {
-//         current_count1=HAL_LPTIM_ReadCounter(&hlptim1);
-//         if(current_count1>=end_count1&&current_count1<end_count1+15000)
-//         {
-//                break;
-//         }
-//       }
-//       if(!GetFlagLoraWaitSync())
-//       {
-//        send_lora_data[MSG_TYPE_IDX]=LORA_MSGTYPE_UPDATEFILE_REQUEST;
-//        memcpy(&send_lora_data[WANGGUAN_ID],&wangguan_up_id,2);//网关ID 占用2个字节
-//        memcpy(&send_lora_data[JIZHAN_ID],&dev_id,2);//标签或者基站的设备ID 2个字节
-//        send_lora_data[MUQIAN_BAG]=mudeshengjibao;
-//        crc16=Cal_CRC16(send_lora_data,6);
-//        memcpy(&send_lora_data[6],&crc16,2);
-//           
-//       }
-//   }
    }
 }
 
-void test1()
-{
-    if(!memcmp(&dev_id,&rxbuffer[ANCTAG_DEVICEID_IDX],2))
-    {LoraUp_Poll();}
-}
\ No newline at end of file

--
Gitblit v1.9.3