STM32/STM8技术william hill官网
直播中

李兆水

7年用户 189经验值
私信 关注
[问答]

请问stm32f4如何实现双串口输出而不发生冲突?



我配置了uart2和3,其中uart2和其它芯片的串口进行通信,输出数据,而uart3输出调试信息和log,但是在运行中发现:
1.单独使用任何一个uart进行输出打印,数据都是正常的;
2.在程序中分别输出2路信息,一旦uart分别被调用到,就会冲突导致两uart口都不再输出。停在那里了。。


uart2使用的是UART2_sendData()发送数据;uart3是改写了fputc,重定向printf的输出。

是什么原因导致两个串口输出冲突而停止?有什么办法可以解决多串口分别使用的问题?

补充:
容易出现串口都停止打印的时候,uart2先被调用,然后uart3,即printf后用。将printf和Uart_sendData()先后顺序换一下,两串口能正常输出。代码见下方的楼层。









回帖(21)

况冶

2018-9-14 09:45:21
相关代码贴出来大家分析分析啊
举报

陈俊

2018-9-14 09:54:07
我的串口的无法识别
举报

杨悟牛

2018-9-14 10:05:39
DMA,你的选择
举报

黄晔华

2018-9-14 10:14:07
原则上是不能出错的,如果你没搞错。

要不就是你在两个串口通讯中共用了什么东西。具体是什么你知道的。
举报

毕凯

2018-9-14 10:27:41
用不同的定时间驱动不同的uart
举报

李兆水

2018-9-14 10:41:39
引用: ke3978 发表于 2018-9-14 15:00
原则上是不能出错的,如果你没搞错。

要不就是你在两个串口通讯中共用了什么东西。具体是什么你知道的。

我用了不同的管脚配置Uart2和Uart3,fputc对应的是Uart3,而Uart_sendData对应是Uart2。这样的配置还会公用什么呢?
还有一个配置地方就是时钟了,这应该不会冲突吧。

请指点。

举报

李兆水

2018-9-14 10:56:11
引用: 云淡风轻丶 发表于 2018-9-14 14:40
我的串口的无法识别

不会的吧。按照例程使用,应该能配置成功的。


举报

刘琨

2018-9-14 11:07:12
肯定是你程序的原因。当时我用429的时候,一次开4个没问题。103试过一次开两个也没问题。不过没有用printf重定向。我是自己重写了Serial.println
举报

黄晔华

2018-9-14 11:18:03
本帖最后由 damiaa 于 2015-1-26 17:58 编辑

时钟不会。IO如果你确定是不同的IO 那也就不会。但你程序明显有问题,肯定是互相干扰阿,不共用是不会这样的。要不就内存溢出,数组出界。反正就这些问题,不会是UART本身。按理讲库也不会有问题。
举报

李兆水

2018-9-14 11:36:20
引用: 60user160 发表于 2018-9-14 15:53
肯定是你程序的原因。当时我用429的时候,一次开4个没问题。103试过一次开两个也没问题。不过没有用printf重定向。我是自己重写了Serial.println

举报

李兆水

2018-9-14 11:49:01
我上面的串口输出,根据代码条件选择,任意只使用一个输出时都正常。一旦条件满足,需要另一个也被调用到时,就不正常了。俩串口都停止。
举报

姬房有

2018-9-14 11:56:59
自己写个printf试试,没遇到过
举报

毕凯

2018-9-14 12:02:11
谢谢分享
举报

孙婷婷

2018-9-14 12:07:58
理论上是没有冲突的,这样只能先看看死在哪个位置了。
举报

廖阿朋

2018-9-14 12:16:50
加班要到年底了,手里有f091还没来得及研究
举报

郑婷婷

2018-9-14 12:35:00
引用: a732538 发表于 2018-9-14 17:03
加班要到年底了,手里有f091还没来得及研究

同加班…板子放了一周了orz
举报

杨杜昼

2018-9-14 12:49:51
仔细检查程序
举报

刘琨

2018-9-14 13:08:47
引用: a732538 发表于 2018-9-14 17:03
加班要到年底了,手里有f091还没来得及研究

这是一个凄惨的故事。。。
举报

李兆水

2018-9-14 13:18:55
本帖最后由 ataudio 于 2015-1-27 13:21 编辑

最新确定消息:上面的代码运行没什么问题,两串口同时输出都OK了,但是将printf放到了Uart_sendData()代码段的前面,就是说先printf,后Uart_sendData()就会出现两打印口都停止输出。


原因不详。分析来说,于理不合。



举报

更多回帖

发帖
×
20
完善资料,
赚取积分