All of lore.kernel.org
 help / color / mirror / Atom feed
From: "Rafael J. Wysocki" <rjw@sisk.pl>
To: Greg KH <gregkh@suse.de>
Cc: LKML <linux-kernel@vger.kernel.org>,
	Jesse Barnes <jbarnes@virtuousgeek.org>,
	mingo@redhat.com, "H. Peter Anvin" <hpa@zytor.com>,
	Kay Sievers <kay.sievers@suse.de>,
	Linux PM mailing list <linux-pm@lists.linux-foundation.org>,
	tglx@linutronix.de
Subject: Re: [RFC][Update][PATCH 1/2] Introduce struct syscore_ops and related functionality
Date: Fri, 11 Mar 2011 21:13:13 +0100	[thread overview]
Message-ID: <201103112113.13807.rjw__24185.0924947814$1299874457$gmane$org@sisk.pl> (raw)
In-Reply-To: <20110311171131.GA10437@suse.de>

On Friday, March 11, 2011, Greg KH wrote:
> On Thu, Mar 10, 2011 at 12:30:45PM +0100, Rafael J. Wysocki wrote:
> > On Thursday, March 10, 2011, Alan Stern wrote:
> > > On Thu, 10 Mar 2011, Rafael J. Wysocki wrote:
> > > 
> > > > Some subsystems need to carry out suspend/resume and shutdown
> > > > operations with one CPU on-line and interrupts disabled.  The only
> > > > way to register such operations is to define a sysdev class and
> > > > a sysdev specifically for this purpose which is cumbersome and
> > > > inefficient.  Moreover, the arguments taken by sysdev suspend,
> > > > resume and shutdown callbacks are practically never necessary.
> > > > 
> > > > For this reason, introduce a simpler interface allowing subsystems
> > > > to register operations to be executed very late during system suspend
> > > > and shutdown and very early during resume in the form of
> > > > strcut syscore_ops objects.
> > > 
> > > ...
> > > 
> > > > Index: linux-2.6/drivers/base/syscore.c
> > > > ===================================================================
> > > > --- /dev/null
> > > > +++ linux-2.6/drivers/base/syscore.c
> > > 
> > > It's true that the existing sys.c file lies in drivers/base; this is
> > > presumably because it handles a bunch of class-related registration
> > > stuff.  Now you're getting rid of all that, leaving just the
> > > power-related operations, so doesn't it make more sense to put this
> > > file in drivers/base/power?
> > > 
> > > > +/**
> > > > + * syscore_suspend - Execute all the registered system core suspend callbacks.
> > > > + *
> > > > + * This function is executed with one CPU on-line and disabled interrupts.
> > > > + */
> > > > +int syscore_suspend(void)
> > > > +{
> > > > +	struct syscore_ops *ops;
> > > > +
> > > > +	list_for_each_entry_reverse(ops, &syscore_ops_list, node)
> > > > +		if (ops->suspend) {
> > > > +			int ret = ops->suspend();
> > > > +			if (ret) {
> > > > +				pr_err("PM: System core suspend callback "
> > > > +					"%pF failed.\n", ops->suspend);
> > > > +				return ret;
> > > 
> > > If an error occurs, you need to go back and resume all the things that
> > > were suspended.  At least, that's what the code in sysdev_suspend does.
> > > 
> > > > +			}
> > > > +		}
> > > > +
> > > > +	return 0;
> > > > +}
> > 
> > Below is a new version of the patch.  I've taken your comment on the failing
> > suspend into account, fix the list traversal direction in syscore_shutdown()
> > and added some debug statements.
> > 
> > Thanks,
> > Rafael
> > 
> > ---
> > Some subsystems need to carry out suspend/resume and shutdown
> > operations with one CPU on-line and interrupts disabled.  The only
> > way to register such operations is to define a sysdev class and
> > a sysdev specifically for this purpose which is cumbersome and
> > inefficient.  Moreover, the arguments taken by sysdev suspend,
> > resume and shutdown callbacks are practically never necessary.
> > 
> > For this reason, introduce a simpler interface allowing subsystems
> > to register operations to be executed very late during system suspend
> > and shutdown and very early during resume in the form of
> > strcut syscore_ops objects.
> > 
> > ---
> >  drivers/base/Makefile       |    2 
> >  drivers/base/syscore.c      |  107 ++++++++++++++++++++++++++++++++++++++++++++
> >  include/linux/syscore_ops.h |   29 +++++++++++
> >  kernel/power/hibernate.c    |    9 +++
> >  kernel/power/suspend.c      |    4 +
> >  kernel/sys.c                |    4 +
> >  6 files changed, 154 insertions(+), 1 deletion(-)
> > 
> > Index: linux-2.6/include/linux/syscore_ops.h
> > ===================================================================
> > --- /dev/null
> > +++ linux-2.6/include/linux/syscore_ops.h
> > @@ -0,0 +1,29 @@
> > +/*
> > + *  syscore_ops.h - System core operations.
> > + *
> > + *  Copyright (C) 2011 Rafael J. Wysocki <rjw@sisk.pl>, Novell Inc.
> > + *
> > + *  This file is released under the GPLv2.
> > + */
> > +
> > +#ifndef _LINUX_SYSCORE_OPS_H
> > +#define _LINUX_SYSCORE_OPS_H
> > +
> > +#include <linux/list.h>
> > +
> > +struct syscore_ops {
> > +	struct list_head node;
> > +	int (*suspend)(void);
> > +	void (*resume)(void);
> > +	void (*shutdown)(void);
> > +};
> > +
> > +extern void register_syscore_ops(struct syscore_ops *ops);
> > +extern void unregister_syscore_ops(struct syscore_ops *ops);
> > +#ifdef CONFIG_PM_SLEEP
> > +extern int syscore_suspend(void);
> > +extern void syscore_resume(void);
> > +#endif
> 
> Minor nit, provide inline functions for these when CONFIG_PM_SLEEP is
> not defined so the code still builds?

