当前位置:首页 > 嵌入式 > 嵌入式软件
[导读]长期以来,RS 232和RS 485串行通信技术一直是自动测量仪器和设备的通用通信标准。近年来,随着计算机技术,网络技术和网络技术的发展,工业自动化系统,仪器仪表领域加快了智能化,数字化和网络化的发展。通讯技术及其在工业自动化系统中的应用。出现了PLC通信技术,红外和蓝牙无线通信技术,USB接口通信技术,现场总线技术和嵌入式Internet技术等新技术。其中,基于嵌入式Internet访问技术的联网仪器是近年来提出的一个新概念。它是仪器检测技术与现代计算机技术,网络通信技术和微电子技术深度融合的产物。测试仪器已连接到Internet,并成为执行测量和控制任务的仪器网站。这种联网的仪器可以像普通仪器一样,按照定义的过程自动测量,控制,存储和显示相关的物理量,而授权用户则可以授权访问。 Internet可以远程工作,监视和诊断仪器,在某些应用程序中出现了许多问题,其中之一是系统的传输速率和使用率不高,本文是在这种情况下创建的。

长期以来,RS 232和RS 485串行通信技术一直是自动测量仪器和设备的通用通信标准。近年来,随着计算机技术,网络技术和网络技术的发展,工业自动化系统,仪器仪表领域加快了智能化,数字化和网络化的发展。通讯技术及其在工业自动化系统中的应用。出现了PLC通信技术,红外和蓝牙无线通信技术,USB接口通信技术,现场总线技术和嵌入式Internet技术等新技术。其中,基于嵌入式Internet访问技术的联网仪器是近年来提出的一个新概念。它是仪器检测技术与现代计算机技术,网络通信技术和微电子技术深度融合的产物。测试仪器已连接到Internet,并成为执行测量和控制任务的仪器网站。这种联网的仪器可以像普通仪器一样,按照定义的过程自动测量,控制,存储和显示相关的物理量,而授权用户则可以授权访问。 Internet可以远程工作,监视和诊断仪器,在某些应用程序中出现了许多问题,其中之一是系统的传输速率和使用率不高,本文是在这种情况下创建的。

1 TCP通信硬件接口

典型的8位机采用TCP协议接入Internet的以太网网络接口如图1所示。RTL8019AS以其优异的性价比,成为目前单片机以太网系统的首选以太网接口芯片。该芯片符合IEEE802.3 10Base2和10BaseT标准,具有自动奇偶检测和纠错功能,支持全双工工作模式。RTL8019AS工作于8位跳线模式,数据线SD0~SD7与8位单片机(51系列)的数据线(AD0~AD7)相连,地址线A0~A4与8位单片机的地址线(A0~A4)相连。读写信号经74S04产生。RTL8019AS的基地址(配合引脚34(AEN))为 0x8000H,对应RTL8019AS内部地址0x300H。RTL8019AS通过网络变压器HR901170A和RJ45接口与以太网相连接入internet,隔离网络上的干扰信号。

2 单片机系统中TCP通信问题分析

TCP协议是TCP/IP协议簇的核心,也是最复杂的协议。但由于其独特的自动检错和重发机制,实现了数据的可靠通信,但也正是由于其复杂性,在8 位机上实现TCP协议通信耗时就比较多,传输速率低下。TCP协议的数据通信过程,以客户机为例进行分析。图2是典型的采集系统TCP数据通信的时间序列图。在建立连接后,由客户机向服务器发送数据。假设此时客户机的启始序列号为100,每次固定发送100字的样数据。服务器负责接受该数据,但不下发任何送数据,只确认所接收的数据,其启始序列号为50。

由于服务器(一般为装有windows系统的微机或工业计算机)并不是收到数据就直接发送确认,而是继续等待接受序列中的其他数据。这就会经常触发服务器的接受延时的确认算法,这将导致剩下的数据不能在200 ms内发送。对于高速交互的采样系统而言,这将产生明显的时延。Host Requirements RFC申明TCP必须实现Nagle算法,但必须为用户提供一种方法来关闭该算法在某个连接上的执行。该算法要求TCP连接上最多只能有一个未被确认的未完成的小分组,在该分组的确认到达之前不能发送其他的小分组。实际使用Sniffer监听软件也得到同样的结果,在接收到下位机的数据包后,上位机延时 200 ms后,发送确认包,其传输速度为10 packet/s,实际网络利用率不足1%。由图3可见,只要提高服务器确认发送的速度,就可以提高通信的速度。对于本系统采用33M的主频(C051F 单片机)发送一个分组(1 024 B)和接受一个确认分组(60 B)总用时为3~3.5 ms,关闭Nagle算法后,使用Sniffer监听分析数据包,系统上位机在收到数据包后,立即发送确认包,期间只有0.3 ms左右的网络延时,系统速率提高到设定的20 ms发送一次采样数据,即100 packet/s,系统利用率提高为为原来的10倍。

