printf重定向问题

我用的STM32型号为STM32F100VBT6B
重定向方法一:
#ifdef __GNUC__
  /* With GCC/RAISONANCE, small printf (option LD Linker->Libraries->Small printf
     set to 'Yes') calls __io_putchar() */
  #define PUTCHAR_PROTOTYPE int __io_putchar(int ch)
#else
  #define PUTCHAR_PROTOTYPE int fputc(int ch, FILE *f)
#endif /* __GNUC__ */
void Put_u8(u8 Temp)
{
	printf("%c",Temp);
}
void Put_u16(u16 Temp)
{
	u8 Temp_H,Temp_L;
	Temp_H=(u8)(Temp>>8);
	Temp_L=(u8)Temp;
	printf("%c\t%c",Temp_H,Temp_L);
}
PUTCHAR_PROTOTYPE
{
  /* Place your implementation of fputc here */
  /* e.g. write a character to the USART */
  //u8 delayTimeCount = 0;

  USART_SendData(USART1, (uint8_t) ch);
  /* Loop until the end of transmission */
  while (USART_GetFlagStatus(USART1, USART_FLAG_TC) == RESET);
  return ch;
}
以上是我的重定向代码,其实也是参考人家的。

重定向了printf出现了两个奇怪的现象:
奇怪点一:断电后放一会(等电放完,也可以断电后短接正负极放电),然后再上电,MCU就起不来,再断电,立马上电, mcu就可以起来了。
奇怪点二:接上MCU的日志串口(直接黑白绿)到电脑,就不会有上述奇怪点一了,而且还能正常打印日志;
为了排查问题,做了如下几个实验:
1, 去掉所有用到printf的代码,上电可以正常启动
2. 直接用USART1 发送字符,上电也是可以正常启动的
一开始我怀疑硬件有问题,看来串口1可以正常使用,而且也可以正常开机。说明跟硬件无关,那就是把printf重定向到USART1出问题了。仔细检查代码也没发现哪里不对,在网上搜索了一番。重定向通常就两种方法,一种是我上面的那种,另外一种如下:
重定向方法二:
#pragma import(__use_no_semihosting) 
/****************************************************************************** 
*标准库需要的支持函数 
******************************************************************************/ 
struct __FILE 
{ 
int handle; 
/* Whatever you require here. If the only file you are using is */ 
/* standard output using printf() for debugging, no file handling */ 
/* is required. */ 
}; 
/* FILE is typedef’ d in stdio.h. */ 
FILE __stdout; 

/// <summary> 
/// 定义_sys_exit()以避免使用半主机模式 
/// </summary> 
/// <param name="x"></param> 
/// <returns></returns> 
_sys_exit(int x) 
{ 
x = x; 
} 



int fputc(int ch, FILE *f)
{
    //USART_SendData(USART1, (u8) ch);
    USART1->DR = (u8) ch;
    
    /* Loop until the end of transmission */
    while(USART_GetFlagStatus(USART1, USART_FLAG_TXE) == RESET)
    {
    }

    return ch;
}

而且网友提示,用这种重定向时,不需要用 MiclroLIB


然而,我用这种重定向,还是出现上述两个奇怪现象。 哎,先记录下,折腾了一天也没搞定,期待有大神看到可以指点下。

  • 3
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
printf重定向是指将printf函数的输出从默认的显示器为其他设备或文件。在C语言中,可以通过重定义fputc函数来实现printf重定向。具体来说,可以通过重定义fputc函数将printf的输出重定向到串口、文件或其他设备上。 示例代码中使用了freopen函数来实现printf重定向。首先,通过调用freopen函数将标准输出(stdout)重定向到指定的文件或设备。例如,可以将printf的输出重定向到USART1串口,这样就可以将单片机的数据打印到PC上的超级终端或串口调试助手。然后,通过再次调用freopen函数将标准输出恢复为默认的显示器。 需要注意的是,重定义fputc函数是实现printf重定向的关键。在重定义的fputc函数中,可以将printf的输出数据重定向到指定的设备或文件,例如将数据重定向到ITM端口。 总结起来,printf重定向是通过重定义fputc函数来实现的,可以将printf的输出从默认的显示器为其他设备或文件。 #### 引用[.reference_title] - *1* [printf函数的重定向](https://blog.csdn.net/weixin_51121577/article/details/127337297)[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^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* *3* [printf重定向的相关总结](https://blog.csdn.net/gogo0707/article/details/124652111)[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^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值