From 928251d0f4e554e66ea2c7453fe06de6675ae16e Mon Sep 17 00:00:00 2001 From: WXK <287788329@qq.com> Date: 星期三, 26 三月 2025 14:49:41 +0800 Subject: [PATCH] 去掉ota,单独搞ota文件 --- keil/include/main/main.c | 177 +++++++++++++++++++++++++++++++++++++++++------------------ 1 files changed, 123 insertions(+), 54 deletions(-) diff --git a/keil/include/main/main.c b/keil/include/main/main.c index 4f5e77a..bfd50f2 100644 --- a/keil/include/main/main.c +++ b/keil/include/main/main.c @@ -370,31 +370,31 @@ // g_com_map[IP_3]=6; // g_com_map[PORT]=6666; - g_com_map[IP_0]=117; - g_com_map[IP_1]=72; - g_com_map[IP_2]=111; - g_com_map[IP_3]=237; - g_com_map[PORT]=7000; - - g_com_map[TCP_IP_0]=111; - g_com_map[TCP_IP_1]=198; - g_com_map[TCP_IP_2]=60; - g_com_map[TCP_IP_3]=6; - g_com_map[TCP_PORT]=1234; +// g_com_map[IP_0]=117; +// g_com_map[IP_1]=72; +// g_com_map[IP_2]=111; +// g_com_map[IP_3]=237; +// g_com_map[PORT]=7000; +// +// g_com_map[TCP_IP_0]=111; +// g_com_map[TCP_IP_1]=198; +// g_com_map[TCP_IP_2]=60; +// g_com_map[TCP_IP_3]=6; +// g_com_map[TCP_PORT]=1234; /* RTCMMODE_NONE, RTCMMODE_TCP, RTCMMODE_NTRIP, */ - g_com_map[RTCMMODE_INDEX] = RTCMMODE_TCP; +// g_com_map[RTCMMODE_INDEX] = RTCMMODE_NTRIP; - snprintf((char *)&g_com_map[NTRIP_HOST_INDEX], 32, "140.143.212.42"); - g_com_map[NTRIP_PORT_INDEX] = HIDO_UtilStrToInt("8005"); -// snprintf((char *)&g_com_map[NTRIP_PORT_INDEX], 32, "8005"); - snprintf((char *)&g_com_map[NTRIP_USERNANME_INDEX], 32, "test005"); - snprintf((char *)&g_com_map[NTRIP_PASSWORD_INDEX], 32, "Hxzk0228"); - snprintf((char *)&g_com_map[NTRIP_SOURCENAME_INDEX], 32, "RTCM32_GNSS2"); +// snprintf((char *)&g_com_map[NTRIP_HOST_INDEX], 32, "140.143.212.42"); +// g_com_map[NTRIP_PORT_INDEX] = HIDO_UtilStrToInt("8005"); +//// snprintf((char *)&g_com_map[NTRIP_PORT_INDEX], 32, "8005"); +// snprintf((char *)&g_com_map[NTRIP_USERNANME_INDEX], 32, "test005"); +// snprintf((char *)&g_com_map[NTRIP_PASSWORD_INDEX], 32, "Hxzk0228"); +// snprintf((char *)&g_com_map[NTRIP_SOURCENAME_INDEX], 32, "RTCM32_GNSS2"); if(g_com_map[BIND_DEV_ID]==0) @@ -416,7 +416,7 @@ LOG_INFO(TRACE_MODULE_APP,"设备ID: %x .\r\n",dev_id); - LOG_INFO(TRACE_MODULE_APP,"固件版本:4G-GPS定位手环 V%d.%d. \r\n",g_com_map[VERSION]>>8,g_com_map[VERSION]&0xff); + LOG_INFO(TRACE_MODULE_APP,"固件版本:4G-GPS定位工卡 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",g_com_map[IP_0],g_com_map[IP_1],g_com_map[IP_2],g_com_map[IP_3],g_com_map[PORT]); if(g_com_map[RTCMMODE_INDEX] == RTCMMODE_TCP) { @@ -434,13 +434,14 @@ { LOG_INFO(TRACE_MODULE_APP,"单点定位模式模式. \r\n"); } + delay_ms(500); } uint32_t adctick = 0; uint8_t only_one_flag; uint16_t chongman_time; uint8_t bat_percent_old=100; uint8_t input5vflag; -uint8_t kai_4g_flag; +extern uint8_t ota_flag; void IdleTask(void) { if(read_5v_input_pca()) @@ -463,9 +464,10 @@ while(1) { nomove_count = 0; - if(HIDO_TimerGetTick()-adctick>6000) //10分钟采样一次 电量 +// adctick = HIDO_TimerGetTick(); + if(HIDO_TimerGetTick()-adctick>60) //10分钟采样一次 电量 { - chongman_time=chongman_time+6; + chongman_time=chongman_time+60; adctick = HIDO_TimerGetTick(); PCA9555_Set_One_Value_Output(ADC_MINIUS,0);//拉低 adc_get(&sample[0], NUM_SAMPLES, adc_callback);//adc采样 @@ -475,7 +477,7 @@ only_one_flag=1; chongman_time=0; } - if(bat_percent>=99&&chongman_time>=1800) + if(bat_percent>=99&&chongman_time>=600) { powerled = GREEN; }else{ @@ -483,19 +485,27 @@ } if(DBG_GetMode() == DBG_MODE_SHELL) { - if(kai_4g_flag==0) - { - kai_4g_flag=1; -// PCA9555_Set_One_Value_Output(AIR780E_ENBALE,1); - Shell_Init(); - } - if(g_com_map[RTCMMODE_INDEX] == RTCMMODE_TCP) - {TCPClient_Poll_1();} - HIDO_InputPoll(); - Internet_Poll(); - HIDO_TimerPoll(); - HIDO_ATLitePoll(); - TCPClient_Poll(); + if(ota_flag==1) + { +// OTA_Poll(); +// HTTPClient_Poll(); + } + else + { + uwb_app_poll(); + } + Internet_Poll(); + HIDO_TimerPoll(); + HIDO_ATLitePoll(); + TCPClient_Poll(); + if(g_com_map[RTCMMODE_INDEX] == RTCMMODE_TCP) + {TCPClient_Poll_1();} + if(flag_secondtask) + { + flag_secondtask = 0; + SecondTask(); + } + UserKeyTask(); } UART_CheckReceive(); if(flag_secondtask) @@ -506,6 +516,12 @@ if(DBG_GetMode() == DBG_MODE_SHELL) { Set4LEDColor(uwbled,rtkled,led4g,powerled); + if(g_com_map[CNT_RESTART]==1) + { + g_com_map[CNT_RESTART]=0; + save_com_map_to_flash(); + NVIC_SystemReset(); + } } else { @@ -568,6 +584,7 @@ uart_close(UART_ID1);//解绑原来串口1 uart_close(UART_ID0);//解绑原来串口0 } + uint8_t flag_4guart_needinit=0; uint8_t index1,index2,index3; int16_t Voltage_input; @@ -577,6 +594,53 @@ extern uint8_t receive_flag; extern uint8_t YUANGPS_ParseGGA_data[256]; extern uint8_t YUANGPS_ParseGGA_changdu; +static HIDO_CHAR url[256 + 1]; +//void OTA_MODE(void) +//{ +// if(g_com_map[OTA_FLAG]) +// { +// Uart_Register(UART_ID_4G, UART_ID0); +// Uart_Register(UART_ID_DBG_GPS, UART_ID1); +// DBG_Init(); +// DBG_SetMode(DBG_MODE_SHELL); +// Internet_Init(); +// // TCPClient_Init(); +// HTTPClient_Init(); +// gpio_open(); +// LED_output_init();//配置彩色灯引脚 +// IIC2_Init(); +// // Accelerometer_Init(); +// PCA9555_init(); +// uart_receive(UART_ID1,m_EUART_DMA_RXBuf,EUART_RX_BUF_SIZE,uart_receive_callback); +// power_init(); +// sleep_timer_open(true, SLEEP_TIMER_MODE_RELOAD, sleep_timer_callback); +// sleep_timer_start(__MS_TO_32K_CNT(SLEEP_TIMER_NUM));//测试 +// pca_input_detection_init(pca_handler);//pca检测输入 +// state5v=1; +// state5V_prase_flag=state5v; +// gps_prase_flag=0;//解除gps解析 +// uart1_change_from_gps_to_debug();//测试 +// PCA9555_Set_One_Value_Output(MCU_A,1);//输出高电平切换为5V输入 +// memcpy((HIDO_UINT8 *)url,g_com_map+OTA_URL_INDEX,g_com_map[OTA_URL_CHANGDU]); +// OTA_Start((HIDO_UINT8 *)url); +// +//// g_com_map[OTA_FLAG]=0; +//// save_com_map_to_flash(); +//// delay_us(100000); +//// NVIC_SystemReset(); //软复位回到bootloader +// +// +// while (1) +// { +// OTA_Poll(); +// HTTPClient_Poll(); +// Internet_Poll(); +// HIDO_TimerPoll(); +// HIDO_ATLitePoll(); +//// IdleTask(); +// } +// } +//} int main(void) { board_clock_run(); @@ -600,9 +664,11 @@ } calib_chip(); wdt_close(WDT_ID0); - Uart_Register(UART_ID_4G, UART_ID0); -// Uart_Register(UART_ID_DBG, UART_ID1); Program_Init(); + Uart_Register(UART_ID_4G, UART_ID0); + Uart_Register(UART_ID_DBG_GPS, UART_ID1); + DBG_Init(); + Internet_Init(); TCPClient_Init(); if(g_com_map[RTCMMODE_INDEX] == RTCMMODE_NTRIP) @@ -614,6 +680,7 @@ { TCPClient_Init_1(); } +// HTTPClient_Init(); gpio_open(); LED_output_init();//配置彩色灯引脚 IIC2_Init(); @@ -629,7 +696,6 @@ pca_input_detection_init(pca_handler);//pca检测输入 Uwb_init(); OpenUWB(); - DBG_Init(); // DBG_SetMode(DBG_MODE_SHELL); // Shell_Init(); @@ -641,28 +707,31 @@ delay_ms(500); Set4LEDColor(LEDOFF,LEDOFF,LEDOFF,LEDOFF); } - g_com_map[MODBUS_MODE] = 0; - state5v=0; - state5V_prase_flag=state5v; - gps_prase_flag=1;//恢复gps解析 - uart1_change_from_debug_to_gps();//测试 - PCA9555_Set_One_Value_Output(MCU_A,0);//输出低电平切换为GPS + g_com_map[MODBUS_MODE] = 0; + state5v=0; + state5V_prase_flag=state5v; + gps_prase_flag=1;//恢复gps解析 + uart1_change_from_debug_to_gps();//测试 + PCA9555_Set_One_Value_Output(MCU_A,0);//输出低电平切换为GPS while (1) { - uwb_app_poll(); + if(ota_flag==1) + { +// OTA_Poll(); +// HTTPClient_Poll(); + } + else + { + uwb_app_poll(); + } Internet_Poll(); HIDO_TimerPoll(); HIDO_ATLitePoll(); TCPClient_Poll(); if(g_com_map[RTCMMODE_INDEX] == RTCMMODE_TCP) - {TCPClient_Poll_1();} -// if(g_com_map[RTCMMODE_INDEX] == RTCMMODE_NTRIP&&gps_ntripsend==2) -// { -// gps_ntripsend=0; -// NTRIPApp_ReportGGA(YUANGPS_ParseGGA_data, YUANGPS_ParseGGA_changdu); -// memset(YUANGPS_ParseGGA_data,0,YUANGPS_ParseGGA_changdu); -// YUANGPS_ParseGGA_changdu=0; -// } + { + TCPClient_Poll_1(); + } if(flag_secondtask) { flag_secondtask = 0; -- Gitblit v1.9.3