#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);
}
- 软件终端机测试, 可以看到 “Read Test 00000000”, 但输出不实时, 会几十个 , 才一起送一次,但没掉,都在。
- 示波器看PC13波形是连续且时间间隔是一致的,可以排除其他硬件因素。
程序没报错,也都执行,就是输出不实时连续。
Ex:
Read Test: 51
停一段时间, 约一秒, 直接连续输出, 跳到
Read Test: 110
ps: 实验
直接用 ( USART1->DR , USART_SR_TXE ) 控制 输出, 是正常且连续的。
问题是前人的码里面,printf( ) 有点多啊!