Received: by 2002:a25:9945:0:0:0:0:0 with SMTP id n5csp4756849ybo; Mon, 20 May 2019 03:52:52 -0700 (PDT) X-Google-Smtp-Source: APXvYqz9kjfTvL97XKf9wpSmLT/oQheVf9C2fOpz0vijPzgQaCimq0+PuNeT7oyPNu9+DIo6ppzQ X-Received: by 2002:aa7:87d7:: with SMTP id i23mr79075359pfo.211.1558349572669; Mon, 20 May 2019 03:52:52 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1558349572; cv=none; d=google.com; s=arc-20160816; b=QLQZlcPddTdkblW9wizBn7d04TpYQvt/w9Mw6xwDhmbLeHVpwzjB0Kn1jzZJ8DUcLT rz1qr6Rj1nBQsnVpaDWhdtXdfXYzM92cO1wvNBcK7py5LDU15RINl2f4kxsDDDeU2SbJ RQ7juIMyf288i5iii5g6xAToqQ+m3LgxkOfqdUHc4yl1Q4UJ0q6MFhNDIaBHjlAr4KoV dyuXJ/KrVSuPAfvTWDaCSWokBNgvv9rAWSagkyWnvE0tBhbi3GOy15KQrgmgdhjOB1DS V2YKeuOGZpH3TgO+vHP+5ZEHA3kXyeawj5OkGghvC8zJqjyHfPsX0B40T/Bf4X9J52VU rb0w== 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=sfXZahb3m6z2Zi4oIkSdY/zBZvAifZj/fKOXnfMLa6U=; b=nlf0PgjRW6aiMBcnrEwTc+MzE5ep1aoZKXOaTeMOAmF9a+AWPahMBVJM0JdnpOxYPN NnlnjjrVokj4vjlVQR/NWgF81h3wWfy1aTzPDbidNXpKrsONRv2yhLkp51JV9NI0U6F3 raAphM9F7MUZe3cCdaz4AC3yTq2/92iBrkIcVMSNJqJuHBEY4v9OcuieD/j8kdEHDQoU 3vsEkLKxldGjOLtuEmJ9cpqWhv7Cj1JGbftigV/iPcX/aQooxHkXe3FnurFUraKdH6Ju 6VYXjojc3AU2XJrIsePKx14Kdo/tKOIowyQuOeq0+suJme9mNQNtisbz5S6r4XMsBgrj GCig== 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 a71si16836878pge.211.2019.05.20.03.52.36; Mon, 20 May 2019 03:52:52 -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 S1732254AbfETJvE (ORCPT + 99 others); Mon, 20 May 2019 05:51:04 -0400 Received: from inva021.nxp.com ([92.121.34.21]:38282 "EHLO inva021.nxp.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1730353AbfETJvD (ORCPT ); Mon, 20 May 2019 05:51:03 -0400 Received: from inva021.nxp.com (localhost [127.0.0.1]) by inva021.eu-rdc02.nxp.com (Postfix) with ESMTP id 483F120028A; Mon, 20 May 2019 11:51:01 +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 4968320018B; Mon, 20 May 2019 11:50:55 +0200 (CEST) Received: from localhost.localdomain (mega.ap.freescale.net [10.192.208.232]) by invc005.ap-rdc01.nxp.com (Postfix) with ESMTP id E68B6402A2; Mon, 20 May 2019 17:50:47 +0800 (SGT) From: Ran Wang To: Li Yang , Rob Herring , Mark Rutland , Pavel Machek Cc: "Rafael J . Wysocki" , 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 v4 1/3] PM: wakeup: Add routine to help fetch wakeup source object. Date: Mon, 20 May 2019 17:52:36 +0800 Message-Id: <20190520095238.29210-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 --- Change in v4: - None. Change in v3: - Adjust indentation of *attached_dev;. Change in v2: - None. 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 5b2b6a0..6904485 100644 --- a/drivers/base/power/wakeup.c +++ b/drivers/base/power/wakeup.c @@ -14,6 +14,7 @@ #include #include #include +#include #include #include @@ -226,6 +227,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. @@ -242,6 +259,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 0ff134d..913b2fb 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 @@ -101,6 +103,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