首页 | 新闻 | 新品 | 文库 | 方案 | 视频 | 下载 | 商城 | 开发板 | 数据中心 | 座谈新版 | 培训 | 工具 | 博客 | 论坛 | 百科 | GEC | 活动 | 主题月 | 电子展
返回列表 回复 发帖

在Spartan-3系列FPGA中使用LUT构建分布式RAM(3)---连载――我与FPGA活动

在Spartan-3系列FPGA中使用LUT构建分布式RAM(3)---连载――我与FPGA活动

前面简要介绍了Spartan-3系列FPGA中分布式RAM的基本特性。为什么不从更高级的Virtex系列入手呢?我仔细看了一下各个系列的介绍、对比,Spartan系列基本就是Virtex系列的精简版,其基本原理是一样的,所以从简单的入手来融会贯通未尝不是一个好办法。至于各个器件具体的有什么配置,在Xilinx网站上查找它们各自的Datasheet或者User guide即可(这也是资源最近我着重提到的学习资源)。表1给出了Spartan与Virtex系列中分布式RAM的基本对比情况。

          表1 Spartan与Virtex系列中分布式RAM的基本对比情况
          Xilinx库中Spartan3系列FPGA中SRAM和DRAM的原语一共有4个,如表2所示。(不清楚怎么调用原语的同学可以参考http://xilinx.eetrend.com/blog/810http://xilinx.eetrend.com/blog/814)。这些原语的详细说明都位于Spartan-3 Libraries Guide for HDL Designs,即UG607.pdf之中。

          表2 库中分布式RAM的原语
          表2中原语在调用时,其输入和输出都是1位宽的。为了实现更大的内存函数,可以把它们进行并联使用,如表3所示。在调用CoreGenerator时,每个端口的定义都会有详细的说明,在此不再详细描述,请参考原语调用时CoreGenerator的help或者上面的UG607.pdf。

          表3 分布式RAM原语的并联使用
          分布式的RAM在器件初始化之后,其内容为全零。如果要求配置为初始化后非零的情况,需要使用INIT属性。每一个INIT都是以16进制编码的矢量,从MSB到LSB排序。表4给出了每个原语的INIT长度。

          表4 每个原语的INIT长
          每一个Spartan-3 FPGA的CLB都包含4个slice,它们的位置排列datasheet、user guide或者PlanAhead中都可以看到。相比较而言,PlanAhead中的更为直观,可以参考http://xilinx.eetrend.com/blog/817中的图5。分布式RAM仅仅位于SLICEM类型的SLICE中,其中的“M”即表示这种slice支持与存储器相关的函数;而SLICEL中的L表明这种类型的slice仅支持逻辑。

附件大小Biao_1_Bu_Tong_Xi_Lie_De_Fen_Bu_Shi_RAMTe_Zheng_.jpg44.82 KBBiao_2_Fen_Bu_Shi_RAMDe_Yuan_Yu_.jpg38.63 KBBiao_3_Yuan_Yu_De_Bing_Lian_.jpg39.19 KBBiao_4_Bu_Tong_Yuan_Yu_INITShu_Xing_De_Chang_Du_.jpg33.34 KB
记录学习中的点点滴滴,让每一天过的更加有意义!
返回列表