SetIpNetEntry2 関数

SetIpNetEntry2 関数は、ローカル コンピューター上の既存の近隣 IP アドレス エントリの物理アドレスを設定します。

構文

NETIOAPI_API SetIpNetEntry2(
  _In_ PMIB_IPNET_ROW2 Row
);

パラメーター

  • Row [in]
    近接 IP アドレス エントリの MIB_IPNET_ROW2 構造体エントリへのポインター。

戻り値

関数が成功した場合、SetIpNetEntry2 は STATUS_SUCCESS を返します。

関数が失敗した場合、SetIpNetEntry2 は次のいずれかのエラー コードを返します:

リターン コード 説明
STATUS_INVALID_PARAMETER

その関数に無効なパラメーターが渡された。 このエラーは次の状況で返されます。

  • Row パラメーターで NULL ポインターが渡された。

  • Row パラメーターが指す MIB_IPNET_ROW2 構造体の Address メンバーが、有効なユニキャスト、エニーキャスト、またはマルチキャスト IPv4 または IPv6 アドレスに設定されなかった。

  • MIB_IPNET_ROW2 構造体の PhysicalAddress メンバーと PhysicalAddressLength メンバーが、有効な物理アドレスに設定されなかった。

  • MIB_IPFORWARD_ROW2 構造体の InterfaceLuid メンバーと InterfaceIndex メンバーの両方が指定されていなかった。

  • ループバック アドレスが Address メンバーで渡された。

STATUS_NOT_FOUND

指定されたインターフェイスが見つかりませんでした。 このエラーは、Row パラメーターが指す MIB_IPNET_ROW2 構造体の InterfaceLuid メンバーまたは InterfaceIndex メンバーで指定されるネットワーク インターフェイスを関数が見つけられない場合に返されます。

STATUS_NOT_SUPPORTED

要求はサポートされていません。 このエラーは、ローカル コンピューターに IPv4 スタックが存在せず、Row パラメーターが指す MIB_IPNET_ROW2 構造体の Address メンバーに IPv4 アドレスが指定されていた場合、またはローカル コンピュータに IPv6 スタックが存在せず、Address メンバーに IPv6 アドレスが指定されていた場合に返されます。

その他

FormatMessage 関数を使用して、返されたエラーのメッセージ文字列を取得します。

解説

ドライバーは、Row パラメーターが指す MIB_IPNET_ROW2 構造体の次のメンバーを初期化する必要があります。

  • 住所
    有効なユニキャスト、エニーキャスト、またはマルチキャスト IPv4 または IPv6 アドレスとファミリに設定します。

  • PhysicalAddressPhysicalAddressLength
    有効な物理アドレスに設定します。

  • InterfaceLuid または InterfaceIndex
    これらのメンバーは、前に示した順序で使用されます。 したがって、InterfaceLuid が指定されている場合は、このメンバーを使用してインターフェイスが決定されます。 InterfaceLuid メンバーに値が設定されていない (このメンバーの値がゼロに設定されている) 場合は、InterfaceIndex メンバーが次にインターフェイスを決定するために使用されます。

SetIpNetEntry2 関数は、Row パラメーターが指す MIB_IPNET_ROW2 構造体の Address メンバーで渡される IP アドレスが、指定されたインターフェイス上の既存の近隣 IP アドレスでない場合に失敗します。

要件

対象プラットフォーム

ユニバーサル

バージョン

Windows Vista 以降のバージョンの Windows オペレーティング システムで使用できます。

ヘッダー

Netioapi.h (Netioapi.h を含む)

ライブラリ

Netio.lib

IRQL

< DISPATCH_LEVEL

関連項目

CreateIpNetEntry2

DeleteIpNetEntry2

FlushIpNetTable2

GetIpNetEntry2

GetIpNetTable2

MIB_IPNET_ROW2

MIB_IPNET_TABLE2

ResolveIpNetEntry2