DMA FIFO: Wieviele Elemente sollte man holen? - Druckversion +- LabVIEWForum.de (https://www.labviewforum.de) +-- Forum: LabVIEW (/Forum-LabVIEW) +--- Forum: LabVIEW Module (/Forum-LabVIEW-Module) +---- Forum: LabVIEW FPGA (/Forum-LabVIEW-FPGA) +---- Thema: DMA FIFO: Wieviele Elemente sollte man holen? (/Thread-DMA-FIFO-Wieviele-Elemente-sollte-man-holen) |
DMA FIFO: Wieviele Elemente sollte man holen? - differtd - 08.01.2010 09:38 Guten Morgen! Ich habe einen FPGA an meinem cRIO und möchte über den DMA FIFO Messwerte von dem cRIO auf ein Host VI übertragen. Die Depth des FIFOs steht auf 4095 und ich hole pro durchlauf zB 1000 Elemente vom FIFO ab. Nach ein paar durchläufen zeigt mir der "Elements Remaining"-Ausgang des FIFOs dann, dass keine Daten mehr ausstehen. Das ist auch ganz schön... Aber was holt mein Host ab, wenn da keine Daten mehr im FIFO ausstehen? Holt der nichts oder macht er irgend welche Zauberei? Schönen Gruß! LV 8.6 cRIO 9022 DMA FIFO: Wieviele Elemente sollte man holen? - chrissyPu - 08.01.2010 11:27 Hi, Das hängt davon ab, wie du die Timeouts und die abzuholenden Elemente konfigurierst... Hast doch alle Möglichkeiten, z.B. Abfragen, wieviele Elemente noch da sind und entsprechend weniger abrufne oder abbrechen oder auf das Timeout reagieren, wenn du sachen abholst etc. ch DMA FIFO: Wieviele Elemente sollte man holen? - differtd - 08.01.2010 15:01 Hi, Aber die ganzen Optionen des abfragens und so nützen mir doch nichts wenn der FPGA die ganze Zeit weiter Daten in den FIFO reinschiebt?! DMA FIFO: Wieviele Elemente sollte man holen? - chrissyPu - 08.01.2010 16:24 Tag, dann versteh ich Deine Frage nicht. Es ist doch so, dass der FPGA bzw. der RT Daten in den Fifo schreibt. Das macht er so lange, bis der Fifo voll ist, wenn das der Fall ist, bekommst Du einen Fehler auf dem FPGA gemeldet. Ggf. kann man das konfigurieren, wie lange er warten und probieren soll, Werte in den Fifo zu schreiben, bevor der Fehler kommt. Irgendein Prozess, der den FiFo überwacht (der m.E. über den Fifo-Start-Methodenknoten gestartet wird, wobei ich nicht ganz genau weiß, ob das stimmt) schaut dann, das z.B. die Sachen aus dem FiFo auch irgendwie ins Memory geschrieben werden. In Deinem Fall wäre das ein Prozess, der per DMA die Daten aus dem Puffer aus dem FPGA-Memory auf das Memory vom Host schreibt. Aus diesem Host-Memory rufst Du jetzt mit deinem Methodenknoten die Daten ab und zwar so viele, wie Du haben willst. Auch hier gibt es jetzt die Möglichkeit zu sagen, wieviele Daten abgeholt werden sollen und was passiert, wenn nicht ausreichend Daten da sind bzw. es zu lange dauert, bis diese Daten da sind. Zur Ablaufsteuerung kann man hier z.B. die Eigenschaft der im Fifo vorhandenen Elemente nutzen. Deine erste Frage aus dem ersten Post hätte ich dementsprechend so beantwortet: Je nach Einstellung des Fifo-Lesen-Knotens aufm Host kommt entweder ein Timeout oder (wenn Du entsprechend auf die Remaining Elements reagierst) ein OK, alle Daten gelesen. Deine zweite Frage aus dem letzten Post entsprechend Nein, denn es kommt drauf an, was passiert: [list]Wenn der Fifo immer weiter reinschreibt und du immer 1000 Werte rausholst, ohne ein Timeout zu haben (das ist m.E. die Voreinstellung), dann holst du so lange alle Werte ab, wie die Abfragemenge des Hostes größer als die Datengenerationsrate des Targets ist. In diesem Fall wird die Fifo-Read-Operation nicht immer gleich lange dauern, weil der Knoten irgendwann an einer Stelle warten wird, bis die 1000 Werte voll sind. Das ganze geht endlos....<> [st][list]Schreibt der FPGA mit dieser Konfiguration schneller, wird irgendwann der FIFO-Puffer voll sein und du hast eine Fehlermeldung auf dem Target. Wenn Du die nicht abarbeitest, fehlen Dir Daten, was du wahrscheinlich auch nicht merkst, da die RTs glaube ich keine automatische Fehlerhandler haben, wie im normalen LV<> [st]Wenn man also mehr Kontrolle haben will, hat man entweder die Option, über Interrupts zu synchronisieren oder auf dem Host immer erst den Status des Fifo abzufragen und dann immer diese Anzahl an Elementen auszulesen. Damit ist man (wenn man vorher mal die Datenraten durchgerechnet bzw. sich angeschaut hat) meist auf der sicheren Seite. So far, ch |