EVT_SPB_CONTROLLER_OTHER 콜백 함수(spbcx.h)

SPB 컨트롤러 드라이버의 EvtSpbControllerIoOther 이벤트 콜백 함수는 다른 이벤트 콜백 함수 또는 SPB 프레임워크 확장(SpbCx)에서 처리되지 않는 디바이스 I/O 제어 요청을 처리합니다.

구문

EVT_SPB_CONTROLLER_OTHER EvtSpbControllerOther;

void EvtSpbControllerOther(
  [in] WDFDEVICE Controller,
  [in] SPBTARGET Target,
  [in] SPBREQUEST Request,
  [in] size_t OutputBufferLength,
  [in] size_t InputBufferLength,
  [in] ULONG IoControlCode
)
{...}

매개 변수

[in] Controller

SPB 컨트롤러를 나타내는 프레임워크 디바이스 개체 에 대한 WDFDEVICE 핸들입니다.

[in] Target

이 I/O 요청에 대한 대상에 대한 SPBTARGET 핸들입니다. 대상은 버스에 연결된 주변 장치 또는 포트입니다. SPB 프레임워크 확장(SpbCx)은 이전에 대상에 대한 연결을 연 EvtSpbTargetConnect 콜백의 대상에 이 핸들을 할당했습니다.

[in] Request

I/O 요청에 대한 SPBREQUEST 핸들입니다. SPB 컨트롤러 드라이버는 이 요청을 완료해야 합니다. 자세한 내용은 설명 부분을 참조하세요.

[in] OutputBufferLength

출력 버퍼가 요청과 함께 제공되는 경우 출력 버퍼의 길이(바이트)입니다.

[in] InputBufferLength

입력 버퍼가 요청과 함께 제공되는 경우 입력 버퍼의 길이(바이트)입니다.

[in] IoControlCode

요청에 대한 I/O 제어 코드(IOCTL)입니다. 이 값은 SPB 프레임워크 확장(SpbCx)이 인식하지 못하는 IOCTL입니다. 자세한 내용은 설명 부분을 참조하세요.

반환 값

없음

설명

SpbCx는 SPB 컨트롤러에 대한 I/O 큐를 관리합니다. SPB 컨트롤러 드라이버가 EvtSpbControllerIoOther 콜백 함수를 등록하는 경우 SpbCx는 SpbCx가 지원하지 않는 디바이스 I/O 제어 요청이 컨트롤러의 I/O 큐에 도착하면 이 함수를 호출합니다. Request 매개 변수 값은 이 요청을 캡슐화하는 핸들입니다. SPB 컨트롤러 드라이버는 요청된 작업을 수행하거나 오류 상태 반환하여 이 요청을 완료해야 합니다. 드라이버가 지정된 IOCTL을 지원하지 않는 경우 드라이버는 STATUS_NOT_SUPPORTED 오류 상태 반환해야 합니다. SpbCx에서 지원하는 IOCTL 목록은 SpbCx I/O 제어 코드를 참조하세요.

EvtSpbControllerIoOther 콜백을 사용하면 버스별 또는 드라이버별 명령을 SPB 컨트롤러 드라이버에 IOCTL로 디스패치할 수 있습니다. 예를 들어 클라이언트(주변 드라이버)는 이러한 IOCTL을 사용하여 SPI 버스의 대상 디바이스와 전체 이중 데이터 교환과 같은 버스 관련 작업을 조정할 수 있습니다. 이러한 IOCTL은 SpbCx에서 지원하는 IOCTL과 동일한 흐름 제어의 적용을 받습니다.

EvtSpbControllerIoOther 콜백 함수는 EvtIoDeviceControl과 유사하며 비슷한 방식으로 IOCTL을 처리합니다. WDF 드라이버가 I/O 요청을 처리하는 방법에 대한 일반적인 내용은 프레임워크 요청 개체를 참조하세요.

EvtSpbControllerIoOther 콜백은 상태 값을 반환하지 않습니다. 대신 SPB 컨트롤러 드라이버는 I/O 요청에 대한 완료 상태 요청된 작업의 상태 나타냅니다.

I/O 요청을 즉시 완료할 수 없는 경우 SPB 컨트롤러 드라이버가 요청 처리를 완료할 때까지 기다리지 않고 콜백 함수가 반환되어야 합니다. SPB 컨트롤러 드라이버는 나중에 요청을 비동기적으로 완료할 수 있습니다.

EvtSpbControllerIoOther 함수는 사용자 모드 클라이언트에서 수신하는 I/O 컨트롤 요청의 매개 변수 값의 유효성을 검사해야 합니다. EvtSpbControllerIoOther 이외의 모든 EvtSpbXxx 콜백 함수의 경우 SpbCx는 함수를 호출하기 전에 사용자 모드 매개 변수의 유효성을 검사합니다.

EvtSpbControllerIoOther 콜백 함수를 등록하려면 SpbControllerSetIoOther 메서드를 호출합니다.

예제

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

예를 들어 라는 MyEvtSpbControllerIoOtherEvtSpbControllerIoOther 콜백 함수를 정의하려면 다음 코드 예제와 같이 EVT_SPB_CONTROLLER_OTHER 함수 형식을 사용합니다.

EVT_SPB_CONTROLLER_OTHER  MyEvtSpbControllerIoOther;

그런 다음 다음과 같이 콜백 함수를 구현합니다.

_Use_decl_annotations_
VOID
  MyEvtSpbControllerIoOther(
    WDFDEVICE Controller,
    SPBTARGET Target,
    SPBREQUEST Request,
    size_t OutputBufferLength,
    size_t InputBufferLength,
    ULONG IoControlCode
    )
{ ... }

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

요구 사항

요구 사항
지원되는 최소 클라이언트 Windows 8 부터 지원합니다.
대상 플랫폼 데스크톱
머리글 spbcx.h
IRQL IRQL <= DISPATCH_LEVEL 호출합니다.

추가 정보

EvtIoDeviceControl

EvtSpbTargetConnect

SPBREQUEST

SPBTARGET

SpbControllerSetIoOther