搜索
bottom↓
回复: 9

xilinx的RAM综合问题(同步和异步)

[复制链接]

出0入0汤圆

发表于 2014-9-28 22:08:10 | 显示全部楼层 |阅读模式
  1. always @(posedge clk)
  2. begin
  3.     if (we)
  4.     begin
  5.         ram[a] <= di;
  6.         a_next <= a;
  7.     end
  8. end

  9. assign do = ram[a_next];
复制代码


上面这样的,就是同步的,综合出来就是用BRAM来实现。

下面的,就是异步的,综合出来是LUT来实现。

  1. always @(posedge clk)
  2. begin
  3.     if (we)
  4.     begin
  5.         ram[a] <= di;
  6.     end
  7. end

  8. assign do = ram[a];
复制代码


请问第一段代码,为什么说它是同步的?我知道那个地址是同步的...
但是对于输出值do来说,都是直接根据地址选择数据,不知有何区别?
也就是说,两端代码之间就相差个地址寄存而已,为什么第二段代码不能用BRAM来实现?BRAM内部是怎么样的结构?

不知道表达清楚了没有?

阿莫论坛20周年了!感谢大家的支持与爱护!!

曾经有一段真挚的爱情摆在我的面前,我没有珍惜,现在想起来,还好我没有珍惜……

出0入0汤圆

发表于 2014-9-28 22:43:50 | 显示全部楼层
第二例的 do 可能一直在变吧。
而第一例中  do 的值仅会在we时变化一次,后面都是固定的值。

出0入0汤圆

 楼主| 发表于 2014-9-29 08:16:39 | 显示全部楼层
aozima 发表于 2014-9-28 22:43
第二例的 do 可能一直在变吧。
而第一例中  do 的值仅会在we时变化一次,后面都是固定的值。 ...

这个我懂啊,但是为什么就不能用BRAM来实现...?

出0入0汤圆

发表于 2014-11-10 23:33:44 | 显示全部楼层
阻塞与非阻塞  你要认真看看

出0入0汤圆

 楼主| 发表于 2014-11-11 08:50:13 | 显示全部楼层
守望者2012 发表于 2014-11-10 23:33
阻塞与非阻塞  你要认真看看

这跟阻塞和非阻塞有关系?

出0入0汤圆

发表于 2014-11-11 09:05:52 | 显示全部楼层
第一个不应该是在we锁存address吧

出0入0汤圆

 楼主| 发表于 2014-11-11 11:26:04 | 显示全部楼层
7802848 发表于 2014-11-11 09:05
第一个不应该是在we锁存address吧

这个在xilinx的资料上复制出来的...

出0入8汤圆

发表于 2014-11-13 01:02:25 | 显示全部楼层
第一种do是clk时钟域下的load.属于同步时序逻辑。同步是相对对clk说的。
第二种do和clk完全没关系,是组合逻辑。

出0入0汤圆

发表于 2014-11-13 01:33:56 | 显示全部楼层
本帖最后由 McuPlayer 于 2014-11-13 01:36 编辑

你用的bram是单端口的,意味着某一时刻只能一个addr,而addr在clk的时候要更新,所以你你看到的永远是旧的addr对应的数据
当然,你可以使用双端口RAM的方式,读写的addr错位也不要紧

强烈建议直接使用BRAM Primitive做,不要叫编译器自动去选择BRAM还是DRAM
当然,记忆Primitive是很恼火的事情,其实Xilinx的ISE和Altera的QuarterII都提供相应的Wizard来做这个,点点鼠标而已

出0入0汤圆

发表于 2014-11-13 01:59:55 | 显示全部楼层
In latch mode, the read operation uses one clock edge. The read address is registered on the
read port, and the stored data is loaded into the output latches after the RAM access time.
When using the output register, the read operation will take one extra latency cycle to
arrive at the output.

看xilinx的手册,我的猜测是,主要是第二种方式不符合BRAM的工作方式,所以没有 办法综合成BRAM吧。 而第一种方式是和手册上说的,BRAM的工作方式一致。


回帖提示: 反政府言论将被立即封锁ID 在按“提交”前,请自问一下:我这样表达会给举报吗,会给自己惹麻烦吗? 另外:尽量不要使用Mark、顶等没有意义的回复。不得大量使用大字体和彩色字。【本论坛不允许直接上传手机拍摄图片,浪费大家下载带宽和论坛服务器空间,请压缩后(图片小于1兆)才上传。压缩方法可以在微信里面发给自己(不要勾选“原图),然后下载,就能得到压缩后的图片。注意:要连续压缩2次才能满足要求!!】。另外,手机版只能上传图片,要上传附件需要切换到电脑版(不需要使用电脑,手机上切换到电脑版就行,页面底部)。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

手机版|Archiver|amobbs.com 阿莫电子技术论坛 ( 粤ICP备2022115958号, 版权所有:东莞阿莫电子贸易商行 创办于2004年 (公安交互式论坛备案:44190002001997 ) )

GMT+8, 2024-8-27 02:44

© Since 2004 www.amobbs.com, 原www.ourdev.cn, 原www.ouravr.com

快速回复 返回顶部 返回列表