gcc编译使用hal库时重定向printf()函数

##GCC编译使用hal库时重定向printf()函数
1.使用STM32CUBEMX配置好对应的串口

2.新建usart_debug.h的头文件,并添加到工程里面

以下为usart_debug.h代码

/*使用说明:使用标准库重定向printf()函数 
	1.配置串口和串口handle
	2.在需要的地方添加usart_debug.h头文件
	3.使用printf()函数--不支持浮点数输出 
*/

#ifndef __USART_DEBUG_H
#define __USART_DEBUG_H

#define USART_DEBUG USART1			/*配置使用的串口*/
#define huart_debug huart1 			/*配置使用的串口handle*/ 

/*stm32cubemx配置串口后自动生成的头文件,这里包含以下*/
#include "usart.h"

/*重定向需要使用到的头文件*/ 
#include "stdio.h"

/*告知连接器不从c库链接使用半主机的函数--不使用半主机模式*/ 
#pragma import(__use_no_semihosting)

/*重新定义__write函数*/ 
int _write(int fd, char *ptr, int len)
{
	HAL_UART_Transmit(&huart_debug, (uint8_t *)ptr, len, 0xFFFF);
	return len;
}

/*定义_sys_exit()以避免使用半主机模式*/ 
void _sys_exit(int x)
{
	x = x;
}

/*标准库需要的支持类型*/ 
struct __FILE
{
	int handle;
};
FILE __stdout;

/*重定向fputc()*/
int fputc(int ch, FILE *stream)
{
	/*堵塞判断串口是否发送完成*/
	while((USART_DEBUG->ISR & 0x40) == 0)
	;
	/*串口发送完成,将该字节发送*/
	USART_DEBUG->TDR = (uint8_t) ch;
	return ch;
}
 
#endif /*__USART_DEBUG_H*/  

使用:

/* USER CODE BEGIN Includes */     
#include "usart_debug.h"
/* USER CODE END Includes */
/* USER CODE BEGIN Header_StartDefaultTask */
/**
  * @brief  Function implementing the defaultTask thread.
  * @param  argument: Not used 
  * @retval None
  */
/* USER CODE END Header_StartDefaultTask */
void StartDefaultTask(void const * argument)
{

  /* USER CODE BEGIN StartDefaultTask */
  /* Infinite loop */
  for(;;)
  {
      HAL_GPIO_TogglePin(led_run_GPIO_Port, led_run_Pin);
      osDelay(1000);
      printf("test_ok\r\n");
  }
  /* USER CODE END StartDefaultTask */
}

现象:
在这里插入图片描述
链接: git头文件链接.
时间:2020.07.29

猜你喜欢

转载自blog.csdn.net/weixin_44099973/article/details/107655771