HomeMatic Wired: Unterschied zwischen den Versionen

Aus FHEMWiki
(Tippfehler korrigiert)
(Problemlösungen beim Upgrade beschrieben)
Zeile 10: Zeile 10:
HM485 ist nicht automatisch Teil von FHEM. Es muss explizit installiert bzw. hinzugefügt werden. Die Installation funktioniert folgendermaßen:
HM485 ist nicht automatisch Teil von FHEM. Es muss explizit installiert bzw. hinzugefügt werden. Die Installation funktioniert folgendermaßen:
* Falls man sich seiner Sache nicht ganz sicher ist, empfiehlt sich zuerst ein Backup der FHEM-Installation.
* Falls man sich seiner Sache nicht ganz sicher ist, empfiehlt sich zuerst ein Backup der FHEM-Installation.
* HM485 benötigt das Perl-Modul XML::Simple. Unter Debian (inklusive normaler Raspberry-Installationen) ist dieses Modul im Paket libxml-simple-perl enthalten, kann also mittels <code>apt-get -s install libxml-simple-perl</code> (auf Betriebssystemebene als root) installiert werden. Ansonsten kann es z.B. über Cpan installiert werden.
* Falls man den letzten FHEM-Update vor dem 24.12.2015 gemacht hat, dann muss man vor der HM485-Installation einen Update durchführen. Also im Kommandofeld eingeben:<code>update</code> Dann den Update-Vorgang abwarten und Neustarten:<code>shutdown restart</code>.
* Falls man den letzten FHEM-Update vor dem 24.12.2015 gemacht hat, dann muss man vor der HM485-Installation einen Update durchführen. Also im Kommandofeld eingeben:<code>update</code> Dann den Update-Vorgang abwarten und Neustarten:<code>shutdown restart</code>.
* Dann das HM485-Repository zum FHEM Update hinzufügen:  
* Dann das HM485-Repository zum FHEM Update hinzufügen:  
Zeile 17: Zeile 18:


