- 1、本文档共62页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
汇编及嵌入式C语言会计学第三章 ARM程序设计基础第1页/共62页3.1 ARM编程器所支持的伪操作 伪指令——一些特殊的指令助记符,没有相对应的操作码。伪指令在源程序中的作用是为完成汇编程序作各种准备,这些伪指令仅在汇编过程中起作用,一旦汇编结束,伪指令的使命也就完成了。 伪指令所完成的操作称为伪操作。第2页/共62页3.1.1 符号定义伪指令 符号定义伪指令用于定义ARM 汇编程序中的变量、对变量赋值以及定义寄存器的别名等操作。 常见的符号定义伪指令有如下几种: — 用于定义全局变量的GBLA、GBLL 和GBLS — 用于定义局部变量的LCLA、LCLL 和LCLS — 用于对变量赋值的SETA、SETL、SETS — 为通用寄存器列表定义名称的RLIST第3页/共62页3.1.1 符号定义伪指令GBLA、GBLL和GBLS - GBLA 伪指令用于定义一个全局的数字变量,并初始化为0; - GBLL 伪指令用于定义一个全局的逻辑变量,并初始化为F(假); - GBLS 伪指令用于定义一个全局的字符串变量,并初始化为空; 由于以上三条伪指令用于定义全局变量,因此在整个程序范围内变量名必须唯一。 第4页/共62页3.1.1 符号定义伪指令举例如下: GBLA Test1 ;定义一个全局的数字变量Test1 SETA 0xaa ;将该变量赋值为0xaa GBLL Test2 ;定义一个全局的逻辑变量Test2 SETL {TRUE} ;将该变量赋值为真 GBLS Test3 ;定义一个全局的字符串变量Test3 SETS “Testing” ;将该变量赋值为“Testing” 第5页/共62页3.1.1 符号定义伪指令LCLA、LCLL和LCLS - LCLA 伪指令用于定义一个局部的数字变量,并初始化为0; - LCLL 伪指令用于定义一个局部的逻辑变量,并初始化为F(假); - LCLS 伪指令用于定义一个局部的字符串变量,并初始化为空; 以上三条伪指令用于声明局部变量,在其作用范围内变量名必须唯一。第6页/共62页3.1.1 符号定义伪指令举例如下: LCLA Test4 ;声明一个局部的数字变量Test4 SETA 0xaa ;将该变量赋值为0xaa LCLL Test5 ;声明一个局部的逻辑变量Test5 SETL {TRUE} ;将该变量赋值为真 LCLS Test6 ;定义一个局部的字符串变量Test6 SETS “Testing” ;将该变量赋值为“Testing” 第7页/共62页3.1.1 符号定义伪指令SETA、SETL和SETS - SETA 伪指令用于给数字变量赋值; - SETL 给一个逻辑变量赋值; - SETS 伪指令用于给一个字符串变量赋值; 第8页/共62页3.1.1 符号定义伪指令RLIST RLIST伪指令可用于对一个通用寄存器列表定义名称,使用该伪指令定义的名称可在ARM 指令LDM/STM 中使用。在LDM/STM 指令中,列表中的寄存器访问次序为根据寄存器的编号由低高,而与列表中的寄存器排列次序无关。 举例如下: RegList RLIST {R0-R5,R8,R10} ;将寄存器列表名称定义为RegList,可在ARM指令LDM/STM中通过该名称访问寄存器列表。 第9页/共62页3.1.2 数据定义伪指令 数据定义伪指令一般用于为特定的数据分配存储单元,同时可完成已分配存储单元的初始化。 常见的数字定义伪指令有如下几种: — DCB用于分配一片连续的字节存储单元并用指定的数据初始化。 — DCW(DCWU) 用于分配一片连续的半字存储单元并用指定的数据初始化。 — DCD(DCDU) 用于分配一片连续的字存储单元并用指定的数据初始化。 第10页/共62页3.1.2 数字定义伪指令DCB DCB 伪指令用于分配一片连续的字节存储单元并用伪指令中指定的表达式初始化。其中,表达式可以为0~255 的数字或字符串。DCB 也可用“=”代替。 举例如下: Str DCB “This is a test!” ;分配一片连续的字节存储单元并初始化。第11页/共62页3.1.2 数字定义伪指令DCW(或DCWU) DCW (或DCWU) 伪指令用于分配一片连续的半字存储单元并用伪指令中指定的表达式初始化。其中,表达式可以为
您可能关注的文档
最近下载
- 《改造我们的学习》课件+2024-2025学年统编版高中语文选择性必修中册.pptx VIP
- T∕CECS 10028-2019 绿色建材评价 钢结构房屋用钢构件(可复制版).pdf
- 毕业典礼的活动策划方案.pptx VIP
- A4线缆标签打印模板.xls VIP
- 2022年高中学业水平考试试题及答案9科.docx VIP
- 临潭县住房和城乡建设局社会稳定风险评估工作实施方案.pdf VIP
- 新北区苏科版二年级上册劳动《6、树叶书签》教案.docx VIP
- 试验设计与数据处理(第三版)李云雁-第4章-回归分析.pptx VIP
- 西子奥的斯OH-CON电气原理图纸XAA21310S 一体化LMCB图纸.pdf
- A4标签打印模板.xls VIP
文档评论(0)