WdfIoTargetCreate 함수(wdfiotarget.h)

[KMDF 및 UMDF에 적용]

WdfIoTargetCreate 메서드는 지정된 디바이스에 대한 원격 I/O 대상을 만듭니다.

구문

NTSTATUS WdfIoTargetCreate(
  [in]           WDFDEVICE              Device,
  [in, optional] PWDF_OBJECT_ATTRIBUTES IoTargetAttributes,
  [out]          WDFIOTARGET            *IoTarget
);

매개 변수

[in] Device

프레임워크 디바이스 개체에 대한 핸들입니다.

[in, optional] IoTargetAttributes

I/O 대상 개체의 개체 특성을 지정하는 호출자가 할당한 WDF_OBJECT_ATTRIBUTES 구조체에 대한 포인터입니다. 이 매개 변수는 선택 사항이며 WDF_NO_OBJECT_ATTRIBUTES 수 있습니다.

[out] IoTarget

I/O 대상 개체에 대한 핸들을 수신하는 위치에 대한 포인터입니다.

반환 값

WdfIoTargetCreate 는 작업이 성공하면 STATUS_SUCCESS 반환합니다. 그렇지 않으면 이 메서드는 다음 값 중 하나를 반환할 수 있습니다.

반환 코드 설명
STATUS_INVALID_PARAMETER
잘못된 매개 변수가 감지되었습니다.
STATUS_INSUFFICIENT_RESOURCES
새 I/O 대상 개체를 만들기 위한 메모리가 부족했습니다.
STATUS_INVALID_DEVICE_REQUEST
IoTargetAttributes가 지정한 WDF_OBJECT_ATTRIBUTES 구조체의 ParentObject 멤버는 Device가 지정한 프레임워크 디바이스 개체 또는 부모 체인이 해당 개체로 이어지는 개체를 지정하지 않았습니다.
 

WdfIoTargetCreate에서 반환할 수 있는 다른 반환 값 목록은 프레임워크 개체 만들기 오류를 참조하세요.

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

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

설명

드라이버가 WdfIoTargetCreate를 호출한 후 드라이버는 WdfIoTargetOpen을 호출해야 원격 I/O 대상에 요청을 보낼 수 있습니다.

드라이버가 WDF_OBJECT_ATTRIBUTES 구조체의 ParentObject 멤버에서 부모 개체를 지정하는 경우 부모 개체는 프레임워크 디바이스 개체이거나 부모 체인이 프레임워크 디바이스 개체로 이어지는 개체일 수 있습니다. 프레임워크는 I/O 대상 개체(또는 드라이버)가 디바이스 개체를 삭제할 때 삭제합니다.

WdfIoTargetCreate에 대한 자세한 내용은 일반 I/O 대상 초기화를 참조하세요.

드라이버가 I/O 대상 개체 에 대해 EvtCleanupCallback 또는 EvtDestroyCallback 콜백 함수를 제공하는 경우 프레임워크는 IRQL = PASSIVE_LEVEL 이러한 콜백 함수를 호출합니다.

I/O 대상에 대한 자세한 내용은 I/O 대상 사용을 참조하세요.

예제

WdfIoTargetCreate를 사용하는 코드 예제는 WdfIoTargetOpen을 참조하세요.

요구 사항

요구 사항
대상 플랫폼 유니버설
최소 KMDF 버전 1.0
최소 UMDF 버전 2.0
머리글 wdfiotarget.h(Wdf.h 포함)
라이브러리 Wdf01000.sys(KMDF); WUDFx02000.dll(UMDF)
IRQL PASSIVE_LEVEL
DDI 규정 준수 규칙 DriverCreate(kmdf), KmdfIrql(kmdf), KmdfIrql2(kmdf), KmdfIrqlExplicit(kmdf)

추가 정보

WDF_OBJECT_ATTRIBUTES

WdfIoTargetOpen