- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
ARM汇编器所支持的伪指令5
ARM汇编器所支持的伪指令5
ARM汇编器所支持的伪指令52010-10-29 16:464.3汇编语言的程序结构
4.3.1汇编语言的程序结构
在ARM(Thumb)汇编语言程序中,以程序段为单位组织代码。段是相对独立的指令或数据序列,具有特定的名称。段可以分为代码段和数据段,代码段的内容为执行代码,数据段存放代码运行时需要用到的数据。一个汇编程序至少应该有一个代码段,当程序较长时,可以分割为多个代码段和数据段,多个段在程序编译链接时最终形成一个可执行的映象文件。
可执行映象文件通常由以下几部分构成:
-一个或多个代码段,代码段的属性为只读。
-零个或多个包含初始化数据的数据段,数据段的属性为可读写。
-零个或多个不包含初始化数据的数据段,数据段的属性为可读写。
链接器根据系统默认或用户设定的规则,将各个段安排在存储器中的相应位置。因此源程序中段之间的相对位置与可执行的映象文件中段的相对位置一般不会相同。
以下是一个汇编语言源程序的基本结构:
AREA Init,CODE,READONLY ENTRY Start LDR R0,=0x3FF5000 LDR R1,0xFF STR R1,[R0]
LDR R0,=0x3FF5008 LDR R1,0x01 STR R1,[R0]
┉┉
END
在汇编语言程序中,用AREA伪指令定义一个段,并说明所定义段的相关属性,本例定义一个名为Init的代码段,属性为只读。ENTRY伪指令标识程序的入口点,接下来为指令序列,程序的末尾为END伪指令,该伪指令告诉编译器源文件的结束,每一个汇编程序段都必须有一条END伪指令,指示代码段的结束。
4.3.2汇编语言的子程序调用
在ARM汇编语言程序中,子程序的调用一般是通过BL指令来实现的。在程序中,使用指令:BL子程序名
即可完成子程序的调用。
该指令在执行时完成如下操作:将子程序的返回地址存放在连接寄存器LR中,同时将程序计数器PC指向子程序的入口点,当子程序执行完毕需要返回调用处时,只需要将存放在LR中的返回地址重新拷贝给程序计数器PC即可。在调用子程序的同时,也可以完成参数的传递和从子程序返回运算的结果,通常可以使用寄存器R0~R3完成。
以下是使用BL指令调用子程序的汇编语言源程序的基本结构:
AREA Init,CODE,READONLY ENTRY Start LDR R0,=0x3FF5000 LDR R1,0xFF STR R1,[R0]
LDR R0,=0x3FF5008 LDR R1,0x01 STR R1,[R0]
BL PRINT_TEXT
┉┉
PRINT_TEXT
┉┉
MOV PC,BL
┉┉
END 4.3.3汇编语言程序示例
以下是一个基于S3C4510B的串行通讯程序,关于S3C4510B的串行通讯的工作原理,可以参考第六章的相关内容,在此仅向读者说明一个完整汇编语言程序的基本结构:
*
Institute of Automation,Chinese Academy of Sciences Description:This example shows the UART communication!
Author:JuGuang,Lee Date:
*
UARTLCON0 EQU 0x3FFD000 UARTCONT0 EQU 0x3FFD004 UARTSTAT0 EQU 0x3FFD008 UTXBUF0 EQU 0x3FFD00C UARTBRD0 EQU 0x3FFD014 AREA Init,CODE,READONLY ENTRY
*
LED Display
*
LDR R1,=0x3FF5000 LDR R0,=ff STR R0,[R1]
LDR R1,=0x3FF5008 LDR R0,=ff STR R0,[R1]
*
UART0 line control register
*
LDR R1,=UARTLCON0 LDR R0,=0x03 STR R0,[R1]
*
UART0 control regiser
*
LDR R1,=UARTCONT0 LDR R0,=0x9 STR R0,[R1]
*
UART0 baud rate divisor regiser Baudrate=19200,对应于50MHz的系统工作频率
*
LDR R1,=UARTBRD0 LDR R0,=0x500 STR R0,[R1]
*
Print the messages!
*
LOOP LDR R0,=Line1 BL PrintLine LDR R0,=Line2 BL PrintLine LDR R0,=Line3 BL PrintLine LDR R0,=Line4 BL PrintLine LDR
您可能关注的文档
最近下载
- 《现代汉语语法研究——层次分析法》PPT课件.pptx VIP
- 2022年厦门大学计算机科学与技术专业《操作系统》科目期末试卷B(有答案).pdf VIP
- 跨越国界的正义追寻:腐败犯罪所得跨境追回的国际法律剖析.docx VIP
- 水电站安全标准化全套资料—安全管理制度汇编.pdf VIP
- 2026-2030女鞋市场发展分析及行业投资战略研究报告.docx
- CFD软件:CFX二次开发_(11).边界条件的自定义开发.docx VIP
- 《工程项目管理》期末考试试卷(有答案).pdf VIP
- T∕NAHIEM 111-2024 生物、医疗行业传递窗技术规范.pdf VIP
- 2023年厦门大学计算机科学与技术专业《操作系统》科目期末试卷A(有答案).docx VIP
- 《现代汉语(下册语法部分)》PPT课件.ppt VIP
原创力文档


文档评论(0)