新闻中心

EEPW首页 > 嵌入式系统 > 设计应用 > ARM程序优化及其在嵌入式TCP/IP协议实现中的应用

ARM程序优化及其在嵌入式TCP/IP协议实现中的应用

作者:时间:2012-04-20来源:网络收藏

随着技术的发展,人们对系统的智能化、小型化的要求也越来越高。基于结构的微处理器以其高性能、低功耗、低价格等方面的优势被广泛于各种电子产品,特别是一些高端的控制中,例如移动电话、工业控制、网络通信等方面。技术具有很好的性能和功效,其合作伙伴包括许多世界顶级的半导体公司。可以说技术几乎无处不在。

本文引用地址:http://www.eepw.com.cn/article/171582.htm

互联网族在全世界范围内已经成为开放系统互联的,它提供了很好的交互操作能力,可兼容多种网络技术。技术与技术的结合已经展现出强劲的发展势头和巨大的市场潜力。如何开发面向 ARM的高效代码,尤其是提高类似于栈等基础性的软件模块的执行效率已成为每个从事基于ARM的嵌入式系统开发人员必须思考的问题。

面向ARM的

开发高效的涉及很多方面,包括优秀的算法、良好的编程风格以及针对目标的。程序是指软件编程基本结束后,利用软件开发工具对程序代码进行调整和改进,使程序能够更加充分地利用有限的软硬件资源,缩减代码尺寸,提高运行效率的过程。

在实际的程序设计过程中,程序优化的两个目标(运行速度和代码大小)往往是互相矛盾的。为了提高程序运行效率,就要以牺牲存储空间、增加代码量为代价;而为了减少程序代码量、压缩存储器空间,可能又要以降低程序运行效率为代价。按照优化的侧重点不同,程序优化可分为运行速度优化和代码尺寸优化。随着微电子技术的不断发展,存储空间已不再是制约系统集成的主要因素。面向ARM的程序优化主要是讨论如何在了解汇编语言和编译规则的基础上编写出能够高效运行的C语言程序。

作为高性能、低功耗的RISC芯片,ARM的C语言编译器已经非常成熟。尽管如此,在编写面向ARM的C源程序时,对程序进行必要的优化仍是提高程序运行效率的有效途径。以下是一些在TCP/IP协议过程中用到的比较典型的优化原则和方法,这些技术也适用于其他RISC

指令集微处理器。

变量定义

32位 ARM处理器的指令集支持有符号/无符号的8位、16位、32位整型和浮点型变量类型,这不仅可以节省代码,而且可以提高代码的运行效率。按照作用范围的不同,C语言的变量可以划分为全局变量和局部变量。ARM编译器通常将全局变量定位在存储空间中,局部变量分配给通用寄存器。

在全局变量声明时,需要考虑最佳的存储器布局,使得各种类型的变量能以32位的空间位基准对齐,从而减少不必要的存储空间浪费,提高运行效率。如:

49.jpg

这里定义的四个变量形式相同,只是次序不同,却导致了在最终映像中不同的数据布局,如图1所示。显然第二种方式节约了更多的存储器空间。

50.jpg

对于局部变量,要尽量不使用32位以外的变量类型。当一个函数的局部变量数目不多时,编译器会把局部变量分配给内部寄存器,每个变量占一个32位的寄存器。这样short和char类型的变量不但起不到节省空间的作用,反而会耗费更多的指令周期来完成short和char的存取操作。C语言代码编译结果如下所示:

51.jpg

条件执行

条件执行是程序中必不可少的基本操作。典型的条件执行代码序列是由一个比较指令开始的,接下来是一系列相关的执行语句。ARM中的条件执行是通过对运算结果标志位进行判断的,一些带标志位的运算结果中,N和Z标志位的结果与比较语句的结果相同。尽管在C语言中没有带标志位的指令,但在面向ARM的C语言程序中,如果运算结果是与0作比较,编译器会移去比较指令,通过一条带标志位指令实现运算和判断。例如:

52.jpg

linux操作系统文章专题:linux操作系统详解(linux不再难懂)

tcp/ip相关文章:tcp/ip是什么



上一页 1 2 3 4 下一页

评论


相关推荐

技术专区

关闭