From: "Rémi Bernon" Subject: [PATCH 2/6] ntoskrnl.exe/tests: Support IOCTL_HID_GET_INPUT_REPORT. Message-Id: <20210618120611.703993-2-rbernon@codeweavers.com> Date: Fri, 18 Jun 2021 14:06:07 +0200 In-Reply-To: <20210618120611.703993-1-rbernon@codeweavers.com> References: <20210618120611.703993-1-rbernon@codeweavers.com> Signed-off-by: Rémi Bernon --- dlls/ntoskrnl.exe/tests/driver_hid.c | 18 ++++++++++++++++++ 1 file changed, 18 insertions(+) diff --git a/dlls/ntoskrnl.exe/tests/driver_hid.c b/dlls/ntoskrnl.exe/tests/driver_hid.c index 01a3747cd29..e684e2531db 100644 --- a/dlls/ntoskrnl.exe/tests/driver_hid.c +++ b/dlls/ntoskrnl.exe/tests/driver_hid.c @@ -382,6 +382,24 @@ static NTSTATUS WINAPI driver_internal_ioctl(DEVICE_OBJECT *device, IRP *irp) break; } + case IOCTL_HID_GET_INPUT_REPORT: + { + HID_XFER_PACKET *packet = irp->UserBuffer; + ULONG expected_size = 23; + ok(!in_size, "got input size %u\n", in_size); + ok(out_size == sizeof(*packet), "got output size %u\n", out_size); + + ok(packet->reportId == report_id, "got packet report id %u\n", packet->reportId); + ok(packet->reportBufferLen == expected_size, "got packet buffer len %u\n", packet->reportBufferLen); + ok(!!packet->reportBuffer, "got packet buffer %p\n", packet->reportBuffer); + + memset(packet->reportBuffer, 0xa5, packet->reportBufferLen); + if (report_id) ((char *)packet->reportBuffer)[0] = report_id; + irp->IoStatus.Information = expected_size; + ret = STATUS_SUCCESS; + break; + } + case IOCTL_HID_GET_STRING: ok(!in_size, "got input size %u\n", in_size); ok(out_size == 128, "got output size %u\n", out_size); -- 2.31.0