浅谈ARM-Linux环境下UDP协议的通信应用研究.doc

上传人:99****p 文档编号:2028001 上传时间:2019-03-29 格式:DOC 页数:10 大小:33KB
下载 相关 举报
浅谈ARM-Linux环境下UDP协议的通信应用研究.doc_第1页
第1页 / 共10页
浅谈ARM-Linux环境下UDP协议的通信应用研究.doc_第2页
第2页 / 共10页
浅谈ARM-Linux环境下UDP协议的通信应用研究.doc_第3页
第3页 / 共10页
浅谈ARM-Linux环境下UDP协议的通信应用研究.doc_第4页
第4页 / 共10页
浅谈ARM-Linux环境下UDP协议的通信应用研究.doc_第5页
第5页 / 共10页
点击查看更多>>
资源描述

1、浅谈 ARM-Linux 环境下 UDP 协议的通信应用研究摘要:进行 UDP 协议通信时,发送端和接收端的状态是相对独立的,发送端不与接收端建立连接,而是不停向接收端发送,为了确保不丢失报文,上位机采取了按固定次数重发相同内容报文的机制。这种机制虽然可以有效确保报文不丢失,但大量冗余数据报被发送,网络资源利用率不高。显然重发次数越多,冗余数据报越多,效率越低。要想有效保证数据报准确发送的同时又不产生过多冗余数据报,那么重复发送的次数的确定就成为问题的关键。以下给出一种确定上位机重发次数的方法。关键词:ARM;Linux;交叉编译环境;UDP 协议;重发机制;重发次数 UDP 协议以其高效性和

2、应用的简单,被广泛运用于嵌入式网络开发中。由于 UDP 协议的应用简单,在嵌入式设备开发过程中,网络资源的利用率并不高。以下将介绍一个 UDP 具体项目实验过程,描述 ARM-Linux环境的软硬件环境构建过程,并对 UDP 协议下一种重发模式中上位机的重发次数的确定提出一种可行的方法。1 研究背景随着嵌入式技术的快速发展,嵌入式设备已经在许多领域取代了传统的微型机设备。本文的选题主要来自于实习期间承接的一项改造项目:某院校特长生评分系统的改造。项目改造目的有:1) 保留原上位机。2) 改用手持式客户端进行显示及评分操作。3)保留原有网络设备。针对要求,我们使用 S3C2440 作为硬件平台,

3、移植 Linux 操作系统,并在 ARM-Linux 环境下研究了 UDP 协议的通信过程,进行了上位机与嵌入式系统的UDP 协议通信实验及分析,并给出一种重发机制中的发送次数求法。2 硬件平台介绍S3C2440 处理速度达到了 400MHZ,具有较高的性价比。为了提高开发效率,我们采用公司自行研制开发的 ET-S3C2440 开发板。2.1 ET-S3C2440 开发板简介ET-S3C2440 是公司自行开发的一款 ARM9 架构的实验开发板,其结构框图如图 1。核心板的主要器件有:32MB2 片 SDRAM,64MB NORFLASH,512MB NANDFLASH。设计了启动方式可选,通

4、过开关选择从 Nandflash 或Norflash 启动。2.2 实验相关电路说明底板电路主要功能是输入输出以及网络通讯功能。按键输入部分采用扫描方式获得输入,用一个单向地址锁存器和一个双向地址锁存器与地址总线相连,可以通过扫描地址来获得按键输入。LCD 采用三星的 3.5寸 TFT 屏作为显示输出设备。网卡芯片选用的是与原设备匹配的 10M 的CS8900A,关于 CS8900A 与 S3C2440 的硬件连接,有众多资源可供参考,本文不再赘述。3 系统软件平台的构建硬件平台搭建完毕后要将操作系统和应用程序在硬件平台上运行起来。以下是对嵌入式 Linux 操作系统移植的过程。3.1 交叉编

