From 59a4e01d92da432e9736b24c085089cd31963833 Mon Sep 17 00:00:00 2001 From: zhangbo <zhangbo@qq.com> Date: 星期三, 21 五月 2025 15:19:22 +0800 Subject: [PATCH] 修改了串口读取的bug,现在是通过飞线控制的 PCA蓝牙IRQ拉低,修改灯的闪灯逻辑, --- keil/include/main/main.c | 58 +++++++++++++++++++++++++++------------------------------- 1 files changed, 27 insertions(+), 31 deletions(-) diff --git a/keil/include/main/main.c b/keil/include/main/main.c index 323c301..f1b2324 100644 --- a/keil/include/main/main.c +++ b/keil/include/main/main.c @@ -171,10 +171,10 @@ .int_tx = false, #endif }; -void uart_receive_callback(void *dev, uint32_t err_code) -{ - uart_receive(UART_ID1,m_EUART_DMA_RXBuf,EUART_RX_BUF_SIZE,uart_receive_callback); -} +//void uart_receive_callback(void *dev, uint32_t err_code) +//{ +// uart_receive(UART_ID1,m_EUART_DMA_RXBuf,EUART_RX_BUF_SIZE,uart_receive_callback); +//} static void adc_callback(void *data, uint32_t number) { @@ -351,26 +351,19 @@ { sleep_time++; } - - if(!read_5v_input_pca()) { if(bat_percent>15) { - uint8_t state=0; - state=!state; - if(state==1) - GREEN_LED_ON; - else - GREEN_LED_OFF; - - + powerled=1; } else { powerled=0; } - } + } + + input5v_time=1; //马达震动逻辑 if(g_com_map[MOTOR_ENABLE]) @@ -448,7 +441,11 @@ { uart_receive(UART_ID0,m_EUART_DMA_RXBuf,EUART_RX_BUF_SIZE,uart0_receive_callback); } - + +void uart1_receive_callback() +{ + uart_receive(UART_ID1,m_EUART_DMA_RXBuf_1,USART_RX_BUF_SIZE,uart1_receive_callback); +} static void voltage_input_handler(enum IO_PIN_T pin) { @@ -467,13 +464,14 @@ void Program_Init(void) { Usart1ParseDataCallback = UsartParseDataHandler;//需改为默认为gps处理,UsartParseDataHandler为升级处理当调试时候改为 + Usart0ParseDataCallback = UsartParseDataHandler_1; parameter_init_anchor();//g_com_map表初始化角色默认为基站 - g_com_map[DEV_ID]=0x1234; +// g_com_map[DEV_ID]=0x0721; g_com_map[STATIONARY_TIME] = 10; // g_com_map[GROUP_ID]=1; dev_id=g_com_map[DEV_ID];//这里不太对 group_id=g_com_map[GROUP_ID];//组ID - group_id=0x04; +// group_id=0x04; tag_frequency = 1000/g_com_map[COM_INTERVAL];//测距频率这个存的是测距时间 memcpy(&disoffset,&g_com_map[DIST_OFFSET],2); // g_com_map[ALARM_DISTANCE1] = 40; @@ -499,7 +497,7 @@ ip2 = (g_com_map[TCP_IP_2]>>12&0xf)*1000+(g_com_map[TCP_IP_2]>>8&0xf)*100+(g_com_map[TCP_IP_2]>>4&0xf)*10+(g_com_map[TCP_IP_2]&0xf); ip3 = (g_com_map[TCP_IP_3]>>12&0xf)*1000+(g_com_map[TCP_IP_3]>>8&0xf)*100+(g_com_map[TCP_IP_3]>>4&0xf)*10+(g_com_map[TCP_IP_3]&0xf); port = g_com_map[TCP_PORT]; - g_com_map[VERSION] = (1<<8)|12; + g_com_map[VERSION] = (1<<8)|13; LOG_INFO(TRACE_MODULE_APP,"设备ID: %x .\r\n",dev_id); LOG_INFO(TRACE_MODULE_APP,"固件版本:BGK-mk+蓝牙薄工卡V%d.%d. \r\n",g_com_map[VERSION]>>8,g_com_map[VERSION]&0xff); LOG_INFO(TRACE_MODULE_APP,"服务器地址: %d.%d.%d.%d:%d.\r\n",ip0,ip1,ip2,ip3,port); @@ -510,6 +508,7 @@ void IdleTask(void) { UART0_CheckReceive(); + UART_CheckReceive(); if(read_5v_input_pca()) { chongman_time=0; @@ -628,7 +627,7 @@ } void IMUTask(void) { - if(nomove_count>g_com_map[NOMOVESLEEP_TIME]&&g_com_map[IMU_ENABLE]==2) + if(nomove_count>g_com_map[NOMOVESLEEP_TIME]&&g_com_map[IMU_ENABLE]==1) { power_wakeup_enable((enum POWER_WAKEUP_SOURCE_T)PCA_INPUT_DETECT, POWER_WAKEUP_LEVEL_LOW); mcu_deep_sleep(); @@ -674,6 +673,7 @@ io_pin_mux_set(UART1_TX, IO_FUNC4); board_debug_console_open(TRACE_PORT_UART1,BAUD_115200); + uart_receive(UART_ID1,m_EUART_DMA_RXBuf_1,USART_RX_BUF_SIZE,uart1_receive_callback);//开启dma } void spi_init() { @@ -767,12 +767,11 @@ case UWB_OPEN_COUNT: CloseUWB(); LoraReportPoll(); - LEDTask(0,0,0,2); - break; case UWB_MEASUREMENT_INTERVAL: LEDTask(uwbled,btled,loraled,powerled); + LEDTask(0,0,0,2); PCA9555_Set_One_Value_Output(IO_KONG,0); delay_us(10000); PCA9555_Set_One_Value_Output(IO_KONG,1); @@ -791,12 +790,13 @@ case UWB_OPEN_COUNT: CloseUWB(); LoraReportPoll(); - LEDTask(0,0,0,2); + break; case UWB_MEASUREMENT_INTERVAL_SLEEP: LEDTask(uwbled,btled,loraled,powerled); + LEDTask(0,0,0,2); PCA9555_Set_One_Value_Output(IO_KONG,0); delay_us(10000); PCA9555_Set_One_Value_Output(IO_KONG,1); @@ -840,19 +840,15 @@ if(powerled==1) { GREEN_LED_ON; - RED_LED_OFF; - } - else if(powerled==2) - { - RED_LED_OFF; - GREEN_LED_OFF; + GREEN_LED_OFF;; } else if(powerled==0) { RED_LED_ON; - GREEN_LED_OFF; + RED_LED_OFF; + } - + // PCA9555_Set_One_Value_Output(BT_IRQ ,0); -- Gitblit v1.9.3