VBus-Decoder: Unterschied zwischen den Versionen

Aus Hobbyelektronik.org
K (FAQ hinzugefügt)
(44 dazwischenliegende Versionen von 2 Benutzern werden nicht angezeigt)
Zeile 1: Zeile 1:
 
[[Bild:Vbus regler.jpg|thumb|Das Corpus Delicti]]
 
[[Bild:Vbus regler.jpg|thumb|Das Corpus Delicti]]
{{Infobox AVR
+
Bei der Solaranlage meiner Eltern übernimmt ein Viessmann Vitosolic 200 die Regelung.  
| Typ  = ATmega32
 
| Takt  = 12
 
| FuseH = CF
 
| FuseL = FF
 
}}
 
In unserer Solaranlage arbeitet ein Viessmann Vitosolic 200, der die Regelung der Anlage übernimmt.
 
 
Nach kurzer Recherche stellte sich heraus, dass es sich um eine etwas angepasste Version des [http://www.resol.de/index/produktdetail/kategorie/1/id/9/sprache/de RESOL DeltaSol® M] handelt.
 
Nach kurzer Recherche stellte sich heraus, dass es sich um eine etwas angepasste Version des [http://www.resol.de/index/produktdetail/kategorie/1/id/9/sprache/de RESOL DeltaSol® M] handelt.
  
Statt der RS232-Schnittstelle hat das Teil einen Anschluss für den Viessmann-eigenen KM-Bus, zu dem keinerlei Informationen verfügbar sind.
+
Statt der RS-232-Schnittstelle hat das Teil einen Anschluss für den Viessmann-eigenen KM-Bus, zu dem mir keinerlei Informationen bekannt sind.
  
Beim VBus sieht es schon ein wenig anders aus. In der [http://www.mikrocontroller.net/topic/96431 Diskussion] auf Mikrocontroller.net bin ich auf den Beitrag von [http://www.mikrocontroller.net/topic/96431#1231974 Daniel Wippermann] gestoßen, woraufhin ich an die angegebene Adresse eine E-Mail geschickt habe.  
+
Beim VBus sieht es deutlich besser aus. In der [http://www.mikrocontroller.net/topic/96431 Diskussion] auf Mikrocontroller.net bin ich auf den Beitrag von [http://www.mikrocontroller.net/topic/96431#1231974 Daniel Wippermann] gestoßen, woraufhin ich an die angegebene Adresse eine E-Mail geschickt habe.  
  
 
Keine zweieinhalb Stunden später habe ich die Dokumentation (inklusive der Erlaubnis zur Veröffentlichung, siehe Download) zum Protokolls erhalten.
 
Keine zweieinhalb Stunden später habe ich die Dokumentation (inklusive der Erlaubnis zur Veröffentlichung, siehe Download) zum Protokolls erhalten.
  
=Hardwareschnittstelle=
+
Irgendwann nach der Erstveröffentlichung dieses Artikels entstand eine deutlich erweiterte Dokumentation auf den [https://danielwippermann.github.io/resol-vbus/vbus-specification.html Github-Seiten von Daniel Wippermann]. Nicht nur das, sondern auch eine Implementierung des Protokolls in Javascript.
 +
 
 +
=Hardware-Schnittstelle=
 
[[Bild:Resol sch.png|thumb|Wo Rx und Tx ist, muss erraten werden ;)]]
 
[[Bild:Resol sch.png|thumb|Wo Rx und Tx ist, muss erraten werden ;)]]
Bei dem VBus handelt es sich um eine bidirektionale halbduplex Zweidrahtschnittstelle, die zwar Ähnlichkeiten zu RS485 hat, diesem aber nicht entspricht.
+
Bei dem VBus handelt es sich um eine bidirektionale halbduplex Zweidrahtschnittstelle, die - entgegen mancher Meinungen - überhaupt keine Ähnlichkeiten mit RS-485 hat.
 +
 
 +
'''Bei ein paar Reglern scheint Resol eine RS-485-Schnittstelle mit VBus-Protokoll zu verwenden, die mit den hier vorgestellten Schaltungen nicht kompatibel ist. Bitte vor dem Nachbau der Hardware prüfen, um welches System es sich handelt. Das kann entweder durch das Anleitung erfolgen (Angabe der Spannung und Strom, bei RS-485 ist üblicherweise keine Stromversorgung) oder durch Nachmessen: An den VBus-Klemmen sollte eine (zappelnde) Spannung von etwa 8 V anliegen.'''
  
Der Master (Regel-Einheit) versorgt den Bus mit etwa 8,2V und 35mA (S. 4 in der Doku). Die Daten werden durch Spannungsabsenkung auf dem Bus übertragen.
+
Der Master (Regel-Einheit) versorgt den Bus mit etwa 8,2 V und 35 mA (S. 4 in der Doku). Die Daten werden durch Spannungsabsenkung auf dem Bus übertragen.
 
Mit der Schaltung auf Seite 5 des PDFs kann auf dem Bus sowohl gelesen, als auch geschrieben werden. Im Bild rechts meine Interpretation der Schaltung (in der noch die Abblockkondensatoren fehlen).
 
Mit der Schaltung auf Seite 5 des PDFs kann auf dem Bus sowohl gelesen, als auch geschrieben werden. Im Bild rechts meine Interpretation der Schaltung (in der noch die Abblockkondensatoren fehlen).
  
Über die Buchse links kann man sich mit UART (nicht RS232!) mit 9600 Baud, 8 Datenbits, 1 Stoppbit ohne Parität mit dem Master unterhalten.
+
Über die Buchse links kann man sich mit UART (nicht RS-232!) mit 9600 Baud, 8 Datenbits, 1 Stoppbit ohne Parität mit dem Master unterhalten.
  
Der in meiner Schaltung verwendete FET für die bidirektionale Kommunikation ist übrigens ein BS170
+
Der in meiner Schaltung verwendete FET für die bidirektionale Kommunikation ist übrigens ein BS170; wobei der Typ nicht kritisch ist, solange er den Bus kurzschließen kann, ohne dabei in Rauch aufzugehen.
  
 
=Protokoll=
 
=Protokoll=
Zeile 30: Zeile 28:
  
 
Folgendes Daten habe ich zum Testen verwendet:
 
Folgendes Daten habe ich zum Testen verwendet:
<pre>
 
0xAA, 0x10, 0x00, 0x21, 0x73, 0x10, 0x00, 0x01, 0x12, 0x38,
 
0x5E, 0x04, 0x5E, 0x01, 0x05, 0x39
 
0x45, 0x01, 0x38, 0x22, 0x04, 0x5B
 
0x38, 0x22, 0x38, 0x22, 0x05, 0x46
 
0x6C, 0x01, 0x38, 0x22, 0x05, 0x33
 
0x38, 0x22, 0x38, 0x22, 0x05, 0x46
 
0x38, 0x22, 0x38, 0x22, 0x05, 0x46
 
0x00, 0x00, 0x00, 0x00, 0x00, 0x7F
 
0x00, 0x00, 0x00, 0x00, 0x00, 0x7F
 
0x00, 0x00, 0x00, 0x00, 0x00, 0x7F
 
0x38, 0x0F, 0x00, 0x00, 0x01, 0x37
 
0x47, 0x00, 0x00, 0x00, 0x00, 0x38
 
0x64, 0x64, 0x00, 0x00, 0x00, 0x37
 
0x00, 0x00, 0x00, 0x00, 0x00, 0x7F
 
0x00, 0x00, 0x00, 0x00, 0x00, 0x7F
 
0x00, 0x00, 0x43, 0x00, 0x00, 0x3C
 
0x00, 0x00, 0x02, 0x00, 0x00, 0x7D
 
0x01, 0x03, 0x60, 0x02, 0x04, 0x15
 
0x02, 0x00, 0x00, 0x00, 0x00, 0x7D
 
</pre>
 
  
Zu allererst wird ein 10 Byte langer Kopf gesendet, der mit einem eindeutigen Sync-Wort (0xAA) beginnt. Eindeutig heißt: An keiner anderen Stelle im Protokoll wird das MSB belegt. Man kann sich also zu jedem beliebigen Zeitpunkt in den Bus einklinken!
+
<code>
 +
<span class="he0"><span class="hb1">0xAA</span>, <span class="hb2">0x10, 0x00</span>, <span class="hb3">0x21, 0x73</span>, <span class="hb4">0x10</span>, <span class="hb5">0x00, 0x01</span>, <span class="hb6">0x12</span>, <span class="hb7">0x38</span></span>, <br />
 +
0x5E, 0x04, 0x5E, 0x01, 0x05, 0x39, <br />
 +
0x45, 0x01, 0x38, 0x22, 0x04, 0x5B, <br />
 +
0x38, 0x22, 0x38, 0x22, 0x05, 0x46, <br />
 +
0x6C, 0x01, 0x38, 0x22, 0x05, 0x33, <br />
 +
0x38, 0x22, 0x38, 0x22, 0x05, 0x46, <br />
 +
0x38, 0x22, 0x38, 0x22, 0x05, 0x46, <br />
 +
0x00, 0x00, 0x00, 0x00, 0x00, 0x7F, <br />
 +
0x00, 0x00, 0x00, 0x00, 0x00, 0x7F, <br />
 +
0x00, 0x00, 0x00, 0x00, 0x00, 0x7F, <br />
 +
0x38, 0x0F, 0x00, 0x00, 0x01, 0x37, <br />
 +
0x47, 0x00, 0x00, 0x00, 0x00, 0x38, <br />
 +
0x64, 0x64, 0x00, 0x00, 0x00, 0x37, <br />
 +
0x00, 0x00, 0x00, 0x00, 0x00, 0x7F, <br />
 +
0x00, 0x00, 0x00, 0x00, 0x00, 0x7F, <br />
 +
0x00, 0x00, 0x43, 0x00, 0x00, 0x3C, <br />
 +
0x00, 0x00, 0x02, 0x00, 0x00, 0x7D, <br />
 +
0x01, 0x03, 0x60, 0x02, 0x04, 0x15, <br />
 +
0x02, 0x00, 0x00, 0x00, 0x00, 0x7D, <br />
 +
</code>
 +
 
 +
Zu allererst wird ein <span class="he0">10 Byte langer Kopf</span> gesendet, der mit einem eindeutigen <span class="hb1">Sync-Wort (0xAA)</span> beginnt. Eindeutig heißt: An keiner anderen Stelle im Protokoll wird dieses Zeichen verwendet (bzw. das MSB belegt). Man kann sich also zu jedem beliebigen Zeitpunkt in den Bus einklinken!
 +
 
 +
Gefolgt vom Sync-Wort kommen <span class="hb2">Ziel-</span> und <span class="hb3">Quelladresse</span> (<span class="hb2">0x0010</span> <= <span class="hb3">0x7321</span>), <span class="hb4">die Protokollversion (0x10)</span>, der <span class="hb5">ausgeführte Befehl (0x0100)</span> und die Anzahl der danach folgenden <span class="hb6">Nutzdatenframes (0x12)</span>. Abschließend wird eine <span class="hb7">Prüfsumme (0x38)</span> der zuvor gesendeten Daten übertragen.
 +
 
 +
Im Anschluss an den Header wird die im Header angegebene <span class="hb6">Anzahl an Datenframes</span> mit je 6 Byte Länge geschickt (Auszug von oben):
 +
 
 +
<code>
 +
<span class="hb1">0x5E, 0x04, 0x5E, 0x01</span>, <span class="hb2">0x05</span>, <span class="hb3">0x39</span>,
 +
</code>
  
Gefolgt vom Sync-Wort kommen Ziel- und Quelladresse (0x0010 <= 0x7321), die Protokollversion (0x10), der ausgeführte Befehl (0x0100) und die Anzahl der danach folgenden Nutzpakete (0x12). Abschließend wird eine Prüfsumme (0x38) der zuvor gesendeten Daten übertragen.
+
Die ersten 4 enthalten <span class="hb1">Nutzdaten</span>, im 5. wird ein <span class="hb2">Septett</span> geschickt und abschließend erfolgt wieder eine <span class="hb3">Prüfsumme</span>.
  
Im Anschluss des Headers werden n Datenframes mit je 6 Byte Länge geschickt. Die ersten 4 enthalten Nutzdaten, im 5. wird ein Septett geschickt und abschließend erfolgt wieder eine Checksum.
+
Das Septett ist eine Ergänzung der zuvor gesendeten Nutzdaten. Da, wie oben erwähnt, das MSB nur im Sync-Wort vorkommen darf, ist es für die folgende Daten kein verboten - dieses findet sich jeweils in diesem zusätzlichen Byte.
  
Das Septett ist eine Ergänzung der zuvor gesendeten Nutzdaten. Da, wie oben erwähnt, das MSB nur im Sync-Wort vorkommen kann, dürfen folgende Daten kein höchstwertiges Bit enthalten. Dieses findet sich jeweils im Septett.
+
Die Prüfsumme der einzelnen Nachrichtenteile wird mittels CRC8 berechnet.
  
Das ist auch schon das gröbste.
+
Das ist auch schon das Gröbste.
 
Mit Protokollversion 2.0 und 3.0 habe ich mich noch nicht auseinandergesetzt, da diese zum Erfassen der Messwerte nicht benötigt werden.
 
Mit Protokollversion 2.0 und 3.0 habe ich mich noch nicht auseinandergesetzt, da diese zum Erfassen der Messwerte nicht benötigt werden.
  
==Hintergrund==
+
==Adressen==
Noch eine kleine Hintergrundinformation, worum es sich bei der Ziel- und Quell-Adresse handelt.
+
Wie in vielen Bussystemen verwendet auch der VBus Pakete für die Nachrichten. Zu den Informationen in der PDF-Spezifikation sei an der Stelle auch auf die [https://danielwippermann.github.io/resol-vbus/vbus-packets.html Paketbeschreibung] verwiesen.
  
Die Quelladresse ist selbstverständlich der Regler (0x7321 = Vitosolic 200 [Regler]), die Zieladresse (0x0010) wird in der kompletten Dokumentation nur als DFA beschrieben. Dabei handelt es sich nicht um eine komische Umschreibung für einen Broadcast, sondern um die Daten für ein zusätzliches Gerät, der '''D'''aten'''f'''ern'''a'''nzeige.
+
Die für den bei uns eingesetzten Regler lautet die Adresse 0x7321 (Vitosolic 200 [Regler]), die für das Logging relevanten Daten gehen an 0x0010 und werden in der Dokumentation lediglich als DFA beschrieben. Dabei handelt es sich nicht um eine komische Umschreibung für einen Broadcast, sondern um die Daten für ein zusätzliches Gerät - der Datenfernanzeige.
  
 
An diese sendet der Regler alle von ihm gemessenen Werte. Neben der Regler-Identität hat der Vitosolic 200 noch die Identitäten WMZ1 und WM2 (Wärmemengenzähler).
 
An diese sendet der Regler alle von ihm gemessenen Werte. Neben der Regler-Identität hat der Vitosolic 200 noch die Identitäten WMZ1 und WM2 (Wärmemengenzähler).
  
=Software=
+
=Hardware=
Die Software ist, wie immer, in C geschrieben.
+
Im Laufe der Zeit haben sich mehrere Schaltungen ergeben. Um diesen Artikel übersichtlich zu halten, wurden die verschiedenen Varianten auf Unterseiten aufgeteilt:
Über den Befehl Vbus_ProcessChar() kann ein Zeichen von der seriellen Schnittstelle übergeben werden. Im einfachsten Fall kann die ISR-Routine wie folgt aussehen:
 
  
<pre>
+
(Die Links zu den Unterseiten sind befinden sich jeweils in den Überschriften)
ISR (USART_RXC_vect) {
 
Vbus_ProcessChar(UDR);
 
}
 
</pre>
 
  
Vorher muss noch der UART initialisiert werden (9600 8N1, sei() nicht vergessen!).
+
==[[VBus-Decoder/Adapter für RS-232|Adapter für RS-232]]==
 +
Wenn man noch einen PC oder Adapter hat der RS-232 spricht, kann sich dieser Hardware bedienen.
  
Die empfangenen und dekodierten Daten werden in der Variable vbus_outdata gespeichert.
+
Der Zugriff ist nur lesend möglich und es gibt keine galvanische Trennung zwischen Bus und DTE.
In dieser Variable muss auch angegeben werden, ob ein Paket gelesen werden soll:
 
<pre>
 
vbus_outdata.update = 1;
 
</pre>
 
  
Ist ein Paket vollständig angekommen, wird die valid-Eigenschaft auf 1 gesetzt. Im Demo-Code wird nach erfolgreichem Empfang das komplette Datenpaket am UART ausgegeben (bitte nicht an den Regler zurückschicken, sondern möglichst an den PC!):
+
<gallery>
 +
  Bild:Vbus_rxo_brd.png|thumb|Layout der PC-Hardware
 +
</gallery>
  
<pre>
+
==[[VBus-Decoder/Adapter Nano|Adapter Nano]]==
int main() {
+
Die vermutlich universellste Variante - schön klein, galvanische Trennung und funktioniert auf der Empfängerseite ab 3,3 V.
  
   ...
+
<gallery>
 +
   resol_nano_0.1_assy.jpg|Bestückte Leiterkarte
 +
</gallery>
  
  while(1) {
+
==[[VBus-Decoder/Adapter für den Raspberry Pi|Adapter für den Raspberry Pi]]==
    if(vbus_outdata.valid == 1) {
+
Wer Geräte ins Netzwerk bringen will, hat meistens auch einen Einplatinencomputer der Raspberry Pi Foudation auf der Liste.
      vbus_outdata.valid = 0;
 
      VBus_Show_Values();
 
      vbus_outdata.update = 1;
 
    }
 
  }
 
}
 
</pre>
 
  
 +
<gallery>
 +
    Vbuspi 1.0 bare.jpg|Unbestückte Leiterkarte (v1.0)
 +
    Vbuspi 1.1 assy zero.jpg|Bestückte Leiterkarte auf einem Raspberry Pi Zero W
 +
</gallery>
  
 +
Achtung: Es ist empfehlenswert, entweder [[VBus-Decoder/Adapter_für_den_Raspberry_Pi_v1.3|Version 1.3]] oder zumindest [[VBus-Decoder/Adapter_für_den_Raspberry_Pi#Die Enttäuschung - Teil 2|1.2b]] nachzubauen.
  
==Debug-Ausgabe==
+
==[[VBus-Decoder/Adapter für den ESP8266|Adapter für den ESP8266]]==
[[Bild:Vbus debug.jpg|thumb|Anzeige auf dem Display. die ICs unten und rechts gehören nicht zur Schaltung]]
+
Noch etwas kleiner als für den Raspberry Pi: Ein Adapter mit ESP8266-Modulen.
Der Debug in der Software gibt einige Informationen zur Dekodierung auf einem LC-Display aus.
 
  
Dieser Modus kann in der Datei vbus.h Zeile 35 aktiviert werden (standardmäßig deaktiviert).
+
<gallery>
 +
    vbusesp_top.jpg|Bestückte Leiterkarte
 +
</gallery>
  
Über UART würde eine Ausgabe kaum sinn machen, da man durch das langsame Senden den Empfang der Daten verpasst.
+
==[[VBus-Decoder/Adapter_Nano#Troubleshooting|Troubleshooting]]==
 +
Für die Schaltung des Adapter Nano gibt es eine Troubleshooting-Anleitung, die in Teilen auch für die 5 V-Version der Raspberry-Pi-Variante gültig ist.
  
Zugegebenermaßen: ich habe einen Exoten mit LC7980-Controller und einer Auflösung von 240x40 Pixel verwendet. Die Routinen lassen sich aber halbwegs einfach auf einen anderen Displaycontroller anpassen.
+
=[[VBus-Decoder/FAQ|FAQ]]=
Die Ausgabe auf dem Display sieht wie folgt aus:
+
(bitte auf die Überschrift klicken)
  
Bei jedem Erhalt eines Sync-Wortes wird "Sync" angezeigt.
+
=Software=
 
+
==[[VBus-Decoder/AVR8-Software|AVR8]]==
Wurde der Head empfangen, wird der Displayinhalt gelöscht und folgendes ausgegeben:
+
Zur Datenauswertung und für einfache, zusätzliche, Regelaufgaben (wie zum Beispiel Deaktivieren der Heizung, wenn die Solaranlage den Speicher belädt) - oder um die Anlage ins Internet of Things zu bekommen sind Mikrocontroller sehr geeignete Komponenten.
 
 
<pre>
 
D:<Ziel-Adresse> S:<Quell-Adresse> V:<Protokoll-Version> C:<Befehl> F:<Anzahl Frames> X:<Prüfsumme ok|nok>
 
</pre>
 
  
Danach wird, wenn die Prüfsumme ok ist jedoch das falsche Protokoll angegeben wurde, die Meldung "!V1.0->dropped " ausgegeben.
+
Eine Implementierung für die [[VBus-Decoder/AVR8-Software|AVR8-Plattform]] findet sich auf der entsprechenden Unterseite.
Hat das Paket das "falsche" Adress-Pärchen, wird "Wrong addr->dropped " angezeigt.
 
  
Kommen diese beiden Meldungen nicht, werden Informationen über die dekodierten Frames ausgegeben:
+
==Python==
 +
Nicki hat sich die Arbeit gemacht und einen Code zum Auswerten der Nachrichten in Python portiert. Ich hatte selbst noch keine gute Gelegenheit, ihn zu testen - daher ohne Garantie, Gewährleistung oder Support:
  
<pre>
+
* [[Datei:VBus-Python.zip]]
F<Frame-Index><Prüfsumme ok|nok>
 
</pre>
 
  
Nachdem alle Frames empfangen wurden, wird ein "AFR" (all frames received) ausgegeben
+
Oliver hat basierend auf dem Code von Nicki eine Schnittstelle zur [https://www.volkszaehler.org/ Volkszähler]-Middleware gebaut:
  
Im Ganzen kann solch eine Ausgabe wie folgt aussehen:
 
 
<pre>
 
<pre>
Sync [Display wird geleert]
+
Der Code nutzt die Resol-Decoder-Lib von Nicki, die ist auch mit dabei.
D:0x0010 S:0x7321 V:1 C:0x0100 F:18 X:ok F0ok F1ok F2ok F3ok F4ok F5ok F6ok F7ok F8ok F9nok F10ok F11ok F12ok F13ok F14nok F15ok F16ok F17ok AFR
+
In der config.py stellt man die Adresse der Middleware in seinem Netzwerk,
 +
sowie die UUID der Kanäle ein, damit man die Daten referenzieren kann.
 +
(Zum Test kann man auch simulierte Daten nutzen, oder die Ausgabe in ein File schreiben lassen)
 
</pre>
 
</pre>
  
Gleiches Beispiel mit meinen Testdaten, nur dass hier (im Gegensatz zu den Daten!!) Frame 9 und 14 ungültig sind.
+
* [[Datei:Vbus_volkszaehler.zip]]
 
 
==Zuordnung der Datenfelder==
 
Die Zuordnung der empfangenen Daten kann man relativ einfach zu den entsprechenden Feldern zuordnen.
 
 
 
Im der Datei %ProgramFiles%\RESOL\ServiceCenterFull\eclipse\plugins\de.resol.servicecenter.vbus.<Device>\VBusSpecification<Device>.xml
 
 
 
findet man alle Zuordnungen der Felder. Achtung: es kann Lücken geben - dadurch sind in meinem Code die "unknown"-Felder entstanden.
 
 
 
==Bekannte Fehler/Macken==
 
[[Bild:Vbus_putty_vs_rss.png|thumb|Daten meiner Auswertung (links) und die des Resol ServiceCenters]]
 
<strike>Manche Felder sind falsch oder an der falschen Stelle. Im Vergleich zum Resol ServiceCenter (in Klammern) ergibt sich folgendes:</strike>
 
*<strike>Temperatursensor 12 zeigt 0.0 an (888.8 - unbelegt)</strike>
 
** Grund war, dass ich zählen konnte. (0-12 anstatt 0-11 bzw. 1-12)
 
*<strike>Sensorbruchsmaske ist 0 (4024)</strike>
 
**Offset des Feldes war falsch
 
*<strike>Sensorkurzschlussmaske und Sensorbenutzungsmaske sind vertauscht</strike>
 
**wie oben
 
*<strike>Negative Temperaturen werden falsch angezeigt (kann aber auch an itoa liegen)</strike>
 
**Hätte schon funktioniert, wenn man allerdings die Zahl vor itoa durch 10 teilt... (jetzt wird es richtig angezeigt, da vorher ein Zweierkomplement gemacht wird)
 
 
 
Folgendes wurde noch nicht getestet/ist unbekannt:
 
*Einstrahlung
 
*Werte hinter der Fehler- & Warnungsmaske (muss ich noch in den XML-Dateien nachlesen)
 
*Unbekannt-Felder
 
** anscheinend immer 0x00
 
*Woher kommt der Wochentag bei der Systemzeit
 
  
Verbesserungswürdig an der Software:
+
==Protokoll-Analysator==
*RAM-Belegung
 
*<strike>Ziel der Daten (vbus_outdata) durch Pointer definierbar</strike>
 
**erledigt
 
*Unterstützung der weiteren Protokolle (Parametrisierung - werde ich aber vermutlich nicht in absehbarer Zeit implementieren)
 
*Es ist nicht ersichtlich, welche Daten durch Prüfsummenfehler ungültig sind
 
  
=Download=
+
Da es mehrere Anfragen zur Untersuchung des Protokolls gab, habe ich vor einer Weile einen kleinen Protokollanalysator zusammengestrickt. Dieser unterstützt aktuell Protokollversion 1.0 und ist als "gefährliche Beta" anzusehen: [https://hobbyelektronik.org/tools/vbus-analyzer/ Resol Protocol Analyzer]
  
*[[Datei:VBus-Protokollspezifikation.pdf]] Stand: 20.04.2009
+
=Downloads=
*[[Datei:VbusDecode.zip]] Version 0.2beta vom 09.03.2010 ATmega32 @ 12MHz
+
* [[Datei:VBus-Protokollspezifikation.pdf]] Stand: 20.04.2009
 +
* (Die Downloads für die Hardware befindet sich auf der jeweiligen Unterseite)
  
 
'''An dieser Stelle noch einmal vielen Dank an Resol für die Bereitstellung der Informationen und die Erlaubnis, diese hier weiter zu verteilen!'''
 
'''An dieser Stelle noch einmal vielen Dank an Resol für die Bereitstellung der Informationen und die Erlaubnis, diese hier weiter zu verteilen!'''
Zeile 189: Zeile 157:
 
* [http://www.resol.de RESOL - Elektronische Regelungen GmbH]
 
* [http://www.resol.de RESOL - Elektronische Regelungen GmbH]
 
* [http://www.resol.de/index/produktdetail/kategorie/1/id/9/sprache/de DeltaSol® M] Regler, der dem Viessmann Vitosolic 200 "alt" in ziemlich genau entspricht
 
* [http://www.resol.de/index/produktdetail/kategorie/1/id/9/sprache/de DeltaSol® M] Regler, der dem Viessmann Vitosolic 200 "alt" in ziemlich genau entspricht
 
+
* [https://danielwippermann.github.io/resol-vbus Github-Seiten von Daniel Wippermann]
=[[VBus-Decoder/FAQ|FAQ]]=
 
(bitte auf die Überschrift klicken)
 
  
 
[[Kategorie:AVR]]
 
[[Kategorie:AVR]]
[[Kategorie:Maschinen]]
+
[[Kategorie:Energieerfassung]]
 +
[[Kategorie:Solaranlage]]
 +
[[Kategorie:VBus]]

Version vom 13. Dezember 2021, 21:51 Uhr

Das Corpus Delicti

Bei der Solaranlage meiner Eltern übernimmt ein Viessmann Vitosolic 200 die Regelung. Nach kurzer Recherche stellte sich heraus, dass es sich um eine etwas angepasste Version des RESOL DeltaSol® M handelt.

Statt der RS-232-Schnittstelle hat das Teil einen Anschluss für den Viessmann-eigenen KM-Bus, zu dem mir keinerlei Informationen bekannt sind.

Beim VBus sieht es deutlich besser aus. In der Diskussion auf Mikrocontroller.net bin ich auf den Beitrag von Daniel Wippermann gestoßen, woraufhin ich an die angegebene Adresse eine E-Mail geschickt habe.

Keine zweieinhalb Stunden später habe ich die Dokumentation (inklusive der Erlaubnis zur Veröffentlichung, siehe Download) zum Protokolls erhalten.

Irgendwann nach der Erstveröffentlichung dieses Artikels entstand eine deutlich erweiterte Dokumentation auf den Github-Seiten von Daniel Wippermann. Nicht nur das, sondern auch eine Implementierung des Protokolls in Javascript.

Hardware-Schnittstelle

Wo Rx und Tx ist, muss erraten werden ;)

Bei dem VBus handelt es sich um eine bidirektionale halbduplex Zweidrahtschnittstelle, die - entgegen mancher Meinungen - überhaupt keine Ähnlichkeiten mit RS-485 hat.

Bei ein paar Reglern scheint Resol eine RS-485-Schnittstelle mit VBus-Protokoll zu verwenden, die mit den hier vorgestellten Schaltungen nicht kompatibel ist. Bitte vor dem Nachbau der Hardware prüfen, um welches System es sich handelt. Das kann entweder durch das Anleitung erfolgen (Angabe der Spannung und Strom, bei RS-485 ist üblicherweise keine Stromversorgung) oder durch Nachmessen: An den VBus-Klemmen sollte eine (zappelnde) Spannung von etwa 8 V anliegen.

Der Master (Regel-Einheit) versorgt den Bus mit etwa 8,2 V und 35 mA (S. 4 in der Doku). Die Daten werden durch Spannungsabsenkung auf dem Bus übertragen. Mit der Schaltung auf Seite 5 des PDFs kann auf dem Bus sowohl gelesen, als auch geschrieben werden. Im Bild rechts meine Interpretation der Schaltung (in der noch die Abblockkondensatoren fehlen).

Über die Buchse links kann man sich mit UART (nicht RS-232!) mit 9600 Baud, 8 Datenbits, 1 Stoppbit ohne Parität mit dem Master unterhalten.

Der in meiner Schaltung verwendete FET für die bidirektionale Kommunikation ist übrigens ein BS170; wobei der Typ nicht kritisch ist, solange er den Bus kurzschließen kann, ohne dabei in Rauch aufzugehen.

Protokoll

Das Protokoll des VBus ist in seiner Version 1.0 ziemlich gut handzuhaben.

Folgendes Daten habe ich zum Testen verwendet:

0xAA, 0x10, 0x00, 0x21, 0x73, 0x10, 0x00, 0x01, 0x12, 0x38,
0x5E, 0x04, 0x5E, 0x01, 0x05, 0x39,
0x45, 0x01, 0x38, 0x22, 0x04, 0x5B,
0x38, 0x22, 0x38, 0x22, 0x05, 0x46,
0x6C, 0x01, 0x38, 0x22, 0x05, 0x33,
0x38, 0x22, 0x38, 0x22, 0x05, 0x46,
0x38, 0x22, 0x38, 0x22, 0x05, 0x46,
0x00, 0x00, 0x00, 0x00, 0x00, 0x7F,
0x00, 0x00, 0x00, 0x00, 0x00, 0x7F,
0x00, 0x00, 0x00, 0x00, 0x00, 0x7F,
0x38, 0x0F, 0x00, 0x00, 0x01, 0x37,
0x47, 0x00, 0x00, 0x00, 0x00, 0x38,
0x64, 0x64, 0x00, 0x00, 0x00, 0x37,
0x00, 0x00, 0x00, 0x00, 0x00, 0x7F,
0x00, 0x00, 0x00, 0x00, 0x00, 0x7F,
0x00, 0x00, 0x43, 0x00, 0x00, 0x3C,
0x00, 0x00, 0x02, 0x00, 0x00, 0x7D,
0x01, 0x03, 0x60, 0x02, 0x04, 0x15,
0x02, 0x00, 0x00, 0x00, 0x00, 0x7D,

Zu allererst wird ein 10 Byte langer Kopf gesendet, der mit einem eindeutigen Sync-Wort (0xAA) beginnt. Eindeutig heißt: An keiner anderen Stelle im Protokoll wird dieses Zeichen verwendet (bzw. das MSB belegt). Man kann sich also zu jedem beliebigen Zeitpunkt in den Bus einklinken!

Gefolgt vom Sync-Wort kommen Ziel- und Quelladresse (0x0010 <= 0x7321), die Protokollversion (0x10), der ausgeführte Befehl (0x0100) und die Anzahl der danach folgenden Nutzdatenframes (0x12). Abschließend wird eine Prüfsumme (0x38) der zuvor gesendeten Daten übertragen.

Im Anschluss an den Header wird die im Header angegebene Anzahl an Datenframes mit je 6 Byte Länge geschickt (Auszug von oben):

0x5E, 0x04, 0x5E, 0x01, 0x05, 0x39,

Die ersten 4 enthalten Nutzdaten, im 5. wird ein Septett geschickt und abschließend erfolgt wieder eine Prüfsumme.

Das Septett ist eine Ergänzung der zuvor gesendeten Nutzdaten. Da, wie oben erwähnt, das MSB nur im Sync-Wort vorkommen darf, ist es für die folgende Daten kein verboten - dieses findet sich jeweils in diesem zusätzlichen Byte.

Die Prüfsumme der einzelnen Nachrichtenteile wird mittels CRC8 berechnet.

Das ist auch schon das Gröbste. Mit Protokollversion 2.0 und 3.0 habe ich mich noch nicht auseinandergesetzt, da diese zum Erfassen der Messwerte nicht benötigt werden.

Adressen

Wie in vielen Bussystemen verwendet auch der VBus Pakete für die Nachrichten. Zu den Informationen in der PDF-Spezifikation sei an der Stelle auch auf die Paketbeschreibung verwiesen.

Die für den bei uns eingesetzten Regler lautet die Adresse 0x7321 (Vitosolic 200 [Regler]), die für das Logging relevanten Daten gehen an 0x0010 und werden in der Dokumentation lediglich als DFA beschrieben. Dabei handelt es sich nicht um eine komische Umschreibung für einen Broadcast, sondern um die Daten für ein zusätzliches Gerät - der Datenfernanzeige.

An diese sendet der Regler alle von ihm gemessenen Werte. Neben der Regler-Identität hat der Vitosolic 200 noch die Identitäten WMZ1 und WM2 (Wärmemengenzähler).

Hardware

Im Laufe der Zeit haben sich mehrere Schaltungen ergeben. Um diesen Artikel übersichtlich zu halten, wurden die verschiedenen Varianten auf Unterseiten aufgeteilt:

(Die Links zu den Unterseiten sind befinden sich jeweils in den Überschriften)

Adapter für RS-232

Wenn man noch einen PC oder Adapter hat der RS-232 spricht, kann sich dieser Hardware bedienen.

Der Zugriff ist nur lesend möglich und es gibt keine galvanische Trennung zwischen Bus und DTE.

Adapter Nano

Die vermutlich universellste Variante - schön klein, galvanische Trennung und funktioniert auf der Empfängerseite ab 3,3 V.

Adapter für den Raspberry Pi

Wer Geräte ins Netzwerk bringen will, hat meistens auch einen Einplatinencomputer der Raspberry Pi Foudation auf der Liste.

Achtung: Es ist empfehlenswert, entweder Version 1.3 oder zumindest 1.2b nachzubauen.

Adapter für den ESP8266

Noch etwas kleiner als für den Raspberry Pi: Ein Adapter mit ESP8266-Modulen.

Troubleshooting

Für die Schaltung des Adapter Nano gibt es eine Troubleshooting-Anleitung, die in Teilen auch für die 5 V-Version der Raspberry-Pi-Variante gültig ist.

FAQ

(bitte auf die Überschrift klicken)

Software

AVR8

Zur Datenauswertung und für einfache, zusätzliche, Regelaufgaben (wie zum Beispiel Deaktivieren der Heizung, wenn die Solaranlage den Speicher belädt) - oder um die Anlage ins Internet of Things zu bekommen sind Mikrocontroller sehr geeignete Komponenten.

Eine Implementierung für die AVR8-Plattform findet sich auf der entsprechenden Unterseite.

Python

Nicki hat sich die Arbeit gemacht und einen Code zum Auswerten der Nachrichten in Python portiert. Ich hatte selbst noch keine gute Gelegenheit, ihn zu testen - daher ohne Garantie, Gewährleistung oder Support:

Oliver hat basierend auf dem Code von Nicki eine Schnittstelle zur Volkszähler-Middleware gebaut:

Der Code nutzt die Resol-Decoder-Lib von Nicki, die ist auch mit dabei.
In der config.py stellt man die Adresse der Middleware in seinem Netzwerk, 
sowie die UUID der Kanäle ein, damit man die Daten referenzieren kann.
(Zum Test kann man auch simulierte Daten nutzen, oder die Ausgabe in ein File schreiben lassen)

Protokoll-Analysator

Da es mehrere Anfragen zur Untersuchung des Protokolls gab, habe ich vor einer Weile einen kleinen Protokollanalysator zusammengestrickt. Dieser unterstützt aktuell Protokollversion 1.0 und ist als "gefährliche Beta" anzusehen: Resol Protocol Analyzer

Downloads

An dieser Stelle noch einmal vielen Dank an Resol für die Bereitstellung der Informationen und die Erlaubnis, diese hier weiter zu verteilen!

Weblinks