(TMS320C54X DSP原理及应用)第8章DSP芯片应用.ppt

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 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;

文档评论(0)

autohhh + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档