Hallo,
ich bekenne mich des Crosspostings (
http://forums.ni.com/ni/board/message?boar...hread.id=466426 ) schuldig, aber ich bin echt verzweifelt, da mein Problem mit Sicherheit nur eine Kleinigkeit ist, die ich übersehe. Leider sitze ich schon seit Tagen daran und finde einfach keine Lösung. Habe auch sämtliche Beispiele durchgearbeitet aber finde nicht den Haken. Ich hoffe, hier kann mir jemand weiterhelfen.
Mein Problem:
Ich möchte vom Host zum FPGA Daten übertragen, nutze dazu einen DMA-FIFO. Push des Arrays im host vi, pull der Daten auf dem target. Simuliere ich nun das Target auf dem dev computer, funktioniert das Ganze auch. Lasse ich das target vi jedoch auf dem realen Target laufen, funktionierts nicht mehr.
Im Anhang der Code vom host ([
attachment=23471]) und vom target ([
attachment=23472]). Hoffentlich konnte ich mein Problem deutlich machen.
LV2009, cRIO-9072
Vielen Dank im Voraus.
Also,
wenn du das ganze genau so programmierst, wie hier dargestellt und nur das erste Element des FIFO auf dem FPGA-Target ankommt (so steht es im anderen Post), dann macht es doch ganz genau das, was es soll. Die Sequenz auf dem Target liest ein Element und schaut, wieviel Elemente noch im FiFo sind (wobei das definitiv nicht deterministisch ist, wie Du das programmiert hast - nutz doch mal die Referenz als Datenflusskontrolle...). Dann läuft eine Schleife, die wartet, ob der button "Stopp" gedrückt wird (wobei ich mich da frage, warum Du das machst - du weißt doch anscheinend wieviele Elemente im FiFo drin sind - kann man auch gut mit einer For-Schleife machen) und das tust du im host-VI (zumindest in dem Teil, den du hier zeigst) nicht.
Ohne VIs kann ich Dir da glaub ich auch nicht weiterhelfen... Noch ein paar weitere Gedanken:
- FiFos haben mal eine Zeitlang glaube ich nur U32-Datentypen verarbeitet. Vielleicht liegt das daran.
- Hast Du mal über eine Ablaufkontrolle über Interrupts nachgedacht? Sonst musst Du immer pollen, ob ein Status irgendwie schon erreicht wurde, da sind die Wait for Interrupt-Elemente finde ich immer einfacher zu handeln...
Grüße,
ch
Also mal kurz zu meinem Aufbau:
Hier gehts es eigentlich nur darum, die grundsätzliche Funktion zu testen. Nachdem also vom Host der FIFO gefüllt wurde (mit einigen Werten aus dem Frontpanel), sollte ich so über Drücken der Taste "Next" auf dem Target vi nach und nach alle Werte auslesen können, mit zusätzlicher Kontrollanzeige wie viele Werte noch im FIFO vorhanden sind. Genau das funktioniert aber auf dem realen Target nicht, bei der Simulation/Emulation auf dem Dev Computer schon. Und genau das verstehe ich nicht.
Hi,
könntest Du bitte mal die VIs posten? Und wie betätigst Du den Stopp- Butten auf dem Target und schaust Dir die Indikatoren an? Und noch was ist mir eingefallen: Dein Target ist schnell und in keinster Weise mit deinem Host synchronisiert. Außerdem weiß ich nicht, ob RT-Targets Latch-Funktionalitäten bei Buttons ordentlich unterstützen, sprich, Deine Schleifen könnten definitiv mehrfach durchlaufen, ohne dass Du das auf dem Host mitbekommst. Möglichkeiten: Controls von Cases, die Funktionalitäten ein- und ausschalten noch im Case wieder zurücksetzen...
ch
Hallo ch,
Hier sind die beiden VIs:
[
attachment=23488][
attachment=23487]
Indikatoren und Stop-Button erreiche ich doch ganz einfach über ein Frontpanel (habe ich die Frage richtig verstanden?).
Hi,
danke für die VIs (damit das Jens jetzt nicht schreiben muss: Die Version fehlt). Version ist leider auch der Grund, dass ich sie nicht lesen kann (drück mich noch vor der 2009-Installation).
Zur Bedienung: Ich hab zwar nur eine R-Serie, habe aber mal mit einem Kollegen gesprochen: Ein cRIO kannst Du m.E. nur über verknüpfte Netzwerkvariablen in deinem Host-VI oder über eine Weboberfläche, die das Frontpanel vom RT-Target abbildet, bedienen. Allerdings kann man auch für den Fall, dass man das ganze auf dem RT laufen lässt, auf dem Host das VI, das auf dem RT läuft, öffnen und bedienen, nur kommen die Befehle dann nicht am RT an, sondern laufen irgendwie ins Leere. Könnte das ganze daran liegen? Deine Aussage "ganz einfach über ein Frontpanel" macht mich da nämlich ein bisschen stutzig...
ch
Der FPGA ist Hardware und demzufolge kann man auch nicht auf Button ( hier NEXT) des FPGA-VI's klicken. Das FPGA Panel ist ein reiner Indikator zum Debuggen.
Auf das NEXT Control muss per RT zugegriffen werden. Dann sollte es gehen.
Hope it helps
Christian