然而对于有些应用场合,每次采样的数据量并不大(小于100 B),采用关闭Nagle 算法来提高传输率是不理想的,因为这样增加了网络上传输的分组的数量,同时增大了客户机(下位机)处理这些多出来的分组的时间消耗,降低了系统利用率,增大了传输出错率,大幅度的减少了持续传输时间。实验中,当采用高频单片机(100M主频),将数据通信速率提高到1 000 packet/s,发现传输错误的数据包达到5%,同时传输持续时间由原来的大于48 h不间断,减少为不足2 h,系统利用率也只有不到2%,同时已无法继续提高传输速度(由硬件条件限制)。为解决这个问题,同过分析具体TCP通信的各环节对时间的消耗过程,寻求在已有的硬件基础上,通过软件来解决问题。

首先是数据分组打包。这里的耗时与要打包的数据量和主频有关。为了便于计算,以下都用最简单的MCS-8051单片机为例进行分析。对于发送100 B的数据,外界晶振为12M的51单片机,其一个机器周期为1μs。典型的打包代码(包括TCP包和IP包)的执行总周期约为2 200个机器周期(具体大小与编写软件所使用的语言和编译器有关),用时为2.2 ms。

其次是数据备份。TCP协议需要超时重发,因而备份已发出而未收到确认的数据分组是必要的。这里的耗时与数据量和主频以及数据本备份的存储器类型有关。对于100 B数据和40 B的头部(包括TCP包的20 B头部和IP包的20 B头部),总共140 B的数据备份,采用外部存储器,典型代码的执行周期为1 130个机器周期,用时为1.13 ms。

再次是发送数据分组。这里的耗时也与数据量和主频有关。典型发送分组代码的执行总周期为2 200个机器周期,耗时为2.2 ms。

最后确认分组。这里要做的工作有:检测接口芯片,判断分组类型,拆分IP包,拆分TCP包,典型代码的执行周期为4 130个机器周期,用时4.13 ms。

总共用时9.66 ms,其中接受确认分组耗时最多,占总用时的42.8%。

3 改进后的TCP通信方案

由上面分析可以看出,对于小分组来说,接收确认分组的过程比较复杂,因而耗时也最多。因而控制服务器确认分组的发送数量,成为提高效率的关键。

研究发现通过调整Nagle算法的延时时间(每个接口的延迟ACK定时器可通过设定注册表表项TCPDelAckTicks 的值 (HKLM \ SYSTEM \CurrentControlSet\Services\Tcpip\Parameters\Interface\)来调整,该注册表表项在MicrosoftWindows NT 4.0 Service Pack 4中首次引进)和采样单片机的发送流程来控制服务器发送确认的数量。

这里发送数据分组并没有等待确认分组这个过程。当有确认到达时,所做的工作正常情况下和图3所示的系统没什么区别,只是在当丢失了分组后的异常状态出现后,才在更新连接状态时处理了超时检测和出错重发等事件。之后在数据打包后也没有备份,这里是采用了大存储器数据偏移技术,也就是说在一个分组的确认未到达时,其原始数据是不会被覆盖的,新的分组打包在其后的内存单元中,这样就节省了数据备份所消耗的时间,不过无形中增大了对内存的需求。但本应用针对的是小分组情况,所以实际需求的内存并不大。实际工作中,为了使系统稳定工作,应建立2个TCP连接,一个用于服务器(上位机)发送控制命令和进行参数设定使用,一个用于客户机(下位机)上传采样数据使用。虽然TCP可以双向传送数据,可实际工作中,发现这样在高速通信下出错率比双连接单向数据通信要高出许多,主要是因为客户机(下位机)对TCP头部的确认号和序列号的调整容易出错所致。实际使用3~5个采样分组发送一个确认分组。因为延时太短体现不了效率的提高,但延时太长,如果出错,将产生大量重发分组的情况,影响网络性能,同时也增大了对内存的需求量。通过使用Snifferr软件进行监听比较,在同样的采样速率下,在改进前,发送包速率为500packet/s,接收确认包速率为500 packte/s,出错率5%,持续传输时间小于2 h;改进后,发送包速率为500 packet/s,接收确认包速率为183 packet/s,出错率小于0.1%,持续时间大于48 h。同时,同样的硬件条件下,理论上可以进一步提高采样速率。

