Si vous voulez tester ce kit sous Linux, et sans trop d'efforts, ce tutoriel est peut-être fait pour vous...
La Raspberry Pi Pico que j'utilise est montée sur une petite plaque de câblage, avec un bouton-poussoir entre les broches (28)GND et (30)RUN. Ce bouton-poussoir sert à faire un Reset de la carte (sic), et évite ainsi les nombreuses connexions/déconnexions du câble USB pendant la mise au point de vos programmes.
Le kit est installé sur un Linux Ubuntu (et même testé avec succès sur une machine virtuelle Lubuntu montée avec VirtualBox).
1) Installation du kit et des outils
Pour installer la dernière version du kit sur votre dossier personnel ~/pico-sdk, il faut cloner le dépôt sur le Github officiel de la fondation :
Code bash : | Sélectionner tout |
1 2 | $ cd ~ $ git clone https://github.com/raspberrypi/pico-sdk.git |
Et si la commande git ne répond pas, c'est qu'il faut d'abord installer le gestionnaire : sudo apt-get install git.
Par anticipation, il faut compléter le kit avec des sous-modules. Pour les installer :
Code bash : | Sélectionner tout |
1 2 | $ cd ~/pico-sdk $ git submodule update --init |
il faut maintenant installer le compilateur et l'utilitaire CMake (attention : + de 2 Go de fichiers) :
Code bash : | Sélectionner tout |
$ sudo apt install cmake gcc-arm-none-eabi libnewlib-arm-none-eabi libstdc++-arm-none-eabi-newlib
Il faut ensuite que le système connaisse le chemin (path) vers le kit. Vous pouvez par exemple éditer le fichier ~/.bashrc, avec l'éditeur nano :
Code bash : | Sélectionner tout |
$ sudo nano ~/.bashrc
Code bash : | Sélectionner tout |
export PICO_SDK_PATH=~/pico-sdk
2) Un premier projet : le blink
Pour un premier programme, vous allez faire clignoter la LED intégrée en surface de la carte Raspberry Pi Pico (comme c'est original !!).
Commencez par créer le dossier du projet, par exemple :
Code bash : | Sélectionner tout |
1 2 3 | $ cd ~ $ mkdir essai-blink-pico $ cd essai-blink-pico |
Avec votre éditeur de sources préférés, créez le fichier source blink.c en langage C (d'après pico-examples/blink) :
Code c : | Sélectionner tout |
1 2 3 4 5 6 7 8 9 10 11 12 13 | #include "pico/stdlib.h" int main() { const uint LED_PIN = PICO_DEFAULT_LED_PIN; gpio_init(LED_PIN); gpio_set_dir(LED_PIN, GPIO_OUT); while (true) { gpio_put(LED_PIN, 1); sleep_ms(250); gpio_put(LED_PIN, 0); sleep_ms(250); } } |
Les étapes de construction (build) du projet qui suivent sont plus délicates à comprendre. Vous trouverez les détails au paragraphe Quick-start your own project.
Le script de compilation est produit par l'utilitaire CMake. Pour comprendre CMake, je vous recommande l'excellent tutoriel : Utiliser CMake pour compiler un projet par Alexandre Laurent (aka LittleWhite).
Fonctionnement de CMake
Image reproduite d'après https://alexandre-laurent.developpez...toriels/cmake/
avec l'aimable autorisation de LittleWhite
Ainsi, le dossier du projet complet ~/essai-blink-pico comportera les fichiers et dossier suivants :
~/essai-blink-pico
|__ blink.c
|__ build
|__ CMakeLists.txt
|__ pico_sdk_import.cmake
- Le fichier pico_sdk_import.cmake est une copie de celui présent dans le sous-dossier d'installation du kit ~/pico-sdk/external. Voir aussi pico-sdk/external/pico_sdk_import.cmake.
- Le fichier générique CMakeLists.txt qui produira le script de compilation aura le contenu suivant :
Code : Sélectionner tout 1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21cmake_minimum_required(VERSION 3.13) # initialize the SDK based on PICO_SDK_PATH # note: this must happen before project() include(pico_sdk_import.cmake) project(blink) # initialize the Raspberry Pi Pico SDK pico_sdk_init() # rest of your project add_executable(blink blink.c ) # Add pico_stdlib library which aggregates commonly used features target_link_libraries(blink pico_stdlib) # create map/bin/hex/uf2 file in addition to ELF. pico_add_extra_outputs(blink)
- Il vous reste à créer un dossier build où seront stockés les fichiers de construction du projet.
3) Génération du projet
Placez-vous dans le dossier ~/essai-blink-pico/build et lancez CMake :
Code bash : | Sélectionner tout |
1 2 | $ cd ~/essai-blink-pico/build $ cmake .. |
Si tout se passe bien, le compte-rendu se termine par des messages triomphants, du genre :
...
-- Configuring done
-- Generating done
-- Build files have been written to: /home/fleb/essai-blink-pico/build
Code bash : | Sélectionner tout |
$ make
4) Flasher le fichier binaire uf2 dans la carte
Le fichier avec l'extension uf2 qui nous intéresse, à flasher dans la carte, est dans le dossier ~/essai-blink-pico/build : blink.uf2.
Quand la carte est connectée par le câble USB, exécutez la séquence suivante :
- appuyez sur le bouton BOOTSEL de la carte ;
- appuyez sur le bouton Reset (placé entre les broches (28)GND et (30)RUN, voir plus haut) ;
- relâchez le bouton Reset ;
- relâchez le bouton BOOTSEL.
La carte passe alors en mode USB et se comporte comme une clé USB. Un dossier monté devrait apparaître comme ci-dessous :
Il reste à flasher le binaire par glisser-déposer du fichier blink.uf2 dans ce dossier.
Un dernier Reset, et le miracle du blink se produit...
5) Sitographie
Et sur Developpez.com :
- La fondation Raspberry Pi fait son entrée dans l'univers des microcontrôleurs avec sa nouvelle carte à 4 $ dénommée Pi Pico
- Raspberry Pi Pico W, la plateforme IoT arrive avec le Wi-Fi intégré à 6 dollars
- La Fondation Raspberry Pi lance une sonde de débogage pour trouver et analyser les erreurs dans le code exécuté sur le Pi Pico
En complément :