Received: by 2002:ac0:a5b6:0:0:0:0:0 with SMTP id m51-v6csp660131imm; Tue, 5 Jun 2018 02:14:43 -0700 (PDT) X-Google-Smtp-Source: ADUXVKKi7Srq75Xos8/lvjN9jbCJb/q55QKQ1G11JVXvyhofUSvAHf8NqvSDtBFxaqptHrYDoQ/e X-Received: by 2002:a62:8b0a:: with SMTP id j10-v6mr24794518pfe.28.1528190083454; Tue, 05 Jun 2018 02:14:43 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1528190083; cv=none; d=google.com; s=arc-20160816; b=OGIlLsWZ45JRdpD3TEt7Wl/Vr5N7krY1PkakzZsOmWdMDGRtDZCrTaPLcszyt7Tro2 iEkTrywqgUybIIHl6E1sLd9q2DGeKxSQDd05RddAB1lElvYijifNaGb1T2H0arM+BBVs GMdjbHs1cpK+yhapYnGJGZhc8j7Qh152pXnoGsAD595acapPfItrIm5C7t0fccorfPSh Q7PSKpJZ6nEPEt5qtwdOdoSzIATPxg0M0bvOXj55ydBJHyqloT4Jjq6vPgdWzsGI/cFL pcT0L1XVk7ydQTknSfZIgPnCd/j4eeF+GP8ym09Lb2SA6kZ59vMi6n6u0s4T6UImKLep yjnw== 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=kYZo5jbYTI4sQEQuOTUAKAW6u88igooJ97qhqVc1phk=; b=EPDI3aQcAb8p4tvq11VgpV7eYV9TL5e9ve4l6Arr8uGoSwXI36KwtZ4pn0a4JXaOtS FCkBYkc2YWC1QDfldfZD8fWRYko7f3EnLL2kyCexd13bGEMUDh3oGGFFWOu4FADkXa5p GeyG/s+Uw3k+Lk9d09F2JghPOUC4QPkhER1M9JrP7YmS59VQvx6/UA4p8EARvTeC+VAq dm0KCDWY2xy9VaaOnUWNqEfWJ+kObptwm3IxrymgktAK6kXt+QwhT+dhADv13W3csfWw s1gMeEeT8hIfFm+a9v1TnbhxrHI2OaJ1c+GnC/lxixAOIv6tYjU+hR0bfHJhVrp0au/y aLYg== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@gmail.com header.s=20161025 header.b=IlHpaSXB; 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=fail (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id b2-v6si36500635pgn.599.2018.06.05.02.14.28; Tue, 05 Jun 2018 02:14:43 -0700 (PDT) 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=fail header.i=@gmail.com header.s=20161025 header.b=IlHpaSXB; 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=fail (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1751913AbeFEJOL (ORCPT + 99 others); Tue, 5 Jun 2018 05:14:11 -0400 Received: from mail-oi0-f67.google.com ([209.85.218.67]:45843 "EHLO mail-oi0-f67.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751890AbeFEJOI (ORCPT ); Tue, 5 Jun 2018 05:14:08 -0400 Received: by mail-oi0-f67.google.com with SMTP id b130-v6so1369698oif.12; Tue, 05 Jun 2018 02:14:07 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=mime-version:sender:in-reply-to:references:from:date:message-id :subject:to:cc; bh=kYZo5jbYTI4sQEQuOTUAKAW6u88igooJ97qhqVc1phk=; b=IlHpaSXBhNE5kS/O+lTihOR1wTMWkRQSVpzrBNjzSqdBouu8tO6+HvsbYaKIbdxenL FPo7l8YV9k6r/zfx8aw8EUrxnEVi9OVgb/VYspRWiCL5u8w8CM7PFKiN/jrQ27Anr/HO 1cWiT9xKtNm2orlYQBAcoi7C9FJPKLEqXNA9vbbHgavU63icpBSiQ15h/w93vu3RSwXY XnDhPgK5ArbCI8wsJPPRfiMuXh8tseKr+sDQ3yhdQB0aDmcwzuCXjKo0UP8MxveySd3Y P2ORVhxhMsYG08ziI/pICHhNQlzE1aK+27rtQeIeltLepcmU5+YVQZiNgQt09in3chzI jLpA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:mime-version:sender:in-reply-to:references:from :date:message-id:subject:to:cc; bh=kYZo5jbYTI4sQEQuOTUAKAW6u88igooJ97qhqVc1phk=; b=Z93f6m8X7/frDy+DmNzrdVyRK6sUzCBV19TaL2IATSAZIftV2xMIbmWj92oXGsobzf V8+DRIe+53vZxFAujgQGWMB45dS08PaLApRZH/GhEc/xEdepAq2DQPPLSZ5zX/CSWTkU J4SS9UZZ0gXTpQ4AoC59Ri6pvuVxcpLYJ+wpjmrMgJs+GYHOTc0aWFI5+eGIdbvI8uRP LwU7/isomvElY+iXjpGHA73CkkY0mY5mIYIYqCkuox87FEo4bWA4q7eN8QH1LAjhRl8R xt0+d65FC9RdJHWnVWjcSHj1SkjBMSOGrcQFWtXE2R/OxHPctyNgb9yMrHNYfhMyWkQn tOtQ== X-Gm-Message-State: APt69E0uTMZel7IBdzvlRDUGNiFj2U05BA26KjEKFrcqMiE9gtu08BKg dcSlHoZTY8lqISXZsDCe7VKCWPceGF39rOjZVJA= X-Received: by 2002:aca:ac16:: with SMTP id v22-v6mr14579030oie.227.1528190047473; Tue, 05 Jun 2018 02:14:07 -0700 (PDT) MIME-Version: 1.0 Received: by 2002:a9d:1468:0:0:0:0:0 with HTTP; Tue, 5 Jun 2018 02:14:07 -0700 (PDT) In-Reply-To: <20180604215339.GG164893@dtor-ws> References: <20180601180053.120202-1-ravisadineni@chromium.org> <20180602010708.152025-1-ravisadineni@chromium.org> <20180604215339.GG164893@dtor-ws> From: "Rafael J. Wysocki" Date: Tue, 5 Jun 2018 11:14:07 +0200 X-Google-Sender-Auth: S6P_3b26Um1FGQFvYSu8kzVrdmQ Message-ID: Subject: Re: [PATCH V2] i8042: Increment wakeup_count for the respective port. To: Dmitry Torokhov Cc: Ravi Chandra Sadineni , "Rafael J. Wysocki" , chenhong3@huawei.com, Ravi Chandra Sadineni , Dmitry Torokhov , Todd Broch , Linux Kernel Mailing List , linux-input@vger.kernel.org, Rajat Jain , Benson Leung 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 On Mon, Jun 4, 2018 at 11:53 PM, Dmitry Torokhov wrote: > On Fri, Jun 01, 2018 at 06:07:08PM -0700, Ravi Chandra Sadineni wrote: >> Call pm_wakeup_event on every irq. This should help us in identifying if >> keyboard was a potential wake reason for the last resume. >> >> Signed-off-by: Ravi Chandra Sadineni >> --- >> V2: Increment the wakeup count only when there is a irq and not when the >> method is called internally. >> >> drivers/input/serio/i8042.c | 3 +++ >> 1 file changed, 3 insertions(+) >> >> diff --git a/drivers/input/serio/i8042.c b/drivers/input/serio/i8042.c >> index 824f4c1c1f310..2bd6f2633e29a 100644 >> --- a/drivers/input/serio/i8042.c >> +++ b/drivers/input/serio/i8042.c >> @@ -573,6 +573,9 @@ static irqreturn_t i8042_interrupt(int irq, void *dev_id) >> port = &i8042_ports[port_no]; >> serio = port->exists ? port->serio : NULL; >> >> + if (irq && serio && device_may_wakeup(&serio->dev)) >> + pm_wakeup_event(&serio->dev, 0); > > The constant checks for device_may_wakeup() before calling > pm_wakeup_event()needed to avoid warnings in wakeup_source_activate() > (?) are annoying. I'm not following you here. pm_wakeup_event() -> pm_wakeup_dev_event() -> pm_wakeup_ws_event(dev->power.wakeup, ...) Checks if the first arg is NULL and returns quietly if so. I don't see why you need the device_may_wakeup() check. > Rafael, can we move the check into pm_wakeup_dev_event()? That would be redundant, wouldn't it? > I am also confused when pm_wakeup_event() vs pm_wakeup_hard_event() vs > pm_wakeup_dev_event() should be used, if any. Is there any guidance? First off, the "hard" variant is for when you want to abort suspends in progress or wake up from suspend to idle regardless of whether or not wakeup source tracking is enabled. Second, use pm_wakeup_dev_event() if the decision on "hard" vs "soft" needs to be made at run time. Thanks, Rafael