利用FPGA解决TMS320C54K与SDRAM的接口问题
出处:ni.hao. 发布于:2007-12-12 10:37:29
1 SDRAM介绍
本文采用的SDRAM为TMS626812A,它内部分为两条,每条1M字节,数据宽度为8位,故存储总容量为2M字节。
所有输入和输出操作都是在时钟CLK上升沿的作用下进行的,刷新时钟交替刷新内部的两条RAM。TMS626812A主要有六条控制命令,它们是:条激活/行地址入口、列地址入口/写操作、列地址入口/读操作、条无效、自动刷新、自行刷新。SDRAM与TMS320C54x接口中用到的命令主要有: MRS、 DEAC、 ACTV、WRT-P、READ-P和REFR。这里,设计目的就是产生控制信号来满足这些命令的时序要求。关于TMS626812A的具体说明可以查看其数据手册。
2 SDRAM与TMS320C54x之间的通用接口
DSP I/F代表TMS320C54x端接口单元,SDRAM CNTL 代表SDRAM 端接口控制单元。SDRAM被设置成性读写128个字节,而DSP只读写一个字节,因而建立了两个缓冲区B0、B1来缓存和中转数据。B0、B1大小都为128字节,而且映射到DSP中的同一地址空间。
尽管B0、B1对应于同一地址空间,但对两个缓冲区不能在同一时刻进行合法访问。实际上,当B0被DSP访问时,B1就被SDRAM访问,反之也成立。若DSP向B1写数据,SDRAM就从B0读数据;而当SDRAM的数据写到B0中时,DSP就从B1读数据。两者同时从同一缓冲区读或写都将激发错误。上边所述的数据转移方式有两种好处:一是加速了TMS320C54x的访问速度,二是解决了二者之间的时钟不同步问题。
3 FPGA中的硬件设计
TMS320C54x为外部存储器的扩展提供了下列信号CLK、CS、A0~A15、D0~D15、RW、MSTRB、ISTRB、IS而SDRAM接收下列信号CLK、CKE、CS、DQM、W、RAS、CAS、A0~A11。由于两端控制信号不同,需要在DSP与SDRAM之间加上控制逻辑,以便将从DSP过来的信号解释成SDRAM能够接收的信号。图3是用FPGA设计的顶层硬件接口图。
图中主要有三个模块:DSP-IO、DMA_BUF和SD-CMD。其中DSP-IO是DSP端的接口,用来解码TMS320C54x发送的SDRAM地址和命令。DMA_BUF代表缓冲区B0、B1。SD_CMD模块用来产生SDRAM访问所需的各种信号。
DSP_IO模块又包括IO_DMA、DSP_BUF和DSP_READ。IO_DMA产生SDRAM的命令信号即图3中的DSP_RDY、DSP_SD_RW、DSP_SD_BANK_SW、DSP_SD_ADDR20..0、DSP_SD_ADDR_RESET、DSP_SD_START。DSP_BUF产生访问B0、B1的地址、数据和控制信号,图3中指DSP_SD_BUFCLKI、DSP_SD_BUFCLKO、DSP_SD_BUFWE、DSP_SD_BUFADDR6..0、DSP_SD_BUFIN7..0。DSP-READ子模块用来控制DSP的读写方向。 DMA_BUF分为B0、B1两个缓冲区,用来进行数据传送每个缓冲区的输入输出信号包括CLKI、CLKO、WE、ADDR6-0、DATA_IN7-0、DATA_OUT7-0。BANK_SW是一个开关信号用于DSP和SDRAM对B0、B1的切换访问。
SD_CMD模块包括刷新、读、写功能。当DSP芯片发出SDRAM读命令时,128字节的数据从SDRAM中读出来并被存储到B0或B1中,当DSP发出写命令之时,128字节的数据传到B0或B1之中并被终写到SDRAM中。
4 软件设计
TMS626812A SDRAM有两兆字节的存储容量。所以DSP用两个I/O地址向FPGA传送访问SDRAM的高低地址。此文中该两个I/O地址对应于图4中的03hDMA_ADDH和04hDMA_ADDL。另外,还有一个I/O地址图4中的05h用来向FPGA传送命令产生SDRAM访问的信号。
DSP向SDRAM写数据时的操作步骤如下:
1数据先被写到B0或B1。
2SDRAM的访问地址经由DSP的I/O地址DMA_ADDH和DMA_ADDL发送到FPGA中。
3DSP向FPGA发出一个命令(I/O地址为DMA_CTL)产生控制信号,使SDRAM从B0或B1中读取数值。
DSP从SDRAM读数据的操作步骤如下:
1DSP传送访问SDRAM的地址。
2DSP经由FPGA传送一个命令,使得数据从SDRAM中读到FPGA中。
3DSP从B0或B1中读得数据。
具体设计时,应参考相关资料进行补充。不同的DSP与不同类型的SDRAM接口时,会有细微的区别,电路设计完毕后要进行认真而多方面的测试。
版权与免责声明
凡本网注明“出处:维库电子市场网”的所有作品,版权均属于维库电子市场网,转载请必须注明维库电子市场网,https://www.dzsc.com,违反者本网将追究相关法律责任。
本网转载并注明自其它出处的作品,目的在于传递更多信息,并不代表本网赞同其观点或证实其内容的真实性,不承担此类作品侵权行为的直接责任及连带责任。其他媒体、网站或个人从本网转载时,必须保留本网注明的作品出处,并自负版权等法律责任。
如涉及作品内容、版权等问题,请在作品发表之日起一周内与本网联系,否则视为放弃相关权利。
- SQL核心知识点总结2025/8/11 16:51:36
- 等电位端子箱是什么_等电位端子箱的作用2025/8/1 11:36:41
- 基于PID控制和重复控制的复合控制策略2025/7/29 16:58:24
- 什么是树莓派?一文快速了解树莓派基础知识2025/6/18 16:30:52
- 什么是有机液分析与有机液知识介绍2025/6/7 16:31:44