Wie du den Fehler „TypeError: argument of type ‚NoneType‘ is not iterable“ mit dem Upload des esptool behebst, zeige ich dir in diesem neuen Beitrag.
Traceback (most recent call last): File "esptool.py", line 37, in <module> File "esptool\__init__.py", line 1064, in _main File "esptool\__init__.py", line 859, in main File "esptool\cmds.py", line 466, in write_flash File "esptool\util.py", line 37, in flash_size_bytes TypeError: argument of type 'NoneType' is not iterable [23556] Failed to execute script 'esptool' du Chip is ESP32-D0WDQ6 (revision v1.1) Features: WiFi, BT, Dual Core, 240MHz, VRef calibration in efuse, Coding Scheme None Crystal is 40MHz MAC: 08:b6:1f:9d:16:18 Uploading stub... Running stub... Stub running... Changing baud rate to 921600 Changed. WARNING: Failed to communicate with the flash chip, read/write operations will fail. Try checking the chip connections or removing any other hardware connected to IOs. Configuring flash size... e to unhandled exception! Fehlgeschlagenes Hochladen: Hochladefehler: exit status 1
Inhaltsverzeichnis
- Mögliche Ursache des Fehlers
- Konfiguration in der Arduino IDE
- Lösung – Löschen des Speichers
- Quellenangabe
Mögliche Ursache des Fehlers
Der Fehler ist in meinem Fall mit dem CrowPanel 2.4″ HMI aufgetreten. Dieses Gerät verfügt neben einem ESP32-D0WDQ6 auch über ein 2,4″ TFT Display vom Typ ILI9341V. Wenn ich nun ein kleines Beispiel mit einer Textausgabe auf dem Display aufspielen möchte, dann wird dieses scheinbar erfolgreich ausgeführt, jedoch wird nichts angezeigt. Danach jedoch wird immer der Fehler geworfen.
Konfiguration in der Arduino IDE
Wichtig zu betrachten ist die Konfiguration des Mikrocontrollers in der Arduino IDE. Es gibt einige Beiträge im Internet wo darauf hingewiesen wurde das der Wert von Uploadspeed auf 115200 baud gesetzt werden soll.
Der Wechsel von 921600 baud (Default) zu 115200 baud hat bei mir keinen Unterschied bewirkt.
Lösung – Löschen des Speichers
Meine Lösung war es, den Speicher des ESP32 zu löschen.
Dazu wird im ersten Schritt der Mikrocontroller vom Computer getrennt, dann die Taste BOOT gedrückt und die Verbindung wieder hergestellt. Es wird weiterhin die Taste BOOT gedrückt gehalten!
Im nächsten Schritt wird der nachfolgende Befehl ausgeführt. (Am besten vorbereiten, damit nur noch die Enter-Taste betätigt werden muss.)
python esptool.py --port COM12 --baud 115200 erase_flash
In meinem Fall ist das Pythonskript esptool.py unter nachfolgender Struktur installiert.
C:\Users\stdr\AppData\Local\Arduino15\packages\esp8266\hardware\esp8266\3.1.2\tools\esptool>
Wenn jetzt auf der Kommandozeile die Ausgabe „Erasing flash (this may take a while)…“ erscheint, wird die Taste BOOT wieder losgelassen.
esptool.py v3.0 Serial port COM12 Connecting...... Detecting chip type... ESP32 Chip is ESP32-D0WDQ6 (revision 1) Features: WiFi, BT, Dual Core, 240MHz, VRef calibration in efuse, Coding Scheme None Crystal is 40MHz MAC: 08:b6:1f:9d:16:18 Uploading stub... Running stub... Stub running... Erasing flash (this may take a while)... Chip erase completed successfully in 13.1s Hard resetting via RTS pin...
Dann dauert es ca. 1 Minute und der Speicher sollte anschließend gelöscht sein und der nächste Upload sollte funktionieren.
Nachfolgend habe ich ein kleines Programm mit der Ausgabe von „Hallo“ auf dem Mikrocontroller installiert. Dieses ist recht klein, ergo dauert das Kompilieren und der Upload nicht so lange.
esptool.py v4.6 Serial port COM12 Connecting..... Chip is ESP32-D0WDQ6 (revision v1.1) Features: WiFi, BT, Dual Core, 240MHz, VRef calibration in efuse, Coding Scheme None Crystal is 40MHz MAC: 08:b6:1f:9d:16:18 Uploading stub... Running stub... Stub running... Changing baud rate to 921600 Changed. Configuring flash size... Flash will be erased from 0x00001000 to 0x00005fff... Flash will be erased from 0x00008000 to 0x00008fff... Flash will be erased from 0x0000e000 to 0x0000ffff... Flash will be erased from 0x00010000 to 0x00056fff... Compressed 19744 bytes to 13604... Writing at 0x00001000... (100 %) Wrote 19744 bytes (13604 compressed) at 0x00001000 in 0.4 seconds (effective 420.9 kbit/s)... Hash of data verified. Compressed 3072 bytes to 146... Writing at 0x00008000... (100 %) Wrote 3072 bytes (146 compressed) at 0x00008000 in 0.0 seconds (effective 612.4 kbit/s)... Hash of data verified. Compressed 8192 bytes to 47... Writing at 0x0000e000... (100 %) Wrote 8192 bytes (47 compressed) at 0x0000e000 in 0.1 seconds (effective 841.2 kbit/s)... Hash of data verified. Compressed 290672 bytes to 162356... Writing at 0x00010000... (10 %) Writing at 0x0001c339... (20 %) Writing at 0x0002423e... (30 %) Writing at 0x00029904... (40 %) Writing at 0x0002eb61... (50 %) Writing at 0x00033df8... (60 %) Writing at 0x0003c5a5... (70 %) Writing at 0x00044666... (80 %) Writing at 0x0004c7f5... (90 %) Writing at 0x00051da4... (100 %) Wrote 290672 bytes (162356 compressed) at 0x00010000 in 2.6 seconds (effective 908.5 kbit/s)... Hash of data verified. Leaving... Hard resetting via RTS pin...
Quellenangabe
Die Lösung zum Fehler „‚NoneType‘ is not iterable“ mit dem esptool habe ich von der Seite https://randomnerdtutorials.com/esp32-erase-flash-memory/ entnommen.
Dort gehts eigentlich nur darum wie der Speicher gelöscht wird. Jedoch bewirkt dieses zusätzlich das Fehlerhafte konfigurationen ebenso entfernt werden.