hdl coder dual port ram
1 Ansicht (letzte 30 Tage)
Ältere Kommentare anzeigen
Mohammed Shameem Hussain
am 27 Mai 2016
Kommentiert: Adrian Perez
am 3 Mär. 2023
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
0 Kommentare
Akzeptierte Antwort
Tim McBrayer
am 31 Mai 2016
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 Kommentare
Sean Little
am 18 Aug. 2020
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
am 3 Mär. 2023
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.
Weitere Antworten (0)
Siehe auch
Produkte
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!