ImageVerifierCode 换一换
格式:PPT , 页数:49 ,大小:625KB ,
资源ID:1362650      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/1362650.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(ARM嵌入式软件开发.ppt)为本站会员(b****1)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

ARM嵌入式软件开发.ppt

1、嵌入式软件开发,嵌入式开发过程,“PC软件”,独立的嵌入式应用,当程序员开始开发一个基于ARM应用的时候,你可以使用ARM的ADS编写类似于“HELLO WORLD”的程序,使用ARMulator或者在评估板上来调试,但当你把他移植到独立的嵌入式应用设备中时,下面这些问题就成为我们首要考虑的:硬件环境中所使用的C库函数 目标板上的存储器资源 应用程序的初始化,议程,PC软件的构造定制标准C库函数到目标板 定制IMAGE的存储器映射到目标板复位和初始化深层次的存储器器映象考虑编译和调试IMAGE,ADS默认的标准C库,ANSI C,input/output,error handling,stac

2、k&heapsetup,other,Semihosting Support,应用程序调用的C库函数eg:fputc(),设备驱动层使用semihosting SWIseg:_sys_write(),调试工具环境,C Library,Debug Agent,C库函数功能是支持PC软件的,而目标板上的可执行软件则依赖相关的硬件资源;在ARM体系中,我们可以采用semihosting通过相应的驱动来进行调试。,ADS默认的存储器映射,在默认的情况下,我们链接、定位、运行在0 x8000heap 被直接放置在数据区的上面堆栈的基地址是通过调试环境从C库函数的Startup Code 里读取出来的。AR

3、Mulator=from configuration file(peripherals.ami)default=0 x08000000Multi-ICE=from debugger internal variable$top_of_memorydefault=0 x80000,RO,RW,ZI,0 x8000,链接时确定,由调试环境提供,Heap(malloc,alloc),Stack,C Library,User Code,应用程序启动,_maincopy code and datazero uninitialized data,程序入口点,Agenda,一个PC软件的构造定制标准C库函数到

4、目标板 定制IMAGE的存储器映射到目标板复位和初始化深层次的存储器器映象考虑编译和调试IMAGE,重定向C库函数(1),SemihostingSupport,ANSI C,input/output,你可以使用适合你目标板运行的驱动来替换标准C库中的设备驱动。Eg:printf()可打印到LCD上,而不是打印控制台上,input/output,ANSI C,C Library,User Code,Debug Agent,Target Hardware,Retarget,重定向C库函数(2),要重定向C库函数,简单的办法是使用你自己的可执行的semihosting SWIs来代替原来的C库函数,

