基于CPLD和DSP的高速外部接口_第1页
基于CPLD和DSP的高速外部接口_第2页
基于CPLD和DSP的高速外部接口_第3页
基于CPLD和DSP的高速外部接口_第4页
基于CPLD和DSP的高速外部接口_第5页
免费预览已结束,剩余1页可下载查看

下载本文档

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

文档简介

1、基于CPLD和DSP的高速外部接口周遐1金瑞2钟思佳3李瑞锋4(昆明冶金高等专科学校自动化与电力学院云南昆明650033)摘要:在了解CPLD(ComplexProgrammableLogicDevices)和DSP(digitalsignalprocessor)的基础上,利用CPLD强大的逻辑功能和DSP的高速运算能力,实现对外部接口的高速无缝连接,以提高DSP访问外设的速率,充分发挥其高速运算能力。关键词:DSP;CPLD;TMS320C6201;QuartusII;接口BasedonCPLDandDSPhighspeedexteriorconnectionZhouXiaJinRuiZho

2、ngSi-jiaLIrui-feng(ThefacultyofAutomationandElectricpower,kunmingMetallurgycollege,Kunming,650033,China)Abstract:ThisarticleinunderstandsCPLDandintheDSPfoundation,UsingCPLDformidablelogicalfunctionandDSPhighspeedoperationalcapability,Realizationtoexteriorconnectionhighspeedseamlessconnection,Enhance

3、stheDSPvisitperipheralthespeed,displaysitshighspeedoperationalcapabilityfully.Keywords:DSPCPLDTMS320C6201QuartusIIConnection0引言DSP虽然在算法处理上功能很强大,但其控制功能是非常弱的;而CPLD本身并不具有内部寄存器,虽然可以用CPLD的逻辑块来实现寄存器,但是这将耗费大量的CPLD资源。然而,CPLD的强项在于时序和逻辑控制。本文介绍的逻辑控制系统就是充分利用了DSP和CPLD的优点,将多个A/D转换单元通过CPLD映射到DSP的I/O地址空间,利用CPLD屏蔽A/

4、D转换的初始化以及读写操作过程,使得DSP可以透过CPLD这个"黑匣子"快速、准确地从外设中获取数据。1 CLPD与DSP简介1.1 CLPD简介复杂可编程控制器件(CPLDComplexProgrammableLogicDevices)是随着半导体工艺不断完善、用户对器件集成度要求不断提高的形势下所发展起来的产物。当前CPLD的规模已从取代PAL和GAL的500门以下的芯片系列,发展到5000门以上,现有上百万门的CPLD芯片系列。随着工艺水平的提高,在增加器件容量的同时,为提高芯片的利用率和工作频率,CPLD从内部结构上作了许多改进,出现了多种不同的形式,功能更加齐全,

5、应用不断扩展。CPLD是由三大部分组成的。一个二维的逻辑块阵列,构成了PLD器件的逻辑组成核心。输入/输出块。连接逻辑块的互连资源,连线资源由各种长度的连线线段组成,其中也有一些可编程的连接开关,它们用于逻辑块之间、逻辑块与输入/输出块之间的连接。1.2 DSP简介DSPs的速度较快,要求译码的速度也必须较快。利用小规模逻辑器件译码的方式已不能满足DSP系统的要求。同时,DSP系统中经常需要外部快速部件的配合,这些部件往往是专门的电路,可由可编程器件实现。CPLD的时序严格、速度较快、可编程性好,非常适1周遐(1959),男,1982年毕业于云南大学,高级工程师副教授研究方向:电子技术、通信技

6、术IOdMElUrh红色:连线资源T1*VfBIt相斗片胃舟W1F<AF1.1ED!ft中KI本行口安雷*会醴里.SiSkRAKtLTrrvED4中那卑打口匚日士口1CPI.'图1典型的PLD的框图合于实现译码和专门电路。本文的介绍的是美国司的TMS320C6201芯片。内部包含三个主要部分TMS320C6201的硬件体系结构。图2TMS320C6201的硬件体系结构TI(TexasInstrument,德州仪器,简称TI)公:CPU、存储器和辅助资源。图给出了2设计原理设计思路首先构建系统框架如图3所示:TH6BI;EJ.1JFBusDrtwtfFLASHI,I_II.Ifif

7、iOEMIFccMUMKtf<ZJAL2QJ2T)Bl.L图3系统框袈由图可以看见,在DSP上连接了若干外设,只要知道外设的地址,通过地址映射的方法,DSP可以方便的访问这些外设。以下为MAP1方式下的DSP内存映象图,未列的空间为没有定义。起始地址#长度用途备注0x0000,0000#10000内部程序存贮器(IPM)64KB0x0040,0000#80000SBSRAM512KB0x140,0000#0x200000FLASH2MB0x160,0000#0x80000控制寄存器定义0x168,0000#0x80000为用户保留的异步接口空间UCE1#0x170,0000#0x1000

