0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

PC机与嵌入式设备通信协议设计原则

Linux大陆 来源:CSDN-RimeLink 2023-07-06 11:39 次阅读

嵌入式设备在运行中需要设置参数,这个工作经常由PC机来实现,需要为双方通信设计协议,有代表性协议是如下三种:

9e7c85dc-1bae-11ee-962d-dac502259ad0.png

从上表可以看到,一般嵌入式设备内存和运算性能都有限,因此固定二进制是首选通信协议。

一. 简单性

保证协议是一个简单的方案,晦涩难懂往往意味着实现困难和容易出错。协议的结构宜采用平面方式,每个域作用明确,数据域尽可能设计得长度和位置固定,注释详尽,文档清晰,实例丰富,让人尽快上手和理解。

协议一般都需要以下域:帧头,长度,帧类型,目标地址,源地址,数据,校验,帧尾。

二. 可扩展

必须保证将来增加功能和更改硬件后协议仍能胜任工作,这往往是通过预留空间来实现,协议的变更应该只是量的增加,不至于引起协议结构的变化。

三. 低耦合

理想情况下每个协议包是原子信息,即本协议包不与其他协议包牵连,以防止通讯丢帧和设置牵连带来的错误。

四. 稳定性

协议包长度适宜:太小包含的信息过少,协议包的种类繁多,容易引起通讯混乱和牵连错误;太大包含的信息过多,可读性较差,组帧和解帧的工作困难,还会带来通讯易受干扰的缺陷,一般协议长度以最小原子性信息为标尺。

协议必须包括校验机制,以便于接收方判别协议包正确完整接收,如果出错需要较好的机制来确保通讯成功(如重传)。

五. 高效率

按信息类型区分协议包类别,如:设置网络信息参数,设置当前运行参数,可以区分开来,方便程序处理。

将同种操作编码为一个子集是一种高效手段,如Read操作,编码为0x0010,Write操作,编码为0x0020。

数据尽可能设计成同构模式,如果实在有差异,至少将同类型数据放置在一起,这样程序可以充分利用指针和线性寻址加速处理。

六. 易实现

尽量减少复杂算法的使用,如,通讯链路稳定,数据帧的校验码可以由CheckSum代替CRC。除非资源非常紧张,否则不要将过多的信息挤压在一个数据里,因为它会带来可读性差和实现困难。

七.软件开发

尽可能地让硬件ISR完成驱动工作,不要让“进程”参与复杂的时序逻辑,否则处理器将步履蹒跚且逻辑复杂!如:

接收固定长度的数据帧,可以使用DMA,每接收完一帧DMA_ISR向进程发消息。小心处理DMA断层异常(接收的数据帧长度正常但数据错误,数据为上帧的后半部分+本帧的前半部分)。

接收不定长的数据帧,可以使用状态机,当接收到“帧尾数据”时向进程发消息。

相关文章:如何高效解析不定长度的协议帧?

小心数据紊乱和超时异常(数据紊乱时需要将状态机及时复位,超时一般使用定时器监控)。

八. 考虑硬件

如果通信链路是高速总线(如SPORT可达100Mbps),一般设计成一帧产生一次中断,它通过长度触发的DMA来实现,需要将协议设计成固定长度,如附录A。它具备高效率,但灵活性较差。

如果通信链路是低速总线(如UART一般100kbps),一般接收一字节产生一次中断,可以将协议设计成变长帧,如附录B。它具备高灵活性,但效率较低。

附录A 一个基于DMA传输固定长度的协议实例

9e9cc90a-1bae-11ee-962d-dac502259ad0.jpg

如图显示了PC发送数据帧的格式,总长为64字节,是4字节的整倍数,符合绝大部分32位处理器结构体对齐的特性。

0x3C:INT8U,帧头,可见字符’<’

Len:INT8U,本帧的总数据长度,在图4即为64

Dst:INT8U,标识目标设备的ID号

Src:INT8U,标识源设备的ID号

Data:56字节的存储区,内容依赖于具体的通信帧(实例见表2)

Cmd:INT16U,数据帧的类别

CS:INT8U, 对它前面所有数据(62字节)进行8位累加和校验

0x7D:INT8U, 帧尾,可见字符’}’

Data域数据结构实例:

9eaf6204-1bae-11ee-962d-dac502259ad0.png

附录B 一个基于变长格式的UART通信协议实例

PC与iWL880A(一种无线通信产品)通信帧采用变长格式,如下图所示。大部分设备(常见为PC机)对于接收以“回车符”的机制很好处理,协议中的Tail就等于0x0D(换行符)。

9ecf9966-1bae-11ee-962d-dac502259ad0.jpg

