From patchwork Sat Nov 28 12:37:20 2020 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Linus Walleij X-Patchwork-Id: 334144 Delivered-To: patch@linaro.org Received: by 2002:a92:5e16:0:0:0:0:0 with SMTP id s22csp3424638ilb; Sat, 28 Nov 2020 14:05:32 -0800 (PST) X-Google-Smtp-Source: ABdhPJwDHAMHXlZMB31IunN7rLLnyvBZx56RtHkMUeSsX6WZol89wskmoM5R31pD3nb3uUoqPiNg X-Received: by 2002:a50:e042:: with SMTP id g2mr13904589edl.292.1606601132698; Sat, 28 Nov 2020 14:05:32 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1606601132; cv=none; d=google.com; s=arc-20160816; b=amTW+5T1ABKKrhKU/0qhQKgyVk0IMjEC/xy756elMa72DSPEv6nX2GxI9vCmzVsgHJ 54PzDslrJ8uoffCJAg9BmxbmWFSuqX3p6DTL9wOIG9Rfysm6PI/faMrQ7hyhqsSVptBB WGZOhox8Je+STUorL1Xr+B+EEFqoF6VnJcOauRzcQcXI5sWrNRZOj1zWhultsbaZJIKe NyvFn61Oc+pfpRUlkWSywzjzDL+aBceQygJ68u/QEF5rGsfjX+/wGyoxX7HNQOVoKxbF JHSR6BChcV1E4/j7yNWNpNQt7WybUaOEdstWJxGTYNR9t72Bjn+gp951qmL7Fqumy9nH VBmQ== 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:dkim-signature; bh=e4VRle5XYJGMSXH05W51yvLETuLs3J9IHLNDYKySqxc=; b=0H3OmIZlMfaZFigP5WqSTIl4DUAKwoBu5LpVkEM1O3CcYUX6uQQHzMe97INaiK0LaU Y14FAqldrYoOGmmLQx2DaXHrvACiFb3APmn/S4CkzcmILEgzcAZQuZWqgqUbbTYwSn89 tHHG1St5FDtJ+CuKQ/Gu3UkBFj4anTBtulfQuFYTmWLyIK1J1Uk7Or/9Eup7AqT8fUQ1 AKElMTTVip7Vxpds/jSycfjrHm8lxAwhRz/nWkZwtmWX2fDNw7J+huIfWlxEUCTN7u/W ES1O9NnC62TMZLcGIKcR+ToKi5hy9bj6UyQFRFHCYC+PuAEGTQiSEXSZHa9eZJeKji9H gosQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linaro.org header.s=google header.b=HEcSZCUp; spf=pass (google.com: domain of linux-input-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-input-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linaro.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id m91si576960ede.352.2020.11.28.14.05.32; Sat, 28 Nov 2020 14:05:32 -0800 (PST) Received-SPF: pass (google.com: domain of linux-input-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@linaro.org header.s=google header.b=HEcSZCUp; spf=pass (google.com: domain of linux-input-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-input-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linaro.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2387849AbgK1VuZ (ORCPT + 1 other); Sat, 28 Nov 2020 16:50:25 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:40018 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1730118AbgK1Sh7 (ORCPT ); Sat, 28 Nov 2020 13:37:59 -0500 Received: from mail-lf1-x142.google.com (mail-lf1-x142.google.com [IPv6:2a00:1450:4864:20::142]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id C9975C02A18E for ; Sat, 28 Nov 2020 04:37:26 -0800 (PST) Received: by mail-lf1-x142.google.com with SMTP id d20so10907887lfe.11 for ; Sat, 28 Nov 2020 04:37:26 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=from:to:cc:subject:date:message-id:mime-version :content-transfer-encoding; bh=e4VRle5XYJGMSXH05W51yvLETuLs3J9IHLNDYKySqxc=; b=HEcSZCUpbimBKnJL9fn5HiDpNtUOkNUHYcYl48Q9ZBfPef2Kvub5oaTkNffhD1YYn7 LzqSRnydWU1gItOpT2jPXWRYGgN6xZJvM6P82x7l3XR3ce5KYy5MfIKwdTfx+Yl3AcG/ M7AM/EyW4XoqnUpg4fHJpAUmZHx04uMjkitq4QhrKkWe1gyacQvlOBieWC8DaOX+mWVj srEJSA7PD5Qx58De2YFTEkoqhzAcDx0D9sOYKe8YEtxtify0mzVhg4EmDKlI+uul2Dvk B/LPewOPbouMrnDMkiiLGcYGF22Ztl6eWnShj08OpQEMrX/rjYjdbtwaXLv8rZSEYAsS 0PVg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:mime-version :content-transfer-encoding; bh=e4VRle5XYJGMSXH05W51yvLETuLs3J9IHLNDYKySqxc=; b=e5qXM4IGA/ehNP7v+6EzrPxKE/GjmIhTXpxVb2BKA0mFrHm24EZ3Vyju2l7tPIk2DB ndZSCkZvJNnNtcuJyucDuKiq2py4RLmPuVz+8q29nt8xOJldH2JpbRPKQCvOrXumDExZ TkQvQcUS5i/zfeIM3kmZ7ZcxiQzkj5ISENtvMFJIXE8byEFKsAtXZmnl/RRgUEoWuOjN n56QqpXde0ooimlb6asFItDN7N6oXYv1L9F7djPgtfq/IHkug3MV08QtUOpzMsNpKyuI 1MTAuOuoZ7G//TVqZ2cI3rDFuR6AlCC1ev/MRZgvD1i39IJvTZkba+SS2YBwBAjRIern VsyA== X-Gm-Message-State: AOAM530AmYQKyn35yaWCNZX+pE6lg2Fc05IzwvrzZVpM5NCAQrblGt4M rsd4Qe06BnZhUZ7QXlgoLOg7MQ== X-Received: by 2002:ac2:5939:: with SMTP id v25mr5385426lfi.490.1606567045318; Sat, 28 Nov 2020 04:37:25 -0800 (PST) Received: from localhost.bredbandsbolaget (c-92d7225c.014-348-6c756e10.bbcust.telenor.se. [92.34.215.146]) by smtp.gmail.com with ESMTPSA id f24sm1364239ljc.54.2020.11.28.04.37.24 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Sat, 28 Nov 2020 04:37:24 -0800 (PST) From: Linus Walleij To: Dmitry Torokhov , linux-input@vger.kernel.org Cc: Linus Walleij , Andre , Nick Dyer , Jiada Wang , stable@vger.kernel.org Subject: [PATCH] Input: atmel_mxt_ts - Fix lost interrupts Date: Sat, 28 Nov 2020 13:37:20 +0100 Message-Id: <20201128123720.929948-1-linus.walleij@linaro.org> X-Mailer: git-send-email 2.26.2 MIME-Version: 1.0 Precedence: bulk List-ID: X-Mailing-List: linux-input@vger.kernel.org After commit 74d905d2d38a devices requiring the workaround for edge triggered interrupts stopped working. This is because the "data" state container defaults to *not* using the workaround, but the workaround gets used *before* the check of whether it is needed or not. This semantic is not obvious from just looking on the patch, but related to the program flow. The hardware needs the quirk to be used before even proceeding to check if the quirk is needed. This patch makes the quirk be used until we determine it is *not* needed. Cc: Andre Cc: Nick Dyer Cc: Jiada Wang Cc: stable@vger.kernel.org Fixes: 74d905d2d38a ("Input: atmel_mxt_ts - only read messages in mxt_acquire_irq() when necessary") Signed-off-by: Linus Walleij --- drivers/input/touchscreen/atmel_mxt_ts.c | 7 ++++--- 1 file changed, 4 insertions(+), 3 deletions(-) -- 2.26.2 diff --git a/drivers/input/touchscreen/atmel_mxt_ts.c b/drivers/input/touchscreen/atmel_mxt_ts.c index e34984388791..f25b2f6038a7 100644 --- a/drivers/input/touchscreen/atmel_mxt_ts.c +++ b/drivers/input/touchscreen/atmel_mxt_ts.c @@ -1297,8 +1297,6 @@ static int mxt_check_retrigen(struct mxt_data *data) int val; struct irq_data *irqd; - data->use_retrigen_workaround = false; - irqd = irq_get_irq_data(data->irq); if (!irqd) return -EINVAL; @@ -1313,8 +1311,10 @@ static int mxt_check_retrigen(struct mxt_data *data) if (error) return error; - if (val & MXT_COMMS_RETRIGEN) + if (val & MXT_COMMS_RETRIGEN) { + data->use_retrigen_workaround = false; return 0; + } } dev_warn(&client->dev, "Enabling RETRIGEN workaround\n"); @@ -3117,6 +3117,7 @@ static int mxt_probe(struct i2c_client *client, const struct i2c_device_id *id) data = devm_kzalloc(&client->dev, sizeof(struct mxt_data), GFP_KERNEL); if (!data) return -ENOMEM; + data->use_retrigen_workaround = true; snprintf(data->phys, sizeof(data->phys), "i2c-%u-%04x/input0", client->adapter->nr, client->addr);