LM4F120シリーズを使ってみる2 -Stellaris Launchpad単体でOpenOCDで書き込み・デバッグを行う-
退院したら荷物がいろいろ届いていました。
9月末に購入したSTM32F3-Discoveryもようやく来てました…長かった…!
体の方も完全に元に戻ったので東海自然歩道のほうも再開していきますので皆様方
覚悟してください!
さて本題に入りますが入院前にStellaris LaunchpadにビルドインされたTI-ICDIの
OpenOCDの対応状況について少し触れてました。あの時完成間近だったのでもうコミット
されてるよねと思ったら差し戻しでまだレビュー中になっています。
なんだかリリース時期について揉めてるようですが、私たちユーザサイドもパッチを落として
試すことができるのでどんな感じか試してみました。
以前のLuminary-ICDIと違う点はJTAGデバイスとして使うチップがFTDIのではなく、LM4F
マイコンのファームウエアとして作りこまれていてドライバもTIのプロプライエタリな
物となっています。この点はSTLink/V2がOpenOCDで使えるようになった経緯とおんなじ
ですね。こちらもTIのスタッフの助力の下TI-ICDIを叩くためのAPIを提供してもらって
OpenOCDの上位のレイヤーと下駄合わせをしています。
そしてAPIを使ってアクセスするのがSTLink/V2だけではなくなるので汎用的なレイヤで
あるstlink_swdからhla_swdへとトランスポートの名称が変わってます(OpenOCDのコン
フィグファイルの定義を少し書き換える必要が出る程度の影響ですが)。
使用するデバイスドライバはTI提供のデバイスドライバがそのまま利用可能です。
OpenOCDがサポートしているのはJTAG接続のみでSWDは未サポートなのでご注意を。
てわけで早速書き込み・デバッグしてみました。
> "C:¥Devz¥Coreutils¥bin¥make.exe" program
openocd -s C:/Devz/ARM/OCD/tcl -f target/ek-lm4f120xl_flash.cfg -c "mt_flash main.elf"
Open On-Chip Debugger 0.7.0-dev-00089-gd6d4283-dirty (2012-11-16-14:13)
Licensed under GNU GPL v2
For bug reports, read
http://openocd.sourceforge.net/doc/doxygen/bugs.html
adapter speed: 1000 kHz
Info : clock speed 1000 kHz
Info : ICDI Firmware version: 9270
Info : lm4f120h5qr.cpu: hardware has 6 breakpoints, 4 watchpoints
target state: halted
target halted due to debug-request, current mode: Thread
xPSR: 0x01000000 pc: 0x00000280 msp: 0x20008000
auto erase enabled
target state: halted
target halted due to breakpoint, current mode: Thread
xPSR: 0x61000000 pc: 0x20000042 msp: 0x20008000
wrote 33792 bytes from file main.elf in 2.059203s (16.026 KiB/s)
target state: halted
target halted due to breakpoint, current mode: Thread
xPSR: 0x61000000 pc: 0x2000002e msp: 0x20008000
target state: halted
target halted due to breakpoint, current mode: Thread
xPSR: 0x61000000 pc: 0x2000002e msp: 0x20008000
verified 33216 bytes in 0.561601s (57.759 KiB/s)
shutdown command invoked
> Process Exit Code: 0
> Time Taken: 00:03
今回のTI-ICDIの対応を機に表示される情報が詳しい物に変わってますね。
わずかな人のみが気づいていたようですが今回の書き込みに使ったテスト用のファー
ムは実は入院直前にUARTのルーチンも追加してました。
ChaN氏のLPC2388向けUART-FiFoを移植してます。
もちろんいつものデバッグ環境も自由自在です。
尤もTIの場合はIDE環境が非常に充実してるので無理やり私の行ってる環境にしないで
メーカー謹製の開発環境のままでも良いかと思います。
ついでですが冒頭のSTM32F3Discoveryでも同じことしてみましたこちらはおなじみの
STLink/V2がビルドインされてます。
> "C:¥Devz¥Coreutils¥bin¥make.exe" program
openocd -s C:/Devz/ARM/OCD/tcl -f target/stm32f3x_stlink_flash.cfg -c "mt_flash main.elf"
Open On-Chip Debugger 0.7.0-dev-00089-gd6d4283-dirty (2012-11-16-14:13)
Licensed under GNU GPL v2
For bug reports, read
http://openocd.sourceforge.net/doc/doxygen/bugs.html
adapter speed: 1000 kHz
srst_only separate srst_nogate srst_open_drain
Info : clock speed 1000 kHz
Info : STLINK v2 JTAG v16 API v2 SWIM v0 VID 0x0483 PID 0x3748
Info : stm32f3x.cpu: hardware has 6 breakpoints, 4 watchpoints
target state: halted
target halted due to debug-request, current mode: Thread
xPSR: 0x01000000 pc: 0x08000708 msp: 0x10002000
adapter speed: 8000 kHz
auto erase enabled
Info : device id = 0x10036422
Info : flash size = 256kbytes
target state: halted
target halted due to breakpoint, current mode: Thread
xPSR: 0x61000000 pc: 0x2000003a msp: 0x10002000
wrote 6144 bytes from file main.elf in 0.624001s (9.615 KiB/s)
target state: halted
target halted due to breakpoint, current mode: Thread
xPSR: 0x61000000 pc: 0x2000002e msp: 0x10002000
target state: halted
target halted due to breakpoint, current mode: Thread
xPSR: 0x61000000 pc: 0x2000002e msp: 0x10002000
verified 4172 bytes in 0.171600s (23.743 KiB/s)
shutdown command invoked
> Process Exit Code: 0
> Time Taken: 00:02
こちらも詳しい表示に変更されています。
いつもの。
STM32F3-Discvoeryもまた別に時間を割いてご紹介するつもりですのでこうご期待!
今回の検証に使ったOpenOCDはテスト版なので公開していませんがWindows環境を
持ってる人で試してみたい方は連絡ください。
さらについでですがLM4F用のioviewでGPIOの出力レジスタをビット単位で表示出来る
ように更新しました。
- ARM/STM32 (88)
- OpenOCD (20)
- ARM/NxP (34)
- ARM/Cypress (5)
- ARM/Others (3)
- AVR (5)
- FPGA (4)
- GPS/GNSS (17)
- MISC (45)
- Wirelessなアレ (16)
- ブラウザベンチマーク (28)
- 日本の自然歩道 (10)
- GNSSモジュールを試用する18 -みちびき四機体制記念-
⇒ matsup (04/19) - いろいろ試す28
⇒ ひかわ (09/23) - いろいろ試す28
⇒ ねむい (09/22) - WVGAな解像度で容量性タッチパネルなTFT-LCDモジュールを動かすその1
⇒ ねむい (09/22) - WVGAな解像度で容量性タッチパネルなTFT-LCDモジュールを動かすその1
⇒ あきらひとし (09/21) - いろいろ試す28
⇒ ひかわ (09/18) - いろいろ試す28
⇒ ひかわ (09/18) - GNSSモジュールを試用する16 -みちびき参号機打ち上げ成功記念-
⇒ ねむい (09/16) - GNSSモジュールを試用する16 -みちびき参号機打ち上げ成功記念-
⇒ matsup (09/14) - いろいろ試す28
⇒ ねむい (08/31)
- GNSSモジュールを試用する18 -みちびき四機体制記念-

