Received: by 2002:a05:6358:45e:b0:b5:b6eb:e1f9 with SMTP id 30csp3158333rwe; Mon, 29 Aug 2022 06:52:27 -0700 (PDT) X-Google-Smtp-Source: AA6agR5J1nb+RMStCqV1rg4FgedIl8308oxTcELNKvdfr8NUY9kYlAQg6rFQzez3wKnrppSibsa1 X-Received: by 2002:a05:6a00:16c4:b0:535:890:d4a with SMTP id l4-20020a056a0016c400b0053508900d4amr16670889pfc.0.1661781147150; Mon, 29 Aug 2022 06:52:27 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1661781147; cv=none; d=google.com; s=arc-20160816; b=hUTU/N7eUZ4hP3iX7ud+Nok+tbFEwSZZYudhzqkxB7rqqHBIS1YCB099LhUosE+00k /YSMcS6iVJIIi2ZSZmVt+2iGHBnmlwl/aToiHKhJ1reozAFxNKJj/FPUEKl0o7ApXdSK OjTXHsl8OWii974AaDF5V8ho15gmmbOG3oqqav4cppEAOIIeO4o9LMqi1qzbofxUBC8l yjbEMTJoa/PdGjOWkYS9QO9TIX7bpU4fEvnzdr+loKI2zv5znIV572wzmRmXpeJz9VZa K87y71NkvjE5ip1Qf17UPMFs1kp4Yz+aJZEM1RJeTdcOMKb1cz5cO7TOjPptS4NBS9qp bAsQ== 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 :references:in-reply-to:message-id:date:subject:cc:to:from; bh=e4wMNDJuHI9NZ7560IRQpYRnB6Gslc6nUisjAlG0MDQ=; b=MHLCN2sbCPmXchcWSqG/AOt20UmC4xLF7Ly3p+vU2YumfccpmakgGHuA+MmqmXFb9/ X6dzv7A+1juMmrS8TxORwLhsx+PhRMT50GMnBA9FT2bG9KCtjbT8dQ+JBAPyyi1sJBjQ F0YO1aaRSDCIhRL+eLe3CNRJKT81/SY/Khq8YLhzE/1KiIR/BlRCtzAIGKZZTrAKSSQJ uxvEuA16XohT0ArybKmBmun2xNG5vpxVTxXs6j26fj1AsO4PjfV3C5ReUuz0Y1bGpHcm TSNYi1zLROTBZJpei1oqdbTQ2btST1XC+CwVK+SAhZoJWixNzGuMtpKHSpDczaSNPLn8 j5Gw== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=analog.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id nv18-20020a17090b1b5200b001fddccc9214si2123993pjb.171.2022.08.29.06.52.15; Mon, 29 Aug 2022 06:52:27 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=analog.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S230414AbiH2NSO (ORCPT + 99 others); Mon, 29 Aug 2022 09:18:14 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:33696 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229757AbiH2NRM (ORCPT ); Mon, 29 Aug 2022 09:17:12 -0400 Received: from mx0a-00128a01.pphosted.com (mx0a-00128a01.pphosted.com [148.163.135.77]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id A881580E9D; Mon, 29 Aug 2022 06:16:39 -0700 (PDT) Received: from pps.filterd (m0167088.ppops.net [127.0.0.1]) by mx0a-00128a01.pphosted.com (8.17.1.5/8.17.1.5) with ESMTP id 27TB2F31015197; Mon, 29 Aug 2022 09:15:13 -0400 Received: from nwd2mta4.analog.com ([137.71.173.58]) by mx0a-00128a01.pphosted.com (PPS) with ESMTPS id 3j7d4843am-1 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=NOT); Mon, 29 Aug 2022 09:15:13 -0400 Received: from ASHBMBX9.ad.analog.com (ASHBMBX9.ad.analog.com [10.64.17.10]) by nwd2mta4.analog.com (8.14.7/8.14.7) with ESMTP id 27TDFCos019131 (version=TLSv1/SSLv3 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=FAIL); Mon, 29 Aug 2022 09:15:12 -0400 Received: from ASHBMBX9.ad.analog.com (10.64.17.10) by ASHBMBX9.ad.analog.com (10.64.17.10) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.2.986.14; Mon, 29 Aug 2022 09:15:11 -0400 Received: from zeus.spd.analog.com (10.66.68.11) by ashbmbx9.ad.analog.com (10.64.17.10) with Microsoft SMTP Server id 15.2.986.14 via Frontend Transport; Mon, 29 Aug 2022 09:15:11 -0400 Received: from nsa.ad.analog.com ([10.44.3.68]) by zeus.spd.analog.com (8.15.1/8.15.1) with ESMTP id 27TDEeiS026449; Mon, 29 Aug 2022 09:15:05 -0400 From: =?UTF-8?q?Nuno=20S=C3=A1?= To: , Bartosz Golaszewski , Dmitry Torokhov , , , Linus Walleij , , =?UTF-8?q?Nuno=20S=C3=A1?= CC: Andy Shevchenko , Rob Herring , Krzysztof Kozlowski , Michael Hennerich Subject: [PATCH v4 08/10] input: keyboard: adp5588-keys: add optional reset gpio Date: Mon, 29 Aug 2022 15:15:51 +0200 Message-ID: <20220829131553.690063-9-nuno.sa@analog.com> X-Mailer: git-send-email 2.37.2 In-Reply-To: <20220829131553.690063-1-nuno.sa@analog.com> References: <20220829131553.690063-1-nuno.sa@analog.com> MIME-Version: 1.0 Content-Type: text/plain; charset="UTF-8" Content-Transfer-Encoding: 8bit X-ADIRuleOP-NewSCL: Rule Triggered X-Proofpoint-GUID: Yr-eSYquuVgF2olYoJR0GRoZ-Gi9MjkI X-Proofpoint-ORIG-GUID: Yr-eSYquuVgF2olYoJR0GRoZ-Gi9MjkI X-Proofpoint-Virus-Version: vendor=baseguard engine=ICAP:2.0.205,Aquarius:18.0.895,Hydra:6.0.517,FMLib:17.11.122.1 definitions=2022-08-29_07,2022-08-25_01,2022-06-22_01 X-Proofpoint-Spam-Details: rule=outbound_notspam policy=outbound score=0 suspectscore=0 spamscore=0 impostorscore=0 priorityscore=1501 bulkscore=0 clxscore=1015 malwarescore=0 lowpriorityscore=0 mlxlogscore=999 mlxscore=0 adultscore=0 phishscore=0 classifier=spam adjust=0 reason=mlx scancount=1 engine=8.12.0-2207270000 definitions=main-2208290061 X-Spam-Status: No, score=-2.6 required=5.0 tests=BAYES_00,RCVD_IN_DNSWL_LOW, RCVD_IN_MSPIKE_H2,SPF_HELO_NONE,SPF_PASS,T_SCC_BODY_TEXT_LINE autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Optionally reset the device during probe. Signed-off-by: Nuno Sá Reviewed-by: Linus Walleij Reviewed-by: Andy Shevchenko --- drivers/input/keyboard/adp5588-keys.c | 12 ++++++++++++ 1 file changed, 12 insertions(+) diff --git a/drivers/input/keyboard/adp5588-keys.c b/drivers/input/keyboard/adp5588-keys.c index 3a234ec37fd4..b2bb7c6702e1 100644 --- a/drivers/input/keyboard/adp5588-keys.c +++ b/drivers/input/keyboard/adp5588-keys.c @@ -11,6 +11,7 @@ #include #include #include +#include #include #include #include @@ -715,6 +716,7 @@ static int adp5588_probe(struct i2c_client *client, { struct adp5588_kpad *kpad; struct input_dev *input; + struct gpio_desc *gpio; unsigned int revid; int ret; int error; @@ -740,6 +742,16 @@ static int adp5588_probe(struct i2c_client *client, if (error) return error; + gpio = devm_gpiod_get_optional(&client->dev, "reset", GPIOD_OUT_HIGH); + if (IS_ERR(gpio)) + return PTR_ERR(gpio); + + if (gpio) { + fsleep(30); + gpiod_set_value_cansleep(gpio, 0); + fsleep(60); + } + ret = adp5588_read(client, DEV_ID); if (ret < 0) return ret; -- 2.37.2