Re: [PATCH] Hibernation: Add PM_RESTORE_PREPARE and PM_POST_RESTORE notifiers

From: Rafael J. Wysocki
Date: Mon Nov 05 2007 - 17:30:30 EST


On Thursday, 1 of November 2007, Rafael J. Wysocki wrote:
> [Len, please add to the suspend branch.]
> ---
> From: Alan Stern <stern@xxxxxxxxxxxxxxxxxxx>
>
> This patch (as1006) adds PM_RESTORE_PREPARE and PM_POST_RESTORE
> notifiers to the PM core, to be used in analogy with the existing
> PM_HIBERNATION_PREPARE and PM_POST_HIBERNATION notifiers.
>
> Signed-off-by: Alan Stern <stern@xxxxxxxxxxxxxxxxxxx>
> Cc: Pavel Machek <pavel@xxxxxx>
> Cc: Nigel Cunningham <nigel@xxxxxxxxxxxxxxxxxx>
> Signed-off-by: "Rafael J. Wysocki" <rjw@xxxxxxx>
> ---

Please consider this version of the patch as obsolete. An update has just been
sent.

Greetings,
Rafael


> Documentation/power/notifiers.txt | 8 ++++++++
> include/linux/notifier.h | 2 ++
> kernel/power/disk.c | 6 ++++++
> kernel/power/user.c | 27 +++++++++++++++------------
> 4 files changed, 31 insertions(+), 12 deletions(-)
>
> Index: linux-2.6/Documentation/power/notifiers.txt
> ===================================================================
> --- linux-2.6.orig/Documentation/power/notifiers.txt
> +++ linux-2.6/Documentation/power/notifiers.txt
> @@ -28,6 +28,14 @@ PM_POST_HIBERNATION The system memory st
> hibernation. Device drivers' .resume() callbacks have
> been executed and tasks have been thawed.
>
> +PM_RESTORE_PREPARE The system is going to restore a hibernation image.
> + If all goes well the restored kernel will issue a
> + PM_POST_HIBERNATION notification.
> +
> +PM_POST_RESTORE An error occurred during the hibernation restore.
> + Device drivers' .resume() callbacks have been executed
> + and tasks have been thawed.
> +
> PM_SUSPEND_PREPARE The system is preparing for a suspend.
>
> PM_POST_SUSPEND The system has just resumed or an error occured during
> Index: linux-2.6/include/linux/notifier.h
> ===================================================================
> --- linux-2.6.orig/include/linux/notifier.h
> +++ linux-2.6/include/linux/notifier.h
> @@ -230,6 +230,8 @@ static inline int notifier_to_errno(int
> #define PM_POST_HIBERNATION 0x0002 /* Hibernation finished */
> #define PM_SUSPEND_PREPARE 0x0003 /* Going to suspend the system */
> #define PM_POST_SUSPEND 0x0004 /* Suspend finished */
> +#define PM_RESTORE_PREPARE 0x0005 /* Going to restore a saved image */
> +#define PM_POST_RESTORE 0x0006 /* Restore failed */
>
> /* Console keyboard events.
> * Note: KBD_KEYCODE is always sent before KBD_UNBOUND_KEYCODE, KBD_UNICODE and
> Index: linux-2.6/kernel/power/disk.c
> ===================================================================
> --- linux-2.6.orig/kernel/power/disk.c
> +++ linux-2.6/kernel/power/disk.c
> @@ -489,6 +489,10 @@ static int software_resume(void)
> goto Unlock;
> }
>
> + error = pm_notifier_call_chain(PM_RESTORE_PREPARE);
> + if (error)
> + goto Exit;
> +
> error = create_basic_memory_bitmaps();
> if (error)
> goto Finish;
> @@ -512,6 +516,8 @@ static int software_resume(void)
> Done:
> free_basic_memory_bitmaps();
> Finish:
> + pm_notifier_call_chain(PM_POST_RESTORE);
> + Exit:
> atomic_inc(&snapshot_device_available);
> /* For success case, the suspend path will release the lock */
> Unlock:
> Index: linux-2.6/kernel/power/user.c
> ===================================================================
> --- linux-2.6.orig/kernel/power/user.c
> +++ linux-2.6/kernel/power/user.c
> @@ -67,6 +67,7 @@ atomic_t snapshot_device_available = ATO
> static int snapshot_open(struct inode *inode, struct file *filp)
> {
> struct snapshot_data *data;
> + int error;
>
> if (!atomic_add_unless(&snapshot_device_available, -1, 0))
> return -EBUSY;
> @@ -87,9 +88,15 @@ static int snapshot_open(struct inode *i
> data->swap = swsusp_resume_device ?
> swap_type_of(swsusp_resume_device, 0, NULL) : -1;
> data->mode = O_RDONLY;
> + error = pm_notifier_call_chain(PM_RESTORE_PREPARE);
> } else {
> data->swap = -1;
> data->mode = O_WRONLY;
> + error = pm_notifier_call_chain(PM_HIBERNATION_PREPARE);
> + }
> + if (error) {
> + atomic_inc(&snapshot_device_available);
> + return error;
> }
> data->frozen = 0;
> data->ready = 0;
> @@ -111,6 +118,8 @@ static int snapshot_release(struct inode
> thaw_processes();
> mutex_unlock(&pm_mutex);
> }
> + pm_notifier_call_chain(data->mode == O_WRONLY ?
> + PM_POST_HIBERNATION : PM_POST_RESTORE);
> atomic_inc(&snapshot_device_available);
> return 0;
> }
> @@ -174,18 +183,13 @@ static int snapshot_ioctl(struct inode *
> if (data->frozen)
> break;
> mutex_lock(&pm_mutex);
> - error = pm_notifier_call_chain(PM_HIBERNATION_PREPARE);
> - if (!error) {
> - printk("Syncing filesystems ... ");
> - sys_sync();
> - printk("done.\n");
> -
> - error = freeze_processes();
> - if (error)
> - thaw_processes();
> - }
> + printk("Syncing filesystems ... ");
> + sys_sync();
> + printk("done.\n");
> +
> + error = freeze_processes();
> if (error)
> - pm_notifier_call_chain(PM_POST_HIBERNATION);
> + thaw_processes();
> mutex_unlock(&pm_mutex);
> if (!error)
> data->frozen = 1;
> @@ -196,7 +200,6 @@ static int snapshot_ioctl(struct inode *
> break;
> mutex_lock(&pm_mutex);
> thaw_processes();
> - pm_notifier_call_chain(PM_POST_HIBERNATION);
> mutex_unlock(&pm_mutex);
> data->frozen = 0;
> break;
> -
> To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
> the body of a message to majordomo@xxxxxxxxxxxxxxx
> More majordomo info at http://vger.kernel.org/majordomo-info.html
> Please read the FAQ at http://www.tux.org/lkml/
>
>



--
"Premature optimization is the root of all evil." - Donald Knuth
-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/