aboutsummaryrefslogtreecommitdiffstats
path: root/include/linux/pm_wakeup.h
diff options
context:
space:
mode:
authorGlenn Elliott <gelliott@cs.unc.edu>2012-03-04 19:47:13 -0500
committerGlenn Elliott <gelliott@cs.unc.edu>2012-03-04 19:47:13 -0500
commitc71c03bda1e86c9d5198c5d83f712e695c4f2a1e (patch)
treeecb166cb3e2b7e2adb3b5e292245fefd23381ac8 /include/linux/pm_wakeup.h
parentea53c912f8a86a8567697115b6a0d8152beee5c8 (diff)
parent6a00f206debf8a5c8899055726ad127dbeeed098 (diff)
Merge branch 'mpi-master' into wip-k-fmlpwip-k-fmlp
Conflicts: litmus/sched_cedf.c
Diffstat (limited to 'include/linux/pm_wakeup.h')
-rw-r--r--include/linux/pm_wakeup.h122
1 files changed, 99 insertions, 23 deletions
diff --git a/include/linux/pm_wakeup.h b/include/linux/pm_wakeup.h
index 76aca48722ae..a32da962d693 100644
--- a/include/linux/pm_wakeup.h
+++ b/include/linux/pm_wakeup.h
@@ -2,6 +2,7 @@
2 * pm_wakeup.h - Power management wakeup interface 2 * pm_wakeup.h - Power management wakeup interface
3 * 3 *
4 * Copyright (C) 2008 Alan Stern 4 * Copyright (C) 2008 Alan Stern
5 * Copyright (C) 2010 Rafael J. Wysocki, Novell Inc.
5 * 6 *
6 * This program is free software; you can redistribute it and/or modify 7 * This program is free software; you can redistribute it and/or modify
7 * it under the terms of the GNU General Public License as published by 8 * it under the terms of the GNU General Public License as published by
@@ -27,19 +28,71 @@
27 28
28#include <linux/types.h> 29#include <linux/types.h>
29 30
30#ifdef CONFIG_PM 31/**
31 32 * struct wakeup_source - Representation of wakeup sources
32/* Changes to device_may_wakeup take effect on the next pm state change.
33 * 33 *
34 * By default, most devices should leave wakeup disabled. The exceptions 34 * @total_time: Total time this wakeup source has been active.
35 * are devices that everyone expects to be wakeup sources: keyboards, 35 * @max_time: Maximum time this wakeup source has been continuously active.
36 * power buttons, possibly network interfaces, etc. 36 * @last_time: Monotonic clock when the wakeup source's was activated last time.
37 * @event_count: Number of signaled wakeup events.
38 * @active_count: Number of times the wakeup sorce was activated.
39 * @relax_count: Number of times the wakeup sorce was deactivated.
40 * @hit_count: Number of times the wakeup sorce might abort system suspend.
41 * @active: Status of the wakeup source.
42 */
43struct wakeup_source {
44 char *name;
45 struct list_head entry;
46 spinlock_t lock;
47 struct timer_list timer;
48 unsigned long timer_expires;
49 ktime_t total_time;
50 ktime_t max_time;
51 ktime_t last_time;
52 unsigned long event_count;
53 unsigned long active_count;
54 unsigned long relax_count;
55 unsigned long hit_count;
56 unsigned int active:1;
57};
58
59#ifdef CONFIG_PM_SLEEP
60
61/*
62 * Changes to device_may_wakeup take effect on the next pm state change.
37 */ 63 */
38static inline void device_init_wakeup(struct device *dev, bool val) 64
65static inline bool device_can_wakeup(struct device *dev)
39{ 66{
40 dev->power.can_wakeup = dev->power.should_wakeup = val; 67 return dev->power.can_wakeup;
41} 68}
42 69
70static inline bool device_may_wakeup(struct device *dev)
71{
72 return dev->power.can_wakeup && !!dev->power.wakeup;
73}
74
75/* drivers/base/power/wakeup.c */
76extern struct wakeup_source *wakeup_source_create(const char *name);
77extern void wakeup_source_destroy(struct wakeup_source *ws);
78extern void wakeup_source_add(struct wakeup_source *ws);
79extern void wakeup_source_remove(struct wakeup_source *ws);
80extern struct wakeup_source *wakeup_source_register(const char *name);
81extern void wakeup_source_unregister(struct wakeup_source *ws);
82extern int device_wakeup_enable(struct device *dev);
83extern int device_wakeup_disable(struct device *dev);
84extern void device_set_wakeup_capable(struct device *dev, bool capable);
85extern int device_init_wakeup(struct device *dev, bool val);
86extern int device_set_wakeup_enable(struct device *dev, bool enable);
87extern void __pm_stay_awake(struct wakeup_source *ws);
88extern void pm_stay_awake(struct device *dev);
89extern void __pm_relax(struct wakeup_source *ws);
90extern void pm_relax(struct device *dev);
91extern void __pm_wakeup_event(struct wakeup_source *ws, unsigned int msec);
92extern void pm_wakeup_event(struct device *dev, unsigned int msec);
93
94#else /* !CONFIG_PM_SLEEP */
95
43static inline void device_set_wakeup_capable(struct device *dev, bool capable) 96static inline void device_set_wakeup_capable(struct device *dev, bool capable)
44{ 97{
45 dev->power.can_wakeup = capable; 98 dev->power.can_wakeup = capable;
@@ -50,43 +103,66 @@ static inline bool device_can_wakeup(struct device *dev)
50 return dev->power.can_wakeup; 103 return dev->power.can_wakeup;
51} 104}
52 105
53static inline void device_set_wakeup_enable(struct device *dev, bool enable) 106static inline struct wakeup_source *wakeup_source_create(const char *name)
54{ 107{
55 dev->power.should_wakeup = enable; 108 return NULL;
56} 109}
57 110
58static inline bool device_may_wakeup(struct device *dev) 111static inline void wakeup_source_destroy(struct wakeup_source *ws) {}
112
113static inline void wakeup_source_add(struct wakeup_source *ws) {}
114
115static inline void wakeup_source_remove(struct wakeup_source *ws) {}
116
117static inline struct wakeup_source *wakeup_source_register(const char *name)
59{ 118{
60 return dev->power.can_wakeup && dev->power.should_wakeup; 119 return NULL;
61} 120}
62 121
63#else /* !CONFIG_PM */ 122static inline void wakeup_source_unregister(struct wakeup_source *ws) {}
64 123
65/* For some reason the following routines work even without CONFIG_PM */ 124static inline int device_wakeup_enable(struct device *dev)
66static inline void device_init_wakeup(struct device *dev, bool val)
67{ 125{
68 dev->power.can_wakeup = val; 126 dev->power.should_wakeup = true;
127 return 0;
69} 128}
70 129
71static inline void device_set_wakeup_capable(struct device *dev, bool capable) 130static inline int device_wakeup_disable(struct device *dev)
72{ 131{
73 dev->power.can_wakeup = capable; 132 dev->power.should_wakeup = false;
133 return 0;
74} 134}
75 135
76static inline bool device_can_wakeup(struct device *dev) 136static inline int device_set_wakeup_enable(struct device *dev, bool enable)
77{ 137{
78 return dev->power.can_wakeup; 138 dev->power.should_wakeup = enable;
139 return 0;
79} 140}
80 141
81static inline void device_set_wakeup_enable(struct device *dev, bool enable) 142static inline int device_init_wakeup(struct device *dev, bool val)
82{ 143{
144 device_set_wakeup_capable(dev, val);
145 device_set_wakeup_enable(dev, val);
146 return 0;
83} 147}
84 148
85static inline bool device_may_wakeup(struct device *dev) 149static inline bool device_may_wakeup(struct device *dev)
86{ 150{
87 return false; 151 return dev->power.can_wakeup && dev->power.should_wakeup;
88} 152}
89 153
90#endif /* !CONFIG_PM */ 154static inline void __pm_stay_awake(struct wakeup_source *ws) {}
155
156static inline void pm_stay_awake(struct device *dev) {}
157
158static inline void __pm_relax(struct wakeup_source *ws) {}
159
160static inline void pm_relax(struct device *dev) {}
161
162static inline void __pm_wakeup_event(struct wakeup_source *ws, unsigned int msec) {}
163
164static inline void pm_wakeup_event(struct device *dev, unsigned int msec) {}
165
166#endif /* !CONFIG_PM_SLEEP */
91 167
92#endif /* _LINUX_PM_WAKEUP_H */ 168#endif /* _LINUX_PM_WAKEUP_H */