第4章dsp程序编写和调试环境简介_第1页
第4章dsp程序编写和调试环境简介_第2页
第4章dsp程序编写和调试环境简介_第3页
第4章dsp程序编写和调试环境简介_第4页
第4章dsp程序编写和调试环境简介_第5页
已阅读5页,还剩33页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

第4章:程序编写和调试环境简介,4.1程序的编写4.2调试环境代码编译器CC简介4.3调试一个程序的简单步骤4.4头文件和命令文件,4.1程序的编写,汇编伪指令分成7类(根据功能):定义段的伪指令;初始化常数的伪指令;调准段程序计数器的伪指令;引用其他文件的伪指令;条件汇编伪指令;在汇编时定义符号的伪指令;执行其他功能的伪指令。,4.1程序的编写,1.段定义伪指令作用:把汇编语言程序的各个部分划分在适当的段中。.asect创建具有绝对地址的初始化命名段;.bss为未初始化的变量保留空间;.sect定义已初始化的带命名段,其后的数据存入该段;.text该段包含了可执行的代码;.usect在一个未初始化的有命名的段中为变量保留空间。.data通常包含了初始化的数据;段是通过叠加方式来建立的。例如在汇编器第一次遇到.data伪指令时,data指令后面的语句都被汇编在.data段中(直到汇编器遇到.text和.sect伪指令为止)。如果后来又在其他的段中遇到.data指令,其后的语句继续加到.data段中。这样虽然程序中是多个.data段分散在各处,但汇编器只创建一个.data段,它可以连续地被分配到内存中。,4.1程序的编写,2.常数初始化伪指令.bes和.space在当前段中保留特点的位。汇编器用0填充这些保留位。用户可以通过把位数乘16来保留规定的字数。当使用.space的标号时,指向保留位的第一个字;当使用.bes标号时,指向保留位的最后一个字。.byte把一个或多个8位的值放入当前段的连续字中。该指令类似于.word,不同之处在于.word中的每个值的宽度限制为16位。.field将单个数值置入当前字规定的位数中。.float和.bfloat计算以IEEE格式表示的单精度(32位)浮点数,并存放在当前段的连续字中,高位先存。.float能自动按域的边界排列,.bfloat不能。.int和.word把一个或多个16位数存放到当前段的连续字中。.int为无符号整型量,.word为带符号整型量。.long和.blong把32位数存放到当前段连续的两个字中,高位字先存。.long能自动按长字的边界排列,.blong却不能。.string把8位的字符从一个或多个字符串中传送到当前段中。,4.1程序的编写,3.段程序计数器(SPC)定位指令.align使SPC对准1字(16位)128字的边界,这保证了紧接着该指令的代码从一个整字或页的边界开始。如果SPC已经定位于选定的边界,它就不会增加了。.align伪指令的操作数必须等于20216之间的一个2的幂值(尽管超过27的值没有意义)。不同的操作数代表了不同的边界定位要求。操作数为1是让SPC对准字边界;操作数为2是让SPC对准长字(偶地址)边界;操作数为128是让SPC对准页边界;不带操作数时,其默认值为128,即对准页边界。.even调准SPC,使其指向下一个完整字。在使用.field伪指令之后,用户应当使用.even。如果.field指令未填满一个字,那么.even指令将使汇编器填满全字,并把未用的位填0。,4.1程序的编写,4.引用其他文件的伪指令.copy/.include伪指令告诉汇编器开始从其他文件中读源语句。当汇编读完以后,继续从当前文件中读源语句。从.copy文件中读的语句会打印在列表中,而从.include文件中读的语句不会打印在列表中。.def确认一个在当前模块中定义的且能被其他模块使用的符号,汇编器把这个符号存入符号表中。.ref确认一个在当前模块中使用但在其他段中定义的符号。汇编器把这个符号标注成一个未定义的外部符号,且把它装入目标符号表中,以便链接器能还原它的定义。.global表明一个外部符号,使其他模块在连接时可以使用。如果在当前段定义了该符号,那么该符号就可以被其他模块使用,与.def功能相同;如果在当前段没有定义该符号,则使用了其他模块定义的符号,与.ref功能相同。一个未定义的全局符号只有当它在程序中使用的时候,链接器才对其进行处理。,4.1程序的编写,5.控制条件汇编的伪指令.if/.elseif/.else/.endif这些指令告诉汇编器,根据表达式的值条件汇编一块代码。.if表示一个条件块的开始,如果条件为真就汇编紧接着的代码;.elseif是表示如果.if的条件为假,而.elseif的条件为真,就汇编紧接着的代码;.endif结束该条件块。.loop/.break/.endloop告诉汇编器按照表达式的值循环汇编一块代码。.loop标注一块循环代码的开始;.break告诉汇编器当表达式为假时,继续循环汇编,当表达式为真时,立刻转到.endloop后的代码去执行;.endloop标注一个可循环块的末尾。,4.1程序的编写,6.在汇编时定义符号的伪指令作用:汇编时的定义符号指令是使有意义的符号名与常数值或字符串相等同。.asg规定一个字符串与一个替代符号相等,并将其存放在替代符号表中。当汇编器遇到一个替代符号,就用对应的字符串来代替这个符号。替代符号可以重新定义。.eval计算一个表达式的值并把结果传送到与一个替代符号等同的字符串中。该指令在处理计数器时非常有用。.label定义一个专门的符号以表示当前段内装入时的地址,而不是运行时的地址。当段在一个地址装载在另一个地址处运行时,该指令特别有用。.set/.equ把一个常数值等效成一个符号,存放在符号表中,且不能被清除。,4.1程序的编写,7.其他方面的汇编伪指令.end结束汇编。它是一个程序的最后一个源语句。.version决定指令所运行的处理器。每一种C54x芯片都有自己的值。,4.1程序的编写,3种基本的文件:汇编语言文件后缀为.ASM,书写该文件所用指令为LF2407支持的汇编语言指令。该程序中实现DSP要完成的功能。通常在该文件的最开始写上.include“F2407REGS.H”,表明包含了F2407REGS.H头文件里定义的一些寄存器。头文件后缀为.H,定义DSP系统用到的一些寄存器映射地址和用户用到的常量和用户自定义的寄存器。命令文件(.CMD)后缀为.CMD,实现对程序存储器空间和数据存储器空间的分配。该文件常用的伪指令:MEMORY和SECTIONS。,4.1程序的编写,MEMORY伪指令用来标示实际存在目标系统中且可被使用的存储器范围,每个存储器范围具有名字、起始地址和长度。语法如下;MEMORYPAGE0:namel(attr):origin=constant,length=constant;PAGEn:namen(attr):origin=constant,length=constant;PAGE标示存储器空间。用户规定可以多达255页,通常PAGE0规定程序存储器,PAGE1规定数据存储器。name命名存储器。attr规定与已命名范围有关的14个属性。R可读;W可写;X可执行;I可初始化origin规定存储器范围的起始地址。length规定存储器范围的长度。,4.1程序的编写,SECTIONS伪指令描述输入段怎样被组合到输出段内;在可执行程序内定义输出段;规定在存储器内何处放置输出段;允许重命名输出段。语法如下;SECTIONSname:property,property,property,name:property,property,property,每一个以name开始的段的规格说明定义了一个输出段。在段名后是特性列表,定义段的内容及分配方式。可能具有的特性如下:装载位置规定段将被装载到存储器何处;运行位置段将在存储器何处运行;输入段组成输出段的输入段;段类型特定段类型的标志;填充值用于填充未初始化空位的数值,4.2调试环境代码编译器CC简介,本节要求:了解CCS开发环境具有的功能,能够操作CCS的窗口、菜单和工具条。掌握CCS工程管理的概念,能够完成简单程序的编辑、汇编、连接和调试。CCS是TI公司DSP软件的集成开发环境(IDE),本节以CCS2.0为参照讲述。,4.2调试环境代码编译器CC简介,CCS集成开发环境简介Windows下工作,类似于VC+的集成开发环境;采用图形接口界面,有编辑工具和工程管理工具;它将汇编器、链接器、C/C+编译器、建库工具等集成在一个统一的开发平台中;CCS所集成的代码调试工具具有各种调试功能,能对TMS320系列DSP进行指令级的仿真和可视化的实时数据分析。丰富的输入/出库函数和信号处理库函数。,4.2调试环境代码编译器CC简介,CCS2.0系统的安装用来对该编译器的运行环境进行配置。程序调试仿真环境。,4.2调试环境代码编译器CC简介,系统配置原因:为使CCSIDE能工作在不同的硬件或仿真目标上。步骤:双击桌面上的SetupCCS2(C2000)图标,启动CCS设置。在弹出对话框中单击“Clear”按钮,清除以前定义的配置。从列出的可供选择的配置文件中,选择能与使用的目标系统相匹配的配置文件。单击加入系统配置按钮,将所选中的配置文件输入到CCS设置窗口当前正在创建的系统配置中。单击“FileSave(保存)”按钮,将配置保存在系统寄存器中。当完成CCS配置后,单击“FileExit”按钮,退出CCSSetup。,4.2调试环境代码编译器CC简介,1.CCS的窗口双击桌面上CCS2(C2000)图标,启动CCSIDE显示CCS主界面。,用来组织用户的若干程序并由此构成一个项目,用户可以从工程列表中选中需要编辑和调试的特定程序。,帮助用户查看机器指令,查找错误,用户既可以编辑程序,又可以设置断点和探针,并调试程序。,可以根据用户需要显示数据。,查看、编辑内存和寄存器。,查看、编辑内存和寄存器。,显示对工程进行编译,汇编和连接时的一些状态信息,如果在编译、汇编和连接过程中发现错误,则该窗口显示出错误类型和错误位置。,主菜单:用户可以通过条目来管理各窗口。,4.2调试环境代码编译器CC简介,2、CCS的菜单File(文件):文件管理,载入执行程序、符号及数据,文件输入输出等Edit(编辑):文件及变量编辑,如剪贴、撤消、字符串查找等View(查看):工具条显示设置,内存、寄存器和图形显示等Project(工程):工程管理(新建、打开、关闭及添加文件等)、编译、构建工程等Debug(调试):断点、探针设置,单步执行、复位等Profiler(性能):性能菜单,包括时钟和性能断点设置等,4.2调试环境代码编译器CC简介,2、CCS的菜单GEL(扩展功能):利用通用扩展语言设置扩展功能Option(选项):选项设置,设置字体、颜色、键盘属性、动画速度、内存映射等Tools(工具):包括引脚连接、端口连接、命令窗口、连接设置等DSP/BIOS(实时分析工具):用来辅助CCS环境实现程序实时调试Windows(窗口):窗口管理,包括窗口排列、窗口列表等Help(帮助):CCS在线帮助菜单,包括用户手册、入门指南等,4.2调试环境代码编译器CC简介,Project菜单(工程文件被存盘为*.pjt文件)New新建一个工程,将该工程保存至新建工程的文件夹里。AddFilestoProject工程中支持C源文件(*.C)、汇编源文件(*.ASM)、库文件(*.OBJ、*.LIB)和链接命令文件(*.CMD)。工程管理会自动加入头文件和include引用的文件,不允许添入其他类型的文件。CompileFile对C或汇编源文件进行编译。Biuld对工程进行编译、汇编和连接,生成可执行文件.OUT。RebuiledAll对工程中所有文件重新编译并链接生成输出文件。StopBuild停止对工程的编译、汇编和连接。BiuldOptions用来设定编译器、汇编器和链接器的参数,通常采用默认设置。RecentProjectFiles显示最近打开过的工程。,4.2调试环境代码编译器CC简介,View菜单Dis-Assembly观察汇编程序窗口;可在此窗口中对汇编程序进行修改。Memory观察存储窗口;可选择观察的存储器类型和存储器的起始地址。CPURegisters考察调试过程中CPU寄存器的和各个状态位的变化情况。WatchWindow观察调试过程中的变量,C表达式,地址和寄存器的值。MixedSourceandASM在调试过程中即观察C程序又观察汇编程序。,4.2调试环境代码编译器CC简介,Debug菜单Breakpoints将光标放在要设置断点的程序处可在程序中设置断点;程序运行到断点处自动停止。ProbePoints在程序中设置探测点。StepInto单步执行程序并进入调用的子程序。StepOver单步执行程序但不进入调用的子程序或中断服务程序。StepOut跳出子程序。Run执行程序到断点、探测点或用户中断。Halt用来停止程序的执行。ResetDSP对处理器进行复位。Restart将程序指针指向程序的起始地址,从程序最开始处执行程序。提示:善用CCS的Help,4.2调试环境代码编译器CC简介,3、CCS的工具栏StandardToolbar:包括新建、打开、保存、剪切、复制、粘贴、取消、恢复、查找、打印和帮助等ProjectToolbar:包括选择当前工程、编译文件、设置和移去断点/ProbePoint等功能。EditToolbar:提供一些常用的查找和设置标签命令。GELToolbar:提供了执行GEL函数的一种快捷方法。ASM/SourceSteppingToolbar:提供了单步调试C或汇编源程序的方法TargetControlToolbar:提供了目标程序控制的一些工具DebugWindowToolbar:提供了调试窗口工具,4.3调试一个程序的简单步骤,CCS的工程管理CCS对程序采用工程(Project)的集成管理方法。工程保持并跟踪在生成目标程序或库过程中的所有信息。典型工程文件记录的信息源程序文件名和目标库;编译器、汇编器和链接器选项;头文件;创建和管理工程工程的创建、打开和关闭(ProjectNew/Open/Close)使用工程观察窗口(单击工程文件夹、工程名(*.pjt)和各个文件夹上的“+/”号即可)添加文件到工程(ProjectAddFilestoProject)从工程中删除文件(RemovefromProject),4.3调试一个程序的简单步骤,调试(1)装载可执行程序FileLoadProgram(2)复位(CCS提供4种方法)ResetDSP:DebugResetDSP命令初始化所有R并停止运行程序。LoadKernel:LodeKernel命令重新装入DSP核Why?若用户使用一基于核的调试器,则DSP核应负责主机的通信。如果DSP核被破坏,则设备驱动程序将无法与目标板通信。Restart:DebugRestart命令将PC恢复到当前载入程序的入口地址,但不执行当前程序。Gomain:DebugGomain命令提供了一种快速运行用户应用程序的方法。(在主程序入口处设置临时断点,然后开始执行。当程序被暂停或遇到一个断点时,临时断点被删除。),4.3调试一个程序的简单步骤,调试(3)程序执行方式单步执行操作单步进入:DebugStepInto:每操作一次,执行一条指令;单步执行:DebugStepOver:每操作一次,执行一条指令(函数,子程序看作一条);单步调出:DebugStepOut:从子程序跳出;执行到光标处:DebugRuntoCursor:程序运行到光标所在语句。连续运行操作(实时运行)运行程序:DebugRun:从当前PC所指位置开始执行到结束或断点;停止程序:DebugHalt:暂停程序的执行;自由运行:DebugRunfree:全速执行用户程序,忽略所有断点。,4.3调试一个程序的简单步骤,调试(3)程序执行方式断点运行程序(动画)在执行各个命令前应当预先设置好程序断点,每按一次按钮,从当前程序位置执行到所有遇到的第一个断点,。命令:Debuganimate;断点设置:使用对话框;采用工程工具条“设置断点”按钮探针(probe)断点:CCS在源程序某条语句上设置的一种断点。每个探针断点都有相应的属性(用户设置)用来与一个文件的读/写相关联。用户程序运行到探针断点所在语句时,自动读入数据或将计算结果输出到某个文件中。,4.3调试一个程序的简单步骤,调试(4)存储器、寄存器、变量的操作存储器:拷贝数据块/填充数据块/察看/编辑内存寄存器:显示寄存器/编辑寄存器变量:用观察窗口查看变量/编辑变量(5)数据输入/输出利用数据读入/写出功能命令:FileData(Lode/Save)用途:偶尔的手工读入/写出场合利用探针功能:适用于自动调入和输出数据场合。,4.4CCS工程组成,(1).pjt文件CCS工程文件。在CC中,工程文件的扩展名为.mak。(2).lib文件CCS运行支持库。(3).h文件头文件。(4).c文件C源文件。(5).asm文件汇编语言源文件。(6).cmd文件链接命令文件。(7).obj文件目标文件,COFF格式。(8).out文件可执行文件,COFF格式。,4.4CCS工程组成,头文件CCS工程中的头文件与其它基于C语言的开发环境中的头文件基本相同,主要是用来定义工程中的常量和数据结构。为了提高开发效率,开发人员往往会将DSP片内的控制寄存器定义写成一个头文件,这样在各个基于相同型号DSP的开发中,可以共享这个定义控制寄存器的头文件。,4.4CCS工程组成,中断向量定义与传统的单片机类似,DSP的中断也可以采用查询和回调两种方式来处理。如果采用回调方式处理,其实现方式是在中断向量地址处放置一个跳转语句,跳转到相应的中断处理函数。在CCS中,需要编写一个.asm文件,定义所有的中断向量。,4.4CCS工程组成,链接命令文件CCS的链接器也可以有很多选项,如-l、-stack、-o等,另外在链接器选项中还应该将开发中的逻辑段与目标系统存储器物理地址的对应关系定义清楚。这些链接器选项的实现有三种方式:利用命令行实现:即在命令行中link命令后面将所有的链接选项写明,使链接器按照选项设定去工作。利用工程选项菜单实现:在CCS菜单ProjectBuildOptionsLinker页面中可以对链接器选项进行设置。利用链接命令文件实现:即编写一个链接命令文件,将所有链接选项写在文件中,并将此文件加入工程。链接命令文件实际上就是一个ASCII码文件,扩展名是.cmd。推荐使用工程选项菜单和链接命令文件的方式来实现链接器选

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论