- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
第8章 DSP芯片应用 8.1 引 言 前面几章我们介绍了DSP芯片的原理以及CCS开发工具。TMS320C5409是目前性能价格比较高的一种定点DSP芯片,已经在很多领域得到了广泛的应用。本章以TMS320C5409为例,介绍DSP应用系统的设计、调试和开发过程。 8.2 DSP芯片C语言开发简介8.2.1 TMS320C54x C/C++编译器支持的数据类型 表8-1列出了TMS320C54x C/C++编译器支持的数据类型的大小、表示形式和表示范围,这些数据类型在float.h和limits.h中定义。在C语言开发的过程中,采用合适的数据类型对于系统的正确运行有着极为重要的意义。 8.2.2 C语言的数据访问方法 1.DSP片内寄存器的访问 DSP片内寄存器在C语言中一般采用指针方式来访问,常用的方法是将DSP寄存器地址的列表定义在头文件(如reg.h)中。DSP寄存器地址定义的形式为宏,如下所示: #define IMR (volatile unsigned int *)0x0000 #define IFR (volatile unsigned int *)0x0001 #define ST0 (volatile unsigned int *)0x0006 #define ST1 (volatile unsigned int *)0x0007 #define AL (volatile unsigned int *)0x0008 #define AH (volatile unsigned int *)0x0009 #define AG (volatile unsigned int *)0x000A #define BL (volatile unsigned int *)0x000B #define BH (volatile unsigned int *)0x000C #define BG (volatile unsigned int *)0x000D #define T (volatile unsigned int *)0x000E #define TRN (volatile unsigned int *)0x000F #define AR0 (volatile unsigned int *)0x0010 #define AR1 (volatile unsigned int *)0x0011 #define AR2 (volatile unsigned int *)0x0012 #define SP (volatile unsigned int *)0x0018 #define BK (volatile unsigned int *)0x0019 #define BRC (volatile unsigned int *)0x001A #define RSA (volatile unsigned int *)0x001B #define REA (volatile unsigned int *)0x001C #define PMST (volatile unsigned int *)0x001D #define XPC (volatile unsigned int *)0x001E 在主程序中,若要读出或者写入一个特定的寄存器,就要对相应的指针进行操作。下例通过指针操作对SWWSR和BSCR进行初始化。 #define SWWSR (volatile unsigned int *)0x0028 #define BSCR (volatile unsigned int *)0x0029 int func (?) { *SWWSR = 0x2000; *BSCR = 0x0000; } 2.DSP内部和外部存储器的访问 同DSP片内寄存器的访问相类似,对存储器的访问也采用指针方式来进行。下例通过指针操作对内部存储器单元0x3000和外部存储器单元0x8FFF进行操作。 int *data1 = 0x3000; /*内部存储器单元*/ int *data2= 0x8FFF; /*外部存储器单元*/ int func (?) { * data1 = 2000;
您可能关注的文档
最近下载
- 长期卧床并发症.ppt VIP
- 《第4课 记录数据讲诀窍》精品教案.docx VIP
- 高中通用技术作品设计报告书.docx VIP
- 柔性悬臂梁振动主动控制的实验与优化策略研究.docx VIP
- 现代西班牙语第一册(董燕生)练习答案及译文.docx VIP
- PE室外给水管道安装施工组织设计.doc VIP
- 被动防护网施工专项方案.docx VIP
- 2025年国培卫健、粤医云(公卫)6月基层公共卫生服务能力提升项目参考答案.docx VIP
- 2024年秋季高一入学分班考试模拟历史(新高考通用考试版).docx VIP
- 义务教育版(2024)四年级信息科技 第3课 寻找可靠数据源 教案.docx VIP
文档评论(0)