阿波罗使用HAL库USART2输出乱码

2019-07-20 12:17发布

使用STM32CubeMX产生的代码,正常输出。自己新建的工程,拷贝STM32CubeMX生产的代码。结果USART2输出是乱码,GPIO口控制LED灯饰正常的。求解为什么?是不是工程建立的时候有什么要配置的。
第一次使用HAL库,以前使用STD库都很正常。代码就是很简单的,让USART2重复输出。

下面是代码:
“main.c”如下:
UART_HandleTypeDef huart2;

static void SystemClock_Config(void)
{

    RCC_OscInitTypeDef RCC_OscInitStruct;
    RCC_ClkInitTypeDef RCC_ClkInitStruct;

    /**Configure the main internal regulator output voltage
    */
    __HAL_RCC_PWR_CLK_ENABLE();

    __HAL_PWR_VOLTAGESCALING_CONFIG(PWR_REGULATOR_VOLTAGE_SCALE1);

    /**Initializes the CPU, AHB and APB busses clocks
    */
    RCC_OscInitStruct.OscillatorType = RCC_OSCILLATORTYPE_HSE;
    RCC_OscInitStruct.HSEState = RCC_HSE_ON;
    RCC_OscInitStruct.PLL.PLLState = RCC_PLL_ON;
    RCC_OscInitStruct.PLL.PLLSource = RCC_PLLSOURCE_HSE;
    RCC_OscInitStruct.PLL.PLLM = 25;
    RCC_OscInitStruct.PLL.PLLN = 360;
    RCC_OscInitStruct.PLL.PLLP = RCC_PLLP_DIV2;
    RCC_OscInitStruct.PLL.PLLQ = 4;
    if (HAL_RCC_OscConfig(&RCC_OscInitStruct) != HAL_OK)
    {
    }

    /**Activate the Over-Drive mode
    */
    if (HAL_PWREx_EnableOverDrive() != HAL_OK)
    {
    }

    /**Initializes the CPU, AHB and APB busses clocks
    */
    RCC_ClkInitStruct.ClockType = RCC_CLOCKTYPE_HCLK|RCC_CLOCKTYPE_SYSCLK
                                  |RCC_CLOCKTYPE_PCLK1|RCC_CLOCKTYPE_PCLK2;
    RCC_ClkInitStruct.SYSCLKSource = RCC_SYSCLKSOURCE_PLLCLK;
    RCC_ClkInitStruct.AHBCLKDivider = RCC_SYSCLK_DIV1;
    RCC_ClkInitStruct.APB1CLKDivider = RCC_HCLK_DIV4;
    RCC_ClkInitStruct.APB2CLKDivider = RCC_HCLK_DIV2;

    if (HAL_RCC_ClockConfig(&RCC_ClkInitStruct, FLASH_LATENCY_5) != HAL_OK)
    {
    }

    /**Configure the Systick interrupt time
    */
    HAL_SYSTICK_Config(HAL_RCC_GetHCLKFreq()/1000);

    /**Configure the Systick
    */
    HAL_SYSTICK_CLKSourceConfig(SYSTICK_CLKSOURCE_HCLK);

    /* SysTick_IRQn interrupt configuration */
    HAL_NVIC_SetPriority(SysTick_IRQn, 0, 0);
}

static void MX_GPIO_Init(void)
{

  __HAL_RCC_GPIOH_CLK_ENABLE();
  __HAL_RCC_GPIOA_CLK_ENABLE();

}

static void USART_Config(void)
{
    huart2.Instance = USART2;
    huart2.Init.BaudRate = 115200;
    huart2.Init.WordLength = UART_WORDLENGTH_8B;
    huart2.Init.StopBits = UART_STOPBITS_1;
    huart2.Init.Parity = UART_PARITY_NONE;
    huart2.Init.Mode = UART_MODE_TX_RX;
    huart2.Init.HwFlowCtl = UART_HWCONTROL_NONE;
    huart2.Init.OverSampling = UART_OVERSAMPLING_16;
    if (HAL_UART_Init(&huart2) != HAL_OK)
    {}
}

int main(void)
{
友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
该问题目前已经被作者或者管理员关闭, 无法添加新回复
30条回答
huanghan
1楼-- · 2019-07-21 16:40
好了,下载测试一下
huanghan
2楼-- · 2019-07-21 20:57
 精彩回答 2  元偷偷看……
huanghan
3楼-- · 2019-07-22 02:04
波特频率 115200
liweidxh
4楼-- · 2019-07-22 06:43
huanghan 发表于 2017-8-29 09:21
好了,自己打开编译一下

用软件STM32CubeMX生产的代码,我也可以,因为我不喜欢这个代码风格,就自建一个工程,把STM32CubeMX相应代码原封不动拷贝到工程里,输出就是乱码了。应该不是这个printf的原因。
huanghan
5楼-- · 2019-07-22 09:19
 精彩回答 2  元偷偷看……
liweidxh
6楼-- · 2019-07-22 10:31
huanghan 发表于 2017-8-29 09:36
HAL_UART_Transmit(&huart2,buf,5,1000);  你用的这个函数不是串口打印函数,相当于这个USART_SendData(USA ...

用STM32CubeMX生成的代码,用HAL_UART_Transmit直接可以输出。
printf使用了fputc,
int fputc(int ch, FILE *f)
{
  HAL_UART_Transmit(&huart2, (uint8_t *)&ch, 1, 0xFFFF);
  return ch;
}
这里面不还是使用了HAL_UART_Transmit。

一周热门 更多>