[[Arduino勉強会]]

#contents

2021/05/01からのアクセス回数 &counter;

** Arduino UNOのスケッチのソース・デバッグ [#wd6c9552]
Arduino UNOを使い始めて10年あまりが立ちますが、ずっと不思議に思ってことにArduinoのスケッチをソースレベルでデバッグする方法を紹介した記事がないことです。

Arduinoに使われているATmega328P単体ならATMEL Studio(現 Microchip Studio)を使ってC言語のソースデバッグの記事は見かけられますが、
Arduinoとなるとほとんどヒットしません。
また、AVR Studioでソースレベルのデバッグをするには、AVR Dragon(7,350円)やAtmel-ICE(11,000円)と高価なツールが必要でした。

&ref(AVR-DRAGON.png,,70%);


** 安価なデバッグツールMPLAB Snapの登場 [#ee5d1ea2]
トランジスタ技術2021年4月号では、基板レベルではありますが安価なMPLAB Snap(2,850円)を使ったデバッグ方法が紹介されました。

&ref(MPLAB-Snap.png,,50%);


*** MPLAB Snapの改造 [#k310afc9]
Microchip StudioでMPLAB Snapを使用するには、少しの準備(改造)が必要です。
- プルダウン抵抗R48の取り外し
- Firmwareの更新

技術2021年4月号の写真2(43p)は、少し古いモデルみたいで、私が秋月から購入したものはR48の位置が少し異なっていました。
隙間が狭くピンセットが入らなかったので、チップ抵抗にコテを当てた後ドライバーでずらして、取り外しました。

&ref(R48-Remove.png,,50%);


MPLAB SnapのFirmwareの更新には、Windows版のMPLABX IDEが必要です(Mac版では更新できませんでした)。

MPLABX IDEは以下のサイトからMPLABX-v5.45-windows-installer.exeをダウンロードしました。
- https://www.microchip.com/en-us/development-tools-tools-and-software/mplab-x-ide

MPBLAX IDEでATmega328Pのプロジェクトを作成し、MPLAB Snapを接続すると更新できました(すみません画像を取りそこねました)。

更新前のバージョンは
#pre{{
```
Connecting to MPLAB Snap...

Currently loaded versions:
Application version............00.00.17
Boot version...................01.00.00
Script version.................00.04.07
Script build number............59586f4647
Tool pack version .............1.3.305
```
}}

アップグレード後のバージョンは以下のように出力されました。
#pre{{
```
Connecting to MPLAB Snap...

Currently loaded versions:
Application version............00.04.18
Boot version...................01.00.00
Script version.................00.04.07
Script build number............59586f4647
Tool pack version .............1.3.305
```
}}

