stm32f103串口printf,scanf函数串口重定向

首先配置USART串口(初始化这些)

重定向函数

先看代码

uart.c中

#include <usart.h>
#include <main.h>

void usart2_init(unsigned long blud)
{
	GPIO_InitTypeDef GPIO_InitStruct;
	
	RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA,  ENABLE);
	RCC_APB1PeriphClockCmd(RCC_APB1Periph_USART2, ENABLE);
	//PA2-TX
	
	GPIO_InitStruct.GPIO_Mode = GPIO_Mode_AF_PP;
	GPIO_InitStruct.GPIO_Pin = GPIO_Pin_2;
	GPIO_InitStruct.GPIO_Speed  = GPIO_Speed_50MHz;
	GPIO_Init(GPIOA,&GPIO_InitStruct);
	
	//PA3_RX
	GPIO_InitStruct.GPIO_Mode  = GPIO_Mode_IN_FLOATING;
	GPIO_InitStruct.GPIO_Pin  = GPIO_Pin_3;
	GPIO_Init(GPIOA,&GPIO_InitStruct);
	
	USART_InitTypeDef USART_InitStruct;
	
	USART_InitStruct.USART_BaudRate = blud;
	USART_InitStruct.USART_HardwareFlowControl =USART_HardwareFlowControl_None;
	USART_InitStruct.USART_Mode =USART_Mode_Rx | USART_Mode_Tx;
	USART_InitStruct.USART_Parity  = USART_Parity_No;
	USART_InitStruct.USART_StopBits  = USART_StopBits_1;
	USART_InitStruct.USART_WordLength  =USART_WordLength_8b;
	USART_Init(USART2,&USART_InitStruct);
	
	USART_Cmd(USART2,ENABLE);
	/*
	USART_ITConfig(USART2,USART_IT_RXNE,ENABLE);
	
	NVIC_InitTypeDef NVIC_InitStruct;
	
	NVIC_InitStruct.NVIC_IRQChannel = USART2_IRQn;
	NVIC_InitStruct.NVIC_IRQChannelCmd  = ENABLE;
	NVIC_InitStruct.NVIC_IRQChannelPreemptionPriority  = 1;
	NVIC_InitStruct.NVIC_IRQChannelSubPriority  = 1;
	
	NVIC_PriorityGroupConfig(NVIC_PriorityGroup_2);
	NVIC_Init(&NVIC_InitStruct);*/
	



}

void sendbit(USART_TypeDef* USARTx,unsigned char  uchar)
{
	USART_SendData(USARTx,uchar);
	while(!USART_GetFlagStatus(USARTx,USART_FLAG_TXE));
}

void senstring(USART_TypeDef* USARTx,char* string)
{
	char* str=string;
	while(*str)
	{
		sendbit(USARTx,*str);
		str++;
	}
	
}
int fputc(int ch,FILE *f)
{
	sendbit(UART_PRINTF,(uint8_t)ch);
	return ch;
}
/*int fputc(int ch,FILE *f)
{  
    while(USART_GetFlagStatus(USART2,USART_FLAG_TC) != SET); 
    USART_SendData(USART2,(unsigned char)ch);    
    while(USART_GetFlagStatus(USART2,USART_FLAG_TC) != SET);  
    return (ch);  
}
 */


int fgetc(FILE *f)
{
	while(!USART_GetFlagStatus(USART_SCANF,USART_FLAG_RXNE));
	return (int)USART_ReceiveData(USART_SCANF);
}



main函数中


int main(void)
{
	int a;
	usart2_init(115200);
	while(1)
	{
		printf("Hello");
		scanf("%d",&a);
		printf("a+1=%d",a+1);
	}		
}

附上效果图吧
注意要勾上发送新行

值得注意的是重定义函数之后之前定义的NVIC中断都不需要了

  • 2
    点赞
  • 19
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
STM32F103C8T6是一款基于ARM Cortex-M3内核的微控制器,它是STMicroelectronics公司推出的一款低功耗、高性能的单片机。HAL(Hardware Abstraction Layer)是STMicroelectronics提供的一套软件库,用于简化STM32微控制器的开发过程。 串口重定向是指将标准输入输出函数(如printfscanf重定向串口进行数据的输入输出。在STM32F103C8T6上使用HAL库进行串口重定向的步骤如下: 1. 配置串口:首先需要配置串口的参数,包括波特率、数据位、停止位、校验位等。可以使用HAL库提供的函数进行配置,例如`HAL_UART_Init()`。 2. 重定向标准输入输出流:通过重定向标准输入输出流,可以使用标准输入输出函数(如printfscanf)进行串口的数据输入输出。可以使用HAL库提供的函数,例如`HAL_UART_Receive()`和`HAL_UART_Transmit()`。 3. 重写标准输入输出函数:为了实现串口重定向,需要重写标准输入输出函数。可以通过重写`_write()`和`_read()`函数来实现。在这些函数中,可以调用HAL库提供的函数进行数据的发送和接收。 下面是一个示例代码,演示了如何使用HAL库进行串口重定向: ```c #include "stm32f1xx_hal.h" #include "stdio.h" UART_HandleTypeDef huart1; void SystemClock_Config(void); static void MX_GPIO_Init(void); static void MX_USART1_UART_Init(void); int _write(int file, char *ptr, int len) { HAL_UART_Transmit(&huart1, (uint8_t *)ptr, len, HAL_MAX_DELAY); return len; } int _read(int file, char *ptr, int len) { HAL_UART_Receive(&huart1, (uint8_t *)ptr, len, HAL_MAX_DELAY); return len; } int main(void) { HAL_Init(); SystemClock_Config(); MX_GPIO_Init(); MX_USART1_UART_Init(); printf("Hello, World!\n"); while (1) { // 读取串口数据并处理 char data; scanf("%c", &data); // 处理数据... // 发送数据到串口 printf("Received: %c\n", data); } } void SystemClock_Config(void) { // 系统时钟配置... } static void MX_GPIO_Init(void) { // GPIO初始化... } static void MX_USART1_UART_Init(void) { huart1.Instance = USART1; huart1.Init.BaudRate = 115200; huart1.Init.WordLength = UART_WORDLENGTH_8B; huart1.Init.StopBits = UART_STOPBITS_1; huart1.Init.Parity = UART_PARITY_NONE; huart1.Init.Mode = UART_MODE_TX_RX; huart1.Init.HwFlowCtl = UART_HWCONTROL_NONE; huart1.Init.OverSampling = UART_OVERSAMPLING_16; if (HAL_UART_Init(&huart1) != HAL_OK) { Error_Handler(); } } ```
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值