功能:
格式:
注意:
1、BIT
功能:指令用于将一个位地址赋给指定的符号名。
指令格式:符号名 BIT 位地址经BIT 指令定义过的位符号名不能更改。
例如:X_ON
格式:
功能用于给字符名称定义位地址。
SPK
2、 BSEG
指令格式如下:BSEG [AT 绝对地址表达式]
3、CODE
功能:用于将程序存储器ROM 地址赋给指定的符号名。
指令格式:符号名
例如:RESET
指令格式如下:CSEG [AT 绝对地址表达式]
5、DATA(BYTE)
功能:指令用于将一个内部RAM 的地址赋给指定的符号名
指令格式:符号名 DATA
数值表达式的值应在0~255 之间,表达式必须是一个简单再定位表达式。
例如:REGBUF
DATA与BYTE的区别:
DATA与BYTE是相类似的伪指令。
值,在表达式中对变元个数没有限制,只要此条伪指令能容纳在源程序的一行内,其格式为:标号: DB 表
达式只要表达式不是字符串,每一表达式值都被赋给一个字节。计算表达式值时按16位处理,但其结果只取
低8位,若多个表达式出现在一个DB伪指令中,它们必须以逗号分开。表达式中有字符串时,以单引号“”
作分隔符,每个字符占一个字节,字符串不加改变地被存在各字节中,并不将小写字母转换成大写字母。
例如:DB 00H 01H 03H 46H
7、DBIT
功能:在内部数据区的BIT 段以位为单位保留存储空间。
指令格式:[标号:] DBIT 数值表达式其操作类似于DB。
个变元,第一个变元定义了存储区的长度的字节数,在汇编时,汇编程序将跳过这些单元把其它指令汇编在
这些字节之后,因此在使用DS伪指令时第一个变元不可活力第二个变元表示在这些单元中真入什么值,第
二个变元可以活力活力时这些字节将不处理。下例中0173处有一条DS 9,则空出9个字节,下一第指令被汇
编到017C处;在017C处空出1BH个单元,在这些字节中被27H所填充。DS指令的格式如下:
表达式1定义了存储区的长度(以字节为单位)。这个变元不能省略。表达式2是可选择的,它的值低8位
用以填入所定义的存储区。若省略则这部分存储单元不处理。
例: 0000 04 INC A
DS ---预留存储区命令
格式:
存储区预留的存储单元数由表达式的值决定。
TMP:
从标号TEP地址处开始保留1个存储单元(字节)。
9、DSEG
指令格式如下:DSEG [AT 绝对地址表达式]
10、DW
其格式为:
句有一个参数,可以是数值0,也可以是表达式,
其格式是: 标号: END 表达式
它的值就是程序的地址并且作为一个特殊的记录写入HEX文件。若这个表达式省略,HEX文件中其值就是0。
12、EQU(=)
存器名赋给一个指定符号名。
指令格式:
经过EQU 指令赋值的符号可在程序的其它地方使用,以代替其赋值。
例如:MAX EQU 2000
则在程序的其它地方出现MAX,就用2000 代替。
表达式必须是一个简单再定位表达式。
EXTRN 是与PUBLIC 配套使用的,要调用其它模块的函数,就必须先在模块前声明。
指令格式:EXTRN 段类型(符号,符号······)
例如:EXTRN
调用外部TONGXING和ZHUANHUAN 程序。
14、IDATA
IDATA 指令用于将一个间接寻址的内部RAM 地址赋给指定的符号名。
指令格式:符号名
例如:FULLER
条件伪操作格式:
当IF指令中的表达式为真时,被汇编的代码段是程序块1;当IF指令中的表达式为假时,被汇编的代码段是
程序块2。
16、INCLUDE
功能:
格式:
注意:1、文件名中若没有扩展名,则系统默认是。ASM(该文件必须是能打开的)。
17、ISEG
功能:绝对选择指令ISEG内部间接寻址绝对数据段idata
指令格式如下:ISEG [AT 绝对地址表达式]
宏指令格式
代码段
宏调用格式
它们的格式为:
功能:LIST伪指令使汇编时主生程序清单,但即使不用该指令,汇编也会自动产生清单。但如果使用了NOLIST伪指令后需要继续主生清单则必须使用LIST伪指令。
功能:用来给当前模块命名。
指令格式:NAME 模块名
例如:NAME TIMER
定义一个模块名为TIMER 的模块。
其格式为$NOCODE
NOCODE伪指令使得在汇编时,条件汇编程序结构中那些真值为假的条件不产生清单。有关条件汇编结构在下
面介绍。如果没有这条伪指令,汇编将主生所有条件下的清单,不论其真值是否为真。但是假的条件,不产
生目标码。而NOCODE伪指令使汇编清单中只列出那些由汇编程序用到的部分,因此,当使用NOCODE伪指令
时,程序清单与源程序并非逐行对应。
它们的格式为:
功能:NOLIST伪指令使汇编时不产生清单,所有包含此伪指令及在这条伪指令之后的语句都不进入列表文
件。当不需要任何列表文件,并且不需要显示程序清单时,可以在启动汇编时不加.L附加项,且在源代码
的第一行加上NOLIST指令。使用NOLIST伪指令与附加项/L不同之处是NOLIST伪指令可加在源程序中,与LIST
伪指令配合使用,使源程序中某些部分不产生清单。而不加附加项/L则不产生任何程序清单。不过,不管有
无$NOLIST伪指令,程序在汇编时检查到的错误都将在屏幕上显示出错的源代码行及错误信息
功能:PAGE伪指令用于形成新的一中定义一面的行数。其格式为:$PAGE 表达式
若表达式缺省则开始新的一页,若有表达式,则每页行数重新定义。汇编开始时页长为66行。一页中除出页外,剩余55行用于打印源程序,这一格式适用于标准打印纸。如果变元值小于66,页内可打印的源代码行将相应减少。页长最小值为12。若小于12时,每页内除页上只打印一行源程序。页长变元是16位字节,因而每页最长可定义到65535行,这时分页打印变为连续打印,在屏幕显示程序清单或在卷筒纸上打印程序清单时,常常使用连续打印,如果在启动汇编时用/N选项,页长就是65535。
功能:声明可被其它模块使用的公共函数名。
指令格式:PUBLIC 符号 [,符号,符号[,······]]
PUBLIC 后可跟多个函数名,用逗号格开。每个函数名都必须是在模块内定义过的。
例如:PUBLIC
其中_OUTER 可供C 调用。
功能:再定位段选择指令为RSEG,用于选择一个已在前面定义过的再定义段作为当前段,
指令格式:RSEG 段名
段名必须是在前面声明过的再定位段。
例如:
DATAS SEGMENT DATA :声明一个再定位DATA 段
CODES SEGMENT CODE ;声明一个再定位CODE 段
BSEG AT 60H
绝对段选择指令
CSEG---绝对代码段
DSEG---内部绝对数据段
XSEG---外部绝对数据段
ISEG ---内部间接寻址数据段
BSEG---绝对位寻址数据段
格式:
CSEG
DSEG
XSEG
ISEG
BSEG
括号内是可选项,用来指定当前绝对段的基地址。
功能:SEGMENT 指令用来声明一个再定位段和一个可选的再定位类型。
指令格式:再定位段型
例如:
功能:SET 指令类似于EQU 指令,不同的是SET 指令定义过的符号可重定义。
指令格式:符号名 SET 表达式
例如:MAX SET 2000
功能:TITLE伪指令用于在列表文件页头建立一个标题,其格式为:
这里标量行就是将出现在页头的标量与通常的字符串定义不同。这里标量行不加引号。汇编从$TITLE 之后的第一个可打印字符开始,到回车符之间的字符串作为标量标量的最大长度是60个字符,基标量行省略,则标题行为空行。若TITLE伪指令在一页,它说明的标量行包含在本页,否则,标题将出现在下页页头。
功能:XDATA 指令用于将一个外部RAM 的地址赋给指定的符号名。
例如:RSEG XSEG1 ;选择一个外部数据段
MING DS 10 ;在标号MING 处保留10 个字节
MUNIT XDATA HOUR+5
功能:绝对选择指令XSEG外部绝对数据段xdata
XSEG [AT 绝对地址表达式]
USING指令通知汇编器使用8051的哪一个工作寄存器组。
格式:
USING
ORG指令用来改变汇编器的计数器,从而设定一个新的程序起始地址。
格式:
ORG
数据定义伪操作格式:
代码段(CSEG)
数据段(DESG)
外部段(XSEG)
功能段(FSEG)
位
表-8
如果在汇编中没有REG52。INC的包含文件,以下的程序出错:
NAME ASMTEST
$include(LOOKUPTABLE.INC)
;$include(REG52.INC)
?PR?TSEG?ASM_TEST SEGMENT CODE
PUBLIC ASM_LOOKUP_ROUTINE
RSEG ?PR?TSEG?ASM_TEST
using 0
ASM_LOOKUP_ROUTINE:
MOV
MOV
MOVC A , @A+DPTR
CLR
RET
END
错误提示是:ASM_TEST.ASM(15): error A45: UNDEFINED SYMBOL
在汇编程序中包含文件的定义
NAME ASMTEST
$include(LOOKUPTABLE.INC)
$include(REG52.INC)
?PR?TSEG?ASM_TEST SEGMENT CODE
PUBLIC ASM_LOOKUP_ROUTINE
RSEG ?PR?TSEG?ASM_TEST
using 0
ASM_LOOKUP_ROUTINE:
MOV
MOV
MOVC A , @A+DPTR
CLR
RET
END
如果两个include没有空行,会出现以下的错误提示:
assembling ASM_TEST.ASM...
ASM_TEST.ASM(3): error A34: , EXPECTED
ASM_TEST.ASM(3): error A34: , EXPECTED
ASM_TEST.ASM(3): error A34: , EXPECTED
ASM_TEST.ASM(3): error A9: SYNTAX ERROR
ASM_TEST.ASM(3): error A34: , EXPECTED
ASM_TEST.ASM(14): error A45: UNDEFINED SYMBOL
ASM_TEST.ASM - 6 Error(s), 0 Warning(s).
从C中访问位于汇编函数中的表格
TEST.C: 包含调用汇编函数的C程序。
ASM_TEST.ASM: 包含使用查表的汇编函数。
LOOKUPTABLE.INC: 包含查表。
每个文件的内容如下面所示。为了将查表定义在一个固定的地址0x1000,打开工程-选项(Project-Options),选择Target-BL51 Locate。在代码段(Code Segment)字段中输入段名(起始地址)。例如在本例中,你应该输入LOOKUPTABLE(0x1000)。对于你的程序,你可能需要从MAP文件(*.M51)中查找段名。
LOOKUPTABLE SETMENT CODE
RSEG LOOKUPTABLE
TABLE: DB 02H, 03H, 04H, 05H, 06H, 07H, 08H, 09H
NAME ASMTEST
$include(LOOKUPTABLE.INC)
?PR?TSEG?ASM_TEST SEGMENT CODE
PUBLIC ASM_LOOKUP_ROUTINE
RSEG ?PR?TSEG?ASM_TEST
using
ASM_LOOKUP_ROUTINE:
extern void ASM_LOOKUP_ROUTINE(void);
void main(void)
{
}