** Arduino UNOでデバッグツールが動かない理由 [#p979e366]
Arduino UNOでデバッグツールが動かない理由が以下のサイトに説明されています。
- http://www.solutions-cubed.com/electronic-design-blog/debugging-arduino-sketches-with-atmel-studio-7/

Arduino UNOの公式サイトから回路図の一部を引用します。
- https://www.arduino.cc/en/uploads/Main/Arduino_Uno_Rev3-schematic.pdf

&ref(RESET-R-C.png,,50%);


Arduino IDEでスケッチをArduinoにアップロードした後に、Arduinoをリセットする必要があります。
このリセット信号は瞬間的にLOWになるパルスが必要ですが、シリアルの通信でそのような制御はできません。
そこで、CTSをLOWにしたあとC4とRN10のCR回路でリセット信号を作っています。

Arduino IDEにとっては便利なCR回路ですが、これがデバッグツールの制御に悪影響を与え、デバッグできなかったのです。

*** シリアルのリセット信号のカット [#hc590c6b]
Arduino UNOの互換器では、CR回路がボードに直付けになっており、切り離すことができません。

しかし、秋月電子から発売されている
<a href="https://akizukidenshi.com/catalog/g/gP-04399/">ATMEGA168/328用マイコンボード(I/Oボード)通販コード:P-04399</a>
を使うとシリアルとの接続(TX, RX, RST)をジャンパーで選択することができます。

&ref(AE-ATmega.png,,50%);


## ArduinoスケッチをMicrochip Studioでデバッグ
残念ながら、Microchip Studioは、Windows版のみが提供されており、MacのVirtualBoxでは動作しませんでした(Paralles, VMwareでは動作が確認されているみたいです)。

*** Microchip Studioのインストール [#yfebb69a]
Microchip Studio for AVR and SAM Devices 7.0.2542のオフラインインストーラを以下のURLからダウンロードします。
- https://www.microchip.com/content/dam/mchp/documents/parked-documents/as-installer-7.0.2542-full.exe


*** Arduino UNOとMBLAB Snapとの接続 [#u3ac9def]
Arduino UNOとMBLAB Snapとの結線は、トランジスタ技術2021年4月号の図8から引用します。

&ref(Fig-8.png,,50%);


結線を整理すると以下のようになります。

| MPLAB Snap | Arduiono ISPピン |h
| 2: VDD | 2: VCC |
| 3: GND | 6: GND |
| 4: DAT | 1: MISO |
| 5: CLK | 3: SCK |
| 6: AUX | 5: /RESET |
| 7: TDI | 4: MOSI |

自由に切り離せるメス・押すのピンケーブルを使って以下のようにテープでまとめました。

&ref(AVR-Cable.png,,50%);


*** Arduinoスケッチのインポート [#p0649f60]
Microchip StudioにArduinoスケッチをインポートする手順は、以下の動画に紹介されています。
- https://onlinedocs.microchip.com/pr/GUID-54E8AE06-C4C4-430C-B316-1C19714D122B-en-US-2/index.html?GUID-438A4502-6265-4930-9D7A-230E3D7BB909

手順としては、以下の通りです。
- File > New > Project...を選択
- プロジェクトの作成ディレクトリを指定
- インポートするスケッチとボード、デバイスを選択

Arduinoプロジェクトの作成画面では、「Create project from Arduino sketch」を選択し、プロジェクト名称、作成ディレクトリを入力して、OKボタンを押下します。

&ref(NewArduinoProj.png,,50%);


インポートするArduinoのスケッチを指定し、ボードのタイプ、CPUデバイスをセットしてOKボタンを押下します。
必要なライブラリも合わせてインポートされ、Microchip Stduioのプロジェクト画面が表示されます。

&ref(BlinkProj.png,,50%);


** デバッグの手順 [#ub3787a3]
Arduinoスケッチをデバッグするときに注意が必要なことにヒューズ・ビットの切り替えです。 ATmega328Pのデバッグには、ISPインタフェースからdebugWIREインタフェースに切り替えるために、 ヒューズ・ビットを書き換える必要があります。

Arduino(ATMEGA168/328用ボード)のジャンパを外して電源をオンにし、MPLAB Snapを接続してください。

&ref(Arduino-Snap.png,,50%);


以下の手順でデバッグを開始します。
- Debug > 「プロジェクト名」 Properties...を選択し、debugger/programmerでMPLAB Snapを選択、InterfaceでdebugWIREを選択

&ref(Project-properties.png,,50%);


- Debug > Start Debugging and Break(Alt+F5)を選択
- ボードでの最初のデバッグの場合、"Failed to launch debug session with debugWIRE"の警告メッセージがでますので、YESボタンを押下

&ref(Failed-to-launch debug-session.png,,50%);


-「debugWIRE is enabled」情報メッセージができますので、Arduinoの電源を入れ直し後、OKボタンを押下してください。

&ref(debugWIRE-is-enabled.png,,50%);


- main関数で停止
Start Debugging and Break(Alt+F5)でデバッグを開始するとmain関数の先頭で停止します。

この後は、Step Over(ステップ実行)、Step Into(関数内に入る)、Step Out (関数を抜ける)、Continue(続ける)等の
デバッグコマンドが使用でき、Autos画面では変数の値が確認できます。

&ref(stop-at-main.png,,50%);


ブレークポイントをセットしておけば、Continueボタンを押下した時にブレークポイントで停止します。

&ref(break-at.png,,50%);


*** Launch Failedが出たとき [#k15c9995]
Launch Failedが出たときには、ターゲットボードの電源またはケーブルの配線をチェックしてください。

&ref(Failed-to-enable-DW.png,,50%);


*** デバッグ完了時 [#cff3248f]
デバッグを完了したら、必ずISPモードに戻してください。
debugWIREモードからISPモードに戻すには、デバッグの最後に
- Debug > Disable debugWIRE and Closeを選択してください。

** コメント [#xa9dd3a3]
#vote(おもしろかった[5],そうでもない[0],わかりずらい[0])
#vote(おもしろかった[6],そうでもない[0],わかりずらい[0])

皆様のご意見、ご希望をお待ちしております。
#comment_kcaptcha

トップ   編集 差分 バックアップ 添付 複製 名前変更 リロード   新規 一覧 単語検索 最終更新   ヘルプ   最終更新のRSS
SmartDoc