ARM Cortex-A8/A9开发板 | ARM11开发板ARM11开发套件 | ARM9开发板ARM9开发套件 | 飞思卡尔I.MX28I.MX6开发板 |
tiny210/mini210开发板 | mini6410开发板/套餐 | Tiny6410开发板无线套件 | mini2440开发板/套餐 | micro2440开发板带核心板 | 友善开发板配件 模块 | QQ2440 V3 SBC-2410X |
FL2440 OK2440-IV V4 | OK2440-III OK2440V3 | TE2440-II TE2440V2 | OK6410 S3C6410 ARM11 | FL6410/OK6410B ARM11 | TE6410 S3C6410 ARM11 | TE-9263 AT91SAM9263 | 开发板配件 模块和其他 |
Xilinx开发板/fpga开发套件 | altera开发板/fpga开发套件 | 基于FMC FPGA/DSP子卡 |
BeagleBoard原厂开发板 | PandaBoard原厂开发板 |
TI DM3730 DevKit8500D | TI系列 omap3530开发板 | ATMEL系列 开发板 | Samsung系列 开发板 | 开发板配件-仿真器 模块 | NXP LPC3250 mini3250 |
Tiny210 三星S5PV210 | Mini210/Mini210s开发板 | Tiny4412开发板Cortex-A9 | Tiny6410开发板 ARM11 | mini2440开发板 ARM9 | micro2440开发板 ARM9 | mini6410开发板 ARM11 | 友善ARM开发板配件 模块 |
keil ARM仿真器/开发工具 | STM32开发板 Cortex-M3 | NXP LPC开发板Cortex-M3 | ATMEL系列 ARM开发板 | Luminary EKK8962开发板 | Freescale i.MX31开发板 | 三星s3c2440 s3c6410开发板 |
FL2440 OK2440-IV V4 | OK6410 S3C6410 ARM11 | FL6410/OK6410B ARM11 | OK210/-A Cortex-A8 | TE2440-II TE2440V2 | TE6410 S3C6410 ARM11 | TE-9263 AT91SAM9263 | ARM开发板配件 模块等 |
Real6410开发板/套餐 | Real210开发板/Real2410 | WIFI GPS GPRS模块摄像头 |
Xilinx开发板/开发套件KIT | Altera开发板/开发套件KIT | 配套模块 |
NXP LPC开发板 ARM7 | Cortex-M3 STM32开发板 | 最小系统模块类(初学者勿选) | 开发工具 仿真器 调试器 | TFT液晶屏LCD 液晶模块 |
DM642开发板/DM642实验箱 | DM6446开发板/DSP实验箱 | DSP仿真器 液晶屏 摄像头等 |
DM3730/AM3715/AM3359 | OMAP3530AM1808AM3517 | 飞思卡尔Cortex-A9开发板 | ATMEL系列ARM开发板 | NXP LPC3250 LPC1788 | Samsung系列ARM开发板 | STM32系列F207/F407 | ARM开发板配件-仿真器 模块 |
Realv210 S5PV210开发板 | Real6410开发板 ARM11 | WIFI GPS GPRS模块摄像头 |
NXP LPC开发板 ARM7 | Cortex-M3 STM32开发板 | ARM小系统模块(初学勿选) | 开发工具 ARM仿真器 调试器 | TFT液晶屏LCD 液晶模块 |
keil ARM仿真器/开发工具 | STM32开发板 Cortex-M3 | NXP LPC开发板Cortex-M3 | ATMEL系列 ARM开发板 | Luminary EKK8962开发板 | Freescale i.MX31开发板 | 三星s3c2440 s3c6410开发板 |
Exynos4412开发板A9四核 | UT-S5PV210 S5PC100 | UT-S3C6410开发板 ARM11 | idea 6410开发板 ARM11 | UT-S3C2450开发板 ARM9 | UT-S3C2416开发板 ARM9 | UT-S3C6410核心板 工控 |
Xilinx开发板 FPGA开发套件 | altera开发板 FPGA开发套件 | FMC模块 配件 下载线 |
DM642开发板/DM642实验箱 | DM6446开发板/DSP实验箱 | DSP仿真器 液晶屏 摄像头等 |
s3c2410 ARM9 FS2410 | s3c2440开发板 ARM9 | s3c44B0开发板 ARM7 | s3c6410 2450 2443/13 | PXA270 PXA320 PXA255 | Atmel 9200 9261 9G20 | Philips NXP开发板YL-LPC | FS-EP9315开发板ARM9 | LCD液晶屏TFT真彩/触摸屏 | ARM仿真器/仿真调试工具 | ARM开发板配套ARM核心板 |
三星s3c2410 s3c44B0 | 三星s3c6410 s3c2443 | Intel PXA270 PXA320 | UP-CUP OMAP5910平台 | FPGA Xilinx altera平台 | 配件-仿真器 模块 液晶屏LCD | 龙芯开发板UP-DRAGON-I | 物联网教学科研设备 | EDA/FPGA/SOPC教学科研 |
utu2440-F-V4.5 含核心板 | utu2440-S-V4.1 单板结构 | YC2440-F-V5.1开发板 豪华型 | YC-ePC-A系列人机界面 | Mars-EDA套件CPLD FPGA | 触摸屏LCD 摄像头 WI-FI模块 |
ARM开发板/开发平台 | FPGA开发板/开发平台 | 编程器/烧写器下载器烧录 | ZLG 仿真器ARM FPGA DSP | ZLG周立功逻辑分析仪 |
DSP初学者开发套件(DSK) | DSP仿真器/仿真系统 | DSP开发板/DSP试验箱 | DaVinci系列多媒体平台 | Xilinx FPGA大学计划产品 | SEED教学实验系统 | FPGA/DSP FPGA开发板 | TI原厂开发板套件/CCS软件 |
ARM开发板 | XSCALE开发板 | ARM仿真器 | SOPC开发板 | DSP开发板 | 达芬奇系列DSP开发平台 | DSP仿真器 | DSP实验箱 | DSP专业研究平台 | ARM实验箱系列 |
广嵌实验室项目产品 | GEC2440/GEC6410开发板 |
泰克Tektronix示波器 | 普源RIGOL示波器 | USB虚拟示波器 |
UT-S5PC100 UT-S5PV210 | UT-S3C6410开发板 ARM11 | idea 6410开发板 ARM11 | UT-S3C2450开发板 ARM9 | UT-S3C2416开发板 ARM9 | UT-S3C6410核心板 工控 | 开发板模块wifi gps等 |
EMA OMAP3530开发板 | EMA OMAP 3530核心板 |
三星s3c2410 s3c44B0 | 三星s3c6410 s3c2443 | Intel PXA270 PXA320 | UP-CUP OMAP5910平台 | FPGA Xilinx Altera平台 | 配件-仿真器 模块 液晶屏LCD | 龙芯系列 UP-DRAGON-I |
utu2440-F-V4.5 含核心板 | utu2440-S-V4.1 单板结构 | YC2440-F-V5.1开发板 豪华型 | 触摸屏LCD 摄像头 WI-FI模块 | Mars-EDA套件CPLD FPGA | ePC系列工控一体机ARM9 A8 |
ARM开发板/开发平台 | FPGA开发板/开发平台 | 编程器/烧写器下载器烧录 | ZLG 仿真器ARM FPGA DSP | ZLG周立功逻辑分析仪 |
DSP初学者开发套件(DSK) | DSP仿真器 | DSP开发板 | DSP实验箱 | Xilinx FPGA大学计划产品 |
ARM开发板 | XSCALE开发板 | ARM仿真器 | SOPC开发板 | DSP开发板 | 达芬奇系列DSP开发平台 | DSP仿真器 | DSP实验箱 | DSP专业研究平台 | ARM实验箱系列 |
ARM开发板S3C6410等 | Cortex-A8/ARM11仿真器 | ADSP Blackfin开发板 | FPGA Spartan-3E开发板 |
GEC2410开发套件ARM9 | GEC2440开发套件ARM9 |
泰克 示波器 |
引 言
随着对高处理惩罚本领、及时多任务、超低功耗等方面需求的增长,高端嵌入式处理惩罚器已经进入了海内开辟职员的视野,并在海内得到了广泛的器重和应用。ARM是如今嵌入式范畴应用最遍及的RISC微处理惩罚器布局,依附低本钱、低功耗、高性能等好处占据了嵌入式体系应用范畴的领先职位地方。ADS是ARM公司推出的ARM集成开辟环境,提供了对C和C++的支持,是如今开辟ARM的重要东西。本文针对日益收缩的嵌入式开辟周期,连合ARM体系开辟调试经历,对利用ARM标准库举行应用步伐开辟作了比较体系的阐发。
1 ARM标准库先容
ADS提供了ANSI C和C++标准库,本文仅讨论ANSI C库,该库包括下面几个部分:
◇IS0 C库标准所定义的函数;
◇在semlhosted环境下用来实现C库函数与目标相干的函数;
◇C和C++编译器要利用的heIper函数。
该库提供的诸如文件输入输出之类的配置,利用了标准的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。
调用_main()将大大简化汇编启动代码的编写,汇编代码仅需完成体系硬件的初始化,而没有须要将代码从加载域地点复制到实行域地点,以及ZI域清零等事变。分外是当利用散布式加载时_main()的作用就越发明显了。但是_main()并没有创建C库运行必须的环境,这项事来由_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()调用创建内存模型,其他两个函数没有默认的实现。
实现该函数,必须餍足下面的条件:
◇利用不高出96字节的栈空间;
◇除了R12(ip)外不要污染其他寄存器;
◇将堆基址、栈基址、堆边界和栈边界分别存在RO~R3作为返回参数;
◇堆必须保持8个字节对齐。
实现例程如下:
为了进步应用步伐开辟服从和可移植性,盼望在目标体系上利用ARM库提供的标准输人输出库函数。
高层输入输出函数是不依赖于目标体系环境的,但是高层输入输出函数必须调用依赖于目标体系的底层函数,才华实现应用体系的输入输出。依据目标体系硬件环境重新定义这些底层函数,就可以利用库提供的标准input/output库函数了。下面以淘汰ARM标准库提供的printf系列输出函数为例来作阐明。
标准I/O库中最常用的是printf系列函数,包括_printf()、printf()、_fprintf()、fprintf()、vprintf()和vfprintf()。全部这些函数非透明地利用_FILE,并且仅依赖于fputc()和ferror()两个函数。函数_printf()和_fprintf()与printf()和fprintf()的区别仅在于前两个函数不克不及格局化浮点值。只要定义了本身的_FILE版本和fputc()、ferror()函数,外加定义一个具有FILE范例的_stdout变量,就可以不作任意修改地利用printf系列、fwrite()、fputs()和puts()函数了。
下面给出了详细实现的模板,可以根据实际必要修改。
#include<stdio.h>
struct__FILE
{
int handle;
/*用户必要的任意代码(要是利用文件仅是为了调试利用prinft在标准输出端输出信息,则不必要任意文件处理惩罚代码)*/
};
FlLE_stdout;/*FILE在stdio.h中定义为:typedef struct_
FILE FILE;*/
int fputc(int ch,FILE*f){
/*用户实现的fpute代码。输出一个字符,可以根据必要实现*/
return ch;
}
int ferror(FILE*f){
/*用户实现的ferror代码*/
return EOF;
}
结语
本文阐发了ARM标准库的事变机理,给出了淘汰C库举行步伐开辟的关键步调。实际应用时必要根据详细的硬件环境和应用请求淘汰C库,进步代码实行服从。
博航网 www.broadon.net 版权所有
京ICP备10051899号-2 京公网安备110108006479号