Page 1 of 2

Modbus Register schreiben

Posted: 22 Jan 2022, 21:38
by ostermann
Ich versuche gerade, einen Schrittmotor-Controller via ModbusRTU anzusprechen. Das Lesen von Read-Only Registern funktioniert schonmal. Beim Schreiben von Konfigurationsdaten habe ich aber noch Probleme.

Der Regler unterstützt die Funktionen:
Read Holding Registers 3 (03h)
Write Single Register 6 (06h)
Write Multiple Registers 16 (10h)
Mask Write Register 22 (16h)
Read/Write Multiple Registers 23 (17h)

Der RevPi kann offenbar kein "Read/Write Multiple Register", sondern nur "WRITE_MULTIPLE_REGISTERS". Demnach kann ich nicht sehen, ob die gesendeten Werte korrekt übernommen wurden? Oder muss ich dafür die gleiche Adresse 2x ansprechen, einmal mit "Write_Multiple_Register" und danach per "Read_Holding_Register"?

Mit freundlichen Grüßen
Thorsten Ostermann

Re: Modbus Register schreiben

Posted: 26 Jan 2022, 16:23
by ostermann
Ich habe jetzt mal ein "Write Multiple Registers (0x10)" in die Konfiguarion aufgenommen. Ich kann die zugeordnete Variable "AnalogOut0" mit PiTest beschreiben, sehe aber keinen Effekt am Ausgang.

Wenn ich mir die Kommunikation auf dem Bus ansehe, sendet der RevPi zyklisch "4C 10 A5 1E 00 01 02 00 00 39 B7". Das entspricht einem Write an den Slave 76(dez) auf Adresse 42270, 1 Register, 2 Bytes. Aber Value ist "0x 00 00"? Ich habe extra mal auf das analoge Signal getriggert. um zu sehen ob der Ausgang wenigstens kurz auf den per PiTest gesetzten Wert von 2000(dez) , also 2V geht. Aber da passiert nichts. Warum sendet der RevPi nicht dauerhaft den zuletzt per PiTest gesetzten Wert?
MODBUS Frame
MODBUS Frame
scope_59.png (30.8 KiB) Viewed 10470 times
Mit freundlichen Grüßen
Thorsten Ostermann

Re: Modbus Register schreiben

Posted: 27 Jan 2022, 10:28
by crismancich
Hallo Thorsten,

deine Beobachtung deckt sich mit unserer Doku. Read/Write wird vom Master offensichtlich nicht unterstützt:
https://revolutionpi.de/tutorials/modbu ... verwenden/

Wir haben das aufgenommen und an den zuständigen Product Owner weitergeleitet. In dieser Form erhalten die Product Owner Feedback aus dem Feld und entscheiden darüber, welche Features in die Roadmap aufgenommen werden.

Re: Modbus Register schreiben

Posted: 27 Jan 2022, 19:56
by ostermann
Hallo Boris,

Mein letzter Beitrag bezieht sich auf meinen Test mit "WRITE_MULTIPLE_REGISTERS". Das sollte laut Doku unterstützt werden, funktioniert aber offenbar nicht oder nicht so wie ich es erwarten würde. Der Slave kann das, aber der RevPi als Master sendet die Nutzdaten nicht raus?!

Mit freundlichen Grüßen
Thorsten Ostermann

Re: Modbus Register schreiben

Posted: 28 Jan 2022, 09:54
by nicolaiB
Hallo Thorsten,

ich habe das hier gerade mal nachgestellt und kann mit dem FC WRITE_MULTIPLE_REGISTERS Daten übertragen. Um dein Problem genauer zu analysieren bräuchte ich bitte folgende Dinge von deinem Aufbau:

- Log des Modbus Masters (journalctl -u pimodbus-master > dein_modbus_master.log)
- Screenshot deiner Extended Attributes im Pictory

Gruß Nicolai

Re: Modbus Register schreiben

Posted: 28 Jan 2022, 16:14
by ostermann
Hallo Nicolai,

mal vom frisch gebooteten Pi. Schreibversuch über piTest:

Code: Select all

