Outils pour utilisateurs

Outils du site


esp32_devkit

Différences

Ci-dessous, les différences entre deux révisions de la page.

Lien vers cette vue comparative

Les deux révisions précédentesRévision précédente
Prochaine révision
Révision précédente
esp32_devkit [2019/01/05 16:44] bigMaxesp32_devkit [2020/10/27 18:33] (Version actuelle) – ↷ Liens modifiés en raison d'un déplacement. serge
Ligne 1: Ligne 1:
 ====== ESP32 devkit v1 ====== ====== ESP32 devkit v1 ======
 Ici sont rassemblés des informations pour travailler avec un ESP32 devkit. Ici sont rassemblés des informations pour travailler avec un ESP32 devkit.
 +Ce kit a été créé par une boite nommée Espressif. [[ https://www.espressif.com/en/products/hardware/esp32/overview ]]
 +
 +{{ media_06:esp32_devkit.jpg?direct&600 |}}
  
 <WRAP center round important 60%> <WRAP center round important 60%>
 Avant toute chose, il faut bien vérifier le modèle de l'ESP32 board que vous utilisez, car il existe de noumbreux modèles differents, avec pour chacun un cablage différents. Avant toute chose, il faut bien vérifier le modèle de l'ESP32 board que vous utilisez, car il existe de noumbreux modèles differents, avec pour chacun un cablage différents.
 </WRAP> </WRAP>
 +
 +La version "lolin32" semble être un bon choix pour une carte de developpement, car elle fit mieux sur une breadbord. Il reste une ligne de chaque côté de la breadbord pour connecter des fils. Elle dispose de quoi brancher une batterie et du nécéssaire de recharge de la baterie, et consomme très peu de courant en deepsleep mode. Néansmoins, il semble qu'il faille toujours souder les connecteurs sois même.
 +
 +Un tuto complet ici : [[ https://mjrobot.org/iot-made-simple-playing-with-the-esp32-on-arduino-ide/ ]]. Attenton, votre ESP32 est probablement cablé différement !
 +
 +<WRAP center round info 60%>
 +Beaucoup de versions sont listés dans ce [[ https://docs.google.com/spreadsheets/d/1Mu-bNwpnkiNUiM7f2dx8-gPnIAFMibsC2hMlWhIHbPQ/edit#gid=0 | magnifique document google ]] : vous trouverez forcément chaussures à votre pied. Vous pouvez trier le document par un tas de critères, comme "breadboard friendly", présence d'un ecran, présence d'un transceiver LoRa, présence d'une gestion de charge de batterie, ...
 +</WRAP>
 +
 +
 +===== Détails techniques =====
 +Voici les détails techniques colléctés en vrac depuis le site internet de [[ https://mjrobot.org ]].
 +
 +==== Fonctionnalités clées ====
 +  * 240 MHz dual-core Tensilica LX6 microcontroller avec 600 DMIPS
 +  * 520 KB SRAM intégré
 +  * Émetteur-récepteur Wi-Fi 802.11 b/g/n HT40 Wi-Fi transceiver intégré, baseband, stack et LwIP
 +  * Bluetooth dual mode intégré (classic et BLE)
 +  * 16 MB flash, memory-mapped to the CPU code space
 +  * 2.3V to 3.6V operating voltage
 +  * Temperature de fonctionnement de -40°C à +125°C
 +  * Onboard PCB antenna / IPEX connector for external antenna
 +
 +==== Capteurs ====
 +  * Ultra-low noise analog amplifier
 +  * Capteur à effet Hall
 +  * 10x capacitive touch interfaces
 +  * 32 kHz crystal oscillator
 +
 +==== 34 ports GPIO ====
 +  * 3 x UARTs, including hardware flow control
 +  * 3 x SPI
 +  * 2 x I2S
 +  * 18 x ADC input channels
 +  * 2 x DAC
 +  * 2 x I2C
 +  * PWM/timer input/output available on every GPIO pin
 +  * OpenOCD debug interface with 32 kB TRAX buffer
 +  * SDIO master/slave 50 MHz
 +  * Supports external SPI flash up to 16 MB
 +  * SD-card interface support
 +
 +==== Securité des communications ====
 +  * WEP, WPA/WPA2 PSK/Enterprise
 +  * Hardware accelerated encryption: AES/SHA2/Elliptical Curve Cryptography/RSA-4096
 +
 +==== Performance ====
 +  * Supports sniffer, Station, SoftAP and Wi-Fi direct mode
 +  * Max data rate of 150 Mbps@11n HT40, 72 Mbps@11n HT20, 54 Mbps@11g, and 11 Mbps@11b
 +  * Maximum transmit power of 19.5 dBm@11b, 16.5 dBm@11g, 15.5 dBm@11n
 +  * Minimum receiver sensitivity of -97 dBm
 +  * 135 Mbps UDP sustained throughput
 +  * 5 μA power consumption in Deep-sleep
 +
  
 ===== Utilisation de l'IDE Arduino ===== ===== Utilisation de l'IDE Arduino =====
Ligne 11: Ligne 68:
 Le projet annonce que la plupart du framework arduino est implémenté. Le projet annonce que la plupart du framework arduino est implémenté.
  
-===== Les premiers ESP32 devkit de max ===== +===== Les premiers pas de max sur l'ESP32 devkit ===== 
-Mes premiers ESP32 devkit semblent etre des +Mes premiers ESP32 devkit semblent etre des "ESP32 devkit v1". C'est un terme plutot générique et il existe beaucoup de kit differents avec ce nom. Mon devkit est chiant car il n'est pas breadboard friendly. Lorsque je le monte sur une breadboard, je n'ai accès quà un côté des pins dispositif.
  
-{{ :esp32_de_max_pinout.png?1200 |}}+{{ media_03:esp32_de_max_pinout.png?1200 |}}
  
 Voici un tuto bien étoffé pour commencer à bricoler rapidement avec le meme ESP32 devkit que le mien : [[ https://mjrobot.org/iot-made-simple-playing-with-the-esp32-on-arduino-ide/ ]] Voici un tuto bien étoffé pour commencer à bricoler rapidement avec le meme ESP32 devkit que le mien : [[ https://mjrobot.org/iot-made-simple-playing-with-the-esp32-on-arduino-ide/ ]]
  
-{{tag>micro_controleur}}+==== Ports de communications SPI ==== 
 +cf: [[ http://iot-bits.com/esp32/esp32-spi-tutorial-part-1/ ]] 
 + 
 +Sur l'ESP32, 2 ports SPI sont disponnibles :  
 +  * SPI2 (HSPI) 
 +  * SPI3 (VSPI) 
 + 
 +Sketch examples pour manipuler les 2 ports SPI hardware : [[ https://github.com/espressif/arduino-esp32/blob/master/libraries/SPI/examples/SPI_Multiple_Buses/SPI_Multiple_Buses.ino ]] 
 + 
 +=== HSPI (SPI2) === 
 +  * CLK => GPIO 14 
 +  * MISO => GPIO 13 
 +  * MOSI => GPIO 12 
 +  * SS => GPIO 15 
 + 
 +=== VSPI (SPI3) === 
 +  * CLK => GPIO 18 
 +  * MISO => GPIO 23 
 +  * MOSI => GPIO 19 
 +  * SS => GPIO 5 
 + 
 + 
 +==== Notes ==== 
 +  * GPIO2 pilote la diode bleue. 
 +  * GPIO22 pas utilisable en INPUT ou en INPUT_PULLUP ? 
 + 
 +==== Troubleshooting ==== 
 +  * Lors de l'UPLOAD du code compilé: l'erreur suivante apparait : "Serial object has no attribut dtr". Pour régler cela il faut maj la biblothèque python pyserial: **sudo pip install --upgrade pyserial** 
 +  * Lors de l'UPLOAD du code compilé: l'erreur suivante apparait : "Failed to connect to ESP32: Timed out waiting for packet header". Il faut vérifier que les pin RX0/TX0 (GPIO3/GPIO1) de l'ESP32 ne sont pas utilisés. Ces 2 pins servent à la liaison de debug. 
 +  * Ajouter l'utilisateur dans le groupe dialout. 
 + 
 +==== Pilotage d'un écran TFT 240x240 px : le ST7789 ==== 
 +{{ media_06:tft_240px_screen.jpg?direct&400|}} 
 + 
 +Cablage 
 + 
 +  * 1 GND Power ground 
 +  * 2 VCC Power 3.3+ 
 +  * 3 SCL SPI clock line 
 +  * 4 SDA SPI data line 
 +  * 5 RES Reset 
 +  * 6 DC Data/command selection foot 
 +  * 7 BLK Backlight control, the default can be left floating, low level to turn off the backlight. 
 + 
 +Je recommande la lib TFT-eSPI de Bodmer qui permet de driver beaucoup d'écran, et qui est construite sépcifiquement pour les ESP. Elle permet notamment le choix de l'un ou l'autre des 2 ports SPI hardware de l'ESP32. La lib est disponible dans le lib manager arduino ou sur github ici : [[ https://github.com/Bodmer/TFT_eSPI ]] 
 +\\ 
 +Je déconseil la lib d'Adafruit qui n'a jamais voulu fonctionner avec un SPI hardware de l'ESP32. 
 +\\ 
 +Configuration de la lib TFT-eSPI dans le fichier User_Setup.h : 
 +<code c> 
 +#define ST7789_DRIVER   
 + 
 +#define TFT_WIDTH  240 
 +#define TFT_HEIGHT 240 
 + 
 +#define TFT_MISO 23 
 +#define TFT_MOSI 19 
 +#define TFT_SCLK 18 
 +#define TFT_CS   -1  // Chip select control pin 
 +#define TFT_DC   15  // Data Command control pin 
 +#define TFT_RST   22  // Reset pin (could connect to RST pin) 
 +</code> 
 + 
 +Plus de code sur github ici : https://github.com/mxbossard/laperco-capteurs/blob/master/arduino_sketches/screen_test_2/screen_test_2.ino 
 + 
 +===== Les premiers pas de Bjorn sur l'ESP32 devkit ===== 
 +Mon objectif initial est de tester des librairies graphiques en vue d'un futur projet sur ce genre de hardware (teasing de ouf). J'avais sous la main un écran ST7735 (en 128x160px) qui embarque également un port microSD, je l'ai acheté à vil prix chez une grande enseigne française d'électronique. 
 +Le module ESP32 m'a été gentiment prêté par Gaziel qui en avait un au fond de son sac. Celui-ci viens du marché chinois des internets et laisse une rangé de libre de chaque coté de la breadboard une fois enfiché. 
 + 
 +==== Hardware ==== 
 +=== L'écran === 
 +l'écran est un 1.8' de chez Joy-it: http://anleitung.joy-it.net/?goods=1-8-tft-lcd-st7735 . Il embarque également un port microSd: une partie de l'adressage du module est consacré au display et l'autre au stockage. On notera que ce module ne possède pas de pin "LED" contrôlant le rétro-éclairage, certains modules concurrents en disposent ce qui permet de piloter la luminosité depuis l'ESP32. Mon module est toujours éclairé au max. 
 +=== Le montage === 
 +Le montage respecte le schéma présenté sur le site [[http://www.xtronical.com/projects/frogger/2-moving-esp32-connecting-display/|Xtronical]]. Choix moyennement judicieux, on y reviendra dans la partie software. Il diverge dans l'adressage des pins CS, RTS et DC par rapport au montages qu'on peu trouver chez Adafruit par exemple. La connexion à la pin LED à été ignorée sur mon montage. 
 + 
 +{{https://i1.wp.com/www.xtronical.com/wp-content/uploads/2017/12/WiringDiagram.jpg?453x272 }} 
 + 
 +^ LCD SCREEN ^ NODEMCU ESP32 ^ 
 +|5V| 3v3| 
 +|GND| GND| 
 +|LED| 5V| 
 +|SCL (SPI Clock)| GPIO18 VSPI SCK (SPI Clock)| 
 +|SDA (SPI Data)| GPIO23 VSPI MOSI (MOSI, Data to Screen)| 
 +|RS (Register Select)| GPIO2 (labelled as DC in Adafruit code)| 
 +|RST (Screen reset) | GPIO4| 
 +|CS (Chip Select : Defined as Slave Select in SPI) If low this device is active on data lines| GPIO5 VSPI SS (Slave Select/ Chip Select)| 
 + 
 +==== Software ==== 
 +=== Les librairies === 
 +{{ media_02:esp_tft_junk.jpg?400|}} 
 +  * Une des premières documentation que j'ai eu étant le site de [[http://www.xtronical.com|Xtronical]] j'ai utilisé les libraies qu'il recommandait. Le résultat était correct mais à un écran de résolution 128x128 (toujours avec le chipset ST7735) apparassait du "junk"(ou du bruit, appelez ça comme vous voulez) sur la partie non adressé de l'écran (cf. image de droite). J'ai cru bon de modifier cette lib pour retrouver la résolution cible ce qui se traduisit par un échec cuisant. 
 +  * J'ai ensuite répéré la librairie [[https://github.com/loboris/ESP32_TFT_library|ESP32_TFT_library]] que je ne suis pas parvenu à intégrer dans un projet sur Arduino Ide. 
 +  * J'ai enfin arrêté de faire pas comme les autres et me suis rabatu sur la lib d'Adafruit (la même que max). J'ai adapté les sorties GPIO pour correspondre au schéma ci-dessus: 
 +<code c> 
 +#define TFT_CS         5 
 +#define TFT_RST        4 // Or set to -1 and connect to Arduino RESET pin 
 +#define TFT_DC         2 
 +</code> 
 +  * Le truc un peu foufou avec cette lib c'est qu'adafruit à repéré que selon le fournisseur ou le batch du module on tombait sur des dalles qui on des params différents. On peu donc en fonction de son matériel voir apparaitre du junk sur les brods de l'écran voir avoir l’adressage des couleurs inversé. La fonction initR(*) permet de charger le bon setup pour chaque écran. Dans mon cas j'ai utulisé le setup INITR_GREENTAB, ce qui correspond à la couleur de l'étiquette sur la protection écran, détail qui permet de différencier certains display. (astuce de ouf, je ne m'en suis toujours pas remis) 
 + 
 +<code c> 
 +Adafruit_ST7735 tft = Adafruit_ST7735(TFT_CS, TFT_DC, TFT_RST); 
 + 
 +  tft.initR(INITR_BLACKTAB);      // Init ST7735S chip, black tab 
 +  tft.initR(INITR_GREENTAB);      // Init ST7735S chip, green tab 
 +  //  if using a 1.44" TFT: 
 +  tft.initR(INITR_144GREENTAB); // Init ST7735R chip, green tab 
 +  //if using a 0.96" 180x60 TFT: 
 +  tft.initR(INITR_MINI160x80);  // Init ST7735S mini display 
 +  // etc. 
 +</code> 
 +==== Notes ==== 
 +  * todo 
 + 
 +===== Notes pour l'utilisation du serveur WEB de l'ESP32 ===== 
 +Un tuto interessant au sujet de l'outillage pour construire des pages web en économisant l'espace mémoire : [[ https://nathanmcminn.com/2018/09/23/a-modern-micro-web-stack-for-the-esp32/ ]] 
 +On y parle notamment de SPIFFS le mini File System disponible pour ESP32. 
 +cf : [[https://github.com/ntmcminn/arduino-examples/blob/master/esp32-ap-mode/esp32-ap-mode.ino ]] 
 + 
 +{{tag>micro_controleur documentation max}}
esp32_devkit.1546706643.txt.gz · Dernière modification : 2019/01/05 16:44 de bigMax