5、译环境的构建Linux 2.6.29.1 版本的内核可以登录到下载。本文选择的是 arm-linux-gcc-4.3.2 工具链()在宿主机上进入 Linux 系统,切换当前目录到工具链所在目录,新建一个 arm 目录保存解压后的文件(mkdir /user/local/arm)并将 arm-linux-gcc-4.3.2 解压到这个目录中(tar jxvf arm-linux-gcc-4.3.2 C /user/local/arm)。然后将环境变量$PATH 修改一下,让$PATH 中包含有 arm-linux-gcc 所在的目录(编辑/etc/profile 添加语句”export PAT

6、H=/user/local/arm/4.3.2/bin:$PATH”),然后 reboot 一下,这样交叉编译环境就构建好了。3.2 BOOTLOADER 的移植vivi 是一款相当成熟和相对简单的常用 bootloader,我们以 vivi为移植原型,将 S3C2440 所有 IO 端口寄存器定义添加到头文件2440add.inc,删除部分硬件平台使用不到的代码,最后将修改过的 vivi制作成镜像烧录到 flash 中。13.3 Linux 内核移植获取 Linux-2.6.29.1 源代码并解压后,首先修改内核源代码所在目录中的 Makefile,将系统架构修改为 Arm(ARCH ?=a

7、rm ),交叉编译工具修改为 arm-linux-gcc (CROSS_COMPILE ?=arm-linux-),修改输入时钟(arch/arm/mach-s3c2440/mach-smdk2440.c 中的函数 static void _init smdk2440_map_io 中,修改 s3c24xx_init_clocks(12000000)此处所用晶振为 12M)。修改 machine 名称(在 arch/arm/mach-s3c2440/mach-smdk2440.c 文件中的函数 MACHINE_START( ),修改为MACHINE_START(S3C2440, “自定义机器名

8、”),修改 NANDflash 分区信息(arch/arm/plat-s3c24xx/common-smdk.c 结构体 static struct mtd_partition smdk_default_nand_part中保存的是 nandflah 的分区信息,将其修改为当前使用的分区信息),然后修改 nandflash 的匹配时间(3c2410_platform_nand_smdk_nand_info smdk_nand_info =)。上述内核源代码修改完成后,还需要对一些设备的驱动进行修改。本文使用的 NEC 3.5 寸 320240 液晶屏,硬件平台使用 GPG4 脚进行背光控制,需

9、要修改 LCD 背光(/arch/arm/mach-s3c2440/mach-smdk2440.c中 static void _init smdk2440_machine_init(void),将函数中的GPIO 口配置为 GPG4)。关于 CS8900A 网卡的驱动移植,相关资源很丰富,本文也不再赘述。本实验中 nandflash 采用的是 yaffs2 文件系统,所以打 yaffs2 文件系统补丁,压缩包为 cvs-root.tar.gz。至此,Linux 的内核源代码修改工作完成了,下面还需要利用Makefile,进行内核配置。在 Linux 2.6.29.1 内核目录下首先 make

10、s3c2410_defconfig 使用2410 的配置模板来配置 2440;然后 make menuconfig,这时我们可以在图形化界面中,空格键可改变各个配置选项的被选中状态,根据需要进行配置即可。配置完成后保存好配置,最后进行内核的编译(make dep 建立文件间依赖 make clean 清除编译残留文件 make zImage 生成内核压缩镜像文件)。编译过程完成后会在内核目录 arch/arm/boot/下生成 zImage 内核映像文件,将这个镜像文件烧录到 flash 中,调试检验,经上述修改后的内核工作运行正常。3.4 根文件系统的制作根文件系统是使用 busybox-1

11、.13.3 来制作完成。下载 busybox 并解压完成后,修改 Makefile 中的架构为 ARM 架构,编译工具为 arm-linux-gcc( ARCH ?=arm; CROSS_COMPILE ?=arm-linux-),然后 Make menuconfig,通过图形界面对 busybox 进行配置,然后对 busybox 进行编译(make CONFIG_PREFIX=/opt/studyarm/rootfs install),在目标目录下会生成目录 bin、sbin、usr 和文件 linuxrc 的内容。基本目录结构生成后,应该在目标目录下建立一些未生成的必要的系统目录如 de

12、v、etc、lib 等,并通过 chmod 命令改变目录权限为可写。再将一些必要的动态链接库和静态库拷贝到 lib 下,然后在 dev 目录下创建设备节点,最后创建该嵌入式 Linux 系统的初始化配置文件(包括设备列表文件、口令、网络分组组名、HOSTNAME 主机名、etc/inittab 初始化表单、etc/profile 环境变量配置文件、用于系统初始化的.bash 脚本文件等)。由于本实验需对网络编程,要求自动初始化 CS8900A 网卡芯片的 IP 地址、网关、子网掩码等,所以在开机自启动脚本中加入ifconfig 语句,使得开机时自动配置网卡参数。根文件系统构建完成后,使用 ya

13、ffs2 文件系统制作工具mkyaffs2image.tgz,通过命令 mkyaffs2image rootfs rootfs.img 生成根文件系统镜像,然后将镜像烧写入 flash 中。4 ARM-Linux 环境下的 UDP 协议通信实验经过上述硬件设计和操作系统移植过程,本文所使用到的实验环境已经构建完毕,经反复调试修改,嵌入式 Linux 操作系统在平台下运行正常,于是进行 UDP 协议通信实验。4.1 UDP 协议套接字编程基础UDP 是一个面向数据报和无连接的简单传输层协议,它不像 TCP 那样通过握手过程建立服务器与客户端的连接才可以工作。在网络通信质量较好的情况下,UDP 体

14、现出高效率,这适合于传送少量报文的应用。 linux 系统是通过套接字结构来进行网络编程的,应用程序通过对套接字的几个函数调用,会返回一个用于通信的套接字描述符,而 Linux 应用程序在进行任何形式的 I/O 操作时,程序实际上是在读写一个文件描述符。因此 Linux 下的套接字编程,可以看成是对普通文件描述符的操作,这些操作与被使用的硬件平台无关,这是 linux 设备无关性的优点。UDP 协议的通信模型如图 3 所示。在上述流程中,客户端所收到的报文被存储在缓冲区中,recvfrom()函数返回了报文存储缓冲区的首地址,我们可以很方便地对这个首地址进行数组操作,从而实现对报文的解码。4.

15、2 上位机报文结构及重发机制分析根据项目要求,上位机软件依然保留,我们使用协议嗅探工具对上位机发送的报文进行了嗅探,得到了上位机报文的结构如表 1 所示。表 1 上位机报文结构上位机发出的每条报文由 32 个字节组成,第 0 位为版本信息。第112 位为比赛信息和运动员教练信息,是报文的关键信息部分,1322 位为服务器端和客户端的 IP 地址及端口号信息,23 位是上位机对客户端的操作指令代码,24 位是相关重发机制的代码,30 和 31 两位是 CheckSum,用来保证数据传输的正确。上位机采用的重发机制是一种上位机按照固定重发次数多次发送同一关键内容报文的机制,其第 24位重发机制位被

16、分为高 4 位和低 4 位两部分,高四位的内容是当前发送的报文的索引号,每次发送一条新内容的报文时索引号自增 1,索引号的取值范围在 0x000xFF 范围内循环自增。低四位是重发编号,表示同一索引号的报文正在被第几次重发,固定的重发次数由上位机初始化时设定。4.3 嵌入式客户端的实验程序设计针对报文结构,我们对接收端编写实验程序代码,代码的主要功能是从上位机接收报文,将计算出的 CheckSum 校验和与收到的校验和对比判断报文是否正确,然后从正确报文中取出主要信息并按照报文中的上位机指令码进行输出。其结构流程图如图 3 所示。实验程序经编码、调试后在交叉编译环境中交叉编译,生成 arm-L

17、inux 环境下可执行文件,在目标板上执行。经测试试验程序能够正确接收上位机发来的报文,对报文解码,并能根据上位机命令对关键信息做输出处理。4.4 对上位机重发次数的研究进行 UDP 协议通信时,发送端和接收端的状态是相对独立的,发送端不与接收端建立连接,而是不停向接收端发送,为了确保不丢失报文,上位机采取了按固定次数重发相同内容报文的机制。然而这种机制虽然可以有效确保报文不丢失,但是大量冗余数据报被发送,网络资源利用率不高。重发次数越多,冗余数据报越多,效率越低。要想有效保证数据报准确发送的同时又不产生过多冗余数据报,那么重复发送的次数的确定就成为问题的关键。以下给出一种确定上位机重发次数的

18、方法。假设当前网络状况下,每次报文发送被丢失的概率为 p,系统允许接收端报文关键内容丢失概率为 q,那么如何确定以上重发机制中的重发次数 k 呢?特殊情况下若报文重发次数为 2,分别在每条报文重发机制位注明一个索引号和一个重发编号,发送端发送报文的次序应形如 1.1 ,1.2 ,2.1 ,2.2 ,3.1 ,3.2其中索引号相同的报文关键内容相同,重发编号不同代表同一关键内容报文的不同次发送。因此只有出现连续两次丢失数据报的情况下,报文关键内容才可能丢失。出现连续两次丢失的情况有 2 种,当 x.1 , x.2 丢失,此时索引号为 x 的报文关键信息将全部丢失。当 x.2,(x+1). 1 丢

19、失,丢失报文的索引号不同,此时不会发生报文关键信息丢失,因此报文关键内容丢失的概率 q=p2/2。当报文重发次数为 3,依然在每条报文的重发机制位注明索引号和重发号,发送报文的次序应为 1.1 ,1.2 ,1.3 ,2.1 ,2.2 ,2.3 ,3.1 ,3.2。只有出现连续 3 次丢失数据报的情况报文关键信息才可能丢失,列出连续 3 次丢失报文的情况有 3 种,当 x.1 , x.2 , x.3 丢失,此时索引号为 x 的报文信息全部丢失。当 x.2 , x.3 ,(x+1).1 或 x.3 ,(x+1).1 ,(x+1).2 丢失时不影响报文的准确传递。因此此时报文关键内容丢失的概率 q=

20、p3/3。推广至一般情况易得当报文重发次数为 k 时,报文关键内容丢失的概率 q=pk/k,移项有 kq=pk。于是我们得到求重发次数 k 的方法1) 根据网络状况获得报文丢失概率 p; 2) 根据客户需求取得报文关键内容的允许丢失率范围 q;3) 分别作出 y=px 和 y=qx 的图像;4) 求得两图像的交点的 x 坐标,并将 x 坐标值取整加一即为所求重发次数 k。本文实验中,需求方允许报文关键信息丢失概率 q=0.0001,我们分别对上位机发送端和下位机接收端收发的报文进行了统计,在某一固定时间段内,上位机共发送报文 19665 条,接收端接收报文 18636 条,传输过程中丢失的报文

