您好,欢迎访问三七文档
当前位置:首页 > 商业/管理/HR > 企业文化 > TI_DSP软件开发工具
1数字信号处理器DigitalSignalProcessorTIDSP软件开发工具CCS(CodeComposerStudio)的使用21CCS集成环境IDE(IntegratedDevelopmentEnvironment)不仅仅是代码生成工具–具备基本调试功能,还具备实时分析的能力–支持整个软件开发过程:–设计–代码生成(项目建立,源程序编写,配置文件)–调试(语法检查,探测点,日志log功能)–实时分析(实时调试,实时状态显示,任务切换跟踪)实时(RealTime)是DSP的灵魂31.1CCS集成环境IDE41.1CCS集成环境IDE的组成51.1CCS集成环境IDE的组成包括主机和目标系统两部分CCS首先是作为代码生成工具,作为代码生成工具有这样一些输入:配置工具产生的配置文件,DSP/BIOSAPI的库函数。自己的程序文件.c,.h,生成可执行文件主机方:最底层是JTAG,上面是调试器,再上面是CCS的各种插件,包括DSP/BIOS插件(实时调试),还用RTDX(实时数据交换)目标系统一方:最底层是硬件和JTAG,向上是DSP/BIOS实时操作系统(这是可选的也可以没有操作系统,完全自己管理),再向上是应用程序.61.2CCS代码生成工具流图71.2CCS代码生成工具流图每个白色框代表一种代码生成工具,条纹框是它的输入文件类型比如:C编译器(C程序),汇编优化器(线性汇编程序),汇编器(汇编),建库工具,连接器最后可执行文件由调试器加载目标系统以上的工具时常用和通用的.其它的工具hexconversionutility16进制转换工具,把COFF转换为其它格式文件写到EPROM中cross-referencelister产生交叉参考列表,它列出定义的symbol,定义symbol的行,以及用到symbol的位置(行),还有symbol的类型,编译和连接时分配给symbol的值.absolutelister,产生连接后的coff文件的绝对地址列表Archiver:文档管理工具—打包.8C源程序宏源文件文档管理器宏文件库C编译器汇编源程序代数式指令翻译器汇编源程序汇编器建库实用程序支持运行的库函数COFF目标文件链接器可执行的COFF文件交叉应用列表程序PC机及DSP调试工具'C54x绝对列表程序EPROM编程器十六进制转换程序十六进制转换程序文档管理器CCS代码生成工具流图91.3CCS软件TI公司耗资近2亿美元CCS2.0ForC5000系列CCS2.0ForC6000系列CCS2.0ForDSK(DeveloperStartKit,初学者开发套件)CCS2.1升级包界面(1)111.3.1CCS2.0界面(1)CCS提供一个类似VC++的集成开发环境,使用比较方便有菜单,工具条,左边是项目窗口,右边是代码编辑窗口(和图形显示窗口),下边是编译器编译结果,和变量显示窗口,和寄存器观察窗口.Project工具条:编译,连接,设置三种点:断点、探点(probe)、时间分析点(profile)调试工具条:程序step运行(4种),连续运行(2种),查看变量、寄存器、存储器,调用堆栈,反汇编窗口Standard工具条:新建,保存,打开,查找,剪贴,Findinfiles功能比较好用编辑工具条:mark(大小括号)查找,缩进(outdent),书签121.3.1CCS2.0界面(2)CCS提供一些类似VC的代码编辑功能–语法高亮显示,自动缩近,文字查找等等•原程序和反汇编同时显示(逐条语句对应,但优化后是模块对应)131.3.2CCS2.0项目管理应用程序按项目来管理,按层次以图形化的方式显示–项目文件(.mak)–CMD文件–.h头文件–.lib库文件–.c源程序141.3.3CCS图形化设置各种编译选项(汇编器选项,连接器选项等)通过图形化方式来设置,不需要手工添加选项151.3.3CCS2.0图形化设置161.3.4CCS2.0调试功能(1)断点设置:多种step方法:singlestep(stepinto);stepover;stepout;runtocursor运行到断点处自动更新窗口观察和编辑变量、寄存器和存储器调用堆栈(callstack),显示函数调用层次关系.补充上电时的工作:$ASM$(simulator,硬件上电复位RESET中断服务程序)c_int00_auto_init(C变量初始化)返回后c_int00调main()函数….Main()完成后,c_int00调exit(1),做一些清楚工作,如关闭打开的文件.exit在调abort,无限循环利用探点(probepoint)流入流出(streaminandout)存储器数据171.3.4CCS2.0调试功能(2)图形化显示数据一维数据,二维图象,眼图等代码剖析(Profile)计算代码运行时间181.3.4CCS2.0调试功能(3)191.3.5CCS2.0DSP/BIOS操作系统DSP/BIOS是一个实时操作系统RTOS提供通常的RTOS的功能(任务调度,任务间通讯)提供驱动程序模型,层次化地设计应用程序DSP/BIOS以CCS插件的形式提供一些实时分析工具程序跟踪:观察任务的调度、切换性能监视:观察CPU的负载状态统计:对事件做统计提供RTDX(实时数据交换),不打断DSP运行的情况下实现主机和DSP的数据交换201.3.6CCS2.0RTDX(1)RTDX,即Real-timeDataExchange提供了一种实时,连续的观测手段,不打断DSP运行(数据可连续观测,也可传回来存储后观测)不打断DSP运行的情况下,主机和DSP间传递数据回传到主机的数据可以在“OLE自动化客户”中显示211.3.6CCS2.0RTDX(2)包括Host方和Target方Target方编程接口RTDXtargetAPIHost方编程接口RTDXCOMAPI(组件对象模型COM是windows下一种编程技术)221.3.7CCS2.0界面(2)主机方的RTDX库是和CCS集成在一起的主机一方有一个函数接口,目标方DSP上也有一个函数接口主机应用程序通过COMAPI发送数据到DSP,或接收数据,应用程序可以按自己的方式来显示数据,RTDX可以脱离DSP/BIOS使用,给用户灵活性下一张图是一个例子,用LabView作一个显示界面,LabView调用RTDXAPI得到DSP传来的数据231.3.7CCS2.0界面(2)这是一个fir滤波的例子.HOST原始数据(显示,左上方)(RTDX)dspfilter(RTDX)HOST(显示,左下方)左上方:原始的数据左下方:滤波后数据右上方:dsp的fir滤波后的信号(左下方显示)的功率谱右下方:Labview对原始信号进行fir滤波后的信号的功率谱(对比)241.3.8CCS2.0的文件与环境变量.mak.lib.obj.out.wks(.wks保存当前CCS中的设置:打开的变量窗口,显示的图形。方便,快捷。)可编辑文件:.c.asm.h.cmd(.sa)三个环境变量:C6X_A_DIR,C6X_C_DIR,PATH25CCS小结CCS不仅仅是代码生成工具,对软件开发的各个阶段都有支持提供底层实时操作系统DSP/BIOS提供RTDX新的实时调试手段,与CCS集成,不需要自己添加额外的用于调试的硬件(但是速率比较低)262简单程序开发流程(1)建立项目ProjectNew选择一个目录,生成一个项目文件test.mak272简单程序开发流程(2)添加文件ProjectAddFilestoProject…添加文件(.c,.lib,.cmd,.sa,.asm…)1)vectors.asm包含汇编指令处理reset中断服务程序,跳转到Cc的入口.c_int00.2)扫描dependence:.h282简单程序开发流程(3)代码编辑双击项目窗口的文件名,开始编辑源程序292简单程序开发流程(4)设置编译选项ProjectOptions302简单程序开发流程(4)设置编译选项312简单程序开发流程(4)设置编译选项322简单程序开发流程(5)Build,DebugProjectBuild332简单程序开发流程(6)Debug加载程序FileLoadProgram…设置断点,通过WatchWindow观察变量单步执行黄色条代表当前执行到那条语句紫色条代表断点位置342简单程序开发流程(7)Profile(剖析)ProfileEnableClock设置profilepoint(绿色条)每个绿色条在窗口中对应有一行统计数字,用来统计profilepoint(绿色条)之间的时钟数调试器内部有时钟计数,最后查看每一个观测点的运行时间356一些调试经验(1)1)一次新增的调试代码不能过长.2)防御式编程:如通信中的等待时间不能过长3)对感兴趣的事件做记录:中断发生次数,等待超时计数4)CCS的运行中添加断点和运行前添加断点5)窗口刷新的影响:大量的数据更新回影响底层的时序6)随时关系程序运行时间,过长会影响时序,设置计算器.366一些调试经验(2)7)注意数组的越界和指针的使用:也是其它编程通常的错误,这个错误可能其它部分修改,尤其对硬件计数器的修改导致各种错误,调试方法:递进增加代码,看map文件,了解前后关系8)多用服务中断程序,但中断服务程序不能带参数,只有通过全局变量传递值,所以全局变量常用.9)volatile关键字.背景中修改,不被优化掉.10)关于中断嵌套:长中断被频繁中断中断,允许嵌套是,关闭自身,即不允许重入.原因在于打乱时序关系.11)观察中断间的同步:通过设全局变量和记录数组观察嵌套中断发生时被嵌套中断程序的运行状态37关于TIDSP软件开发的学习1)CCS只是一部分-《Tutorial》教程入手(100页左右)。其它的用到的再查用户使用手册User’sGuide2)C的运行环境:C6000的写在《优化Ccompileruser’sguide》中7、8章。包括扩充的C的关键字,编程伪指令,寄存器调用规则,存储器模式,C语言与汇编语言的接口;3)CPU和汇编语言:耗时长的部分用汇编写。C6000写线性汇编要了解CPU结构。4)硬件知识:其实是不应该省略的。难点:中断,DMA,IO口。中断的实现过程,花点时间最后了解到clk级。5)参考书:要真正开发应用还要读英文材料。《DSP集成开发与应用实例》,张雄伟,电子工业,2002.CCS介绍比较全面38CCSTutorialHelp-TutorialTI公司的推广活动课程截图41Thanksforyourtime!
本文标题:TI_DSP软件开发工具
链接地址:https://www.777doc.com/doc-2863105 .html