FltDeleteVolumeContext, fonction (fltkernel.h)
FltDeleteVolumeContext supprime un contexte défini par un pilote minifilter donné pour un volume donné et marque le contexte de suppression.
Syntaxe
NTSTATUS FLTAPI FltDeleteVolumeContext(
[in] PFLT_FILTER Filter,
[in] PFLT_VOLUME Volume,
[out, optional] PFLT_CONTEXT *OldContext
);
Paramètres
[in] Filter
Pointeur de filtre opaque pour l’appelant.
[in] Volume
Pointeur de volume opaque pour le volume.
[out, optional] OldContext
Pointeur vers une variable allouée par l’appelant qui reçoit l’adresse du contexte supprimé. Ce paramètre est facultatif et peut être NULL. Si OldContext n’est pas NULL et ne pointe pas vers NULL_CONTEXT, l’appelant est chargé d’appeler FltReleaseContext pour libérer ce contexte lorsqu’il n’est plus nécessaire.
Valeur de retour
FltDeleteVolumeContext retourne STATUS_SUCCESS ou une valeur NTSTATUS appropriée, comme l’une des valeurs suivantes :
Retourner le code | Description |
---|---|
STATUS_FLT_DELETING_OBJECT | Le volume spécifié est détruit. Il s’agit d’un code d’erreur. |
STATUS_NOT_FOUND | Aucun contexte correspondant n’a été trouvé. Il s’agit d’un code d’erreur. |
Remarques
Pour plus d’informations sur les contextes, consultez À propos des contextes minifilter.
Étant donné que les contextes sont comptabilisés par référence, il n’est généralement pas nécessaire qu’un pilote minifilter appelle une routine telle que FltDeleteVolumeContext pour supprimer explicitement un contexte.
Un pilote minifilter appelle FltDeleteVolumeContext pour supprimer un contexte d’un volume et marquer le contexte à supprimer. Le contexte est généralement libéré immédiatement, sauf s’il existe une référence en attente sur celle-ci (par exemple, parce que le contexte est toujours utilisé par un autre thread).
Pour allouer un nouveau contexte, appelez FltAllocateContext.
Pour obtenir un contexte de volume, appelez FltGetVolumeContext.
Pour définir un contexte de volume, appelez FltSetVolumeContext.
Exigences
Exigence | Valeur |
---|---|
plateforme cible | Universel |
d’en-tête | fltkernel.h (include Fltkernel.h) |
bibliothèque | FltMgr.lib |
IRQL | <= APC_LEVEL |