From 28f37df5dd32d6630dbcc23dca88f6a3ae063d7f Mon Sep 17 00:00:00 2001 From: zhangbo <zhangbo@qq.com> Date: 星期五, 23 五月 2025 18:03:21 +0800 Subject: [PATCH] 移植了国产加速度计的计步逻辑,逻辑是30s没有步数进入休眠模式1分钟上传一次 --- keil/include/board/board.c | 35 ++++++++++++++++++++++------------- 1 files changed, 22 insertions(+), 13 deletions(-) diff --git a/keil/include/board/board.c b/keil/include/board/board.c index 3201d57..48be017 100644 --- a/keil/include/board/board.c +++ b/keil/include/board/board.c @@ -44,6 +44,7 @@ #include "mk_calib.h" #include "mk_misc.h" #include "mk_uwb.h" +#include <global_param.h> #ifdef WSF_EN #include "wsf_nvm.h" #endif @@ -113,6 +114,14 @@ #endif // LOG_INFO(TRACE_MODULE_APP, "Hello from MKSEMI!\r\n"); // LOG_INFO(TRACE_MODULE_APP, "Build information %s\r\n", mk_build_inf); +} +//修改波特率函数 +void board_debug_console_open_baud(enum TRACE_PORT_T port,enum UART_BAUD_T baud_rate) +{ +#if TRACE_EN + trace_open(port, baud_rate); + user_trace_port = port; +#endif } void board_calibration_params_default(void) @@ -407,7 +416,6 @@ gpio_pin_set_dir(ACCLERATE_DETECT_Pin , GPIO_DIR_IN, 0); io_pull_set(ACCLERATE_DETECT_Pin, IO_PULL_DOWN, IO_PULL_UP_LEVEL4); gpio_enable_irq(ACCLERATE_DETECT_Pin, GPIO_IRQ_TYPE_RISING_EDGE, accelerate_irq_handler); - } void board_4GUsart_detection_init(GPIO_IRQ_HANDLER_T irq_handler) //4G 串口输入检测中断,下拉触发 { @@ -416,7 +424,7 @@ gpio_pin_set_dir(_4G_USART_RX_Pin , GPIO_DIR_IN, 0); io_pull_set(_4G_USART_RX_Pin, IO_PULL_UP, IO_PULL_UP_LEVEL2); gpio_enable_irq(_4G_USART_RX_Pin, GPIO_IRQ_TYPE_FALLING_EDGE, _4Gusart_irq_handler); - power_wakeup_enable((enum POWER_WAKEUP_SOURCE_T)_4G_USART_RX_Pin, POWER_WAKEUP_LEVEL_LOW); +// power_wakeup_enable((enum POWER_WAKEUP_SOURCE_T)_4G_USART_RX_Pin, POWER_WAKEUP_LEVEL_LOW); } void pca_input_detection_init(GPIO_IRQ_HANDLER_T irq_handler) { @@ -456,13 +464,12 @@ { gpio_pin_toggle(idx); } -void board_output_init(void) -{ - //adc采集gnd默认拉高 - io_pin_mux_set(ADC_GND_ENABLE, IO_FUNC0); - gpio_pin_set_dir(ADC_GND_ENABLE , GPIO_DIR_OUT, 1); -// io_open_drain_set(ADC_GND_ENABLE, 1); - io_pull_set(ADC_GND_ENABLE,IO_HIGH_Z,IO_PULL_UP_NONE);//3 +void LED_output_init(void) +{ + //LEDgpio控制 + io_pin_mux_set(WS2812_PIN, IO_FUNC0); + gpio_pin_set_dir(WS2812_PIN , GPIO_DIR_OUT, 0); + io_pull_set(WS2812_PIN,IO_HIGH_Z,IO_PULL_UP_NONE);//3 } void board_configure(void) @@ -475,11 +482,13 @@ board_led_off(BOARD_LED_1); #endif } - +extern uint32_t gpsbaudrate; void board_restore_from_power_down(void) -{ +{ + test_uart_cfg.baud=gpsbaudrate; uart_open(UART_ID1, &test_uart_cfg); AIR780EUartInit(); + adc_open(&usr_adc_cfg); m_EUART_DMA_RXPtr = 0;//清空上次缓存器避免重复发 @@ -487,8 +496,8 @@ uci_tl_resume(); #else // button - restore interrupt type - gpio_enable_irq(_4G_USART_RX_Pin, GPIO_IRQ_TYPE_FALLING_EDGE, _4Gusart_irq_handler); - gpio_enable_irq(ACCLERATE_DETECT_Pin, GPIO_IRQ_TYPE_RISING_EDGE, accelerate_irq_handler); + gpio_enable_irq(PCA_INPUT_DETECT, GPIO_IRQ_TYPE_RISING_EDGE, pca_input_detect_irq_handler); +// gpio_enable_irq(ACCLERATE_DETECT_Pin, GPIO_IRQ_TYPE_RISING_EDGE, accelerate_irq_handler); // if (button_irq_handler) // { // gpio_enable_irq(BOARD_SW_1, GPIO_IRQ_TYPE_FALLING_EDGE, button_irq_handler); -- Gitblit v1.9.3