DRIVER_CANCEL 콜백 함수(wdm.h)

취소 루틴은 I/O 작업을 취소합니다.

구문

DRIVER_CANCEL DriverCancel;

void DriverCancel(
  [in, out] _DEVICE_OBJECT *DeviceObject,
  [in, out] _IRP *Irp
)
{...}

매개 변수

[in, out] DeviceObject

DEVICE_OBJECT 구조체에 대한 호출자 제공 포인터입니다. 이는 이전에 드라이버의 AddDevice 루틴에서 만든 대상 디바이스의 디바이스 개체입니다.

[in, out] Irp

취소할 I/O 작업을 설명하는 IRP 구조체에 대한 호출자 제공 포인터입니다.

반환 값

없음

설명

드라이버 또는 다른 시스템 구성 요소가 IoCancelIrp를 호출하면 IRP에 대해 등록된 경우 I/O 관리자는 IRP의 취소 루틴을 호출합니다.

IRP에 대한 Cancel 루틴을 등록하기 위해 드라이버는 다음 두 가지 방법 중 하나를 사용할 수 있습니다.

  1. StartIo 루틴을 제공하고 I/O 관리자 제공 디바이스 큐를 사용하는 드라이버는 IoStartPacket을 호출할 때 취소 루틴을 지정할 수 있습니다.

  2. 추가 디바이스 큐를 만들고 관리하는 드라이버는 IoSetCancelRoutine을 호출하여 취소 루틴을 등록할 수 있습니다.

한 번에 하나의 취소 루틴만 IRP에 등록할 수 있습니다.

I/O 관리자는 드라이버의 취소 루틴을 호출하기 전에 IoAcquireCancelSpinLock을 호출하므로 Cancel 루틴은 특정 시점에 IoReleaseCancelSpinLock을 호출해야 합니다. 루틴은 스핀 잠금을 필요 이상으로 길게 유지해서는 안 됩니다.

취소 루틴은 IRQL을 호출자가 제공한 값으로 변경하는 IoReleaseCancelSpinLock을 호출할 때까지 IRQL = DISPATCH_LEVEL 임의 스레드 컨텍스트에서 실행됩니다. 드라이버는 이 값에 대해 Irp-CancelIrql>을 지정해야 합니다.

Cancel 루틴은 I/O 상태 블록의 Status 멤버를 STATUS_CANCELLED 설정하고 해당 정보 멤버를 0으로 설정해야 합니다. 그런 다음 루틴은 IoCompleteRequest를 호출하여 지정된 IRP를 완료해야 합니다.

드라이버의 취소 루틴을 구현하는 방법에 대한 자세한 내용은 IRP 취소를 참조하세요.

예제

콜백 취소 루틴을 정의하려면 먼저 정의할 콜백 루틴의 유형을 식별하는 함수 선언을 제공해야 합니다. Windows는 드라이버에 대한 콜백 함수 형식 집합을 제공합니다. 콜백 함수 형식을 사용하여 함수를 선언하면 드라이버에 대한 코드 분석, SDV( 정적 드라이버 검증 도구 ) 및 기타 확인 도구에서 오류를 찾는 데 도움이 되며 Windows 운영 체제용 드라이버를 작성하기 위한 요구 사항입니다.

예를 들어 라는 MyCancel콜백 취소 루틴을 정의하려면 이 코드 예제와 같이 DRIVER_CANCEL 형식을 사용합니다.

DRIVER_CANCEL MyCancel;

그런 다음 다음과 같이 콜백 루틴을 구현합니다.

_Use_decl_annotations_
VOID
  MyCancel(
    struct _DEVICE_OBJECT  *DeviceObject,
    struct _IRP  *Irp
    )
  {
      // Function body
  }

DRIVER_CANCEL 함수 형식은 Wdm.h 헤더 파일에 정의되어 있습니다. 코드 분석 도구를 실행할 때 오류를 보다 정확하게 식별하려면 함수 정의에 _Use_decl_annotations_ 주석을 추가해야 합니다. 주석을 _Use_decl_annotations_ 사용하면 헤더 파일의 DRIVER_CANCEL 함수 형식에 적용되는 주석이 사용됩니다. 함수 선언에 대한 요구 사항에 대한 자세한 내용은 WDM 드라이버에 함수 역할 형식을 사용하여 함수 선언을 참조하세요. 에 대한 _Use_decl_annotations_자세한 내용은 함수 동작 주석 지정을 참조하세요.

요구 사항

요구 사항
대상 플랫폼 데스크톱
헤더 wdm.h(Wdm.h, Ntddk.h, Ntifs.h 포함)
IRQL DISPATCH_LEVEL 호출됩니다(설명 섹션 참조).