- 1、本文档共27页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
DSP28335—CMD文件解读(映射关系)剖析
DSP28335—CMD解读(1)在DSP28335工程文件里(不用BIOS产生CMD文件),手写CMD文件一般有两个,在RAM里调试时用的两个CMD文件分别为DSP2833x_Headers_nonBIOS.cmd和28335_RAM_lnk.cmd,烧写到flash里时用的两个CMD文件分别为DSP2833x_Headers_nonBIOS.cmd和F28335.cmd,其中DSP2833x_Headers_nonBIOS.cmd文件可以在所有工程文件中通用,主要作用是把外设寄存器产生的数据段映射到对应的存储空间,可以跟DSP2833x_GlobalVariableDefs.c文件对照一下看看。下面通过一个简单例子,比如向CpuTimer0Regs. TIM.all写数据,来解读一下CMD文件是如何把寄存器里的值准确映射到所在存储器的位置的。先在DSP2833x_GlobalVariableDefs.c文件里找到以下几行代码:#ifdef __cplusplus#pragma DATA_SECTION(CpuTimer0RegsFile)#else#pragma DATA_SECTION(CpuTimer0Regs,CpuTimer0RegsFile);#endifvolatile struct CPUTIMER_REGS CpuTimer0Regs;由上可知CpuTimer0Regs是一个结构体变量名(其定义在DSP2833x_CpuTimers.c文件里),通过预处理命令#pragma 为这个结构体定义了一个名称为CpuTimer0RegsFile的数据段。接着在DSP2833x_Headers_nonBIOS.cmd文件里找到如下代码:SECTIONS{???PieVectTableFile : PIE_VECT,???PAGE = 1???DevEmuRegsFile????: DEV_EMU,?????PAGE = 1???FlashRegsFile?????: FLASH_REGS,??PAGE = 1???CsmRegsFile???????: CSM,?????????PAGE = 1???AdcMirrorFile?????: ADC_MIRROR,??PAGE = 1???XintfRegsFile?????: XINTF,???????PAGE = 1???CpuTimer0RegsFile : CPU_TIMER0,??PAGE = 1}红字体代码的作用就是,通过SECTIONS伪指令把CpuTimer0RegsFile数据段装载到名称为CPU_TIMER0的存储空间。同样在DSP2833x_Headers_nonBIOS.cmd文件里找到如下代码:MEMORY{?PAGE 0:????PAGE 1:???????DEV_EMU?????: origin = 0x000880, length = 0x000180???????FLASH_REGS??: origin = 0x000A80, length = 0x000060???????CSM?????????: origin = 0x000AE0, length = 0x000010????????ADC_MIRROR??: origin = 0x000B00, length = 0x000010???????XINTF???????: origin = 0x000B20, length = 0x000020?????????CPU_TIMER0??: origin = 0x000C00, length = 0x000008????}??????CPU_TIMER0存储空间通过MEMORY伪指令指示了其起始地址和长度,也就等于间接确定了结构体CpuTimer0Regs的具体位置,所以通过以上几层映射关系,当向CpuTimer0Regs. TIM.all写数据时就可以准确的写入DSP内部寄存器所在的存储器的位置。由此看见,CMD的作用就是为程序代码和数据分配存储空间。本节先针对DSP2833x_Headers_nonBIOS.cmd文件做一下解读,后续再分别解读一下CMD用于调试和烧写时需要注意哪些问题。?另外有关volatile关键字的解读可参考/s/blog_762cf5f80101aosq.html?本文原创,与同样在努力学习DSP的你共享~?如有错,请指出~O(∩_∩)O谢谢在nonBIOS情况下,CMD文件不外乎就三个:28335_RAM_lnk.cmd(用于仿真调试)?、??DSP2833x_Headers_nonBIOS.cmd?、???F28335.cmd(用于flash烧写)。仿真调试时只用前两个,用于flash烧写
您可能关注的文档
- DOE讲义.ppt
- DOE试(实)验设计与方差设计培训讲义.doc
- DOS内部命令和批处理命令列表.doc
- Dom.ppt
- Dos操作系统与windowsXP下的命令操作.ppt
- 第1章微电子概论概述.ppt
- DMFC.ppt
- DQ-20型惰性气体发生装置.doc
- DPJ5(定时器).ppt
- 第1章油气藏中流体成分和性质.ppt
- 2024年度党员干部专题组织生活会个人新四各方面对照检查材料3篇合集.docx
- 2023年民主生活会领导干部个人发言3篇范文.docx
- 第二批主题教育专题组织生活会普通党员个人对照检查材料合集2篇.docx
- 学习以案促改党纪教育专题组织生活会个人对照检查材料两篇.docx
- 党员领导干部2023年民主生活会“六个方面”个人对照检查材料3篇范文.docx
- 党员干部“严守纪律规矩 加强作风建设”组织生活会个人对照检查材料集合篇.docx
- 2024班子防治统计造假专题民主生活会对照检查材料两篇范文.docx
- 2024公司机关党支部教育专题组织生活会个人对照检查材料两篇.docx
- 2023年度专题民主生活会个人对照新6个对照方面检查材料3篇文稿.docx
- 2024第二批主题教育专题组织生活会对照检查材料2篇文本.docx
文档评论(0)