Received: by 2002:a25:e74b:0:0:0:0:0 with SMTP id e72csp1547938ybh; Mon, 20 Jul 2020 00:39:36 -0700 (PDT) X-Google-Smtp-Source: ABdhPJx9xnFu8IIWajCUmC0x+Xh6jObY4oJvcmBUdfBjD451kOwoD6FUOroeOFS+sDLf5fp+od4G X-Received: by 2002:a17:906:700f:: with SMTP id n15mr20627701ejj.390.1595230776546; Mon, 20 Jul 2020 00:39:36 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1595230776; cv=none; d=google.com; s=arc-20160816; b=Mxo5za9dsAfm+As4befVl5Verx4GFrW5TAAb27Hdr+6xo/Fquu52saXTGVpkijx4JZ bYN75SFp7tqiKFaLmwmCqKPmjUC2XhVpb+OQ9DBI14d0CMEXqMEtnsxUh0d6LtsSgWBS UBgmzppMCZP60uSuhX7YK64JyjE3mBq1i25wdm0dizeHviEWItL7y6CGSW8Bvpx4gZlw ePPOpmvfkmBJbcswZPXPXY2S6/0u0DNlQk3hMcZ1BGHo3G+dIiF/N5Upxg0IkM0/YPTC MqhzWHq1OR+LQXF8/YkW3ftamaa4WTMlE/3Caj3bzWMJ2p4PnPp+6tckBfmz4aTWq+yU eMhQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:mime-version:message-id:date:subject:cc :to:from:ironport-sdr:ironport-sdr; bh=4ckU15Pg6rNr13DslJCRP7qa7eaSlNQH2V5CwlQufc0=; b=pO3OTNYL66MBDbvQMSNLkqSKyWWiHTHtic/NQ1TB4iKCeoEOfEgAb2x8xQrdULK8Fo z8T5j+WzD6WrL22P3moSDYzM7XlKbooowKI6K7/vttcBqrma1ELQlPygeh6Yl38j/nK+ nhbxbI59agR0bE22Ls8rlohPr+CO0HCVGpHlGShal+FyQTFFWZ5DX+0/21r9+YihnRxk DUh3Tax5VUp2br3Kgz54Ms6q09eQ5ZcQNtQrmlxPjmFyt+wqbffW63hswJqU/M7Q9Y8s xp4K6y9PPiNuOWNQNWUZbCl/R+kvDti29fgkpLX9kcBox5bWNClJ4+8j82j71DxqWJpc IoRw== 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 g9si9700136ejj.380.2020.07.20.00.39.13; Mon, 20 Jul 2020 00:39:36 -0700 (PDT) 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 S1726832AbgGTHgR (ORCPT + 99 others); Mon, 20 Jul 2020 03:36:17 -0400 Received: from esa1.mentor.iphmx.com ([68.232.129.153]:4118 "EHLO esa1.mentor.iphmx.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725845AbgGTHgQ (ORCPT ); Mon, 20 Jul 2020 03:36:16 -0400 IronPort-SDR: JUnDqMFjtYTPZOUwFTzlUfIEmN24CtaNyobpyL8Ex0OyyIuVLSXqSGeKEGzcHj2l8NjM7JL2gJ lTnZHDl4laNOrJmlLgPM7YUXQLcthz9ycX5fm1b52O5Fc0yAUN7hgmSpxD0+LE47L5cvy/i6bb zFoPqN8C69dpevq2SllV0PtzY09jqgSMPJ8JK8Mbnvb7KSRaWvcoKNsFKO8nxvasHLXOVJ/3pJ zDoyFan93SdFWGuNYb3znYx2N47h5/AF/Z2/yGw7T0G3QUGU1x3XhbcKMiNwHeTSuyfbESIiDG dKw= X-IronPort-AV: E=Sophos;i="5.75,374,1589270400"; d="scan'208";a="53223919" Received: from orw-gwy-01-in.mentorg.com ([192.94.38.165]) by esa1.mentor.iphmx.com with ESMTP; 19 Jul 2020 23:36:16 -0800 IronPort-SDR: iOL27on271qN9yuzAA9Wm6NDdC++jqAt5e3iyn35j9ytrv5/nZzlArOrPsgZ4fvV+WBywGGhuz WAe16lA+jYbh2V+TSuqjziO7qlYs4mnRY7Ij+9Uoy3jVGXHfhJz6SPDieBz9qKzE4eNQn+Zj88 OJecc1QmH5ri4d9ooge4J/YjvRHXzbaXJJ1Xc1WSaa63083Pxf8anOL9l4xgw27+meVgXoR2lk jKUA23O1+ugMvvCd+BDe/MuUtwDljpvlwB9UiCN/npxe/lfg3ESp/+ToT6B4xH5EPlS+vk/KPm xzA= From: Jiada Wang To: , CC: , , , , , Subject: [PATCH 1/1] Input: atmel_mxt_ts - only read messages in mxt_acquire_irq() when necessary Date: Mon, 20 Jul 2020 16:36:12 +0900 Message-ID: <20200720073612.6252-1-jiada_wang@mentor.com> X-Mailer: git-send-email 2.17.1 MIME-Version: 1.0 Content-Type: text/plain Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Nick Dyer The workaround of reading all messages until an invalid is received is a way of forcing the CHG line high, which means that when using edge-triggered interrupts the interrupt can be acquired. With level-triggered interrupts the workaround is unnecessary. Also, most recent maXTouch chips have a feature called RETRIGEN which, when enabled, reasserts the interrupt line every cycle if there are messages waiting. This also makes the workaround unnecessary. Note: the RETRIGEN feature is only in some firmware versions/chips, it's not valid simply to enable the bit. Signed-off-by: Nick Dyer Acked-by: Benson Leung Acked-by: Yufeng Shen (cherry picked from ndyer/linux/for-upstream commit 1ae4e8281e491b22442cd5acdfca1862555f8ecb) [gdavis: Fix conflicts due to v4.6-rc7 commit eb43335c4095 ("Input: atmel_mxt_ts - use mxt_acquire_irq in mxt_soft_reset").] Signed-off-by: George G. Davis [jiada: reset use_retrigen_workaround at beginning of mxt_check_retrigen() call mxt_check_retrigen() after mxt_acquire_irq() in mxt_initialize() replace white-spaces with tab for MXT_COMMS_RETRIGEN] Signed-off-by: Jiada Wang --- drivers/input/touchscreen/atmel_mxt_ts.c | 51 ++++++++++++++++++++++-- 1 file changed, 48 insertions(+), 3 deletions(-) diff --git a/drivers/input/touchscreen/atmel_mxt_ts.c b/drivers/input/touchscreen/atmel_mxt_ts.c index a2189739e30f..2b4cb5c87a43 100644 --- a/drivers/input/touchscreen/atmel_mxt_ts.c +++ b/drivers/input/touchscreen/atmel_mxt_ts.c @@ -20,6 +20,7 @@ #include #include #include +#include #include #include #include @@ -129,6 +130,7 @@ struct t9_range { /* MXT_SPT_COMMSCONFIG_T18 */ #define MXT_COMMS_CTRL 0 #define MXT_COMMS_CMD 1 +#define MXT_COMMS_RETRIGEN BIT(6) /* MXT_DEBUG_DIAGNOSTIC_T37 */ #define MXT_DIAGNOSTIC_PAGEUP 0x01 @@ -308,6 +310,7 @@ struct mxt_data { struct t7_config t7_cfg; struct mxt_dbg dbg; struct gpio_desc *reset_gpio; + bool use_retrigen_workaround; /* Cached parameters from object table */ u16 T5_address; @@ -318,6 +321,7 @@ struct mxt_data { u16 T71_address; u8 T9_reportid_min; u8 T9_reportid_max; + u16 T18_address; u8 T19_reportid; u16 T44_address; u8 T100_reportid_min; @@ -1190,9 +1194,11 @@ static int mxt_acquire_irq(struct mxt_data *data) enable_irq(data->irq); - error = mxt_process_messages_until_invalid(data); - if (error) - return error; + if (data->use_retrigen_workaround) { + error = mxt_process_messages_until_invalid(data); + if (error) + return error; + } return 0; } @@ -1282,6 +1288,33 @@ static u32 mxt_calculate_crc(u8 *base, off_t start_off, off_t end_off) return crc; } +static int mxt_check_retrigen(struct mxt_data *data) +{ + struct i2c_client *client = data->client; + int error; + int val; + + data->use_retrigen_workaround = false; + + if (irq_get_trigger_type(data->irq) & IRQF_TRIGGER_LOW) + return 0; + + if (data->T18_address) { + error = __mxt_read_reg(client, + data->T18_address + MXT_COMMS_CTRL, + 1, &val); + if (error) + return error; + + if (val & MXT_COMMS_RETRIGEN) + return 0; + } + + dev_warn(&client->dev, "Enabling RETRIGEN workaround\n"); + data->use_retrigen_workaround = true; + return 0; +} + static int mxt_prepare_cfg_mem(struct mxt_data *data, struct mxt_cfg *cfg) { struct device *dev = &data->client->dev; @@ -1561,6 +1594,10 @@ static int mxt_update_cfg(struct mxt_data *data, const struct firmware *fw) mxt_update_crc(data, MXT_COMMAND_BACKUPNV, MXT_BACKUP_VALUE); + ret = mxt_check_retrigen(data); + if (ret) + goto release_mem; + ret = mxt_soft_reset(data); if (ret) goto release_mem; @@ -1604,6 +1641,7 @@ static void mxt_free_object_table(struct mxt_data *data) data->T71_address = 0; data->T9_reportid_min = 0; data->T9_reportid_max = 0; + data->T18_address = 0; data->T19_reportid = 0; data->T44_address = 0; data->T100_reportid_min = 0; @@ -1678,6 +1716,9 @@ static int mxt_parse_object_table(struct mxt_data *data, object->num_report_ids - 1; data->num_touchids = object->num_report_ids; break; + case MXT_SPT_COMMSCONFIG_T18: + data->T18_address = object->start_address; + break; case MXT_SPT_MESSAGECOUNT_T44: data->T44_address = object->start_address; break; @@ -2141,6 +2182,10 @@ static int mxt_initialize(struct mxt_data *data) if (error) return error; + error = mxt_check_retrigen(data); + if (error) + return error; + error = request_firmware_nowait(THIS_MODULE, true, MXT_CFG_NAME, &client->dev, GFP_KERNEL, data, mxt_config_cb); -- 2.17.1