次の方法で共有


FN_VMB_PACKET_SEND_WITH_EXTERNAL_PFNS コールバック関数 (vmbuskernelmodeclientlibapi.h)

[一部の情報は、商用リリース前に大幅に変更される可能性があるプレリリース製品に関連しています。 Microsoft は、ここで提供される情報に関して明示的または黙示的な保証を行いません。

VmbPacketSendWithExternalPfns 関数は、パケット バッファーまたは外部データ内のデータをページ フレーム番号 (PFN) の配列として送信します。 この関数は、そのデータを VMBus パケット オブジェクトに関連付けます。これは、トランザクションの有効期間中のパケットを表します。

構文

FN_VMB_PACKET_SEND_WITH_EXTERNAL_PFNS FnVmbPacketSendWithExternalPfns;

NTSTATUS FnVmbPacketSendWithExternalPfns(
  __drv_aliasesMem VMBPACKET PacketObject,
  PVOID Buffer,
  UINT32 BufferLength,
  PPFN_NUMBER ExternalDataPfns,
  UINT32 PfnLength,
  UINT32 Flags
)
{...}

パラメーター

PacketObject

VMBus パケット オブジェクトへのハンドル。

Buffer

VMBus リング バッファーを介して送信されるコマンド パケットを含むバッファー。

BufferLength

Buffer パラメーター内のバッファーの長さ (バイト単位)。

ExternalDataPfns

パケットに関連付けられたデータ バッファーを記述するページ フレーム番号の配列。

PfnLength

ExternalDataPfns から送信PFN の数。 参照される最終的な配列インデックスは、ExternalDataPfns[PfnOffset+PfnLength-1] 含まれます。

Flags

フラグ。 関連するフラグを次に示します。

価値 意味
VMBUS_CHANNEL_FORMAT_FLAG_WAIT_FOR_COMPLETION
このパケットは完了と見なすことができず、そのリソースは、完了パケットが反対のエンドポイントから戻るまで解放できません。 このフラグは設定する必要があります。
VMBUS_CHANNEL_FORMAT_FLAG_PAGED_BUFFER
インライン バッファーはページングされ、それに応じて処理する必要があります。つまり、DPC レベルに入る前にコピーする必要があります。 ユーザー モード バッファーのプローブまたはアクセス違反の処理は、呼び出し元の責任です。

戻り値

操作が成功した場合はSTATUS_SUCCESSを返し、それ以外の場合は適切な NTSTATUS エラー コードを返します。

備考

この関数は、VmbPacketSend 関数とは異なり、PFN の配列 (実質的に物理アドレス) を渡すことができます。

大事な

この関数は、Vmbkmcl.sys バス ドライバーによって提供される VMBus カーネル モード クライアント ライブラリ (KMCL) インターフェイスを介して呼び出されます。 これは、KMCL_CLIENT_INTERFACE_V1 構造体からアクセスされるクライアント関数です。

詳細については、KMCL_CLIENT_INTERFACE_V1の「解説」セクションを参照してください。

必要条件

要件 価値
サポートされる最小クライアント Windows 10 バージョン 1803
ヘッダー vmbuskernelmodeclientlibapi.h

関連項目

VmbPacketSend する