Funzione FwpsInjectNetworkSendAsync0 (fwpsk.h)
La funzione FwpsInjectNetworkSendAsync0 inserisce i dati dei pacchetti nel percorso dei dati di invio.
Sintassi
NTSTATUS FwpsInjectNetworkSendAsync0(
[in] HANDLE injectionHandle,
[in, optional] HANDLE injectionContext,
[in] UINT32 flags,
[in] COMPARTMENT_ID compartmentId,
[in, out] NET_BUFFER_LIST *netBufferList,
[in] FWPS_INJECT_COMPLETE0 completionFn,
[in, optional] HANDLE completionContext
);
Parametri
[in] injectionHandle
Handle di inserimento creato in precedenza da una chiamata alla funzione FwpsChangectionHandleCreate0 con il parametro flag impostato su FWPS_INJECTION_TYPE_NETWORK.
[in, optional] injectionContext
Handle facoltativo nel contesto di inserimento. Se specificato, può essere ottenuto chiamando la funzione FwpsQueryPacketChangectionState0 quando lo stato di inserimento dei pacchetti FWPS_PACKET_INJECTION_STATE è FWPS_PACKET_INJECTED_BY_SELF o FWPS_PACKET_PREVIOUSLY_INJECTED_BY_SELF.
[in] flags
Riservato. I driver di callout devono impostare questo parametro su zero.
[in] compartmentId
Identificatore del raggruppamento di routing in cui vengono inseriti i dati del pacchetto, specificati come tipo di COMPARTMENT_ID . Questo identificatore viene fornito a un callout tramite il membro compartmentId del FWPS_INCOMING_METADATA_VALUES0 struttura passata alla funzione di callout del driver di classificazioneFn . Se il membro compartmentId è disponibile per i callout, FWPS_METADATA_FIELD_COMPARTMENT_ID verrà impostato nel membro currentMetadataValues . In caso contrario, impostare questo parametro su UNSPECIFIED_COMPARTMENT_ID.
[in, out] netBufferList
Puntatore a una struttura NET_BUFFER_LIST che descrive i dati dei pacchetti inseriti. Un driver di callout alloca una struttura NET_BUFFER_LIST da usare per inserire i dati dei pacchetti chiamando la funzione FwpsAllocateCloneNetBufferList0 o la funzione FwpsAllocateNetBufferAndNetBufferList0 . La struttura NET_BUFFER_LIST deve iniziare con un'intestazione IP.
[in] completionFn
Puntatore a una funzione callout di completamentoFn fornita dal driver di callout. Il motore di filtro chiama questa funzione dopo i dati del pacchetto, descritti dal parametro NetBufferList , è stato inserito nello stack di rete.
[in, optional] completionContext
Puntatore a un contesto fornito dal driver di callout passato alla funzione callout a cui fa riferimento il parametro completamentoFn . Questo parametro è facoltativo e può essere NULL.
Valore restituito
La funzione FwpsInjectNetworkSendAsync0 restituisce uno dei codici NTSTATUS seguenti.
Codice restituito | Descrizione |
---|---|
|
L'inserimento dei dati dei pacchetti è stato avviato correttamente. Il motore di filtro chiamerà la funzione di completamento dopo che il motore di filtro ha completato l'inserimento dei dati del pacchetto nello stack di rete o quando si è verificato un errore successivamente. In caso di errore, il membro Stato della struttura di NET_BUFFER_LIST completata indicherà il motivo dell'errore. |
|
Lo stack di rete TCP/IP non è pronto per accettare l'inserimento dei dati dei pacchetti. |
|
L'handle di inserimento viene chiuso. |
|
L'handle di inserimento non è stato creato con il parametro Flags dell'oggetto FwpsSignectionHandleCreate0 funzione impostata su FWPS_INJECTION_TYPE_NETWORK. |
|
Si è verificato un errore. |
Commenti
Un driver callout chiama la funzione FwpsInjectNetworkSendAsync0 per inserire i dati del pacchetto di rete nel percorso dei dati di invio. Questa funzione può essere eseguita in modo asincrono. I driver di callout in genere inseriscono i dati nello stack di rete durante la modifica dei dati dei pacchetti. Per altre informazioni sul modo in cui un driver di callout può modificare i dati dei pacchetti, vedere Callout Driver Operations.For more information about how a callout driver driver can modify packet data, see Callout Driver Operations.
Se il valore restituito non è STATUS_SUCCESS, la funzione di completamento non verrà chiamata. In questo caso, l'elenco di buffer net puntato a netBufferList deve essere liberato da una chiamata a FwpsFreeNetBufferList0 o Funzioni FwpsFreeCloneNetBufferList0 .
Il pacchetto inserito può essere indicato di nuovo al driver di callout. Per evitare il ciclo infinito, il driver deve prima chiamare il La funzione FwpsQueryPacketChangectionState0 prima di procedere con una chiamata alla funzione di callout di classificazioneFn e il driver deve consentire pacchetti con lo stato di inserimento FWPS_PACKET_INJECTION_STATE impostato su FWPS_PACKET_INJECTED_BY_SELF o FWPS_PACKET_PREVIOUSLY_INJECTED_BY_SELF.
Requisiti
Requisito | Valore |
---|---|
Client minimo supportato | Disponibile a partire da Windows Vista. |
Piattaforma di destinazione | Universale |
Intestazione | fwpsk.h (includere Fwpsk.h) |
Libreria | Fwpkclnt.lib |
IRQL | <= DISPATCH_LEVEL |