ARM标准库
ADS提供了ANSI C和C 标准库,本文仅讨论ANSI C库,该库包含下面几个部分:
◇IS0 C库标准所定义的函数;
◇在Semihosted 环境下用来实现C库函数和目标相关的函数;
◇C和C 编译器要使用的helper函数。
该库提供的诸如文档输入输出之类的设备,使用了标准的ARM semihosted执行环境(semihosting是针对ARM目标机的一种机制,他能够根据应用程式代码的输入/输出请求,和运行有调度功能的主机通信,这种技术允许主机为通常没有输入和输出功能的目标硬件提供主机资源)。ARMulator、Angel和Multi-lCE都支持这个环境,能够使用ADs中提供的研发工具研发应用程式,然后在ARMulator或是研发板上运行和调试该程式。假如要使应用系统单独于这个环境,则必须重新实现C库中依赖于这个环境的相关函数,根据用户系统的运行环境对C库进行适当的裁减。 ..
使用ANSI标准C库进行程式研发,不但能够提高研发效率而且能够增强程式的可移植性。在程式中使用库函数,必须先建立一个库函数能够执行的环境,这些工作都由库中的函数完成。当应用程式链接了C库中的函数时,C库中的函数将完成:
◇创建C程式所需的执行环境(建立栈,假如需要创建一个堆,初始化程式使用的部分库);
◇调用main()函数开始执行C程式;
◇支持程式使用的Is0定义的函数;
◇捕获运行时的错误和信号,假如需要,根据错误终止执行或程式退出。版权申明:本站文章均来自网络,本站所有转载文章言论不代表本站观点
2 裁减ARM标准C函数库
标准库中包含了部分依赖于ARM semihosted执行环境的函数,这部分函数的函数名中包含有单个或两个下划线“-”,需要重新实现这部分函数。假如在程式中定义这些函数,则编译器就会使用新定义的函数,这个过程称为库函数的裁减。一般情况下,只需要重新定义很少的几个函数就能够使用C库。
ARM应用系统开始执行用户应用程式,必须先将应用程式加载到执行域,建立应用程式的执行环境。使用C库时,这些繁琐的工作就大部分由c函数来完成了。汇编程式完成系统初始化后,跳转到C程式的人口_main () (注意:不是main(),当C程式中定义了main()主函数时,编译器就会生成_main 代码)。由_main()引导库函数完成C执行环境的初始化,具体过程如下:
◇将非启动代码的RO和RW执行域代码从加载域地址复制到执行域地址;
◇将ZI段 清零;
◇跳转到_rt_entry。
◇调用_rt_stackheap_init()建立堆和栈;
◇调用_rt_lib_init()初始化引用的库函数;假如需要,建立main()函数的参数argc和argv等;
◇调用main()函数,执行应用程式,能够应用库函数;
◇用main()函数的返回值作参数调用exit()。
_rt_entry并不是C函数,他是用ARM C库编程的起始点。_rt_entry不能用C语言宴现,因为这时候堆栈还没有建立,堆栈由_ rt_stackheap_init()来建立。
上面简单介绍了C程式使用库函数时的调用过程,由_rt—stackheap_init()建立C库使用的内存模型--堆和栈。因为ARM库是建立在 semihosted执行环境的,他实现的内存模型是基于这个环境的,所以必须修改这个内存模型建立机制。表1列出了需要重新实现的函数,实现了这些函数,应用程式就能够脱离宿主机环境单独运行了。其中,必须重新实现的是_user initial_stackheap(),因为默认的实现是基于semihosted执行环境的,该函数被_n_stackheap_init()调用创建内存模型,其他两个函数没有默认的实现。 .
表1
函数
__user_initial_stackheap()
__user_heap_extend()
__user_stack_slop()
实现该函数,必须满足下面的条件:
◇使用不超过96字节的栈空间;
◇除了R12(ip)外不要污染其他寄存器;
◇将堆基址、栈基址、堆边界和栈边界分别存在RO~R3作为返回参数;
◇堆必须保持8个字节对齐。
实现例程如下:
#include
__value_in-regs struct __initial_stackheap __user_initial-sta ckheap(
{
}
为了提高应用程式研发效率和可移植性,希望在目
ARM标准 相关文章:
- ARM标准汇编与GNU汇编(11-21)
- Windows CE 进程、线程和内存管理(11-09)
- RedHatLinux新手入门教程(5)(11-12)
- uClinux介绍(11-09)
- openwebmailV1.60安装教学(11-12)
- Linux嵌入式系统开发平台选型探讨(11-09)