数据定义伪操作

来源:本站
导读:目前正在解读《数据定义伪操作》的相关信息,《数据定义伪操作》是由用户自行发布的知识型内容!下面请观看由(电工技术网 - www.9ddd.net)用户发布《数据定义伪操作》的详细说明。
简介: 本文是关于 数据定义伪操作。

数据定义伪操作用于数据缓冲池定义、数据表定义、数据空间分配等,包括以下的伪操作。

(1) LTORG

LTORG用于声明一个数据缓冲池的开始。在使用伪指令LDR时,常常需要在适当的地方加入LTORG声明数据缓冲池,LDR加载的数据暂时放于数据缓冲池。

语法格式

LTORG

使用说明

当程序中使用LDR之类的指令时,数据缓冲池的使用可能越界。为防止越界发生,可使用LTORG伪操作通常放在无条件跳转指令之后,或者子程序返回指令之后,这样处理器就不会错误地将数据缓冲池的数据当做指令来执行。

示例9 用LTORG伪操作定义数据缓冲池举例

AREA Example,CODE,READONLY ;声明一个代码段,名称为Example,属性为只读

start BL funcl

funcl ;子程序

LDRR1,=0x8000 ;将0x8000加载到R1

;在后面介绍伪指令LDR时详细解释

MOVPC,LR ;子程序结束

LTORG ;定义数据缓冲池,存放8000

DataSPACE 40 ;从当前位置开始分配40字节的内存单元并初始化为0

END ;程序结束

(2) MAP

MAP用于定义一个结构化的内存表的首地址。此时,内存表的位置计数器{VAR}(汇编器的内置变量)设置成该地址值。MAP可以用“^”代替。

语法格式

MAP expr {,base-register}

其中:expr为数字表达式或者是程序中已经定义过的标号。base-register为一个寄存器。当指令中没有base-register时,expr即为结构化内存表的首地址。此时,内存表的位置计数器{VAR}设置成该地址值。当指令中包含这一项时,结构化内存表的首地址为expr和base-register寄存器内容的和。

使用说明

MAP伪操作和FIELD伪操作配合使用来定义结构化的内存表结构。

示例10 MAP伪操作举例

MAP fun ;fun就是内存表的首地址

MAP 0x100,R9 ;内存表的首地址为R9+0x100

提醒:《数据定义伪操作》最后刷新时间 2024-03-14 00:55:47,本站为公益型个人网站,仅供个人学习和记录信息,不进行任何商业性质的盈利。如果内容、图片资源失效或内容涉及侵权,请反馈至,我们会及时处理。本站只保证内容的可读性,无法保证真实性,《数据定义伪操作》该内容的真实性请自行鉴别。