From 9e8a2b9c07fddcba3f0d2ae84c0c65f0f7f16c6a Mon Sep 17 00:00:00 2001
From: zhyinch <zhyinch@gmail.com>
Date: 星期四, 27 一月 2022 20:37:12 +0800
Subject: [PATCH] 中断模式,超宽带芯片读取状态异常,没有超时标志位

---
 源码/核心板/Src/main.c |   76 ++++++++++++++++++++++++++-----------
 1 files changed, 53 insertions(+), 23 deletions(-)

diff --git "a/\346\272\220\347\240\201/\346\240\270\345\277\203\346\235\277/Src/main.c" "b/\346\272\220\347\240\201/\346\240\270\345\277\203\346\235\277/Src/main.c"
index 5c98265..960746b 100644
--- "a/\346\272\220\347\240\201/\346\240\270\345\277\203\346\235\277/Src/main.c"
+++ "b/\346\272\220\347\240\201/\346\240\270\345\277\203\346\235\277/Src/main.c"
@@ -46,7 +46,7 @@
 	RCC_Configuration();
 	//SystemInit();
 	NVIC_SetVectorTable(NVIC_VectTab_FLASH, 0x5000);
-	Nvic_Init();
+	
 //	Systick_Init();
 	TIM3_Int_Init();
 	Led_Init();
@@ -55,8 +55,9 @@
 	Uart1_Init();
 	Spi_Init();
 	ADC_Configuration();
-	IWDG_Config(IWDG_Prescaler_128 ,4095);   //10s
-    IWDG_Feed();
+	//IWDG_Config(IWDG_Prescaler_128 ,4095);   //10s
+	Nvic_Init();
+  IWDG_Feed();
 	GPIO_PinRemapConfig(GPIO_Remap_SWJ_JTAGDisable, ENABLE);
 }
 u8 anchor_type;
@@ -99,8 +100,9 @@
 		if(dist_threshold>15000)
 		{dist_threshold = 15000;}
 }
+extern u8 needanchorrx;  
 u16 JDQ_time;
-u16 g_commap_antdelay;
+int16_t g_commap_antdelay;
 void Program_Init(void)
 {	float temp;
 	u16 temp2;
@@ -109,6 +111,7 @@
 	parameter_init();
 	//deca_sleep(1000);
 	HeartBeatInit();
+	Modbus_RegMap();
 #ifdef DEBUG_MODE
 //	g_com_map[DEV_ROLE]=1;
 //		g_com_map[DEV_ID]=1;
@@ -119,12 +122,36 @@
 	g_com_map[ANC_FLAG]=1;
 		save_com_map_to_flash();
 #endif
+//    
+//    g_com_map[COM_INTERVAL]=100;
+//		g_com_map[MAX_REPORT_ANC_NUM]=10;
+//		g_com_map[GROUP_ID]=0;
+//		g_com_map[DIST_OFFSET]=-116;
+
+//			g_com_map[DEV_ROLE] =0x0;  //基站
+//	
+//		g_com_map[ANC_POLL]=1;
+//		g_com_map[ALARM_DEV] = 0;
+//		g_com_map[ALARM_DISTANCE1] = 0;	//默认报警距离50cm
+//		g_com_map[ALARM_DISTANCE2] = 900;	//默认报警距离50cm
+//		g_com_map[ALARM_DISTANCE3] = 1400;	//默认报警距离50cm
+//         g_com_map[RELAY2_DISTANCE1] = 0;	//默认报警距离50cm
+//		g_com_map[RELAY2_DISTANCE2] = 900;	//默认报警距离50cm
+//		g_com_map[RELAY2_DISTANCE3] = 1400;	//默认报警距离50cm
+//        g_com_map[WAR_JDQ_TIME] = 1; //1秒
+//		g_com_map[POWER]=30;
+//        g_com_map[SPEEDFILTER_THRES]=10000;
+//		g_com_map[FILTER_COEFFICIENT]=40;
+//        g_com_map[ANT_LENGTH]=0;
+//        g_com_map[NOMOVESLEEP_TIME]=728;
+      
+        
 	OUT485_ENABLE;
 	ComMapCheck();	
-	g_com_map[VERSION] = 0x0137;
+	g_com_map[VERSION] = 0x013a;
     FLASH_Read(FLASH_HARDWARE_FLAG, (uint8_t*)&g_com_map[HARDWAREFLAG_INDEX], 16);
     dist_threshold = (g_com_map[SPEEDFILTER_THRES]*10)/(1000/g_com_map[COM_INTERVAL]);
-    g_commap_antdelay = (float)g_com_map[ANT_LENGTH]*5.8;
+    g_commap_antdelay = g_com_map[ANT_LENGTH];
     JDQ_time = g_com_map[WAR_JDQ_TIME]*10;
 	g_com_map[SW_TYPE] = 	SW_FANGZHUANG;
 	dev_id = g_com_map[DEV_ID];
@@ -142,18 +169,19 @@
 			module_power=67;
 		}
 	