4 典型应用

对于高速、低数据量的采集或测控系统,如石油管道的查漏和修复系统,要求高速采集对管壁的超声波扫描信号,通常结合温度、压力、深度和角度信号为一组采样信号,其总量不足20 B。这些系统要求高的采样速率,但每次采集的数据并不多,这就产生了大量小的数据分组,这些小分组将迅速降低系统性能和网络性能。采用本方案,可以较好地解决这些问题。

5 结 论

本文分析了低层TCP协议的特定实现中每个连接的时间消耗,并找到了提高系统效率和通信速度的方法。 实践表明,这种设计提高了系统效率,提高了数据传输速率,减少了网络中传输的冗余数据包的数量,并大大提高了系统性能。 它特别适用于数据量少的高速采集或测量与控制系统。

本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

随着现代家庭生活方式不断升级,厨房已不再只是功能空间,而逐渐成为融合审美表达、健康管理与智能体验的重要场域。消费者在关注空间整体性的同时,也对食材储存的安全性、洁净度以及使用便利性提出了更高要求。基于对中国家庭真实使用场...

关键字: 冰箱 嵌入式

在嵌入式系统、工业物联网等各类电子设备中,UART与网口是两种应用广泛的通信接口,前者作为经典的串行通信接口,承担着简单设备互联、调试日志传输等基础任务,后者则专注于高速、远距离的数据交互,是设备接入网络、实现大数据量传...

关键字: 嵌入式 通信接口 网口通讯

在软件开发领域,设计模式被誉为“解决特定问题的最佳实践”,但在嵌入式开发中,它却常常处于“边缘地带”。许多嵌入式工程师职业生涯中可能从未刻意使用过设计模式,甚至认为这些“软件工程理论”与单片机、传感器、实时系统等硬件紧密...

关键字: 嵌入式 设计模式

在居住结构持续演进与消费需求不断升级的背景下,中国家庭厨房正经历从“功能集合”向“系统空间”的深层转变。厨房不再只是烹饪的场所,而逐渐成为融合效率、健康、美学与家庭互动的重要生活空间。基于对这一趋势的长期洞察,西门子家电...

关键字: 嵌入式 蒸玲珑

在物联网设备、工业控制系统和智能家居等嵌入式场景中,轻量级WEB服务器扮演着核心角色。它们不仅需要满足资源受限环境下的性能需求,还需兼顾安全性、可扩展性和开发效率。本文从资源占用、功能特性、适用场景三个维度,对比分析六大...

关键字: 嵌入式 WEB服务器

在嵌入式软件开发工具领域,一场悄然的变革正在发生。随着全球软件行业向订阅制转型,嵌入式软件开发工具的授权模式也迎来了重要调整。市场上的嵌入式软件开发工具基本可以分为三类:商用开发工具,开源开发工具和厂商私有开发工具,其中...

关键字: 嵌入式 MCU RISC-V

在资源受限的嵌入式系统中,传统调试工具(如JTAG)往往成本高昂且占用引脚资源。本文介绍一种基于串口的低成本调试方案,通过自定义协议实现内存数据的实时监控,硬件成本可降低80%以上,特别适用于8/16位MCU开发场景。

关键字: 嵌入式 串口 内存数据

随着国家家电以旧换新补贴政策的持续推进,绿色节能、品质升级正成为越来越多家庭的新年焕新关键词。面对消费者在居住空间、生活效率与健康体验上的多元需求,西门子家电围绕新春焕新节点,正式开启“开门红”焕新季,通过国家补贴与企业...

关键字: 嵌入式 咖啡机 嵌饮机

设计人员通过瑞萨远程板场可在新MCU发布首日免费开始编程和编码

关键字: MCU 嵌入式 电路板
关闭