吕傑森 2022-09-18 03:50 采纳率: 40%
浏览 31
已结题

<CubeIDE + GCC> printf 输出不实时, 会Queue 一串 , 才送一次

#STM32F103C8T6
从MDK转到CubeIDE 1.10.1 + GCC, 上位机一直收不到 USART 回传心跳, 就Time out了。
抓方向,单独把 USART 和 stdio.h 测试。
发现<CubeIDE + GCC> printf 输出不实时, 会Queueu 一串心跳 , 才送一次,上位机Time out了…
请问, 这可能是我哪边设定错误吗?

#include <stdio.h>
// printf re-mapping to USART1
int __io_putchar(int ch)
{
    //HAL_UART_Transmit(&huart1,(uint8_t *)&ch,1,0xFFFF);
    while( !(USART1->SR & USART_SR_TXE) );
    (void)USART1->SR;
    USART1->DR=(ch & 0x1FF);
    return ch;
}

uint8_t ucBuf[16]; 
/* Test Program */
void Test (void)
{
   uint32_t  i=0;
    for( ; ; )
      {
          GPIOC->BRR = (1U << 13 );
        for( uint16_t  j=0;  j<256;  j++ )
        {
            ucBuf[j%16] = (uint8_t)ucReadRegister(j);
        }
         if( FAIL == bDataCompare(ucBuf)  ) break; 
        GPIOC->BSRR = (1U << 13 );
        printf("\rRead Test: %8lu", i );
    }
    hwSetBuzzerON( );    
    while(1); 
}
  1. 软件终端机测试, 可以看到 “Read Test 00000000”, 但输出不实时, 会几十个 , 才一起送一次,但没掉,都在。
  2. 示波器看PC13波形是连续且时间间隔是一致的,可以排除其他硬件因素。

程序没报错,也都执行,就是输出不实时连续。
Ex:
Read Test: 51
停一段时间, 约一秒, 直接连续输出, 跳到
Read Test: 110

ps: 实验
直接用 ( USART1->DR , USART_SR_TXE ) 控制 输出, 是正常且连续的。
问题是前人的码里面,printf( ) 有点多啊!

展开全部

  • 写回答

1条回答 默认 最新

  • 吕傑森 2022-09-23 14:38
    关注

    从网上搜到类似的现象, UNIX下printf有缓存:

    1. 会在遇到 \n 时输出
    2. 遇到 scanf()
    3. 缓存空间满了


    把需要printf立即输出都以** \n**结尾, 可以解决目前测试问题。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
编辑
预览

报告相同问题?

问题事件

  • 已结题 (查看结题原因) 9月26日
  • 已采纳回答 9月23日
  • 修改了问题 9月18日
  • 修改了问题 9月18日
  • 展开全部

悬赏问题

  • ¥15 没输出运行不了什么问题
  • ¥20 输入import torch显示Intel MKL FATAL ERROR,系统驱动1%,: Cannot load mkl_intel_thread.dll.
  • ¥15 点云密度大则包围盒小
  • ¥15 nginx使用nfs进行服务器的数据共享
  • ¥15 C#i编程中so-ir-192编码的字符集转码UTF8问题
  • ¥15 51嵌入式入门按键小项目
  • ¥30 海外项目,如何降低Google Map接口费用?
  • ¥15 fluentmeshing
  • ¥15 手机/平板的浏览器里如何实现类似荧光笔的效果
  • ¥15 盘古气象大模型调用(python)
手机看
程序员都在用的中文IT技术交流社区

程序员都在用的中文IT技术交流社区

专业的中文 IT 技术社区,与千万技术人共成长

专业的中文 IT 技术社区,与千万技术人共成长

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

客服 返回
顶部