ExTimerCallback コールバック ルーチンは、EX_TIMER タイマー オブジェクトの時間間隔が経過した後に実行されます。
構文
EXT_CALLBACK ExtCallback;
VOID ExtCallback(
[in] PEX_TIMER Timer,
[in] PVOID Context
)
{...}
パラメーター
[in] Timer
EX_TIMER 構造体へのポインター。 この構造体は、以前に ExAllocateTimer ルーチンによって割り当てられたタイマー オブジェクトです。
[in] Context
ExAllocateTimer ルーチンの CallbackContext パラメーターとしてドライバーが以前に指定したコンテキスト値。
戻り値
何一つ
備考
オプションとして、ドライバーは、ExAllocateTimer ルーチンに渡す コールバック パラメーターで、ExTimerCallback ルーチンへのポインターを指定できます。 タイマーの有効期限が切れると、オペレーティング システムは ExTimerCallback ルーチンを呼び出します。
タイマー操作を開始するために、ドライバーは、ExSetTimer ルーチンに入力パラメーターとしてタイマー オブジェクトを渡します。 タイマーの有効期限が切れると、オペレーティング システムは実行する ExTimerCallback ルーチンをスケジュールします。
タイマー オブジェクトは待機可能なオブジェクトです。 ドライバー スレッドは、KeWaitForSingleObject や KeWaitForMultipleObjects などのルーチンを呼び出して、タイマーの有効期限が切れるのを待つことができます。 タイマーの有効期限が切れると、オペレーティング システムはタイマー オブジェクトに通知します。
タイマーの有効期限が切れる前に、タイマーが取り消される可能性があります。 ドライバーは、明示的にタイマーを取り消すために、ExCancelTimer ルーチンを呼び出すことができます。 このオブジェクトに対して以前に設定されたタイマーの有効期限が切れる前に、ドライバーが ExSetTimer ルーチンを呼び出してタイマー オブジェクトに対して新しいタイマーを開始した場合、この呼び出しは以前のタイマーを暗黙的に取り消し、新しいタイマーを開始します。
ExTimerCallback ルーチンは、ExSetTimer や ExDeleteTimer などのルーチンを呼び出すことができます。 ExTimerCallback ルーチンが ExDeleteTimer 呼び出す場合、この呼び出しで指定される Wait パラメーターは FALSE する必要があります。 詳細については、「System-Allocated Timer オブジェクトの削除」を参照してください。
マルチプロセッサ システムでは、2 つの異なるプロセッサで同時に実行される可能性がある定期的なタイマーの 2 つの連続する有効期限の ExTimerCallback コールバックを します。
詳細については、「ExXxxTimer ルーチンとEX_TIMER オブジェクト する」を参照してください。
例
ExTimerCallback コールバック ルーチンを定義するには、まず、定義するコールバック ルーチンの種類を識別する関数宣言を指定する必要があります。 Windows には、ドライバーのコールバック関数の種類のセットが用意されています。 コールバック関数の種類を使用して関数を宣言すると、ドライバー のコード分析、静的ドライバー検証ツール (SDV)、およびその他の検証ツールをすると、エラーが検出され、Windows オペレーティング システムのドライバーを記述するための要件になります。
たとえば、MyExTimerCallbackという名前の ExTimerCallback コールバック ルーチンを定義するには、次のコード例に示すように、EXT_CALLBACK関数型を使用します。
EXT_CALLBACK MyExTimerCallback;
次に、次のようにコールバック ルーチンを実装します。
_Use_decl_annotations_
VOID
MyExTimerCallback(
PEX_TIMER Timer,
PVOID Context
)
{...}
EXT_CALLBACK関数の種類は、Wdm.h ヘッダー ファイルで定義されています。 コード分析ツールの実行時にエラーをより正確に識別するには、_Use_decl_annotations_ 注釈を関数定義に追加してください。
_Use_decl_annotations_ 注釈により、ヘッダー ファイル内のEXT_CALLBACK関数型に適用される注釈が確実に使用されます。 関数宣言の要件の詳細については、「WDM ドライバー の関数ロール型を使用して関数を宣言するを参照してください。
_Use_decl_annotations_の詳細については、「関数の動作に注釈を付ける」を参照してください。
必要条件
| 要件 | 価値 |
|---|---|
| サポートされる最小クライアント | Windows 8.1 以降で使用できます。 |
| ターゲット プラットフォーム の | デスクトップ |
| ヘッダー | wdm.h (Wdm.h、Ntddk.h、Ntifs.h を含む) |
| IRQL | DISPATCH_LEVELで呼び出されます。 |
関連項目
ExAllocateTimer の
ExCancelTimer を する
ExSetTimer の
KeWaitForMultipleObjects の
KeWaitForSingleObject を する