STM32中printf函数

标准库函数的默认输出设备是显示器,要实现在串口或LCD输出,必须重定义标准库函数里调用的与输出设备相关的函数.

例如:printf输出到串口,需要将fputc里面的输出指向串口(重定向),方法如下:

#ifdef __GNUC__ 
#define PUTCHAR_PROTOTYPE int __io_putchar(int ch)
#else 
#define PUTCHAR_PROTOTYPE int fputc(int ch, FILE *f)
#endif 

PUTCHAR_PROTOTYPE 
	USART_SendData(USART1, (uint8_t) ch); 
 	while (USART_GetFlagStatus(USART1, USART_FLAG_TC) == RESET); 
	return ch;
}


因printf()之类的函数,使用了半主机模式。使用标准库会导致程序无法运行,以下是解决方法:


方法1.使用微库,因为使用微库的话,不会使用半主机模式.


方法2.仍然使用标准库,在主程序添加下面代码:


#pragma import(__use_no_semihosting)  
_sys_exit(int x) 
{  
	x = x;
 }  
struct __FILE 
{  
	int handle; 
}; 
 FILE __stdout; 
//---------------------------------------------------------------------------------------------------------------------------
 
  
 #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;  
///   
/// 定义_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;
 }

你可能感兴趣的:(STM32)