「インストール - Arduino IDE」の版間の差分
(同じ利用者による、間の47版が非表示) | |||
3行目: | 3行目: | ||
Arduino IDEを用いることで、スケッチを作成して、USBケーブルを通じてArduinoボードにアップロードするための環境が整う。<br> | Arduino IDEを用いることで、スケッチを作成して、USBケーブルを通じてArduinoボードにアップロードするための環境が整う。<br> | ||
<br> | <br> | ||
<center> | |||
{| class="wikitable" | style="background-color:#fefefe;" | |||
|- | |||
|- | ! colspan="4" style="background-color:#44CC99;" | 参考書 | ||
| < | |- style="text-align: center;" | ||
|- | | style="width: 25%"| <center><html><a href="https://www.amazon.co.jp/Prototyping-Lab-%E7%AC%AC2%E7%89%88-%E2%80%95%E3%80%8C%E4%BD%9C%E3%82%8A%E3%81%AA%E3%81%8C%E3%82%89%E8%80%83%E3%81%88%E3%82%8B%E3%80%8D%E3%81%9F%E3%82%81%E3%81%AEArduino%E5%AE%9F%E8%B7%B5%E3%83%AC%E3%82%B7%E3%83%94-Make/dp/4873117895?__mk_ja_JP=%E3%82%AB%E3%82%BF%E3%82%AB%E3%83%8A&keywords=Prototyping+Lab+%E3%80%8C%E4%BD%9C%E3%82%8A%E3%81%AA%E3%81%8C%E3%82%89%E8%80%83%E3%81%88%E3%82%8B%E3%80%8D%E3%81%9F%E3%82%81%E3%81%AEArduino%E5%AE%9F%E8%B7%B5%E3%83%AC%E3%82%B7%E3%83%94&qid=1669498194&qu=eyJxc2MiOiItMC4wMSIsInFzYSI6IjAuMDAiLCJxc3AiOiIwLjAwIn0%3D&sr=8-2&linkCode=li2&tag=presire2-22&linkId=1b5756aa855a4be5a88f51de3dd0ba99&language=ja_JP&ref_=as_li_ss_il" target="_blank"><img style="width: 250px; height: auto;" src="https://m.media-amazon.com/images/I/91KfZbyAH6L._SL1500_.jpg" ></a></html><br>[https://www.amazon.co.jp/Prototyping-Lab-%E7%AC%AC2%E7%89%88-%E2%80%95%E3%80%8C%E4%BD%9C%E3%82%8A%E3%81%AA%E3%81%8C%E3%82%89%E8%80%83%E3%81%88%E3%82%8B%E3%80%8D%E3%81%9F%E3%82%81%E3%81%AEArduino%E5%AE%9F%E8%B7%B5%E3%83%AC%E3%82%B7%E3%83%94-Make/dp/4873117895?__mk_ja_JP=%E3%82%AB%E3%82%BF%E3%82%AB%E3%83%8A&keywords=Prototyping+Lab+%E3%80%8C%E4%BD%9C%E3%82%8A%E3%81%AA%E3%81%8C%E3%82%89%E8%80%83%E3%81%88%E3%82%8B%E3%80%8D%E3%81%9F%E3%82%81%E3%81%AEArduino%E5%AE%9F%E8%B7%B5%E3%83%AC%E3%82%B7%E3%83%94&qid=1669498194&qu=eyJxc2MiOiItMC4wMSIsInFzYSI6IjAuMDAiLCJxc3AiOiIwLjAwIn0%3D&sr=8-2&linkCode=ll1&tag=presire2-22&linkId=f071b96c70015985136a09fc7385ac87&language=ja_JP&ref_=as_li_ss_tl Prototyping Lab 第2版<br>「作りながら考える」ためのArduino実践レシピ]</center> | ||
| < | | style="width: 25%"| <center><html><a href="https://www.amazon.co.jp/Arduino%E3%82%92%E3%81%AF%E3%81%98%E3%82%81%E3%82%88%E3%81%86-%E7%AC%AC4%E7%89%88-Make-Massimo-Banzi/dp/4814400233?__mk_ja_JP=%E3%82%AB%E3%82%BF%E3%82%AB%E3%83%8A&crid=3C7AL0F17GT0Z&keywords=Arduino%E3%82%92%E3%81%AF%E3%81%98%E3%82%81%E3%82%88%E3%81%86&qid=1683612888&sprefix=arduino%E3%82%92%E3%81%AF%E3%81%98%E3%82%81%E3%82%88%E3%81%86%2Caps%2C158&sr=8-1&linkCode=li2&tag=presire2-22&linkId=f9aba5b02d269684b67a4901e2d48ab6&language=ja_JP&ref_=as_li_ss_il" target="_blank"><img style="width: 250px; height: auto;" src="https://m.media-amazon.com/images/I/813u8pOj7cL._SL1500_.jpg" /></a></html><br>[https://www.amazon.co.jp/Arduino%E3%82%92%E3%81%AF%E3%81%98%E3%82%81%E3%82%88%E3%81%86-%E7%AC%AC4%E7%89%88-Make-Massimo-Banzi/dp/4814400233?__mk_ja_JP=%E3%82%AB%E3%82%BF%E3%82%AB%E3%83%8A&crid=3C7AL0F17GT0Z&keywords=Arduino%E3%82%92%E3%81%AF%E3%81%98%E3%82%81%E3%82%88%E3%81%86&qid=1683612888&sprefix=arduino%E3%82%92%E3%81%AF%E3%81%98%E3%82%81%E3%82%88%E3%81%86%2Caps%2C158&sr=8-1&linkCode=ll1&tag=presire2-22&linkId=6c9f412d9818bcd52187de391148e08d&language=ja_JP&ref_=as_li_ss_tl Arduinoをはじめよう 第4版]</center> | ||
| style="width: 25%"| <center><html><a href="https://www.amazon.co.jp/Arduino-Book-Beginners-PROGRAMMING-PROJECTS-ebook/dp/B09ML2HC5M?__mk_ja_JP=%E3%82%AB%E3%82%BF%E3%82%AB%E3%83%8A&crid=1GRONF5XA47UR&keywords=arduino+%E6%B4%8B%E6%9B%B8&qid=1669498743&qu=eyJxc2MiOiIxLjQ4IiwicXNhIjoiMC4wMCIsInFzcCI6IjAuMDAifQ%3D%3D&refinements=p_72%3A82387051&rnid=82385051&s=english-books&sprefix=arduino+%E6%9C%AC%E6%B4%8B%E6%9B%B8%2Caps%2C178&sr=1-6&linkCode=li2&tag=presire2-22&linkId=85937e37fd5d1f50ae0db836cc05a2c1&language=ja_JP&ref_=as_li_ss_il" target="_blank"><img style="width: 250px; height: auto;" src="https://m.media-amazon.com/images/I/61QVgV+3fwL._SL1176_.jpg" ></a></html><br>[https://www.amazon.co.jp/Arduino-Book-Beginners-PROGRAMMING-PROJECTS-ebook/dp/B09ML2HC5M?__mk_ja_JP=%E3%82%AB%E3%82%BF%E3%82%AB%E3%83%8A&crid=1GRONF5XA47UR&keywords=arduino+%E6%B4%8B%E6%9B%B8&qid=1669498743&qu=eyJxc2MiOiIxLjQ4IiwicXNhIjoiMC4wMCIsInFzcCI6IjAuMDAifQ%3D%3D&refinements=p_72%3A82387051&rnid=82385051&s=english-books&sprefix=arduino+%E6%9C%AC%E6%B4%8B%E6%9B%B8%2Caps%2C178&sr=1-6&linkCode=ll1&tag=presire2-22&linkId=42147e00b4bc9cf28a6299fcda3da4bd&language=ja_JP&ref_=as_li_ss_tl Handbook of Arduino<br>100以上の実践的なガイド]</center> | |||
|- style="text-align: center;" | |||
| style="width: 25%"| <center><html><a href="https://www.amazon.co.jp/Exploring-Arduino-Techniques-Engineering-Wizardry-ebook/dp/B07ZL5GV94?__mk_ja_JP=%E3%82%AB%E3%82%BF%E3%82%AB%E3%83%8A&crid=1GRONF5XA47UR&keywords=arduino+%E6%B4%8B%E6%9B%B8&qid=1669498743&qu=eyJxc2MiOiIxLjQ4IiwicXNhIjoiMC4wMCIsInFzcCI6IjAuMDAifQ%3D%3D&refinements=p_72%3A82387051&rnid=82385051&s=english-books&sprefix=arduino+%E6%9C%AC%E6%B4%8B%E6%9B%B8%2Caps%2C178&sr=1-1&linkCode=li2&tag=presire2-22&linkId=2cfce35a939ebaeb405274aa0c857491&language=ja_JP&ref_=as_li_ss_il" target="_blank"><img style="width: 250px; height: auto;" src="https://m.media-amazon.com/images/I/51YEa0eKNLL.jpg" /></a></html><br>[https://www.amazon.co.jp/Exploring-Arduino-Techniques-Engineering-Wizardry-ebook/dp/B07ZL5GV94?__mk_ja_JP=%E3%82%AB%E3%82%BF%E3%82%AB%E3%83%8A&crid=1GRONF5XA47UR&keywords=arduino+%E6%B4%8B%E6%9B%B8&qid=1669498743&qu=eyJxc2MiOiIxLjQ4IiwicXNhIjoiMC4wMCIsInFzcCI6IjAuMDAifQ%3D%3D&refinements=p_72%3A82387051&rnid=82385051&s=english-books&sprefix=arduino+%E6%9C%AC%E6%B4%8B%E6%9B%B8%2Caps%2C178&sr=1-1&linkCode=ll1&tag=presire2-22&linkId=d43ecfef526a1499d26838cc0f103f40&language=ja_JP&ref_=as_li_ss_tl Exploring Arduino<br>技術者のためのツールとテクニック]</center> | |||
| style="width: 25%"| <center><html><a href="https://www.amazon.co.jp/ELEGOO-Arduino%E7%94%A8UNO-R3-%E6%9C%80%E7%B5%82%E7%89%88%E3%82%B9%E3%82%BF%E3%83%BC%E3%82%BF%E3%82%AD%E3%83%83%E3%83%88-UNO%E3%83%81%E3%83%A5%E3%83%BC%E3%83%88%E3%83%AA%E3%82%A2%E3%83%AB%E4%BB%98-Items/dp/B06Y56JV64?__mk_ja_JP=%E3%82%AB%E3%82%BF%E3%82%AB%E3%83%8A&crid=27XI7KRHV2FW9&keywords=Arduino+%E3%82%B9%E3%82%BF%E3%83%BC%E3%82%BF%E3%83%BC&qid=1669498475&qu=eyJxc2MiOiIyLjk1IiwicXNhIjoiMi43OSIsInFzcCI6IjIuNDQifQ%3D%3D&sprefix=arduino+%E3%82%B9%E3%82%BF%E3%83%BC%E3%82%BF%E3%83%BC%2Caps%2C167&sr=8-6&linkCode=li2&tag=presire2-22&linkId=2138c12060b5926f1a945b864b49b778&language=ja_JP&ref_=as_li_ss_il" target="_blank"><img style="width: 250px; height: auto;" src="https://m.media-amazon.com/images/I/81AgsEZ+ULL._SL1500_.jpg" /></a></html><br>[https://www.amazon.co.jp/ELEGOO-Arduino%E7%94%A8UNO-R3-%E6%9C%80%E7%B5%82%E7%89%88%E3%82%B9%E3%82%BF%E3%83%BC%E3%82%BF%E3%82%AD%E3%83%83%E3%83%88-UNO%E3%83%81%E3%83%A5%E3%83%BC%E3%83%88%E3%83%AA%E3%82%A2%E3%83%AB%E4%BB%98-Items/dp/B06Y56JV64?__mk_ja_JP=%E3%82%AB%E3%82%BF%E3%82%AB%E3%83%8A&crid=27XI7KRHV2FW9&keywords=Arduino+%E3%82%B9%E3%82%BF%E3%83%BC%E3%82%BF%E3%83%BC&qid=1669498475&qu=eyJxc2MiOiIyLjk1IiwicXNhIjoiMi43OSIsInFzcCI6IjIuNDQifQ%3D%3D&sprefix=arduino+%E3%82%B9%E3%82%BF%E3%83%BC%E3%82%BF%E3%83%BC%2Caps%2C167&sr=8-6&linkCode=ll1&tag=presire2-22&linkId=a8468bbdb25691b7217d83d709780eab&language=ja_JP&ref_=as_li_ss_tl ELEGOO Arduino UNO R3<br>最終版スタータキット<br>UNOチュートリアル付]</center> | |||
|} | |} | ||
</center> | |||
<br><br> | <br><br> | ||
20行目: | 25行目: | ||
セキュリティメッセージが表示される場合は、[インストール]ボタンを押下する。<br> | セキュリティメッセージが表示される場合は、[インストール]ボタンを押下する。<br> | ||
<br> | <br> | ||
==== | ==== RHEL / SUSE ==== | ||
Arduino IDEは、以下の3つのインストール方法がある。<br> | Arduino IDEは、以下の3つのインストール方法がある。<br> | ||
ここでは、リポジトリに追加してインストールする方法およびインストールせずに使用する方法を記載する。<br> | ここでは、リポジトリに追加してインストールする方法およびインストールせずに使用する方法を記載する。<br> | ||
28行目: | 33行目: | ||
<br> | <br> | ||
===== リポジトリを追加してインストール ===== | ===== リポジトリを追加してインストール ===== | ||
<u>Arduino IDE 2を使用する場合、依存関係のライブラリをインストールする。</u><br> | |||
# RHEL | |||
sudo dnf install fuse | |||
# SUSE | |||
sudo zypper install fuse | |||
<br> | |||
まず、Arduino IDEのリポジトリを追加する。<br> | まず、Arduino IDEのリポジトリを追加する。<br> | ||
sudo zypper --gpg-auto-import-keys ar -f https://download.opensuse.org/repositories/CrossToolchain:/avr/ | # SUSE | ||
sudo zypper --gpg-auto-import-keys ar -f 'https://download.opensuse.org/repositories/CrossToolchain:/avr/$releasever/' 'CrossToolchain:avr' | |||
sudo zypper refresh | sudo zypper refresh | ||
<br> | <br> | ||
35行目: | 48行目: | ||
sudo zypper install arduino | sudo zypper install arduino | ||
<br> | <br> | ||
===== | ===== 手動でインストール ===== | ||
[https://www.arduino.cc/en/Main/Software Arduinoの公式サイト]から、Arduino | <u>Arduino IDE 2を使用する場合、依存関係のライブラリをインストールする。</u><br> | ||
# RHEL | |||
sudo dnf install fuse | |||
# SUSE | |||
sudo zypper install fuse | |||
<br> | |||
[https://www.arduino.cc/en/Main/Software Arduinoの公式サイト]から、Arduino IDE 2をダウンロードする。<br> | |||
ダウンロードしたファイルを解凍する。<br> | |||
unzip arduino-ide_<バージョン>_Linux_64bit.zip | |||
mv arduino-ide_<バージョン>_Linux_64bit Arduino_IDE | |||
<br> | <br> | ||
必要ならば、Arduino IDE 2を任意のディレクトリに配置する。<br> | |||
mv Arduino_IDE <任意のインストールディレクトリ> | |||
<br> | <br> | ||
Arduino IDE 2のデスクトップエントリファイルを作成する。<br> | |||
vi ~/.local/share/applications/org.Arduino-IDE.desktop | |||
<br> | |||
<syntaxhighlight lang="ini"> | |||
# ~/.local/share/applications/org.Arduino-IDE.desktopファイル | |||
[Desktop Entry] | [Desktop Entry] | ||
49行目: | 75行目: | ||
GenericName=Arduino IDE | GenericName=Arduino IDE | ||
Comment=Open-source electronics prototyping platform | Comment=Open-source electronics prototyping platform | ||
Exec= | Exec=/<Arduino IDEのインストールディレクトリ>/arduino | ||
Icon=/<Arduino IDE 2のインストールディレクトリ>/resources/app/resources/icons/512x512.png | |||
Categories=Development;IDE;Electronics; | |||
Keywords=embedded electronics;electronics;avr;microcontroller; | |||
MimeType=text/x-arduino; | |||
StartupWMClass=processing-app-Base | StartupWMClass=processing-app-Base | ||
Terminal=false | Terminal=false | ||
</syntaxhighlight> | |||
<br><br> | |||
== Arduino IDEの設定 == | |||
==== フォントの設定 ==== | |||
Arduino IDE 1.8系, 2系において、標準フォントの表示が粗いため、別のフォントを使用することを推奨する。<br> | |||
<br> | |||
フォントの設定を行うため、preferences.txtファイルを以下のように編集する。<br> | |||
* Windows | |||
*: C:\Users\<ユーザ名>\AppData\Local\Arduino<バージョン>\preferences.txt | |||
* RHEL / SUSE | |||
*: ~/.arduino<バージョン>/preferences.txt | |||
<br> | |||
# C:\Users\<ユーザ名>\AppData\Local\Arduino<バージョン>\preferences.txtファイル | |||
# または | |||
# ~/.arduino<バージョン>/preferences.txtファイル | |||
editor.font=Noto Sans,plain,14 | |||
<br> | |||
==== Arduino IDE 1.8系の設定 ==== | |||
スケッチをアップロードする時、ボードとシリアルポートを選択した後に、以下に示すようなエラーが出力される場合がある。<br> | |||
Error opening serial port ... | |||
<br> | |||
これを解決するため、シリアルポートのパーミッションを設定する。<br> | |||
まず、PCとArduinoを接続した後、/dev/ttyACM<span style="color: #20C000">X</span>の所属グループ名を確認する。 (X : 数値)<br> | |||
ls -l '/dev/ttyACM*' | |||
# 出力例 | |||
crw-rw---- 1 root dialout 188, 0 5 apr 23.01 ttyACM0 | |||
<br> | |||
Arduino IDE 1.8系を使用するユーザをdialoutグループをメンバーにする必要がある。また、必要ならば、lockグループ、uucpグループもメンバーにする。<br> | |||
<u>ただし、ほとんどの環境では、dialoutグループにユーザを追加するだけでよい。</u><br> | |||
<br> | |||
もし、YaSTで行う場合は、[セキュリティとユーザ]セクション - [ユーザとグループの管理]を選択して、必要な変更を行う。<br> | |||
また、ターミナルから実行するには、以下のコマンドを実行する。<br> | |||
sudo usermod -aG dialout $USER | |||
# または | |||
sudo usermod -aG tty dialout lock uucp $USER | |||
<br> | |||
もし、上記のグループからユーザを削除する場合は、以下のコマンドを実行する。<br> | |||
sudo gpasswd -d $USER tty dialout lock uucp | |||
<br> | |||
設定を反映させるため、PCを再ログイン、または、再起動する。<br> | |||
<br> | |||
スケッチをボードにアップロード、および、シリアルモニターが使用できるかどうかを確認する。<br> | |||
<br> | |||
==== Arduino IDE 2系の設定 ==== | |||
Arduino IDE 2がシリアルポートにアクセスしてソースコードをボードにアップロードできるようにするには、/etc/udev/rules.d/99-arduino.rulesファイルを作成して、ルールを追加する。<br> | |||
sudo vi /etc/udev/rules.d/99-arduino.rules | |||
<br> | |||
# /etc/udev/rules.d/99-arduino.rulesファイル | |||
SUBSYSTEMS=="usb", ATTRS{idVendor}=="2341", GROUP="plugdev", MODE="0666" | |||
<br> | |||
Udevを再起動、または、PCを再起動する。<br> | |||
<br> | |||
<u>※注意</u><br> | |||
<u>Udevを再起動する場合 (特に、変更が特定のデバイスに関連している場合) は、そのデバイスを再接続する、または、</u><br> | |||
<u><code>sudo udevadm trigger</code>コマンドを実行して対話的にデバイスのイベントをトリガーする必要がある。</u><br> | |||
# Udevを再起動 | |||
sudo udevadm control --reload-rules | |||
または | |||
sudo udevadm trigger --action=change または sudo udevadm trigger | |||
# PCを再起動 | |||
sudo systemctl reboot | |||
<br><br> | |||
== CH34xドライバを使用する場合 == | |||
==== CH34xドライバのパッチのインストール ==== | |||
<u>Arduinoのクローン</u>において、Linux標準のCH34xドライバを使用する場合、シリアル通信に失敗するケースがいくつか報告されている。<br> | |||
もし、問題が発生する場合、CH34xのパッチを当てたドライバをインストールすることができる。<br> | |||
<br> | |||
# CH34xを使用したデバイスを、USBポートから外す。 | |||
# 問題が発生したログを確認する。 | |||
#: <code>sudo dmesg | grep - iE ch34</code> | |||
#: <br> | |||
#: <code>出力例:</code> | |||
#: <code>[ xxx] ch34x ttyUSB0: ch34x converter now disconnected from ttyUSB0</code> | |||
#: <code>[ xxx] ch34x 3-2:1.0: device disconnected</code> | |||
# パッチ適用済みのCH34xのビルドに必要なライブラリをインストールする。 | |||
#: <code>sudo zypper install kernel-source</code> | |||
#: <br> | |||
# [https://github.com/juliagoda/CH341SER パッチ適用済みのCH34xのGithub]にアクセスして、ドライバのソースコードをダウンロードする。 | |||
# パッチ適用済みのCH34xをビルドおよびインストールする。 | |||
#: <code>sudo make clean</code> | |||
#: <code>sudo make -j $(nproc)</code> | |||
#: <code>sudo make load</code> | |||
# 古いドライバをアンインストールする。 | |||
#: <code>sudo rmmod ch341</code> | |||
# 現在インストールされているモジュールの一覧を表示する。 | |||
#: <code>lsmod | grep ch34</code> | |||
# CH34xを使用したデバイスを、USBポートに接続する。 | |||
# 接続に関するログを確認する。 | |||
#: <code>sudo dmesg | grep - iE ch34</code> | |||
#: <br> | |||
#: <code>出力例:</code> | |||
#: <code>[ xxx] ch341-uart ttyUSB0: ch341-uart converter now disconnected from ttyUSB0</code> | |||
#: <code>[ xxx] ch341 3-2:1.0: device disconnected</code> | |||
<br> | |||
場合によっては、シリアルポートのパーミッションを設定する必要がある。<br> | |||
<u>PCの環境において、CH34xがどのように列挙されたかにより、デバイスファイル(/dev/ttyUSB0)が異なる場合があるため、</u><br> | |||
<u>シリアルポートの設定に問題がある場合は、必要に応じてポートを調整すること。</u><br> | |||
sudo usermod -a -G dialout $USER | |||
sudo chmod a+rw /dev/ttyUSB0 | |||
<br><br> | |||
== ライブラリのディレクトリ == | |||
==== Winodws ==== | |||
Arduino IDEからインストールしたライブラリは、C:\Users\[ユーザー名]\Documents\Arduino\librariesフォルダに保存される。<br> | |||
<br> | |||
また、システムにプリインストールされているライブラリは、C:\Program Files\Arduino IDE\resources\libraryフォルダに保存される。<br> | |||
<br> | |||
なお、ライブラリの場所を確認する場合は、Arduino IDEのメイン画面から、[ファイル] - [環境設定]から、[スケッチブックの保存場所]ボタンを押下して確認できる。<br> | |||
デフォルトでは、ドキュメント\Arduinoに設定されている。<br> | |||
<br> | |||
==== Linux ==== | |||
Arduino IDEからインストールしたライブラリは、~/Arduino/librariesディレクトリに保存される。<br> | |||
<br> | |||
なお、Arduino IDE 2では、2種類のライブラリの保存場所がある。<br> | |||
* ユーザがインストールしたライブラリ | |||
*: ~/Arduino/libraries | |||
* システムにプリインストールされているライブラリ | |||
*: ~/.arduino15/libraries | |||
*: /usr/share/arduino/libraries | |||
<br> | |||
なお、ライブラリの場所を確認する場合は、Arduino IDEのメイン画面から、[ファイル] - [環境設定]から、[スケッチブックの保存場所]ボタンを押下して確認できる。<br> | |||
<br><br> | <br><br> | ||
== | == エラー関連 == | ||
Arduino | ==== 書き込みできない場合 ==== | ||
プログラムの書き込み時において、以下に示すようなエラーが出力される場合がある。<br> | |||
Cannot perform port reset: 1200-bps touch: setting DTR to OFF: broken pipe | |||
<br> | |||
このエラーは、Arduinoのブートローダーとの通信に問題が発生している典型的なケースである。<br> | |||
* 解決方法 1 : デバイスファイルのパーミッション変更する | |||
*: (デバイスファイル名が異なる場合は適宜変更すること) | |||
*: <code>sudo chmod a+rw /dev/ttyACM0</code> | |||
*: <br> | |||
* 解決方法 2 : 実行するユーザをdialoutグループに追加する | |||
*: <code>sudo usermod -a -G dialout $USER</code> | |||
*: この後、再ログインする必要がある。 | |||
*: <br> | |||
* 解決方法 2 : Arduinoを再起動する | |||
** ArduinoのUSBケーブルを抜き差しする、または、別のUSBポートに接続する。 | |||
** Arduinoのリセットボタンを押下した後に書き込みを実行する。 | |||
*: <br> | |||
* 解決方法 4 : Arduinoが認識されているかどうかを確認する | |||
*: デバイスの認識を確認する。 | |||
*: <code>ls -l /dev/ttyACM*</code> または <code>sudo dmesg | grep tty</code> | |||
*: <br> | |||
* 解決方法 5 : udevルールの確認と追加 | |||
*: udevルールを追加するため、以下に示す内容を追記する。 | |||
*: <code>sudo nano /etc/udev/rules.d/99-arduino.rules</code> | |||
*: <br> | |||
*: <syntaxhighlight lang="sh">SUBSYSTEM=="tty", ATTRS{idVendor}=="2341", ATTRS{idProduct}=="0043", MODE="0666" | |||
SUBSYSTEM=="tty", ATTRS{idVendor}=="2341", ATTRS{idProduct}=="0001", MODE="0666" | |||
</syntaxhighlight> | |||
*: <br> | |||
*: 設定を反映させるため、udevを再起動する。 | |||
*: <code>sudo udevadm control --reload-rules</code> | |||
<br> | |||
特に、解決方法1〜2の方法で解決することが多い。<br> | |||
<br> | |||
==== ファームウェアの復元 ==== | |||
===== Arudino UNO R4 WiFi ===== | |||
Arduino UNO R4 WiFiにはUSB-シリアル通信を処理するESP32-S3チップが搭載されている。<br> | |||
このチップのファームウェアは、Arduino IDEまたはArduino Cloudを使用してアップグレードできるが、アップグレード後のファームウェアが正常に動作しない場合がある。<br> | |||
<br> | |||
この時、espflashツールを使用してファームウェアを復元することができる。<br> | |||
<br> | |||
これは、以下に示すような症状が起きている場合に有効である。<br> | |||
* Arudino UNO R4 WiFiが、Arduino IDEまたはArduino Cloudの[ボード情報の取得]を選択すると、汎用のESP32ボード (例: ESP32-S3-Box) として検出される。 | |||
* Arudino UNO R4 WiFiが、Arduino IDEまたはArduino Cloudの[ボード情報の取得]を選択すると、データUSBケーブルでコンピュータに接続されているにもかかわらず、どのボードとしても検出されない。 | |||
<br> | <br> | ||
# まず、下図のように、Arduino UNO R4 WiFiにある6ピンヘッダのGNDピンとDownloadピンを短絡 (ショート) させる必要がある。<br> | |||
#: [[ファイル:Arduino UNO R4 ESP32 Data Pins.png|フレームなし|中央]] | |||
# Arduino UNO R4 WiFiと不要なUSBデバイスをPCから外す。 | |||
# Arduino UNO R4 WiFi上で、USB type Cコネクタの隣にある6ピンヘッダのGNDピンとDownloadピンを探す。 | |||
#: <br> | |||
# GNDピンとDownloadピンを短絡させる。<br>これは、2つのピンの間にメス-メス ジャンパワイヤを使用して接続することを推奨する。 | |||
# メス-メス ジャンパワイヤが持っていない場合は、先の尖った導電性の物体 (オス-オス ジャンパワイヤの一端等) を使用して、両方のピンに接触するように配置することもできる。 | |||
# 短絡させた状態で、Arduino UNO R4 WiFiをPCに接続する。 | |||
# 新しいデバイスが接続されたというメッセージが表示される場合は、接続を許可する。 | |||
<br> | <br> | ||
次に、[https://github.com/arduino/uno-r4-wifi-usb-bridge/releases espflashツールのGithub]にアクセスして、espflashツールをダウンロードする。<br> | |||
ダウンロードしたファイルを解凍する。<br> | |||
unzip unor4wifi-update-linux.zip | |||
cd unor4wifi-update-linux | |||
<br> | <br> | ||
espflashツールを実行してファームウェアを復元する。<br> | |||
./bin/espflash write-bin -b 115200 0x0 firmware/UNOR4-WIFI-S3-*.bin | |||
<br> | |||
復元前において、以下に示すようなプロンプトが表示される。<br> | |||
この時、キーボードの[N]キーを押下する。<br> | |||
? Remember this serial port for future use? (y/n) > | |||
訳: 今後の使用のために、このシリアルポートを記憶しておきますか? (y/n) | |||
<br> | |||
ファームウェアの復元に成功した後、Arudino UNO R4 WiFiをPCから外す。<br> | |||
次に、GNDピンとDownloadピンのジャンパワイヤ (短絡用) を外す。<br> | |||
<br> | |||
Arudino UNO R4 WiFiをPCに再度接続する。<br> | |||
Arduino IDE等から[ボード情報の取得]を選択して、"Arudino UNO R4 WiFi"と表示されているかどうかを確認する。<br> | |||
<br> | |||
<u>※注意</u><br> | |||
<u>Linux上でespflashツールを実行する時、以下に示すようなエラーが出力される場合がある。</u><br> | |||
<u>これは、システムにインストールされているGLIBCのバージョンが古いためである。</u><br> | |||
./bin/espflash: /lib64/libc.so.6: version `GLIBC_2.33' not found (required by ./bin/espflash) | |||
./bin/espflash: /lib64/libc.so.6: version `GLIBC_2.32' not found (required by ./bin/espflash) | |||
./bin/espflash: /lib64/libc.so.6: version `GLIBC_2.34' not found (required by ./bin/espflash) | |||
<br> | |||
この時、[[インストール - GLIBC]]のページを参照して、エラーで出力されているバージョン以降のGLIBCを別途インストールする。<br> | |||
インストールしたGLIBCをラッピングして、espflashツールを実行する。<br> | |||
# 別途インストールしたGLIBCをラッピングして、espflashツールを実行する場合 | |||
export GLIBC_DIR="<GLIBCのインストールディレクトリ>" | |||
$GLIBC_DIR/lib/ld-linux-x86-64.so.2 \ | |||
--library-path $GLIBC_DIR/lib64:$GLIBC_DIR/lib:/usr/lib64:/usr/lib:/lib64:/lib \ | |||
./bin/espflash write-bin -b 115200 0x0 firmware/UNOR4-WIFI-S3-*.bin | |||
<br><br> | <br><br> | ||
== | == Fritzingデザインソフトウェア == | ||
Arduinoプロジェクトで使用するための推奨されるソフトウェアである。<br> | |||
<br> | |||
https:// | Fritzingは、インタラクティブな電子機器をクリエイティブに操作できるようにするためのオープンソースライブラリである。<br> | ||
Fritzingは、Arduinoプロジェクトの文書化、電子回路の詳細の学習、他の人との作業の共有、製造設計に役立つ。<br> | |||
<br> | |||
==== パッケージ管理システムからインストール ==== | |||
SUSEでは、メインリポジトリを利用してFritzingをインストールすることができる。<br> | |||
sudo zypper install fritzing | |||
<br> | |||
==== AppImageをダウンロード ==== | |||
GLIBC 2.31以降であれば、どのLinuxディストリビューションでも動作するようにAppImageとして配布されている。<br> | |||
ただし、AppImageをサポートするためにlibfuse2ライブラリをインストールする必要がある。<br> | |||
<br> | |||
[https://fritzing.org/download/ Fritzingの公式Webサイト]にアクセスして、AppImageファイルをダウンロードする。<br> | |||
価格は、8ユーロまたは25ユーロから任意の金額から選択する。<br> | |||
<br> | |||
ダウンロードしたFritzingに実行権限を付加する。<br> | |||
chmod u+x fritzing-<バージョン>-qt6.AppImage | |||
<br> | |||
==== ソースコードからインストール ==== | |||
一般的に、Fritzingは有料であるが、ソースコードからインストールすることにより無料で使用することができる。<br> | |||
<br> | |||
まず、Fritzingのビルドに必要なライブラリをインストールする。<br> | |||
なお、最新のFritzingはQt 6に対応している。<br> | |||
# RHEL | |||
sudo dnf install make gcc gcc-c++ xz-devel \ | |||
qt6-base-devel qt6-core-devel qt6-qt5compat-devel qt6-concurrent-devel qt6-xml-devel \ | |||
qt6-network-devel qt6-sql-devel qt6-serialport-devel qt6-printsupport-devel \ | |||
qt6-gui-devel qt6-widgets-devel qt6-svg-devel qt6-openglwidgets-devel | |||
# SUSE | |||
sudo zypperi install make gcc gcc-c++ xz-devel \ | |||
qt6-base-devel qt6-core-devel qt6-qt5compat-devel qt6-concurrent-devel qt6-xml-devel \ | |||
qt6-network-devel qt6-sql-devel qt6-serialport-devel qt6-printsupport-devel \ | |||
qt6-gui-devel qt6-widgets-devel qt6-svg-devel qt6-openglwidgets-devel | |||
<br> | |||
以前のFritzingをインストールする場合は、Qt 5ライブラリが必要となる。<br> | |||
# RHEL | |||
sudo dnf install make gcc gcc-c++ xz-devel \ | |||
qt6-base-devel qt6-core-devel qt6-qt5compat-devel qt6-concurrent-devel qt6-xml-devel \ | |||
qt6-network-devel qt6-sql-devel qt6-serialport-devel qt6-printsupport-devel \ | |||
qt6-gui-devel qt6-widgets-devel qt6-svg-devel qt6-openglwidgets-devel | |||
# SUSE | |||
sudo zypper install libqt5-qtbase-devel libQt5Core-devel libQt5Concurrent-devel libQt5Xml-devel \ | |||
libQt5Network-devel libqt5-qtserialport-devel libQt5PrintSupport-devel libQt5Sql-devel \ | |||
libQt5Gui-devel libQt5Widgets-devel libqt5-qtsvg-devel | |||
<br> | |||
[https://github.com/fritzing/fritzing-app FritzingのGithub]から<code>git clone</code>コマンドを実行して、ソースコードをダウンロードする。<br> | |||
git clone https://github.com/fritzing/fritzing-app.git | |||
cd fritzing-app | |||
<br> | <br> | ||
Fritzingをビルドおよびインストールする。<br> | |||
mkdir build && cd build | |||
# | qmake PREFIX=<Fritzingのインストールディレクトリ> \ | ||
../phoenix.pro | |||
<br> | |||
<u>※注意</u><br> | |||
<u><code>qmake</code>コマンドは、Linuxディストリビューションによってはコマンド名が異なる場合がある。</u><br> | |||
<br><br> | |||
== AVR GCCツールチェーンの使用 == | |||
==== 公式のリポジトリからインストール ==== | |||
まず、以下のリポジトリを追加する。<br> | |||
# SUSE | |||
sudo zypper ar -cfp 90 'https://download.opensuse.org/repositories/CrossToolchain:/avr/$releasever/' AVR-GCC | |||
<br> | |||
インストールするライブラリは、以下の4つである。<br> | |||
* avrdude | |||
* avr-libc | |||
* cross-avr-binutils | |||
* cross-avr-gcc | |||
<br> | |||
もし、Arduino IDEがAVR-GCCを見つけることができない場合、/usr/local/binディレクトリ等にシンボリックリンクを作成する。<br> | |||
例えば、AVR-GCCが/optディレクトリにインストールされている場合、以下のコマンドを実行する。<br> | |||
sudo find /opt/cross/bin/ -iname "avr*" -exec ln -s -t /usr/local/bin/ {} \; | |||
<br> | |||
==== サードパーティ製のインストール ==== | |||
<u>※注意 1</u><br> | |||
<u>これは、Windows x86, x64およびLinux x64向けのAVR GCCツールチェーンである。</u><br> | |||
<u>Binutils、AVR LibC、AVRDUDE、Make、GDBも含まれている。</u><br> | |||
<br> | |||
<u>※注意 2</u><br> | |||
<u>サードパーティ製のGCCツールチェーンはArduino IDE 1.8.13で動作確認しているため、Arduino IDE 2で使用できるかどうかは不明である。</u><br> | |||
<br> | |||
Arduino IDEにおいて、Arduino付属のコンパイラが古いため、AVRの一部のライブラリとの互換性が無い場合がある。<br> | |||
そのため、サードパーティ製の最新版に近いAVR GCCツールチェーンを使用することができる。<br> | |||
<br> | |||
まず、Arduino IDEの標準コンパイラをバックアップする。<br> | |||
cp -r /<Arduinoのインストールディレクトリ>/hardware/tools/avr /<Arduinoのインストールディレクトリ>/hardware/tools/avr_org | |||
<br> | |||
次に、AVR GCCツールチェーンをダウンロードする。<br> | |||
* Webサイト | |||
*: https://blog.zakkemble.net/avr-gcc-builds | |||
* Github | |||
*: https://github.com/ZakKemble/avr-gcc-build | |||
<br> | |||
ダウンロードしたAVR GCCツールチェーンを解凍する。<br> | |||
tar xf avr-gcc-<バージョン名>-x64-linux.tar.bz2 | |||
<br> | |||
解凍したAVR GCCツールチェーンのファイルおよびディレクトリを、/<Arduino IDEのインストールディレクトリ>/hardware/toolsディレクトリに上書きする。<br> | |||
mv -f avr-gcc-<バージョン名>-x64-linux/* /<Arduinoのインストールディレクトリ>/Arduino/arduino-1.8.13/hardware/tools/avr | |||
<br> | |||
Arduino IDEを起動する時、サードパーティ製AVR GCCツールチェーンが自動的に検出される。<br> | |||
<br> | <br> | ||
AVR GCCツールチェーンが正常に動作するかどうかを確認するため、例えば、Blinkサンプル等をコンパイルしてArduinoにダウンロードする。<br> | |||
<br><br> | |||
== VSCodeでの開発 == | |||
VSCodeでは、コード補完機能も使用できることから、開発が効率化することができる。<br> | |||
このセクションでは、Arduinoの開発をVSCodeで行うための設定に関する手順を記載する。<br> | |||
<br> | |||
==== 前提条件 ==== | |||
前提条件として、以下の導入が完了しているものとする。 | |||
* VSCode | |||
* VSCodeの拡張機能(Arduino for Visual Studio Code、arduino-snippets、C/C++ for Visual Studio Code) | |||
* Arduino IDE | |||
<br> | |||
==== VSCodeの設定 ==== | |||
VSCodeを起動して、[ファイル]メニュー - [ユーザー設定] - [設定]を選択して、設定画面を開く。<br> | |||
設定画面右の[ユーザー]タブ - [拡張機能] - [ArduinoConfiguration]を選択する。<br> | |||
<br> | |||
以下に、設定項目と編集内容を記載する。<br> | |||
* arduino.path | |||
*: Arduino IDEの実行ファイルがあるディレクトリを入力する。 | |||
*: Windowsの場合 : C:\Program Files (x86)\Arduino | |||
*: Linuxの場合 : <Arduino IDEのインストールディレクトリ> | |||
*: <br> | |||
* arduino.commandPath | |||
*: Arduino IDEのインストールディレクトリにある実行ファイル名を入力する。 | |||
*: Windowsの場合 : arduino_debug.exe | |||
*: Linuxの場合 : arduino | |||
*: <br> | |||
* arduino.defaultBaudRate | |||
*: シリアルモニタのボーレートのデフォルト値を設定する。 | |||
*: ボーレートの値は、9600を推奨する。 | |||
*: <br> | |||
* C_Cpp.intelliSenseEngine | |||
*: コード補完機能の設定である。この設定項目では、<code>Tag Parser</code>を選択する。 | |||
*: <br> | |||
* C_Cpp.default.includePath | |||
*: インクルードする時に読み込むライブラリの場所を入力する。 | |||
*: [setting.jsonで編集]を選択する。 | |||
*: 以下に設定例を示す。 | |||
*: <br> | |||
*: Windowsの場合 | |||
*: <code>"C_Cpp.default.includePath": [</code> | |||
*: <code> "C:\\Users\\<ユーザ名>\\Documents\\Arduino\\libraries",</code> | |||
*: <code> "C:\\Program Files (x86)\\Arduino\\tools",</code> | |||
*: <code> "C:\\Program Files (x86)\\Arduino\\libraries",</code> | |||
*: <code> "C:\\Program Files (x86)\\Arduino\\hardware"]</code> | |||
*: <br> | |||
*: Linuxの場合 | |||
*: <code>"C_Cpp.default.includePath": [</code> | |||
*: <code> "/home/<ユーザ名>/Arduino/libraries",</code> | |||
*: <code> "/home/<ユーザ名>/InstallSoftware/Arduino/arduino-<バージョン名>/libraries",</code> | |||
*: <code> "/home/<ユーザ名>/InstallSoftware/Arduino/arduino-<バージョン名>/tools",</code> | |||
*: <code> "/home/<ユーザ名>/InstallSoftware/Arduino/arduino-<バージョン名>/hardware"]</code> | |||
<br> | |||
以下に、setting.jsonの設定例を示す。<br> | |||
{ | |||
// ...略 | |||
// Arduino | |||
"arduino.defaultBaudRate": 9600, // ボーレートの設定 | |||
"arduino.path": "/home/<ユーザ名>/InstallSoftware/Arduino/arduino-<Arduino IDEのバージョン>", | |||
"arduino.commandPath": "arduino", | |||
"arduino.logLevel": "info", | |||
"arduino.enableUSBDetection": true, | |||
"arduino.disableTestingOpen": false, | |||
"arduino.skipHeaderProvider": false, | |||
"arduino.disableIntelliSenseAutoGen": true, // VSCode起動時のIntelliSenseの自動生成を無効にする | |||
// C++ | |||
"C_Cpp.intelliSenseEngine": "Tag Parser", | |||
"C_Cpp.default.includePath": [ | |||
"/home/<ユーザ名>/Arduino/libraries", | |||
"/home/<ユーザ名>/InstallSoftware/Arduino/arduino-1.8.13/libraries", | |||
"/home/<ユーザ名>/InstallSoftware/Arduino/arduino-1.8.13/tools", | |||
"/home/<ユーザ名>/InstallSoftware/Arduino/arduino-1.8.13/hardware"] | |||
} | |||
<br> | <br> | ||
コンパイルまたはファームウェアのダウンロードにおいて、出力されるメッセージが文字化けする場合、<br> | |||
以下のファイルを編集して、215〜225行目までのソースコードをコメントアウトする。<br> | |||
* Windows | |||
*: C:\Users\%USERNAME%\.vscode\extensions\vsciot-vscode.vscode-arduino-<バージョン名>\out\src\common\util.js | |||
* Linux | |||
*: ~/.vscode/extensions/vsciot-vscode.vscode-arduino-<バージョン名>/out/src/common/utils.js | |||
<br><br> | <br><br> | ||
__FORCETOC__ | __FORCETOC__ | ||
[[カテゴリ: | [[カテゴリ:RHEL]][[カテゴリ:SUSE]][[カテゴリ:Windows10]][[カテゴリ:Arduino]] |
2024年12月23日 (月) 03:27時点における最新版
概要
Arduino IDEとは、Arduino向けのスケッチ(プログラム)を作成する統合開発環境である。
Arduino IDEを用いることで、スケッチを作成して、USBケーブルを通じてArduinoボードにアップロードするための環境が整う。
参考書 | |||
---|---|---|---|
Prototyping Lab 第2版 「作りながら考える」ためのArduino実践レシピ |
Arduinoをはじめよう 第4版 |
Handbook of Arduino 100以上の実践的なガイド | |
Exploring Arduino 技術者のためのツールとテクニック |
ELEGOO Arduino UNO R3 最終版スタータキット UNOチュートリアル付 |
Arduino IDEのインストール
Windows
Arduino IDEをダウンロードしてインストールを開始する。
基本的には、[Next]ボタンを押下し続けることでインストールは完了する。
インストールの途中で、Arduino USB Driver、libusb-win32、Genuino USB Driver等のデバイスドライバがインストールされる。
セキュリティメッセージが表示される場合は、[インストール]ボタンを押下する。
RHEL / SUSE
Arduino IDEは、以下の3つのインストール方法がある。
ここでは、リポジトリに追加してインストールする方法およびインストールせずに使用する方法を記載する。
- ワンクリックインストール(SUSEのみ)
- リポジトリに追加してインストールする方法
- インストールせずに使用する方法
リポジトリを追加してインストール
Arduino IDE 2を使用する場合、依存関係のライブラリをインストールする。
# RHEL sudo dnf install fuse # SUSE sudo zypper install fuse
まず、Arduino IDEのリポジトリを追加する。
# SUSE sudo zypper --gpg-auto-import-keys ar -f 'https://download.opensuse.org/repositories/CrossToolchain:/avr/$releasever/' 'CrossToolchain:avr' sudo zypper refresh
次に、Ardduino IDEをインストールする。
sudo zypper install arduino
手動でインストール
Arduino IDE 2を使用する場合、依存関係のライブラリをインストールする。
# RHEL sudo dnf install fuse # SUSE sudo zypper install fuse
Arduinoの公式サイトから、Arduino IDE 2をダウンロードする。
ダウンロードしたファイルを解凍する。
unzip arduino-ide_<バージョン>_Linux_64bit.zip mv arduino-ide_<バージョン>_Linux_64bit Arduino_IDE
必要ならば、Arduino IDE 2を任意のディレクトリに配置する。
mv Arduino_IDE <任意のインストールディレクトリ>
Arduino IDE 2のデスクトップエントリファイルを作成する。
vi ~/.local/share/applications/org.Arduino-IDE.desktop
# ~/.local/share/applications/org.Arduino-IDE.desktopファイル
[Desktop Entry]
Type=Application
Name=Arduino IDE <Arduinoのバージョン>
GenericName=Arduino IDE
Comment=Open-source electronics prototyping platform
Exec=/<Arduino IDEのインストールディレクトリ>/arduino
Icon=/<Arduino IDE 2のインストールディレクトリ>/resources/app/resources/icons/512x512.png
Categories=Development;IDE;Electronics;
Keywords=embedded electronics;electronics;avr;microcontroller;
MimeType=text/x-arduino;
StartupWMClass=processing-app-Base
Terminal=false
Arduino IDEの設定
フォントの設定
Arduino IDE 1.8系, 2系において、標準フォントの表示が粗いため、別のフォントを使用することを推奨する。
フォントの設定を行うため、preferences.txtファイルを以下のように編集する。
- Windows
- C:\Users\<ユーザ名>\AppData\Local\Arduino<バージョン>\preferences.txt
- RHEL / SUSE
- ~/.arduino<バージョン>/preferences.txt
# C:\Users\<ユーザ名>\AppData\Local\Arduino<バージョン>\preferences.txtファイル # または # ~/.arduino<バージョン>/preferences.txtファイル editor.font=Noto Sans,plain,14
Arduino IDE 1.8系の設定
スケッチをアップロードする時、ボードとシリアルポートを選択した後に、以下に示すようなエラーが出力される場合がある。
Error opening serial port ...
これを解決するため、シリアルポートのパーミッションを設定する。
まず、PCとArduinoを接続した後、/dev/ttyACMXの所属グループ名を確認する。 (X : 数値)
ls -l '/dev/ttyACM*' # 出力例 crw-rw---- 1 root dialout 188, 0 5 apr 23.01 ttyACM0
Arduino IDE 1.8系を使用するユーザをdialoutグループをメンバーにする必要がある。また、必要ならば、lockグループ、uucpグループもメンバーにする。
ただし、ほとんどの環境では、dialoutグループにユーザを追加するだけでよい。
もし、YaSTで行う場合は、[セキュリティとユーザ]セクション - [ユーザとグループの管理]を選択して、必要な変更を行う。
また、ターミナルから実行するには、以下のコマンドを実行する。
sudo usermod -aG dialout $USER # または sudo usermod -aG tty dialout lock uucp $USER
もし、上記のグループからユーザを削除する場合は、以下のコマンドを実行する。
sudo gpasswd -d $USER tty dialout lock uucp
設定を反映させるため、PCを再ログイン、または、再起動する。
スケッチをボードにアップロード、および、シリアルモニターが使用できるかどうかを確認する。
Arduino IDE 2系の設定
Arduino IDE 2がシリアルポートにアクセスしてソースコードをボードにアップロードできるようにするには、/etc/udev/rules.d/99-arduino.rulesファイルを作成して、ルールを追加する。
sudo vi /etc/udev/rules.d/99-arduino.rules
# /etc/udev/rules.d/99-arduino.rulesファイル SUBSYSTEMS=="usb", ATTRS{idVendor}=="2341", GROUP="plugdev", MODE="0666"
Udevを再起動、または、PCを再起動する。
※注意
Udevを再起動する場合 (特に、変更が特定のデバイスに関連している場合) は、そのデバイスを再接続する、または、
sudo udevadm trigger
コマンドを実行して対話的にデバイスのイベントをトリガーする必要がある。
# Udevを再起動 sudo udevadm control --reload-rules または sudo udevadm trigger --action=change または sudo udevadm trigger # PCを再起動 sudo systemctl reboot
CH34xドライバを使用する場合
CH34xドライバのパッチのインストール
Arduinoのクローンにおいて、Linux標準のCH34xドライバを使用する場合、シリアル通信に失敗するケースがいくつか報告されている。
もし、問題が発生する場合、CH34xのパッチを当てたドライバをインストールすることができる。
- CH34xを使用したデバイスを、USBポートから外す。
- 問題が発生したログを確認する。
sudo dmesg | grep - iE ch34
出力例:
[ xxx] ch34x ttyUSB0: ch34x converter now disconnected from ttyUSB0
[ xxx] ch34x 3-2:1.0: device disconnected
- パッチ適用済みのCH34xのビルドに必要なライブラリをインストールする。
sudo zypper install kernel-source
- パッチ適用済みのCH34xのGithubにアクセスして、ドライバのソースコードをダウンロードする。
- パッチ適用済みのCH34xをビルドおよびインストールする。
sudo make clean
sudo make -j $(nproc)
sudo make load
- 古いドライバをアンインストールする。
sudo rmmod ch341
- 現在インストールされているモジュールの一覧を表示する。
lsmod | grep ch34
- CH34xを使用したデバイスを、USBポートに接続する。
- 接続に関するログを確認する。
sudo dmesg | grep - iE ch34
出力例:
[ xxx] ch341-uart ttyUSB0: ch341-uart converter now disconnected from ttyUSB0
[ xxx] ch341 3-2:1.0: device disconnected
場合によっては、シリアルポートのパーミッションを設定する必要がある。
PCの環境において、CH34xがどのように列挙されたかにより、デバイスファイル(/dev/ttyUSB0)が異なる場合があるため、
シリアルポートの設定に問題がある場合は、必要に応じてポートを調整すること。
sudo usermod -a -G dialout $USER sudo chmod a+rw /dev/ttyUSB0
ライブラリのディレクトリ
Winodws
Arduino IDEからインストールしたライブラリは、C:\Users\[ユーザー名]\Documents\Arduino\librariesフォルダに保存される。
また、システムにプリインストールされているライブラリは、C:\Program Files\Arduino IDE\resources\libraryフォルダに保存される。
なお、ライブラリの場所を確認する場合は、Arduino IDEのメイン画面から、[ファイル] - [環境設定]から、[スケッチブックの保存場所]ボタンを押下して確認できる。
デフォルトでは、ドキュメント\Arduinoに設定されている。
Linux
Arduino IDEからインストールしたライブラリは、~/Arduino/librariesディレクトリに保存される。
なお、Arduino IDE 2では、2種類のライブラリの保存場所がある。
- ユーザがインストールしたライブラリ
- ~/Arduino/libraries
- システムにプリインストールされているライブラリ
- ~/.arduino15/libraries
- /usr/share/arduino/libraries
なお、ライブラリの場所を確認する場合は、Arduino IDEのメイン画面から、[ファイル] - [環境設定]から、[スケッチブックの保存場所]ボタンを押下して確認できる。
エラー関連
書き込みできない場合
プログラムの書き込み時において、以下に示すようなエラーが出力される場合がある。
Cannot perform port reset: 1200-bps touch: setting DTR to OFF: broken pipe
このエラーは、Arduinoのブートローダーとの通信に問題が発生している典型的なケースである。
- 解決方法 1 : デバイスファイルのパーミッション変更する
- (デバイスファイル名が異なる場合は適宜変更すること)
sudo chmod a+rw /dev/ttyACM0
- 解決方法 2 : 実行するユーザをdialoutグループに追加する
sudo usermod -a -G dialout $USER
- この後、再ログインする必要がある。
- 解決方法 2 : Arduinoを再起動する
- ArduinoのUSBケーブルを抜き差しする、または、別のUSBポートに接続する。
- Arduinoのリセットボタンを押下した後に書き込みを実行する。
- 解決方法 4 : Arduinoが認識されているかどうかを確認する
- デバイスの認識を確認する。
ls -l /dev/ttyACM*
またはsudo dmesg | grep tty
- 解決方法 5 : udevルールの確認と追加
- udevルールを追加するため、以下に示す内容を追記する。
sudo nano /etc/udev/rules.d/99-arduino.rules
SUBSYSTEM=="tty", ATTRS{idVendor}=="2341", ATTRS{idProduct}=="0043", MODE="0666" SUBSYSTEM=="tty", ATTRS{idVendor}=="2341", ATTRS{idProduct}=="0001", MODE="0666"
- 設定を反映させるため、udevを再起動する。
sudo udevadm control --reload-rules
特に、解決方法1〜2の方法で解決することが多い。
ファームウェアの復元
Arudino UNO R4 WiFi
Arduino UNO R4 WiFiにはUSB-シリアル通信を処理するESP32-S3チップが搭載されている。
このチップのファームウェアは、Arduino IDEまたはArduino Cloudを使用してアップグレードできるが、アップグレード後のファームウェアが正常に動作しない場合がある。
この時、espflashツールを使用してファームウェアを復元することができる。
これは、以下に示すような症状が起きている場合に有効である。
- Arudino UNO R4 WiFiが、Arduino IDEまたはArduino Cloudの[ボード情報の取得]を選択すると、汎用のESP32ボード (例: ESP32-S3-Box) として検出される。
- Arudino UNO R4 WiFiが、Arduino IDEまたはArduino Cloudの[ボード情報の取得]を選択すると、データUSBケーブルでコンピュータに接続されているにもかかわらず、どのボードとしても検出されない。
- まず、下図のように、Arduino UNO R4 WiFiにある6ピンヘッダのGNDピンとDownloadピンを短絡 (ショート) させる必要がある。
- Arduino UNO R4 WiFiと不要なUSBデバイスをPCから外す。
- Arduino UNO R4 WiFi上で、USB type Cコネクタの隣にある6ピンヘッダのGNDピンとDownloadピンを探す。
- GNDピンとDownloadピンを短絡させる。
これは、2つのピンの間にメス-メス ジャンパワイヤを使用して接続することを推奨する。 - メス-メス ジャンパワイヤが持っていない場合は、先の尖った導電性の物体 (オス-オス ジャンパワイヤの一端等) を使用して、両方のピンに接触するように配置することもできる。
- 短絡させた状態で、Arduino UNO R4 WiFiをPCに接続する。
- 新しいデバイスが接続されたというメッセージが表示される場合は、接続を許可する。
次に、espflashツールのGithubにアクセスして、espflashツールをダウンロードする。
ダウンロードしたファイルを解凍する。
unzip unor4wifi-update-linux.zip cd unor4wifi-update-linux
espflashツールを実行してファームウェアを復元する。
./bin/espflash write-bin -b 115200 0x0 firmware/UNOR4-WIFI-S3-*.bin
復元前において、以下に示すようなプロンプトが表示される。
この時、キーボードの[N]キーを押下する。
? Remember this serial port for future use? (y/n) > 訳: 今後の使用のために、このシリアルポートを記憶しておきますか? (y/n)
ファームウェアの復元に成功した後、Arudino UNO R4 WiFiをPCから外す。
次に、GNDピンとDownloadピンのジャンパワイヤ (短絡用) を外す。
Arudino UNO R4 WiFiをPCに再度接続する。
Arduino IDE等から[ボード情報の取得]を選択して、"Arudino UNO R4 WiFi"と表示されているかどうかを確認する。
※注意
Linux上でespflashツールを実行する時、以下に示すようなエラーが出力される場合がある。
これは、システムにインストールされているGLIBCのバージョンが古いためである。
./bin/espflash: /lib64/libc.so.6: version `GLIBC_2.33' not found (required by ./bin/espflash) ./bin/espflash: /lib64/libc.so.6: version `GLIBC_2.32' not found (required by ./bin/espflash) ./bin/espflash: /lib64/libc.so.6: version `GLIBC_2.34' not found (required by ./bin/espflash)
この時、インストール - GLIBCのページを参照して、エラーで出力されているバージョン以降のGLIBCを別途インストールする。
インストールしたGLIBCをラッピングして、espflashツールを実行する。
# 別途インストールしたGLIBCをラッピングして、espflashツールを実行する場合 export GLIBC_DIR="<GLIBCのインストールディレクトリ>" $GLIBC_DIR/lib/ld-linux-x86-64.so.2 \ --library-path $GLIBC_DIR/lib64:$GLIBC_DIR/lib:/usr/lib64:/usr/lib:/lib64:/lib \ ./bin/espflash write-bin -b 115200 0x0 firmware/UNOR4-WIFI-S3-*.bin
Fritzingデザインソフトウェア
Arduinoプロジェクトで使用するための推奨されるソフトウェアである。
Fritzingは、インタラクティブな電子機器をクリエイティブに操作できるようにするためのオープンソースライブラリである。
Fritzingは、Arduinoプロジェクトの文書化、電子回路の詳細の学習、他の人との作業の共有、製造設計に役立つ。
パッケージ管理システムからインストール
SUSEでは、メインリポジトリを利用してFritzingをインストールすることができる。
sudo zypper install fritzing
AppImageをダウンロード
GLIBC 2.31以降であれば、どのLinuxディストリビューションでも動作するようにAppImageとして配布されている。
ただし、AppImageをサポートするためにlibfuse2ライブラリをインストールする必要がある。
Fritzingの公式Webサイトにアクセスして、AppImageファイルをダウンロードする。
価格は、8ユーロまたは25ユーロから任意の金額から選択する。
ダウンロードしたFritzingに実行権限を付加する。
chmod u+x fritzing-<バージョン>-qt6.AppImage
ソースコードからインストール
一般的に、Fritzingは有料であるが、ソースコードからインストールすることにより無料で使用することができる。
まず、Fritzingのビルドに必要なライブラリをインストールする。
なお、最新のFritzingはQt 6に対応している。
# RHEL sudo dnf install make gcc gcc-c++ xz-devel \ qt6-base-devel qt6-core-devel qt6-qt5compat-devel qt6-concurrent-devel qt6-xml-devel \ qt6-network-devel qt6-sql-devel qt6-serialport-devel qt6-printsupport-devel \ qt6-gui-devel qt6-widgets-devel qt6-svg-devel qt6-openglwidgets-devel # SUSE sudo zypperi install make gcc gcc-c++ xz-devel \ qt6-base-devel qt6-core-devel qt6-qt5compat-devel qt6-concurrent-devel qt6-xml-devel \ qt6-network-devel qt6-sql-devel qt6-serialport-devel qt6-printsupport-devel \ qt6-gui-devel qt6-widgets-devel qt6-svg-devel qt6-openglwidgets-devel
以前のFritzingをインストールする場合は、Qt 5ライブラリが必要となる。
# RHEL sudo dnf install make gcc gcc-c++ xz-devel \ qt6-base-devel qt6-core-devel qt6-qt5compat-devel qt6-concurrent-devel qt6-xml-devel \ qt6-network-devel qt6-sql-devel qt6-serialport-devel qt6-printsupport-devel \ qt6-gui-devel qt6-widgets-devel qt6-svg-devel qt6-openglwidgets-devel # SUSE sudo zypper install libqt5-qtbase-devel libQt5Core-devel libQt5Concurrent-devel libQt5Xml-devel \ libQt5Network-devel libqt5-qtserialport-devel libQt5PrintSupport-devel libQt5Sql-devel \ libQt5Gui-devel libQt5Widgets-devel libqt5-qtsvg-devel
FritzingのGithubからgit clone
コマンドを実行して、ソースコードをダウンロードする。
git clone https://github.com/fritzing/fritzing-app.git cd fritzing-app
Fritzingをビルドおよびインストールする。
mkdir build && cd build qmake PREFIX=<Fritzingのインストールディレクトリ> \ ../phoenix.pro
※注意
qmake
コマンドは、Linuxディストリビューションによってはコマンド名が異なる場合がある。
AVR GCCツールチェーンの使用
公式のリポジトリからインストール
まず、以下のリポジトリを追加する。
# SUSE sudo zypper ar -cfp 90 'https://download.opensuse.org/repositories/CrossToolchain:/avr/$releasever/' AVR-GCC
インストールするライブラリは、以下の4つである。
- avrdude
- avr-libc
- cross-avr-binutils
- cross-avr-gcc
もし、Arduino IDEがAVR-GCCを見つけることができない場合、/usr/local/binディレクトリ等にシンボリックリンクを作成する。
例えば、AVR-GCCが/optディレクトリにインストールされている場合、以下のコマンドを実行する。
sudo find /opt/cross/bin/ -iname "avr*" -exec ln -s -t /usr/local/bin/ {} \;
サードパーティ製のインストール
※注意 1
これは、Windows x86, x64およびLinux x64向けのAVR GCCツールチェーンである。
Binutils、AVR LibC、AVRDUDE、Make、GDBも含まれている。
※注意 2
サードパーティ製のGCCツールチェーンはArduino IDE 1.8.13で動作確認しているため、Arduino IDE 2で使用できるかどうかは不明である。
Arduino IDEにおいて、Arduino付属のコンパイラが古いため、AVRの一部のライブラリとの互換性が無い場合がある。
そのため、サードパーティ製の最新版に近いAVR GCCツールチェーンを使用することができる。
まず、Arduino IDEの標準コンパイラをバックアップする。
cp -r /<Arduinoのインストールディレクトリ>/hardware/tools/avr /<Arduinoのインストールディレクトリ>/hardware/tools/avr_org
次に、AVR GCCツールチェーンをダウンロードする。
ダウンロードしたAVR GCCツールチェーンを解凍する。
tar xf avr-gcc-<バージョン名>-x64-linux.tar.bz2
解凍したAVR GCCツールチェーンのファイルおよびディレクトリを、/<Arduino IDEのインストールディレクトリ>/hardware/toolsディレクトリに上書きする。
mv -f avr-gcc-<バージョン名>-x64-linux/* /<Arduinoのインストールディレクトリ>/Arduino/arduino-1.8.13/hardware/tools/avr
Arduino IDEを起動する時、サードパーティ製AVR GCCツールチェーンが自動的に検出される。
AVR GCCツールチェーンが正常に動作するかどうかを確認するため、例えば、Blinkサンプル等をコンパイルしてArduinoにダウンロードする。
VSCodeでの開発
VSCodeでは、コード補完機能も使用できることから、開発が効率化することができる。
このセクションでは、Arduinoの開発をVSCodeで行うための設定に関する手順を記載する。
前提条件
前提条件として、以下の導入が完了しているものとする。
- VSCode
- VSCodeの拡張機能(Arduino for Visual Studio Code、arduino-snippets、C/C++ for Visual Studio Code)
- Arduino IDE
VSCodeの設定
VSCodeを起動して、[ファイル]メニュー - [ユーザー設定] - [設定]を選択して、設定画面を開く。
設定画面右の[ユーザー]タブ - [拡張機能] - [ArduinoConfiguration]を選択する。
以下に、設定項目と編集内容を記載する。
- arduino.path
- Arduino IDEの実行ファイルがあるディレクトリを入力する。
- Windowsの場合 : C:\Program Files (x86)\Arduino
- Linuxの場合 : <Arduino IDEのインストールディレクトリ>
- arduino.commandPath
- Arduino IDEのインストールディレクトリにある実行ファイル名を入力する。
- Windowsの場合 : arduino_debug.exe
- Linuxの場合 : arduino
- arduino.defaultBaudRate
- シリアルモニタのボーレートのデフォルト値を設定する。
- ボーレートの値は、9600を推奨する。
- C_Cpp.intelliSenseEngine
- コード補完機能の設定である。この設定項目では、
Tag Parser
を選択する。
- コード補完機能の設定である。この設定項目では、
- C_Cpp.default.includePath
- インクルードする時に読み込むライブラリの場所を入力する。
- [setting.jsonで編集]を選択する。
- 以下に設定例を示す。
- Windowsの場合
"C_Cpp.default.includePath": [
"C:\\Users\\<ユーザ名>\\Documents\\Arduino\\libraries",
"C:\\Program Files (x86)\\Arduino\\tools",
"C:\\Program Files (x86)\\Arduino\\libraries",
"C:\\Program Files (x86)\\Arduino\\hardware"]
- Linuxの場合
"C_Cpp.default.includePath": [
"/home/<ユーザ名>/Arduino/libraries",
"/home/<ユーザ名>/InstallSoftware/Arduino/arduino-<バージョン名>/libraries",
"/home/<ユーザ名>/InstallSoftware/Arduino/arduino-<バージョン名>/tools",
"/home/<ユーザ名>/InstallSoftware/Arduino/arduino-<バージョン名>/hardware"]
以下に、setting.jsonの設定例を示す。
{ // ...略 // Arduino "arduino.defaultBaudRate": 9600, // ボーレートの設定 "arduino.path": "/home/<ユーザ名>/InstallSoftware/Arduino/arduino-<Arduino IDEのバージョン>", "arduino.commandPath": "arduino", "arduino.logLevel": "info", "arduino.enableUSBDetection": true, "arduino.disableTestingOpen": false, "arduino.skipHeaderProvider": false, "arduino.disableIntelliSenseAutoGen": true, // VSCode起動時のIntelliSenseの自動生成を無効にする // C++ "C_Cpp.intelliSenseEngine": "Tag Parser", "C_Cpp.default.includePath": [ "/home/<ユーザ名>/Arduino/libraries", "/home/<ユーザ名>/InstallSoftware/Arduino/arduino-1.8.13/libraries", "/home/<ユーザ名>/InstallSoftware/Arduino/arduino-1.8.13/tools", "/home/<ユーザ名>/InstallSoftware/Arduino/arduino-1.8.13/hardware"] }
コンパイルまたはファームウェアのダウンロードにおいて、出力されるメッセージが文字化けする場合、
以下のファイルを編集して、215〜225行目までのソースコードをコメントアウトする。
- Windows
- C:\Users\%USERNAME%\.vscode\extensions\vsciot-vscode.vscode-arduino-<バージョン名>\out\src\common\util.js
- Linux
- ~/.vscode/extensions/vsciot-vscode.vscode-arduino-<バージョン名>/out/src/common/utils.js