diff options
author | Greg Kroah-Hartman <gregkh@suse.de> | 2006-09-19 09:39:19 -0700 |
---|---|---|
committer | Greg Kroah-Hartman <gregkh@suse.de> | 2006-09-25 21:08:39 -0700 |
commit | 2589f1887b0bf9f08ec3d7f3c5705ccb7c628076 (patch) | |
tree | 172fcb59cf5a8b500aafe905a690ea4b439277c4 /drivers | |
parent | c47ed219ba81632595e9f02e27318151fec16c9e (diff) | |
download | kernel-crypto-2589f1887b0bf9f08ec3d7f3c5705ccb7c628076.tar.gz kernel-crypto-2589f1887b0bf9f08ec3d7f3c5705ccb7c628076.tar.xz kernel-crypto-2589f1887b0bf9f08ec3d7f3c5705ccb7c628076.zip |
Driver core: add ability for devices to create and remove bin files
Makes it easier for devices to create and remove binary attribute files
so they don't have to call directly into sysfs. This is needed to help
with the conversion from struct class_device to struct device.
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
Diffstat (limited to 'drivers')
-rw-r--r-- | drivers/base/core.c | 26 |
1 files changed, 26 insertions, 0 deletions
diff --git a/drivers/base/core.c b/drivers/base/core.c index 1d3d3582fcc..bc9f35c8169 100644 --- a/drivers/base/core.c +++ b/drivers/base/core.c @@ -319,6 +319,32 @@ void device_remove_file(struct device * dev, struct device_attribute * attr) } } +/** + * device_create_bin_file - create sysfs binary attribute file for device. + * @dev: device. + * @attr: device binary attribute descriptor. + */ +int device_create_bin_file(struct device *dev, struct bin_attribute *attr) +{ + int error = -EINVAL; + if (dev) + error = sysfs_create_bin_file(&dev->kobj, attr); + return error; +} +EXPORT_SYMBOL_GPL(device_create_bin_file); + +/** + * device_remove_bin_file - remove sysfs binary attribute file + * @dev: device. + * @attr: device binary attribute descriptor. + */ +void device_remove_bin_file(struct device *dev, struct bin_attribute *attr) +{ + if (dev) + sysfs_remove_bin_file(&dev->kobj, attr); +} +EXPORT_SYMBOL_GPL(device_remove_bin_file); + static void klist_children_get(struct klist_node *n) { struct device *dev = container_of(n, struct device, knode_parent); |