嵌入式开发教程之使用ARM标准C库进行嵌入式应用程序开发.ppt_第1页
嵌入式开发教程之使用ARM标准C库进行嵌入式应用程序开发.ppt_第2页
嵌入式开发教程之使用ARM标准C库进行嵌入式应用程序开发.ppt_第3页
嵌入式开发教程之使用ARM标准C库进行嵌入式应用程序开发.ppt_第4页
嵌入式开发教程之使用ARM标准C库进行嵌入式应用程序开发.ppt_第5页
已阅读5页,还剩9页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、嵌入式开发教程之使用ARM标准C库进行嵌入式应用程序开发,引 言 1 arm标准库介绍 2 裁减arm标准C函数库 3重新实现user initialstackheap(),随着对高处理能力、实时多任务、超低功耗等方面需求的增长,高端嵌入式处理器已经进入了国内开发人员的视野,并在国内得到了普遍的重视和应用。arm是目前嵌入式领域应用最广泛的RISC微处理器结构,凭借低成本、低功耗、高性能等优点占据了嵌入式系统应用领域的领先地位。ADS是ARM公司推出的arm集成开发环境,提供了对C和C+的支持,是目前开发ARM的主要工具。本文针对日益缩短的嵌入式开发周期,结合ARM系统开发调试经验,对使用ar

2、m标准库进行应用程序开发作了比较系统的分析。,前言,ADS提供了ANSI C和C+标准库,本文仅讨论ANSI C库,该库包含下面几个部分: IS0 C库标准所定义的函数; 在semlhosted环境下用来实现C库函数与目标相关的函数; C和C+编译器要使用的heIper函数。 该库提供的诸如文件输入输出之类的设备,使用了标准的ARM semihosted执行环境(semihosting是针对ARM目标机的一种机制,它能够根据应用程序代码的输入/输出请求,与运行有调度功能的主机通信,这种技术允许主机为通常没有输入和输出功能的目标硬件提供主机资源)。ARMulator、Angel和Multi-lC

3、E都支持这个环境,可以使用ADs中提供的开发工具开发应用程序,然后在armulator或者是开发板上运行和调试该程序。如果要使应用系统独立于这个环境,则必须重新实现C库中依赖于这个环境的相关函数,根据用户系统的运行环境对C库进行适当的裁减。,1 arm标准库介绍,使用ANSI标准C库进行程序开发,不仅可以提高开发效率而且可以增强程序的可移植性。在程序中使用库函数,必须先建立一个库函数可以执行的环境,这些工作都由库中的函数完成。当应用程序链接了C库中的函数时,C库中的函数将完成: 创建C程序所需的执行环境(建立栈,如果需要创建一个堆,初始化程序使用的部分库); 调用main()函数开始执行C程序

4、; 支持程序使用的Is0定义的函数; 捕获运行时的错误和信号,如果需要,根据错误终止执行或程序退出。,嵌入式开发教程,标准库中包含了部分依赖于arm semihosted执行环境的函数,这部分函数的函数名中包含有单个或两个下划线“-”,需要重新实现这部分函数。如果在程序中定义这些函数,则编译器就会使用新定义的函数,这个过程称为库函数的裁减。一般情况下,只需要重新定义很少的几个函数就可以使用C库。 arm应用系统开始执行用户应用程序,必须先将应用程序加载到执行域,建立应用程序的执行环境。使用C库时,这些繁琐的工作就大部分由c函数来完成了。汇编程序完成系统初始化后,跳转到C程序的人口_main()

5、(注意:不是main(),当C程序中定义了main()主函数时,编译器就会生成_main代码)。由_main()引导库函数完成C执行环境的初始化,具体过程如下: 将非启动代码的RO和RW执行域代码从加载域地址复制到执行域地址; 将ZI域清零; 跳转到_rt_entry。,2 裁减arm标准C函数库,调用_main()将大大简化汇编启动代码的编写,汇编代码仅需完成系统硬件的初始化,而没有必要将代码从加载域地址复制到执行域地址,以及ZI域清零等工作。特别是当使用分布式加载时_main()的作用就更加明显了。但是_main()并没有建立C库运行必须的环境,这项工作由_rt_entry()完成,主要调

6、用过程为: 调用_rt_stackheap_init()建立堆和栈; 调用_rt_lib_init()初始化引用的库函数;如果需要,建立main()函数的参数argc和argv等; 调用main()函数,执行应用程序,可以应用库函数; 用main()函数的返回值作参数调用exit()。,嵌入式开发教程,_rt_entry并不是C函数,它是用arm C库编程的起始点。_rt_entry不能用C语言宴现,因为这时候堆栈还没有建立,堆栈由 rt_stackheap_init()来建立。 上面简单介绍了C程序使用库函数时的调用过程,由_rtstackheap_init()建立C库使用的内存模型堆和栈。

7、因为arm库是建立在semihosted执行环境的,它实现的内存模型是基于这个环境的,所以必须修改这个内存模型建立机制。表1列出了需要重新实现的函数,实现了这些函数,应用程序就可以脱离宿主机环境独立运行了。其中,必须重新实现的是user initialstackheap(),因为默认的实现是基于semihosted执行环境的,该函数被nstackheapinit()调用创建内存模型,其他两个函数没有默认的实现。,嵌入式开发教程,实现该函数,必须满足下面的条件: 使用不超过96字节的栈空间; 除了R12(ip)外不要污染其他寄存器; 将堆基址、栈基址、堆边界和栈边界分别存在ROR3作为返回参数;

8、 堆必须保持8个字节对齐。 实现例程如下:,重新实现user initialstackheap(),为了提高应用程序开发效率和可移植性,希望在目标系统上使用arm库提供的标准输人输出库函数。 高层输入输出函数是不依赖于目标系统环境的,但是高层输入输出函数必须调用依赖于目标系统的底层函数,才能实现应用系统的输入输出。依据目标系统硬件环境重新定义这些底层函数,就可以使用库提供的标准inputoutput库函数了。下面以裁减arm标准库提供的printf系列输出函数为例来作说明。 标准I/O库中最常用的是printf系列函数,包括_printf()、printf()、_fprintf()、fprin

9、tf()、vprintf()和vfprintf()。所有这些函数非透明地使用_FILE,并且仅依赖于fputc()和ferror()两个函数。函数_printf()和_fprintf()与printf()和fprintf()的区别仅在于前两个函数不能格式化浮点值。只要定义了自己的_FILE版本和fputc()、ferror()函数,外加定义一个具有FILE类型的_stdout变量,就可以不作任何修改地使用printf系列、fwrite()、fputs()和puts()函数了。,嵌入式开发教程,下面给出了具体实现的模板,可以根据实际需要修改。 #include struct_FILE int handle; /*用户需要的任何代码(如果使用文件仅是为了调试使用prinft在标准输出端输出信息,则不需要任何文件处理代码)*/; FlLE_stdout;/*FILE在stdio.h中定义为:typedef

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论