21、 19665-18636=1029 条,当前网络环境下的报文丢失率为,即 p=0.0523。据此数值分别作出 y=0.0001x 的曲线和 y=0.0523 x 的曲线,取得两曲线交点 x 坐标为 x2.78,最后将 x=2.78 取整加 1 得到k=3,即上位机对同一数据报的重发次数应该定为 3 次就可保证系统丢失报文的概率低于 0.0001。5 结论与展望本文从硬件平台搭建、Linux 移植以及 UDP 协议编程几个方面介绍了arm-Linux 环境下 UDP 协议通信的具体实现,并分析了一种在实际嵌入式项目中常用的上位机数据报重发机制,最后对这种机制中的重发次数的确定方法给出了求解过程,为后续的具体项目实施提供了实践依据,也希望为其他应用这种重发机制的嵌入式产品开发者们提供了借鉴。参考文献: 1 李伟.基于 ARM9 的嵌入式 Linux 手持平台的设计与实现D.武汉:武汉理工大学硕士学位论文,2009.范艳开.基于 ARM 的嵌入式 Linux 操作系统移植D.西安:西北工业大学,2005.刘畅,彭楚武.Linux 下的 UDP 协议编程J.仪表技术,2006(1).NEil Matthew Richard Stones.Beginning Linux ProgrammingM.2nd ed.Wrox Press,2002

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 学术论文资料库 > 毕业论文

Copyright © 2018-2021 Wenke99.com All rights reserved

工信部备案号浙ICP备20026746号-2  

公安局备案号:浙公网安备33038302330469号

本站为C2C交文档易平台,即用户上传的文档直接卖给下载用户,本站只是网络服务中间平台,所有原创文档下载所得归上传人所有,若您发现上传作品侵犯了您的权利,请立刻联系网站客服并提供证据,平台将在3个工作日内予以改正。