WdfUsbTargetDeviceSendControlTransferSynchronously 함수(wdfusb.h)

[KMDF 및 UMDF에 적용]

WdfUsbTargetDeviceSendControlTransferSynchronously 메서드는 USB 제어 전송 요청을 빌드하고 I/O 대상에 동기적으로 보냅니다.

구문

NTSTATUS WdfUsbTargetDeviceSendControlTransferSynchronously(
  [in]            WDFUSBDEVICE                  UsbDevice,
  [in, optional]  WDFREQUEST                    Request,
  [in, optional]  PWDF_REQUEST_SEND_OPTIONS     RequestOptions,
  [in]            PWDF_USB_CONTROL_SETUP_PACKET SetupPacket,
  [in, optional]  PWDF_MEMORY_DESCRIPTOR        MemoryDescriptor,
  [out, optional] PULONG                        BytesTransferred
);

매개 변수

[in] UsbDevice

WdfUsbTargetDeviceCreateWithParameters에 대한 이전 호출에서 가져온 USB 디바이스 개체에 대한 핸들입니다.

[in, optional] Request

프레임워크 요청 개체에 대한 핸들입니다. 이 매개 변수는 선택 사항이며 NULL일 수 있습니다. 자세한 내용은 아래 설명 부분을 참조하십시오.

[in, optional] RequestOptions

요청에 대한 옵션을 지정하는 호출자가 할당한 WDF_REQUEST_SEND_OPTIONS 구조체에 대한 포인터입니다. 이 포인터는 선택 사항이며 NULL일 수 있습니다. 자세한 내용은 아래 설명 부분을 참조하십시오.

[in] SetupPacket

컨트롤 전송을 설명하는 호출자가 할당한 WDF_USB_CONTROL_SETUP_PACKET 구조체에 대한 포인터입니다.

[in, optional] MemoryDescriptor

디바이스별 명령에 따라 입력 또는 출력 버퍼를 설명하는 호출자가 할당한 WDF_MEMORY_DESCRIPTOR 구조체에 대한 포인터입니다. 이 포인터는 선택 사항이며 NULL일 수 있습니다. 자세한 내용은 아래 설명 부분을 참조하십시오.

[out, optional] BytesTransferred

전송되는 바이트 수를 받는 위치에 대한 포인터입니다. 이 매개 변수는 선택 사항이며 NULL일 수 있습니다.

반환 값

작업이 성공하면 WdfUsbTargetDeviceSendControlTransferSynchronously I/O 대상의 완료 상태 값을 반환합니다. 그렇지 않으면 이 메서드는 다음 값 중 하나를 반환할 수 있습니다.

반환 코드 설명
STATUS_INVALID_PARAMETER
잘못된 매개 변수가 감지되었습니다.
STATUS_INSUFFICIENT_RESOURCES
메모리가 부족했습니다.
STATUS_INVALID_DEVICE_REQUEST
잘못된 메모리 설명자가 지정되었거나 지정된 I/O 요청이 이미 I/O 대상에 큐에 대기 중입니다.
STATUS_IO_TIMEOUT
드라이버에서 제한 시간 값을 제공했으며 할당된 시간 내에 요청이 완료되지 않았습니다.
 

이 메서드는 다른 NTSTATUS 값을 반환할 수도 있습니다.

드라이버에서 잘못된 개체 핸들을 제공하는 경우 버그 검사가 발생합니다.

설명

WdfUsbTargetDeviceSendControlTransferSynchronously 메서드를 사용하여 USB 제어 전송 요청을 동기적으로 보냅니다. 이러한 요청을 비동기적으로 보내려면 WdfUsbTargetDeviceFormatRequestForControlTransferWdfRequestSend를 사용합니다.

드라이버가 RequestOptions 매개 변수가 가리키는 WDF_REQUEST_SEND_OPTIONS 구조에서 시간 제한 값을 제공하지 않거나 오류가 검색되지 않는 한 WdfUsbTargetDeviceSendControlTransferSynchronously 메서드는 요청이 완료될 때까지 반환되지 않습니다.