- April 2018 (1)
- March 2018 (1)
- February 2018 (1)
- January 2018 (1)
- December 2017 (2)
- November 2017 (2)
- October 2017 (1)
- September 2017 (1)
- August 2017 (1)
- July 2017 (1)
- June 2017 (1)
- May 2017 (1)
- April 2017 (1)
- March 2017 (2)
- February 2017 (2)
- January 2017 (2)
- December 2016 (7)
- November 2016 (2)
- October 2016 (2)
- September 2016 (1)
- August 2016 (1)
- July 2016 (1)
- June 2016 (1)
- May 2016 (2)
- April 2016 (1)
- March 2016 (2)
- February 2016 (1)
- January 2016 (1)
- December 2015 (3)
- November 2015 (1)
- October 2015 (3)
- September 2015 (2)
- August 2015 (2)
- July 2015 (3)
- June 2015 (3)
- May 2015 (4)
- April 2015 (2)
- March 2015 (4)
- February 2015 (1)
- January 2015 (3)
- December 2014 (3)
- November 2014 (2)
- October 2014 (1)
- September 2014 (2)
- August 2014 (2)
- July 2014 (3)
- June 2014 (2)
- May 2014 (1)
- April 2014 (1)
- March 2014 (4)
- February 2014 (4)
- January 2014 (3)
- December 2013 (5)
- November 2013 (4)
- October 2013 (3)
- September 2013 (2)
- August 2013 (2)
- July 2013 (2)
- June 2013 (3)
- May 2013 (2)
- April 2013 (2)
- March 2013 (2)
- February 2013 (2)
- January 2013 (3)
- December 2012 (4)
- November 2012 (2)
- October 2012 (2)
- September 2012 (4)
- August 2012 (1)
- July 2012 (3)
- June 2012 (2)
- May 2012 (3)
- April 2012 (3)
- March 2012 (2)
- February 2012 (3)
- January 2012 (3)
- December 2011 (5)
- November 2011 (3)
- October 2011 (2)
- September 2011 (2)
- August 2011 (2)
- July 2011 (2)
- June 2011 (2)
- May 2011 (2)
- April 2011 (2)
- March 2011 (2)
- February 2011 (2)
- January 2011 (3)
- December 2010 (7)
- November 2010 (1)
- October 2010 (1)
- September 2010 (1)
- August 2010 (3)
- July 2010 (4)
- May 2010 (1)
- April 2010 (2)
- March 2010 (2)
- February 2010 (2)
- January 2010 (3)
- December 2009 (3)
- November 2009 (8)
- October 2009 (7)
- September 2009 (5)
- August 2009 (4)
- July 2009 (6)
- June 2009 (7)
- May 2009 (14)
- January 1970 (1)

