Molti progetti IoT (Internet of Thing) sono basati sul kit di sviluppo NodeMCU che è composto da un modulo transceiver a basso costo Wi-Fi ESP e da un micro-controllore (MC Unit) prodotto da Espressif Systems.
I fabbricanti Amica, Lolin e DOIT hanno prodotto negli anni 3 versioni di NodeMCU: la seconda versione (V2) rappresenta un’evoluzione della precedente Ver 0.9 (V1) con l’aggiornamento del modulo da un ESP-12 a un ESP-12E. In realtà la V3 è un fork della V2 creata dal produttore LoLin che monta un convertitore CH340G, lo stesso utilizzato anche nella V1.
NodeMCU
NodeMCU è dotato di 4 MB di memoria flash per l’archiviazione di programmi e dati, quanto basta per parsare le response in formato json. Inoltre abbiamo abbiamo accesso a 11 pin GPIO e un pin convertitore analogico-digitale (ADC) con risoluzione a 10 bit.
La scheda ha un regolatore di tensione integrato ed è possibile alimentare il modulo utilizzando la presa mini USB o il pin Vin.
L’ESP8266 integra il ricetrasmettitore Wi-Fi 802.11b/g/n HT40, quindi può connettersi a una rete WiFi consentendoci di collegarci ad altri dispositivi.
Step 1- Installare Esptool
Esptool è un’utility scritta in Python che permette al nostro computer di comunicare con il bootloader dei SoC ESP8266 e EPS32. Inoltre ci permetterà di leggere, cancellare (erase) o scrivere (write) la memoria del device dandoci quindi la possibilità di riprogrammarlo con altri firmware.
Possiamo installare l’ultima versione stabile usando il gestore di pacchetti pip:
pip install esptool
Adesso controlliamo la versione che abbiamo installato:
> esptool version
esptool.py v3.1
3.1
Step 2 – Erase Flash Memory
NodeMCU include il bridge controller CP2102, che converte il segnale USB in seriale (USB-to-UART) consentendoci di programmare e comunicare con il SOC ESP8266.
Dobbiamo quindi installare su Windows 10 il driver CP210x USB to UART Bridge VCP scaricandolo dal sito web di Silicon Labs. Adesso su Windows 10 dobbiamo aprire la Gestione dispositivi (device manager) per trovare la porta COM su cui il device è stato riconociuto.
La porta seriale COM sarà quella che useremo durante l’emissione dei comandi da terminale, nel mio caso la porta seriale è la COM4. Utilizzando Esptool è necessario cancellare la flash memory dell’ESP32 con il comando:
esptool --port [porta seriale] erase_flash
Dovremmo avere un output simile al seguente:
esptool.py v3.1
Serial port COM4
Connecting....
Detecting chip type... ESP8266
Chip is ESP8266EX
Features: WiFi
Crystal is 26MHz
MAC: 84:f3:eb:05:90:c5
Uploading stub...
Running stub...
Stub running...
Erasing flash (this may take a while)...
Chip erase completed successfully in 3.5s
Hard resetting via RTS pin...
Dovremmo vedere il messaggio di operazione conclusa con successo:
Chip erase completed successfully
Step 3 – Download del firmware
A questo punto, dobbiamo scaricare l’ultima versione stabile del firmware, stando attenti a selezionare la board giusta. Nel nostro caso è una board esp32 generica e la versione da me scaricata è la V1.17 rilasciata il 2 settembre 2021.
Step 4 – Flash del firmware
Utilizzando Esptool è possibile caricare il firmware con MicroPython all’interno dell’ESP32 con il seguente comando:
esptool --port com4 --baud 115200 write_flash --flash_size=detect -fm dio 0 <br>esp8266-20210902-v1.17.bin
L’output che comparirà sarà come il seguente:
esptool.py v3.1
Serial port com4
Connecting...
Device PID identification is only supported on COM and /dev/ serial ports.
.
Detecting chip type... ESP8266
Chip is ESP8266EX
Features: WiFi
Crystal is 26MHz
MAC: 84:f3:eb:05:90:c5
Uploading stub...
Running stub...
Stub running...
Configuring flash size...
Auto-detected Flash size: 4MB
Flash will be erased from 0x00000000 to 0x0009afff...
Flash params set to 0x0240
Compressed 633688 bytes to 416263...
Wrote 633688 bytes (416263 compressed) at 0x00000000 in 36.8 seconds
(effective 137.6 kbit/s)...
Hash of data verified.
Leaving...
Hard resetting via RTS pin...
Step 5 – Modules
In un articolo precedente “Getting started: MicroPython” abbiamo visto che MicroPython mira ad essere il più compatibile possibile con Python, ma è progettato per funzionare su devices dalle risorse hardware limitate.
>>> help("modules")
Tutte le versioni di MicroPython sono dotate di moduli per interagire con l’hardware, i pin GPIO, le periferiche e i componenti collegati tramite tali pin. Ad esempio i devices con funzionalità di rete, includeranno moduli per supportare queste funzionalità come WiFi, json, requests.
__main__ machine ubinascii ure
_boot math ucollections urequests
_onewire micropython ucryptolib urllib/urequest
_uasyncio neopixel uctypes uselect
_webrepl network uerrno usocket
apa102 ntptime uhashlib ussl
btree onewire uheapq ustruct
builtins port_diag uio usys
dht ssd1306 ujson utime
ds18x20 uarray umqtt/robust utimeq
esp uasyncio/__init__ umqtt/simple uwebsocket
flashbdev uasyncio/core uos uzlib
framebuf uasyncio/event upip webrepl
gc uasyncio/funcs upip_utarfile webrepl_setup
inisetup uasyncio/lock upysh websocket_helper
lwip uasyncio/stream urandom
Plus any modules on the filesystem