드라이버가 I/O 큐에서 받은 I/O 요청을 전달하거나 새 요청을 만들고 보낼 수 있습니다. 두 경우 모두 프레임워크에는 요청 개체가 필요하며 제어 전송 유형에 따라 일부 버퍼 공간이 필요할 수 있습니다.

드라이버가 I/O 큐에서 받은 I/O 요청을 전달하려면 다음을 수행합니다.

  1. Request 매개 변수에 대해 수신된 요청 의 핸들을 지정합니다.
  2. MemoryDescriptor 매개 변수에 대해 수신된 요청의 입력 또는 출력 버퍼를 사용합니다.

    드라이버는 WdfRequestRetrieveInputMemory 또는 WdfRequestRetrieveOutputMemory를 호출하여 요청의 입력 또는 출력 버퍼를 나타내는 프레임워크 메모리 개체에 대한 핸들을 가져온 다음, 드라이버가 MemoryDescriptor 매개 변수에 대해 제공하는 WDF_MEMORY_DESCRIPTOR 구조에 해당 핸들을 배치할 수 있습니다.

새 요청을 만들고 보내려면 다음을 수행합니다.
  1. Request 매개 변수에 NULL 요청 핸들을 제공하거나 새 요청 개체를 만들고 해당 핸들을 제공합니다.
    • NULL 요청 핸들을 제공하는 경우 프레임워크는 내부 요청 개체를 사용합니다. 이 기술은 사용하기는 간단하지만 드라이버는 요청을 취소할 수 없습니다.
    • WdfRequestCreate를 호출하여 하나 이상의 요청 개체를 만드는 경우 WdfRequestReuse를 호출하여 이러한 요청 개체를 다시 사용할 수 있습니다. 이 기술을 사용하면 드라이버의 EvtDriverDeviceAdd 콜백 함수가 디바이스에 대한 요청 개체를 미리 할당할 수 있습니다. 또한 필요한 경우 다른 드라이버 스레드 가 WdfRequestCancelSentRequest 를 호출하여 요청을 취소할 수 있습니다.

    드라이버가 NULL이 아닌 요청 매개 변수를 제공하는지 또는 NULL 요청 매개 변수를 제공하는지 여부에 관계없이 드라이버는 NULL이 아닌 RequestOptions 매개 변수를 지정할 수 있습니다. 예를 들어 RequestOptions 매개 변수를 사용하여 제한 시간 값을 지정할 수 있습니다.

  2. WdfUsbTargetDeviceSendControlTransferSynchronously 메서드의 MemoryDescriptor 매개 변수에 대한 버퍼 공간을 제공합니다.

    드라이버는 이 버퍼 공간을 로컬로 할당된 버퍼, WDFMEMORY 핸들 또는 MDL로 지정할 수 있습니다. 가장 편리한 방법을 사용할 수 있습니다.

    필요한 경우 프레임워크는 데이터 버퍼에 액세스하기 위한 I/O 대상의 메서드에 맞는 버퍼 설명을 변환합니다.

    사용할 수 있는 기술은 다음과 같습니다.

    • 로컬 버퍼 제공

      WdfUsbTargetDeviceSendControlTransferSynchronously I/O 요청을 동기적으로 처리하기 때문에 드라이버는 다음 코드 예제와 같이 호출 루틴에 로컬인 요청 버퍼를 만들 수 있습니다.

      WDF_MEMORY_DESCRIPTOR  memoryDescriptor;
      MY_BUFFER_TYPE  myBuffer;
      WDF_MEMORY_DESCRIPTOR_INIT_BUFFER(&memoryDescriptor,
                                        (PVOID) &myBuffer,
                                        sizeof(myBuffer));
      
    • WDFMEMORY 핸들 제공

      다음 코드 예제와 같이 WdfMemoryCreate 또는 WdfMemoryCreatePreallocated 를 호출하여 프레임워크 관리 메모리에 대한 핸들을 가져옵니다.

      WDF_MEMORY_DESCRIPTOR  memoryDescriptor;
      WDFMEMORY  memoryHandle = NULL;
      status = WdfMemoryCreate(NULL,
                               NonPagedPool,
                               POOL_TAG,
                               MY_BUFFER_SIZE,
                               &memoryHandle,
                               NULL);
      WDF_MEMORY_DESCRIPTOR_INIT_HANDLE(&memoryDescriptor,
                                        memoryHandle,
                                        NULL);
      

      또는 드라이버가 해당 버퍼의 콘텐츠를 I/O 대상에 전달하도록 하려면 WdfRequestRetrieveInputMemory 또는 WdfRequestRetrieveOutputMemory 를 호출하여 수신된 I/O 요청의 버퍼를 나타내는 프레임워크 메모리 개체에 대한 핸들을 가져올 수 있습니다. WdfUsbTargetDeviceSendControlTransferSynchronously에서 I/O 대상으로 보내는 새 요청이 삭제, 재사용 또는 다시 포맷될 때까지 드라이버는 수신된 I/O 요청을 완료하지 않아야 합니다. (WdfUsbTargetDeviceSendControlTransferSynchronously 메모리 개체의 참조 횟수를 증분합니다. 요청 개체를 삭제, 재사용 또는 다시 포맷하면 메모리 개체의 참조 수가 감소합니다.)

    • MDL 공급

      드라이버는 WdfRequestRetrieveInputWdmdl 또는 WdfRequestRetrieveOutputWdmmdl 을 호출하여 수신된 I/O 요청과 연결된 MDL을 가져올 수 있습니다.