-//	if(g_com_map[DEV_ROLE])
-//	{
-//	printf("标签ID: %d .\r\n",dev_id);
-//	printf("通讯间隔: %d ms.\r\n",g_com_map[COM_INTERVAL]);
-//	printf("单次通讯基站数量: %d个.\r\n",g_com_map[MAX_REPORT_ANC_NUM]);
-//	}else{
-//	
-//	anchor_type = dev_id%g_com_map[MAX_REPORT_ANC_NUM];
-//	printf("基站ID: %x .\r\n",dev_id);
-//	printf("基站类型: %c .\r\n",anchor_type+0x41);
-//	printf("单次通讯基站数量: %d个.\r\n",g_com_map[MAX_REPORT_ANC_NUM]);
-//	}
+	if(g_com_map[DEV_ROLE])
+	{
+		needanchorrx = 0;
+	printf("标签ID: %d .\r\n",dev_id);
+	printf("通讯间隔: %d ms.\r\n",g_com_map[COM_INTERVAL]);
+	printf("单次通讯基站数量: %d个.\r\n",g_com_map[MAX_REPORT_ANC_NUM]);
+	}else{
+	needanchorrx = 1;
+	anchor_type = dev_id%g_com_map[MAX_REPORT_ANC_NUM];
+	printf("基站ID: %x .\r\n",dev_id);
+	printf("基站类型: %c .\r\n",anchor_type+0x41);
+	printf("单次通讯基站数量: %d个.\r\n",g_com_map[MAX_REPORT_ANC_NUM]);
+	}
 	OUT485_DISABLE;
 //	printf("DEVICE PAIRID: %d .\r\n",g_com_map[PAIR_ID]);
 //	printf("DEVICE ALARM DISTANCE: 1.%d 2.%d 3.%d .\r\n",g_com_map[ALARM_DISTANCE1],g_com_map[ALARM_DISTANCE2],g_com_map[ALARM_DISTANCE3]);
@@ -161,7 +189,7 @@
 	
 	for(i=0;i<255;i++)
 	{
-		g_Tagdist[i]=0xffff;
+		g_Tagdist[i]=0x1ffff;
 	}
 }
 
@@ -281,7 +309,7 @@
 		}
 
 	}
-    
+
 int main(void)
 {
  
@@ -305,11 +333,13 @@
 	{
 		g_start_send_flag = 0;		
 		Tag_App();
+		needanchorrx = 1;
 	}
 		IdleTask();		
-if(g_com_map[DEV_ROLE]==0)
-		Anchor_App();
-
+if(g_com_map[DEV_ROLE]==0&&needanchorrx==1)
+    {needanchorrx = 0;
+        Anchor_Start();
+    }
 	}
 }
 

--
Gitblit v1.9.3