OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 6531|回复: 14

为什么printf重定向不能输出到串口4?(使用Cubemx生成初始化代码)

[复制链接]

3

主题

18

帖子

0

精华

初级会员

Rank: 2

积分
75
金钱
75
注册时间
2021-7-9
在线时间
18 小时
发表于 2021-7-31 15:04:43 | 显示全部楼层 |阅读模式
10金钱
我用Cubemx生成了两个工程,一个是串口1,一个是串口4,模式的设置一模一样,都是下面这样:



然后我在主函数前面添加了printf的重定向代码(下面这个是串口1的)



串口1的printf使用正常,在XCOM上能观察到输出;
然后我把上述代码的USART1改为UART4,复制到串口4的工程,就没输出了。
我之前在另一个类似的工程也是这样,串口1可以用printf,串口4就不行了,请问是什么情况?


最佳答案

查看完整内容[请看2#楼]

解决了,原来是跳线帽把串口1的发送和接收端口与USB的RXD和TXD连在一起了,所以无论软件怎么设置,只有串口1有用。 把跳线帽拔了,把RXD和TXD连接串口4的发送和接收端,就可以用串口调试助手来看串口4的输出了。
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

3

主题

18

帖子

0

精华

初级会员

Rank: 2

积分
75
金钱
75
注册时间
2021-7-9
在线时间
18 小时
 楼主| 发表于 2021-7-31 15:04:44 | 显示全部楼层
解决了,原来是跳线帽把串口1的发送和接收端口与USB的RXD和TXD连在一起了,所以无论软件怎么设置,只有串口1有用。
把跳线帽拔了,把RXD和TXD连接串口4的发送和接收端,就可以用串口调试助手来看串口4的输出了。
回复

使用道具 举报

3

主题

18

帖子

0

精华

初级会员

Rank: 2

积分
75
金钱
75
注册时间
2021-7-9
在线时间
18 小时
 楼主| 发表于 2021-7-31 15:08:52 | 显示全部楼层
我用的是精英板,stm32F103ZET6
回复

使用道具 举报

3

主题

821

帖子

0

精华

论坛元老

Rank: 8Rank: 8

积分
3369
金钱
3369
注册时间
2011-11-10
在线时间
207 小时
发表于 2021-7-31 21:18:57 | 显示全部楼层
串口4初始化了没有?
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165524
金钱
165524
注册时间
2010-12-1
在线时间
2116 小时
发表于 2021-8-1 02:03:11 | 显示全部楼层
仿真找问题,看寄存器值变化
回复

使用道具 举报

3

主题

18

帖子

0

精华

初级会员

Rank: 2

积分
75
金钱
75
注册时间
2021-7-9
在线时间
18 小时
 楼主| 发表于 2021-8-1 15:07:47 | 显示全部楼层
正点原子 发表于 2021-8-1 02:03
仿真找问题,看寄存器值变化

调试吗?不知道为什么调试的时候进不了printf函数内部,而且我看USART1的各个寄存器的值和UART4的都是一样的。。只是波特率设置寄存器BRR那里不太一样,因为这两个串口的时钟不同导致的,我找不出什么问题。。。
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165524
金钱
165524
注册时间
2010-12-1
在线时间
2116 小时
发表于 2021-8-2 01:37:28 | 显示全部楼层
长临123 发表于 2021-8-1 15:07
调试吗?不知道为什么调试的时候进不了printf函数内部,而且我看USART1的各个寄存器的值和UART4的都是一 ...

不需要进入printf,你要看的是外设寄存器值,printf一般是不会有问题的,这么多人用,不用怀疑printf的代码,应该怀疑你串口初始化的代码
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复

使用道具 举报

4

主题

83

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
205
金钱
205
注册时间
2019-11-12
在线时间
77 小时
发表于 2021-8-2 08:32:08 | 显示全部楼层
cube生成的代码配置肯定没问题,怀疑1和4不在一个apb上,时钟你没设对吧。
回复

使用道具 举报

3

主题

18

帖子

0

精华

初级会员

Rank: 2

积分
75
金钱
75
注册时间
2021-7-9
在线时间
18 小时
 楼主| 发表于 2021-8-3 08:17:48 | 显示全部楼层
nstopb 发表于 2021-8-2 08:32
cube生成的代码配置肯定没问题,怀疑1和4不在一个apb上,时钟你没设对吧。

我在Cubemx上将RCC改为外部高速晶振,将HCLK改为72M,就没别的了
回复

使用道具 举报

3

主题

18

帖子

0

精华

初级会员

Rank: 2

积分
75
金钱
75
注册时间
2021-7-9
在线时间
18 小时
 楼主| 发表于 2021-8-3 08:18:57 | 显示全部楼层
c2007s 发表于 2021-7-31 21:18
串口4初始化了没有?

初始化了啊,Cubemx上设置了,自动生成的代码就初始化了
回复

使用道具 举报

3

主题

18

帖子

0

精华

初级会员

Rank: 2

积分
75
金钱
75
注册时间
2021-7-9
在线时间
18 小时
 楼主| 发表于 2021-8-3 08:28:30 | 显示全部楼层
正点原子 发表于 2021-8-2 01:37
不需要进入printf,你要看的是外设寄存器值,printf一般是不会有问题的,这么多人用,不用怀疑printf的代 ...

我在Cubemx上的设置是一样的,生成的代码我检查了,也是一样的,下面是USART1的代码:
void MX_USART1_UART_Init(void)
{
  huart1.Instance = USART1;
  huart1.Init.BaudRate = 115200;
  huart1.Init.WordLength = UART_WORDLENGTH_8B;
  huart1.Init.StopBits = UART_STOPBITS_1;
  huart1.Init.Parity = UART_PARITY_NONE;
  huart1.Init.Mode = UART_MODE_TX_RX;
  huart1.Init.HwFlowCtl = UART_HWCONTROL_NONE;
  huart1.Init.OverSampling = UART_OVERSAMPLING_16;
  if (HAL_UART_Init(&huart1) != HAL_OK)
  {
    Error_Handler();
  }
}

void HAL_UART_MspInit(UART_HandleTypeDef* uartHandle)
{

  GPIO_InitTypeDef GPIO_InitStruct = {0};
  if(uartHandle->Instance==USART1)
  {
    __HAL_RCC_USART1_CLK_ENABLE();

    __HAL_RCC_GPIOA_CLK_ENABLE();
    GPIO_InitStruct.Pin = GPIO_PIN_9;
    GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
    GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_HIGH;
    HAL_GPIO_Init(GPIOA, &GPIO_InitStruct);

    GPIO_InitStruct.Pin = GPIO_PIN_10;
    GPIO_InitStruct.Mode = GPIO_MODE_INPUT;
    GPIO_InitStruct.Pull = GPIO_NOPULL;
    HAL_GPIO_Init(GPIOA, &GPIO_InitStruct);
        }
}

下面是UART4的代码:void MX_UART4_Init(void)
{

  huart4.Instance = UART4;
  huart4.Init.BaudRate = 115200;
  huart4.Init.WordLength = UART_WORDLENGTH_8B;
  huart4.Init.StopBits = UART_STOPBITS_1;
  huart4.Init.Parity = UART_PARITY_NONE;
  huart4.Init.Mode = UART_MODE_TX_RX;
  huart4.Init.HwFlowCtl = UART_HWCONTROL_NONE;
  huart4.Init.OverSampling = UART_OVERSAMPLING_16;
  if (HAL_UART_Init(&huart4) != HAL_OK)
  {
    Error_Handler();
  }
}

void HAL_UART_MspInit(UART_HandleTypeDef* uartHandle)
{

  GPIO_InitTypeDef GPIO_InitStruct = {0};
  if(uartHandle->Instance==UART4)
  {

    __HAL_RCC_UART4_CLK_ENABLE();

    __HAL_RCC_GPIOC_CLK_ENABLE();
    GPIO_InitStruct.Pin = GPIO_PIN_10;
    GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
    GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_HIGH;
    HAL_GPIO_Init(GPIOC, &GPIO_InitStruct);

    GPIO_InitStruct.Pin = GPIO_PIN_11;
    GPIO_InitStruct.Mode = GPIO_MODE_INPUT;
    GPIO_InitStruct.Pull = GPIO_NOPULL;
    HAL_GPIO_Init(GPIOC, &GPIO_InitStruct);
        }
}



回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165524
金钱
165524
注册时间
2010-12-1
在线时间
2116 小时
发表于 2021-8-4 02:21:46 | 显示全部楼层
长临123 发表于 2021-8-3 08:28
我在Cubemx上的设置是一样的,生成的代码我检查了,也是一样的,下面是USART1的代码:
void MX_USART1_U ...

仿真找问题
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复

使用道具 举报

3

主题

18

帖子

0

精华

初级会员

Rank: 2

积分
75
金钱
75
注册时间
2021-7-9
在线时间
18 小时
 楼主| 发表于 2021-8-4 08:45:00 | 显示全部楼层

之前调试了,寄存器的值都是一样的,只有波特率设置寄存器BRR不一样,那是因为两个串口的时钟不同导致的。
回复

使用道具 举报

13

主题

643

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
2432
金钱
2432
注册时间
2019-12-28
在线时间
527 小时
发表于 2021-8-4 12:14:39 | 显示全部楼层
回复

使用道具 举报

3

主题

18

帖子

0

精华

初级会员

Rank: 2

积分
75
金钱
75
注册时间
2021-7-9
在线时间
18 小时
 楼主| 发表于 2021-8-4 14:22:42 | 显示全部楼层
狼里个狼121 发表于 2021-8-4 12:14
可以参考下这个的http://www.openedv.com/forum.php?mod=viewthread&tid=328385

额,完全没看懂,移植过去也不行
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2025-5-30 13:54

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

快速回复 返回顶部 返回列表