Skip to content

Firmware einspielen

David Hebbeker edited this page Mar 9, 2018 · 49 revisions

vorherige Seite: Bezugsquellen Einzelteile - nächste Seite: Zusammenbau der Komponenten (Schaltung)

USB2serial Treiber installieren

Das Betriebssystem des Rechners, welches zum Übertragen ("flashen") des Sensors-Programms ("Firmware") benötigt einen Treiber / ein Modul um mit dem NodeMCU kommunizieren zu können. Der Rechner kommuniziert mit dem USB2Serial Chip, welcher auf der NodeMCU verbaut ist. Je nach Version des NodeMCU muss ein entsprechender Treiber installiert sein. Bei Linux Betriebssystemen ist in der Regel bereits ein passender Treiber vorhanden.

Identifizieren der Version des NodeMCU

NodeMCU umdrehen und schauen, ob da CP2102 oder CH340G steht. Ist alternativ auch (mit einer Lupe) auf einem der Chips auf dem NodeMCU zu finden. [comment]: # "CP2102 und CH340G sind jeweils UART zu USB Transciever"

CP2102 (NodeMCU v2)

CP210x USB TO UART Bridge Treiber

CH340G (NodeMCU v3)

CH340G Bridge Treiber

Nach der Installation der Treiber Rechner neu starten.

Bemerkung für MacOS 10.9 oder neuer: Wenn ein nicht-signierter Treiber installiert wird, muss dies in MacOS explizit erlaubt werden. Eine gute Beschreibung gibt es bei tzapu.com

Firmware einspielen und Konfiguration löschen

Achtung: Für das Flashen (Aufspielen des Sensor-Programms) der NodeMCU ein USB-Kabel mit nicht mehr als 1m Länge benutzen.

Variante 1

Anstelle den ESP8266 oder NodeMCU mit dem Terminal zu programmieren, kann die Arduino IDE genutzt werden. In dieser Anleitung werden die Schritte gezeigt, um die Arduino IDE für den ESP8266 vorzubereiten.

  • Arduino IDE unter https://www.arduino.cc/en/Main/Software downloaden und installieren.
  • Erweiterung für ESP8266 installieren. Anleitung unter https://github.com/esp8266/Arduino.
  • In der IDE unter "Werkzeuge -> Board: ..." "NodeMCU 1.0 (ESP-12E Module)" auswählen.
  • Die bin-Dateien der zu installierenden Firmware in ein Verzeichnis kopieren. Achtung, GitHub zeigt im Browser zunächst eine HTML-Version an, zuerst oben rechts über dem Sourcecode auf "Raw" klicken, dann das Ergebnis speichern.
  • Alle in der Readme.md aufgelisteten Bibliotheken installieren. Dabei auf die angegebenen Versionen achten!
  • Die Datei ext_def.h an die eigenen Anforderungen anpassen (WLAN-Einstellungen, Sensoren, wohin mit den Daten, ...)
  • Nach einem Neustart der IDE sollte sich die INO-Datei ohne Fehlermeldung auf die NodeMCU hochladen lassen.

Variante 2

  • Arduino IDE unter https://www.arduino.cc/en/Main/Software downloaden und installieren.
  • Erweiterung für ESP8266 installieren. Anleitung unter https://github.com/esp8266/Arduino.
  • Arduino IDE beenden.
  • Download der fertig übersetzten Firmware von https://www.madavi.de/sensor/update/data/latest.bin
  • Unter Windows die Kommandozeile, unter Linux/MacOS ein Terminal öffnen
  • Bitte im folgenden Schritt beachten:
    Je nach Version der Arduino-IDE kann sich die Version des ESPTools unterscheiden. In unserem Beispiel war Version 0.4.12 aktuell. Gegebenenfalls muss dann im Pfad die Versionsnummer angepasst werden.
  • Windows: "%USERPROFILE%\AppData\Local\Arduino15\packages\esp8266\tools\esptool\0.4.12\esptool.exe" -vv -cd nodemcu -cb 57600 -ca 0x00000 -cp COM11 -cf "Pfad_zur_heruntergeladenen_Firmwaredatei" (der Port hinter '-cp' muss gegebenenfalls angepasst werden, die Anführungszeichen sollten mit eingegeben werden)
  • Linux/MacOS: ~/Library/Arduino15/packages/esp8266/tools/esptool/0.4.12/esptool -vv -cd nodemcu -cb 57600 -ca 0x00000 -cp /dev/cu.wchusbserial1410 -cf Pfad_zur_heruntergeladenen_Firmwaredatei (der Port hinter '-cp' muss gegebenenfalls angepasst werden). Eventuell muss man dies als root ausführen. Dann muss im Pfad '~/' durch das Home-Verzeichnis ersetzt werden. Für Linux (MacOs ungetestet, evtl. mit Pfadanpassung) gibt es ein script in sensors-software/utils/flash/, das auch die Konfiguration löschen kann (s.u.).
  • Den passenden Port erfährt man zum Beispiel, indem man die NodeMCU am gewünschten Port anschließt und danach die Arduino IDE startet. Unter 'Werkzeuge -> Port' sind die verfügbaren Port zu sehen, meist ist recht einfach der Port mit der NodeMCU erkennbar. Einen Port auswählen und dann 'Werkzeuge -> Boardinformationen holen' ausführen. Ist der richtige Port gewählt, erscheinen Codes bei VID und PID. Die IDE danach wieder schließen, da sonst dieser Port blockiert ist.

Löschen der Konfiguration:

Variante 1

Über die Arduino IDE lässt sich die gespeicherte Konfiguration mit dem Plugin "ESP8266 Sketch data upload" löschen. Das Plugin nach Anleitung installieren. Beim Ausführen des Plugins kommt eine Meldung, dass das Daten-Verzeichnis leer ist, und ob man ein leeres SPIFFS Image hochladen möchte. Diese Meldung mit "Ja" beantworten. Der Upload der 3 MB kann dann etwas dauern. Wenn der Upload fertig ist, kann die NodeMCU neu gestartet werden.

Variante 2

Das Vorgehen entspricht Variante 2 des Firmware einspielens. Als "Firmware"-Datei die Datei ppd42ns-wificonfig-ppd-sds-dht.spiffs.bin herunterladen. Der Aufruf des esptool muss dann geändert werden bei "-ca 0x00000" auf "-ca 0x100000" und der Pfad zur "Firmware"-Datei auf den eben erfolgten Download. Implementiert im (Linux/bash-)script unter sensors-software/utils/flash/.

Seiten

Dokumentation

Protokolle

for more, see Protokolle

Clone this wiki locally