历史上的今天
返回首页

历史上的今天

今天是:2024年10月14日(星期一)

正在发生

2021年10月14日 | STM32串口通讯协议浅析

2021-10-14 来源:eefocus

通讯协议是指在嵌入式开发中,不同的硬件系统或者操作系统之间进行数据交换的方式,是一种数据通讯的规约。


通讯协议有很多种,而我今天要说的是串口通讯协议,而且是基于STM32来说的。


首先说串口通信,串口是单片机最常见的外设。常见的UART串口主要有两个线,一个线是发送、一个是接收。至于串口发送数据的时候数据线上的高低电平是怎么变化的,这个大家可以自行查阅相关知识,我们常见的单片机自带的串口已经把这个最底层的电平级别的协议做好了,我们使用的时候,收发都是以一个字节为单位来进行的。


举个例子,我们想使用串口连接STM32的串口1到PC机,然后通过PC上位机给STM32发送一个字节0x01,然后在STM32接收到之后,判断一下是不是0x01,如果是的话,点亮一个小灯,如果不是的话,就不点亮灯。这个很多人都可以理解而且实现起来非常容易,基本上几行代码就实现了。


那么把刚才的例子扩展一下,假如STM32连接了很多很多灯,然后我们要使用串口发送一个指令来控制所有灯,这时候应该怎么操作?


把问题再扩展一下,假如我们要控制或通信的不是一个灯,而是一个更复杂的东西,比如是一个电机控制模块、是一个GPS模块、是一个物联网模块呢,这些东西在数据交互的时候都有很大的数据量,不可能一个一个字节去发送数据。


这时候我们就可以联想一下人类是怎么交互的,首先经过上万年的潜移默化,人类形成了很多种语言,同一个国家的人说话基本上都可以听懂,而不同国家的人说话的时候,如果不懂外语是听不懂的。这是为什么呢,因为同一个国家的人,说话的时候使用的协议是相同的,你说桌子,我就知道是桌子。而不同国家的人,通讯协议是不一样的,所以说话的时候不能理解,比如你说apple,我如果没有学过英语,我就不知道你说的是苹果。但是我学习了你的语言,也就是协议。就可以听懂你说的是苹果了。


所以,STM32和PC通讯,或者扩展到更多的场景,STM32和GPS,其他单片机和WIFI等等,这样的通讯都需要通讯双方执行同样的协议。那么对于刚接触单片机的人而言,就产生了几个问题,协议是什么样的,如何执行协议?


还是以最简单的场景来举例子。以使用PC机发指令来控制STM32点亮8个小灯中的若干个小灯固定时长(一秒到255秒之间)然后关闭这样一个实际小项目为例,我们现在明白了,如果只发一个指令,是没办法完成以上任务的。所以我们需要制定一个简单的协议。比如我STM32的程序这么写:当串口收到0xAA然后又收到0x55的时候,我就开始不断收集,并把收集到的所有数据都放在一个数字中,直到收到0xA5x5A这两个的时候就停止收集。接下来我把收集到的数组里面的第一个拿出来,使用if进行判断,如果是0x01的话就点亮第一个小灯,如果是0x00或者其他的话,就不点亮灯,然后看看数组的第二个字节是多少,是多少就给延时多少。相当于通过前两个字节来控制第一个灯亮灭固定时间长度。同样的接下来的两个字节是第二个灯的亮灭和时间长度。按这样的节奏来,要控制这8个灯需要16个字节。那么我们是否可以优化一下这个协议呢?


假如把8个灯的亮灭信息只用一个字节来表示,后面加8个字节,分别用来表示每个灯的亮灭时间长度,这样的话,就可以用9个字节来完成这个任务。