8、双口RAMt义0x178,0000#0x20RS422控制寄存器定义0x200,0000#0x1000000SDRAM116MB0x300,0000#0x1000000SDRAM216MB0x8000,0000#0x10000内部数据存贮器(IDM)64KB当片内的RAM容量不能满足系统的程序/数据空间要求时,用户必须在片外进行存储器扩展,这就需要利用外存储器接口(EMIF)。实际上,DSP内部各个模块与片外的存储器打交道时,都必须通过EMIF的控制。EMIF支持的存储器包括:同步突发静态RAM(SBSRAM);同步动态RAM(SDRAM);异步器件(包括异步SRAM,ROM和FIFO等,EM

9、IF为它们提供了高度可编程的接口时序,以满足不同的需求);外部共享存储空间的器件。需要强调的是,C6000用的EMIF第一次对这些存储器提供了无缝接口(gluelessintederface)能力,这给开发人员带来了极大的方便。在C6000中,异步接口的每个读/写周期由三个阶段构成:建立,触发,保持。建立:从存储器访问周期开始(片选、地址有效)到读/写有效之前。触发:读/写信号从有效到无效。保持:从读/写信号无效到该访问周期结束。CEx空间控制寄存器对于读和写操作的这三个阶段的时间是可以进行独立的设置的。需要注意的是,建立时间和保持时间可设置的最小值是l(单位是CPU时钟周期),如果用户设置为

10、O,系统将当作1看待。保持时间可以设置为0。另外,不论是连续存取操作,还是单次存取,在存取第一个数时,EMIF会自动维护最小的建立时间为2,即便是用户将setuptime设为1;读取最后一个数据后,CEx信号将在保持(7-holdtime)个时钟周期后恢复为高;写完最后一个数据后,CEx信号将在(3+holdtime)个时钟周期为高,如果holdtime位设为0,CEx信号在4个时钟周期后恢复为高。ROM接口设计在ASRAM设计中我们没有用到/ARE和ARDY信号。其中地址空间信号实际是从CPLD映射过来的,并非DSP内部自行运算得到的。ROM接口设计:ROM在接口时序上,与ASRAM基本没什

11、么不同。它的特殊性有两个,一是只有读操作,二是空间配置有所讲究。C6000EMIF的异步接口支持8bit/16bitROM存取。当从这些所谓“窄存储器空间”读取数据时,EMIF会自动将多次读的数据合成一个32bit值EMIF在这种情形下工作时:不管存取的存储器的宽度怎样,每次读始终是按32bit进行的。输出的地址会自动进行移位,这保证了在对窄存储器存取操作时提供正确的地址。对16bitROM,地址自动左移一位,对8bitROM,地址自动移两位。移出的高位地址被舍弃。EMIF总是先读取较低地址的数据,将其排在LSB,再读取下一个数据,依次放在较高的字节位置。这意味着,不论用户将芯片的LENDLA

12、N位设置为何值,ROM中数据的存放必须是littleendian的。在ROM的设计中:第一,没有用到写信号;第二,虽然是8bit/16bitROM,仍然是EA2(EMIF-侧)与A0(ROM-侧)相连;第三,ROM的片选信号CS很明确地是与CE1相连。这是因为C6201的4个外部存储空间CE0-CE3中,只有CE1可以与8bit/16bit的“窄存储器”接口:需要用到ROMboot时,ROM是必须配置在CE1空间的。图4SRAM接口关系框图图5LASH存储器接口关系框图FLASH存储器接口设计一般来说,闪存的读操作与先写入的ASPAM是完全相同的,只是写操作相对而言要复杂些,原因在于闪存写入时

13、,需要先写入一串命令字序列。但从接口设计的角度而言,闪存与前面的ASRAM/ROM在接口设计上基本一致,并没有什么特殊的地方。关键是在应用时需要根据具体芯片的要求,在软件上配合完成写操作。Flash型存储器的写操作由清“0置”前编程操作构成,清“解口置”1操作按扇区(一块存储区)。本文提到的FLASH存储器的起始地址为0x140,0000,长度为0x200000,当地址映射到其中的区间时,DSP访问FLASHoRS422是一个接口电路,通过提供平衡电路来改进接口电气特性,通过传输线驱动器将逻辑电平变为电位差,实现信息传送。通过传输线接收器将电位差变为逻辑电平,实现信息接收。因而可以支持较高的传

