09.09.2010, 16:46
Beitrag #1
|
Matze
LVF-Team
Beiträge: 1.027
Registriert seit: Apr 2010
20xx
2010
DE_EN
7xxxx
Deutschland
|
100% CPU-Auslastung, trotz Wartezeit?
Hi zusammen,
ich übertrage über ein DMA-FIFO Werte vom FPGA an die RT-Anwendung.
Im FPGA schreibe ich die Werte mit 1 kHz in den FIFO, im RT-System lese ich sie ungebremst in einer Schleife aus und zwar immer 50 Werte auf einmal (über FIFO.Read).
Die CPU-Auslastung steigt hier auf 100%
Stelle ich eine zusätzliche Wartezeit von z.B. 40 ms ein, sinkt die CPU-Auslastung deutlich, aber ohne, dass der FIFO voll läuft. Auch wenn die Wartezeit "Warten (ms)" nach FIFO.Read aufgerufen wird (per Datenfluss eindeutig festgelegt).
Ich habe angenommen "FIFO.Read" wartet so lange, bis 50 Werte im FIFO sind und macht dann mit dem Ablauf weiter. Aufgrund dieser Wartezeit habe ich eine geringe CPU-Auslastung erwartet.
Aber FIFO.Read scheint nicht wirklich zu warten.
Wieso steigt die CPU-Auslastung auf 100%, wenn die Einleseschleife, in der FIFO.Read aufgerufen wird, ungebremst läuft?
|
|
|
09.09.2010, 17:08
Beitrag #2
|
eg
LVF-SeniorMod
Beiträge: 3.868
Registriert seit: Nov 2005
2016
2003
kA
66111
Deutschland
|
100% CPU-Auslastung, trotz Wartezeit?
' schrieb:Ich habe angenommen "FIFO.Read" wartet so lange, bis 50 Werte im FIFO sind und macht dann mit dem Ablauf weiter.
Falsche Annahme?!
|
|
|
09.09.2010, 19:17
Beitrag #3
|
Matze
LVF-Team
Beiträge: 1.027
Registriert seit: Apr 2010
20xx
2010
DE_EN
7xxxx
Deutschland
|
100% CPU-Auslastung, trotz Wartezeit?
' schrieb:Falsche Annahme?!
Äh ach ne, das weiß ich selbst.
Das beantwortet meine Frage aber nicht.
|
|
|
09.09.2010, 19:37
(Dieser Beitrag wurde zuletzt bearbeitet: 09.09.2010 19:38 von eg.)
Beitrag #4
|
eg
LVF-SeniorMod
Beiträge: 3.868
Registriert seit: Nov 2005
2016
2003
kA
66111
Deutschland
|
100% CPU-Auslastung, trotz Wartezeit?
Wieso nicht?
Du musst also eine Verzögerung einbauen, die Daten bei der Verzögerung werden in der FIFO zwischengespeichert, aber max. 50 Werte.
Ansonsten, ohne Verzögerung läuft die Schleife ständig und verbraucht CPU.
So verstehe ich das (habe damit noch nie gearbeitet, aber kann es mir so vorstellen).
|
|
|
09.09.2010, 19:44
Beitrag #5
|
Matze
LVF-Team
Beiträge: 1.027
Registriert seit: Apr 2010
20xx
2010
DE_EN
7xxxx
Deutschland
|
100% CPU-Auslastung, trotz Wartezeit?
Ich teste morgen mal, ob LabVIEW bei < 50 Werten einfach drüber rast und keine Werte zurück gegeben werden.
Aber das fände ich doch etwas ungewöhnlich.
|
|
|
09.09.2010, 19:47
Beitrag #6
|
eg
LVF-SeniorMod
Beiträge: 3.868
Registriert seit: Nov 2005
2016
2003
kA
66111
Deutschland
|
100% CPU-Auslastung, trotz Wartezeit?
Ja, mach das. Es scheint mir dem buffered DAQ-MX Read ähnlich zu funktionieren.
|
|
|
09.09.2010, 20:21
(Dieser Beitrag wurde zuletzt bearbeitet: 21.11.2010 12:45 von rbliomera.)
Beitrag #7
|
rbliomera
LVF-Gelegenheitsschreiber
Beiträge: 56
Registriert seit: Sep 2010
LV X.Y.Z
-
kA
NNNNN
Spain
|
100% CPU-Auslastung, trotz Wartezeit?
Edit: Deleted. /EOM
|
|
|
09.09.2010, 20:23
(Dieser Beitrag wurde zuletzt bearbeitet: 09.09.2010 20:26 von Matze.)
Beitrag #8
|
Matze
LVF-Team
Beiträge: 1.027
Registriert seit: Apr 2010
20xx
2010
DE_EN
7xxxx
Deutschland
|
100% CPU-Auslastung, trotz Wartezeit?
' schrieb:Ja, mach das. Es scheint mir dem buffered DAQ-MX Read ähnlich zu funktionieren.
Dort ist mir das nie aufgefallen und DAQmx-Read wartet auch wirklich, bis x Werte im RAM sind und gibt diese dann zurück.
Wenn ich z.B. mit 50 Hz Werte einlese und immer 100er-Blöcke aus dem RAM hole, dann dauert ein Schleifendurchlauf ca. 2 Sekunden. Und ich meine, die CPU-Auslastung ist dort gering.
Ich bin mir nicht sicher, ob man bei DAQmx-Read überhaupt eine zusätzliche Verzögerung braucht. Bisher habe ich immer eine eingefügt, aber mehr aus Gewohnheit, ohne es genauer zu testen.
Wenn ich dazu komme, werde ich auch das mal näher untersuchen.
Nachtrag: Danke rbliomera. Das Verhalten finde ich nicht gerade optimal, sondern eher richtig schlecht. Dann muss ich wohl pro Schleifendurchlauf erst den FIFO-Status auslesen und wenn < 50 Werte im FIFO sind, die Verzögerung per Case ausführen lassen ...
|
|
|
09.09.2010, 20:58
Beitrag #9
|
|
|
09.09.2010, 21:49
(Dieser Beitrag wurde zuletzt bearbeitet: 21.11.2010 12:45 von rbliomera.)
|
rbliomera
LVF-Gelegenheitsschreiber
Beiträge: 56
Registriert seit: Sep 2010
LV X.Y.Z
-
kA
NNNNN
Spain
|
100% CPU-Auslastung, trotz Wartezeit?
Edit: Deleted. /EOM
|
|
|
| |