Linux-2.6.12-rc2
[linux-2.6/kvm.git] / drivers / base / power / resume.c
blobf8f5055754d65b3fd1c41348dade1e1092b9bc5e
1 /*
2 * resume.c - Functions for waking devices up.
4 * Copyright (c) 2003 Patrick Mochel
5 * Copyright (c) 2003 Open Source Development Labs
7 * This file is released under the GPLv2
9 */
11 #include <linux/device.h>
12 #include "power.h"
14 extern int sysdev_resume(void);
17 /**
18 * resume_device - Restore state for one device.
19 * @dev: Device.
23 int resume_device(struct device * dev)
25 if (dev->bus && dev->bus->resume)
26 return dev->bus->resume(dev);
27 return 0;
32 void dpm_resume(void)
34 down(&dpm_list_sem);
35 while(!list_empty(&dpm_off)) {
36 struct list_head * entry = dpm_off.next;
37 struct device * dev = to_device(entry);
39 get_device(dev);
40 list_del_init(entry);
41 list_add_tail(entry, &dpm_active);
43 up(&dpm_list_sem);
44 if (!dev->power.prev_state)
45 resume_device(dev);
46 down(&dpm_list_sem);
47 put_device(dev);
49 up(&dpm_list_sem);
53 /**
54 * device_resume - Restore state of each device in system.
56 * Walk the dpm_off list, remove each entry, resume the device,
57 * then add it to the dpm_active list.
60 void device_resume(void)
62 down(&dpm_sem);
63 dpm_resume();
64 up(&dpm_sem);
67 EXPORT_SYMBOL_GPL(device_resume);
70 /**
71 * device_power_up_irq - Power on some devices.
73 * Walk the dpm_off_irq list and power each device up. This
74 * is used for devices that required they be powered down with
75 * interrupts disabled. As devices are powered on, they are moved to
76 * the dpm_suspended list.
78 * Interrupts must be disabled when calling this.
81 void dpm_power_up(void)
83 while(!list_empty(&dpm_off_irq)) {
84 struct list_head * entry = dpm_off_irq.next;
85 struct device * dev = to_device(entry);
87 get_device(dev);
88 list_del_init(entry);
89 list_add_tail(entry, &dpm_active);
90 resume_device(dev);
91 put_device(dev);
96 /**
97 * device_pm_power_up - Turn on all devices that need special attention.
99 * Power on system devices then devices that required we shut them down
100 * with interrupts disabled.
101 * Called with interrupts disabled.
104 void device_power_up(void)
106 sysdev_resume();
107 dpm_power_up();
110 EXPORT_SYMBOL_GPL(device_power_up);