Received: by 2002:a25:4158:0:0:0:0:0 with SMTP id o85csp1343695yba; Thu, 16 May 2019 19:49:08 -0700 (PDT) X-Google-Smtp-Source: APXvYqwK06W0zrGS8WuHXxEPBxHtAElPertD0BsX3hJlVONfmAtMcBtJhI4+KM2pjTd2meezrQuh X-Received: by 2002:a65:64da:: with SMTP id t26mr54243274pgv.322.1558061348843; Thu, 16 May 2019 19:49:08 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1558061348; cv=none; d=google.com; s=arc-20160816; b=fnCWhyg2WCd/DlcUQynld6Vmm6oW6ymPV+1u75VJq3/RiDlWyeRpzNliyCCHhKtfGN XMKwbhWidAeb1p+uSovA1SbMsjpdqefluOraw1cksqsiiTU05OeC/MREljQvUPzNsulK jzPcZpE6qelnRaK1mLfVrFKN2Cil7eA9wqVWarZuG+U1e09MOcqoSFujXi9e26liDmQm JwAaD11xc/HX/Vjujf8zdUu94mU+lUariibgpoUiTZj8HNKqFSwCvCYfLJ6/LKprGkFX h4dAEY3d6+Jul8Nn63ks+W5jetkxEmqmMC6pjYqZSCW/InofK6WBblR+0voVnQCN5HHD ZpeA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:message-id:date:subject:cc:to:from; bh=Q1Jyc5YUmrC3Qq5dwktbjfA6jmH+sjDVnBzXPOyMFBY=; b=iVl0Wm0SneABy93Po0xh9VvGBCSy59u47chW0Bm5QY6gYHYxhEpe9OxLTanIn8Fghz g54mQNM8pXO7s7suxNpw+CduiA7o/2m9e8QYEfBiJbTIxHPpFShPQkyTCQ4C2cwb1Gkb jPckR5SJP5WKDRGXugHsmiUyEuihAS47K5iOqgmF4p/ebURCHa4sd60cBxCG4ck/OHsO E0/znkOttyA/Lc8FsbkCLDiByuFu2po2IKQSsnGJ+EHpUEdQiHcW/kuRe2iaD12w2kLG GB45/HMNk1xNnZgSHklGIJhephD9Awc9DzVPK2DBl0uTXJ7dZg/vtHYfZkMbjkoD211P NVfg== 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=nxp.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id g4si6678069plb.188.2019.05.16.19.48.53; Thu, 16 May 2019 19:49:08 -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; 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=nxp.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727578AbfEQCqc (ORCPT + 99 others); Thu, 16 May 2019 22:46:32 -0400 Received: from inva021.nxp.com ([92.121.34.21]:45766 "EHLO inva021.nxp.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725933AbfEQCqc (ORCPT ); Thu, 16 May 2019 22:46:32 -0400 Received: from inva021.nxp.com (localhost [127.0.0.1]) by inva021.eu-rdc02.nxp.com (Postfix) with ESMTP id EBB69200065; Fri, 17 May 2019 04:46:28 +0200 (CEST) Received: from invc005.ap-rdc01.nxp.com (invc005.ap-rdc01.nxp.com [165.114.16.14]) by inva021.eu-rdc02.nxp.com (Postfix) with ESMTP id 4585720025F; Fri, 17 May 2019 04:46:23 +0200 (CEST) Received: from localhost.localdomain (mega.ap.freescale.net [10.192.208.232]) by invc005.ap-rdc01.nxp.com (Postfix) with ESMTP id 0A047402AE; Fri, 17 May 2019 10:46:15 +0800 (SGT) From: Ran Wang To: Li Yang , Rob Herring , Mark Rutland Cc: "Rafael J . Wysocki" , Pavel Machek , Len Brown , Greg Kroah-Hartman , linuxppc-dev@lists.ozlabs.org, linux-arm-kernel@lists.infradead.org, devicetree@vger.kernel.org, linux-kernel@vger.kernel.org, linux-pm@vger.kernel.org, Ran Wang Subject: [PATCH 1/3] PM: wakeup: Add routine to help fetch wakeup source object. Date: Fri, 17 May 2019 10:47:46 +0800 Message-Id: <20190517024748.15534-1-ran.wang_1@nxp.com> X-Mailer: git-send-email 2.17.1 X-Virus-Scanned: ClamAV using ClamSMTP Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Some user might want to go through all registered wakeup sources and doing things accordingly. For example, SoC PM driver might need to do HW programming to prevent powering down specific IP which wakeup source depending on. And is user's responsibility to identify if this wakeup source he is interested in. Signed-off-by: Ran Wang --- drivers/base/power/wakeup.c | 18 ++++++++++++++++++ include/linux/pm_wakeup.h | 3 +++ 2 files changed, 21 insertions(+), 0 deletions(-) diff --git a/drivers/base/power/wakeup.c b/drivers/base/power/wakeup.c index 5fa1898..8d75795 100644 --- a/drivers/base/power/wakeup.c +++ b/drivers/base/power/wakeup.c @@ -14,6 +14,7 @@ #include #include #include +#include #include #include @@ -236,6 +237,22 @@ void wakeup_source_unregister(struct wakeup_source *ws) } } EXPORT_SYMBOL_GPL(wakeup_source_unregister); +/** + * wakeup_source_get_next - Get next wakeup source from the list + * @ws: Previous wakeup source object, null means caller want first one. + */ +struct wakeup_source *wakeup_source_get_next(struct wakeup_source *ws) +{ + struct list_head *ws_head = &wakeup_sources; + + if (ws) + return list_next_or_null_rcu(ws_head, &ws->entry, + struct wakeup_source, entry); + else + return list_entry_rcu(ws_head->next, + struct wakeup_source, entry); +} +EXPORT_SYMBOL_GPL(wakeup_source_get_next); /** * device_wakeup_attach - Attach a wakeup source object to a device object. @@ -252,6 +269,7 @@ static int device_wakeup_attach(struct device *dev, struct wakeup_source *ws) return -EEXIST; } dev->power.wakeup = ws; + ws->attached_dev = dev; if (dev->power.wakeirq) device_wakeup_attach_irq(dev, dev->power.wakeirq); spin_unlock_irq(&dev->power.lock); diff --git a/include/linux/pm_wakeup.h b/include/linux/pm_wakeup.h index 4238dde..1335487 100644 --- a/include/linux/pm_wakeup.h +++ b/include/linux/pm_wakeup.h @@ -50,6 +50,7 @@ * @wakeup_count: Number of times the wakeup source might abort suspend. * @active: Status of the wakeup source. * @has_timeout: The wakeup source has been activated with a timeout. + * @attached_dev: The device it attached to */ struct wakeup_source { const char *name; @@ -70,6 +71,7 @@ struct wakeup_source { unsigned long wakeup_count; bool active:1; bool autosleep_enabled:1; + struct device *attached_dev; }; #ifdef CONFIG_PM_SLEEP @@ -102,6 +104,7 @@ static inline void device_set_wakeup_path(struct device *dev) extern void wakeup_source_remove(struct wakeup_source *ws); extern struct wakeup_source *wakeup_source_register(const char *name); extern void wakeup_source_unregister(struct wakeup_source *ws); +extern struct wakeup_source *wakeup_source_get_next(struct wakeup_source *ws); extern int device_wakeup_enable(struct device *dev); extern int device_wakeup_disable(struct device *dev); extern void device_set_wakeup_capable(struct device *dev, bool capable); -- 1.7.1