STM32程序添加printf函數(shù)后無法運行的解決方法(串口實驗)
例如:printf輸出到串口,需要將fputc里面的輸出指向串口(重定向),方法如下:#ifdef __GNUC__#define PUTCHAR_PROTOTYPE int __io_putchar(int ch)#else#define PUTCHAR_PROTOTYPE int fputc(int ch, FILE *f)#endifPUTCHAR_PROTOTYPE{USART_SendData(USART1, (uint8_t) ch);while (USART_GetFlagStatus(USART1, USART_FLAG_TC) == RESET);return ch;}因printf()之類的函數(shù),使用了半主機模式。使用標準庫會導致程序無法運行,以下是解決方法:方法1.使用微庫,因為使用微庫的話,不會使用半主機模式.
方法2.仍然使用標準庫,在主程序添加下面代碼:
#pragma import(__use_no_semihosting)
_sys_exit(int x)
{
x = x;
}
struct __FILE
{
int handle;
};
FILE __stdout;
另一個高手的講解
剛開始學stm32,順著gpio、uart。。。的順序慢慢爬
初始化的方法學習了馬老師的STM32_Init.h****,自己英文還可以,加上avr的基礎(chǔ)還不錯,所以gpio和時鐘配置都很順利
碰到uart就頭大了,看到各種例程里都是printf()函數(shù),自己也想用,畢竟是avr想用卻開銷不了的東西。但是我自己寫的程序里一旦出現(xiàn)printf,單片機的不干活了。查論壇首先發(fā)現(xiàn)要重定義fputc函數(shù),照做了,還是不行。
后來懷疑是uart1初始化問題,用自己寫的put_c函數(shù)卻沒問題。
后來又發(fā)現(xiàn)一種說法,需要避免使用semihosting(半主機模式),我也把代碼加進去了(改fputc去掉了),還是不行。
再一想,重定義fputc是絕對必須的,加上了之后問題解決,成功使用printf("(敏感詞0373) n");輸出了,哈哈
***************************************************************************************************
以上廢話,可以不看。
簡單地說:想在mdk 3.80a中用printf,需要同時重定義fputc函數(shù)和避免使用semihosting(半主機模式),
論壇里應該有完整介紹這個的帖子,但是我沒搜到,也許是沉了。重發(fā)出來希望能幫上像我這樣的菜鳥們。
需要添加以下代碼
#pragma import(__use_no_semihosting)
/******************************************************************************
*標準庫需要的支持函數(shù)
******************************************************************************/
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;
///
/// 定義_sys_exit()以避免使用半主機模式
///
///
///
_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;
}
評論