From f223f306a6810aa2c2c6181176ea54ed26256273 Mon Sep 17 00:00:00 2001 From: yincheng.zhong <634916154@qq.com> Date: 星期四, 22 十二月 2022 17:43:45 +0800 Subject: [PATCH] 2.61 增加时间片异常处理逻辑 --- Src/main.c | 64 +++++++++++++++++++++++--------- 1 files changed, 46 insertions(+), 18 deletions(-) diff --git a/Src/main.c b/Src/main.c index ac20bcc..99cf2eb 100644 --- a/Src/main.c +++ b/Src/main.c @@ -281,14 +281,14 @@ hardware_pici= STMFLASH_ReadHalfWord(FLASH_HARDWARE_VERSION_MAP+2); hardware_type= STMFLASH_ReadHalfWord(FLASH_HARDWARE_VERSION_MAP+4); //deca_sleep(1000); - g_com_map[VERSION] = 0x0229; + g_com_map[VERSION] = (2<<8)|61; // g_com_map[DEV_ID]=0x7; #ifdef DEBUG_MODE // g_com_map[DEV_ROLE]=1; -// g_com_map[DEV_ID]=0x4009; + // g_com_map[DEV_ID]=0x4009; // g_com_map[ACTIVE_INDEX]=1; - g_com_map[COM_INTERVAL]=50; +// g_com_map[COM_INTERVAL]=50; // g_com_map[MAX_REPORT_ANC_NUM]=1; // g_com_map[NOMOVESLEEP_TIME]=10; // g_com_map[IMU_ENABLE]=0; @@ -296,7 +296,7 @@ #endif //g_com_map[NOMOVESLEEP_TIME]=10; // g_com_map[IMU_ENABLE]=0; -// g_com_map[COM_INTERVAL]=1000; +// g_com_map[COM_INTERVAL]=50; active_flag = g_com_map[ACTIVE_INDEX]; if(active_flag==0) { @@ -313,12 +313,12 @@ group_id=g_com_map[GROUP_ID]; dev_id = g_com_map[DEV_ID]; //slottime=ceil((double)g_com_map[MAX_REPORT_ANC_NUM]*SLOT_SCALE)+3; - slottime = 5; + slottime = 5; max_slotpos=g_com_map[COM_INTERVAL]/slottime; tyncpoll_time=(g_com_map[DEV_ID]%max_slotpos)*slottime; slot_startcount=tyncpoll_time*1000/LPTIMER_LSB; lastpoll_time=tyncpoll_time; - tag_frequency = 1000/g_com_map[COM_INTERVAL]; + tag_frequency = 1; bigslot_num = TOTAL_SLOTNUM/tag_frequency; current_slotnum=1; current_time=GetLPTime(); @@ -352,14 +352,15 @@ void HardWareTypeDiffConfig(void) { -GPIO_InitTypeDef GPIO_InitStruct = {0}; -hardware_type=2; -if(hardware_type == 0) - hardware_type = 1; + GPIO_InitTypeDef GPIO_InitStruct = {0}; + if(g_com_map[MOTORBEEPER_INDEX]!=1&&g_com_map[MOTORBEEPER_INDEX]!=2) + { + g_com_map[MOTORBEEPER_INDEX] = 2; + } + hardware_type = g_com_map[MOTORBEEPER_INDEX]; switch(hardware_type) { - case 1: - + case 1: HAL_GPIO_WritePin(GPIOB, MOTOR_Pin, GPIO_PIN_SET); GPIO_InitStruct.Pin = MOTOR_Pin; GPIO_InitStruct.Mode = GPIO_MODE_OUTPUT_PP; @@ -415,7 +416,7 @@ /* USER CODE BEGIN 2 */ LED_LG_ON; Program_Init(); - LIS3DH_Data_Init(); + Accelerometer_Init(); BarInit(); Dw1000_Init(); Dw1000_App_Init(); @@ -428,7 +429,8 @@ { Error_Handler(); } - + + // HAL_Delay(2000); // mcu_sleep(); //LED0_BLINK; @@ -465,6 +467,7 @@ // HAL_GPIO_WritePin(LED0_GPIO, GPIO_PIN_9, GPIO_PIN_RESET); // } // LED_TR_BLINK; + __disable_irq(); if(bat_percent>15) { LED_TB_ON; Tag_App(); @@ -474,6 +477,7 @@ Tag_App(); LED_TR_OFF; } + __enable_irq(); //LED0_BLINK; IdleTask(); if(waitusart_timer>0) @@ -909,6 +913,8 @@ HAL_GPIO_Init(GPIOB, &GPIO_InitStruct); HAL_GPIO_Init(GPIOC, &GPIO_InitStruct); + + HAL_PWR_EnterSTOPMode(PWR_LOWPOWERREGULATOR_ON, PWR_STOPENTRY_WFI); HAL_PWR_DisableWakeUpPin(PWR_WAKEUP_PIN1); /*Clear all related wakeup flags*/ @@ -918,21 +924,43 @@ /*Enter the Standby mode*/ HAL_PWR_EnterSTANDBYMode(); } -extern u16 tagslotpos; -extern uint8_t tx_near_msg[80],stationary_flag,gotosleep_flag; + +extern u16 tagslotpos,current_slotpos; +extern uint8_t tx_near_msg[80],stationary_flag,gotosleep_flag,current_sync_sec,tagpoll_sync_sec,flag_tagnewpos; float key_keeptime; extern float motor_ontime; +extern uint16_t rec_tagperiod; +void GetRandomPos(void) +{ + current_slotpos = HAL_LPTIM_ReadCounter(&hlptim1)%max_slotpos; //如果丢失连接超过5次就随机换个时间片 + tagpoll_sync_sec = current_slotpos/200; + tagslotpos = current_slotpos%200; + flag_tagnewpos = 0; +} void HAL_LPTIM_CompareMatchCallback(LPTIM_HandleTypeDef *hlptim) { static uint8_t i=0; SystemClock_Config(); - g_start_send_flag=1; + // current_slotnum++; // SetNextPollTime(tagslotpos); + if(current_slotpos>=max_slotpos) + { + GetRandomPos(); + } + if(current_sync_sec==tagpoll_sync_sec) + { + g_start_send_flag=1; + } + current_sync_sec++; + if(current_sync_sec>=(rec_tagperiod)/10||current_sync_sec>10) + { + current_sync_sec=0; + } nomove_count+=1/(float)tag_frequency; if(motor_keeptime>0) { - motor_keeptime-=1/(float)tag_frequency; + motor_keeptime-=1/(float)tag_frequency; } if(motor_keeptime<0) {motor_keeptime = 0;} -- Gitblit v1.9.3