PlatformIO IDE for VSCodeの設定
はじめに
Visual Studio Code (VSCode)は、Microsoft社が提供する軽量ながら強力なソース コード エディターで、デスクトップ上で実行され、Windows、macOS、および Linux で使用できます。PlatformIO IDEは、VSCodeの拡張機能で、ビルドが早く、ライブラリやボードのバージョンがプロジェクト毎に管理されているのが特長です。
用意するもの
- Basic Kit 2
- パソコン (Windows、macOS、または Linux)
事前準備
Pythonのインストール
PlatformIO IDEを動かすには、Pythonが必要です。こちらを参照して、Pythonインストールして下さい。
PlatformIO IDEのインストール
- PlatformIO IDEは、VSCodeの拡張機能なので、まず、VSCodeをインストールして下さい。
拡張機能
(画面左のバー)をクリックし、検索窓に以下を入力して、拡張機能をインストールします。Japanese Language Pack for Visual Studio Code
platformio ide
Serial Monitor
teleplot
STM32CubeProg とArduino IDEのインストール
STM32MCUにプログラムを書き込むために、以下のインストールが必要になります。
クイックスタート
「Hello Wold」の事例で、platformIO IDEの使い方を紹介します。
-
VSCodeを立ち上げ、
ファイル
→新しいウィンドウ
を開きます。 -
PlatformIO
(画面左のバー)をクリックし、PLATFORMIO QUICK ACCESS(画面左)を表示させます。 -
PIO Home/Open
をクリックします。 -
New Project
をクリックすると、Project Wizardが表示されます。Name
、Boad
、Framework
を以下の通り入力して、Finish
をクリックします。新しいBoardを選択した時、プログラミングに必要なファイルのダウンロードするために数分かかります。- Name:
STM32_Hello_World_Pjt
と記入 - Board:
Leafony Systems AP03
を選択 - Framework:
Arduino
を選択
- Name:
-
platformio.ini
(画面左)を開き、 Projectで定義したBoardとFrameworkが、正しく定義されていることを確認します。
[env:leafony_ap03]
platform = ststm32
board = leafony_ap03
framework = arduino
- STM32 MCUは、COMポートの番号とプログラムファイルの実行場所をplatformio.iniに記載して下さい。COMポートの番号は、シリアルモニターから確認出来ます。
Windowsの場合
;upload_protocol for Windows
upload_port = COM<番号>
upload_command = %%userprofile%%\AppData\Local\Arduino15\packages\STM32\tools\STM32Tools\1.4.0\tools\win\stm32CubeProg.bat 1 $SOURCE $UPLOAD_PORT -s
macOSの場合
;upload_protocol for macOS
upload_port = cu.usbserial-<シリアル番号>
upload_command = /Users/<ユーザ名>/Library/Arduino15/packages/STM32/tools/STM32Tools/1.4.0/tools/macosx/stm32CubeProg.sh 1 $SOURCE $UPLOAD_PORT -s
- また、 シリアル通信のボーレートを
monitor_speed =
で定義し、platformio.iniに記載して下さい。
monitor_speed = 115200
src/main.cpp
(画面左)を開き、以下のコードを貼り付けて下さい。 PlatformIO IDEのコードは、Arduino IDEのスケッチの先頭に#include <Arduino.h>
を加えます。
#include <Arduino.h>
void setup() {
Serial.begin(115200);
delay(10);
}
void loop(){
Serial.println("Hello World");
delay(1000);
}
- ソースコード:STM32_Hello_Wold_Pjt
-
PlatformIO ツールバー(画面下のバー)の
Project Environment Switcher
ボタンを押すと、アクティブなプロジェクが画面上側に全て表示されます。実行するプロジェクトを正しく選択して、Build
ボタンを押して下さい。日本語のフォルダの下にある場合は、書き込みすることが出来ないので別の場所にコピーします。 -
こちら を参考に、LeafonyをPCに接続し、STM32 MCUリーフの
プログラムスイッチ
をプログラム側(LED点灯)にし下さい。 -
Upload
ボタンを押すと、プログラムがMCUに書き込まれます。SUCCESS TooK XX.XX seconds
と表示が出ても、以下の表示が出ていない時は、正しく書き込まれていないので、注意をして下さい。 -
正しく書き込まれたら、
プログラムスイッチ
を実行側(LED消灯)にして下さい。 -
MCUのリセットボタンを押して、プログラムを実行させます。
-
シリアルモニター
ボタンを押して起動させ、Hello Wolrd
を表示が出来れば完成です。
STM32CubeProgによるプログラムの書き込み
-
STM32CubeProgでもプログラムを書き込むことが出来ます。こちらをを参照し下さい。
-
プログラムのイメージは、以下にあります。2
C:\Users\ユーザ名\Documents\PlatformIO\Projects\STM32_Hello_World_Pjt\.pio\build\LEAFONY_AP03\firmware.elf
-
画面左のErasing & Programingをクリックして、
File path
にイメージファイルを指定し、プログラムを書き込んで下さい。
CPUの周波数を80MHz(デフォルト)から16MHzに設定変更
CPUの周波数は、80MHz(デフォルト)に設定されています。省電力を実現するためにCPUの周波数を下げることは有効な手段なので、CPUの周波数を16MHzに設定出来るようにしました。設定方法を以下に記します。
platformio.ini
に以下を追記して下さい。
; Enable function to set CPU frequency to 16 MHz in Leafony_tools.cpp
build_flags = -D CPUCLOCK_LOW
-
leafony_tools.cpp
のファイルを以下からダウンロードし、src
に保存して下さい。https://github.com/Leafony/platformio-LEAFONY_AP03
-
以下のソースコードを実行して、CPUの周波数が16MHzに設定されていることをシリアルモニターで確認して下さい。
- ソースコード:STM32_CPU_Frequency_Pjt
ライブラリ
-
インストールの仕方 ライブラリは、platformio.ini の最後の行に、
lib_deps =
で定義すれば、PCにインストールされます。定義の仕方は、GitHubのURLを直接指定する方法とLibraries
で指定する方法の二通りがあります。 -
各リーフのライブラリ一覧は、以下の通りです。
Item | lib_deps | Tags | Description |
---|---|---|---|
BLE | https://github.com/Leafony/TBGLib | Bluetoothライブラリ | |
4-Sensors | adafruit/Adafruit Unified Sensor@^1.1.6 | ユニファイドセンサドライバ | |
adafruit/Adafruit BusIO@^1.14.1 | Bus IOライブラリ | ||
https://github.com/ameltech/sme-hts221-library | 温湿度センサライブラリ | ||
closedcube/ClosedCube OPT3001@^1.1.2 | 照度センサライブラリ | ||
adafruit/Adafruit LIS3DH@1.1.2 | 1.1.2 | 加速度センサライブラリ | |
LCD | tomozh/ST7032@0.0.0-alpha+sha.501bf64fe6 | LCDライブラリ | |
AVR MCU | paulstoffregen/MsTimer2@^1.1 | タイマ割り込みライブラリ | |
RTC&MicroSD | adafruit/RTClib@^2.1.1 | RTCライブラリ | |
STM32 MCU | stm32duino/STM32duino RTC @1.2.0 | 1.2.0 | STM32RTCライブラリ |
stm32duino/STM32duino Low Power@^1.2.2 | STM32LowPowerライブラリ | ||
LTE-M | https://github.com/Leafony/LteLeafV4 | LTE-Mライブラリ |
シリアルプロッター
PlatformIOには、Arduino IDEにあるシリアルプロッターがないため、VSCodeの拡張機能であるTeleplot for VSCode
を導入します。サンプルのソースコードをダウンロードして、試して下さい。
-
GitHubからソースコードをダウンロードし、パソコンの所定の場所に保存1 します。
- ソースコード:STM32_Teleplot_Example_1
-
プログラムを実行して下さい。
-
画面下の
teleplot
の表示をクリックして、COMポートを指定して、Open
を押すとグラフが表示されます -
>varName:1234\n
という形式のシリアルメッセージは、すべてteleplot
に表示されます。詳しくは、こちらを参照して下さい。
// Plot a sinus
Serial.print(">sin:");
Serial.println(sin(i));
// Plot a cosinus
Serial.print(">cos:");
Serial.println(cos(i));
STM32 Beginner Examples
PlatformIO IDEを使った簡単なソースコードを準備しました。GitHubからダウンロードし、パソコンの所定の場所に保存1 してプログラムを試して下さい。
Item | Source code |
---|---|
温湿度センサ読み取り | STM32_Thermo-Hygrometer_Pjt |
照度センサ読み取り | STM32_Illuminance_Meter_Pjt |
加速度センサ読み取り | STM32_Accelerometer_Pjt |
Tips
MCUとBoardとの関係
LeafonyのMCUとPlatformIO IDEのBoardとの関係は、以下の様になります。
Type | Item | Platform | Board | Upload | |
---|---|---|---|---|---|
AP01 | AVR MCU | atmelavr | Arduino Pro or Pro Mini ATmega328(3.3v,8Mhz) | COMポートの自動検出 | |
AP02 | ESP32 MCU | Espressif 32 | Espressif ESP32 Dev Module | COMポートの自動検出 | |
AP03 | STM32 MCU | ststm32 | Leafony Systems AP03 | COMポートの自動検出が出来ない。 |
プログラムを記述する時のArduino IDEとの違い
-
#include <Arduino.h>をプログラムの先頭に記述 Arduino IDEは、プログラム言語としてはC++を使っており、基本的な型の宣言やよく使うライブラリのヘッダファイルは
Arduino.h
を書かなくても自動的にインクルードされますが、PlatformIO IDEは、Arduino.h
がプログラムの先頭に必要に記述する必要があります。 -
独自関数は使用する関数の前に定義 Arduino IDEは、独自関数の定義を使用する関数の後に書いてもビルドが
SUCCESS
になりますが、PlatformIO IDEは、C++のルールに従って独自関数は使用する関数の前に定義する必要があります。
例えば、以下は、独自関数の設定は、使用する関数の後に書いてあるのでビルドがFAIL
になります。
void setup() {
// put your setup code here, to run once:
func();
}
void func() {
;
}
以下は、独自関数の定義は、使用する関数の前に書いてあるのでビルドがSUCSESS
になります。
void func() {
;
}
void setup() {
// put your setup code here, to run once:
func();
}
以下は、プロトタイプ宣言するので、ビルドがSUCSESS
になります。
// Prototypes
void func(void);
void setup() {
// put your setup code here, to run once:
func();
}
void func() {
;
}
プロジェクトフォルダの名前変更や削除
Project Wizarで、New Projectを立ち上げると、フォルダが作成され、デフォルトでは、~/Documents/PlatformIO/Projects に保存されます。 Projectの名前変更やフォルダの削除は、Project Wizarではなく、エクスプローラから直接出来ます。
プロジェクトフォルダの保存場所の設定
プロジェクトフォルダの保存場所の設定は、Project Wizarではなく、ターミナルから行います。
-
VSCodeを立ち上げ、
ファイル
→新しいウィンドウ
を開きます。 -
PlatformIO
(画面左のバー)をクリックし、PLATFORMIO QUICK ACCESS(画面左)を表示させます。 -
PIO Home/Open
をクリックします。 -
ターミナルを立ち上げて、以下のコードを実行します。
pio settings set projects_dir <設定したい(絶対)パス>
-
VSCodeを再起動します。
PlatformIOの公式ドキュメント
PlatformIO の公式ドキュメントは、以下の通りです。
ttps://docs.platformio.org/en/latest/integration/ide/vscode.html#ide-vscode
STM32MCUのボード・ファイル(参考)
Leafony Systems AP03
のボードが、2023年10月に、platformIOに登録されたため、直接ダウンロードすることが出来るようになり、以下の方法でボードを定義する必要がなくなりました。
STM32MCUは、NUCLEO-L452REとピンアサインが異なるため、STM32MCUのBoardファイル(③、④)が必要になります。PlatformIOで NUCLEO-L452REのプロジェクトを立ち上げると①と②がPCにダウンロードされます。次に③と④をGitHubからダウンロードしてpcの保存すれば完了です。
Nucleo L452REのプロジェクトの立ち上げ
-
VSCodeを立ち上げ、
ファイル
→新しいウィンドウ
を開きます。 -
PlatformIO
(画面左のバー)をクリックし、PLATFORMIO QUICK ACCESS(画面左)を表示させます。 -
PIO Home/Open
をクリックします。 -
New Project
をクリックすると、Project Wizardが表示されます。Name
、Boad
、Framework
を以下の通り入力して、Finish
をクリックします。新しいBoardを選択した時、プログラミングに必要なファイルのダウンロードするために数分かかります。- Name:
Test
と記入 - Board:
ST Nucleo L452RE
を選択 - Framework:
Arduino
を選択
- Name:
-
C:\Users\ユーザ名\ .platformio の下に、①と②のふたつのフォルダが出来ていることを確認して下さい。
③Leafony_AP03と④Leafony_AP03.jsonのダウンロードと保存
-
以下からダウンロードし、所定の場所に保存して下さい。
https://github.com/Leafony/platformio-LEAFONY_AP03
-
Project Wizardの
Board
の検索窓にLeafony_AP03
が表示されることを確認して下さい。