现在我们再想想,假如在这个数据传输的过程中,出了一点小错误,其中有一个电平在跳变的时候受到了干扰,没有按照发送方的数据跳变,这时候接收方接收到的数据就是错误的,假如这个错误发生在第一个灯的亮灭位上,那这个灯就会发生错误的反应,这不是发送方想要的结果。那如何避免这种情况发生呢?使用校验位,校验位是什么意思呢,就是我在给你发的时候,我把9个字节的数据做一个运算。运算有很多种方式,以求和为例子,把9个字节的数据求和,然后拿出里面低八位的数据,放在我要发送的9个字节后面。这样,发送的内容除了0xAA,0x55,0xA5和x5A之外,还多了一个位,我们把多出来的这个通过数据位运算得到的这一字节称为校验位。当发送出去之后,接收方在接收完这些数据之后,也对数据位做一个求和,然后取出低八位,和发送方发送过来的那个校验位做比较,如果相等,说明数据发送过程中没有出错,如果不相等,说明数据发送过程中有地方出错了,那么我们整个不要这一包数据了,然后给发送方通知一下,告诉他让他重新发送一下刚才的数据。


现在回到数据收发,PC端发数据,STM32端接收,这时候STM32也就要每过一会儿(很短暂的时间)就去看看串口是否有数据收到,这种方式称为扫描。扫描有一个缺点,就是需要不断的去看,结果可能去看了一百次,才有一次有数据收到,这样效率太低了,老板(cpu)肯定不高兴,就给串口说,以后你自己处理,有数据来了给我说一下我去处理就行,别让我自己去看,手里事情多着呢。所以就有了中断,中断就是当串口上有数据接了,就会产生一个接收中断,这时候串口就去通知老板来处理。原本要不断过来看看有没有数据,现在他有数据了才通知老板,老板开始还感觉不错,比以前扫描的时候轻松了点。


过了一段时间,老板想,这样每来一包数据,我得去拿几十次呀,太累,于是扔给串口一个仓库(数组),然后说,我给你一个特殊的通道(DMA)你以后收完一包数据直接通过这个通道把数据放在这个仓库里,放完了再通知我来处理,别让我来一次处理一个,手里事情多着呢。然后就有了串口空闲中断,串口每次收到一帧数据之后,才会产生一个中断通知cpu处理。串口空闲中断+DMA的方式简直是处理串口通讯的神器,没有之二。


接下来我们再想想,如果我们有一天突然觉得只控制8个灯不够用了,需要扩展几个呢,这时候,灯加上去之后,协议上还要有很大的改动,比如要把灯的控制位插在数据位的后面,就要把校验位往后挪挪,这样程序就需要改改,那么有没有一种方式,可以允许你在一定范围之内随意改灯的数量而不需要修改协议呢?这就需要设计一个不定长的通讯协议了。既然不定长,那也就意味着,发送方每次都可能发送出不同长度的数据给接收方,这也就要求发送方在发送数据的时候,在这个数据包的前面要加上数据有几个字节,这样接收方才好根据这个数量去接收(串口空闲中断+dma的方式不需要根据这个数量去接收),并且根据这个数量去解析,进而控制灯。


推荐阅读

史海拾趣

Delphi Connection Systems公司的发展小趣事

随着全球对环保意识的不断提高,Delphi Connection Systems公司也积极响应环保号召,致力于研发和生产环保型连接器产品。公司采用环保材料和工艺,减少生产过程中的污染排放,同时推出可回收、可再利用的连接器产品。这一举措不仅符合了环保要求,也为客户提供了更加环保的解决方案。

Armel Electronics Inc公司的发展小趣事

随着公司产品的不断升级和市场的逐步扩大,Armel Electronics Inc公司开始寻求更广阔的市场空间。公司积极与国内外知名企业展开合作,共同开发新产品,开拓新市场。通过国际合作,Armel不仅提升了自身的技术水平,还进一步扩大了市场份额,实现了公司的快速发展。

Hitachi (Renesas )公司的发展小趣事

随着公司产品的不断升级和市场的逐步扩大,Armel Electronics Inc公司开始寻求更广阔的市场空间。公司积极与国内外知名企业展开合作,共同开发新产品,开拓新市场。通过国际合作,Armel不仅提升了自身的技术水平,还进一步扩大了市场份额,实现了公司的快速发展。

Dalian Dlicap Corporation公司的发展小趣事

