完善资料让更多小伙伴认识你,还能领取20积分哦, 立即完善>
|
我配置了uart2和3,其中uart2和其它芯片的串口进行通信,输出数据,而uart3输出调试信息和log,但是在运行中发现: 1.单独使用任何一个uart进行输出打印,数据都是正常的; 2.在程序中分别输出2路信息,一旦uart分别被调用到,就会冲突导致两uart口都不再输出。停在那里了。。 uart2使用的是UART2_sendData()发送数据;uart3是改写了fputc,重定向printf的输出。 是什么原因导致两个串口输出冲突而停止?有什么办法可以解决多串口分别使用的问题? 补充: 容易出现串口都停止打印的时候,uart2先被调用,然后uart3,即printf后用。将printf和Uart_sendData()先后顺序换一下,两串口能正常输出。代码见下方的楼层。 |
|
相关推荐
21个回答
|
|
|
相关代码贴出来大家分析分析啊
|
|
|
|
|
|
我的串口的无法识别
|
|
|
|
|
|
DMA,你的选择
|
|
|
|
|
|
|
|
|
|
|
|
用不同的定时间驱动不同的uart
|
|
|
|
|
|
我用了不同的管脚配置Uart2和Uart3,fputc对应的是Uart3,而Uart_sendData对应是Uart2。这样的配置还会公用什么呢? 还有一个配置地方就是时钟了,这应该不会冲突吧。 请指点。 |
|
|
|
|
|
|
|
|
|
|
|
肯定是你程序的原因。当时我用429的时候,一次开4个没问题。103试过一次开两个也没问题。不过没有用printf重定向。我是自己重写了Serial.println
|
|
|
|
|
|
本帖最后由 damiaa 于 2015-1-26 17:58 编辑
时钟不会。IO如果你确定是不同的IO 那也就不会。但你程序明显有问题,肯定是互相干扰阿,不共用是不会这样的。要不就内存溢出,数组出界。反正就这些问题,不会是UART本身。按理讲库也不会有问题。 |
|
|
|
|
60user160 发表于 2018-9-14 15:53 |
|
|
|
|
|
我上面的串口输出,根据代码条件选择,任意只使用一个输出时都正常。一旦条件满足,需要另一个也被调用到时,就不正常了。俩串口都停止。
|
|
|
|
|
|
自己写个printf试试,没遇到过
|
|
|
|
|
|
谢谢分享
|
|
|
|
|
|
理论上是没有冲突的,这样只能先看看死在哪个位置了。
|
|
|
|
|
|
加班要到年底了,手里有f091还没来得及研究
|
|
|
|
|
|
|
|
|
|
|
|
仔细检查程序
|
|
|
|
|
|
|
|
|
|
|
|
本帖最后由 ataudio 于 2015-1-27 13:21 编辑
最新确定消息:上面的代码运行没什么问题,两串口同时输出都OK了,但是将printf放到了Uart_sendData()代码段的前面,就是说先printf,后Uart_sendData()就会出现两打印口都停止输出。 原因不详。分析来说,于理不合。 |
|
|
|
|
你正在撰写答案
如果你是对答案或其他答案精选点评或询问,请使用“评论”功能。
STM32F405驱动DS1302时钟模块,输出时间错乱该怎么排查?
2776 浏览 2 评论
stm32f405rgt6驱动DS1302ZN出现时间错乱问题
2379 浏览 1 评论
stm32用fsmc读取ad7606采集数据,数据不变,只有开发版复位才更新数据
2255 浏览 0 评论
2367 浏览 1 评论
1625 浏览 1 评论
/9
小黑屋| 手机版| Archiver| 电子发烧友 ( 湘ICP备2023018690号 )
GMT+8, 2025-12-1 18:47 , Processed in 1.290049 second(s), Total 108, Slave 91 queries .
Powered by 电子发烧友网
© 2015 bbs.elecfans.com
关注我们的微信
下载发烧友APP
电子发烧友观察
版权所有 © 湖南华秋数字科技有限公司
电子发烧友 (电路图) 湘公网安备 43011202000918 号 电信与信息服务业务经营许可证:合字B2-20210191

淘帖
6274