summaryrefslogtreecommitdiffstats
path: root/fs/sysfs/group.c
diff options
context:
space:
mode:
authorGreg Kroah-Hartman <gregkh@suse.de>2008-02-07 11:58:54 -0500
committerGreg Kroah-Hartman <gregkh@suse.de>2008-02-07 11:31:46 -0800
commit969affd276dec81a35a5ad10d4e05e62e93b380b (patch)
treea6a6bb9f2b658838f09ad28d58211252a5e7db6f /fs/sysfs/group.c
parent7d640c4a5b36c4733460065db1554da924044511 (diff)
downloadlinux-stable-969affd276dec81a35a5ad10d4e05e62e93b380b.tar.gz
linux-stable-969affd276dec81a35a5ad10d4e05e62e93b380b.tar.bz2
linux-stable-969affd276dec81a35a5ad10d4e05e62e93b380b.zip
sysfs: remove BUG_ON() from sysfs_remove_group()
It's possible that the caller of sysfs_remove_group messed up and passed in an attribute group that was not really registered to this kobject. But don't panic for such a foolish error, spit out a warning about what happened, and continue on our way safely. Cc: Roland Dreier <rdreier@cisco.com> Cc: Tejun Heo <htejun@gmail.com> Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
Diffstat (limited to 'fs/sysfs/group.c')
-rw-r--r--fs/sysfs/group.c7
1 files changed, 6 insertions, 1 deletions
diff --git a/fs/sysfs/group.c b/fs/sysfs/group.c
index 0871c3dadce1..477904915032 100644
--- a/fs/sysfs/group.c
+++ b/fs/sysfs/group.c
@@ -77,7 +77,12 @@ void sysfs_remove_group(struct kobject * kobj,
if (grp->name) {
sd = sysfs_get_dirent(dir_sd, grp->name);
- BUG_ON(!sd);
+ if (!sd) {
+ printk(KERN_WARNING "sysfs group %p not found for "
+ "kobject '%s'\n", grp, kobject_name(kobj));
+ WARN_ON(!sd);
+ return;
+ }
} else
sd = sysfs_get(dir_sd);