单片机信息网:深圳市今科电子有限公司
网站地图 RSS订阅
高级搜索 收藏本站
会员中心 欢迎投稿
首页 | 业界动态 | 解决方案 | 技术文献 | 下载中心 | 单片机学习 | 单片机原理 | 单片机编程 | 单片机设计 | 单片机开发 | 技术专题 | 单片机论坛 |单片机博客| 联系我们
单片机新闻 | 单片机学习 | 单片机编程 | 单片机设计 | 单片机开发 | 单片机原理 | 单片机解密 | 芯片解密 | IC解密 | 单片机方案 | 51单片机 | AVR单片机 | PIC单片机
单片机程序实例大全 | 潜入式系统 | PCB设计 | 单片机资料下载 | 工具/软件下载 | 技术经验分享 | 单片机技术人生 | IC资料下载 | 数字电路 | 模拟电路 | 单片机空间
当前位置:主页>单片机原理>文章内容
8位机嵌入式TCP通信速度的研究
来源:单片机信息网 作者: 发布时间:2007-10-24 阅读次数: 【大 中 小】【收藏本文】 【打印

8位机嵌入式TCP通信速度的研究


引 言

  长久以来,串行RS 232和RS 485通信技术一直是自动化仪器、仪表中常用的通信标准。但近年来,随着计算机技术、网络技术、通信技术的发展及其在工业自动化系统中的应用,使得工业自动化系统和仪器、仪表领域加速了向智能化、数字化和网络化方向发展的进程。出现了电力线通信技术、无线红外和蓝牙通信技术、基于USB接口的通信技术、现场总线技术以及嵌入式Internet接入技术等新技术。其中基于嵌入式Internet接入技术的网络化仪器是近年提出的全新概念,它是仪器检测技术与现代计算机技术、网络通信技术、微电子技术深度融合的产物口。检测仪器接入Internet,成为执行测量和控制任务的仪器Web站点,这种网络化仪器可以像普通仪器那样按设定程序对相关物理量进行自动测控、存储和显示等,同时允许已授权的用户通过Internet远程对仪器进行操作、监控、故障诊断等。在具体的应用中,出现了不少问题,其中之一就是传输率和系统利用率不高,本文正是在这种背景下产生的。

  1 TCP通信硬件接口

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

  

典型的8位机采用TCP协议接入Internet的以太网网络接口

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

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

  

典型的采集系统TCP数据通信的时间序列图

  

