L’Internet des Objets

L’Internet des Objets

2.3 Programmer la STM32 discovery

Page précédente Page suivante

Le support des cartes autres qu’arduino est facultatif. Il faut donc ajouter le support. Pour cela, il faut aller dans Fichier =>préférences, figure 2.12, pour ajouter le support disponible à l’https://github.com/stm32duino/BoardManagerFiles/raw/master/STM32/package_stm_index.json. En octobre 2019, cela chargeait presque 1Go de fichiers.

Pour l’utiliser avec un Raspberry, il faut (en décembre 2020) utiliser le fichier https://raw.githubusercontent.com/koendv/stm32duino-raspberrypi/master/BoardManagerFiles/package_stm_index.json.

Il y a un bug avec le fichier .arduino15/…/massStorageCopy.sh qui doit être renommé sans l’extension .sh.

(image)

Fig. 2.12 : Ajout du support STM32.

Ensuite, il faut aller dans Outils=>Type de carte=>Gestionnaire de cartes, filtrez par STM32, et installez STM32 cores by ST, figure 2.13.

(image)

Fig. 2.13 : Ajout du support STM32.

Cette action prend quelques minutes. Ensuite, il faut indiquer le type de carte Outils =>Type de carte=>Discovery, figure2.15.

(image)

Fig. 2.14 : Sélection des cartes Discovery.

Enfin, il faut préciser le Board part number

(image)

Fig. 2.15 : La carte Discovery IoT.

(image) Il se pourrait qu’il y ait un bug. Le téléversement échoue avec un message indiquant qu’un fichier n’est pas trouvé. En regardant bien, il apparaît que c’est l’exécutable 32 bits qui est utilisé. Ce qui échoue sur une installation 64 bits.

...
java.io.IOException: Cannot run program
".../.arduino15/.../linux/massStorageCopy":
error=2, Aucun fichier ou dossier de ce type

Dans ce message d’erreur, linux fait référence à la version 32 bits, il y a le répertoire linux64 à côté. Le nom du programme utilisé, massStorageCopy, fait référence à un disque dur. Pour ajouter le support 32 bits, il faut ajouter l’architecture 32 bits et installer les librairies utiles en version 32 bits (i386).

dpkg --add-architecture i386
apt-get update
apt-get install libstdc++6:i386 libgcc1:i386 zlib1g:i386 libncurses5:i386

L’autre élément qui peut être délicat, c’est que le téléversement pour Arduino se fait par une connexion série. Pour les stm32, ceux ci apparaissent comme une clef usb. Il suffit de copier le fichier exécutable dans le répertoire et il est exécuté automatiquement. Le message d’erreur indique (mais pas de manière claire) que le répertoire n’est pas monté :

DIS_L4IOT not found. Please ensure the device is correctly connected
Une erreur est survenue lors du transfert du croquis

Les logs du système indiquent les différents éléments :

# ls /dev/ttyACM*
ls: impossible d'accéder à '/dev/ttyACM*': \
                    Aucun fichier ou dossier de ce type
# tail -f /var/log/syslog
*** /// Insertion de la carte Discovery /// ***
...
 usb 1-10: new full-speed USB device number 3 using xhci_hcd
 usb 1-10: New USB device found, idVendor=0483, idProduct=374b
 usb 1-10: New USB device strings: Mfr=1, Product=2, SerialNumber=3
 usb 1-10: Product: STM32 STLink
 usb 1-10: Manufacturer: STMicroelectronics
 usb 1-10: SerialNumber: 0676FF514852897267173117
 cdc_acm 1-10:1.2: ttyACM0: USB ACM device
 usbcore: registered new interface driver cdc_acm
 usb-storage 1-10:1.1: USB Mass Storage device detected
 scsi host4: usb-storage 1-10:1.1
 usbcore: registered new interface driver usb-storage
 usbcore: registered new interface driver uas
 scsi 4:0:0:0: Direct-Access MBED microcontroller 1.0 PQ: 0 ANSI: 2
 sd 4:0:0:0: Attached scsi generic sg2 type 0
 sd 4:0:0:0: [sdb] 2120 512-byte logical blocks: (1.09 MB/1.04 MiB)
 sd 4:0:0:0: [sdb] Write Protect is off
 sd 4:0:0:0: [sdb] Mode Sense: 03 00 00 00
 sd 4:0:0:0: [sdb] No Caching mode page found
 sd 4:0:0:0: [sdb] Assuming drive cache: write through
 sd 4:0:0:0: [sdb] Attached SCSI removable disk
...
# ls /dev/ttyACM*
/dev/ttyACM0

Nous voyons qu’avant de brancher la carte, il n’y a pas de périphérique /dev/ttyACM0. Après insertion, le log du système identifie le périphérique usb connecté. Il crée le connecteur série ttyACM0, qui sera utilisé pour communiquer avec la carte, et le périphérique /dev/sdb qui représente le “disque dur” constitué par la carte (pour être rigoureux, c’est un mass storage).

Selon la configuration, ce mass storage peut se monter automatiquement (mauvaise idée) ou manuellement. Il faut donc le monter, par exemple en activant l’icone.

(image)L’automontage de périphérique et pire encore l’exécution automatique, voire l’installation automatique permet de faciliter l’introduction des virus. C’est une fonctionnalité payante, offerte avec les systèmes privatif.

Pour valider l’installation, il faut utiliser un programme d’exemple. Nous allons utiliser le programme blink : Fichier =>Exemples =>base =>Blink. Une nouvelle fenêtre s’ouvre avec le code.

Si tout est bien réglé, alors la compilation s’effectue, Quelques statistiques sont affichées, et la carte clignote fièrement.

Le croquis utilise 13256 octets (1%) de l'espace de stockage de pr
Le croquis utilise 13256 octets (1%) de l'espace de stockage de
programmes. Le maximum est de 1048576 octets.

Les variables globales utilisent 1008 octets (1%) de mémoire
dynamique, ce qui laisse 97296 octets pour les variables locales.
Le maximum est de 98304 octets.

copying /tmp/arduino_.../Blink.ino.bin to /media/stud/DIS_L4IOT

L’exécutable créé est rangé dans /tmp/arduino...ino.bin. Il est possible de conserver ce fichier pour le téléverser dans une autre carte ou à un autre moment. Il ne sera plus nécessaire de relancer l’environnement Arduino.

Page précédente Page suivante