STM32CubeMX配置-串口配置(RCC,Manager配置)

1.配置时钟

RCC时钟树如下:

    根据电路需求,如果选择外部时钟需要配置STM32CubeMX的RCC为HSE LSE,如果内部时钟,时钟树配置为HSI LSI,选择内部时钟如下:

2.配置DEBUG

烧录方式配置为SWD方式,需配置如下:

3.配置串口

配置为异步模式,参数设置,勾选NVIC优先级分组,如下:

4.工程配置 Project Manager

5.生成代码

生成代码默认不开中断,初始化时需打开中断,程序才会进入中断函数。

int main(void)
{
  /* USER CODE BEGIN 1 */
 
  /* USER CODE END 1 */

  /* MCU Configuration--------------------------------------------------------*/

  /* Reset of all peripherals, Initializes the Flash interface and the Systick. */
  HAL_Init();

  /* USER CODE BEGIN Init */

  /* USER CODE END Init */

  /* Configure the system clock */
  SystemClock_Config();

  /* USER CODE BEGIN SysInit */
  
  /* USER CODE END SysInit */

  /* Initialize all configured peripherals */
  MX_GPIO_Init();
  MX_USART2_UART_Init();
  /* USER CODE BEGIN 2 */

  /* USER CODE END 2 */

  /* Infinite loop */
  /* USER CODE BEGIN WHILE */
  while (1)
  {
    /* USER CODE END WHILE */

    /* USER CODE BEGIN 3 */
  }
  /* USER CODE END 3 */
}

串口回调函数调用:

void HAL_UART_RxCpltCallback(UART_HandleTypeDef *huart)
{
	if(huart->Instance == USART1)				
	{		
		if(HAL_UART_Receive_IT(&huart1,(uint8_t*)&rx, sizeof(rx)) == HAL_OK)
		{
			InterverDataHandle.g_su8RxBuf[InterverDataHandle.g_su8RxCnt] = rx;
			InterverDataHandle.g_su8RxCnt++;
			if(InterverDataHandle.g_su8RxCnt >= PS_MODULES_RX_LEN)
			{
				InterverDataHandle.g_su8RxCnt = 0;
			}
			InterverDataHandle.g_sbUartItFlag = 1;
		}	
	}
}

printf重定向

      c语言中printf函数默认输出设备是显示器,如果实现在串口或者LCD上显示,必须重定义标准库函数里面调用的输出设备定义的相关函数。

如果printf输出到串口,需要将fputc里面的输出指向串口,这一过程称为重定向。

printf函数位于标准库中,基于嵌入式的printf同样位于MicroLIB中,在嵌入式系统中使用printf函数,需要添加MicroLIB。

#include <stdio.h>

int fputc(int ch,FILE *f)
{
	HAL_UART_Transmit(&huart2, (uint8_t *)&ch, 1,0xFF);
	return ch;
}

注意闭坑:

        如果要调用中断函数,初始化时需打开中断。

        调用printf函数时,需勾选MicroLIB库。

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
以下是在STM32CubeMX配置DS18B20的步骤: 1. 在Pinout & Configuration选项卡中,选择您要使用的GPIO引脚,并将其配置为GPIO_Output_OD模式。此处我们使用的是PB12引脚。 2. 在Clock Configuration选项卡中,将TIM3时钟使能。 3. 在Configuration选项卡中,选择OneWire模式,并选择TIM3作为时钟源。 4. 在中间的Configuration选项卡中,选择DS18B20作为传感器类型,并输入OneWire总线的引脚。 5. 在Project Manager选项卡中,生成代码并在您的工程中使用。 下面是一个简单的示例代码以读取DS18B20传感器的温度值: ```c #include "stm32f1xx_hal.h" #include "ds18b20.h" void SystemClock_Config(void); int main(void) { HAL_Init(); SystemClock_Config(); DS18B20_Init(GPIOB, GPIO_PIN_12); while (1) { float temperature = DS18B20_ReadTemperature(GPIOB, GPIO_PIN_12); // 这里可以将温度值通过串口等方式输出 HAL_Delay(1000); } } void SystemClock_Config(void) { RCC_OscInitTypeDef RCC_OscInitStruct = {0}; RCC_ClkInitTypeDef RCC_ClkInitStruct = {0}; /** Initializes the RCC Oscillators according to the specified parameters * in the RCC_OscInitTypeDef structure. */ RCC_OscInitStruct.OscillatorType = RCC_OSCILLATORTYPE_HSI; RCC_OscInitStruct.HSIState = RCC_HSI_ON; RCC_OscInitStruct.HSICalibrationValue = RCC_HSICALIBRATION_DEFAULT; RCC_OscInitStruct.PLL.PLLState = RCC_PLL_NONE; if (HAL_RCC_OscConfig(&RCC_OscInitStruct) != HAL_OK) { Error_Handler(); } /** Initializes the CPU, AHB and APB buses clocks */ RCC_ClkInitStruct.ClockType = RCC_CLOCKTYPE_HCLK|RCC_CLOCKTYPE_SYSCLK |RCC_CLOCKTYPE_PCLK1|RCC_CLOCKTYPE_PCLK2; RCC_ClkInitStruct.SYSCLKSource = RCC_SYSCLKSOURCE_HSI; RCC_ClkInitStruct.AHBCLKDivider = RCC_SYSCLK_DIV1; RCC_ClkInitStruct.APB1CLKDivider = RCC_HCLK_DIV1; RCC_ClkInitStruct.APB2CLKDivider = RCC_HCLK_DIV1; if (HAL_RCC_ClockConfig(&RCC_ClkInitStruct, FLASH_LATENCY_0) != HAL_OK) { Error_Handler(); } } ``` 在这个例子中,我们在PB12引脚上使用了DS18B20传感器,并使用了TIM3作为OneWire总线的时钟源。在主函数中,我们初始化DS18B20,并在while循环中读取温度值并输出。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值