对比了一下,即使能LSI和LSE时钟,估计没有起振;例程只使能了HSI,就可以运行。 使能三个时钟: void SystemClock_Config(void) { RCC_OscInitTypeDef RCC_OscInitStruct = {0}; RCC_ClkInitTypeDef RCC_ClkInitStruct = {0}; RCC_PeriphCLKInitTypeDef PeriphClkInit = {0}; / Configure the main internal regulator output voltage */ HAL_PWREx_ControlVoltageScaling(PWR_REGULATOR_VOLTAGE_SCALE1); /* Configure LSE Drive Capability / __HAL_RCC_LSEDRIVE_CONFIG(RCC_LSEDRIVE_LOW); / Initializes the CPU, AHB and APB busses clocks */ RCC_OscInitStruct.OscillatorType = RCC_OSCILLATORTYPE_HSI|RCC_OSCILLATORTYPE_LSI |RCC_OSCILLATORTYPE_LSE; RCC_OscInitStruct.LSEState = RCC_LSE_ON; RCC_OscInitStruct.HSIState = RCC_HSI_ON; RCC_OscInitStruct.HSIDiv = RCC_HSI_DIV1; RCC_OscInitStruct.HSICalibrationValue = RCC_HSICALIBRATION_DEFAULT; RCC_OscInitStruct.LSIState = RCC_LSI_ON; RCC_OscInitStruct.PLL.PLLState = RCC_PLL_ON; RCC_OscInitStruct.PLL.PLLSource = RCC_PLLSOURCE_HSI; RCC_OscInitStruct.PLL.PLLM = RCC_PLLM_DIV1; RCC_OscInitStruct.PLL.PLLN = 8; RCC_OscInitStruct.PLL.PLLP = RCC_PLLP_DIV2; RCC_OscInitStruct.PLL.PLLR = RCC_PLLR_DIV2; if (HAL_RCC_OscConfig(&RCC_OscInitStruct) != HAL_OK) { Error_Handler(); } /* Initializes the CPU, AHB and APB busses clocks / RCC_ClkInitStruct.ClockType = RCC_CLOCKTYPE_HCLK|RCC_CLOCKTYPE_SYSCLK |RCC_CLOCKTYPE_PCLK1; RCC_ClkInitStruct.SYSCLKSource = RCC_SYSCLKSOURCE_PLLCLK; RCC_ClkInitStruct.AHBCLKDivider = RCC_SYSCLK_DIV1; RCC_ClkInitStruct.APB1CLKDivider = RCC_HCLK_DIV2; if (HAL_RCC_ClockConfig(&RCC_ClkInitStruct, FLASH_LATENCY_2) != HAL_OK) { Error_Handler(); } /* Initializes the peripherals clocks / PeriphClkInit.PeriphClockSelection = RCC_PERIPHCLK_RTC|RCC_PERIPHCLK_USART1 |RCC_PERIPHCLK_ADC; PeriphClkInit.Usart1ClockSelection = RCC_USART1CLKSOURCE_PCLK1; PeriphClkInit.AdcClockSelection = RCC_ADCCLKSOURCE_SYSCLK; PeriphClkInit.RTCClockSelection = RCC_RTCCLKSOURCE_LSE; if (HAL_RCCEx_PeriphCLKConfig(&PeriphClkInit) != HAL_OK) { Error_Handler(); } } / USER CODE BEGIN 4 / / USER CODE END 4 / /**
/ USER CODE END Error_Handler_Debug / } ifdef USE_FULL_ASSERT/**
|
STM32G030F6 ADC+DMA多通道非连续采样无法正常工作?
STM32G0B1VE的CAN过滤器个数问题
L9663驱动开发
stm32G474的flash模式如何判定?single bank 和dual bank
STM32G0B1adc+dma采样数据错位
stm32f103USART2无法收发信息
有没有stm32g071 Discovery kit的micropython的固件
STM32F405使用LL库建立SPI通讯报溢出是什么原因?
STM32F429以太网外设数据处理上限
STM32G0B1CBT6 Flash 不能写擦除,更不要说写入?fal库示例代码哪里有,分享一下,谢谢
小伙伴们上手芯片时,都是一个外设调好后再调另一个外设,一块一块搭积木的。
建议:先调试一个外设,并通过MCO检查硬件时钟是否正常工作。
Cube库中有相应的例程,调通后再调另一个外设。
你说的估计没有启振应该是指LSE,你可以进一步确认下。在CubeMx稍加配置后,可以通过LSCO脚直接示波器查看。
不过IWDG使用的使用的是LSI,与LSE无关,即你只要使能了IWDG它一定会工作。
会不会是IWDG没有及时喂狗导致了系统频繁复位,进而影响系统的正常工作,
当然就包括你提到的UART。你检查下iwdg的时间参数和喂狗的情况。
只是纯初始化了这两个外设就不行了,功能还没使能
是的,完全都能独立工作。不知道为啥,谢谢你的建议