面对激烈的市场竞争和行业变革,达利凯普积极推进数字化转型和产业升级。公司引入了先进的生产设备和管理系统,实现了生产过程的自动化和智能化。同时,公司还加大了对新材料、新工艺的研发力度,不断提升产品的性能和品质。这些举措使达利凯普在激烈的市场竞争中保持了领先地位,也为公司的持续发展奠定了坚实基础。

Bomar Interconnect公司的发展小趣事

为了确保产品质量和稳定性,Bomar Interconnect公司建立了严格的质量管理体系。公司引进了先进的质量检测设备和方法,对原材料、生产过程、成品进行全面检测和控制。同时,公司还加强了员工培训,提高了员工的质量意识和操作技能。这些措施有效提升了产品的质量水平,降低了不良品率,为客户提供了更加可靠的产品和服务。

Astec [Astec America, Inc]公司的发展小趣事

随着全球环保意识的不断提高,Astec也开始关注绿色环保和可持续发展问题。公司积极采用环保材料和节能技术,推出了一系列绿色电源产品。同时,Astec还加大了对环保技术的研发力度,努力在保持产品性能的同时,降低生产过程中的能耗和排放。这些举措不仅有助于公司应对环保法规的挑战,还提升了公司的社会形象。

问答坊 | AI 解惑

智能电话报警系统

本帖最后由 paulhyde 于 2014-9-15 09:50 编辑 我的毕业设计题目是\"智能电话报警系统\",现在准备交了,可MT8888自动拨号这部分程序还没调得,有哪位高手可以指点小妹下,万分感谢! 邮箱:dodo716@163.com  …

查看全部问答>

双向汽车防盗器设计(毕业设计系列)

本帖最后由 paulhyde 于 2014-9-15 08:54 编辑  …

查看全部问答>

[推箱子游戏]

[推箱子游戏]基于AT89S51+62256+12864LCD…

查看全部问答>

M3、外设一锤搞定!

刚去拿板子,看见soso美女真是高兴啊! 感谢eeworld! 这里提供我收藏的资料,M3的基本功能都有了,应该足够上手。 心得以后继续上传! 资料大多来自网络!…

查看全部问答>

深度解析与探讨:嵌入式系统的高低温故障的根源

呵呵,ARM7、ARM9 还有PXA3XX 等等嵌入式ARM都存在高低温时容易爆发故障?尤其是主频越高的CPU,越容易爆发高低温故障? 这是为什么? 这是因为我们疏忽了对于整个系统中的很多关键信号的完整性的研究、分析与设计; 我们的硬件、软硬件协调设计 ...…

查看全部问答>

问个小问题

     我买的一块上面有CPLD的开发板,查了附带的光盘资料,没写清每个管脚的作用,以前没用过CPLD ,难道每个管脚都一样,都是通用的吗??难道时钟引脚也随便用吗,每次写完VHDL都不知道该怎么分配管脚,请大家指点一下,只说 ...…

查看全部问答>

MessageBeep()通过蜂鸣器实现问题

我的设备中没有加声卡,只有一个蜂器鸣,写了个蜂鸣器的驱动,WINCE中的函数MessageBeep()如何去实现呢?MessageBeep()都调用了哪些函数和信息?请指点一下,谢谢!…

查看全部问答>

cannot open file 'ceddk.lib'(急寻解决办法)

别人考我一个工程EVC的 在他那可以运行 在我电脑上运行报错如下: LINK : fatal error LNK1104: cannot open file \'ceddk.lib\' 是要将这个库加到工程中吗? 哪位有这个库的发我一个 万分感谢! mickeyhao66@163.com…

查看全部问答>

WINCE问题(得答案后马上结帖)

WinCE中,在主对话框中有一子对话框,在子对话框中我用 CreateWindow(TEXT(\"DISPLAYCLASS\")……) 创建了一个IE控件,请问如何使当我鼠标指针只要一移到IE控件中就弹出一个消息框???…

查看全部问答>

FPGA+USB通信

我现在需要用ISP1362芯片实现USB通信,但是对上位机程序不是很了解,希望得到帮助,我的QQ是1261446649,加我QQ详谈要求和报酬。感激不尽!…

查看全部问答>