Last login: Wed Jan 26 16:03:46 2022 from 192.168.47.149
pi@RevPi66210:~ $ piTest -w AnalogOut0,2500
Write value 2500 dez (=09c4 hex) to offset 205.
dann noch über den RevPiCommander. Kein Signal am Ausgang messbar. Lesen der Eingangswerte funktioniert ohne Probleme.
2022-01-28 16_05_47-PiCtory - 2.0.4.png
2022-01-28 16_05_47-PiCtory - 2.0.4.png (36.4 KiB) Viewed 10349 times
2022-01-28 16_13_28-64 - ModbusRTU Master.png
2022-01-28 16_13_28-64 - ModbusRTU Master.png (25.46 KiB) Viewed 10349 times
Mit freundlichen Grüßen
Thorsten Ostermann

Re: Modbus Register schreiben

Posted: 02 Feb 2022, 20:44
by ostermann
Das Problem scheint durch das letzte Software-Update behoben zu sein. Ich kann jetzt sowohl einzelne als auch mehrere Register schreiben (Modbus-Kommandos 0x06 bzw. 0x10). Die Schreibzugriffe per piTest werden dann auch im RevPiModIO SPS-Monitor angezeigt und kommen richtig im Slave an. Ich werde das jetzt mal mit einem größeren Satz an Variablen mit höherer Updaterate testen.

Mit freundlichen Grüßen
Thorsten Ostermann

Re: Modbus Register schreiben

Posted: 03 Feb 2022, 09:59
by nicolaiB
Hallo Thorsten,

danke für dein Feedback. Ich bin leider noch nicht dazu gekommen, deinen Aufbau hier nachzustellen. Es freut mich daher zu hören, dass mit unserer aktuellen Software die Probleme behoben sind.

Gruß Nicolai

Re: Modbus Register schreiben

Posted: 06 Feb 2022, 13:07
by ostermann
Hallo Nicolai,

ich muss leider zurückrudern. Alle Versuche, den Satz an übertragenen Variablen zu erhöhen sind bisher fehlgeschlagen. Ich bin inzwischen wieder auf je 3 Register zum Lesen und Schreiben zurück gegangen, aber selbst da meldet der Slave immer wieder Fehler.

Bei einem etwas komplexeren Setup ist mir ein merkwürdiges Verhalten vom Master aufgefallen, was zu Kollisionen auf dem Bus führt. Irgendwas scheint da in der State-Machine nicht zu stimmen?! Der Master wartet nach einem Kommando nicht lange genug auf die Antwort vom Slave, sondern schickt schon nach ca. 600µs das nächste Kommando hinterher. Hier mal ein paar Screenshots vom aufgezeichneten Datentransfer.

Ich hatte vorher versucht, verschiedene Registerzugriffe mit verschiedenen Zykluszeiten zu machen, um den Bus nicht unnötig zu belasten. Dabei ist mir das das erste Mal aufgefallen. Aber auch wenn ich gleiche Refresh-Zeiten konfiguriere, lässt sich das beobachten.

Re: Modbus Register schreiben

Posted: 06 Feb 2022, 13:10
by ostermann
Die Screenshots erscheinen leider in der falschen Reihenfolge. Ganz unten ist die Gesamtansicht. Ich konnte sogar Extremfälle beobachten, wo der nächste Master-Request und die Antwort vom Slave auf den vorherigen Request kollidiert sind. Gemäß Modbus-Spec sollte der Master eigentlich bis zu einem definierten Timeout warten, bevor er den nächsten Request sendet. Wo wird dieser Timeout beim RevPi Modbus Master konfiguriert?

Hier noch die Konfiguration der Zugriffe in PiCtory. Für die Fehlersuche wäre es schön, wenn man einzelne Zeilen über eine Checkbox deaktivieren könnte. Ich habe mir damit geholfen, eine unbelegte Slave-ID einzutragen und das Action-Intervall sehr hoch zu setzen. Aber ab und zu wird da ja trotzdem ein Paket rausgeschickt.

Mit freundlichen Grüßen
Thorsten Ostermann