Received: by 2002:a25:7ec1:0:0:0:0:0 with SMTP id z184csp2151225ybc; Wed, 20 Nov 2019 09:36:59 -0800 (PST) X-Google-Smtp-Source: APXvYqw3GBnbsWSKm172/SbOaAD3imbHuGHA22S+3Svp1syveFeRMpH3ix9gMQ7/Dirbt6oKPsy8 X-Received: by 2002:a17:906:b5b:: with SMTP id v27mr6593328ejg.327.1574271419247; Wed, 20 Nov 2019 09:36:59 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1574271419; cv=none; d=google.com; s=arc-20160816; b=bJV1Gjq4rOHpHtWfvPG7Ek6t4ohF9ou/mv/mtD2bWLarkwLIXm16onTI41JRiZ7ua7 sWlQuOD+rwnnqHOCEfE4msReVTX4QswbQys589qEKCuAAilvpIzPZX9bK2KEcSRc5uh9 UHO5tx2qKAasM6emH/U6dJQ5td8XAXvp4peSQLbPH2xwZp9gKyEW3XtzV6UIOothSey5 ZaUmUsReUj4jkxDDZ+Ca+Ipev4A4zJ31Zu5CKpuXsETCvea2ZoDkAF9rCqOXJehwRFaG zJM9OgLttLRn1cGRzEdC0xCwPcuWnxdvlGKgO9WRTaaC4MulxUoX9S5PF9BY28olZOTZ kv3w== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:message-id:references :in-reply-to:subject:cc:to:from:date:content-transfer-encoding :mime-version; bh=T8FE7Jrz//L1MgDEJHIQnojNBuv0pq38ddXAUrdcgaw=; b=QuIMuIvajElMgZNgdYUwMh//RFrPSREgQb+J/Ox3K6o6gMvGP8qQQwbTSNxT0o5RYw Dna5fi7IBLW4zCY0ZC+SN+m94iDkQ2XgPUYwDt3x0rSZpK6Cw56pLZBV6CBMCKpntPC6 zvU0GLqqf/X/MVkh8l7TARASqk6cQ9mR8sDv+E41b8ht76pK4AVj/AzjAqPqj2HOmWGA 1osRp6y3Zegsnv/zcJG8wzhTWq2aJHI3GSwN7PiJb8p729ppJNghEytHCDo0AU0EWLG8 W3Jox52imklE2CX0MI322eYfwn+xShtXIxdaDmuN4iIDTil9dhcRKlYLtWHOtOXWgXJl eNvQ== ARC-Authentication-Results: i=1; mx.google.com; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id gg4si17148250ejb.236.2019.11.20.09.36.34; Wed, 20 Nov 2019 09:36:59 -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; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1732839AbfKTQll (ORCPT + 99 others); Wed, 20 Nov 2019 11:41:41 -0500 Received: from protonic.xs4all.nl ([83.163.252.89]:34198 "EHLO protonic.nl" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1729448AbfKTQll (ORCPT ); Wed, 20 Nov 2019 11:41:41 -0500 X-Greylist: delayed 538 seconds by postgrey-1.27 at vger.kernel.org; Wed, 20 Nov 2019 11:41:40 EST Received: from webmail.promanet.nl (edge2.prtnl [192.168.1.170]) by sparta (Postfix) with ESMTP id B38DC44A0065; Wed, 20 Nov 2019 17:34:53 +0100 (CET) MIME-Version: 1.0 Content-Type: text/plain; charset=US-ASCII; format=flowed Content-Transfer-Encoding: 7bit Date: Wed, 20 Nov 2019 17:32:38 +0100 From: robin To: Marco Felsch Cc: Dmitry Torokhov , Robin Gong , "linux-input @ vger . kernel . org" , "linux-kernel @ vger . kernel . org" , Pengutronix Kernel Team , Shawn Guo , Adam Ford , "linux-arm-kernel @ lists . infradead . org" Subject: Re: [PATCH v3] input: keyboard: snvs_pwrkey: Send key events for i.MX6 S, DL and Q In-Reply-To: <20191120092749.7rru5fj7eybs4tl6@pengutronix.de> References: <20190904062329.97520-1-robin@protonic.nl> <20190912201300.GA636@penguin> <803592d161b9ca75d6ac1c2c54e891a1@protonic.nl> <20190916233701.GH237523@dtor-ws> <20191120092749.7rru5fj7eybs4tl6@pengutronix.de> Message-ID: X-Sender: robin@protonic.nl User-Agent: Roundcube Webmail/1.3.6 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 2019-11-20 10:27, Marco Felsch wrote: > Hi Robin, > > On 19-09-16 16:37, Dmitry Torokhov wrote: >> On Mon, Sep 16, 2019 at 07:45:37AM +0000, Robin Gong wrote: >> > On 2019/9/13 15:31 robin wrote:> >> > > Hi Dmitry, >> > > >> > > On 2019-09-12 22:13, Dmitry Torokhov wrote: >> > > > Hi Robin, >> > > > >> > > > On Wed, Sep 04, 2019 at 06:23:29AM +0000, Robin van der Gracht wrote: >> > > >> The first generation i.MX6 processors does not send an interrupt when >> > > >> the power key is pressed. It sends a power down request interrupt if >> > > >> the key is released before a hard shutdown (5 second press). This >> > > >> should allow software to bring down the SoC safely. >> > > >> >> > > >> For this driver to work as a regular power key with the older SoCs, >> > > >> we need to send a keypress AND release when we get the power down >> > > >> request irq. >> > > >> >> > > >> Signed-off-by: Robin van der Gracht >> > > >> --- >> > > >> @@ -67,13 +83,17 @@ static irqreturn_t imx_snvs_pwrkey_interrupt(int >> > > >> irq, void *dev_id) { >> > > >> struct platform_device *pdev = dev_id; >> > > >> struct pwrkey_drv_data *pdata = platform_get_drvdata(pdev); >> > > >> + unsigned long expire = jiffies; >> > > >> u32 lp_status; >> > > >> >> > > >> pm_wakeup_event(pdata->input->dev.parent, 0); >> > > >> >> > > >> regmap_read(pdata->snvs, SNVS_LPSR_REG, &lp_status); >> > > >> - if (lp_status & SNVS_LPSR_SPO) >> > > >> - mod_timer(&pdata->check_timer, jiffies + >> > > >> msecs_to_jiffies(DEBOUNCE_TIME)); >> > > >> + if (lp_status & SNVS_LPSR_SPO) { >> > > >> + if (pdata->minor_rev > 0) >> > > >> + expire = jiffies + msecs_to_jiffies(DEBOUNCE_TIME); >> > > >> + mod_timer(&pdata->check_timer, expire); >> > > > >> > > > Why do we even need to fire the timer in case of the first generation >> > > > hardware? Just send press and release events directly from the ISR. >> > That timer looks like a software debounce to prevent unexpected and >> > meaningless interrupt/event caused by quick press/release. >> >> Right, but in case of the first generation hardware we schedule the >> timer immediately (expire == 0) and do not check state of the hardware >> in the timer handler, but rather simply emit down/up events, so we do >> not really get any benefit from the timer (again, I am talking about >> first generation hardware only). > > Did you prepared a v4? Just ask to avoid a duplicated work :) No I haven't. Not sure what the public wants. Use timer, don't use timer.. v3 has had long term testing though ;) Regards, Robin van der Gracht