[PATCH 2/6] ntoskrnl.exe/tests: Support IOCTL_HID_GET_INPUT_REPORT.

Rémi Bernon rbernon at codeweavers.com
Fri Jun 18 07:06:07 CDT 2021


Signed-off-by: Rémi Bernon <rbernon at codeweavers.com>
---
 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




More information about the wine-devel mailing list