上海理工大学 DSP讲义05

时间:2025-06-25

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字,全部文档内容请下载后查看。喜欢就下载吧 ……

上海理工大学 DSP讲义05.doc 将本文的Word文档下载到电脑

    精彩图片

    热门精选

    大家正在看

    × 游客快捷下载通道(下载后可以自由复制和排版)

    限时特价:7 元/份 原价:20元

    支付方式:

    开通VIP包月会员 特价:29元/月

    注:下载文档有可能“只有目录或者内容不全”等情况,请下载之前注意辨别,如果您已付费且无法下载或内容有问题,请联系我们协助你处理。
    微信:fanwen365 QQ:370150219