5、从而来满足你的系统要求 比如说,the printf()系列函数(sprintf()除外)都会调用fputc().在默认情况下fputc()的执行使用了semihosting SWI.用下面的语句来代替:extern void sendchar(char*ch);int fputc(int ch,FILE*f)/*e.g.write a character to an LCD*/char tempch=ch;sendchar(可查看在ADS Embedded example目录下的retarget.c,可看到更多的重定向例子 你可以确定有不在连接时使用semihosting SWI 的吗?.,

6、消除C库函数中的semi hosting,为了确保在连接时没有函数使用了semi hosting SWIs,你可以在程序中加入下面的句子:#pragma import(_use_no_semihosting_swi)如果在程序中仍然使用了semihosting,编译时将会报错:Error:Symbol _semihosting_swi_guard multiply defined修改:如果使用(check-verbose linker output for occurrences of I use_ semihosting_ swi),那么连接器将会把那些使用了smeihosting 的程序列

7、出来,然后:提供你自己可运行的功能函数。在ADS 1.2 编译器和库函数手册,表4-2给出了所有使用了semihosting的C库函数。注意:连接器在用户自己的应用代码中不会出现任何有关 semihosting SWI使用的报告。,Agenda,一个PC软件的构造定制标准C库函数到目标板 定制IMAGE的存储器映射到目标板复位和初始化深层次的存储器器映象考虑编译和调试IMAGE,分散加载(Scatterloading),在一个实际应用当中,你可能并不想在0 x8000处开始运行。大多数嵌入式系统都有存储器设备,他们的地址空间是在整个存储器映射中交叉出现的。分散加载提供了一种把你的代码和数据放在

8、不同的存储器定位上的办法分散加载定义了两种类型的存储器区域。Load 区:-在reset/load时保留了应用程序的代码和数据(典型应用为 ROM).Execution 区 在程序执行的同时保留了程序的代码和数据。在应用程序启动 期间,每个load区都可创建一个或多个可执行区。分散加载了的应用把详细的存储器映射保存在一个描述文件中,作为一个参数给armlink使用 eg:armlink program.o-scatter scatter.scf-o program.axf,分散加载(简单例子),只读代码和数据保存在ROM中C库函数初始化代码(在 _main)将:从ROM拷贝RW数据到RAM在R

9、AM中的ZI 数据初始化,Scatter 描述文件,通配符(*)语法允许简单的对CODE 和DATA 进行分组,EXEC_ROM 0 x0000 0 x4000*(+RO),链接器放置规则,在每个可执行区,链接器通过一些基本的规则来放置CODE 和DATA基本的排序方法是通过属性来安排的:RO 领先于RW,RW 领先于ZI有相同的属性时,CODE 在DATA之前放置。更多的排序方法决定于:输入的组名按字母排序,在ARMLINK命令行中指定的顺序。eg:armlink file1.o file2.o,在SCATTOR 文件中的对象排序,为了把特定的CODE 和DATA 放在指定的地址上,你可以不

10、考虑标准的放置规则使用+FIRST 和+LAST,直接把第一个和最后一个对象放在可执行区。图例:把VECTOR表放在区的开始。,LOAD_ROM 0 x0000 0 x4000 EXEC_ROM 0 x0000 0 x4000 vectors.o(Vectors,+FIRST)file1.o(+RO)file2.o(+RO):,在可执行区内,scattor 文件中要排序的对象对输出image没有影响链接器的标准放置规则仍然适用,ROOT区,LOAD_ROM 0 x0000 0 x4000;start address and length EXEC_ROM 0 x0000 0 x4000;roo

11、t(load=exec address)_main.o(+RO);copying code*(Region$Table);RO/RW addresses to copy*(ZISection$Table);ZI addresses to zero RAM 0 x10000 0 x8000*(+RO);All other RO areas*(+RW,+ZI);program variables,Must be in a root region,outside root region,一个 root 区是一个可执行区,它的加载地址等于执行地址。,Root区要点,一个 root 区是一个可执行区,它

12、的加载地址等于执行地址.每个scatter描述文件必须最少包含一个root区,并且最少要包含下列内容:_main.o 含有拷贝code/data的代码Region$Table 和 ZISection$Table 含有将要拷贝的code/data的地址,他是由链接器产生的,不是一个对象文件。(所以*必须用)Error:L6202E:Section Region$Table cannot be assigned to a non-root region.Error:L6202E:Section ZISection$Table cannot be assigned to a non-root reg

13、ion.注意:如果*(+RO)被定位在 root 区,在此之前的将被自动放置Main应用程序的入口点必须放在root区。Error:L6203E:Entry point(0 x08000000)lies within non-root region EXE_FLASH.,Run-time 存储器管理,SemihostingSupport,ANSI C,Stack&HeapSetup,Stack&HeapSetup,ANSI C,C Library,User Code,Debug Agent,Target Hardware,Retarget,如何设置stack和 heap来满足我们的目标存储器?

14、,我们已经通过执行_user_initial_stackheap()把C标准库的运行存储器模式修改到目标平台上。,Stack 和 Heap 初始化,C Library,User Code,_maincopy code and datazero uninitialized data,Image Entry Point,Run-time 存储器模式,你必须决定在放置stack和heap时所使用的区域是单一的区(one-region model)或是不同的两个区(two-region model),Heap,Stack,Stack,One region model,Two region model,

15、HB,SB,SB,HB,HL,单一存储器模式是默认方式为了实现多区域模式,你可以使用 use_two_region_memory在所有的模式下,软件堆栈检查要许可。编译开关是:-apcs/swst 指定堆栈限制(为 two-region 模式),heap is checked against stack pointer,Heap,heap is checked against heap limit,(SL),_user_initial_stackheap(),可以用C或汇编来写,他要返回:Heap 基地址在R0,STACK 的基地址在R1.Heap 的限制地址在R2,STACK的限制地址在R3

16、,EXPORT _user_initial_stackheap_user_initial_stackheapLDR r0,=0 x80000;HBLDR r1,=0 x88000;SB;r2 not used(HL);r3 not used(SL)MOV pc,lr,Heap,Stack,Heap 的限制地址在单一模式是不被使用的。Stack 的限制地址只在软件堆栈检查许可的情况下才有效。,HB=0 x80000,SB=0 x88000,警告!,当使用分散加载时你必须执行 _user_initial_stackheap()在C库初始化代码内的_user_initial_stackheap()的默认执行是在映像文件的RW/ZI数据段后放置HEAP。使用 Image$RW$Base/Image$ZI$Base 连接符号这些符号对scatterloading是无效的。在ADS 1.1和早期版本的软件中:符号被设置为0X0,heap被定位在这!Heap的并发使用,无论是直接(e.g.with malloc()或间接(by use of argc/argv)的都可能破坏向量表或其他代码,典型的结

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1