[STM32F1] stm32f103 串口通讯 乱码问题 DeBug

[复制链接]
2002|7
 楼主| 抹茶妹妹 发表于 2021-7-30 23:20 | 显示全部楼层 |阅读模式
问题现象:STM32F103VET6 + FreeRTOS_V9.0 + UART1   使用printf重映射后,串口输出汉子乱码。
使用固件版本: FreeRTOS V9.0.0   
可能原因分析:
重映射错误
FreeRTOS操作系统实时性打断一帧数据发送
时钟配置错误
串口助手问题

 楼主| 抹茶妹妹 发表于 2021-7-30 23:21 | 显示全部楼层
调试思想与步骤:
重映射错误的可能性不大: 重映射代码如下
  1. /**
  2.   * 函数功能: 重定向c库函数printf到DEBUG_USARTx
  3.   * 输入参数: 无
  4.   * 返 回 值: 无
  5.   * 说    明:无
  6.   */
  7. int fputc(int ch, FILE *f)
  8. {
  9.   HAL_UART_Transmit(&huart1, (uint8_t *)&ch, 1, 0xffff);
  10.   return ch;
  11. }

  12. /**
  13.   * 函数功能: 重定向c库函数getchar,scanf到DEBUG_USARTx
  14.   * 输入参数: 无
  15.   * 返 回 值: 无
  16.   * 说    明:无
  17.   */
  18. int fgetc(FILE * f)
  19. {
  20.   uint8_t ch = 0;
  21.   HAL_UART_Receive(&huart1,&ch, 1, 0xffff);
  22.   return ch;
  23. }
 楼主| 抹茶妹妹 发表于 2021-7-30 23:22 | 显示全部楼层
能够printf数据。

更换串口助手,发现不同串口助手收到的数据格式一样。基本可以排除串口助手问题。
尝试发送英文字母,是否能够正常发送。 我的工程再发送英文字符时,仍为乱码。
通过上一步,基本确定是项目工程设置,或者代码问题。
硬件使用的时钟是8MHz,而系统时钟配置文件:system_stm32f1xx.c中的宏定义
 楼主| 抹茶妹妹 发表于 2021-7-30 23:26 | 显示全部楼层
  1. /*******************************************************************************
  2. *  Clock Definitions
  3. *******************************************************************************/
  4. #if defined(STM32F100xB) ||defined(STM32F100xE)
  5.   uint32_t SystemCoreClock         = 24000000U;        /*!< System Clock Frequency (Core Clock) */
  6. #else
  7.   uint32_t SystemCoreClock         = 16000000U;        /*!< System Clock Frequency (Core Clock) */
  8. #endif
 楼主| 抹茶妹妹 发表于 2021-7-30 23:26 | 显示全部楼层
使用的是:  SystemCoreClock         = 16000000U;
 楼主| 抹茶妹妹 发表于 2021-7-30 23:27 | 显示全部楼层
将上面的代码改为: SystemCoreClock         = 8000000U;
 楼主| 抹茶妹妹 发表于 2021-7-30 23:28 | 显示全部楼层
打印英文字符正常,然后打印中文字符,正常解决。中文字符能够正常显示。
 楼主| 抹茶妹妹 发表于 2021-7-30 23:29 | 显示全部楼层
思考:SystemCoreClock 的值对系统正常运行的影响。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

19

主题

309

帖子

0

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