审核编辑:汤梓红

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 处理器
    +关注

    关注

    68

    文章

    19259

    浏览量

    229650
  • 嵌入式
    +关注

    关注

    5082

    文章

    19104

    浏览量

    304797
  • 通信协议
    +关注

    关注

    28

    文章

    879

    浏览量

    40295
  • 无线通信
    +关注

    关注

    58

    文章

    4564

    浏览量

    143496
  • PC机
    +关注

    关注

    2

    文章

    201

    浏览量

    28573

原文标题:嵌入式设备与PC通信,协议设计原则!

文章出处:【微信号:Linux大陆,微信公众号:Linux大陆】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    嵌入式系统对通信有什么需求?

    嵌入式系统之间的通信通常有两种方式:并行通信和串行通信。并行方式传输数据速度快,但占用的通信线多,传输数据的可靠性随距离的增加而下降,只适用
    发表于 08-09 08:00

    嵌入式领域中常用的5种通信协议是什么

    文章目录嵌入式领域中常用的5种通信协议嵌入式领域中常用的5种通信协议串口协议(UART/USART):串口总线其实就是一种
    发表于 12-14 06:22

    嵌入式系统通信协议及具体程序实现方法是什么

    嵌入式系统通信协议及具体程序实现方法是什么
    发表于 12-20 08:01

    三种常见嵌入式设备通信协议是什么?

    三种常见嵌入式设备通信协议是什么?
    发表于 12-23 08:17

    串口通信协议的相关资料分享

    的建立三、建立STM32与PC之间的通信基础1、串口助手的使用2、效果呈现一、串口通信协议1、UART简介嵌入式开发中,UART串口通信协议
    发表于 02-22 07:16

    EPA 通信协议在μC/OS-II嵌入式系统中的设计与实现

    本文提出了一种基于μC/OS-II 嵌入式系统的EPA 通信协议的实现方案。简要介绍了 EPA 通信协议和模型,针对在以μC/OS-II 嵌入式系统为平台实现EPA
    发表于 05-25 15:02 18次下载

    嵌入式系统与PC的USBUART通信设计

    嵌入式系统与PC的USBUART通信设计  1 概 述   RS232(UART)接口是一种简单、方便和实用的通信接口,用途非常广泛
    发表于 03-08 10:28 1920次阅读
    <b class='flag-5'>嵌入式</b>系统与<b class='flag-5'>PC</b><b class='flag-5'>机</b>的USBUART<b class='flag-5'>通信</b>设计

    基于嵌入式的实时通信协议栈研究与设计

    传统的TCP/IP协议重点在于保证数据传输的可靠性及流量控制,而在实时性要求相对较高的嵌入式领域, 其实时性方面的性能显得不足。为此,对基于TCP/IP协议嵌入式
    发表于 09-23 17:55 27次下载

    结合内部CAN总线与外部网络通信协议嵌入式系统开发

    结合内部CAN总线与外部网络通信协议嵌入式系统开发,网络通信的技术资料,很好很实用。
    发表于 03-28 10:47 10次下载

    PC与单片串口通信协议

    PC与单片串口通信协议
    发表于 12-26 22:12 0次下载

    基于嵌入式网关的socket编程及通信协议

    基于嵌入式网关的socket编程及通信协议
    发表于 08-31 14:59 6次下载
    基于<b class='flag-5'>嵌入式</b>网关的socket编程及<b class='flag-5'>通信协议</b>

    三种常见嵌入式设备通信协议

    嵌入式设备PC通讯的通信协议设计经验 嵌入式设备在运行中需要设置参数,这个工作经常由
    的头像 发表于 03-06 10:06 1.7w次阅读
    三种常见<b class='flag-5'>嵌入式</b><b class='flag-5'>设备</b><b class='flag-5'>通信协议</b>

    基于嵌入式环境的串行帧通信协议设计

    嵌入式系统之间的通信通常有两种方式:并行通信和串行通信。并行方式传输数据速度快,但占用的通信线多,传输数据的可靠性随距离的增加而下降,只适用
    发表于 10-14 16:29 1413次阅读
    基于<b class='flag-5'>嵌入式</b>环境的串行帧<b class='flag-5'>通信协议</b>设计

    单片嵌入式系统中的通信协议

    用途的计算机系统,通常被嵌入到其他设备或系统中,用于实现控制、监测、通信等功能。 在嵌入式系统中,单片通过与其他
    的头像 发表于 04-19 14:08 1199次阅读

    几种常见嵌入式设备通信协议

    几种常见嵌入式设备通信协议
    的头像 发表于 09-18 16:43 1636次阅读
    几种常见<b class='flag-5'>嵌入式</b><b class='flag-5'>设备</b><b class='flag-5'>通信协议</b>