aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/pcmcia/socket_sysfs.c
diff options
context:
space:
mode:
authorDominik Brodowski <linux@dominikbrodowski.net>2006-01-10 13:19:37 -0500
committerDominik Brodowski <linux@dominikbrodowski.net>2006-01-12 12:48:16 -0500
commitdb1019ca0548b263989bc98900eaf15107e533ad (patch)
tree19c399ec6345d8e91103b3b3625238f914246364 /drivers/pcmcia/socket_sysfs.c
parentf542ff6dd1a444c85cc245ac40aef5f703e48674 (diff)
[PATCH] pcmcia: runtime powermanagement interface
With the "power/state" sysfs interface being deprecated, make another one available which is compatible to what was discussed on the linux PM mailinglist. Signed-off-by: Dominik Brodowski <linux@dominikbrodowski.net>
Diffstat (limited to 'drivers/pcmcia/socket_sysfs.c')
-rw-r--r--drivers/pcmcia/socket_sysfs.c25
1 files changed, 25 insertions, 0 deletions
diff --git a/drivers/pcmcia/socket_sysfs.c b/drivers/pcmcia/socket_sysfs.c
index 7a7744662d54..5ab1cdef7c48 100644
--- a/drivers/pcmcia/socket_sysfs.c
+++ b/drivers/pcmcia/socket_sysfs.c
@@ -98,6 +98,30 @@ static ssize_t pccard_store_insert(struct class_device *dev, const char *buf, si
98} 98}
99static CLASS_DEVICE_ATTR(card_insert, 0200, NULL, pccard_store_insert); 99static CLASS_DEVICE_ATTR(card_insert, 0200, NULL, pccard_store_insert);
100 100
101
102static ssize_t pccard_show_card_pm_state(struct class_device *dev, char *buf)
103{
104 struct pcmcia_socket *s = to_socket(dev);
105 return sprintf(buf, "%s\n", s->state & SOCKET_SUSPEND ? "off" : "on");
106}
107
108static ssize_t pccard_store_card_pm_state(struct class_device *dev, const char *buf, size_t count)
109{
110 ssize_t ret = -EINVAL;
111 struct pcmcia_socket *s = to_socket(dev);
112
113 if (!count)
114 return -EINVAL;
115
116 if (!(s->state & SOCKET_SUSPEND) && !strncmp(buf, "off", 3))
117 ret = pcmcia_suspend_card(s);
118 else if ((s->state & SOCKET_SUSPEND) && !strncmp(buf, "on", 2))
119 ret = pcmcia_resume_card(s);
120
121 return ret ? -ENODEV : count;
122}
123static CLASS_DEVICE_ATTR(card_pm_state, 0644, pccard_show_card_pm_state, pccard_store_card_pm_state);
124
101static ssize_t pccard_store_eject(struct class_device *dev, const char *buf, size_t count) 125static ssize_t pccard_store_eject(struct class_device *dev, const char *buf, size_t count)
102{ 126{
103 ssize_t ret; 127 ssize_t ret;
@@ -320,6 +344,7 @@ static struct class_device_attribute *pccard_socket_attributes[] = {
320 &class_device_attr_card_vpp, 344 &class_device_attr_card_vpp,
321 &class_device_attr_card_vcc, 345 &class_device_attr_card_vcc,
322 &class_device_attr_card_insert, 346 &class_device_attr_card_insert,
347 &class_device_attr_card_pm_state,
323 &class_device_attr_card_eject, 348 &class_device_attr_card_eject,
324 &class_device_attr_card_irq_mask, 349 &class_device_attr_card_irq_mask,
325 &class_device_attr_available_resources_setup_done, 350 &class_device_attr_available_resources_setup_done,