KdPrintEx マクロ (wdm.h)
KdPrintEx マクロは、指定した条件が満たされた場合にカーネル デバッガーに文字列を送信します。
KdPrintEx の呼び出しには、二重かっこが必要です。
構文
void KdPrintEx(
_x_
);
パラメーター
_x_
printf のように、書式指定文字列の引数を指定します。
戻り値
なし
解説
KdPrintEx は、デバッグ構成用にコンパイルされるコード内の DbgPrintEx ルーチンと同じです。 このルーチンは、リリース ビルド用にコンパイルされるコードには影響しません。 KdPrintEx ルーチンを呼び出すことができるのは、カーネル モード ドライバーだけです。
Windows Driver Kit (WDK) 8 および WDK 7 は、デバッグ (チェック) ビルドとリリース (無料) ビルドに適した DBG プリプロセッサ定数定義を管理します。 詳細については、「 条件付きコンパイルとビルド環境」を参照してください。
KdPrintEx は、指定された文字列をカーネル デバッガーに渡すか、 ComponentId、 Level、および対応するコンポーネント フィルター マスクの値に応じてまったく何も行いません。 詳細については、「 デバッグ メッセージの読み取りとフィルター処理」を参照してください。
絶対に必要でない限り、ユーザー入力または別のプロセスから文字列を取得して KdPrintEx に渡さないでください。 作成しなかった文字列を使用する場合は、これが有効な書式指定文字列であること、および書式コードが型と数量の引数リストと一致することを確認する必要があります。 最適なコーディング方法は、すべての 書式指定 文字列を静的にし、コンパイル時に定義することです。
Format 文字列のサイズや引数の数に上限はありません。 ただし、 KdPrintEx を 1 回呼び出すと、512 バイトの情報のみが送信されます。 DbgPrint バッファーのサイズにも制限があります。 詳細については、「 DbgPrint バッファーとデバッガー 」を参照してください。
このルーチンは ntddk.h および ndis.h で定義されています。コンポーネント フィルター ID は、dpfilter.h、ndis.h、wdm.h で定義されます。 ntddk.h または ndis.h を含めます。
引数は次のとおりです。
ComponentId [in]
このルーチンを呼び出すコンポーネントを指定します。 これは、dpfilter.h ヘッダー ファイルで定義されているコンポーネント名フィルター ID のいずれかである必要があります。 ドライバーの出力と Windows コンポーネントの出力が混在しないようにするには、 ComponentId に次の値のみを使用する必要があります。
DPFLTR_IHVVIDEO_ID
DPFLTR_IHVAUDIO_ID
DPFLTR_IHVNETWORK_ID
DPFLTR_IHVSTREAMING_ID
DPFLTR_IHVBUS_ID
DPFLTR_IHVDRIVER_ID
書式 [入力]
印刷する書式指定文字列へのポインターを指定します。 書式指定文字列は、ほとんどの printf スタイルの書式指定フィールドをサポートします。 ただし、Unicode 形式コード (%C、 %S、 %lc、 %ls、 %wc、 %ws、 および %wZ) は、IRQL = PASSIVE_LEVELでのみ使用できます。 KdPrintEx ルーチンは、浮動小数点型 (%f、%e、%E、%g、%G、%a、または %A) をサポートしていません。
レベル [入力]
このメッセージの重大度を指定します。 任意の 32 ビット整数を指定できます。 0 ~ 31 (含む) の値は、32 ~ 0xFFFFFFFFの値とは異なる方法で処理されます。 詳細については、「 デバッグ メッセージの読み取りとフィルター処理」を参照してください。
要件
要件 | 値 |
---|---|
サポートされている最小のクライアント | Microsoft Windows XP 以降で使用できます。 |
対象プラットフォーム | デスクトップ |
Header | wdm.h (Wdm.h を含む) |
Library | NtosKrnl.lib (DbgPrintEx を参照)。 |
[DLL] | NtosKrnl.exe |
こちらもご覧ください
フィードバック
https://aka.ms/ContentUserFeedback」を参照してください。
以下は間もなく提供いたします。2024 年を通じて、コンテンツのフィードバック メカニズムとして GitHub の issue を段階的に廃止し、新しいフィードバック システムに置き換えます。 詳細については、「フィードバックの送信と表示