Received: by 10.223.185.116 with SMTP id b49csp911070wrg; Wed, 21 Feb 2018 08:54:47 -0800 (PST) X-Google-Smtp-Source: AH8x227VFTU7kXuSPiE7JbgddG2yJw91cjOBOYmvvFl6BJMLVuEZlDZHW0Yi209T1f83lfDwHrPI X-Received: by 10.101.97.139 with SMTP id c11mr3283816pgv.447.1519232086993; Wed, 21 Feb 2018 08:54:46 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1519232086; cv=none; d=google.com; s=arc-20160816; b=b6+FLSEDjqqcINllPJLYKjdSOZ+P0EYyqover/FrHDhO4DLEWcIWRqBdM4A2UfN1vW a7jSj3ciyKUwJwZ19yWu79jJ1kT8uXyQweCX67OLiF+XCr6h6WyATTPmfkKlvE6y9+WZ 2gp5Wn1WEtWsjL2tgE8hr1Jk6mg61A4hncJ9u62t36XootSe5/439IYZZj8xIfYkddnb NDi0lowQuBUZ/2n3hM3oD4+Sxf9FwrhP1/pOXKvdFfwV0zr3kIslRgyEReKbH5EbOro8 wFIMcDMLVLrkB9YRjCP9HYsWskZj/G3AP2jci/PxK10B3PFrC+xBcJmfhGe8IqlN76qX EF9w== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:cc:to:subject:message-id:date:from :references:in-reply-to:mime-version:dkim-signature :arc-authentication-results; bh=DUk37AtOepqKt6B2Z0ndLLny2iwPmI5kdc1hlZhvB2o=; b=TKBR+DrPHqMnECWc65Zw4pymhXvEWh/h69wzucmFnxvBtviRyQ1nRkI5e3ztfTEDUQ w1fgU2sO9MGmeVlGTjyes3C+KlA4f44kd8KlNrDPl9fYZPpZ9rfqiCK95s/mXDsDmxK4 ccxttEXItTnXG6g/Hji2nxnND5/mii9RPPS/qXfwBvAdVpf+v59bJEZABktBlSpnwmUX xNQChUDrEomgWTkq69NztqDzeb1xnjgh53BajQRk91q1XAXKvpfMaVoWShvL4m9fcmPD pHoDURZ/9Q9/feW7qsmclElxwlXSlFCxClE4cV8uDUsIsHD67O7uuVyUbEvClQk7Yhuu QR/Q== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linaro.org header.s=google header.b=cevmQQe1; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-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. [209.132.180.67]) by mx.google.com with ESMTP id q15si6715501pgc.746.2018.02.21.08.54.32; Wed, 21 Feb 2018 08:54:46 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@linaro.org header.s=google header.b=cevmQQe1; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-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 S933258AbeBULf3 (ORCPT + 99 others); Wed, 21 Feb 2018 06:35:29 -0500 Received: from mail-ot0-f196.google.com ([74.125.82.196]:40006 "EHLO mail-ot0-f196.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1753877AbeBULf1 (ORCPT ); Wed, 21 Feb 2018 06:35:27 -0500 Received: by mail-ot0-f196.google.com with SMTP id s4so1108889oth.7 for ; Wed, 21 Feb 2018 03:35:26 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=mime-version:in-reply-to:references:from:date:message-id:subject:to :cc; bh=DUk37AtOepqKt6B2Z0ndLLny2iwPmI5kdc1hlZhvB2o=; b=cevmQQe1KLc/mzKmbJ1MFzCOM0oA9fWNaHmOBNt2EcBXASc4wjdE4zb3EJMYFPXFJj duroOSDyhTlxU3c78DLDtusxCTIYrECmgzQBkchZBFnMOwEWlN5wmI54LZuEoJ26vxZe 2/PgptTHG+i4PTe5V1yo6OMyRsOYUaATO7C8A= X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:mime-version:in-reply-to:references:from:date :message-id:subject:to:cc; bh=DUk37AtOepqKt6B2Z0ndLLny2iwPmI5kdc1hlZhvB2o=; b=Afvc2iYisjtR6gFKIycbZIBz1xp5HptgpXWfi3oczwUEjLeRyCPGTRFVxgZjdyi8Yb 9O2O7QoCb9irtOnqSAd23t/XzPgSnGEKNj6eklEn9m+nohIfqKpglB6vwi9ZuzUqtnW8 RDvEjf64trhF2PhJf715TnoB+dqrKmHrFyDf65b6meZKvqKxnz1IidcSxv3a5c4DYhZo GqNOJE3bbZwxsG9C9dSsZ/Ms+jBID6+a85sGwni5PUqLY4z7awOdw9kD6tIqVcXeSnLa ce80cz/zu+M9Q4vGHyifSJ6EslDxXxL4zFRxB+ZYU6cVB0MmvqJP9KF6tJoqZuBvx4SX Uogw== X-Gm-Message-State: APf1xPDvgTcO3Tcr5Z6HWpGvcnGC208aP9QDhZIEZNxdhwbZSTdxsSwE YuwhbaCCnr68LHzxpCUWJkWXbaibnhXKGvi34ZBcQg== X-Received: by 10.157.52.100 with SMTP id v91mr117198otb.159.1519212926510; Wed, 21 Feb 2018 03:35:26 -0800 (PST) MIME-Version: 1.0 Received: by 10.157.96.5 with HTTP; Wed, 21 Feb 2018 03:35:26 -0800 (PST) In-Reply-To: <20180219181159.tzbhhvbvpc236qma@rob-hp-laptop> References: <7fc26df245d56fd2014532b56e67630e76e2c513.1518316248.git.baolin.wang@linaro.org> <20180219181159.tzbhhvbvpc236qma@rob-hp-laptop> From: Baolin Wang Date: Wed, 21 Feb 2018 19:35:26 +0800 Message-ID: Subject: Re: [PATCH v2] Input: gpio_keys: Add level trigger support for GPIO keys To: Rob Herring Cc: Dmitry Torokhov , Mark Rutland , Greg KH , stephen lu , Arvind Yadav , Joseph Lo , Kate Stewart , Philippe Ombredanne , Thomas Gleixner , linux-input@vger.kernel.org, DTML , LKML , Mark Brown , Linus Walleij Content-Type: text/plain; charset="UTF-8" Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi Rob, On 20 February 2018 at 02:11, Rob Herring wrote: > On Sun, Feb 11, 2018 at 02:55:04PM +0800, Baolin Wang wrote: >> On some platforms (such as Spreadtrum platform), the GPIO keys can only >> be triggered by level type. So this patch introduces one property to >> indicate if the GPIO trigger type is level trigger or edge trigger. > > If the parent interrupt controller only supports a certain trigger, then > it should ignore setting the trigger type. We still need to set high level type trigger or low level type trigger if it only supports level trigger. > >> >> Signed-off-by: Baolin Wang >> --- >> Changes since v1: >> - Diable the GPIO irq until reversing the GPIO level type. >> --- >> .../devicetree/bindings/input/gpio-keys.txt | 2 ++ >> drivers/input/keyboard/gpio_keys.c | 26 +++++++++++++++++++- >> include/linux/gpio_keys.h | 1 + >> 3 files changed, 28 insertions(+), 1 deletion(-) >> >> diff --git a/Documentation/devicetree/bindings/input/gpio-keys.txt b/Documentation/devicetree/bindings/input/gpio-keys.txt >> index a949404..e3104bd 100644 >> --- a/Documentation/devicetree/bindings/input/gpio-keys.txt >> +++ b/Documentation/devicetree/bindings/input/gpio-keys.txt >> @@ -29,6 +29,8 @@ Optional subnode-properties: >> - linux,can-disable: Boolean, indicates that button is connected >> to dedicated (not shared) interrupt which can be disabled to >> suppress events from the button. >> + - gpio-key,level-trigger: Boolean, indicates that button's interrupt >> + type is level trigger. Otherwise it is edge trigger as default. > > No. Just use 'interrupts' instead of 'gpios' and specify the trigger > type. Or put both if you need to read the state. Okay, so something as below to get the level type from the 'interrupts' property. if (fwnode_property_read_u32(child, "interrupts", &button->level_type)) button->level_type = IRQ_TYPE_NONE; -- Baolin.wang Best Regards