はじめに
前回の記事でご紹介したように、NVMe仕様[1]には、ホストからNVMeドライブに健康状態の自己診断を実行させるコマンド(Device Self-testコマンド)があります。
ただこのDevice Self-testコマンドはオプション機能であり、ドライブによりサポート有無が異なるだけでなく、NVMe仕様ではこのコマンドでの「テスト内容」について例を示すのみにとどめているためテストの内容(範囲)もドライブ依存です。
前回は、比較的容易に取得可能なDevice Self-testのExtended Self-testというテストの所要時間(公称時間)を取り上げて、この値にメーカーや製品の個性が表れていることをご紹介しました。
今回はそんなDevice Self-testの実行方法や内容などについてまとめます。
まとめ
- Device Self-testはドライブメーカー提供ツールでの実行が最も簡単
- Device Self-testはその結果(履歴)を取得可能
- Device Self-testのテスト内容は「製品(メーカー)により異なる」と認識することが重要
Device Self-test実行方法
Windowsの場合
Windows上でNVMeドライブのDevice Self-testを実行する最も簡単な方法は、ドライブのメーカーが提供するツールを使用する方法です。
例えばMicronが提供しているStorage Executiveでは、起動後左側のメニューから「デバイスの自己診断」ボタンを押すと、ドライブがDevice Self-testをサポートしている場合に図1のような画面が表示されます。
図1:Micron Storage ExecutiveでのDrive Self-test起動画面(バージョン7.07.072021.00)
この画面で"Short Self-Test"と"Extended Self-Test"のどちらか実行したいほうを選択して「デバイスの自己診断を実行する」ボタンを押すと、Device Self-testが開始されます。
他メーカーも以下のようなツールを提供していて、ドライブがDevice Self-testをサポートしていれば、同様の方法でDevice-Self testを実行可能です。
- Intel: Intel Memory and Storage Tool
- Kioxia: SSD Utility
- Crucial: Storage Executive
- Samsung: Samsung Magician
- Seagate: SeaTools
- Western Digital: Western Digital Dashboard
Linuxの場合
Linuxでも、メーカーがWindows版と同様のGUIもしくはコマンドラインインターフェース(Command Line Interface; CLI)のツールを提供していれば、それらのツールを利用してDevice Self-testを実行できます。
もしそのようなツールがない場合、例えばUbuntuであればnvme-cli
パッケージ[2]のコマンドを使う方法があります。
対象のドライブが/dev/nvme1
でそのドライブの全Namespaceに対してShort testを実行するには、次のようにします。
% sudo nvme admin-passthru /dev/nvme1 --opcode=20 --namespace-id=0xFFFFFFFF --cdw10=1
--opcode=20
がDevice Self-testコマンドを、--namespace-id=0xFFFFFFFF
が全Namespaceを対象とすることを、そして--cdw10=1
がShort testの実行開始を意味します。なお、Extended testの実行を開始する場合は--cdw10=2
とします。
ちなみに、一度実行を開始したSelf testを中止するには、上記--namespace-id
オプションを取り除き--cdw10=0xF
に値を変更してDevice Self-testコマンドを発行します。
これら引数の詳細については、nvme
コマンドのマニュアルや、NVMe仕様書の5.8節"Device Self-test command"をご覧ください。
Device Self-testの内容
Device Self-testの内容に関してNVMe仕様が定めている主な項目は以下の通りです。
- "Short test"と"Extended test"の2つを定義
- テスト内容の参考(informative)として9つの分類(セグメント)を定義
- テスト状況(実行中かどうか、どの程度実行が完了したか)および最近20回のテスト結果を示すこと(Get Log Pageコマンドで取得可能)
- テスト中にエラーを検出した場合はどのセグメントで検出したのかを示すこと
まずShort testとExtended testについてです。図2のように、Device Self-testコマンドでDevice Self-testを実行する際には「Short testとExtended testのどちらを実行するのか」を指定します。
図2:NVMe仕様におけるDevice Self-testの種類([1]より引用)
Short testとExtended testの違いは、ざっくり言えば「テストにかける時間の長さ」です。Extended testのほうがShort testよりも長い時間をかけることが多いです。
その「テスト内容の分類(セグメント)」は表1の通りです。
表1:Device Self-testのテスト内容分類([1]より引用)
この表1を見ると、最後(9番目)にS.M.A.R.T.情報のチェックがあることから、「1から8までのテストを実行した後に(再度)S.M.A.R.T.情報をチェックして異常がないか確認すべし」という意図が見て取れます。
この分類(セグメント)には、RAM(SRAMやDRAM)のチェックをはじめ、データのチェックやメディア(NANDフラッシュメモリ)のチェック、ハードウェア的な配線のチェック、そしてもちろん寿命のチェックも含まれます。まさにドライブの「自己診断」ですね。
表1のセグメント6の説明には"Extended only"と書かれていますが、これは長時間かかりそうなのでExtended testでの実施を想定している、ということです。
その他のセグメントにおいても、Short testとExtended testではテスト範囲やテスト内容(チェック内容)の種類や数が調整されていると考えられます。
ただし、これも繰り返しになりますが、Device Self-testの内容はメーカー(製品)依存です。つまり、セグメント1を例にとると、メーカー(製品)により以下のようにテスト内容が異なる可能性があります。
- ドライブA:【Short test】DRAMの一部のみテスト【Extended test】DRAM全体をテスト
- ドライブB:【Short test】SRAMの一部のみテスト【Extended test】SRAMとDRAMそれぞれの全体をテスト
- ドライブC:【Short test】SRAMの全体をテスト【Extended test】DRAM全体をテスト
こればかりは外部からはわかりません。ユーザとしては、「Device Self-testは製品によりテスト内容も範囲も異なるものである」と認識しておくことが重要です。
このことからも、「NVMe SSDは自己診断機能にメーカーの個性が表れている」と言えますね。
この「製品依存である」ことは、例えば「Device Self-testのテスト内容やテスト方法をメーカーに確認してテスト内容を把握し、その上で定期的にホストからDevice Self-testを実行させてドライブの健康状態が所定の範囲内にあることを能動的にチェックする」という風に上手く活用することも可能です。
NVMe SSDを選定する際の基準のひとつにもなり得ます。
Device Self-testの履歴を調べる
最後に、Device Self-testの履歴を調べる方法を紹介します。
NVMe仕様は、ドライブがDevice Self-testをサポートする場合、最近20回のDevice Self-test実行結果をホストから取得できるようにすること、としています。取得にはGet Log Pageコマンドを使用します。
図3は、私がGithubで公開しているプログラム[3]で取得した、あるNVMe SSDのDevice Self-testログです。
図3:Get Log Pageコマンドを使用して取得したDevice Self-testのログ
このように、テストの結果や実行した時期(ただしドライブの体内時間的な時間に基づく記録)もログに記録されます。
まとめ
今回の記事では、前回紹介したNVMeドライブのDevice Self-testコマンドについて、具体的な実行方法やテスト内容、テスト結果の履歴を取得する方法を説明しました。
Device Self-testコマンドはオプション機能でかつテスト内容も製品に依存しますが、この「製品により異なる」ことをご自身の使いかたや健康状態の考えかたにより近い製品を選ぶために利用する、という活用方法も考えられます。
References
[1] NVM Express, "NVM Express Base Specification," Revision 1.4b, September 21, 2020
[2] linux-nvme / nvme-cli、2021年10月26日閲覧
[3] ken-yossy / nvmetool-win、2021年11月18日閲覧
ライセンス表記
この記事はクリエイティブ・コモンズ 表示 - 継承 4.0 国際 ライセンスの下に提供されています。