다음을 통해 공유


EVT_WDF_IO_QUEUE_IO_CANCELED_ON_QUEUE 콜백 함수(wdfio.h)

[KMDF 및 UMDF에 적용]

드라이버의 EvtIoCanceledOnQueue 이벤트 콜백 함수는 I/O 큐에서 프레임워크가 제거된 I/O 요청을 완료해야 한다는 것을 드라이버에 알릴 수 있습니다.

구문론

EVT_WDF_IO_QUEUE_IO_CANCELED_ON_QUEUE EvtWdfIoQueueIoCanceledOnQueue;

void EvtWdfIoQueueIoCanceledOnQueue(
  [in] WDFQUEUE Queue,
  [in] WDFREQUEST Request
)
{...}

매개 변수

[in] Queue

I/O 큐 개체에 대한 핸들입니다.

[in] Request

요청 개체에 대한 핸들입니다.

반환 값

없음

비고

드라이버는 WdfIoQueueCreate 메서드를 호출할 때 EvtIoCanceledOnQueue 콜백 함수를 등록합니다. WdfIoQueueCreate호출하는 방법에 대한 자세한 내용은 I/O 큐 만들기참조하세요.

드라이버가 I/O 큐에 대한 EvtIoCanceledOnQueue 콜백 함수를 등록하는 경우 프레임워크는 다음과 같은 상황에서 콜백 함수를 호출합니다.

프레임워크가 EvtIoCanceledOnQueue 콜백 함수를 호출한 후 드라이버 요청 개체를 소유하고 EvtIoCanceledOnQueue 이상에서 적절한 상태 코드로 요청을 완료해야. 프레임워크가 EvtIoCanceledOnQueue호출하는 경우 요청은 여전히 I/O 큐와 연결되지만 드라이버는 요청을 다시 큐에 추가할 수 없습니다. 드라이버가 EvtIoCanceledOnQueue요청을 완료하지 않은 경우에도 요청 소유권은 드라이버와 함께 유지됩니다. EvtIoCanceledOnQueue 반환된 후 드라이버가 요청을 완료하는 경우 WdfIoQueueFindRequest 호출할 수 없으며, 드라이버에 요청 소유권이 이미 있으므로 WdfIoQueueRetrieveFoundRequest 요청 소유권을 다시 가져올 수 없습니다.

일반적으로 EvtIoCanceledOnQueue 드라이버 완료 상태가 STATUS_CANCELLED I/O 요청 완료합니다.

경우에 따라 드라이버가 정보를 기다리기 위해 I/O 요청을 수동 큐에 다시 큐에 추가했을 수 있습니다. 예를 들어 요청 처리기 중 하나에서 드라이버는 보류 중인 DMA 트랜잭션과 연결된 I/O 요청을 수동 큐에 배치할 수 있습니다. 이 경우 드라이버는 EvtIoCanceledOnQueue 콜백에서 DMA 트랜잭션 취소하려고 시도합니다. 취소 작업의 결과에 따라 드라이버는 EvtIoCanceledOnQueue 이상에서 적절한 상태로 요청을 완료합니다.

프레임워크는 프레임워크가 드라이버에 전달한 적이 없는 I/O 요청에 대해 드라이버의 EvtIoCanceledOnQueue 콜백 함수를 호출하지 않습니다.

프레임워크는 드라이버가 I/O 큐에 대해 설정한 디스패치 메서드에 관계없이 I/O 요청이 취소되었음을 확인하는 즉시 EvtIoCanceledOnQueue 콜백 함수를 호출합니다. 따라서 프레임워크는 EvtIoCanceledOnQueue 콜백 함수를 호출할 수 있습니다.

  • 드라이버가 현재 큐에서 다른 요청을 소유하는 경우에도 순차적 디스패치사용하는 큐의 요청입니다.
  • 드라이버가 현재 최대 요청 수를 소유하고 있더라도 드라이버가 numberOfPresentedRequests 설정한 큐의 요청입니다.
EvtIoCanceledOnQueue 콜백 함수에 대한 자세한 내용은 I/O 요청 취소참조하세요.

디바이스 또는 드라이버 WDF_OBJECT_ATTRIBUTES 구조의 ExecutionLevel 멤버가 WdfExecutionLevelPassive 설정되지 않는 한 EvtIoCanceledOnQueue 콜백 함수는 IRQL <= DISPATCH_LEVEL 호출할 수 있습니다.

IRQL이 PASSIVE_LEVEL 경우 프레임워크는 중요한 지역내에서 콜백 함수를 호출합니다.

예시

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

EvtIoCanceledOnQueue 콜백 함수를 정의하려면 먼저 SDV 및 기타 확인 도구에 필요한 함수 선언을 제공해야 합니다. 다음 예제는 PCMCIA 스마트 카드 드라이버 샘플에서 가져온 것입니다.

EVT_WDF_IO_QUEUE_IO_CANCELED_ON_QUEUE PscrEvtIoCanceledOnQueue;

PCMCIA 스마트 카드 드라이버 샘플에서 드라이버는 수동 큐를 사용하여 보류 중인 스마트 카드 알림 요청을 저장합니다. 드라이버는 드라이버가 알림 필드를 지우고 요청을 완료하는 EvtIoCanceledOnQueue 콜백 함수를 제공합니다.

_Use_decl_annotations_
VOID
PscrEvtIoCanceledOnQueue(
    WDFQUEUE  Queue,
    WDFREQUEST  Request
    )

{
    PDEVICE_EXTENSION DeviceExtension;
    PSMARTCARD_EXTENSION smartcardExtension;

    DeviceExtension = GetDeviceExtension(WdfIoQueueGetDevice(Queue));
    smartcardExtension = (PSMARTCARD_EXTENSION) &DeviceExtension->SmartcardExtension;

    //KdPrint(("Cancelled on queue 0x%x\n", WdfRequestWdmGetIrp(Request)));

    InterlockedExchangePointer(
                             &(smartcardExtension->OsData->NotificationIrp),
                             NULL
                             );

    WdfRequestComplete(Request, STATUS_CANCELLED);
}

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

요구 사항

요구 사항 가치
대상 플랫폼 보편적
최소 KMDF 버전 1.0
최소 UMDF 버전 2.0
헤더 wdfio.h(Wdf.h 포함)
IRQL <= DISPATCH_LEVEL(주의 섹션 참조)

참고하십시오

WdfIoQueueCreate

WdfRequestForwardToIoQueue