stm32F407学习DAY.16 多串口实现printf输出(fputc重定向+自定义printf函数)

为了让多个串口可以同时实现printf输出,有两种方法:重定向fputc函数或自定义一个串口的printf函数。

目录

一、重定向fputc

二、自定义printf函数


一、重定向fputc

写在usart.c中,实现串口1的printf输出

//加入以下代码,支持printf函数,而不需要选择use MicroLIB	  
#if 1
#pragma import(__use_no_semihosting)             
//标准库需要的支持函数                 
struct __FILE 
{ 
	int handle; 
}; 

FILE __stdout;       
//定义_sys_exit()以避免使用半主机模式    
void _sys_exit(int x) 
{ 
	x = x; 
} 
//重定义fputc函数 
int fputc(int ch, FILE *f)
{ 	
	while((USART1->SR&0X40)==0);//循环发送,直到发送完毕   
	USART1->DR = (u8) ch;
	return ch;
}

#endif

二、自定义printf函数

需要添加两个头文件:#include <stdarg.h>  、 #include <stdio.h>

并在函数之前对长度进行定义:

#define USART6_REC_LEN  	256
extern size_t strlen(const char *);
/*
用固件库定义串口函数
1、申明头文件#include<stdarg.h>
2、buffer的大小根据需要调整,相应的循环条件也要改,此处可以定义成宏,方便调节buffer大小。
3、定义va_list变量,该变量是一个字符指针,可以理解为指向当前参数的一个指针,取参必须通过这个指针进行。
4、va_start让arg_ptr指向printf函数可变参数里边的第一个参数;
5、vsnprintf()将按照fmt的格式将arg_ptr里的值依次转换成字符保存到buffer中,该函数有最大字符数限制,超过后会被截断,且该函数会自动在字符串末尾加‘\0’。
6、最后必须调用va_end(),由此确保堆栈的正确恢复。
*/
void USART6_printf(char *fmt, ...) 
{
    char buffer[USART6_REC_LEN+1];  // 数据长度
    u8 i = 0;
    va_list arg_ptr;
    va_start(arg_ptr,fmt);
    vsnprintf(buffer,USART6_REC_LEN+1,fmt,arg_ptr);
    while ((i < USART6_REC_LEN) && (i < strlen(buffer)))
    {
        while((USART6->SR&0X40)==0);//循环发送,直到发送完毕
        USART6->DR=(u8)buffer[i++];
    }
    va_end(arg_ptr);
}
  • 2
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在使用stm32单片机中,如果想要将printf函数定向到USART1,可以通过定向fputc函数实现。具体步骤如下: 1. 首先,需要包含头文件stdio.h,以便使用printf函数和FILE类型。\[3\] 2. 在代码中定义一个函数,例如USART1_printf,用于定向fputc函数。这个函数实现可以根据需求自定义,但需要包含头文件stdio.h、string.h和stdarg.h。\[2\] 3. 在定向函数USART1_printf中,使用USART_SendChar函数将字符发送到USART1。可以根据需要使用其他USART发送函数,如USART_SendString等。\[2\] 4. 在main函数中,调用USART_Configuration函数进行USART1的配置。然后,可以使用printf函数来打印调试信息,这些信息将被定向到USART1。\[1\] 下面是一个示例代码: ```c #include <stdio.h> #include <string.h> #include <stdarg.h> // 定向fputc函数到USART1 int USART1_printf(const char* format, ...) { va_list args; va_start(args, format); char buffer\[100\]; vsnprintf(buffer, sizeof(buffer), format, args); va_end(args); int len = strlen(buffer); for (int i = 0; i < len; i++) { USART_SendChar(USART1, buffer\[i\]); } return len; } int main(void) { USART_Configuration(); // USART1的配置函数 // 使用printf函数打印调试信息,信息将被定向到USART1 printf("\r\nstm32f103rct6\r\n"); printf("\r\nCortex-M3\r\n"); while (1); return 0; } ``` 通过以上步骤,就可以将printf函数定向到USART1,实现stm32单片机中通过USART1打印调试信息。 #### 引用[.reference_title] - *1* *3* [STM32printf函数定向](https://blog.csdn.net/qq_29344757/article/details/75363639)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^koosearch_v1,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [STM32实现printf定向到串口的3种方法](https://blog.csdn.net/studyingdda/article/details/127388762)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^koosearch_v1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值