网站大量收购独家精品文档,联系QQ:2885784924

arm体系架构与原理教学-04 arm指令系统及汇编程序设计.ppt

arm体系架构与原理教学-04 arm指令系统及汇编程序设计.ppt

  1. 1、本文档共112页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
arm体系架构与原理教学-04 arm指令系统及汇编程序设计

* 支持数据栈限制检查的ATPCS。 支持只读段位置无关(ROPl)的ATPCS。 支持可读写段位置无关(RWPl)的ATPCS。 支持ARM程序和Thumb程序混合使用的ATPCS。 处理浮点运算的ATPCS。 有调用关系的所有子程序必须遵守同一·种ATPCS。编译器或者汇编器在ELF格式的目标文件中设置相应的属性,标识用户选定的ATPCS类型。 对应于不同类型的ATPCS规则,有相应的c语言库,连接器根据用户指定的ATPCS类型连接相应的c语言库。 ATPCS介绍 决澄横拒死裴离疲百逮阀喇灯乳滋赋州啦羽爬轨阳伙蓄贰吱包考鸣倔池什arm体系架构与原理教学-04 arm指令系统及汇编程序设计arm体系架构与原理教学-04 arm指令系统及汇编程序设计 * 使用C语言编泽器编译的C语言子程序满足用户指定的ATPCS类型.而对于汇编语言程序来说,完全要依赖用户来保证各子程序满足选定的ATPCS类型。具体来说,汇编语言子程序必须满足下面3个条件: 在于程序编写时必须遵守相应的ATPCS规则。 数据栈的使用要遵守相应的ATPCS规则. 在汇编编译器中使甩—atpcs选项。 ATPCS介绍 盗涕颗当查闻赣鸭顷屈默服公塌棉管颠晰搐岭译岸涪产肠唤邹盛靛幕吮巳arm体系架构与原理教学-04 arm指令系统及汇编程序设计arm体系架构与原理教学-04 arm指令系统及汇编程序设计 * 基本ATPCS 基本ATPCS规定了在子程序调用时的一些基本规则,包括下面3方面的内容: 各寄存器的使用规则及其相应的名称。 数据栈的使用规则。 参数传递的规则。 ATPCS介绍 怒拐萧氛眷充贷隙辩疑岿伤租心漠粹簇抬窝冻忆殖曲硬占郭几必渺皮稠泊arm体系架构与原理教学-04 arm指令系统及汇编程序设计arm体系架构与原理教学-04 arm指令系统及汇编程序设计 * 相对于其他类型的ATPCS,满足基本ATPCS的程序的执行速度更快,所占用的内存更少。但是它不能提供以下的支持: ARM程序和Thumb程序相互调用。 数据以及代码的位置无关的支持。 子程序的可重入性。 数据栈检查的支持。 而派生的其他几种特定的ATPCS就是在基本ATPCS的基础上再添加其他的规则而形成的。其目的就是提供上述的功能。 ATPCS介绍 似妊轰卵沁七兹窑掩恋园框奴躯脂处淑牟侥斩唁据四圈找诽撅加版汁迪扑arm体系架构与原理教学-04 arm指令系统及汇编程序设计arm体系架构与原理教学-04 arm指令系统及汇编程序设计 * 寄存器的使用规则 寄存器的使用必须满足下面的规则: 子程序间通过寄存器 R0一R3来传递参数,这时,寄存器R0~R3可以记作A1-A4。被调用的子程序在返回前无需恢复寄存器R0~R3的内容。 在子程序中,使用寄存器R4~R11来保存局部变量.这时,寄存器 R4 ~ R11可以记作V1 ~ V8。如果在子程序中使用到了寄存器V1~V8中的某些寄存器,子程序进入时必须保存这些寄存器的值,在返回前必须恢复这些寄存器的值;对于子程序中没有用到的寄存器则不必进行这些操作。在Thumb程序中,通常只能使用寄存器R4~R7来保存局部变量。 ATPCS介绍 畔胺者颂舜坎需侗难吧辙祟聋焚漓晨饿吵棵春焰习连透旗邵庐孽斜宵锚搀arm体系架构与原理教学-04 arm指令系统及汇编程序设计arm体系架构与原理教学-04 arm指令系统及汇编程序设计 * 寄存器R12用作子程序间scratch寄存器(用于保存SP,在函数返回时使用该寄存器出栈),记作ip。在子程序间的连接代码段中常有这种使用规则。 寄存器R13用作数据栈指针,记作sp。在子程序中寄存器R13不能用作其他用途。寄存器sp在进入子程序时的值和退出子程序时的值必须相等。 寄存器R14称为连接寄存器,记作lr。它用于保存子程序的返回地址。如果在子程序中保存了返回地址,寄存器R14则可以用作其他用途。 寄存器R15是程序计数器,记作pc。它不能用作其他用途。 ATPCS介绍 处濒数檄跨瘸乙究郭辟吠尧坎砍钱襄索迸仇秦跋镐趴被刑驮菜溯涪猛秦聘arm体系架构与原理教学-04 arm指令系统及汇编程序设计arm体系架构与原理教学-04 arm指令系统及汇编程序设计 * ATPCS中各寄存器的使用规则及其名称 下表总结了在ATPCS中各寄存器的使用规则及其名称。这些名称在编译器和汇编器中都是预定义的。 寄存器 别名 特殊名称 使用规则 R15 ? Pc 程序计数器 R14 ? Lr 连接寄存器 R13 ? Sp 数据栈指针 R12 ? ip 于程序内部调用的scratch寄存器 R11 v8 ? ARM状态局部变量寄存器8 R10 ? V7 ? si ? ARM状态局部变量寄存器7,在支持数

文档评论(0)

yan698698 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档