|
|
@ -61,6 +61,9 @@ |
|
|
|
|
|
|
|
|
|
|
|
/* USER CODE BEGIN Includes */ |
|
|
|
/* USER CODE BEGIN Includes */ |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
uint32_t led_tx_countdown = 0; |
|
|
|
|
|
|
|
uint32_t led_rx_countdown = 0; |
|
|
|
|
|
|
|
|
|
|
|
/* USER CODE END Includes */ |
|
|
|
/* USER CODE END Includes */ |
|
|
|
|
|
|
|
|
|
|
|
/* Private variables ---------------------------------------------------------*/ |
|
|
|
/* Private variables ---------------------------------------------------------*/ |
|
|
@ -82,7 +85,7 @@ void SystemClock_Config(void); |
|
|
|
|
|
|
|
|
|
|
|
/* USER CODE END 0 */ |
|
|
|
/* USER CODE END 0 */ |
|
|
|
|
|
|
|
|
|
|
|
extern void EXTI2_IRQHandler(void); |
|
|
|
extern void EXTI1_IRQHandler(void); |
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
/**
|
|
|
|
* @brief The application entry point. |
|
|
|
* @brief The application entry point. |
|
|
@ -113,6 +116,7 @@ int main(void) |
|
|
|
|
|
|
|
|
|
|
|
LL_APB2_GRP1_EnableClock(LL_APB2_GRP1_PERIPH_GPIOC); |
|
|
|
LL_APB2_GRP1_EnableClock(LL_APB2_GRP1_PERIPH_GPIOC); |
|
|
|
LL_APB2_GRP1_EnableClock(LL_APB2_GRP1_PERIPH_GPIOD); |
|
|
|
LL_APB2_GRP1_EnableClock(LL_APB2_GRP1_PERIPH_GPIOD); |
|
|
|
|
|
|
|
LL_APB2_GRP1_EnableClock(LL_APB2_GRP1_PERIPH_GPIOB); |
|
|
|
LL_APB2_GRP1_EnableClock(LL_APB2_GRP1_PERIPH_GPIOA); |
|
|
|
LL_APB2_GRP1_EnableClock(LL_APB2_GRP1_PERIPH_GPIOA); |
|
|
|
|
|
|
|
|
|
|
|
/* Initialize all configured peripherals */ |
|
|
|
/* Initialize all configured peripherals */ |
|
|
@ -123,23 +127,46 @@ int main(void) |
|
|
|
MX_USART1_UART_Init(); |
|
|
|
MX_USART1_UART_Init(); |
|
|
|
/* USER CODE BEGIN 2 */ |
|
|
|
/* USER CODE BEGIN 2 */ |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// give juice to the nrf module
|
|
|
|
|
|
|
|
LL_GPIO_ResetOutputPin(NRF_RESET_GPIO_Port, NRF_RESET_Pin); |
|
|
|
/* USER CODE END 2 */ |
|
|
|
/* USER CODE END 2 */ |
|
|
|
|
|
|
|
|
|
|
|
gw_setup_radio(); |
|
|
|
gw_setup_radio(); |
|
|
|
mq_init(&usb_inq); |
|
|
|
mq_init(&usb_inq); |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// re-enumerate USB
|
|
|
|
|
|
|
|
LL_GPIO_SetOutputPin(RENUM_GPIO_Port, RENUM_Pin); |
|
|
|
|
|
|
|
LL_mDelay(100); |
|
|
|
|
|
|
|
LL_GPIO_ResetOutputPin(RENUM_GPIO_Port, RENUM_Pin); |
|
|
|
|
|
|
|
|
|
|
|
dbg("Main loop starts."); |
|
|
|
dbg("Main loop starts."); |
|
|
|
/* Infinite loop */ |
|
|
|
/* Infinite loop */ |
|
|
|
/* USER CODE BEGIN WHILE */ |
|
|
|
/* USER CODE BEGIN WHILE */ |
|
|
|
int cnt = 0; |
|
|
|
uint32_t cnt = 0; |
|
|
|
uint8_t buff[MQ_SLOT_LEN]; |
|
|
|
uint8_t buff[MQ_SLOT_LEN]; |
|
|
|
|
|
|
|
|
|
|
|
while (1) { |
|
|
|
while (1) { |
|
|
|
if (cnt++ > 500000) { |
|
|
|
cnt++; |
|
|
|
LL_GPIO_TogglePin(LED_GPIO_Port, LED_Pin); |
|
|
|
if (cnt > 1400000) { |
|
|
|
|
|
|
|
LL_GPIO_SetOutputPin(LED_GPIO_Port, LED1_Pin); |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
if (cnt > 1500000) { |
|
|
|
|
|
|
|
LL_GPIO_ResetOutputPin(LED_GPIO_Port, LED1_Pin); |
|
|
|
cnt = 0; |
|
|
|
cnt = 0; |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (led_tx_countdown > 0) { |
|
|
|
|
|
|
|
if (--led_tx_countdown == 0) { |
|
|
|
|
|
|
|
LL_GPIO_ResetOutputPin(LED_GPIO_Port, LEDTX_Pin); |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (led_rx_countdown > 0) { |
|
|
|
|
|
|
|
if (--led_rx_countdown == 0) { |
|
|
|
|
|
|
|
LL_GPIO_ResetOutputPin(LED_GPIO_Port, LEDRX_Pin); |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
if (mq_can_read(&usb_inq)) { |
|
|
|
if (mq_can_read(&usb_inq)) { |
|
|
|
if (!usb_tx_busy) { |
|
|
|
if (!usb_tx_busy) { |
|
|
|
mq_read(&usb_inq, buff); |
|
|
|
mq_read(&usb_inq, buff); |
|
|
@ -160,15 +187,13 @@ void SystemClock_Config(void) |
|
|
|
|
|
|
|
|
|
|
|
LL_FLASH_SetLatency(LL_FLASH_LATENCY_2); |
|
|
|
LL_FLASH_SetLatency(LL_FLASH_LATENCY_2); |
|
|
|
|
|
|
|
|
|
|
|
if(LL_FLASH_GetLatency() != LL_FLASH_LATENCY_2) |
|
|
|
if (LL_FLASH_GetLatency() != LL_FLASH_LATENCY_2) { |
|
|
|
{ |
|
|
|
|
|
|
|
Error_Handler(); |
|
|
|
Error_Handler(); |
|
|
|
} |
|
|
|
} |
|
|
|
LL_RCC_HSE_Enable(); |
|
|
|
LL_RCC_HSE_Enable(); |
|
|
|
|
|
|
|
|
|
|
|
/* Wait till HSE is ready */ |
|
|
|
/* Wait till HSE is ready */ |
|
|
|
while(LL_RCC_HSE_IsReady() != 1) |
|
|
|
while (LL_RCC_HSE_IsReady() != 1) { |
|
|
|
{ |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
} |
|
|
|
} |
|
|
|
LL_RCC_PLL_ConfigDomain_SYS(LL_RCC_PLLSOURCE_HSE_DIV_1, LL_RCC_PLL_MUL_9); |
|
|
|
LL_RCC_PLL_ConfigDomain_SYS(LL_RCC_PLLSOURCE_HSE_DIV_1, LL_RCC_PLL_MUL_9); |
|
|
@ -176,8 +201,7 @@ void SystemClock_Config(void) |
|
|
|
LL_RCC_PLL_Enable(); |
|
|
|
LL_RCC_PLL_Enable(); |
|
|
|
|
|
|
|
|
|
|
|
/* Wait till PLL is ready */ |
|
|
|
/* Wait till PLL is ready */ |
|
|
|
while(LL_RCC_PLL_IsReady() != 1) |
|
|
|
while (LL_RCC_PLL_IsReady() != 1) { |
|
|
|
{ |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
} |
|
|
|
} |
|
|
|
LL_RCC_SetAHBPrescaler(LL_RCC_SYSCLK_DIV_1); |
|
|
|
LL_RCC_SetAHBPrescaler(LL_RCC_SYSCLK_DIV_1); |
|
|
@ -189,8 +213,7 @@ void SystemClock_Config(void) |
|
|
|
LL_RCC_SetSysClkSource(LL_RCC_SYS_CLKSOURCE_PLL); |
|
|
|
LL_RCC_SetSysClkSource(LL_RCC_SYS_CLKSOURCE_PLL); |
|
|
|
|
|
|
|
|
|
|
|
/* Wait till System clock is ready */ |
|
|
|
/* Wait till System clock is ready */ |
|
|
|
while(LL_RCC_GetSysClkSource() != LL_RCC_SYS_CLKSOURCE_STATUS_PLL) |
|
|
|
while (LL_RCC_GetSysClkSource() != LL_RCC_SYS_CLKSOURCE_STATUS_PLL) { |
|
|
|
{ |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
} |
|
|
|
} |
|
|
|
LL_Init1msTick(72000000); |
|
|
|
LL_Init1msTick(72000000); |
|
|
@ -202,7 +225,7 @@ void SystemClock_Config(void) |
|
|
|
LL_RCC_SetUSBClockSource(LL_RCC_USB_CLKSOURCE_PLL_DIV_1_5); |
|
|
|
LL_RCC_SetUSBClockSource(LL_RCC_USB_CLKSOURCE_PLL_DIV_1_5); |
|
|
|
|
|
|
|
|
|
|
|
/* SysTick_IRQn interrupt configuration */ |
|
|
|
/* SysTick_IRQn interrupt configuration */ |
|
|
|
NVIC_SetPriority(SysTick_IRQn, NVIC_EncodePriority(NVIC_GetPriorityGrouping(),0, 0)); |
|
|
|
NVIC_SetPriority(SysTick_IRQn, NVIC_EncodePriority(NVIC_GetPriorityGrouping(), 0, 0)); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
/* USER CODE BEGIN 4 */ |
|
|
|
/* USER CODE BEGIN 4 */ |
|
|
@ -219,13 +242,13 @@ void _Error_Handler(char *file, int line) |
|
|
|
{ |
|
|
|
{ |
|
|
|
/* USER CODE BEGIN Error_Handler_Debug */ |
|
|
|
/* USER CODE BEGIN Error_Handler_Debug */ |
|
|
|
/* User can add his own implementation to report the HAL error return state */ |
|
|
|
/* User can add his own implementation to report the HAL error return state */ |
|
|
|
while(1) |
|
|
|
while (1) { |
|
|
|
{ |
|
|
|
|
|
|
|
} |
|
|
|
} |
|
|
|
/* USER CODE END Error_Handler_Debug */ |
|
|
|
/* USER CODE END Error_Handler_Debug */ |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
#ifdef USE_FULL_ASSERT |
|
|
|
#ifdef USE_FULL_ASSERT |
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
/**
|
|
|
|
* @brief Reports the name of the source file and the source line number |
|
|
|
* @brief Reports the name of the source file and the source line number |
|
|
|
* where the assert_param error has occurred. |
|
|
|
* where the assert_param error has occurred. |
|
|
@ -233,13 +256,14 @@ void _Error_Handler(char *file, int line) |
|
|
|
* @param line: assert_param error line source number |
|
|
|
* @param line: assert_param error line source number |
|
|
|
* @retval None |
|
|
|
* @retval None |
|
|
|
*/ |
|
|
|
*/ |
|
|
|
void assert_failed(uint8_t* file, uint32_t line) |
|
|
|
void assert_failed(uint8_t *file, uint32_t line) |
|
|
|
{ |
|
|
|
{ |
|
|
|
/* USER CODE BEGIN 6 */ |
|
|
|
/* USER CODE BEGIN 6 */ |
|
|
|
/* User can add his own implementation to report the file name and line number,
|
|
|
|
/* User can add his own implementation to report the file name and line number,
|
|
|
|
tex: printf("Wrong parameters value: file %s on line %d\r\n", file, line) */ |
|
|
|
tex: printf("Wrong parameters value: file %s on line %d\r\n", file, line) */ |
|
|
|
/* USER CODE END 6 */ |
|
|
|
/* USER CODE END 6 */ |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
#endif /* USE_FULL_ASSERT */ |
|
|
|
#endif /* USE_FULL_ASSERT */ |
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
/**
|
|
|
|