From: Johan Hovold <johan@kernel.org>
To: Guenter Roeck <linux@roeck-us.net>
Cc: linux-kernel@vger.kernel.org, linux-pm@vger.kernel.org,
"Alan Cox" <gnomes@lxorguk.ukuu.org.uk>,
"Alexander Graf" <agraf@suse.de>,
"Andrew Morton" <akpm@linux-foundation.org>,
"Geert Uytterhoeven" <geert@linux-m68k.org>,
"Heiko Stuebner" <heiko@sntech.de>,
"Lee Jones" <lee.jones@linaro.org>,
"Len Brown" <len.brown@intel.com>, "Pavel Machek" <pavel@ucw.cz>,
"Philippe Rétornaz" <philippe.retornaz@gmail.com>,
"Rafael J. Wysocki" <rjw@rjwysocki.net>,
"Romain Perier" <romain.perier@gmail.com>
Subject: Re: [PATCH v2 01/47] kernel: Add support for poweroff handler call chain
Date: Tue, 21 Oct 2014 11:34:05 +0200 [thread overview]
Message-ID: <20141021093405.GA2113@localhost> (raw)
In-Reply-To: <1413864783-3271-2-git-send-email-linux@roeck-us.net>
On Mon, Oct 20, 2014 at 09:12:17PM -0700, Guenter Roeck wrote:
> v2:
> - poweroff -> power_off
Do you want to stick to power[-_ ]off consistently throughout?
> - Add defines for default priorities
> - Use raw notifiers protected by spinlocks instead of atomic notifiers
> - Add register_poweroff_handler_simple
> - Add devm_register_power_off_handler
>
> include/linux/pm.h | 22 ++++
> kernel/power/Makefile | 1 +
> kernel/power/poweroff_handler.c | 252 ++++++++++++++++++++++++++++++++++++++++
> 3 files changed, 275 insertions(+)
> create mode 100644 kernel/power/poweroff_handler.c
>
> diff --git a/include/linux/pm.h b/include/linux/pm.h
> index 383fd68..7e0cb36 100644
> --- a/include/linux/pm.h
> +++ b/include/linux/pm.h
> @@ -34,7 +34,29 @@
> extern void (*pm_power_off)(void);
> extern void (*pm_power_off_prepare)(void);
>
> +/*
> + * Callbacks to manage poweroff handlers
power-off
> + */
> +
> +struct notifier_block;
> struct device; /* we have a circular dep with device.h */
> +
> +int register_power_off_handler(struct notifier_block *);
> +int devm_register_power_off_handler(struct device *, struct notifier_block *);
> +int register_power_off_handler_simple(void (*function)(void), int priority);
> +int unregister_power_off_handler(struct notifier_block *);
> +void do_kernel_power_off(void);
> +bool have_kernel_power_off(void);
> +
> +/*
> + * Pre-defined poweroff handler priorities
power-off
> + */
> +#define POWEROFF_PRIORITY_FALLBACK 0
> +#define POWEROFF_PRIORITY_LOW 64
> +#define POWEROFF_PRIORITY_DEFAULT 128
> +#define POWEROFF_PRIORITY_HIGH 192
> +#define POWEROFF_PRIORITY_HIGHEST 255
I think at least these ones should match the interface function and have
a POWER_OFF_PRIORITY_ prefix.
> +
> #ifdef CONFIG_VT_CONSOLE_SLEEP
> extern void pm_vt_switch_required(struct device *dev, bool required);
> extern void pm_vt_switch_unregister(struct device *dev);
> diff --git a/kernel/power/Makefile b/kernel/power/Makefile
> index 29472bf..4d9f0c7 100644
> --- a/kernel/power/Makefile
> +++ b/kernel/power/Makefile
> @@ -2,6 +2,7 @@
> ccflags-$(CONFIG_PM_DEBUG) := -DDEBUG
>
> obj-y += qos.o
> +obj-y += poweroff_handler.o
> obj-$(CONFIG_PM) += main.o
> obj-$(CONFIG_VT_CONSOLE_SLEEP) += console.o
> obj-$(CONFIG_FREEZER) += process.o
> diff --git a/kernel/power/poweroff_handler.c b/kernel/power/poweroff_handler.c
> new file mode 100644
> index 0000000..aeb4736
> --- /dev/null
> +++ b/kernel/power/poweroff_handler.c
power_off_handler.c?
> @@ -0,0 +1,252 @@
> +/*
> + * linux/kernel/power/poweroff_handler.c - Poweroff handling functions
> + *
> + * Copyright (c) 2014 Guenter Roeck
> + *
> + * This program is free software; you can redistribute it and/or
> + * modify it under the terms of the GNU General Public Licence
> + * as published by the Free Software Foundation; either version
> + * 2 of the Licence, or (at your option) any later version.
> + */
> +
> +#define pr_fmt(fmt) "poweroff: " fmt
power-off:?
There's a bunch of these introduced by the driver patches as well (e.g.
poweroff_nb).
Johan
next prev parent reply other threads:[~2014-10-21 9:37 UTC|newest]
Thread overview: 151+ messages / expand[flat|nested] mbox.gz Atom feed top
2014-10-21 4:12 [PATCH v2 00/47] kernel: Add support for poweroff handler call chain Guenter Roeck
2014-10-21 4:12 ` [PATCH v2 01/47] " Guenter Roeck
2014-10-21 6:46 ` Philippe Rétornaz
2014-10-21 13:29 ` Guenter Roeck
2014-10-22 8:02 ` Philippe Rétornaz
2014-10-22 13:22 ` Guenter Roeck
2014-10-21 9:34 ` Johan Hovold [this message]
2014-10-21 10:30 ` Lee Jones
2014-10-21 13:32 ` Guenter Roeck
2014-10-21 13:34 ` Guenter Roeck
2014-10-21 15:50 ` Guenter Roeck
2014-10-21 18:27 ` Johan Hovold
2014-10-21 12:26 ` Rafael J. Wysocki
2014-10-21 12:44 ` Heiko Stübner
2014-10-21 13:17 ` Guenter Roeck
2014-10-21 14:15 ` Rafael J. Wysocki
2014-10-21 16:11 ` Guenter Roeck
2014-10-21 4:12 ` [PATCH v2 02/47] memory: emif: Use API function to determine poweroff capability Guenter Roeck
2014-10-22 18:48 ` Santosh Shilimkar
2014-10-22 22:18 ` Guenter Roeck
2014-10-21 4:12 ` [PATCH v2 03/47] hibernate: Call have_kernel_power_off instead of checking pm_power_off Guenter Roeck
2014-10-21 4:12 ` [PATCH v2 04/47] m68k: Replace mach_power_off with pm_power_off Guenter Roeck
2014-10-21 4:12 ` Guenter Roeck
2014-10-22 3:50 ` Greg Ungerer
2014-10-22 3:50 ` Greg Ungerer
2014-10-22 3:50 ` Greg Ungerer
2014-10-21 4:12 ` [PATCH v2 05/47] mfd: as3722: Drop reference to pm_power_off from devicetree bindings Guenter Roeck
2014-10-21 8:15 ` Lee Jones
2014-10-21 4:12 ` [PATCH v2 06/47] gpio-poweroff: " Guenter Roeck
2014-10-21 4:12 ` [PATCH v2 07/47] qnap-poweroff: " Guenter Roeck
2014-10-21 4:12 ` [PATCH v2 08/47] kernel: Move pm_power_off to common code Guenter Roeck
2014-10-21 4:12 ` Guenter Roeck
2014-10-21 4:12 ` Guenter Roeck
2014-10-21 4:12 ` Guenter Roeck
2014-10-21 4:12 ` Guenter Roeck
2014-10-22 15:31 ` Ralf Baechle
2014-10-22 15:31 ` Ralf Baechle
2014-10-22 15:31 ` Ralf Baechle
2014-10-22 15:31 ` Ralf Baechle
2014-10-22 15:31 ` Ralf Baechle
2014-10-22 15:43 ` Guenter Roeck
2014-10-22 15:43 ` Guenter Roeck
2014-10-22 15:43 ` Guenter Roeck
2014-10-22 15:43 ` Guenter Roeck
2014-10-22 15:43 ` Guenter Roeck
2014-10-24 9:47 ` James Hogan
2014-10-24 9:47 ` James Hogan
2014-10-24 9:47 ` [ORLinux] " James Hogan
2014-10-24 9:47 ` James Hogan
2014-10-24 9:47 ` James Hogan
2014-10-24 9:47 ` James Hogan
2014-10-24 9:47 ` James Hogan
2014-10-24 15:53 ` Guenter Roeck
2014-10-24 15:53 ` Guenter Roeck
2014-10-24 15:53 ` Guenter Roeck
2014-10-24 15:53 ` Guenter Roeck
2014-10-24 15:53 ` Guenter Roeck
2014-10-24 9:47 ` James Hogan
2014-10-24 10:02 ` Lennox Wu
2014-10-24 10:02 ` [uml-user] " Lennox Wu
2014-10-24 10:02 ` Lennox Wu
2014-10-24 10:02 ` [uml-devel] " Lennox Wu
2014-10-24 10:02 ` [uml-user] " Lennox Wu
2014-10-24 10:02 ` Lennox Wu
2014-10-24 10:03 ` Lennox Wu
2014-10-24 10:03 ` Lennox Wu
2014-10-24 10:03 ` Lennox Wu
2014-10-24 10:03 ` Lennox Wu
2014-10-24 10:03 ` Lennox Wu
2014-10-24 10:03 ` Lennox Wu
2014-10-24 10:03 ` Lennox Wu
2014-10-24 10:03 ` Lennox Wu
2014-10-24 10:03 ` Lennox Wu
2014-10-24 10:03 ` Lennox Wu
2014-10-24 10:03 ` Lennox Wu
2014-10-24 10:03 ` Lennox Wu
2014-10-21 4:12 ` Guenter Roeck
2014-10-21 4:12 ` Guenter Roeck
2014-10-21 4:12 ` [PATCH v2 09/47] mfd: palmas: Register with kernel poweroff handler Guenter Roeck
2014-10-21 4:12 ` [PATCH v2 10/47] mfd: axp20x: " Guenter Roeck
2014-10-21 4:12 ` [PATCH v2 11/47] mfd: retu: " Guenter Roeck
2014-10-21 4:12 ` [PATCH v2 12/47] mfd: ab8500-sysctrl: " Guenter Roeck
2014-10-21 4:12 ` Guenter Roeck
2014-10-21 4:12 ` Guenter Roeck
2014-10-27 15:59 ` Linus Walleij
2014-10-27 15:59 ` Linus Walleij
2014-10-27 16:42 ` Guenter Roeck
2014-10-27 16:42 ` Guenter Roeck
2014-10-21 4:12 ` [PATCH v2 13/47] mfd: max8907: " Guenter Roeck
2014-10-21 4:12 ` [PATCH v2 14/47] mfd: tps80031: " Guenter Roeck
2014-10-21 4:12 ` [PATCH v2 15/47] mfd: dm355evm_msp: " Guenter Roeck
2014-10-21 4:12 ` [PATCH v2 16/47] mfd: tps6586x: " Guenter Roeck
2014-10-21 4:12 ` [PATCH v2 17/47] mfd: tps65910: " Guenter Roeck
2014-10-21 4:12 ` [PATCH v2 18/47] mfd: twl4030-power: " Guenter Roeck
2014-10-21 4:12 ` [PATCH v2 19/47] mfd: rk808: Register poweroff handler " Guenter Roeck
2014-10-21 4:12 ` [PATCH v2 20/47] mfd: rn5t618: " Guenter Roeck
2014-10-21 4:12 ` [PATCH v2 21/47] ipmi: Register " Guenter Roeck
2014-10-21 4:12 ` [PATCH v2 22/47] power/reset: restart-poweroff: " Guenter Roeck
2014-10-22 21:32 ` Sebastian Reichel
2014-10-22 22:19 ` Guenter Roeck
2014-10-21 4:12 ` [PATCH v2 23/47] power/reset: gpio-poweroff: " Guenter Roeck
2014-10-22 21:32 ` Sebastian Reichel
2014-10-21 4:12 ` [PATCH v2 24/47] power/reset: as3722-poweroff: " Guenter Roeck
2014-10-22 21:33 ` Sebastian Reichel
2014-10-21 4:12 ` [PATCH v2 25/47] power/reset: qnap-poweroff: " Guenter Roeck
2014-10-22 21:33 ` Sebastian Reichel
2014-10-21 4:12 ` [PATCH v2 26/47] power/reset: msm-poweroff: " Guenter Roeck
2014-10-22 21:33 ` Sebastian Reichel
2014-10-21 4:12 ` [PATCH v2 27/47] power/reset: vexpress-poweroff: " Guenter Roeck
2014-10-22 21:34 ` Sebastian Reichel
2014-10-21 4:12 ` [PATCH v2 28/47] power/reset: at91-poweroff: " Guenter Roeck
2014-10-22 21:34 ` Sebastian Reichel
2014-10-21 4:12 ` [PATCH v2 29/47] power/reset: ltc2952-poweroff: " Guenter Roeck
2014-10-22 21:35 ` Sebastian Reichel
2014-10-21 4:12 ` [PATCH v2 30/47] x86: iris: " Guenter Roeck
2014-10-21 4:12 ` [PATCH v2 31/47] x86: apm: " Guenter Roeck
2014-10-21 8:46 ` Jiri Kosina
2014-10-21 4:12 ` [PATCH v2 32/47] x86: olpc: Register xo1 poweroff handler " Guenter Roeck
2014-10-21 4:12 ` [PATCH v2 33/47] staging: nvec: Register " Guenter Roeck
2014-10-21 4:12 ` [PATCH v2 34/47] acpi: Register poweroff handler " Guenter Roeck
2014-10-21 12:27 ` Rafael J. Wysocki
2014-10-21 4:12 ` [PATCH v2 35/47] arm: Register " Guenter Roeck
2014-10-21 4:12 ` Guenter Roeck
2014-10-21 4:12 ` Guenter Roeck
2014-10-21 4:12 ` [PATCH v2 36/47] arm64: psci: " Guenter Roeck
2014-10-21 4:12 ` Guenter Roeck
2014-10-21 4:12 ` Guenter Roeck
2014-10-22 11:23 ` Catalin Marinas
2014-10-22 11:23 ` Catalin Marinas
2014-10-22 15:38 ` Guenter Roeck
2014-10-22 15:38 ` Guenter Roeck
2014-10-22 12:52 ` Mark Rutland
2014-10-22 12:52 ` Mark Rutland
2014-10-22 15:37 ` Guenter Roeck
2014-10-22 15:37 ` Guenter Roeck
2014-10-21 4:12 ` [PATCH v2 37/47] avr32: atngw100: " Guenter Roeck
2014-10-21 4:12 ` [PATCH v2 38/47] ia64: " Guenter Roeck
2014-10-21 4:12 ` Guenter Roeck
2014-10-21 4:12 ` [PATCH v2 39/47] m68k: " Guenter Roeck
2014-10-21 4:12 ` Guenter Roeck
2014-10-21 4:12 ` [PATCH v2 40/47] mips: " Guenter Roeck
2014-10-22 15:32 ` Ralf Baechle
2014-10-22 15:44 ` Guenter Roeck
2014-10-21 4:12 ` [PATCH v2 41/47] sh: " Guenter Roeck
2014-10-21 4:12 ` Guenter Roeck
2014-10-21 4:12 ` [PATCH v2 42/47] x86: lguest: " Guenter Roeck
2014-10-21 4:12 ` [PATCH v2 43/47] x86: ce4100: " Guenter Roeck
2014-10-21 4:13 ` [PATCH v2 44/47] x86: intel-mid: Drop registration of dummy poweroff handlers Guenter Roeck
2014-10-21 4:13 ` [PATCH v2 45/47] x86: pmc_atom: Register poweroff handler with kernel poweroff handler Guenter Roeck
2014-10-21 4:13 ` [PATCH v2 46/47] efi: " Guenter Roeck
2014-10-21 4:13 ` [PATCH v2 47/47] kernel: Remove pm_power_off Guenter Roeck
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=20141021093405.GA2113@localhost \
--to=johan@kernel.org \
--cc=agraf@suse.de \
--cc=akpm@linux-foundation.org \
--cc=geert@linux-m68k.org \
--cc=gnomes@lxorguk.ukuu.org.uk \
--cc=heiko@sntech.de \
--cc=lee.jones@linaro.org \
--cc=len.brown@intel.com \
--cc=linux-kernel@vger.kernel.org \
--cc=linux-pm@vger.kernel.org \
--cc=linux@roeck-us.net \
--cc=pavel@ucw.cz \
--cc=philippe.retornaz@gmail.com \
--cc=rjw@rjwysocki.net \
--cc=romain.perier@gmail.com \
/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.