다음을 통해 공유


IOCTL_INTERNAL_MOUSE_CONNECT IOCTL(kbdmou.h)

IOCTL_INTERNAL_MOUSE_CONNECT 요청은 Mouclass 서비스를 마우스 디바이스에 연결합니다. Mouclass는 마우스 디바이스를 열기 전에 이 요청을 디바이스 스택 아래로 보냅니다.

Moufiltr는 마우스 연결 요청을 수신한 후 다음과 같은 방식으로 요청을 필터링합니다.

  1. Moufiltr에 전달된 CONNECT_DATA(Mouclass) 구조의 복사본을 저장합니다.
  2. 클래스 드라이버 연결 정보에 대한 자체 연결 정보를 대체합니다.
  3. 디바이스 스택 아래로 IOCTL_INTERNAL_MOUSE_CONNECT 요청을 보냅니다.
요청이 실패하면 Moufiltr는 적절한 오류 상태로 요청을 완료합니다.

Moufiltr는 Mouclass 서비스 콜백 루틴인 mouseClassServiceCallback 작업을 보완할 수 있는 필터 서비스 콜백 루틴에 대한 템플릿을 제공합니다. 필터 서비스 콜백은 디바이스 입력 버퍼에서 클래스 드라이버 데이터 큐로 전송되는 입력 데이터를 필터링할 수 있습니다.

Mouclass 서비스의 연결에 대한 자세한 내용은 다음 항목을 참조하세요.

I8042prt 콜백 루틴

무필트르 콜백 루틴

주 코드

IRP_MJ_INTERNAL_DEVICE_CONTROL

입력 버퍼

Parameters.DeviceIoControl.Type3InputBuffer 멤버는 Mouclass에 의해 할당되고 설정된 CONNECT_DATA 구조를 가리킵니다.

입력 버퍼 길이

Parameters.DeviceIoControl.InputBufferLength 멤버는 CONNECT_DATA 구조체의 크기(바이트)보다 크거나 같은 값으로 설정됩니다.

출력 버퍼

Parameters.DeviceIoControl.Type3InputBuffer 멤버는 Moufiltr에서 설정한 CONNECT_DATA 구조를 가리킵니다.

출력 버퍼 길이

CONNECT_DATA 구조체의 크기입니다.

상태 블록

Information 멤버는 0으로 설정됩니다.

상태 멤버는 다음 값 중 하나로 설정됩니다.

STATUS_INVALID_PARAMETER

Parameters.DeviceIoControl.InputBufferLength CONNECT_DATA 구조체의 크기(바이트)보다 작습니다.

STATUS_SHARING_VIOLATION

Moufiltr가 이미 연결되어 있습니다(필터 드라이버는 하나의 연결 요청만 지원).

요구 사항

요구
헤더 kbdmou.h(Kbdmou.h 포함)

참고 항목

CONNECT_DATA(무클래스)

MouseClassServiceCallback