From 8217c70984ac4feb7bfc952e4f6e944bf824527d Mon Sep 17 00:00:00 2001 From: WXK <287788329@qq.com> Date: 星期二, 06 五月 2025 16:51:53 +0800 Subject: [PATCH] Merge branch 'MK大工卡-低精度GPS-1/5HZ' of http://47.108.70.204:60062/r/ChinaUWBProject into MK大工卡-低精度GPS-1/5HZ --- keil/include/main/main.c | 88 +++++++++++++++++++++++++++++-------------- 1 files changed, 59 insertions(+), 29 deletions(-) diff --git a/keil/include/main/main.c b/keil/include/main/main.c index 476ccbe..3f692d9 100644 --- a/keil/include/main/main.c +++ b/keil/include/main/main.c @@ -28,6 +28,8 @@ //#define DEBUG_MODE extern int simple_main(void); extern int temp_main(void); +void boot_deinit(void); +void upload_apppoll(); #define TEST_UART_POLL_MODE 0 #define TEST_UART_INTERUPT_MODE 1 #define TEST_UART_DMA_MODE 2 @@ -41,7 +43,7 @@ #define UWB_OPEN_COUNT 1 -#define UWB_MEASUREMENT_INTERVAL 3 +#define UWB_MEASUREMENT_INTERVAL 5 #define UWB_MEASUREMENT_INTERVAL_SLEEP 60 extern uint8_t mUsartReceivePack[100]; @@ -112,7 +114,7 @@ .flow = UART_FLOW_CONTROL_NONE, .rx_level = UART_RXFIFO_CHAR_1, .tx_level = UART_TXFIFO_EMPTY, - .baud = BAUD_115200, + .baud = BAUD_9600, #if (TEST_UART_MODE == TEST_UART_POLL_MODE) .dma_en = false, .int_rx = false, @@ -131,22 +133,31 @@ { uart_receive(UART_ID1,m_EUART_DMA_RXBuf,EUART_RX_BUF_SIZE,uart_receive_callback); } +uint8_t deep_sleep_falg=1; void mcu_deep_sleep(void) { - uint32_t lock; - trace_flush(); - lock = int_lock(); -// LOG_INFO(TRACE_MODULE_APP, "进入深度休眠\r\n"); +// uint32_t lock; +// trace_flush(); +// lock = int_lock(); +//// LOG_INFO(TRACE_MODULE_APP, "进入深度休眠\r\n"); // gps_air780_power_change(0,0);//关闭gps,4G + deep_sleep_falg=0; PCA9555_Set_One_Value_Output(LED_POWER,0);//输出低电平关闭LED PCA9555_Set_One_Value_Output(GPS_POWER,0);//关闭gps,4G + PCA9555_Set_One_Value_Config(MAIN_RI,0);//配置4G唤醒引脚为输入 +// PCA9555_Set_One_Value_Output(MAIN_RI,1); + boot_deinit(); + CloseUWB(); PCA9555_Set_One_Value_Output(AIR780E_ENBALE,0);//关闭gps,4G - sleep_timer_stop(); - //adc_close(); - power_enter_power_down_mode(1); -// LOG_INFO(TRACE_MODULE_APP, "从休眠出来\r\n"); - sys_reset(0); - int_unlock(lock); + +// sleep_timer_stop(); +// //adc_close(); +// power_enter_power_down_mode(1); +// delay_us(200000); + +// sys_reset(0); +//// LOG_INFO(TRACE_MODULE_APP, "从休眠出来\r\n"); +// int_unlock(lock); } static void adc_callback(void *data, uint32_t number) { @@ -161,7 +172,7 @@ { bat_percent = 0; } - else if(fVoltage_mv > 4100) + else if(fVoltage_mv > 4200) { bat_percent = 100; } @@ -196,6 +207,7 @@ { if(nomove_count>g_com_map[NOMOVESLEEP_TIME]&&g_com_map[IMU_ENABLE]==1) {//power_wakeup_enable((enum POWER_WAKEUP_SOURCE_T)ACCLERATE_DETECT_Pin, POWER_WAKEUP_LEVEL_HIGH); + power_wakeup_enable((enum POWER_WAKEUP_SOURCE_T)PCA_INPUT_DETECT, POWER_WAKEUP_LEVEL_LOW); mcu_deep_sleep(); } } @@ -305,6 +317,9 @@ { input5v_time=1; flag_secondtask = 1; + #ifdef UWB_1_5HZ + uwb_time_count++; + #endif if(!read_5v_input_pca()) { if(bat_percent>15) @@ -321,10 +336,11 @@ input5v_time=1; if(taglist_num==0) { - CloseUWB(); - Uwb_init(); - OpenUWB(); +// CloseUWB(); +// Uwb_init(); +// OpenUWB(); } + upload_apppoll(); }else{ flag_secondtask = 0; } @@ -365,6 +381,7 @@ send_struct.alarmDistence=prewarning_distance;//更新报警距离 memcpy(&send_struct.gunLableId,&g_com_map[BIND_DEV_ID],2);//更新绑定ID send_struct.tagId=dev_id;//更新设备ID + tag_frequency = 1000/g_com_map[COM_INTERVAL]; // g_com_map[IP_0]=111; // g_com_map[IP_1]=198; @@ -414,7 +431,7 @@ } g_com_map[MODBUS_MODE] = 0; log_4g_enable_flag=g_com_map[LOG_4G_ENABLE]; - g_com_map[VERSION] = (1<<8)|7; + g_com_map[VERSION] = (1<<8)|10; LOG_INFO(TRACE_MODULE_APP,"设备ID: %x .\r\n",dev_id); @@ -467,7 +484,7 @@ { nomove_count = 0; // adctick = HIDO_TimerGetTick(); - if(HIDO_TimerGetTick()-adctick>60) //10分钟采样一次 电量 + if(HIDO_TimerGetTick()-adctick>600) //10分钟采样一次 电量 { chongman_time=chongman_time+60; adctick = HIDO_TimerGetTick(); @@ -479,7 +496,7 @@ only_one_flag=1; chongman_time=0; } - if(bat_percent>=99&&chongman_time>=600) + if(bat_percent>=99&&chongman_time>=180) { powerled = GREEN; }else{ @@ -523,6 +540,7 @@ g_com_map[CNT_RESTART]=0; save_com_map_to_flash(); NVIC_SystemReset(); + } } else @@ -557,7 +575,7 @@ { g_com_map[CNT_RESTART]=0; NVIC_SystemReset(); - + } if(g_com_map[MAP_SIGN_INDEX]!=0x55AA||g_com_map[COM_INTERVAL]==0) { @@ -580,17 +598,23 @@ // UART0 TX/RX io_pin_mux_set(IO_PIN_5, IO_FUNC0); io_pin_mux_set(IO_PIN_6, IO_FUNC0); + gpio_pin_set_dir(IO_PIN_5 , GPIO_DIR_OUT, 0); + gpio_pin_set_dir(IO_PIN_6 , GPIO_DIR_OUT, 0); // UART1 RX/TX io_pin_mux_set(IO_PIN_10, IO_FUNC0); io_pin_mux_set(IO_PIN_9, IO_FUNC0); + uart_close(UART_ID1);//解绑原来串口1 uart_close(UART_ID0);//解绑原来串口0 } extern uint32_t uwb_time_count; +uint8_t GPS_UPLOAD_FLAG=0; void upload_apppoll() { - uint32_t elapsed_time_jibu; + uint32_t elapsed_time_jibu; +#ifdef UWB_1_5HZ + switch (current_state) { @@ -599,17 +623,20 @@ switch(elapsed_time_jibu) { case UWB_OPEN_COUNT: - - CloseUWB(); + CloseUWB(); +// uwbled = LEDOFF; + UWBSendUDPTask(); + GPS_UPLOAD_FLAG=1; break; case UWB_MEASUREMENT_INTERVAL: - OpenUWB(); - state_start_time = uwb_time_count; + OpenUWB(); +// uwbled = WHITE; + state_start_time = uwb_time_count; + break; } break; - case STATE_SLEEP: elapsed_time_jibu = uwb_time_count - state_start_time; switch(elapsed_time_jibu) @@ -627,7 +654,7 @@ } break; } - +#endif } uint8_t flag_4guart_needinit=0; @@ -684,6 +711,7 @@ IIC2_Init(); Accelerometer_Init(); PCA9555_init(); + WT588E02B_Init(); adc_open(&usr_adc_cfg); uart_receive(UART_ID1,m_EUART_DMA_RXBuf,EUART_RX_BUF_SIZE,uart_receive_callback); power_init(); @@ -693,7 +721,9 @@ adc_get(&sample[0], NUM_SAMPLES, adc_callback);//adc采样 pca_input_detection_init(pca_handler);//pca检测输入 Uwb_init(); - OpenUWB(); + #ifdef UWB_CK + OpenUWB(); + #endif // DBG_SetMode(DBG_MODE_SHELL); // Shell_Init(); @@ -727,7 +757,7 @@ flag_secondtask = 0; SecondTask(); } - IMUTask(); + IMUTask(); IdleTask(); } } -- Gitblit v1.9.3