Received: by 2002:a25:c593:0:0:0:0:0 with SMTP id v141csp2905894ybe; Sun, 8 Sep 2019 03:14:45 -0700 (PDT) X-Google-Smtp-Source: APXvYqx5dk2zucgPInfLJBWXirM0PeSE87d5Py74P3MXPUO0/RiGAWKymdGLMlbveHiFAJ0/YJ82 X-Received: by 2002:a63:eb56:: with SMTP id b22mr16694660pgk.355.1567937684810; Sun, 08 Sep 2019 03:14:44 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1567937684; cv=none; d=google.com; s=arc-20160816; b=geKc6d9Wya8ZVRQQXh4d3YyUoVZn8iQJazMmBnhhf6CwSSJCJtCXKi03NQCfL5wsol SdHdbuX6E6GZQ7LZN/Gc18ypI3GHyJ01pn7LnjYS0kK7Fq/Q65dw8z/X/aLFLyddtuob ovWn4eew+HClQxHjcM9KWxVdhw01hyS4lYzf4tRpH/uM5jv2THV2WH4H1sNTszorQdz5 vfE9A9dD9d6GY5Qp2xeMVi5ID3ipdMgyAvceNydIRjY031DMxjM0YOwpk0d83dOLKODg iy1ohvBKXuK9ZxeKD7mTDOYkUOJ9cz/t0OAtqI7SaPZao2KyeiZxXOEybNTitApuJvaj lCdA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:in-reply-to :content-disposition:mime-version:references:message-id:subject:cc :to:from:date:dkim-signature; bh=pxKRv8jsRZzTGKhj+ioFhgpVS6Dzsmm59+PKHULgKG4=; b=wZQ5nG3Su7YMRvAhyI+ENX1Zvy9jIQ7l1U+Xlu/7VgKyBIa2QMupr+2DVW4rZGjvFV XtsH0XeTPt8u0Z+kR3Z1t6GzzlAuhEqmRFsiMwpT7bvsL9yXlrByJOhTfaQe44KRzGYW +sZsf/tQeBbtdj+rfBn4Kldi+2dqVsOzhm2qDqD130sjFD8dmb92GjLGjYiDIoivlRiR Xh0Rc0FhLqvf4sB5AEU+AvqhqyD2kKduG6JUcQLRGVAUKSUBdzUtmLXNMaQBIb6zJQZQ cyNrVTcvrt6Y77W0lFUOg2sMJBMr3yPzKu8AKYe4+Rwuy3LJuD+plrE3GeKKYFSdMNtG ZKCQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@chromium.org header.s=google header.b=f5qht4kB; 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=chromium.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id bc10si8955898plb.171.2019.09.08.03.14.28; Sun, 08 Sep 2019 03:14:44 -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=pass header.i=@chromium.org header.s=google header.b=f5qht4kB; 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=chromium.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2405756AbfIFXka (ORCPT + 99 others); Fri, 6 Sep 2019 19:40:30 -0400 Received: from mail-pl1-f195.google.com ([209.85.214.195]:33479 "EHLO mail-pl1-f195.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2405729AbfIFXka (ORCPT ); Fri, 6 Sep 2019 19:40:30 -0400 Received: by mail-pl1-f195.google.com with SMTP id t11so3919124plo.0 for ; Fri, 06 Sep 2019 16:40:29 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=chromium.org; s=google; h=date:from:to:cc:subject:message-id:references:mime-version :content-disposition:in-reply-to:user-agent; bh=pxKRv8jsRZzTGKhj+ioFhgpVS6Dzsmm59+PKHULgKG4=; b=f5qht4kBJty1w+M1QEqeEr7xM9Wdo7RR8Rao8IQtESokz+K0NhWhBs5VMOnCX7Rzey n3kQ0m28gB61aIOoyjV4+gonSGVif7/x2NLw+5C8dnvbzZ1XYCWVrxayUITMuHWvrBRj dD0g2Q/1aGyuTiMBmtgbjVBzyk5nKLsPhOcNw= X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:date:from:to:cc:subject:message-id:references :mime-version:content-disposition:in-reply-to:user-agent; bh=pxKRv8jsRZzTGKhj+ioFhgpVS6Dzsmm59+PKHULgKG4=; b=FrSIzVE4cDbihlebfG/zINJes2PHtYz7ZYlgfQx/rxNjQMdGidkr8hRkW4ULltZupZ 4Ug7l24h6aDD42xytol0QvMtI0H8/EwT3dB9uiWnJE5POIfNRgx1LRplpJVTgvZx47ih A/CtXHs2/fIGjpM8Z8kRDEj4vSuyc4ls8/TtyfzepDzdWRecTOO3hlW0cBg2OwjkX9Xf HwXso85JYKHp1MFxGIoLionQkFTebVkNSRG5JLU7F75kNpiYmmFnQKcUvAKbLikRVRn/ 8A306SGe+1SVBnNwG/THHLlpCtfnQbpq4Q/kV4ww6I13EBWbxM9AboZ8kvj8iSo/RVq1 CJfg== X-Gm-Message-State: APjAAAWdfMCsLTRGxioxFlctzgjSJ0QlwSzGNG3wUL4JprS+bjn1FjDl Novx2dWFLyOBwdGgvOsTtZN0BA== X-Received: by 2002:a17:902:864a:: with SMTP id y10mr11724408plt.294.1567813229347; Fri, 06 Sep 2019 16:40:29 -0700 (PDT) Received: from localhost ([2620:15c:202:1:75a:3f6e:21d:9374]) by smtp.gmail.com with ESMTPSA id m9sm927359pjf.11.2019.09.06.16.40.27 (version=TLS1_3 cipher=TLS_AES_128_GCM_SHA256 bits=128/128); Fri, 06 Sep 2019 16:40:28 -0700 (PDT) Date: Fri, 6 Sep 2019 16:40:25 -0700 From: Matthias Kaehlcke To: Ravi Chandra Sadineni Cc: tglx@linutronix.de, mingo@redhat.com, bp@alien8.de, hpa@zytor.com, x86@kernel.org, rjw@rjwysocki.net, pavel@ucw.cz, len.brown@intel.com, gregkh@linuxfoundation.org, bhe@redhat.com, dyoung@redhat.com, linux-kernel@vger.kernel.org, linux-pm@vger.kernel.org, tbroch@chromium.org, trong@google.com Subject: Re: [PATCH 1/2] power: sysfs: Add link to wakeup class device. Message-ID: <20190906234025.GD133864@google.com> References: <20190724174355.255314-1-ravisadineni@chromium.org> <20190724174355.255314-2-ravisadineni@chromium.org> MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Disposition: inline In-Reply-To: <20190724174355.255314-2-ravisadineni@chromium.org> User-Agent: Mutt/1.10.1 (2018-07-13) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi Ravi, On Wed, Jul 24, 2019 at 10:43:54AM -0700, Ravi Chandra Sadineni wrote: > https://patchwork.kernel.org/patch/11045069/ creates a virtual > device To refer to unsubmitted patches in the commit message it is probably better to use the subject ("PM / wakeup: show wakeup sources stats in sysfs") and add a link after '---', or say "${subject}" [1] and put the link at the bottom of the commit message You might want to try again now that the patch has landed :) > under wakeup class for each wake capable device exposing all related > sysfs attributes. But there isn't a symlink from the actual device > node to these virtual devices. This patch creates a symlink from the > actual device to the corresponding wakeup_source device under wakeup > class. > Signed-off-by: Ravi Chandra Sadineni > --- > drivers/base/power/power.h | 2 ++ > drivers/base/power/sysfs.c | 25 +++++++++++++++++++++++++ > drivers/base/power/wakeup.c | 2 ++ > 3 files changed, 29 insertions(+) > > diff --git a/drivers/base/power/power.h b/drivers/base/power/power.h > index c511def48b48..32b0f5c080a9 100644 > --- a/drivers/base/power/power.h > +++ b/drivers/base/power/power.h > @@ -67,6 +67,8 @@ extern void dpm_sysfs_remove(struct device *dev); > extern void rpm_sysfs_remove(struct device *dev); > extern int wakeup_sysfs_add(struct device *dev); > extern void wakeup_sysfs_remove(struct device *dev); > +extern void wakeup_source_sysfs_link_add(struct device *dev); > +extern void wakeup_source_sysfs_link_remove(struct device *dev); the names seem a bit clunky, how about wakeup_sysfs_add/remove_link()? > extern int pm_qos_sysfs_add_resume_latency(struct device *dev); > extern void pm_qos_sysfs_remove_resume_latency(struct device *dev); > extern int pm_qos_sysfs_add_flags(struct device *dev); > diff --git a/drivers/base/power/sysfs.c b/drivers/base/power/sysfs.c > index d713738ce796..fbbdb7b16ac5 100644 > --- a/drivers/base/power/sysfs.c > +++ b/drivers/base/power/sysfs.c > @@ -95,6 +95,7 @@ > const char power_group_name[] = "power"; > EXPORT_SYMBOL_GPL(power_group_name); > > +static const char wakeup_source_symlink_name[] = "wakeup_source"; > static const char ctrl_auto[] = "auto"; > static const char ctrl_on[] = "on"; > > @@ -679,6 +680,30 @@ int dpm_sysfs_add(struct device *dev) > return rc; > } > > +void wakeup_source_sysfs_link_add(struct device *dev) > +{ > + struct wakeup_source *ws; > + int err; > + > + ws = dev->power.wakeup; > + if (ws && ws->dev) { > + err = sysfs_add_link_to_group(&dev->kobj, power_group_name, > + &ws->dev->kobj, wakeup_source_symlink_name); > + if (err) { > + dev_err(dev, > + "could not add %s symlink err %d\n", I'd suggest "could not add '%s' symlink: %d\n", or "could not add 'wakeup_source' symlink: %d\n", the latter is easier to grep. > + wakeup_source_symlink_name, > + err); > + } > + } > +} > + > +void wakeup_source_sysfs_link_remove(struct device *dev) > +{ > + sysfs_remove_link_from_group(&dev->kobj, power_group_name, > + wakeup_source_symlink_name); > +} > + > int wakeup_sysfs_add(struct device *dev) > { > return sysfs_merge_group(&dev->kobj, &pm_wakeup_attr_group); > diff --git a/drivers/base/power/wakeup.c b/drivers/base/power/wakeup.c > index fe779fe13a7f..87dfe401b035 100644 > --- a/drivers/base/power/wakeup.c > +++ b/drivers/base/power/wakeup.c > @@ -270,6 +270,7 @@ static int device_wakeup_attach(struct device *dev, struct wakeup_source *ws) > if (dev->power.wakeirq) > device_wakeup_attach_irq(dev, dev->power.wakeirq); > spin_unlock_irq(&dev->power.lock); > + wakeup_source_sysfs_link_add(dev); > return 0; > } > > @@ -391,6 +392,7 @@ static struct wakeup_source *device_wakeup_detach(struct device *dev) > ws = dev->power.wakeup; > dev->power.wakeup = NULL; > spin_unlock_irq(&dev->power.lock); > + wakeup_source_sysfs_link_remove(dev); you want to do this before the wakeup source is detached.