LabVIEW

cancel
Showing results for 
Search instead for 
Did you mean: 

Can't make RT use generic FPGA FIFO

Hi all,

 

On a cRIO, I'm making a TCP server in RT that feeds data to a DMA FIFO for FPGA consumption.  We are setting up multiple servers where each feeds a different DMA.  (No, I don't want to merge and multiplex to single DMA).

 

I want a single RT program that takes a FIFO reference so that I can reuse the same RT code for different FIFOs.  I can define a FPGA FIFO reference control,

 

fifoRefSingle.png

but this only supports writing a single element at a time (or two on our target if you select peer-to-peer streaming for the FIFO).  I have tuned the RT program for performance, and looping over thousands of elements per second in RT is NOT the solution.  I want to use the "other" FIFO write which supports arrays - the one I can reference from an FPGA reference as follows:

 

fifoRefMult.png 

 

However, using the FPGA reference I believe requires a particular named FIFO - therefore tying the RT code to a particular FIFO.

 

fifoRefConfig.png

 

 

Any ideas how to do this?

 

Steve

0 Kudos
Message 1 of 8
(4,414 Views)

Hey maherhome,

 

One thing to clear up, the first code snippet you showed will only work on the FPGA (and the 2nd snipped is host only). Not a big deal, since you want to use the right one anyway, but I wanted to be clear that the API is a bit different between host and FPGA.

 

As for a solution, to your problem, I think the LabVIEW FPGA Advanced Session Resources NILabs release will do what you are looking for.

 

Thanks,

 

Sebastian

Message 2 of 8
(4,404 Views)

As speleato said, if your FIFOs have different names then you need to use the Advanced Session Resources. Be aware of the known issues though - it doesn't work very well for remote targets (e.g. over ethernet).


LabVIEW Champion, CLA, CLED, CTD
(blog)
0 Kudos
Message 3 of 8
(4,387 Views)

^^although its worth pointing out that rio does work over the network, so if all you're doing is TCPing things directly into a fifo you may be able to save yourself some time and effort letting RIO do the work for you.

0 Kudos
Message 4 of 8
(4,375 Views)

 

Sorry about the mis-targeted code snippet - I was playing around with FIFO things on a block diagram and didn't noticed the error.

 

The Advanced Session Resources looks great.  I've downloaded and will look into it.

I'm intrigued by the "let RIO do the work for you".  Is this referring to using Labview on PC and a network shared variable (or whatever the name is) and then have an RT program on the cRIO stuff the variable contents into the FIFO?  We don't have Labview on our remote device; hence the raw TCP setup.  Or is there something else (hmm, I don't think you can use nidaq-mx to talk to cRIO) ...

 

Thanks!

 

Steve

 

p.s. the Giant Tetris looks cool!

 

 

Message 5 of 8
(4,356 Views)

I believe smithd is referring to the fact that the Open FPGA VI Reference node can open references to RIO devices located on the network. This means that it's possible to call the FIFO Read operation on the remote system. This also works with the FPGA Interface C API, so while the RIO Driver is required, you don't actually need LabVIEW on the remote system either.

 

A couple cautions if you decide to pursue this. Firstly, the remoting protocol is not optimized for streaming performance. So depending on your needs it may or may not be adequate. Secondly, the server is single threaded, so reading multiple fifos concurrently can result in timeouts and/or larger than expected latency.

0 Kudos
Message 6 of 8
(4,333 Views)

All,

 

Thanks for the advice.  I'm trying to create a basic test using the Advance Sessions Sources and am getting a FIFO name error (-61206) from the Get Single Resource Session node.  The messy diagram below is showing the test VI on the right and a client VI on the left.  The idea is to pass an FPGA reference and the FIFO name "FpgaDataIn" and the test VI grabs the FIFO by name and writes to the FIFO.  

 

One issue to overcome is my beginner skills: the passed FPGA reference needs to be compatible with the FPGA reference control - which defeats the purpose of supporting generic FPGA references.  There must be a way to specifiy a control that accepts a generic FPGA reference (dynamic FPGA cast?  (which I've never used)).

 

Putting that issue aside for a moment, even when I define a FPGA reference control with a signature compatible with the passed FPGA reference I still get the 61206 error.  I noticed issues related to upper/lower case and tried everything lower case (I THINK - I'm not positive I did it completely - but it's tedious with the FPGA reference signatures).

 

I read how the Get Single Resource Session needs a constant reference with a single "FIFO" fifo and have that.

 

Any tips?

 

Thanks!

 

Steve

 

 

 

niForum.png

0 Kudos
Message 7 of 8
(4,315 Views)

After rewriting, recompiling, AND using all lower-case for FIFO resource name, it worked 😃

0 Kudos
Message 8 of 8
(4,237 Views)