14、输速率和较长的传输距离,在最大传输率10Mb/s的情况下,电缆允许长度为120m;如果采用低传输率,如90kb/s时,最大距离可达1200m。UCE1(为用户保留的异步接口空间)的起始地址为0x168,0000,长度为0x80000。保留一定的异步接口空间不是必须的,但是对用户来说是非常方便的,用户可以根据自己的需求自主的来定义这部分空间。3利用QuartusII进行仿真测试与结果分析连接接口仿真波形:mij.iHOLDACE1SEB=_DGSEB-DDmADIXAJOBUCHI国EA1LOOOOOODOODODOaOOOn_n_n_n_n.图6连接接口仿真波形图从仿真结果中可以看出AEB_D

15、G和AEB_DDIR的传递延迟大约为10ns。为看清系统是否有芯片感应时间引起的延迟,所以在测试中引入HOLDA在40ns-45ns时为0,由仿真结果可以看到没有明显的芯片感应时间引起的延迟。在AEB_DDIR的后段见到了一些不正确的尖峰信号,这些尖峰信号称为“毛刺”。如果一个组合逻辑电路中有“毛刺”出现,就说明该电路存在“冒险”。所以要消除竞争冒险的发生条件,避免毛刺的产生。毛刺并不是对所有的输入都有危害,例如D触发器的D输入端,只要毛刺不出现在时钟的上升沿并且满足数据的建立和保持时间,就不会对系统造成危害,因此可以说D触发器的D输入端对毛刺不敏感。根据这个特性,应当在系统中尽可能采用同步电

16、路,这是因为同步电路信号的变化都发生在时钟沿,只要毛刺不出现在时钟的沿口并且不满足数据的建立和保持时间,就不会对系统造成危害。(由于毛刺很短,多为几纳秒,基本上都不可能满足数据的建立和保持时间)所以该处可以在AEB_DDI蝴出信号前连接一个或一组D触发器,利用D触发器的D输入端对毛刺信号不敏感的特点,在AEB_DDIR输出信号的保持时间内,用触发器读取组合逻辑的AEB_DDIF输出信号,这种方法类似于将异步电路转化为同步电路。接口测试仿真波形一:从仿真结果看到,当地址映射为140,0000时,DSP访问外设Flash,与设计要求一致,同时FL_CE1、FL_OE和FL_WE的延迟大约为9ns,

17、是内部传递的时间延迟,没有芯片区应时间引起的延迟。CdK(>U沌;Bm.oU.|E3WaKUK£3»SBJhr迫Al口国haj陋ffi在必DlDHEELST1MCJDn5E£_lSrar.ciiXI.CEOIJ1又曲FL«UWFEJJEt般E图7接口测试仿真波形一图图8接口测试仿真波形二图接口测试仿真波形二:从仿真结果看到,当地址映射为178,0000时,DSP访问外设rs422,与设计要求一致,TL550_CS的延迟大约为13ns,TL550_RD的延迟大约为10ns,TL550_WR勺延迟大约为8ns。其中各信号延迟时间的不同,是因为我们无法保

18、证电路中连线的长度一样长,信号到达逻辑门的时间一致,所以产生了不同的时延。此外,从结果中看出没有产生因芯片感应时间引起的延迟。4结束语从上面的仿真波形可以看出经过CPLD的逻辑编程控制,DSP在访问各个外部接口时并没有出现各个通路相互干扰的问题,且没有较大的时延和芯片引起的传递延迟。通过CPLD的逻辑编程,大大增强了DSP访问外围设备的能力,且提高了资源利用率。使得CPLD和DSP都充分发挥了各自的优点。DSP虽然在算法处理上功能很强大,但其控制功能是非常弱的;而CPLD本身并不具有内部寄存器,虽然可以用CPLD的逻辑块来实现寄存器,但是这将耗费大量的CPLD资源。然而,CPLD的强项在于时序和逻辑控制。从结果可以看到其时间延迟多为10ns左右,符合时序逻辑,可以说本次设计达到了预期的效果,充分发挥了CPLD和DSP各自的优点。基于DSP技术和CPLD应用的广泛性,本文介绍的利用CPLD来扩展DSP对外设的访问能力只是其基础。DSP的应用已经涵盖了工业、通信、娱乐、个人医疗、教育、环境控制、安全等领域。其中TMS320C6201芯片是TI公司生产的TMS320系列产品中新一代高性能DSP芯片,该芯片已经在电子测量、测控、图象、雷达、声纳、和软件无线电等领域得到了广泛运用。而在这些运用中,DSP芯片都需要连接外设,此时就需要利用CPLD的逻辑控制能力来减轻DSP芯片的

温馨提示

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

评论

0/150

提交评论