Vaillant X6 Schnittstelle: Unterschied zwischen den Versionen

Aus Ethersex_Wiki
Wechseln zu: Navigation, Suche
(Befehle)
(Aufbau der Nachrichten)
Zeile 36: Zeile 36:
 
         0x00 Normale Nachrichten
 
         0x00 Normale Nachrichten
 
         0x01 Fehlermeldungen?
 
         0x01 Fehlermeldungen?
         0x02 Broadcast? Verwendet zB. bei der Suche nach angeschlossenen Geräten
+
         0x02 ? - Verwendet bei der Abfrage der Version des Heizgeräts
 +
        0x0a ? - Verwendet bei der Abfrage der Version des Reglers
 
   
 
   
 
  Byte 3  Daten, beinhalten die eigentliche Anforderung an das Gerät, die angeforderten
 
  Byte 3  Daten, beinhalten die eigentliche Anforderung an das Gerät, die angeforderten

Version vom 6. Jänner 2010, 10:36 Uhr

Auf der mit X6 beschrifteten Buchse liegt ein RS232-Signal mit TTL-Pegeln an. Die Geräte kommunizieren mit 9600 Baud (8N1, keine Flusskontrolle). Normalerweise wird über diese Buchse ein PC angeschlossen, auf dem das Programm vrDIALOG ausgeführt wird, oder ein Kommunikationsmodul für das vrNetDIALOG-System.

Belegung

       +---------+
    6  ---       |
GND 5  ---       +--+
TXD 4  ---          |
RXD 3  ---          |
    2  ---       +--+
    1  ---       |
       +---------+

Blick auf die Buchse (!)

Protokoll

Die Kommunikation scheint immer vom angeschlossenen PC (oder Ethersex?) auszugehen. Die Nachrichten in beide Richtungen haben ein ähnliches Format:

Es gibt kein Zeilenende wie CR oder CR+LF.

Aufbau der Nachrichten

Alle Nachrichten haben ein gemeinsames Format:

Bytes
  1     2     3 ... n-1   n
+-----+-----+----    ---+-----+
| Len | ?   | Data      | Chk |
+-----+-----+----    ---+-----+

Byte 1  Gesamtlänge der Nachricht ("n" Bytes, Längenbyte, Nachrichtentyp und Prüfsumme
        sind dabei mitgezählt)

Byte 2  Evtl. sowas wie ein Nachrichtentyp:
        0x00 Normale Nachrichten
        0x01 Fehlermeldungen?
        0x02 ? - Verwendet bei der Abfrage der Version des Heizgeräts
        0x0a ? - Verwendet bei der Abfrage der Version des Reglers

Byte 3  Daten, beinhalten die eigentliche Anforderung an das Gerät, die angeforderten
.. n-1  Werte, oder sonstige Informationen.

Byte n  Prüfsumme, siehe weiter unten

Prüfsumme

Die Berechnung der Prüfsumme ist mir noch nicht klar. Es scheint kein CRC zu sein, sondern eher einen Prüfsumme, die mit unterschiedlichen Gewichten arbeitet.

  • Die gleiche Nachricht hat immer die gleiche Prüfsumme
  • Das vierte Byte der Nachricht scheint ein Gewicht von 1 zu haben:
0x05 0x00 0x00 0x22 0x0A
0x05 0x00 0x00 0x23 0x0B
0x05 0x00 0x00 0x24 0x0C

Befehle

Alle bisher bekannten Befehlsnachrichten sind 7 Byte lang, Nach Abzug des Headers und der Prüfsumme bleiben demnach 4 Bytes für den eigentlichen Befehl.

07 02 00 00 00 04 C4

Fragt nach angeschlossenen Geräten? In meinem Fall meldet das Gerät anscheinend seine Versionsnummer, die von vrDialog als "0153_07.00" angezeigt wird:

08 00 00 99 07 00 14 96

07 00 00 00 01 02 E0

Fragt Sollwert Brauchwassertemperatur ab. Der Temperaturwert ist in den Bytes 3 und 4 wie unten beschrieben kodiert (hier: 35°C)

05 00 02 30 1C

Kodierung von Werten

Temperaturen

Temperaturen scheinen immer auf gleiche Weise kodiert zu sein. Das zuerst gesendete Byte ist das höherwertige Byte. Der erhaltene Zahlenwert entspricht der Temperatur in 1/16°C.

Beispiel

0230h = 560d  =>  560/16 °C = 35 °C

Wahrheitswerte

0F = An
F0 = Aus