Received: by 2002:a05:6a10:f347:0:0:0:0 with SMTP id d7csp2509297pxu; Fri, 18 Dec 2020 15:28:01 -0800 (PST) X-Google-Smtp-Source: ABdhPJzFxV2yNNf3Jh6q2nGJE0AVe+mnImR8BGHGOFb1vYITViHvr/AuyiqJdlUhCq4cjKysqHFR X-Received: by 2002:a05:6402:3186:: with SMTP id di6mr6586599edb.16.1608334081593; Fri, 18 Dec 2020 15:28:01 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1608334081; cv=none; d=google.com; s=arc-20160816; b=mKZ+nwNdLtBHWo2Lm7UZuUQ1jbpDxtHghyJ7T9WBwpe22Wk7R7f/AVRPWc2VKjYIVE f+dM4BFpYLkJz6OdJqiGmO931IgC7V7RWrzsm42IjSfKdGAvGEfZ/vu1WhziAeRtlN/P Y9Yp63V9c/r4HXfHsR+Nw/+iQw6qRP/bpkuN/vdEB9EcRNeWeVQCOAbEyELjHubeIdhx 4ICpTSCs+2cLCtErQeEZ90QZ+YV6znwC0gLFqeLWEtcdeoM34KQhhM7FX4zecVkAajDN CAUBkwxHzR/RLhi0ztfi/aocZw/8H+O/YjOkEGRbHMo8udrHtqfUu6cjKH+MjTTRx1Yt tdqQ== 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=RucXrucLUOdHW4BxRUvPMEYexZ9kWHvi1ji4pZdfEb75jc4pGviO4iZdYE7GOWgW2Q RZutUrytODRVJ1UFPZgnC/39othwFMwZZ576F2E5d+3vytUyDLIkQqIXWnX8GdCCNXWK 7UbZLgI/pyDWW3+kzQvZ4MPq1y9HjYsVgtoGqpp1/W2SObDzkMfUCOzmie3P8gLVqVnH NrLvOEgh7L6Z+xyeDW3sw61SvMlyYVAtnEZskJt0q0Vu2F/UZgwahHQeP7x0zESt4/JZ hYrR6IlAwQj1+7QO6QlL75lKFM2Plf787FTbF/gJsTgmjuUCh3YvqbIe/qM34aHVefdA 4HWA== 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 k27si5408070eji.193.2020.12.18.15.27.39; Fri, 18 Dec 2020 15:28:01 -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 S1726020AbgLRX1N (ORCPT + 99 others); Fri, 18 Dec 2020 18:27:13 -0500 Received: from plasma4.jpberlin.de ([80.241.57.33]:45101 "EHLO plasma4.jpberlin.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725885AbgLRX1M (ORCPT ); Fri, 18 Dec 2020 18:27:12 -0500 Received: from hefe.heinlein-support.de (hefe.heinlein-support.de [91.198.250.172]) by plasma.jpberlin.de (Postfix) with ESMTP id B0DEBAAD30; Sat, 19 Dec 2020 00:26:28 +0100 (CET) X-Virus-Scanned: amavisd-new at heinlein-support.de Received: from plasma.jpberlin.de ([91.198.250.140]) by hefe.heinlein-support.de (hefe.heinlein-support.de [91.198.250.172]) (amavisd-new, port 10030) with ESMTP id 8qM22asEXxr6; Sat, 19 Dec 2020 00:26:24 +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 82FB5AAD16; Sat, 19 Dec 2020 00:26:24 +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 RESEND] virtio-input: add multi-touch support Date: Sat, 19 Dec 2020 01:25:56 +0200 Message-ID: <20201218232556.28041-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.06 / 15.00 / 15.00 X-Rspamd-Queue-Id: B0DEBAAD30 X-Rspamd-UID: 4cff26 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