Zum Upgrade reicht ein <code>update</code>, wenn man HM485 wie oben beschrieben installiert hat. Ansonsten kann man auch das HM485-Repository nachträglich eintragen wie oben beschrieben. Wenn man von einer manuellen Installation auf die "update add"-Variante wechselt, dann sollte man das erste Mal immer <code>update force hm485</code> machen. Will man nur den HM485-Teil aktualisieren und nicht alles in FHEM, dann geht das mit <code>update all hm485</code>.
Zum Upgrade reicht ein <code>update</code>, wenn man HM485 wie oben beschrieben installiert hat. Ansonsten kann man auch das HM485-Repository nachträglich eintragen wie oben beschrieben. Wenn man von einer manuellen Installation auf die "update add"-Variante wechselt, dann sollte man das erste Mal immer <code>update force hm485</code> machen. Will man nur den HM485-Teil aktualisieren und nicht alles in FHEM, dann geht das mit <code>update all hm485</code>.
Falls es insbesondere beim Upgrade oder nach einem Upgrade Probleme gibt (welcher Art auch immer), sollten die folgenden Punkte geprüft werden:
* Ist XML::Simple installiert? Siehe die Installationanleitung weiter oben für Details.
* FHEM braucht Schreibrechte im Verzeichnis <fhem>/FHEM/lib/HM485/Devices (<fhem> steht meistens für /opt/fhem) und allen Dateien und Unterverzeichnissen. Auf Betriebssystemebene (Linux) kann man das mit <code>ls -ls</code> überprüfen. Meistens kann es mit folgendem Befehl repariert werden: <code>chown -R fhem:dialout /opt/fhem/FHEM/lib/HM485/Devices</code>.
* Wenn das nicht hilft, dann kann man auch vor einem <code>shutdown restart</code> alle pm-Dateien im Devices-Verzeichnis löschen (<code>rm /opt/fhem/FHEM/lib/HM485/Devices/*.pm</code>). Diese Dateien werden beim nächsten FHEM-Start neu generiert.


== Verkabelung ==
== Verkabelung ==

Version vom 16. Mai 2017, 08:57 Uhr

HomeMatic Wired (HMW / HM485) ist ein auf RS485 basierendes Bussystem für die Hausautomation. Die Auswahl an Aktoren und Sensoren ist im Vergleich zum HomeMatic-Funksystem geringer. Die wichtigsten Funktionen wie Lichtsteuerung, Rollläden, Tür- / Fenstersensoren, Schalter und Taster lassen sich aber integrieren. Über verschiedene I/O-Module lassen sich viele weitere Geräte anschließen. Auch analoge Messwerte können ausgewertet werden, so dass hier z.B. auch Temperatursensoren integriert werden könnten.

Alle Module sind rückkanalfähig, d.h. es erfolgt eine Rückmeldung, wenn ein Gerät eine Nachricht erhalten hat (ACK für Acknowledgement, also Empfangsbestätigung). Auch werden externe Zustandsänderungen der Geräte unmittelbar über den Bus weitergeleitet (bei den meisten Geräten ist letzteres abschaltbar).

Alle HMW-Module werden über den Bus mit Energie versorgt. Batteriebetriebene Module sind nicht vorgesehen und auch nicht sinnvoll, da HMW ein kabelgebundenes System ist.

Installation und Upgrade in FHEM

Für den Einsatz mit FHEM benötigt man die entsprechende Rechner-Hardware, FHEM selbst und einen Übertragungs- bzw. Konfigurationsadapter (Interface) wie z.B. einen Serial/Netzwerk-RS485-Adapter oder das HomeMatic Wired RS485 LAN Gateway.

HM485 ist nicht automatisch Teil von FHEM. Es muss explizit installiert bzw. hinzugefügt werden. Die Installation funktioniert folgendermaßen:

  • Falls man sich seiner Sache nicht ganz sicher ist, empfiehlt sich zuerst ein Backup der FHEM-Installation.
  • HM485 benötigt das Perl-Modul XML::Simple. Unter Debian (inklusive normaler Raspberry-Installationen) ist dieses Modul im Paket libxml-simple-perl enthalten, kann also mittels apt-get -s install libxml-simple-perl (auf Betriebssystemebene als root) installiert werden. Ansonsten kann es z.B. über Cpan installiert werden.
  • Falls man den letzten FHEM-Update vor dem 24.12.2015 gemacht hat, dann muss man vor der HM485-Installation einen Update durchführen. Also im Kommandofeld eingeben:update Dann den Update-Vorgang abwarten und Neustarten:shutdown restart.
  • Dann das HM485-Repository zum FHEM Update hinzufügen:
  • Jetzt update force hm485 und shutdown restart. HM485 sollte jetzt installiert sein.
  • Es muss jetzt noch sichergestellt werden, dass das Programm HM485d.pl (im Verzeichnis FHEM/lib/HM485/HM485d) für den User fhem ausführbar ist. Das ist normalerweise nicht automatisch der Fall. Es muss im Zweifelsfall per sudo chmod a+x HM485d.pl ausführbar gemacht werden.

Zum Upgrade reicht ein update, wenn man HM485 wie oben beschrieben installiert hat. Ansonsten kann man auch das HM485-Repository nachträglich eintragen wie oben beschrieben. Wenn man von einer manuellen Installation auf die "update add"-Variante wechselt, dann sollte man das erste Mal immer update force hm485 machen. Will man nur den HM485-Teil aktualisieren und nicht alles in FHEM, dann geht das mit update all hm485.

Falls es insbesondere beim Upgrade oder nach einem Upgrade Probleme gibt (welcher Art auch immer), sollten die folgenden Punkte geprüft werden:

  • Ist XML::Simple installiert? Siehe die Installationanleitung weiter oben für Details.
  • FHEM braucht Schreibrechte im Verzeichnis <fhem>/FHEM/lib/HM485/Devices (<fhem> steht meistens für /opt/fhem) und allen Dateien und Unterverzeichnissen. Auf Betriebssystemebene (Linux) kann man das mit ls -ls überprüfen. Meistens kann es mit folgendem Befehl repariert werden: chown -R fhem:dialout /opt/fhem/FHEM/lib/HM485/Devices.
  • Wenn das nicht hilft, dann kann man auch vor einem shutdown restart alle pm-Dateien im Devices-Verzeichnis löschen (rm /opt/fhem/FHEM/lib/HM485/Devices/*.pm). Diese Dateien werden beim nächsten FHEM-Start neu generiert.

Verkabelung

Das folgende Bild zeigt die Verkabelung von HM-Wired am Beispiel eines seriellen USB-Adapters und zwei Geräten. Verkabelungsbeispiel HM-Wired

Im Unterschied zu anderen RS485-Bussystemen wird GND immer mit verbunden. Außerdem sind die Widerstandswerte des sogenannten Busabschluss zu beachten.


Der sogenannte Busabschluss

Im Gegensatz zu anderen RS485-Bussystemen braucht Homematic Wired keinen echten Busabschluss. Die Datenübertragungsrate ist zu niedrig, als dass es zu Problemen wegen Reflexionen kommt. Wahrscheinlich kann es durch den üblichen RS485-Busabschluss (etwa 120 Ohm zwischen A und B) sogar vorkommen, dass der Bus nicht richtig funktioniert oder sogar Geräte beschädigt werden. Das, was von eq3 als Abschlusswiderstand verkauft wird, ist kein Busabschluss, sondern ein Widerstandsnetzwerk, welches den Bus auf ein definiertes Potential bringt, wenn kein Busteilnehmer sendet. Die genauen Werte können dem obigen Bild entnommen werden. Das ganze ist so berechnet, dass sich zwischen A und B in etwa ein Unterschied von 5V ergibt. (Sehe auch Homematic Inside [1]) Wenn man jetzt noch zusätzlich 120Ohm (möglicherweise zweimal) an den Bus hängt, dann hat man in etwa 60Ohm zwischen A und B. Dadurch liegen A und B fast auf demselben Potential und man hat in etwa das Gegenteil von dem erreicht, was man eigentlich wollte.

Falls man nur Homebrew-Devices am Bus hat, hat man möglicherweise gar keine 24V. Dann ist auch der eq3-Abschlusswiderstand nicht sinnvoll. Es reicht dann ein einfacher Pulldown an B und ein Pullup auf 5V an A.

Bevor man hier irgendwelche Experimente macht, sollte man den Busabschluss lieber ganz weglassen. In den meisten Fällen funktioniert es auch komplett ohne.

Pair / Peer bzw. pairen und peeren

HMW-Geräte können unter- bzw. miteinander gepeert werden, wenn z.B. ein Sensor einen Aktor direkt (ohne Zentrale) steuern soll. Ein einfaches Peering zweier Kanäle kann meistens ohne Zentrale erfolgen, d.h. mit den Bedienelementen direkt an den Geräten. Allerdings ist es über die FHEM-Oberfläche in der Regel einfacher. Außerdem können dann weitere Parameter der jeweiligen Verknüpfung angegeben werden.

HMW-Geräte müssen andererseits mit einer Zentrale gepairt werden, wenn diese Zentrale die Geräte (um-)konfigurieren bzw. steuern oder zumindest auslesen können soll.

Anders als bei den HomeMatic-Funk-Geräten erfolgt dieses Pairing automatisch, sobald ein Gerät erstmalig Nachrichten über den RS485 Bus sendet. Zusätzlich besteht die Möglichkeit, über einen Discovery-Befehl alle am Bus angeschlossenen Module zu ermitteln. Auch bei diesem Vorgang erfolgt im Anschluss daran ein automatisches Pairing aller bis dahin unbekannten Geräte mit der Zentrale bzw. mit FHEM.

Aktoren / Sensoren

Eine Übersicht und weitere Informationen über die von FHEM unterstützten HomeMatic-Geräte ist hier zu finden:

Hier dennoch eine dedizierte Liste aller HMW-Geräte und der benötigten Interfaces:

Momentan werden (bzw. wurden) außerdem "HM-Homebrew" Geräte entwickelt.

Modell ID Beschreibung FHEM CCU Firmware
HBW-1W-T10 0x81 10-fach 1-Wire Temperatursensor ja ja Git
HBW-LC-BI4 0x82 4-Kanal Rollladenaktor ja Git, Forum
HBW-LC-Sw8 0x83 8-fach Schaltaktor ja Git, Forum
HBW-Sen-EP 0x84 8-fach S0-Interface ja Git
HBW-Sen-KEY 0x85 RFID-Interface ja Git
HBW-Sen-SC8 0x86 8-fach Tasterschnittstelle ja Git
HBW-Sen-Key-12 0x95 12-fach Tasterschnittstelle ja Git
HBW-CC-Vd2-T 0x87 Steuerung 24V-Ventile ja Git
0x88 Wettersensor
0x89 Tastsensor
HBW-Sec-MDIR-2 0x91 Bewegungsmelder-Schnittstelle Git
HMW-LC-Sw2-DR 0x11 ja ja Git, Forum
HMW-LC-Bl1-DR 0x15 1-Kanal Rollladenaktor ja ja Git
HMW-IO-12-FM nein nein Git
HBW_LC_RGB1_CV 0xA0 3-fach Dimmer als RGB-Controller ja ? Git
HBW-SD6-Multikey 0xB1 Reserviert für 6-fach Taster von haus-bus.de nein nein Git

In der obigen Liste der Homematic-Wired-Homebrew Geräte kommen auch Modellbezeichnungen von Original-Homematic-Geräten vor (HMW...). In diesen Fällen handelt es sich um Homebrew-Geräte, die sich gegenüber FHEM bzw. der CCU wie das angegebene Gerät verhalten. Unter Umständen weicht aber das Verhalten von dem der Original-Geräte ab. Die Spalten "FHEM" und "CCU" besagen, ob das entsprechende Gerät in FHEM bzw. in der CCU erkannt wird und funktioniert. Ist in beiden Spalten ein "nein" eingetragen, dann kann davon ausgegangen werden, dass das Gerät noch gar nicht funktioniert. Bei einem "ja" kann es auch noch Einschränkungen geben.

Zur Erstellung eigener HBW Geräte mittels Arduino gibt es ein Tutorial von Thorsten im Forum.

Links