OpenOCD小ネタ12 -HLA向けのcfgファイルの統合-
お盆前に行われたOpenOCDのHLA系コンフィグファイル大変更への対応を幾つかのター
ゲット向けの試用実例と交えて解説します。とその前に!
最近再び似た質問を多数いただくようになったので・・・
●STLinkがOpenOCDで動きません。
NxP系マイコンのCheckSumValidationと同じく何度も言ってますが何度でもおさらいです。
質問が続く限り何度でもなんどでも な・ん・ど・で・も 説明します!
注:STLink/V1はもう持ってないのでサポート外です。STLink/V2とSTLink/V2-1系向けです。
20140902追:
2014年9月現在、Windows8.x系環境下でSTLink/V2-1がOpenOCDから
利用できません。これはlibusbがWin8.x環境下でUSBコンポジットデバイスを
正しく扱えてないことに起因するものだそうです。
libusbに修正かかるまで辛抱強く待つかXP/Win7に戻すのです!!
STLink/V2の方はコンポジットじゃないのでWin8でも問題なく使用可能です。
20141114追:
Windows8.x環境下でのOpenOCDサポート開始です
1.基本的な結線は本当に正しいか
STLink/V2系はSRST,Vtgt(ターゲットのVCC),SWCLK,SWDIO,GNDが必須です。
SWCLKとSWDIOを"てれこ"にしてたりGND繋げてなかったとか論外ですが(そういった
ケースもありました…私に直接返信はなく質問された方のtwitter上の発言でそれ知っ
たのですが…#)まず第一にGND,SWCLK,SWDIOの結線がターゲットのMCUと正しくなさ
れているかを回路図を良く見てテスターで導通をしっかり確認してください。
2.SRSTは繋がっているか
現在ではNucleo/Discovery等のメーカ製評価ボード向けの特製cfgはすべてSRSTを使用
するように設定されています。したがって私の特製cfgもそれに準じております。
stlink-v2.cfgを直接呼び出す使い方を中途半端に真似ると引っかかるのでご注意ください。
Nucleo/Discovery等のメーカ製評価ボードから自作のボードに環境を変えた際にSRSTの
接続を忘れ上手く動かないといった連絡を特に戴いています。
回路図を良く見てテスターで導(ry
3.Vtgtは繋がっているか
また、Vtgtの接続もほぼ必須です。これも"2."と同様ですが特にNucleo/Discovery等の
メーカ製評価ボードからデバッグ線を引き出して自前のボードと繋げる際に発生します。
ネット上では情報が倒錯しOpenOCDではVtgt必要ないと断言している記述もあるので
ご注意ください。ねむいさんは一貫してVtgt繋げろです。
STLink/V2は接続の際にまずSWCLK,SWDIOの電圧を読みに行ってVtgtの電圧よりも
相対的に高い電圧とみなすとその後の一切を弾くのでコケて絶対先に進めません。これは
ファームウエアレベルでこういう動作をしますので特定のソフトに依存はしません。
メーカ製ボード上ではVDDがSBDで切られてVf分のドロップで3.0V前後と若干低くなった
状態で動作しているので気づきません。しかしながら自作のボードではほとんどが3.3V
で使用されるともいます。このときSWCLK/SWDIOの電圧はデバッガ側より必ず大きく
なるのでコケます。
また、以前も触れましたが一部のボードではコスト削減のためVtgtにつながる抵抗が実装
されていないものもあります。ケアレスミスで時間を浪費しないように回路図を良く見(ry
・・・
STLiink系ばっかりに力入れるわけにはいかないので本題に入ります。
●分かれていたコンフィグファイルが今一つに!
これです。目的はSTLink/V2やTI-ICDI等のHLA(HighLevelAdapter)も従来のFTDI/JLink等
と同じコンフィグファイルを使用できるようにする修正です。
もともとHLAは各メーカが提供する独自のデバッグ用APIをOpenOCDでも利用できるようにと
組み込まれた機構です。したがってターゲットMCUへのローレベルなアクセスができない、
クロック周波数の設定等のアダプタ側でも細かい制御もできないといった制約があります。
ですのでその挙動の違いから使用可能なコマンドも分けられており、従来は各MCU向けの
OpenOCDコンフィグファイルも通常のものとHLA系に分けなければなりませんでした。
しかし今回の修正でHLA系で使うとエラーになっていたadi_v5系のローレベルのコマンドが
エラーとならずオーバーライド(スルーとも言う)できるようになり、hla専用cfgは晴れて
お役御免となったわけです。
さて、変更されて箇所は分かりましたがそれを実際にどう反映させればよいかというと・・・
OpenOCDを呼び出す際の引数として、もしくはcfgファイル内に"transport select"コマンド
を追加で付与します。以前はHLA系アダプタを使用する場合はトランスポートが決め打ち
だったのでSTLink/V2やTI-ICDIのcfgファイルに直接記述されていた物が外に追いやられた
形になってます。EFM32TG822F32の例を取って新旧のOpenOCD引数比較をします。
下記の記述はこちらのデバッグ手順に準じますので事前に把握をお願いします。
旧:
OCD_ARG = -s $(OCDIR)/tcl ¥
-f interface/stlink-v2.cfg ¥
-f target/efm32tg822f32_hla_flash.cfg
新:
OCD_ARG = -s $(OCDIR)/tcl ¥
-f interface/stlink-v2.cfg ¥
-c "transport select hla_swd" ¥
-f target/efm32tg822f32_swd_flash.cfg
こんだけです。TI-ICDIの場合はJTAG接続専用なので"hla_jtag"になります。
STLink/V2,STLink/V2-1はSWD専用なので"hla_swd"です。
メーカ製出来合いのボードの場合、OpenOCDのボート向けcfgで対策されたのがほとんど
なのでこちらで修正する必要はないです。Nucleo-R334板(STLink/V2-1付)の例を示します。
旧:
OCD_ARG = -s $(OCDIR)/tcl ¥
-f target/nucleo-f3_flash.cfg
新(旧と全く同じ):
OCD_ARG = -s $(OCDIR)/tcl ¥
-f target/nucleo-f3_flash.cfg
因みにcmsis-dapの場合も現状SWD専用なのでswdが自動で選択されるので特に変更は
不要です。トラ技ライタ(LPC11U35)にCMSIS-DAPで繋げる例を示します。
旧:
OCD_ARG = -s $(OCDIR)/tcl ¥
-f interface/cmsis-dap.cfg ¥
-f target/lpc11xxx_swd_flash.cfg
新(旧と全く同じ):
OCD_ARG = -s $(OCDIR)/tcl ¥
-f interface/cmsis-dap.cfg ¥
-f target/lpc11xxx_swd_flash.cfg
さらにJTAGKey2等の汎用のJTAGの場合は何も指定しない時はデフォルトでJTAG接続
となるので余計な指定は不要です。STM32F407ZGT6にJTAGKey2で繋げる例を示します。
旧:
OCD_ARG = -s $(OCDIR)/tcl ¥
-f interface/ftdi/jtagkey2.cfg ¥
-f target/stm32f4x_flash.cfg
新(旧と全く同じ):
OCD_ARG = -s $(OCDIR)/tcl ¥
-f interface/ftdi/jtagkey2.cfg ¥
-f target/stm32f4x_flash.cfg
JLINKやVersaloon,FT2232系でSWDしたい場合は宣言は必須ですがこの3つに関しては
私のcfgレベルで対策済なので私が提供するバイナリとcfgを使う限りは変更不要です。
STM32F407ZGT6にVersaloonで繋げる例を示します。
旧:
OCD_ARG = -s $(OCDIR)/tcl ¥
-f interface/vsllink_swd.cfg ¥
-f target/stm32f4x_flash.cfg
新(旧と全く同じ):
OCD_ARG = -s $(OCDIR)/tcl ¥
-f interface/vsllink_swd.cfg ¥
-f target/stm32f4x_flash.cfg
現在のOpenOCDでは以下の4つのtransportが存在していますが、hla系は上記の要領で
多少の変更を追加するだけで対応可能となっています。
transport select jtag (transportを何も指定しないときのデフォルト)
->FT2232系,JLINK系,Versaloon,その他多くのJTAGデバイス
transport select swd
->FT2232系,JLINK系,Versaloon,CMSIS-DAP
transport select hla_swd
->STLink/V2,STLink/V2-1
transport select hla_jtag
->TI-ICDI
なお、今回の統合でSWD接続においてレグレッション・テストを行っていなかったようで
SWDでエラーが発生してしまいました。私はお盆前に自作のパッチを適用したバイナリを
公開していましたが現在はこの問題に気付いた方が別のアプローチからパッチを提出し
マージされております。LPC17xx系でDAPIDの問題が残ってますがマイナーな問題なので
時期に修正されると思います。
現在はすべてのtransportでスムーズにOpenOCDが利用できます。あとは微妙に残ってる
JTAG依存な処理の完全切り離しとSWDのSRSTコントロールの最適化が達成できたら
OpenOCD導入のハードルは下がると思います。
というわけでおきぱにあるOpenOCDバイナリもどしどしご利用ください!
OpenOCD小ネタ11 -EFM32 ZeroGeckoとJLinkのSWD接続正式対応-
以前ちらっとお見せしましたがEFM32のZeroGeckoシリーズの評価ボードをだいぶ前に
手に入れて、評価しております。
MCUにはおなじみトカゲのマークがあります。Cortex-M0+コアを持つEFM32ZG222F32が
搭載されています。
ボードは低消費電力のアプリ作成を意識したものになっていて搭載されている液晶も
メモリ液晶と呼ばれる超低消費電力なものとなっています。
最初に書き込まれているプログラムは、メモリ液晶を利用したインベーダーもどきなゲームを
遊ぶことができます。なおこのゲーム、一機死んだら即ゲームオーバーなかなりシビアな
代物です!!!
今回の記事に合わせ、私が基本としているLED&UARTなEFM32評価ボード向けのGCC
プロジェクトも作成しております。低消費電力モードは使わず極めてシンプルな代物です。
また、以前もふれましたがOpenOCDからもEFM32ZGシリーズも書き込みができるように対応
しております。EFM32自身はSW-DPしか持たないので書き込み/デバッグするためにはSWD
接続可能なアダプタが必要となりますが現在ではSTLink/V2,JTAGKey2,Versaloon、そして
後で述べるJLinkがSWD接続対応のデバッガアダプタとしてOpenOCDから使用可能になって
おりますので不自由はしないでしょう。
こちらは素組みのEFM32ZG板をSWD接続版のJTAGKey2でデバッグしてるところです。
もうおなじみの画面ですね。
話は評価ボードに戻しますがこちらにはJLink-OBと呼ばれる他社向けのMCU評価ボード専用
のJLinkが搭載されております。LPC-Link2等でもほぼ同じ仕組みでオンボードでJLinkをエミュ
レーションしていますが従来、OpenOCDからはJTAG接続だけが可能でした。
したがってSW-DPしか存在しないEFM32ではOpenOCDで書き込みデバッグする際はオンボの
JLinkは無効にしてSTLink/V2やVersaloonのSWD版で使用せざるを得なかったのですが、少し
前にJLinkも正式にSWD接続に対応し、単体でフル活用できるようになっております♥
オンボJLinkでOpenOCDです。JLink純正のドライバじゃないと外部にデバッグプローブを
引き出すことはできませんが私の場合はJLinkエミュが可能なLPc-Link2を所持してるので
通常はlibusb-1.0のみで十分だと思ってます。
ここでOpenOCDでEFM32シリーズを操作するためのコツですが…EFM32はリセット直後の
短い時間の間だけSWDの信号線が別の独自のデバッグプロトコルとして挙動するのでSRST
と組み合わせて操作することができません。したがって"connect under reset"は使用不可
能になります。
誤って低消費電力モードにしてしまうとOpenOCDからの操作ではもう元に戻せなくなり
ますので、くれぐれもご注意ください。
しかしながらEFM32板のオンボJLinkはsegger純正ドライバとEFM32が提供するデバッグ
ツール"energyAware Commander"から独自プロトコルの操作が可能なため、初期状態に
戻すことができるので心配はいりません。
ここまではEFM32とオンボJLinkについて述べてきました。私はJLink化が可能なLPC-Link2
を持っていますのでLPC-Link2にJLinkのファームウエアを再び書き込みこちらも同じように
SWDで接続出来るか試してみたいと思います。
↑ターゲットはトラ技ARMライタという名のLPC11U35板です。
ライセンスの関係上NxP以外の製品で使うところはお見せできませんがOpenOCDでは
ほぼすべてのARMマイコンを書き込みデバッグできる攻守ともに非常にバランスの良い
デバッガアダプタとなりました。
20kBほどの同一のバイナリを同一のUSBポートから書き込んだときのCMSIS-DAPとJlink
エミュとの速度の比較です。
*CMSIS-DAP on LPC-Link2
wrote 20480 bytes from file main.elf in 10.265428s (1.948 KiB/s)
verified 20204 bytes in 0.437491s (45.099 KiB/s)
*JLink on LPC-Link2
wrote 20480 bytes from file main.elf in 2.624950s (7.619 KiB/s)
verified 20204 bytes in 0.265620s (74.281 KiB/s)
CMSIS-DAPファームの時はOpenOCDの実装がせっかくのブロック転送機能をフルに利用
していない残念仕様のためやたらと遅いのですがJlinkエミュならバルク転送がびしばし
使えるので超早いです♥但しSRST/TRSTの操作がちょっと怪しい所があります。
seggerの純正のツールではちゃんと操作できるので時間を見て両者の挙動の違いを詰め
て行きたいと思います。現状SRSTを必ず要する場面は限られていますのでJLinkエミュ
にしっぱなしの方がサクサク作業を進められると思います。ねむいさんのおすすめです。
(※ただしNxP製品以外の書き込み/デバッグに使っちゃ駄目ですよ!)
20140820追:
F**K
今回は数日前のOpenOCDのコミットでHLA(HighLayerAdapter)系デバッガアダプタのcfgが
一般の物に統合されたというかなり重要なことについてもお伝えしたかったのですが、
JlinkのSWD対応の紹介で長くなりすぎましたので次回じっくりと解説させていただきます。
連絡・質問・免責は↑のリンクを
↓SNSもやってます↓
powered by まめわざ- ARM/STM32 (103)
- OpenOCD (27)
- ARM/NxP (34)
- ARM/Cypress (5)
- ARM/Others (3)
- ARM/Raspi (1)
- AVR (11)
- FPGA (4)
- GPS/GNSS (18)
- MISC (75)
- STM8 (1)
- Wirelessなアレ (16)
- ブラウザベンチマーク (28)
- 日本の自然歩道 (23)
- 1Wire温度センサDS18B20の偽物を追え!
⇒ ねむい (04/26) - 1Wire温度センサDS18B20の偽物を追え!
⇒ (04/08) - 中国自然歩道を往く -北伐!県境を越えて鳥取県に侵入せよ!-
⇒ ねむい (12/23) - 中国自然歩道を往く -北伐!県境を越えて鳥取県に侵入せよ!-
⇒ ひかわ (12/18) - 中国自然歩道を往く -北伐!県境を越えて鳥取県に侵入せよ!-
⇒ ひかわ (12/18) - いろいろ試す51
⇒ ねむい (06/26) - いろいろ試す51
⇒ ひかわ (06/10) - STM32G0使ってみる4 -1wireデバイスをいろいろ使ってみる-
⇒ ねむい (12/14) - STM32G0使ってみる4 -1wireデバイスをいろいろ使ってみる-
⇒ ひかわ (12/05) - 大緊急事案!!!1!Raspberry Pi Picoはぢめました!!1!!1
⇒ 竹本浩 (08/14)
- May 2023 (2)
- April 2023 (1)
- March 2023 (1)
- February 2023 (1)
- January 2023 (1)
- December 2022 (2)
- November 2022 (1)
- October 2022 (1)
- September 2022 (1)
- August 2022 (1)
- July 2022 (1)
- June 2022 (1)
- May 2022 (1)
- April 2022 (1)
- March 2022 (1)
- February 2022 (1)
- January 2022 (1)
- December 2021 (2)
- November 2021 (2)
- October 2021 (1)
- September 2021 (1)
- August 2021 (1)
- July 2021 (1)
- June 2021 (1)
- May 2021 (1)
- April 2021 (1)
- March 2021 (1)
- February 2021 (1)
- January 2021 (1)
- December 2020 (3)
- November 2020 (1)
- October 2020 (1)
- September 2020 (1)
- August 2020 (1)
- July 2020 (1)
- June 2020 (2)
- May 2020 (1)
- April 2020 (1)
- March 2020 (1)
- February 2020 (1)
- January 2020 (1)
- December 2019 (3)
- November 2019 (1)
- October 2019 (1)
- September 2019 (2)
- August 2019 (1)
- July 2019 (1)
- June 2019 (1)
- May 2019 (1)
- April 2019 (1)
- March 2019 (1)
- February 2019 (1)
- January 2019 (1)
- December 2018 (3)
- November 2018 (2)
- October 2018 (1)
- September 2018 (1)
- August 2018 (1)
- July 2018 (1)
- June 2018 (1)
- May 2018 (1)
- April 2018 (2)
- 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)
Copyright(C) B-Blog project All rights reserved.