刚开始学stm32,顺着gpio、uart。。。的顺序慢慢爬 初始化的方法学习了马老师的STM32_Init.h大法,自己英文还可以,加上avr的基础还不错,所以gpio和时钟配置都很顺利 碰到uart就头大了,看到各种例程里都是printf()函数,自己也想用,毕竟是avr想用却开销不了的东西。但是我自己写的程序里一旦出现printf,单片机的不干活了。查论坛首先发现要重定义fputc函数,照做了,还是不行。 后来怀疑是uart1初始化问题,用自己写的put_c函数却没问题。 后来又发现一种说法,需要避免使用semihosting(半主机模式),我也把代码加进去了(改fputc去掉了),还是不行。 再一想,重定义fputc是绝对必须的,加上了之后问题解决,成功使用printf("(敏感词0373) \n");输出了,哈哈 *************************************************************************************************** 以上废话,可以不看。 简单地说:想在mdk 3.80a中用printf,需要同时重定义fputc函数和避免使用semihosting(半主机模式), 论坛里应该有完整介绍这个的帖子,但是我没搜到,也许是沉了。重发出来希望能帮上像我这样的菜鸟们。 需要添加以下代码 #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; } 以上代码来自goway 和 yugen 的发言,在此表示感谢 ******************************************************************************************** 更新: 根据四楼的帖子,发现在Options里选上microlib之后,就不用关闭半主机模式了。
我顺便查了一下semihosting的作用,介绍如下 |
终于解决了MDK 3.80a中不能使用printf()函数的问题
最新推荐文章于 2024-06-25 21:42:20 发布