STM32 USART——printf重定向

串口通信:是一种设备间常用的串行,以比特位形式收发数据,电子工程师经常使用这种方式调试。

程序设计
PA9(TX),PA10(RX)

参考帮助文档STM32F4xx_StdPeriph_Examples/USART/USART_Printf/main.c

需要修改 Edit->Options for Target->target->Code Generation->Use Micro LIB打勾,其他不打勾,然后重定义库函数printf里面的fputc函数

/*串口初始化函数*/
void USART1_Init(uint32_t baud)
{
	//初始化用到的结构体,变量定义在最开头
	GPIO_InitTypeDef USART_InitStructure;
	NVIC_InitTypeDef USART_InitStructure;
	USART_InitTypeDef USART_InitStructure;

	//使能时钟
	RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_GPIOA, ENABLE);	//PA时钟
	RCC_APB2PeriphClockCmd(RCC_APB2Periph_USART1,ENABLE);	//串口一时钟

	//配置PA9,10引脚为多功能模式
	GPIO_InitStructure.GPIO_Pin = GPIO_Pin_9|GPIO_Pin_10;	//第9 10号引脚
	GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF;			//多功能模式
	GPIO_InitStructure.GPIO_OType = GPIO_OType_PP;			//可省略,推挽输出,增强驱动能力,引脚的输出电流更大
	GPIO_InitStructure.GPIO_Speed = GPIO_Speed_100MHz;		//可省略,引脚的速度最大为100MHz
	GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_NOPULL;		//可省略,没有使用内部上拉电阻
	GPIO_Init(GPIOA, &GPIO_InitStructure);	

	//将引脚连接到串口
	GPIO_PinAFConfig(GPIOA, GPIO_PinSource9, GPIO_AF_USART1);
	GPIO_PinAFConfig(GPIOA, GPIO_PinSource10, GPIO_AF_USART1);

	//USART的配置
	USART_InitStructure.USART_BaudRate = baud;										//波特率的配置
	USART_InitStructure.USART_WordLength = USART_WordLength_8b;						//8位的数据位
	USART_InitStructure.USART_StopBits = USART_StopBits_1;							//1个停止位
	USART_InitStructure.USART_Parity = USART_Parity_No;								//无校验
	USART_InitStructure.USART_HardwareFlowControl = USART_HardwareFlowControl_None;	//无流控制
	USART_InitStructure.USART_Mode = USART_Mode_Rx | USART_Mode_Tx;					//支持数据的发送与接收
	USART_Init(USART1, &USART_InitStructure);

	//串口中断配置
	NVIC_InitStructure.NVIC_IRQChannel = USART1_IRQn;
	NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 0;
	NVIC_InitStructure.NVIC_IRQChannelSubPriority = 0;
	NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;
	NVIC_Init(&NVIC_InitStructure);
	
	
	/* 使能串口1工作 */
	USART_Cmd(USART1, ENABLE);
	
	//设置串口接收到数据后,就触发中断
	USART_ITConfig(USART1, USART_IT_RXNE, ENABLE);
}

/*重定义fputc函数*/
int fputc(int ch,FILE *f)
{
	USART_SendData(USART1,ch);

	//检测当前的串口是否发送数据完成
	while(RESET==USART_GetFlagStatus(USART1,USART_FLAG_TXE));
	
	return ch;
}

/*发送数据*/
void usart1_send_bytes(uint8_t *pbuf,uint32_t len)
{
	while(len--)
	{
		USART_SendData(USART1,*pbuf++);
	
		//检测当前的串口是否发送数据完成
		while(RESET==USART_GetFlagStatus(USART1,USART_FLAG_TXE));
	
	}
}


int main(void)
{
	//配置中断优先级分组选择第二组
	NVIC_PriorityGroupConfig(NVIC_PriorityGroup_2);
	
	USART1_Init(115200);

	while(1)
	{}
}

/*串口中断函数*/
void USART1_IRQHandler(void)
{
	uint8_t d=0;
	
	//检测是否有接收到数据
	if(USART_GetITStatus(USART1,USART_IT_RXNE)==SET)
	{
		d= USART_ReceiveData(USART1);
	
		usart1_send_bytes(&d,1);		//打印1告诉自己接收成功
		
		//清空标志位,告诉CPU,我已经处理完毕,可以接收新的一次中断请求
		USART_ClearITPendingBit(USART1,USART_IT_RXNE);
	}
}

你可能感兴趣的:(STM32)