IWDFInterrupt::SetPolicy メソッド (wudfddi.h)

[警告: UMDF 2 は UMDF の最新バージョンであり、UMDF 1 よりも優先されます。 すべての新しい UMDF ドライバーは、UMDF 2 を使用して記述する必要があります。 UMDF 1 には新機能が追加されておらず、新しいバージョンのWindows 10では UMDF 1 のサポートが制限されています。 ユニバーサル Windows ドライバーでは、UMDF 2 を使用する必要があります。 詳細については、「UMDF を使用したはじめに」を参照してください。

SetPolicy メソッドは、指定された割り込みの割り込み優先度、プロセッサ アフィニティ、およびアフィニティ ポリシーを指定します。

構文

void SetPolicy(
  [in] WDF_INTERRUPT_POLICY   Policy,
  [in] WDF_INTERRUPT_PRIORITY Priority,
  [in] KAFFINITY              TargetProcessorSet
);

パラメーター

[in] Policy

割り込みのプロセッサ アフィニティ ポリシーを指定する、 WDF_INTERRUPT_POLICY型の列挙子。

[in] Priority

割り込みの優先度を指定する WDF_INTERRUPT_PRIORITY型指定列挙子。

[in] TargetProcessorSet

Policy パラメーターが WdfIrqPolicySpecifiedProcessors に設定されている場合に、割り込みのプロセッサ アフィニティを指定する KAFFINITY 型の値。

戻り値

なし

解説

Windows Vista 以降、ドライバーは割り込みの優先度、プロセッサ アフィニティ、アフィニティ ポリシーを指定できます。 レジストリを使用して SetPolicy が 設定する値をオーバーライドする方法の詳細については、「 割り込みアフィニティと優先度」を参照してください。

ドライバーが Windows Vista より前のバージョンのオペレーティング システムで実行されている場合、フレームワークは、 SetPolicy を呼び出すときにドライバーが指定する値を無視します。

割り込みの優先度、プロセッサ アフィニティ、アフィニティ ポリシーを指定するレジストリ値と INF セクションの詳細については、「 割り込みアフィニティと優先度」を参照してください。

ドライバーが SetPolicy を呼び出す場合は、IWDFDevice3::CreateInterrupt メソッドを呼び出した後、IDriverEntry::OnDeviceAdd コールバック関数で呼び出す必要があります。

UMDF ドライバーでの割り込みの処理の詳細については、「 ハードウェアへのアクセス」および「割り込みの処理」を参照してください。

次のコード例では、通常の優先順位で、プロセッサ 0 にデバイス割り込みを割り当てます。

#define AFFINITY_MASK(n) ((ULONG_PTR)1 << (n))

pIWdfInterrupt->SetPolicy(
                          WdfIrqPolicySpecifiedProcessors,
                          WdfIrqPriorityNormal,
                          AFFINITY_MASK(0)
                          );

要件

要件
サポート終了 UMDF 2.0 以降では使用できません。
対象プラットフォーム デスクトップ
最小 UMDF バージョン 1.11
Header wudfddi.h
[DLL] WUDFx.dll

こちらもご覧ください

IWDFInterrupt

KAFFINITY

WDF_INTERRUPT_POLICY

WDF_INTERRUPT_PRIORITY