Função CreateIpNetEntry2
A função CreateIpNetEntry2 cria uma nova entrada de endereço IP vizinho no computador local.
Sintaxe
NETIOAPI_API CreateIpNetEntry2(
_In_ const MIB_IPNET_ROW2 *Row
);
Parâmetros
- Linha [in]
Um ponteiro para uma entrada de estrutura MIB_IPNET_ROW2 para uma entrada de rota IP.
Retornar valor
CreateIpNetEntry2 retornará STATUS_SUCCESS se a função for bem-sucedida.
Se a função falhar, CreateIpNetEntry2 retornará um dos seguintes códigos de erro:
Código de retorno | Descrição |
---|---|
STATUS_INVALID_PARAMETER | Um parâmetro inválido foi passado para a função. Esse erro será retornado se ocorrer um dos seguintes itens:
|
STATUS_NOT_FOUND | Não foi possível encontrar a interface especificada. Esse erro será retornado se a função não puder localizar o adaptador de rede especificado pelo membro InterfaceLuid ou InterfaceIndex da estrutura MIB_IPNET_ROW2 para a qual o parâmetro Row aponta. |
STATUS_NOT_SUPPORTED | A solicitação não terá suporte. Esse erro será retornado se nenhuma pilha IPv4 estiver localizada no computador local e um endereço IPv4 tiver sido especificado no membro Address da estrutura MIB_IPNET_ROW2 que o parâmetro Row aponta ou se nenhuma pilha IPv6 estiver localizada no computador local e um endereço IPv6 tiver sido especificado no membro Address . |
ERROR_OBJECT_ALREADY_EXISTS | O objeto já existe. Esse erro será retornado se o membro Address da estrutura MIB_IPNET_ROW2 para a qual o parâmetro Row aponta for uma duplicata de um endereço IP vizinho existente na interface especificada pelo membro InterfaceLuid ou InterfaceIndex da estrutura MIB_IPNET_ROW2. |
Outros | Use a função FormatMessage para obter a cadeia de caracteres de mensagem para o erro retornado. |
Comentários
O driver deve inicializar os seguintes membros da estrutura MIB_IPNET_ROW2 para a qual o parâmetro Row aponta:
Defina o Membro do endereço como um endereço IPv4 ou IPv6 de IPv4 ou IPv6 válido.
Defina os membros PhysicalAddress e PhysicalAddressLength na estrutura MIB_IPNET_ROW2 como um endereço físico válido.
Defina InterfaceLuid ou InterfaceIndex como o LUID ou o valor de índice da interface.
Os membros InterfaceLuid e InterfaceIndex são usados na ordem listada anteriormente. Portanto, se InterfaceLuid for especificado, esse membro será usado para determinar a interface à qual adicionar o endereço IP unicast. Se nenhum valor tiver sido definido para o membro InterfaceLuid (o valor desse membro foi definido como zero), o membro InterfaceIndex será usado em seguida para determinar a interface.
A função CreateIpNetEntry2 falhará se o endereço IP passado no membro Address da estrutura MIB_IPNET_ROW2 para a qual o parâmetro Row aponta for uma duplicata de um endereço IP vizinho existente na interface.
Requisitos
Plataforma de destino |
Universal |
Versão |
Disponível no Windows Vista e versões posteriores dos sistemas operacionais Windows. |
Cabeçalho |
Netioapi.h (inclua Netioapi.h) |
Biblioteca |
Netio.lib |
IRQL |
< DISPATCH_LEVEL |