| /* | 
 |  * drivers/base/interface.c - common driverfs interface that's exported to | 
 |  * 	the world for all devices. | 
 |  * | 
 |  * Copyright (c) 2002-3 Patrick Mochel | 
 |  * Copyright (c) 2002-3 Open Source Development Labs | 
 |  * | 
 |  * This file is released under the GPLv2 | 
 |  * | 
 |  */ | 
 |  | 
 | #include <linux/device.h> | 
 | #include <linux/err.h> | 
 | #include <linux/stat.h> | 
 | #include <linux/string.h> | 
 |  | 
 | /** | 
 |  *	detach_state - control the default power state for the device. | 
 |  * | 
 |  *	This is the state the device enters when it's driver module is | 
 |  *	unloaded. The value is an unsigned integer, in the range of 0-4. | 
 |  *	'0' indicates 'On', so no action will be taken when the driver is | 
 |  *	unloaded. This is the default behavior. | 
 |  *	'4' indicates 'Off', meaning the driver core will call the driver's | 
 |  *	shutdown method to quiesce the device. | 
 |  *	1-3 indicate a low-power state for the device to enter via the | 
 |  *	driver's suspend method. | 
 |  */ | 
 |  | 
 | static ssize_t detach_show(struct device * dev, char * buf) | 
 | { | 
 | 	return sprintf(buf, "%u\n", dev->detach_state); | 
 | } | 
 |  | 
 | static ssize_t detach_store(struct device * dev, const char * buf, size_t n) | 
 | { | 
 | 	u32 state; | 
 | 	state = simple_strtoul(buf, NULL, 10); | 
 | 	if (state > 4) | 
 | 		return -EINVAL; | 
 | 	dev->detach_state = state; | 
 | 	return n; | 
 | } | 
 |  | 
 | static DEVICE_ATTR(detach_state, 0644, detach_show, detach_store); | 
 |  | 
 |  | 
 | struct attribute * dev_default_attrs[] = { | 
 | 	&dev_attr_detach_state.attr, | 
 | 	NULL, | 
 | }; |