From mboxrd@z Thu Jan 1 00:00:00 1970 Received: from eggs.gnu.org ([2001:4830:134:3::10]:38157) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1alxWV-0007cj-Hh for qemu-devel@nongnu.org; Fri, 01 Apr 2016 07:45:56 -0400 Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1alxWR-0007YL-Kt for qemu-devel@nongnu.org; Fri, 01 Apr 2016 07:45:55 -0400 Received: from mx1.redhat.com ([209.132.183.28]:32838) by eggs.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1alxWR-0007YG-Fd for qemu-devel@nongnu.org; Fri, 01 Apr 2016 07:45:51 -0400 Received: from int-mx11.intmail.prod.int.phx2.redhat.com (int-mx11.intmail.prod.int.phx2.redhat.com [10.5.11.24]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mx1.redhat.com (Postfix) with ESMTPS id 1E2BDC03BD5C for ; Fri, 1 Apr 2016 11:45:51 +0000 (UTC) From: Ladi Prosek Date: Fri, 1 Apr 2016 13:45:46 +0200 Message-Id: <1459511146-12060-1-git-send-email-lprosek@redhat.com> Subject: [Qemu-devel] [PATCH v2] virtio-input: implement pass-through evdev writes List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , To: qemu-devel@nongnu.org Cc: Ladi Prosek , kraxel@redhat.com The write path for pass-through devices, commonly used for controlling keyboard LEDs via EV_LED, was not implemented. This commit adds the necessary plumbing to connect the status virtio queue to the host evdev file descriptor. Signed-off-by: Ladi Prosek --- v1 -> v2 - dropped the queue of pending writes hw/input/virtio-input-host.c | 23 +++++++++++++++++++++++ 1 file changed, 23 insertions(+) diff --git a/hw/input/virtio-input-host.c b/hw/input/virtio-input-host.c index 36856d6..62185d5 100644 --- a/hw/input/virtio-input-host.c +++ b/hw/input/virtio-input-host.c @@ -145,6 +145,28 @@ static void virtio_input_host_unrealize(DeviceState *dev, Error **errp) } } +static void virtio_input_host_handle_status(VirtIOInput *vinput, + virtio_input_event *event) +{ + VirtIOInputHost *vih = VIRTIO_INPUT_HOST(vinput); + struct input_event evdev; + int rc; + + if (gettimeofday(&evdev.time, NULL)) { + perror("virtio_input_host_handle_status: gettimeofday"); + return; + } + + evdev.type = le16_to_cpu(event->type); + evdev.code = le16_to_cpu(event->code); + evdev.value = le32_to_cpu(event->value); + + rc = write(vih->fd, &evdev, sizeof(evdev)); + if (rc == -1) { + perror("virtio_input_host_handle_status: write"); + } +} + static const VMStateDescription vmstate_virtio_input_host = { .name = "virtio-input-host", .unmigratable = 1, @@ -164,6 +186,7 @@ static void virtio_input_host_class_init(ObjectClass *klass, void *data) dc->props = virtio_input_host_properties; vic->realize = virtio_input_host_realize; vic->unrealize = virtio_input_host_unrealize; + vic->handle_status = virtio_input_host_handle_status; } static void virtio_input_host_init(Object *obj) -- 2.5.5