历史上的今天
返回首页

历史上的今天

今天是:2024年10月17日(星期四)

正在发生

2018年10月17日 | STM连续发送时丢失第一个字节

2018-10-17 来源:eefocus

在编制程序是,遇到这么一个问题:
STM连续发送时丢失第一个字节
这一段程序的输出,应该是 57H 53H 07H D0H
但是,实际调试中输出的是53H 07H D0H,第一个字节57H丢失了。
其实在此之前,我调试甲醛传感器的时候就发现,第一次发送命令无法对甲醛传感器失效,我天真的以为是传感器的问题,没有对我发的命令产生有效响应。
但是,今天的现象表明,是单片机的串口没能将第一个字节发送出来。
于是,我动用了百度,找到了如下文摘:

——————————————————————————————————————————
——————————————————————————————————————————
STM32 串口 发送 必须 先检测 状态,否则 第一个 字节 无法 发出,发送完毕,必须检测发送状态是否完成,否则,发送不成功,
使用stm32f10x调试串口通讯时,发现一个出错的现象,硬件复位重启之后,发送测试数据0x01 0x02 0x03 0x04..接收端收到的数据为:0x02 0x03 0x04,第一个数据丢失。换成发送别的数值的数据,如0x06 0x0ff,则接收到0x0ff,0x06丢失。错误依旧。
    故障排除过程:
    1、刚开始怀疑是接收端的错误,我是使用电脑串口,运行串口辅助调试工具接收,换成其他软件后,发现故障依旧,而且电脑软件一直是开启状态,不像和电脑软件有关。
    2、使用单步调试,单步运行各个发送指令,都正常。能收到0x01 0x02 0x03 0x04的数据。间接的排除了不是电脑软件的问题,而是其他的错误。
    3、单步调试运行虽然正常了,但连续运行时,错误依旧。现在有点摸不到头绪了,单步运行正常,看起来编程没有出错,那故障在哪里呢?测试程序如下
   USART_SendData(USART2, 0x01);                                 //A
   while(USART_GetFlagStatus(USART2, USART_FLAG_TC) == RESET);   //B
   USART_SendData(USART2, 0x02);                                 //C
   while(USART_GetFlagStatus(USART2, USART_FLAG_TC) == RESET);
   USART_SendData(USART2, 0x03);
   while(USART_GetFlagStatus(USART2, USART_FLAG_TC) == RESET);
   USART_SendData(USART2, 0x04);
   while(USART_GetFlagStatus(USART2, USART_FLAG_TC) == RESET);
    4、猜测,也许是因为某个特殊原因,使第二个数据覆盖了首个数据,使得首个数据丢失。假设:在执行B指令时,USART的 TC 状态位==SET,那么就会紧接着执行C指令,也就有可能发生数据的覆盖。于是,在A指令前,加入如下指令:
   USART_ClearFlag(USART2,USART_FLAG_TC);
    5、加入上一条指令后,运行,错误消失了。说明上一个假设,应该是成立的。
    6、查阅stm32f10x参考手册,找到这样一句话:
TC:发送完成
当包含有数据的一帧发送完成后,由硬件将该位置位。如果USART_CR1中的TCIE为1,则产生中断。由软件序列清除该位(先读USART_SR,然后写入USART_DR)。TC位也可以通过写入0来清除,只有在多缓存通讯中才推荐这种清除程序。
0:发送还未完成;
1:发送完成。
    7、注意到这一句:由软件序列清除该位(先读USART_SR,然后写入USART_DR)。 也就是说,要先read USART_SR,然后write USART_DR,才能完成TC状态位的清除。而硬件复位后,串口发送的首个数据之前没有read SR的操作,是直接write DR,也就是说,TC没有被清除掉。 说明第4步的猜测是对的。
    8、那么,应该把指令A前面加的USART_ClearFlag(USART2,USART_FLAG_TC); 改为USART_GetFlagStatus(USART2, USART_FLAG_TC);,应该也能消除错误。测试后证实,确实如此,在发送首个数据之前,先读取一下USART_SR,那么就不会出现首个数据丢失的情况了。
    9、总结:硬件复位后,串口发送首个数据之前,先读取一下USART_SR,则能够保证首个数据发送时,不出现覆盖的情况。当然,也有别的方法,比如先清除TC状态位,或是,在write USART_DR之后,加入一个小延时,让数据发送完毕,应该也能间接排除这个错误。

————————————————————————————————————————————
————————————————————————————————————————————

在此文章的启发下,我做了如下的操作,按照第7条和第8条的提示,我在发送第一个字节的时候,先读一下USART_SR。我是把这个操作放到了串口初始化里,这样就不必每个发送字节函数都进行此操作,至解决初始化后的第一个字节就可以了。
如下图。

STM连续发送时丢失第一个字节
就这么解决了这个问题。

推荐阅读

史海拾趣

Advanced Thermal Solutions公司的发展小趣事

为了进一步扩大市场份额,ATS开始实施全球化战略。公司先后在北美、欧洲和亚洲等地设立了分公司或办事处,以便更好地服务全球客户。同时,ATS还积极参与国际展览和交流活动,与全球各地的合作伙伴建立紧密的合作关系。这些举措使ATS的产品和服务得以覆盖更广泛的地域,公司的知名度和影响力也不断提升。