프레임워크는 내부 URB에서 USBD_SHORT_TRANSFER_OK 플래그를 설정합니다. 이 플래그를 설정하면 데이터 전송의 마지막 패킷이 최대 패킷 크기보다 작을 수 있습니다.

I/O 요청이 완료된 후 상태 정보를 가져오는 방법에 대한 자세한 내용은 완료 정보 가져오기를 참조하세요.

WdfUsbTargetDeviceSendControlTransferSynchronously 메서드 및 USB I/O 대상에 대한 자세한 내용은 USB I/O 대상을 참조하세요.

예제

다음 코드 예제에서는 WDF_USB_CONTROL_SETUP_PACKET 구조를 초기화한 다음 WdfUsbTargetDeviceSendControlTransferSynchronously 호출하여 공급업체별 제어 전송을 보냅니다.

WDF_USB_CONTROL_SETUP_PACKET  controlSetupPacket;

WDF_USB_CONTROL_SETUP_PACKET_INIT_VENDOR(
                                         &controlSetupPacket,
                                         BmRequestHostToDevice,
                                         BmRequestToDevice,
                                         USBFX2LK_REENUMERATE,
                                         0,
                                         0
                                         );

status = WdfUsbTargetDeviceSendControlTransferSynchronously(
                                         UsbDevice,
                                         WDF_NO_HANDLE,
                                         NULL,
                                         &controlSetupPacket,
                                         NULL,
                                         NULL
                                         );
return status;

요구 사항

   
대상 플랫폼 유니버설
최소 KMDF 버전 1.0
최소 UMDF 버전 2.0
헤더 wdfusb.h(Wdfusb.h 포함)
라이브러리 Wdf01000.sys(KMDF); WUDFx02000.dll(UMDF)
IRQL PASSIVE_LEVEL
DDI 규정 준수 규칙 DriverCreate(kmdf), KmdfIrql(kmdf), KmdfIrql2(kmdf), KmdfIrqlExplicit(kmdf), RequestForUrbXrb(kmdf), SyncReqSend(kmdf), UsbKmdfIrql(kmdf), UsbKmdfIrql2(kmdf), UsbKmdfIrqlExplicit(kmdf)

추가 정보

WDF_USB_CONTROL_SETUP_PACKET

WDF_USB_CONTROL_SETUP_PACKET_INIT_VENDOR

WdfRequestCancelSentRequest

WdfUsbTargetDeviceFormatRequestForControlTransfer

WdfUsbTargetDeviceSendUrbSynchronously