diff options
author | Greg Kroah-Hartman <gregkh@suse.de> | 2008-02-07 17:58:54 +0100 |
---|---|---|
committer | Greg Kroah-Hartman <gregkh@suse.de> | 2008-02-07 20:31:46 +0100 |
commit | 969affd276dec81a35a5ad10d4e05e62e93b380b (patch) | |
tree | a6a6bb9f2b658838f09ad28d58211252a5e7db6f /fs/sysfs/group.c | |
parent | Driver core: Revert "Fix Firmware class name collision" (diff) | |
download | linux-969affd276dec81a35a5ad10d4e05e62e93b380b.tar.xz linux-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 '')
-rw-r--r-- | fs/sysfs/group.c | 7 |
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); |