处理流程

  由于服务器(一般为装有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.66ms,其中接受确认分组耗时最多,占总用时的42.8%。

  3 改进后的TCP通信方案

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

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

  如图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协议具体低层实现过程中各个环节对时间消耗的分析,找出了提高系统效率,提高通信速度的方法。实践证明这样的设计提高了系统的效率,提高数据传输率,降低了网络上传送冗余分组的数量,明显改善了系统性能。特别适用于高速、低数据量的采集或测控系统。



上一篇:SI/C负极在实际应用中的失效原因分析   下一篇:AVR单片机捕获中断实现红外线解码

标签:嵌入式系统 单片机 嵌入式 TCP通信 点此搜索本站更多相关信息...搜索更多相关内容..

您可能还感兴趣的内容: 深圳今科电子单片机解密、IC解密服务 今科电子单解机、IC解密业务是怎样的流程?

此页的访问者还关注了下面这些相关资讯


·SI/C负极在实际应用中的失效原因分析
·PIC单片机程序设计的基本格式
·单片机的常用名词
·USB接口类单片机特点及应用
·PIC 8位单片机的汇编语言
·利用单片机PWM信号进行PWM信号
·dsPIC30F6010单片机的原理及应用
·小容量单片机系统的C语言程序结构
·可编程模拟器件原理与开发
·单片机系统硬件抗干扰常用方法实践
·单片机系统设计与C51编程实践
·单片机控制步进电机驱动器工作原理
·PICl6C78系列混合信号嵌入式芯片的原理和应用
·PIC系列单片机简介
·PIC系列单片机程序设计基础
·PIC 8位单片机的分类和特点
·AVR单片机的TWI总线的原理及应用
·单片机(MCU)的分类
·多功能型“银校一卡通”系统关键技术研究
·单片机的Proteus虚拟仿真
·单片机的常用名词
·什么是单片机 什么是dsp芯片?
·为什么要使用仿真器
·AVR单片机的主要特性
·PIC系列单片机简介
·单片机泛泛谈[论坛观点]
·AVR单片机的特点
·PIC单片机的特点及应用
·单片机的用途
·EEPROM 8位单片机/18引脚Flash
·VoIP的基本传输过程简介
·51单片机管脚说明
·单片机的基本结构
·单片机概述
·单片机硬件系统设计原则
·c51单片机实用通信协议
·第七课:51单片机的引脚
·第八课:8051单片机I/O引脚工作原理
·第九课:8051单片机的存储器结构
·第十课:编码及译码器工作原理


版权声明:
( 更多版权详述 | 隐私政策 )

1、凡本网注明“来源:单片机信息网”或“单片机论坛”的文字、图片和音视频作品,版权均属深圳市今科电子有限公司所有,任何媒体、网站或个人未经本网书面授权不得转载、链接、转贴或以其他方式使用;已经本网书面授权的,在使用时必须注明“来源:单片机信息网”或“单片机论坛””。
2、本网未注明“来源:单片机信息网”或“单片机论坛”的作品均为转载稿,本网转载稿件只为传递更多信息,并不意味着认同其观点或真实性。如其他媒体、网站或个人转载使用,必须保留本网注明的“稿件来源”,并自负法律责任。
3、对于单片机信息网通过单片机论坛发布的作品,本网受著作权人委托禁止任何媒体、网站或个人在未经书面授权的情况下转载使用。
4、为维护自身权益、尊重作者版权,单片机信息网特委托深圳市律师协会为本网站法律顾问。对于违反本声明的,单片机信息网律师将依法追究其责任;对于刊载作品涉及版权等问题的,请作者在两周内与网站管理或张朝阳律师联系。
责任编辑:今科电子
双击复制本文网址,发送给您QQ/MSN上的朋友:
[收藏] [推荐] [评论(0条)] [返回顶部] [打印本页] [关闭窗口]
用户名: 新注册) 密码: 匿名评论
评论内容:(不能超过250字,需审核后才会公布,请自觉遵守互联网相关政策法规。

·用户发表意见仅代表其个人意见,并且承担一切因发表内容引起的纠纷和责任
·本站管理人员有权在不通知用户的情况下删除不符合规定的评论信息或留做证据
·请客观的评价您所看到的资讯,提倡就事论事,杜绝漫骂和人身攻击等不文明行为
§最新评论
今科热门解密系列
·PIC芯片DSP系列单片机解密PIC芯
·Freescale单片机解密飞思卡尔芯
·飞思卡尔(Freescale)单片机解密/
·pic18f系列单片机解密
·三星(Samsung)系列单片机极速解
·飞林Feeling芯片系列MCU单片机/I
·MICROCHIP微芯(PIC)系列单片机/M
·单片机破解的常用方法及应对策略
·IC卡预付费电度表的安全及防范技
·单片机解密 单片机解密方法 单片
·PHILIPS系列单片机解密
·独家STC单片机解密
·我对红外遥控信号的解码思路
·51系列单片机解密(数分钟搞定)
·芯片解密业务流程介绍
·单片机解密后提供什么文件?
·单片机解密后为何要提供厂家的专
·芯片是如何被解密的?
·SST系列MCU单片机/IC/芯片解密
·INTEL系列单片机/IC/芯片解密
·ISSI系列MCU单片机IC破解芯片解
·ZILOG系列MCU单片机IC破解芯片解
·MOTOROLA系列MCU单片机IC破解芯
·LG(HYUNDAI系列MCU单片机/IC破
·MCPLD/EPLD系列MCU单片机IC破解
·新茂系列MCU单片机IC破解芯片解
·PHILIPS系列MCU单片机IC破解芯片
·MXIC系列MCU单片机IC破解芯片解
·(ATMEL)51系列MCU单片机IC破解芯
·华邦芯片系列MCU单片机/IC/芯片
·(MICROCHIP)微芯(PIC)系列MCU单
·CYPRESS系列MCU单片机IC破解芯芯
·Sinowealih系列MCU单片机IC破解
·Tenx系列MCU单片机IC破解芯片解
·松翰(SONIX)系列MCU单片机IC破解
·义隆(EMC)系列MCU单片机IC破解
·合泰(HOLTEK)系列MCU单片机IC破
·麦肯(MDT)系列mcu单片机IC破解芯
·今科单片机解密服务
·单片机程序开发
热点技术文章文献
·什么是单片机?
·DSP是什么?
·跟我学编一个最简单的单片机程序
·基于DS18B20的智能温度测量装置
·51单片机的寻址方式
·第八课:8051单片机I/O引脚工作原
·用AT89S205 1单片机实现PWM输出
·基于单片机通用引脚的软件UART设
·单片机控制步进电机驱动器工作原
·单片机模糊PID自整定控制算法的
·单片机模糊控制在电饭煲中的应用
·基于单片机的视频监控矩阵切换器
·dsPIC30F6010单片机的原理及应用
·51单片机的串行口扩展方法
·c51单片机实用通信协议
·单片机硬件系统设计原则
·LED显示屏动态显示和远程监控的
·第十课:编码及译码器工作原理
·SPI模式下MMC卡的读写机制
·第二十八节:伪指令分析
·第七课:51单片机的引脚
·利用单片机PWM信号进行PWM信号
·51单片机的中断系统
·数字电位器在单片机控制变频器中
·51单片机的延时及时序分析
·第二十三课:数据传送类指令分析
·用下载电缆实现AT89S5X的ISP编程
·51单片机的复位
·PIC系列单片机的振荡器配置方法
·51单片机管脚说明
今科推荐产品
·51系列单片机解密(数分钟搞定)
·今科单片机解密服务
·单片机程序开发
·小家电(厨卫电器)系列产品
·灯饰控制系列产品
·四键遥控器系列产品
·红外遥控器系列产品
相关技术文献资讯
·SI/C负极在实际应用中的失效原因
·PIC单片机程序设计的基本格式
·单片机的常用名词
·USB接口类单片机特点及应用
·PIC 8位单片机的汇编语言
·利用单片机PWM信号进行PWM信号
·dsPIC30F6010单片机的原理及应用
·小容量单片机系统的C语言程序结
·可编程模拟器件原理与开发
·单片机系统硬件抗干扰常用方法实
·单片机系统设计与C51编程实践
·单片机控制步进电机驱动器工作原
·PICl6C78系列混合信号嵌入式芯片
·PIC系列单片机简介
·PIC系列单片机程序设计基础
·PIC 8位单片机的分类和特点
·AVR单片机的TWI总线的原理及应用
·单片机(MCU)的分类
·多功能型“银校一卡通”系统关键
·单片机的Proteus虚拟仿真
·单片机的常用名词
·什么是单片机 什么是dsp芯片?
·为什么要使用仿真器
·AVR单片机的主要特性
·PIC系列单片机简介
论坛最新讨论资讯
芯片解密常见问题
· 什么是单片机?
· 单片机要如何加密?
· 单片机芯片是如何被解密的?
· 单片机解密后提供什么文件?
· 芯片解密为何用专用格式文档?
· 芯片解密是怎样的业务流程?
首页 - 隐私政策 - 版权申明 - 网站地图 - 产品中心 - IC解密中心 - 企业文化 - 代理加盟 - 公司简介 - 人才招聘 - 常见问题 - 我要投稿 - 联系我们 - 返回顶部
[单片机信息网] .© 2006-2009 版权所有,严禁非法复制与建立镜像.运营商:[今科电子] 公司地址:中国.深圳/上海 E-Mail:renbangent#126.com sales#techmcu.com(换#为@)
深圳公司 电话热线:+86 0755-82964200 82964201 82964700 传真:0755-82964432 支持手机:13684994966 业务QQ: 501995683 联系人:王小姐 张小姐(工程师) 罗先生(高工)
上海公司 电话热线:+86 021-63062380 15001885509   传真:+86 021-63062380-6   技术支持:15001885509 业务QQ:xxxxxxxx   联系人:郑小姐(业务) 陆工(工程师)
Optimized for 1024x768 to Firefox,Opera and MS-IE6 or higher,Template designed by: Berlin Lee.Web Support[FuAn Network] ICP Record No.:07053756 Webmaster