搜索

[活动专区] 【AT-START-F407测评】03 解决MDK5下AC6编译 Printf不能输出的问题

[复制链接]
159|24
 楼主 | 2021-2-13 11:46 | 显示全部楼层 |阅读模式

关于切换到AC6,可以看我上一篇贴子:
https://bbs.21ic.com/icview-3071490-1-1.html

但是切换后的副作用随之而来,之前串口打印的东西不见了,经过调查发现,问题出现在printf重定向:
修改bsp_uart.c 中的驱动代码如下可以解决问题:
  1. #if 0  /* only For AC5*/
  2. /**
  3.   * [url=home.php?mod=space&uid=247401]@brief[/url]  Retargets the C library printf function to the USART.
  4.   * @param  None
  5.   * @retval None
  6.   */
  7. PUTCHAR_PROTOTYPE
  8. {  
  9.   USART_SendData(AT32_PRINT_UART, ch);
  10.   while ( USART_GetFlagStatus(AT32_PRINT_UART, USART_FLAG_TRAC) == RESET );   
  11.   return ch;
  12. }

  13. #else  /* For AC5 and AC6 */
  14.   
  15.   
  16. /* retarget the C library printf function to the USART */
  17. int fputc(int ch, FILE *f)
  18. {
  19.   USART_SendData(AT32_PRINT_UART, ch);
  20.   while ( USART_GetFlagStatus(AT32_PRINT_UART, USART_FLAG_TRAC) == RESET );   
  21.   return ch;
  22. }

  23. #endif
复制代码


具体代码见附件:
BSP_2.zip (1.5 KB, 下载次数: 2)

使用特权

评论回复
| 2021-2-14 11:11 | 显示全部楼层
明白了

使用特权

评论回复
 楼主 | 2021-3-27 16:01 | 显示全部楼层
本帖最后由 caizhiwei 于 2021-3-27 16:17 编辑

今天又回过头来review代码,发现这样写更合适:

如何让一份代码兼容GCC,ARMCC ,Clang 三种编译器呢?
高手是这样写的 :
  1. /**
  2.   * [url=home.php?mod=space&uid=247401]@brief[/url]  Retargets the C library printf function to the USART.
  3.   * @param  None
  4.   * @retval None
  5.   */
  6. #if defined ( __CC_ARM )

  7. #define PUTCHAR_PROTOTYPE int fputc(int ch, FILE *f)       
  8.   /*
  9. * Arm Compiler above 6.10.1 (armclang)
  10. */
  11. #elif defined (__ARMCC_VERSION) && (__ARMCC_VERSION >= 6100100)
  12.   
  13. #define PUTCHAR_PROTOTYPE int fputc(int ch, FILE *f)

  14. /*
  15. * GNU Compiler
  16. */
  17. #elif defined ( __GNUC__ )

  18. /* With GCC, small printf (option LD Linker->Libraries->Small printf
  19.    set to 'Yes') calls __io_putchar() */
  20. #define PUTCHAR_PROTOTYPE int __io_putchar(int ch)

  21. #endif
复制代码


使用特权

评论回复
 楼主 | 2021-3-27 16:03 | 显示全部楼层
ac6编译器不能输出,原因是默认定义了 __GNUC__,导致错误,我们自定义选择条件编译就好。
ac5 和ac6 都走fputc();

使用特权

评论回复
 楼主 | 2021-4-3 12:11 | 显示全部楼层
  1. PUTCHAR_PROTOTYPE
  2. {
  3.   /* Place your implementation of fputc here */
  4.   /* e.g. write a character to the USART1 and Loop until the end of transmission */
  5.   HAL_UART_Transmit(&hlpuart1, (uint8_t *)&ch, 1, 0xFFFF);
  6.   return ch;
  7. }


  8. int fgetc(FILE *f)
  9. {
  10.     int ret;      
  11.     HAL_UART_Receive(&hlpuart1, (uint8_t *)&ret, 1, HAL_MAX_DELAY);
  12.     return ret;
  13. }

复制代码

使用特权

评论回复
| 2021-4-5 13:59 | 显示全部楼层
keil5 重定向printf函数到串口输出  

使用特权

评论回复
| 2021-4-5 13:59 | 显示全部楼层
使用MicroLib  

使用特权

评论回复
| 2021-4-5 13:59 | 显示全部楼层
习惯了使用printf进行打印输出

使用特权

评论回复
| 2021-4-5 14:00 | 显示全部楼层
使用KEIL5对stm32的printf函数进行重定向  

使用特权

评论回复
| 2021-4-5 14:00 | 显示全部楼层
一种是使用微库  

使用特权

评论回复
| 2021-4-5 14:01 | 显示全部楼层
使用keil5 ?

使用特权

评论回复
| 2021-4-5 14:01 | 显示全部楼层
使用KEIL5 的printf函数

使用特权

评论回复
| 2021-4-5 14:02 | 显示全部楼层
直接使用printf()函数  

使用特权

评论回复
| 2021-4-5 14:02 | 显示全部楼层
直接用sprintf格式化到字符串  

使用特权

评论回复
| 2021-4-5 14:02 | 显示全部楼层
如果使用的是MDK,请在工程属性的“Target“-》”CodeGeneration“中勾驯Use MicroLIB“ 进行如上设置后编译一下

使用特权

评论回复
| 2021-4-5 14:02 | 显示全部楼层
点击options for target,在Target标签下有个Use MicroLIB---取消勾选,不使用微库。

使用特权

评论回复
| 2021-4-5 14:02 | 显示全部楼层
            

使用特权

评论回复
| 2021-4-5 14:03 | 显示全部楼层
printf函数的重定向。  

使用特权

评论回复
| 2021-4-5 14:03 | 显示全部楼层
不勾选  printf函数在main函数中还是用不了

使用特权

评论回复
| 2021-4-5 14:03 | 显示全部楼层
利用printf函数打印调试信息到串口助手

使用特权

评论回复
扫描二维码,随时随地手机跟帖
您需要登录后才可以回帖 登录 | 注册

本版积分规则

我要发帖 我要提问 投诉建议 申请版主

快速回复

您需要登录后才可以回帖
登录 | 注册
高级模式

论坛热帖

在线客服 快速回复 返回顶部 返回列表