ロジックアナライザは、通信プロトコルのデータ解析機器・ツールです。
信号の波形を見るだけならオシロスコープでもいいのですが、SPI, I2C, UARTなどのデジタル通信で、実際にどのようなデータが流れているかを解析するのにはロジックアナライザが便利です。
ここでは、ZEROPLUSのLAP-Cを使って、SPIのデータ解析を行う方法を記載します。
参考記事:
ZEROPLUS社のLAP-CシリーズのロジアナがWindows 10に対応
ロジックアナライザー ZEROPLUS LAP-C を使ってみた ( SDカードの SPI クロック測定等 )
数年ぶりに調べてみたら、日本語記事が多数出ていますね。ありがたいです。
使用機器
仕様
対応プロトコル:SPI, I2C, UART, USB 1.1, USB 2.0, CAN, eMMC, GPIB, HDMIなど、
多数のプロトコルが標準機能として使えます。
チャンネル数:16
サンプリング周波数:100Hz ~ 100MHz
データ表示:PCアプリ(Webからダウンロード可)
接続方法
Youtubeに公式動画が有ります。
LAP-C - Unboxing and connection to DUT (En)
本製品と測定対象プロトコルの信号線をケーブルで繋ぎます。
この時、GNDの接続を忘れないようにします。
PCアプリ
インストール
各製品のページからソフトウェアをダウンロードしてインストールします。
[http://www.zeroplus.com.tw/logic-analyzer_en/products.php?pdn=3&pdnex=list](ZEROPLUS Logic Analyzers)
本記事では、LAP-C(16032) V3.13.05を使用しました。
最新版ではWindows10に対応しており、多くのプロトコルが最初から使えるようになっています。
(旧版では、パッケージ付属のキーで追加ダウンロードが必要でした)
使い方
信号線の設定
以下で接続している場合です。
A0 : SCLK
A1 : CS
A2 : MOSI
A3 : MISO
各「チャネル名称」のシングルクリックで信号線に名前を付けます。
MOSI 対応 (masterからslaveへの送信データ)
SCLK, CS, MOSIまでを範囲選択して右クリックから「信号線をバスにまとめる」を選択します。
グループ化されるので、さらに右クリックで「バス特性」を選択します。
「プロトコルアナライザ」から目的のプロトコルを選択します。
(ここでは「SPI MODULE V1.18.01(CN01)」を指定)
「パラメータ構成」ボタンから、
-
[Configuration]
先ほど付けた名前を設定します。
DATAにはデータの中身を表示したい信号線として、MOSIを指定します。
1つのバスでは同時に1つの信号線データしか表示出来ません。
その他、接続するデバイスに応じて設定します。
次に、CSの「トリガ条件」をクリックして、以下の状態にします。
SPIで通信開始を表す、CSがHighからLowに落ちるタイミングのデータが取得されます。
MISO 対応 (slaveからmasterへの送信データ)
チャネル名称のMISOを右クリックして「新しいチャネル/バス」を追加し、
SCLKの信号線名(A0など)を指定
同様にCSの信号線名(A1など)を指定
すると、MISOの上にA0とA1の信号線が追加されます。
それぞれSCLK, CSと名前を付けて、後はMOSIと同様な設定を行います。
サンプリング設定
メニューから「バス/シグナル」-「サンプリング設定」を選びます。
対象のプロトコルに応じた周波数を設定します。
SPIが1MHz設定ならそれよりも大きい10MHzなどを選択する必要が有ります。
RAMサイズは本製品のスペックに応じた値を選択します。
ここでは、16Kを設定します。
データ圧縮すると、取得出来るデータが増えます。
サンプリング
実行
本製品自体に付いているボタン
もしくは、アプリの実行ボタン(F5)を押します。
ターゲットでSPIの通信を行わせて、トリガ条件を満たしたところでデータを取得して停止します。
結果表示
MOSIとMISOの値が16進で表示されています。
データがASCIIであれば、バス特性で「ASCII」を指定することでテキスト表示されます。
メニューの「ウィンドウ」-「バスパケットを図形リスト化して表示」を選択しておくと、
一連のパケットがリストで表示されます。
トリガのタイミング調整
例えば、複数パケットが流れるがそのうち何番目かのトリガでデータを取得したいという場合、
メニューの「トリガ回数」に何番目かを設定しておきます。
また、全体のサンプリング期間におけるトリガを掛けるタイミングを指定することが出来ます。
例えば、10%にすると、以下のように全サンプリングデータの最初から10%の所がトリガ(Tのラベルが付いている縦の赤い線)になります。
トリガ後の一連のデータを見たいのか、トリガの前のデータを見たいのかで割合を設定します。
画面表示設定
拡大/縮小/移動
左右移動については、
マウスホイールでも出来ますが、次のトリガー位置に移動したいという場合、
トリガーを掛けている信号線(CS)を選択して、ツールバーの以下左右ボタンを押します。
以下の「手」のボタンでも左右ドラッグが出来ますし、真ん中のボタンで範囲選択しての拡大表示が出来ます。
表示モード
時間モードにすると、信号の変化から変化の間の時間が表示されるようになります。
時間間隔計測
例えば、ある位置から別の位置までの時間を知りたいという場合、「定位バー」を使用します。
ラベルAとBが付いた縦線です。
上の「A - B = 65.404us」がAとBの時間間隔です。
Tはトリガが掛かった位置です。