The code using them depends on CONFIG_PM_SLEEP and they are nobody else's
business. :-)

I could avoid using the #ifdef here, but I thought I'd make it clear that
these things were only available when CONFIG_PM_SLEEP was set.

> Other than that, this looks great to me, thanks for doing this.

No problem. :-)

> Do you want me to take it through my tree, or yours?

I can handle it if you give me an ack.

Do you think I should push [1/2] alone for 2.6.39 or wait for the patches
converting subsystems to use this stuff to be ready?  I think it'll take
some time to prepare them, especialy for things in the ARM tree that use
sysdevs in some interesting ways ...

Thanks,
Rafael

  reply	other threads:[~2011-03-11 20:13 UTC|newest]

Thread overview: 198+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2011-03-10  0:31 [RFC][PATCH 0/2] Allow subsystems to avoid using sysdevs for defining "core" PM callbacks Rafael J. Wysocki
2011-03-10  0:33 ` [RFC][PATCH 1/2] Introduce struct syscore_ops and related functionality Rafael J. Wysocki
2011-03-10  0:33 ` Rafael J. Wysocki
2011-03-10  3:33   ` [linux-pm] " Alan Stern
2011-03-10 10:42     ` Rafael J. Wysocki
2011-03-10 10:42     ` Rafael J. Wysocki
2011-03-10 11:30     ` [RFC][Update][PATCH " Rafael J. Wysocki
2011-03-11 17:11       ` Greg KH
2011-03-11 17:11       ` Greg KH
2011-03-11 20:13         ` Rafael J. Wysocki [this message]
2011-03-11 20:13         ` Rafael J. Wysocki
2011-03-11 20:16           ` Greg KH
2011-03-11 20:33             ` Rafael J. Wysocki
2011-03-11 20:33             ` Rafael J. Wysocki
2011-03-11 20:16           ` Greg KH
2011-03-10 11:30     ` Rafael J. Wysocki
2011-03-10  3:33   ` [RFC][PATCH " Alan Stern
2011-03-10  0:34 ` [RFC][PATCH 2/2] Convert several sysdev users to using struct syscore_ops Rafael J. Wysocki
2011-03-10  0:34 ` Rafael J. Wysocki
2011-03-11 17:12   ` Greg KH
2011-03-11 17:12   ` Greg KH
2011-03-11 20:29     ` Rafael J. Wysocki
2011-03-11 20:29     ` Rafael J. Wysocki
2011-03-11 20:33       ` Greg KH
2011-03-11 20:33       ` Greg KH
2011-03-11 20:45         ` Rafael J. Wysocki
2011-03-11 20:45         ` Rafael J. Wysocki
2011-03-10 13:05 ` [RFC][PATCH 0/2] Allow subsystems to avoid using sysdevs for defining "core" PM callbacks Kay Sievers
2011-03-10 13:05 ` Kay Sievers
2011-03-10 19:04   ` Rafael J. Wysocki
2011-03-10 19:04   ` Rafael J. Wysocki
2011-03-12 21:12 ` [PATCH 0/8] " Rafael J. Wysocki
2011-03-12 21:12   ` Rafael J. Wysocki
2011-03-12 21:13   ` [PATCH 1/8] PM / Core: Introcude struct syscore_ops Rafael J. Wysocki
2011-03-12 21:13   ` Rafael J. Wysocki
2011-03-12 21:15   ` [PATCH 2/8] x86: Use syscore_ops instead of sysdev classes and sysdevs Rafael J. Wysocki
2011-03-12 21:15   ` Rafael J. Wysocki
2011-03-13 14:23     ` Thomas Gleixner
2011-03-13 15:07       ` Rafael J. Wysocki
2011-03-13 15:07       ` Rafael J. Wysocki
2011-03-13 14:23     ` Thomas Gleixner
2011-03-12 21:16   ` [PATCH 3/8] ACPI: Use syscore_ops instead of sysdev class and sysdev Rafael J. Wysocki
2011-03-18 21:38     ` Len Brown
2011-03-18 21:38       ` Len Brown
2011-03-12 21:16   ` Rafael J. Wysocki
2011-03-12 21:17   ` [PATCH 4/8] timekeeping: " Rafael J. Wysocki
2011-03-13 13:56     ` Thomas Gleixner
2011-03-13 13:56     ` Thomas Gleixner
2011-03-13 15:08       ` Rafael J. Wysocki
2011-03-13 15:08       ` Rafael J. Wysocki
2011-03-12 21:17   ` Rafael J. Wysocki
2011-03-12 21:18   ` [PATCH 5/8] PCI / Intel IOMMU: " Rafael J. Wysocki
2011-03-12 21:18   ` Rafael J. Wysocki
2011-06-02 17:30     ` Tony Luck
2011-06-06 17:57       ` Rafael J. Wysocki
2011-06-06 17:58         ` Luck, Tony
2011-06-06 17:58         ` Luck, Tony
2011-06-06 17:57       ` Rafael J. Wysocki
2011-06-02 17:30     ` Tony Luck
2011-03-12 21:18   ` [PATCH 6/8] KVM: " Rafael J. Wysocki
2011-03-12 21:18   ` Rafael J. Wysocki
2011-03-12 21:20   ` [PATCH 7/8] cpufreq: Use syscore_ops for boot CPU suspend/resume Rafael J. Wysocki
2011-03-12 21:20   ` Rafael J. Wysocki
2011-03-15 21:43     ` [Update, v2] " Rafael J. Wysocki
2011-03-15 21:43     ` Rafael J. Wysocki
2011-03-12 21:21   ` [PATCH 8/8] Introduce ARCH_NO_SYSDEV_OPS config option Rafael J. Wysocki
2011-03-13 13:55     ` Thomas Gleixner
2011-03-13 13:55       ` Thomas Gleixner
2011-03-13 15:30       ` [Update] " Rafael J. Wysocki
2011-03-13 15:30       ` Rafael J. Wysocki
2011-03-12 21:21   ` Rafael J. Wysocki
2011-03-13 13:02   ` [PATCH 9-10/10] Allow subsystems to avoid using sysdevs for defining "core" PM callbacks Rafael J. Wysocki
2011-03-13 13:02     ` Rafael J. Wysocki
2011-03-13 13:03     ` [PATCH 9/10] sh: Use struct syscore_ops instead of sysdev class and sysdev R. J. Wysocki
2011-03-13 13:03       ` R. J. Wysocki
2011-03-17  8:20       ` Paul Mundt
2011-03-17  8:20         ` Paul Mundt
2011-03-19  0:47         ` Rafael J. Wysocki
2011-03-19  0:47           ` Rafael J. Wysocki
2011-03-22 14:04           ` Paul Mundt
2011-03-22 14:04           ` Paul Mundt
2011-03-22 14:04             ` Paul Mundt
2011-03-22 14:19             ` [PATCH 9/10] sh: Use struct syscore_ops instead of sysdev Kay Sievers
2011-03-22 14:19               ` [PATCH 9/10] sh: Use struct syscore_ops instead of sysdev class and sysdev Kay Sievers
2011-03-22 20:30               ` Rafael J. Wysocki
2011-03-22 20:30               ` Rafael J. Wysocki
2011-03-22 20:30                 ` Rafael J. Wysocki
2011-03-22 20:39                 ` Kay Sievers
2011-03-22 20:39                 ` [PATCH 9/10] sh: Use struct syscore_ops instead of sysdev Kay Sievers
2011-03-22 20:39                   ` [PATCH 9/10] sh: Use struct syscore_ops instead of sysdev class and sysdev Kay Sievers
2011-03-22 21:00                   ` Rafael J. Wysocki
2011-03-22 21:00                   ` Rafael J. Wysocki
2011-03-22 21:00                     ` Rafael J. Wysocki
2011-03-22 21:12                     ` [PATCH 9/10] sh: Use struct syscore_ops instead of sysdev Kay Sievers
2011-03-22 21:12                       ` [PATCH 9/10] sh: Use struct syscore_ops instead of sysdev class and sysdev Kay Sievers
2011-03-22 21:49                       ` Paul Mundt
2011-03-22 21:49                       ` Paul Mundt
2011-03-22 21:49                         ` Paul Mundt
2011-03-22 22:00                         ` Kay Sievers
2011-03-22 22:00                         ` [PATCH 9/10] sh: Use struct syscore_ops instead of sysdev Kay Sievers
2011-03-22 22:00                           ` [PATCH 9/10] sh: Use struct syscore_ops instead of sysdev class and sysdev Kay Sievers
2011-03-22 22:23                           ` Rafael J. Wysocki
2011-03-22 22:23                           ` Rafael J. Wysocki
2011-03-22 22:23                             ` Rafael J. Wysocki
2011-03-22 22:44                             ` [PATCH 9/10] sh: Use struct syscore_ops instead of sysdev Kay Sievers
2011-03-22 22:44                               ` [PATCH 9/10] sh: Use struct syscore_ops instead of sysdev class and sysdev Kay Sievers
2011-03-22 23:32                               ` Rafael J. Wysocki
2011-03-22 23:32                               ` Rafael J. Wysocki
2011-03-22 23:32                                 ` Rafael J. Wysocki
2011-03-22 23:46                                 ` Kay Sievers
2011-03-22 23:46                                 ` [PATCH 9/10] sh: Use struct syscore_ops instead of sysdev Kay Sievers
2011-03-22 23:46                                   ` [PATCH 9/10] sh: Use struct syscore_ops instead of sysdev class and sysdev Kay Sievers
2011-03-22 23:50                                   ` Rafael J. Wysocki
2011-03-22 23:50                                     ` Rafael J. Wysocki
2011-03-22 23:50                                   ` Rafael J. Wysocki
2011-03-23  9:45                               ` [PATCH 9/10] sh: Use struct syscore_ops instead of sysdev Russell King - ARM Linux
2011-03-23  9:45                                 ` [PATCH 9/10] sh: Use struct syscore_ops instead of sysdev class and sysdev Russell King - ARM Linux
2011-03-23  9:45                               ` Russell King - ARM Linux
2011-03-22 22:44                             ` Kay Sievers
2011-03-22 22:23                           ` Paul Mundt
2011-03-22 22:23                             ` Paul Mundt
2011-03-23 11:12                             ` Mark Brown
2011-03-23 11:12                             ` [PATCH 9/10] sh: Use struct syscore_ops instead of sysdev Mark Brown
2011-03-23 11:12                               ` [PATCH 9/10] sh: Use struct syscore_ops instead of sysdev class and sysdev Mark Brown
2011-03-23 11:28                               ` Paul Mundt
2011-03-23 11:28                                 ` Paul Mundt
2011-03-23 11:28                               ` Paul Mundt
2011-03-22 22:23                           ` Paul Mundt
2011-03-22 22:05                       ` Rafael J. Wysocki
2011-03-22 22:05                         ` Rafael J. Wysocki
2011-03-22 22:20                         ` Kay Sievers
2011-03-22 22:20                         ` [PATCH 9/10] sh: Use struct syscore_ops instead of sysdev Kay Sievers
2011-03-22 22:20                           ` [PATCH 9/10] sh: Use struct syscore_ops instead of sysdev class and sysdev Kay Sievers
2011-03-22 22:42                           ` Rafael J. Wysocki
2011-03-22 22:42                           ` Rafael J. Wysocki
2011-03-22 22:42                             ` Rafael J. Wysocki
2011-03-22 22:56                             ` Kay Sievers
2011-03-22 22:56                             ` [PATCH 9/10] sh: Use struct syscore_ops instead of sysdev Kay Sievers
2011-03-22 22:56                               ` [PATCH 9/10] sh: Use struct syscore_ops instead of sysdev class and sysdev Kay Sievers
2011-03-22 23:05                         ` [PATCH 9/10] sh: Use struct syscore_ops instead of sysdev Kay Sievers
2011-03-22 23:05                           ` [PATCH 9/10] sh: Use struct syscore_ops instead of sysdev class and sysdev Kay Sievers
2011-03-22 23:47                           ` Rafael J. Wysocki
2011-03-22 23:47                             ` Rafael J. Wysocki
2011-03-22 23:47                           ` Rafael J. Wysocki
2011-03-22 23:05                         ` Kay Sievers
2011-03-22 22:05                       ` Rafael J. Wysocki
2011-03-22 21:12                     ` Kay Sievers
2011-03-22 14:19             ` Kay Sievers
2011-03-22 20:19             ` Rafael J. Wysocki
2011-03-22 20:19             ` Rafael J. Wysocki
2011-03-22 20:19               ` Rafael J. Wysocki
2011-03-23  9:59               ` Paul Mundt
2011-03-23  9:59                 ` Paul Mundt
2011-03-23 20:39                 ` Rafael J. Wysocki
2011-03-23 20:39                 ` Rafael J. Wysocki
2011-03-23 20:39                   ` Rafael J. Wysocki
2011-03-23  9:59               ` Paul Mundt
2011-03-19  0:47         ` Rafael J. Wysocki
2011-03-17  8:20       ` Paul Mundt
2011-03-13 13:03     ` R. J. Wysocki
2011-03-13 13:04     ` [PATCH 10/10] ARM: Use struct syscore_ops instead of sysdevs for PM in timer and leds Rafael J. Wysocki
2011-03-13 13:04     ` Rafael J. Wysocki
2011-03-13 13:04       ` Rafael J. Wysocki
2011-03-14  9:06       ` Stephen Boyd
2011-03-14  9:06       ` [PATCH 10/10] ARM: Use struct syscore_ops instead of sysdevs Stephen Boyd
2011-03-14  9:06         ` [PATCH 10/10] ARM: Use struct syscore_ops instead of sysdevs for PM in timer and leds Stephen Boyd
2011-03-14 19:54         ` [Update] " Rafael J. Wysocki
2011-03-14 19:54         ` Rafael J. Wysocki
2011-03-14 19:54           ` Rafael J. Wysocki
2011-03-13 13:02   ` [PATCH 9-10/10] Allow subsystems to avoid using sysdevs for defining "core" PM callbacks Rafael J. Wysocki
2011-03-21 23:31   ` [PATCH 0/6] Do not use sysdevs for implementing "core" PM operations on x86 Rafael J. Wysocki
2011-03-21 23:31   ` Rafael J. Wysocki
2011-03-21 23:34     ` [PATCH 1/6] x86: Use syscore_ops instead of sysdev classes and sysdevs Rafael J. Wysocki
2011-03-21 23:34     ` Rafael J. Wysocki
2011-03-21 23:35     ` [PATCH 2/6] timekeeping: Use syscore_ops instead of sysdev class and sysdev Rafael J. Wysocki
2011-03-21 23:35     ` Rafael J. Wysocki
2011-03-21 23:36     ` [PATCH 3/6] PCI / Intel IOMMU: " Rafael J. Wysocki
2011-03-22 10:57       ` Joerg Roedel
2011-03-22 22:07         ` Rafael J. Wysocki
2011-03-22 22:07         ` Rafael J. Wysocki
2011-03-23  7:48           ` Roedel, Joerg
2011-03-23  7:48           ` Roedel, Joerg
2011-03-22 10:57       ` Joerg Roedel
2011-03-21 23:36     ` Rafael J. Wysocki
2011-03-21 23:37     ` [PATCH 4/6] KVM: " Rafael J. Wysocki
2011-03-21 23:37     ` Rafael J. Wysocki
2011-03-22  9:18       ` Avi Kivity
2011-03-22  9:18       ` Avi Kivity
2011-03-21 23:38     ` [PATCH 5/6] cpufreq: Use syscore_ops for boot CPU suspend/resume (v2) Rafael J. Wysocki
2011-03-21 23:38     ` Rafael J. Wysocki
2011-03-21 23:38     ` [PATCH 6/6] Introduce ARCH_NO_SYSDEV_OPS config option (v2) Rafael J. Wysocki
2011-03-21 23:38     ` Rafael J. Wysocki
2011-03-22 10:32     ` [PATCH 0/6] Do not use sysdevs for implementing "core" PM operations on x86 Ingo Molnar
2011-03-22 20:33       ` Rafael J. Wysocki
2011-03-22 20:33       ` Rafael J. Wysocki
2011-03-25 22:51         ` [GIT PULL] More power management updates for 2.6.39 Rafael J. Wysocki
2011-03-25 22:51         ` Rafael J. Wysocki
2011-03-22 10:32     ` [PATCH 0/6] Do not use sysdevs for implementing "core" PM operations on x86 Ingo Molnar

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to='201103112113.13807.rjw__24185.0924947814$1299874457$gmane$org@sisk.pl' \
    --to=rjw@sisk.pl \
    --cc=gregkh@suse.de \
    --cc=hpa@zytor.com \
    --cc=jbarnes@virtuousgeek.org \
    --cc=kay.sievers@suse.de \
    --cc=linux-kernel@vger.kernel.org \
    --cc=linux-pm@lists.linux-foundation.org \
    --cc=mingo@redhat.com \
    --cc=tglx@linutronix.de \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.