다음을 통해 공유


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호출하는 경우 I/O 관리자는 IRP에 등록된 경우 IRP의 취소 루틴을 호출합니다.

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

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

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

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

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

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

취소 루틴은 I/O 상태 블록의 상태 멤버를 STATUS_CANCELLED 설정하고 Information 멤버를 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 호출됩니다(주의 섹션 참조).