FrontPage

2011/10/02からのアクセス回数 9660

SWD対応オープンソースのJTAG Versaloon

Versaloonは、ARM Coretex-M3シリーズで最近よく使われているデバッガとのインターフェース SWDをサポートするオープンソースのJTAGです。

STM32マイコン評価ボードSTM32VLDISCOVERY やARMマイコンパーフェクト学習基板で採用されているLPC1343の評価ボードhttp://akizukidenshi.com/catalog/g/gM-03598/ が開発環境とボードに組み込まれたSWDデバッガでとても簡単に開発できるのですが、すべてWindows上の開発環境です。 *1

arm/CodeBaseを使ったARMマイコンパーフェクト学習基板の使い方でMac OSX上でコンパイルと、 プログラムのセットができても、オープンソースのデバッガOpenOCDがSWDに対応していない *2 ので、とても悔しい思いをしていました。

Versaloonとの出会い

はじめてVersaloonの存在を知ったのは、 ねむいさんのぶろぐ を見たときでした。世の中にはすごい人がいるものだと感動しました。

さっそく、STM8S-Discoveryはじめ必要な部品を揃えSTM8S-DiscoveryのVersaloon化に挑戦しましが、 ハンダ技術にとぼしい私には、MCUのピンにハンダ付けをすることは不可能でした。

そこで、 Versaloonのサイト から完成品のVersaloon Miniを購入し、OpenOCDを作ろうとしましたが、 開発途中のためパッチとソースのバージョンが合わず上手くいきませんでした。

Windowsの方は、ねむいさんが OpenOCDの作成手順 を紹介されていますので、そちら参照するとよいでしょう。

この他に LPC1343 QuickStart Board を販売しているサイトから 10-pin to 20-pin JTAG Adpater Kit を合わせて購入すると便利です。

versaloon.png

再度挑戦しようと思ったわけ

それでももう一度Versaloon対応のOpenOCDを作ってみようと思ったのは、 Bingo氏のサイト で紹介されている STM32 DiscoveryのVersaloon化の手順書 を見たときです。

これならトラ技のオフ会でもらったSTM32L-Dsicoveryを使ってハードの改造なしに、簡単にSTM8S-Discovery をVersaloon化することができると気づきました。 *3

その前に、Versaloon用のOpenOCDを作成する必要があります。以下ではMac OSX上でVersaloon対応のOpenOCDを作成する手順を紹介します。

Mac OSXで動作するSWD対応OpenOCD

Bingo氏は、VersaloonのForumでだれでも再現できるようにな スクリプトと必要なパッチ をまとめてくれました。

Bingo氏は、Versaloonの著者Simon氏の配布ファイルにあるopenocd_updateを修正し、

しています。

MacOSXでのmake

上記配布ファイルを使ってMac OSXでmakeをする場合、準備と若干の修正が必要です。

openocd_updateの実行

準備ができれば、後は簡単です。

Versaloonのファームウェアの更新

私が購入したVersaloon Miniのファームウェアが古く、これをopenocd-force-10-mar-2011.tar.gzに付属する

と入れ替えなくてはならないことが分かりました。

ファームウェアの更新

ファームウェアの更新には、STMの提供するFlash Loader Demonstratorが必要ですが、これを見つけるのに一苦労しました。ということで、

Versaloonにファームウェアを書き込むには、ボタンを押しながらUSBに接続すると赤のLEDが点灯します。 これで、シリアル通信ができるようになります。

Flash Loader Demonstratorを起動し、

flash_loader_demo1.png

指示に従いながら進んでVeraloon_IAR.hexを指定して書き込みます。

flash_loader_demo4.png

OpenOCDのコンフィグファイル

OpenOCDを使う場合、JTAGインターフェースの定義ファイル、ターゲットのMPUの定義ファイルが必要となります。

OpenOCDでは、インストール時によく使われているものについてこれらの定義を

にセットされていますが、versaloonやSWD対応MPUであるLPC1114, LPCLPC1343, LPC1768の定義ファイルは 提供されていません。

いろいろ探してみると流石 ねむいさんのぶろぐ おきば にありました。

をダウンロードしてください。 ねむいさん、ありがとうございます。

定義ファイルのコピー

ダウンロードした定義ファイルを解凍し、以下のようにコピーします。

$ cd OpendOcd_cfgs
$ sudo cp tcl/interface/* /usr/local/share/openocd/scripts/interface/
$ sudo cp tcl/target/* /usr/local/share/openocd/scripts/target/

OpenOCDを使って書き込みのテスト

書き込みのテストには、ねむいさんの作られたkick startのプロジェクトを使いました。

ファイルを展開したら、

$ cd LPC1343_with_KickStarts_20100901
$ 

コメント

選択肢 投票
おもしろかった 0  
そうでもない 0  
わかりずらい 0  

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


(Input image string)

*1 これらを使うときには、VMWareを使ってバーチャルマシンでWindowsを起動しなくてはなりません
*2 Ver. 6以降はサポートされているみたい
*3 私の方法は、Bingo氏の方法よりも簡単です
*4 STマイクロのウェブページの構成が悪いのだと思います。

トップ   新規 一覧 単語検索 最終更新   ヘルプ   最終更新のRSS
SmartDoc