Real-Time Measurement and Control

cancel
Showing results for 
Search instead for 
Did you mean: 

FPGA-RT data transfer

I am sending some data from the RT VI (host) to a FPGA  with a NI-cRIO 9035. I noticed there are some inconsistencies in the data transfer between the two VIs. I have attached a image of how the FPGA is wired.

 

I saw online that data transfer between RT and FPGA using cluster is not advisable, but the different types of data transfer approaches that I saw e.g handshake, FIFO etc mostly work with single data type. Using them on my application might not be feasible (my intuition). How do I go about sending data between the VIs.

 

Note: The RT VI also receives data from a TCP connection in a while loop, does some calculation before sending the resulting cluster to the FPGA. 

0 Kudos
Message 1 of 3
(962 Views)

How often are you sending updates to the FPGA?  If not often (more than several ms per data point), then you are probably fine with the cluster update.  However, you seem to be mixing things together in the cluster that do not actually belong together.  Break out the gains and test type into their own clusters or separate controls.  You only write to those when you actually need to.


GCentral
There are only two ways to tell somebody thanks: Kudos and Marked Solutions
Unofficial Forum Rules and Guidelines
"Not that we are sufficient in ourselves to claim anything as coming from us, but our sufficiency is from God" - 2 Corinthians 3:5
0 Kudos
Message 2 of 3
(933 Views)

I updated the FPGA VI based on your recommendation. But the problem still persists. I have attached the FPGA VI. 

How can I synchronize the timing between the RT and the FPGA VI?

Should the timing for each iteration in the RT VI equals to the wait in the FPGA VI? 

0 Kudos
Message 3 of 3
(920 Views)