![]() |
RS422 Datensenden unter Windows7
Hallo
Beim senden der Daten über ComPort unter Windows werden zwischen den einzelnen bytes 70 bis 100 uS durch windows eingefügt. Meine transmit funktion sendet jedoch die einzelne Bytes ohne unterbruch (pro Meldung 16 Bytes). Benützte Komponente : uComPort, (115.2 Kbaud , N , 8, 1). Die Transmitmethode wird durchgelaufen als Criticalsection, dürfte also nicht durch anderen Task behindert werden. Wie kann man diese Wartezeiten im Windows verhindern ? Umgebung : Delphi7, Windows7 |
AW: RS422 Datensenden unter Windows7
Es gibt ja mehrere Stellen, wo es hängen kann.
Viele ComPort-Komponenten arbeiten in einem Thread, also Senden und Empfangen nicht dort wo du es wegsendest. Hier kommt es natürlich drauf an, wie da die Synchronisierung arbeitet. Hier sollte es zwar nicht passieren, aber z.B. bei einigen TCP/IP-Komponenten wird auch nochmal bissl gewartet, ob nochmal was kommt, um besser ein Großes anstatt vieler kleiner Pakete versenden zu können. Und dann gibt es vermutlich auch nochmal im Treiber/Hardware ein paar Puffer und Verzögerungen, allerdings würde ich so eine "große" Pause doch eher/erstmal in deiner Komponente suchen. Test: CreateFile/TFileStream/... auf 'COM2' (oder welcher es ist), da dann ein Write ausführen und schauen ob es immernoch so lange dauert. Hier im Windows die Defaults für BAUD und Co. beachten/anpassen, sonst müsstest du nach dem Create noch mit ![]() Die alten APIs um ![]() Bei zeitkritischen Anwendungen und wo du selber schon in einem Thread arbeitest, da wäre vermutlich eine synchrone SerialPort-Komponente besser, aber, wie gesagt, arbeiten fast alle Komponenten asynchron, damit wenn man sie im Haupthread benutzt, nicht das Programm hängen bleibt. Zitat:
Bei Einer synchronen Komponente und alles im selben Thread, da könnte man ein
Delphi-Quellcode:
vorher einfügen.
Sleep(0)
Danach wird in einem neuen Slott begonnen und für die nächsten paar dutzend Millisekunden wird der Task nicht unterbrochen. |
AW: RS422 Datensenden unter Windows7
Hallo Himitsu
Danke für die ausführliche Antwort, ich habe vergessen noch zu erwähnen dass die Methode Transmit in einem Thread läuft mit: priority:= TpTimeCritical; Im gleichem Thread ist auch die Methode Receiv wo ich aber keine Verzögerungen festgestell habe. Interessant ist vielleicht auch noch, es werden 3 Messages zu je 16 Bytes gesendet bei ersten zwei sind diese Verzögerungen vorhanden,beim dritten keine mehr. Das würde vielleicht darauf hindeuten was Du geschrieben hast "..,wird auch nochmal bissl gewartet, ob nochmal was kommt " Ich werde Deine Vorschläge probieren und sehe was passiert. Vielen Dank Anton |
AW: RS422 Datensenden unter Windows7
Zitat:
|
AW: RS422 Datensenden unter Windows7
Hallo samso
Zwischen der einzelnen Bytes hat es Lücken, siehe LA Aufzeichnung auf der Emfängerseite Signale Rx-/RX+ in der Beilage. Hier Ausschnitt aus der Methode Transmit, genau die aufgezeichnete Meldung ....... else // alle 16 + 1 Byte Meldungen S1 bis S9 begin OutMsg.Meldung[0]:= OutType; // MeldungsTyp (Byte 0) setzen for i:=0 to 16 do //Byte 0 bis 16 Comport.SendByte(OutMsg.Meldung[i]); MldgOK := true; // Meldung gesendet end; end;//case Gruss Anton |
AW: RS422 Datensenden unter Windows7
Hallo
Die LA Aufzeichnung ist nicht mitgekomme, hier die Korrektur |
AW: RS422 Datensenden unter Windows7
Sehe immer noch keine Aufzeichnung...
Wie soll die Aussehen? Screenshot? |
AW: RS422 Datensenden unter Windows7
Liste der Anhänge anzeigen (Anzahl: 1)
|
AW: RS422 Datensenden unter Windows7
Liste der Anhänge anzeigen (Anzahl: 1)
sorry das war genau die dritte Message, anbei das mit Lücken, 1. Message
Anhang 52907 |
AW: RS422 Datensenden unter Windows7
Zitat:
Für mich sieht das so aus, als wenn dieses Comport.SendByte tatsächlich auf die Übertragung des Bytes wartet. Denn 87µs ist ja gerade die Zeit für die Übertragung eines Bytes. Bietet Comport denn nicht die Möglichkeit einen kompletten Puffer zu schicken? Also alle 16 Bytes in einem Rutsch? |
Alle Zeitangaben in WEZ +1. Es ist jetzt 14:56 Uhr. |
Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz