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
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值