3系列FPGA中使用LUT构建分布式RAM(3)

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

 3系列FPGA中使用LUT构建分布式RAM(3)_设计制作_EDA/IC设计

Xilinx库中Spartan3系列FPGA中SRAM和DRAM的原语一共有4个,如表2所示。(不清楚怎么调用原语的同学可以参考和)。这些原语的详细说明都位于Spartan-3 Libraries Guide for HDL Designs,即UG607.pdf之中。

 3系列FPGA中使用LUT构建分布式RAM(3)_设计制作_EDA/IC设计

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

 3系列FPGA中使用LUT构建分布式RAM(3)_设计制作_EDA/IC设计

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

 3系列FPGA中使用LUT构建分布式RAM(3)_设计制作_EDA/IC设计

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

7
138
0
43

相关资讯

  1. 1、视频监控那些事儿1387
  2. 2、长沙互联网与创业者们3381
  3. 3、设计女性科技产品的3个误区3641
  4. 4、财报分析(科目篇):资产类科目3284
  5. 5、一款叫好又叫座的产品,长什么样子?3871
  6. 6、产品经理日报第1028期|微信悄然上线了“申请销号”功能661
  7. 7、电子商务2.0时代到来?853
  8. 8、值乎VS分答,知识向右,娱乐向左1612
  9. 9、未来,全栈运营可能比专家运营更吃香2182
  10. 10、小程序,就是新零售的未来……3522
全部评论(0)
我也有话说
0
收藏
点赞
顶部