hdl coder dual port ram

3 次查看(过去 30 天)
Hi,
I am facing asertion error in dual port RAM, as I want to write the into PORTA and read from PORTB. But there is not read enable signal therefore what shour be input signla value to portB adress when it is ideal or during the portA is getting filled ?
If I have a counter then that counter always start from 0 and portA counter also start from 0 that mean both have to access same address at the same time.
Please help me to solve this problem
thank you

采纳的回答

Tim McBrayer
Tim McBrayer 2016-5-31
This is the current design of the Dual Rate Dual Port RAM. The assertion is in place because the documentation for FPGA target devices in general report reading and writing the same address at different rates as undefined.
You can use the Dual Port RAM block instead of the Dual Rate Dual Port RAM, if that block's capabilities meet your requirement. Otherwise, you will need to change your logic to prevent the two ports from accessing the same address at the same time.
  2 个评论
Sean Little
Sean Little 2020-8-18
I would agree with this error happening on simultaneous WRITEs to the same address. But not a full assertion (stop the whole simulation) for a read at the same address as a write. There is no read enable! PortA might be writing to random addresses in the RAM, and PortB must be reading from somewhere! So really, the only way (that I see) that one can guarantee that PortB is not reading from an address being written to on the other port is to put simulation only logic on portB such as adding one to the address on portA or some such hack to make that guarantee. This is not how a block RAM works in hardware.
Is there a way to convert this assertion into a warning? I am striking out in finding a way to break the link to the "HDL RAMs" library and remove that assertion, and anyway, I am nervous about editing that block because I might break the code generation step.
Adrian Perez
Adrian Perez 2023-3-3
Sean, I am also facing this issue, and I need the multirate capability of the Dual Rate RAM. Did you end up finding a way to do this cleanly? Having to "park" the reading index every time there is a collision is inefficient at best.

请先登录,再进行评论。

更多回答(0 个)

类别

Help CenterFile Exchange 中查找有关 Code Generation 的更多信息

标签

产品

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by