TMS320LF240x DSP结构原理及应用(第4章)
主讲教师: 杨海马
2006/2/12
第4章 DSP汇编语言1. 2. 3. 4.
汇编语言格式 伪指令 通用目标格式文件 CCS2000调试环境
2006/2/12
4.1 汇编语言格式
源语句的格式
[标号][:] 助记符 [操作数1,操作数2,…][;注释]1.
标号域 必须从源语句第一列开始写 冒号并不作为标号一部分,可省 若不用标号,第一字必须是空格或分号
2. 3. 4.
助记符 操作数 注释域 可以以;或*号开始
2006/2/12
4.2 伪指令1.
定义段的伪指令 .asect:创建具有绝对地址的初始化命名段。 .bss:为未初始化变量在.bss段内保留空间 .sect:定义初始化命令段并把后续代码或数据与该段联系
.text:标示.text段内代码部分.usect:在未初始化命名段内保留空间
2006/2/12
4.2 伪指令2.
初始化常数伪指令.bes和.space:在当前段中保留规定个数的位 .byte:把一个或多个8位数值放入当前连续的字中
.field:把单个数值放入当前字规定的位数中.float:和.bfloat:计算单精度32位IEEE格式浮点数并保存在当 前段两个连续字中,先存储低字,后高字;.bfloat保证定义的浮 点数不跨越页边界 .int和.word:将一个或多个16位值存储在当前段内的连续字中 .long和.blong:将32位数值放入当前段内连续的两个字块中。 先低位,后高位。 .string:把8位字符从一个或多个字符串放入当前段。
2006/2/12
4.2 伪指令
.bss 符号,子长[,块标志]
功能:变量定义伪指令,为变量在RAM中保留空间 1. 符号是一个必须的参数,指向.bss保留空间的第一个地址 2. 字长表示汇编器在.bss段内分配多少个字 举例:
.bss GPR1,2
.copy [“] 文件名 [”]; .include [“] 文件名 [”]
功能:从其他文件中读入源文件 1. 遇到此命令,会停止汇编当前源文件语句 举例: .include “F2407REGS.h”
2006/2/12
4.2 伪指令
.data
功能:数据段定义伪指令,用来存放数据表或者初始化变量 举例:
.data … .
.def 符号1
功能:定义全局变量 举例: .def _c_int02006/2/12
4.2 伪指令
[标号] .byte 数值1
功能:将一个或多个8位的值置入当前连续字中 举例: strx
.byte
10,-1,”abc”,”a”
.sect “段名”
功能:定义初始化命名段。 举例: .sect “.pvecs”
2006/2/12
4.2 伪指令
.string “字符串1”[,
]
功能:将字符串中的字符放入当前段中,每个字符占用1个字节 举例: str_ptr
.string
”abc”
.usect “段名”,字长
功能:为一个未命名段中的变量保留空间。功能类似于.bss。 特点:其他段指令(.data .sect .text)都终止当前段,并告诉汇 编器开始汇编到另一段,而.usect .bss不会影响当前段。
举例: ptr2006/2/12
.usect
“.var1”,100;在var1段保留100个字
4.2 伪指令
.text .end终止汇编器操作
功能:定义代码段
举例:
.data.byte 0Ah,0Bh .text ;汇编到.text段
LACC 03hptr array .usect “var1”,1 .usect “var1”,100
ADD 037h2006/2/12
;还在.text段
4.2 伪指令
总结1. 当汇编器遇到.text .data .sect 中的任何一条伪指令时,
将终止汇编当前段,而将随后的代码汇编到指定段。 2. 用.usect .sect这三种指令可以定义段,但在一个程序中 ,段名不能相同3. 汇编器为每一个段保留一个独立的程序计数器(SPC),汇
编器从0地址段开始处理每个段,同一个段均按照顺序存 放。
2006/2/12
4.3 通用目标格式文件COFF
三种基本的文件.ASM后缀,该文件头要写上:.include “F2407REGS.H ” .h头文件中定义DSP系统用到的一些寄存器映射地址。 命令文件名.CMD,该文件实现对程序存储器空间和数据存储器空间的分配 MEMORY伪指令用来表示实际存在的目标系统中且可被使用的存储器范围 ,每个存储器范围具有名字,起始地址,长度。 MEMORY { PAGE0: PAGE1: } SECTION伪指令作用:描述输入段怎样被组合到输出段… name1[(attr)]: origin=constant,length=constant; name1[(attr)]: origin=constant,length=constant;
2006/2/12
4.3 通用目标格式文件COFF
.cmd 文件
功能:实现程序存储器空间和数据存储器空间配 内容:该文件常用伪指令为MEMORY,SECTION1.
MEMORY伪指令语法:MEMORY{ PAGE 0: 存储器名: ORIGIN=常数,LENGTH=常数;程序 PAGE 1: 存储器名: ORIGIN=常数,LENGTH=常数;数据 PAGE 2: 存储器名: ORIGIN=常数,LENGTH=常数
} PAGE:定义存储器空间,最多255页
2006/2/12
4.3 通用目标格式文件COFF2. SECTIONS伪指令语法:SECTIONS{ 段名1 : load= allocation 段名2 : { } > allocation …… ;allocation装载地址 ;
} PAGE:定义存储器空间,最多255页
2006/2/12
4.3 通用目标格式文件COFF
例:LF2407_PM.cmd功能:定义LF2407芯片内程序、数据和IO空间MEMORY { PAGE0 PM: PVECS: PROG: SARAM_P: EX1_PM: B0_PM: PAGE1 REGS: BLK_B2: BLK_B0: BLK_B1: SARAM_D: PEREGS: EX2_DM: PAGE2 IO_EX: IO_IN: } SECTIONS { .vectors: .pvecs: .text: .bss: .data: } : ORIGIN=0000H, ORIGIN=0044H, ORIGIN=0150H, ORIGIN=8000H, ORIGIN=8800H, ORIGIN=FF00H, : ORIGIN=0000H, ORIGIN=0060H, ORIGIN=0200H, ORIGIN=0300H, ORIGIN=0800H, ORIGIN=7000H, ORIGIN=8000H, : ORIGIN=0000H, ORIGIN=0FFF0H, /*程序空间 LENGTH=0044H LENGTH=0100H LENGTH=7EAFH LENGTH=0800H LENGTH=7600H LENGTH=0100H /*数据空间 LENGTH=0060H LENGTH=0020H LENGTH=0100H LENGTH=0100H LENGTH=0800H …… 此处隐藏:1442字,全部文档内容请下载后查看。喜欢就下载吧 ……