Jump to content

Transferring Data between the FPGA and the Host


GoUp

Recommended Posts

Posted

Hello!

 

Is there anything similar to "DMA MEMORY" that behaves like DMA FIFO, but without the FIFO part?

 

I would like to transfer 1000 bytes of data from the FPGA to the cRIO host and 1000 bytes of data from the host to the FPGA and I don't care about old data - I only need the latest data.
Ideally I would like to have two pieces of memory, each 1000 bytes long.
One piece that can be written from the FPGA and read from the host and the other piece that can be written by the host and read by the FPGA, so that the first byte of data is always on the address 0.

 

DMA FIFO is not a viable solution, because I would like to get the data as fast as possible, but I can read it on the host only on certain non deterministic intervals.
If I would use the DMA FIFO, I would need a huge FIFO to store all the unused old measurements.

 

Thank you for any reply or suggestion.

 

Kind regards,

 

Greg
 

Posted (edited)

Thank you for your fast response.

 

Unfortunately if I use a control/indicator array I am using too much registers and LUTs.
Is there any way around, so that I can put the entire array in a memory block?

 

Kind regards,

Greg

Edited by GoUp
Posted

Are you sure you're using right datatype for this array, i.e. U8/I8 instead of U32/I32? This makes huge difference in elements usage.

Posted

I am using U8, but the problem is that I need two arrays each 1000 elements long and this with the extra code is too much.
It seems that the only way is to use DMA FIFOs.

Kind regards,

Greg

Posted

Yes, you can put the array in a memory block on the FPGA, and then transfer one element at a time to the host using a front panel control. On the FPGA front panel you'll need three elements: an address, a value, and a boolean to signal to read. The host sets the address, then sets the boolean true. When the FPGA sees the true value, it reads the address, retrieves it from memory, writes the value, and sets the boolean false. When the host sees that the boolean is false, it reads the value, then updates the address and sets the boolean true again, etc.

Join the conversation

You can post now and register later. If you have an account, sign in now to post with your account.

Guest
Unfortunately, your content contains terms that we do not allow. Please edit your content to remove the highlighted words below.
Reply to this topic...

×   Pasted as rich text.   Paste as plain text instead

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   Your previous content has been restored.   Clear editor

×   You cannot paste images directly. Upload or insert images from URL.

×
×
  • Create New...

Important Information

By using this site, you agree to our Terms of Use.