ECLIPTEK公司的发展小趣事

面对数字化浪潮的冲击,ECLIPTEK公司积极拥抱数字化转型和智能制造。公司引入大数据、云计算和人工智能等先进技术,推动生产过程的智能化和自动化。通过数字化转型和智能制造,ECLIPTEK不仅提高了生产效率和质量,还降低了生产成本和能源消耗。这一转型为公司未来的发展奠定了坚实的基础。

台湾唯圣(GW)公司的发展小趣事
包括保险丝、过流保护器等,用于在电流异常时切断电路,保护设备和人体安全。
DESOUTTER公司的发展小趣事

Desoutter公司成立于1914年,由Desoutter兄弟创立。起初,公司专注于气动工具的研发和生产,很快就以其高质量和可靠性在市场中获得了认可。随着工业革命的深入,气动工具的需求日益增长,Desoutter公司凭借技术优势和市场洞察,逐步扩大了生产规模,奠定了在气动工具领域的领先地位。

Barry Industries Inc公司的发展小趣事

Barry Industries Inc在创业初期面临资金短缺、技术壁垒和市场竞争激烈等诸多挑战。然而,公司创始人凭借对电子行业的深厚理解和对市场需求的敏锐洞察,坚信公司的微波半导体封装技术具有巨大潜力。在创始团队的坚持与努力下,公司逐渐克服了初期的困难,逐步在市场上建立了自己的地位。

FARNELL公司的发展小趣事

为了保持在电子行业中的领先地位,FARNELL公司积极寻求创新与合作。公司与多家知名电子元器件制造商建立了长期合作关系,共同研发新产品、新技术。同时,FARNELL公司还致力于为客户提供定制化的解决方案,满足不同客户的需求。这种创新与合作的精神使FARNELL公司在电子行业中保持了持续的发展动力。

问答坊 | AI 解惑

ARM培训视频-dsp-CPLD-FPGA开发视频-嵌入式系统开发-单片机开发视频

ARM培训视频-dsp-CPLD-FPGA开发视频-嵌入式系统开发-单片机开发视频 ------------------------------------------------------------------ 【ARM培训视频】课程主要内容 1.概念和基本工具: 嵌入式系统基本概念、嵌入式操作系统介绍 嵌入式系 ...…

查看全部问答>

特性阻抗公式

 a.微带线(microstrip) Z={87/[sqrt(Er+1.41)]}ln[5.98H/(0.8W+T)] 其中,W为线宽,T为走线的铜皮厚度,H为走线到参考平面的距离,Er是PCB板材质的介电常数(dielectric constant)。此公式必须在0.1…

查看全部问答>

我该怎么办啊?迷茫。。。

我03年毕业于一所普通的本科院校,学的是机械工程自动化专业,毕业后即来到了现在工作的这家在全国还算比较有名的大型家电制造企业从事生产工艺工作。每天的工作枯燥乏味,工艺巡检,要么就是这个零部件尺寸长了,装不进去,或者那个零部件短了需要 ...…

查看全部问答>

wince 设置默认输入法问题!

最近接手一个wince项目,使用QT4.4.3做的,现在要解决的问题是在控件上输入的时候,调用出wince自带的手写输入法 我现在的设想是 做一个Dll,用SipEnumIM枚举所有的输入法,然后查找出的wince自带的手写输入法的CLSID,将手写输入法的CLSID设置为 ...…

查看全部问答>

LM3S9B96 EM2扩展板用户指南

LM3S9B96 EM2扩展板用户指南 9B96的数据表坛子里有,就不重复了哈…

查看全部问答>

版主呀,或者管理员呀,快进来看看呀!

好了,欢迎进来,某某某,你好!      想请版主或者管理员等等有能力回答的人告诉我们大家一个问题,那就是:      这个用户组头衔是怎么升级的?      跟积分有关系? 还是跟威望 ...…

查看全部问答>

Sitara AM355x低成本新手套件概述

在德州仪器额微博中看到了这个评估套件的视频,分享给大家! 视频内容简要介绍了这款强大的评估套件 [ 本帖最后由 IC爬虫 于 2012-10-24 12:11 编辑 ]…

查看全部问答>

工作无成就感

目前的工作提不起激情,轻闲的空虚,无聊的总跑厕所抽闷烟,前段时间还可以搞搞AVR,现在板子不好打了,流程特多,学习很是不方便,为了上班而上班,我不要这样过   80后!一个沉重的代名词,仿佛一切定格!如何找回存在的价值! [ 本帖 ...…

查看全部问答>

控制芯片的选择

电子设计大赛中的控制类说是四轴飞行器,控制芯片都是用的STM32,我想问一下,MSP430F149可以吗?姿态算法可以实现吗? 希望各位大神指点。 谢谢啦。…

查看全部问答>

从MSP430F149转到G2553,快把我搞疯了。

发现所有的手册中说明的寄存器名称,MSP430G2553.H中就找不到。不知道是我找错资料了还是怎么了,麻烦大家给我个好资料。…

查看全部问答>