Received: by 2002:a05:6a10:f347:0:0:0:0 with SMTP id d7csp2510610pxu; Fri, 18 Dec 2020 15:30:52 -0800 (PST) X-Google-Smtp-Source: ABdhPJySpB3g3k4VwoR/WzM7y+BxvM8fMe4BytB2zrvsA3tXhX8KBHvIaiFIs5AqLZ7Kn7oJ4ppy X-Received: by 2002:a17:906:720e:: with SMTP id m14mr5178977ejk.161.1608334252790; Fri, 18 Dec 2020 15:30:52 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1608334252; cv=none; d=google.com; s=arc-20160816; b=C1TSMsdU3AQWm1YcG2p20BweA3eU25o8zZNuT8NUhc0P5o6K6QyaI3h+bG6IdwQqaD ZMPWWKhLFKqGMnpvA9xTdyoAA3h91+z7sciklQI7gwJdIJ2CJpvVFisS+5FocRw4jQ9H z1WEw6bcBalRlVivZpM/oJJ7QhpdNvU/qhs43RvyWRJIf4fWV5dVdQqLgi/XVm4PNzAw eQ4D0vpyzKr2vTV6mMZTuNHbDJ9tXSYbSgfcz3PCyeOejOb+/uKtqRGgdGAoiT4B15HM dpZXf1cSBn0oq2ZS6EsF+LV+7smGLqwixfvWksIWiZUVNXsIepO4dN+rKF4S0/TlivA9 c6VQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :message-id:date:subject:cc:to:from; bh=6ScLpkhDsQFLoZ05fPMF7WRBE/Nvli1GXJHxDyFis6g=; b=a0Wb2tzXU8vZQlp0Bd1AKRRszDNDnXgJt9VXRiUSyvloRcq98k9L4E2lytN3A3jJLd OirGWs3N5p5HNHv8zONuO2QLWJ4yNF9tN9IUjCFJXXKl51e/vM5k5tL8y6QPoT2wa0e+ 69juTWw1rYQ1wex5t5SAgcuGHSsHXw93iXkPoY+HaYwHl6Nhuv/sWuYJlZcizjUmIq/t cieMFc6j5o54DqcKduqOda+IMvu6ASCOPKBx8oRkTnx7JuUQ6qoy0MWY8gZ8nbMpbIkN C0e0T3zTBB1R+GEM3fnmqg+NVILfXBeJpiQaplgzJWoD2CoX3Xem1nKDIRw6G9D8lDH8 caVw== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id d13si7783206edv.602.2020.12.18.15.30.30; Fri, 18 Dec 2020 15:30:52 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1725885AbgLRX2x (ORCPT + 99 others); Fri, 18 Dec 2020 18:28:53 -0500 Received: from plasma4.jpberlin.de ([80.241.57.33]:58365 "EHLO plasma4.jpberlin.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725815AbgLRX2x (ORCPT ); Fri, 18 Dec 2020 18:28:53 -0500 Received: from spamfilter05.heinlein-hosting.de (spamfilter05.heinlein-hosting.de [80.241.56.123]) by plasma.jpberlin.de (Postfix) with ESMTP id ABD19AAB1A; Sat, 19 Dec 2020 00:18:05 +0100 (CET) X-Virus-Scanned: amavisd-new at heinlein-support.de Received: from plasma.jpberlin.de ([80.241.56.68]) by spamfilter05.heinlein-hosting.de (spamfilter05.heinlein-hosting.de [80.241.56.123]) (amavisd-new, port 10030) with ESMTP id 52UN0snNzPPf; Sat, 19 Dec 2020 00:18:04 +0100 (CET) Received: from webmail.opensynergy.com (unknown [217.66.60.5]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-SHA384 (256/256 bits)) (Client CN "*.opensynergy.com", Issuer "Starfield Secure Certificate Authority - G2" (not verified)) (Authenticated sender: opensynergy@jpberlin.de) by plasma.jpberlin.de (Postfix) with ESMTPSA id 526F4AA8E3; Sat, 19 Dec 2020 00:18:04 +0100 (CET) From: Vasyl Vavrychuk To: , , CC: "Michael S. Tsirkin" , Jason Wang , Gerd Hoffmann , Henrik Rydberg , Dmitry Torokhov , Mathias Crombez , Vasyl Vavrychuk Subject: [PATCH v3] virtio-input: add multi-touch support Date: Sat, 19 Dec 2020 01:17:51 +0200 Message-ID: <20201218231751.27420-1-vasyl.vavrychuk@opensynergy.com> MIME-Version: 1.0 Content-Transfer-Encoding: 7BIT Content-Type: text/plain; charset=US-ASCII X-ClientProxiedBy: SR-MAIL-02.open-synergy.com (10.26.10.22) To SR-MAIL-01.open-synergy.com (10.26.10.21) X-MBO-SPAM-Probability: X-Rspamd-Score: -3.49 / 15.00 / 15.00 X-Rspamd-Queue-Id: ABD19AAB1A X-Rspamd-UID: 7f919c Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Mathias Crombez Without multi-touch slots allocated, ABS_MT_SLOT events will be lost by input_handle_abs_event. Implementation is based on uinput_create_device. Signed-off-by: Mathias Crombez Co-developed-by: Vasyl Vavrychuk Signed-off-by: Vasyl Vavrychuk --- v2: fix patch corrupted by corporate email server v3: use number of slots from the host drivers/virtio/virtio_input.c | 11 ++++++++++- 1 file changed, 10 insertions(+), 1 deletion(-) diff --git a/drivers/virtio/virtio_input.c b/drivers/virtio/virtio_input.c index f1f6208edcf5..f643536807dd 100644 --- a/drivers/virtio/virtio_input.c +++ b/drivers/virtio/virtio_input.c @@ -7,6 +7,7 @@ #include #include +#include struct virtio_input { struct virtio_device *vdev; @@ -204,7 +205,7 @@ static int virtinput_probe(struct virtio_device *vdev) struct virtio_input *vi; unsigned long flags; size_t size; - int abs, err; + int abs, err, nslots; if (!virtio_has_feature(vdev, VIRTIO_F_VERSION_1)) return -ENODEV; @@ -289,6 +290,13 @@ static int virtinput_probe(struct virtio_device *vdev) continue; virtinput_cfg_abs(vi, abs); } + + if (test_bit(ABS_MT_SLOT, vi->idev->absbit)) { + nslots = input_abs_get_max(vi->idev, ABS_MT_SLOT) + 1; + err = input_mt_init_slots(vi->idev, nslots, 0); + if (err) + goto err_mt_init_slots; + } } virtio_device_ready(vdev); @@ -304,6 +312,7 @@ static int virtinput_probe(struct virtio_device *vdev) spin_lock_irqsave(&vi->lock, flags); vi->ready = false; spin_unlock_irqrestore(&vi->lock, flags); +err_mt_init_slots: input_free_device(vi->idev); err_input_alloc: vdev->config->del_vqs(vdev); -- 2.23.0