吕傑森 2022-09-18 11: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 22:38
    关注

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

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


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

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

报告相同问题?

问题事件

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

悬赏问题

  • ¥20 机器学习能否像多层线性模型一样处理嵌套数据
  • ¥20 西门子S7-Graph,S7-300,梯形图
  • ¥50 用易语言http 访问不了网页
  • ¥50 safari浏览器fetch提交数据后数据丢失问题
  • ¥15 matlab不知道怎么改,求解答!!
  • ¥15 永磁直线电机的电流环pi调不出来
  • ¥15 用stata实现聚类的代码
  • ¥15 请问paddlehub能支持移动端开发吗?在Android studio上该如何部署?
  • ¥20 docker里部署springboot项目,访问不到扬声器
  • ¥15 netty整合springboot之后自动重连失效